Spaces:
Sleeping
Sleeping
Commit
·
0b9e421
1
Parent(s):
b896bd3
Move all deprecated functions to deprecated.py
Browse files- pysr/__init__.py +2 -1
- pysr/deprecated.py +54 -0
- pysr/feynman_problems.py +1 -1
- pysr/sr.py +0 -42
pysr/__init__.py
CHANGED
|
@@ -1,9 +1,10 @@
|
|
| 1 |
from . import sklearn_monkeypatch
|
|
|
|
| 2 |
from .export_jax import sympy2jax
|
| 3 |
from .export_torch import sympy2torch
|
| 4 |
from .feynman_problems import FeynmanProblem, Problem
|
| 5 |
from .julia_helpers import install
|
| 6 |
-
from .sr import PySRRegressor
|
| 7 |
from .version import __version__
|
| 8 |
|
| 9 |
__all__ = [
|
|
|
|
| 1 |
from . import sklearn_monkeypatch
|
| 2 |
+
from .deprecated import best, best_callable, best_row, best_tex, pysr
|
| 3 |
from .export_jax import sympy2jax
|
| 4 |
from .export_torch import sympy2torch
|
| 5 |
from .feynman_problems import FeynmanProblem, Problem
|
| 6 |
from .julia_helpers import install
|
| 7 |
+
from .sr import PySRRegressor
|
| 8 |
from .version import __version__
|
| 9 |
|
| 10 |
__all__ = [
|
pysr/deprecated.py
CHANGED
|
@@ -1,4 +1,58 @@
|
|
| 1 |
"""Various functions to deprecate features."""
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 2 |
|
| 3 |
|
| 4 |
def make_deprecated_kwargs_for_pysr_regressor():
|
|
|
|
| 1 |
"""Various functions to deprecate features."""
|
| 2 |
+
import warnings
|
| 3 |
+
|
| 4 |
+
|
| 5 |
+
def pysr(X, y, weights=None, **kwargs): # pragma: no cover
|
| 6 |
+
from .sr import PySRRegressor
|
| 7 |
+
|
| 8 |
+
warnings.warn(
|
| 9 |
+
"Calling `pysr` is deprecated. "
|
| 10 |
+
"Please use `model = PySRRegressor(**params); "
|
| 11 |
+
"model.fit(X, y)` going forward.",
|
| 12 |
+
FutureWarning,
|
| 13 |
+
)
|
| 14 |
+
model = PySRRegressor(**kwargs)
|
| 15 |
+
model.fit(X, y, weights=weights)
|
| 16 |
+
return model.equations_
|
| 17 |
+
|
| 18 |
+
|
| 19 |
+
def best(*args, **kwargs): # pragma: no cover
|
| 20 |
+
raise NotImplementedError(
|
| 21 |
+
"`best` has been deprecated. "
|
| 22 |
+
"Please use the `PySRRegressor` interface. "
|
| 23 |
+
"After fitting, you can return `.sympy()` "
|
| 24 |
+
"to get the sympy representation "
|
| 25 |
+
"of the best equation."
|
| 26 |
+
)
|
| 27 |
+
|
| 28 |
+
|
| 29 |
+
def best_row(*args, **kwargs): # pragma: no cover
|
| 30 |
+
raise NotImplementedError(
|
| 31 |
+
"`best_row` has been deprecated. "
|
| 32 |
+
"Please use the `PySRRegressor` interface. "
|
| 33 |
+
"After fitting, you can run `print(model)` to view the best equation, "
|
| 34 |
+
"or "
|
| 35 |
+
"`model.get_best()` to return the best equation's "
|
| 36 |
+
"row in `model.equations_`."
|
| 37 |
+
)
|
| 38 |
+
|
| 39 |
+
|
| 40 |
+
def best_tex(*args, **kwargs): # pragma: no cover
|
| 41 |
+
raise NotImplementedError(
|
| 42 |
+
"`best_tex` has been deprecated. "
|
| 43 |
+
"Please use the `PySRRegressor` interface. "
|
| 44 |
+
"After fitting, you can return `.latex()` to "
|
| 45 |
+
"get the sympy representation "
|
| 46 |
+
"of the best equation."
|
| 47 |
+
)
|
| 48 |
+
|
| 49 |
+
|
| 50 |
+
def best_callable(*args, **kwargs): # pragma: no cover
|
| 51 |
+
raise NotImplementedError(
|
| 52 |
+
"`best_callable` has been deprecated. Please use the `PySRRegressor` "
|
| 53 |
+
"interface. After fitting, you can use "
|
| 54 |
+
"`.predict(X)` to use the best callable."
|
| 55 |
+
)
|
| 56 |
|
| 57 |
|
| 58 |
def make_deprecated_kwargs_for_pysr_regressor():
|
pysr/feynman_problems.py
CHANGED
|
@@ -4,7 +4,7 @@ from pathlib import Path
|
|
| 4 |
|
| 5 |
import numpy as np
|
| 6 |
|
| 7 |
-
from .
|
| 8 |
|
| 9 |
PKG_DIR = Path(__file__).parents[1]
|
| 10 |
FEYNMAN_DATASET = PKG_DIR / "datasets" / "FeynmanEquations.csv"
|
|
|
|
| 4 |
|
| 5 |
import numpy as np
|
| 6 |
|
| 7 |
+
from .deprecated import best, pysr
|
| 8 |
|
| 9 |
PKG_DIR = Path(__file__).parents[1]
|
| 10 |
FEYNMAN_DATASET = PKG_DIR / "datasets" / "FeynmanEquations.csv"
|
pysr/sr.py
CHANGED
|
@@ -48,17 +48,6 @@ Main = None # TODO: Rename to more descriptive name like "julia_runtime"
|
|
| 48 |
already_ran = False
|
| 49 |
|
| 50 |
|
| 51 |
-
def pysr(X, y, weights=None, **kwargs): # pragma: no cover
|
| 52 |
-
warnings.warn(
|
| 53 |
-
"Calling `pysr` is deprecated. "
|
| 54 |
-
"Please use `model = PySRRegressor(**params); model.fit(X, y)` going forward.",
|
| 55 |
-
FutureWarning,
|
| 56 |
-
)
|
| 57 |
-
model = PySRRegressor(**kwargs)
|
| 58 |
-
model.fit(X, y, weights=weights)
|
| 59 |
-
return model.equations_
|
| 60 |
-
|
| 61 |
-
|
| 62 |
def _process_constraints(binary_operators, unary_operators, constraints):
|
| 63 |
constraints = constraints.copy()
|
| 64 |
for op in unary_operators:
|
|
@@ -181,37 +170,6 @@ def _check_assertions(
|
|
| 181 |
)
|
| 182 |
|
| 183 |
|
| 184 |
-
def best(*args, **kwargs): # pragma: no cover
|
| 185 |
-
raise NotImplementedError(
|
| 186 |
-
"`best` has been deprecated. Please use the `PySRRegressor` interface. "
|
| 187 |
-
"After fitting, you can return `.sympy()` to get the sympy representation "
|
| 188 |
-
"of the best equation."
|
| 189 |
-
)
|
| 190 |
-
|
| 191 |
-
|
| 192 |
-
def best_row(*args, **kwargs): # pragma: no cover
|
| 193 |
-
raise NotImplementedError(
|
| 194 |
-
"`best_row` has been deprecated. Please use the `PySRRegressor` interface. "
|
| 195 |
-
"After fitting, you can run `print(model)` to view the best equation, or "
|
| 196 |
-
"`model.get_best()` to return the best equation's row in `model.equations_`."
|
| 197 |
-
)
|
| 198 |
-
|
| 199 |
-
|
| 200 |
-
def best_tex(*args, **kwargs): # pragma: no cover
|
| 201 |
-
raise NotImplementedError(
|
| 202 |
-
"`best_tex` has been deprecated. Please use the `PySRRegressor` interface. "
|
| 203 |
-
"After fitting, you can return `.latex()` to get the sympy representation "
|
| 204 |
-
"of the best equation."
|
| 205 |
-
)
|
| 206 |
-
|
| 207 |
-
|
| 208 |
-
def best_callable(*args, **kwargs): # pragma: no cover
|
| 209 |
-
raise NotImplementedError(
|
| 210 |
-
"`best_callable` has been deprecated. Please use the `PySRRegressor` "
|
| 211 |
-
"interface. After fitting, you can use `.predict(X)` to use the best callable."
|
| 212 |
-
)
|
| 213 |
-
|
| 214 |
-
|
| 215 |
# Class validation constants
|
| 216 |
VALID_OPTIMIZER_ALGORITHMS = ["NelderMead", "BFGS"]
|
| 217 |
|
|
|
|
| 48 |
already_ran = False
|
| 49 |
|
| 50 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 51 |
def _process_constraints(binary_operators, unary_operators, constraints):
|
| 52 |
constraints = constraints.copy()
|
| 53 |
for op in unary_operators:
|
|
|
|
| 170 |
)
|
| 171 |
|
| 172 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 173 |
# Class validation constants
|
| 174 |
VALID_OPTIMIZER_ALGORITHMS = ["NelderMead", "BFGS"]
|
| 175 |
|