Spaces:
Sleeping
Sleeping
| import numpy as np | |
| from pysr import pysr, sympy2jax | |
| from jax import numpy as jnp | |
| from jax import random | |
| from jax import grad | |
| import sympy | |
| X = np.random.randn(100, 5) | |
| print("Test 1 - defaults; simple linear relation") | |
| y = X[:, 0] | |
| equations = pysr(X, y, | |
| niterations=10, | |
| user_input=False) | |
| print(equations) | |
| assert equations.iloc[-1]['MSE'] < 1e-4 | |
| print("Test 2 - test custom operator") | |
| y = X[:, 0]**2 | |
| equations = pysr(X, y, | |
| unary_operators=["sq(x) = x^2"], binary_operators=["plus"], | |
| extra_sympy_mappings={'square': lambda x: x**2}, | |
| niterations=10, | |
| user_input=False) | |
| print(equations) | |
| assert equations.iloc[-1]['MSE'] < 1e-4 | |
| X = np.random.randn(100, 1) | |
| y = X[:, 0] + 3.0 | |
| print("Test 3 - empty operator list, and single dimension input") | |
| equations = pysr(X, y, | |
| unary_operators=[], binary_operators=["plus"], | |
| niterations=10, | |
| user_input=False) | |
| print(equations) | |
| assert equations.iloc[-1]['MSE'] < 1e-4 | |
| print("Test 4 - text JAX export") | |
| x, y, z = sympy.symbols('x y z') | |
| cosx = 1.0 * sympy.cos(x) + y | |
| key = random.PRNGKey(0) | |
| X = random.normal(key, (1000, 2)) | |
| true = 1.0 * jnp.cos(X[:, 0]) + X[:, 1] | |
| f, params = sympy2jax(cosx, [x]) | |
| assert jnp.all(jnp.isclose(f(X, params), true)).item() | |