-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: better jax
- Loading branch information
Showing
20 changed files
with
1,426 additions
and
846 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,43 +1,34 @@ | ||
# spotter | ||
|
||
```{image} _static/spotter.jpg | ||
:width: 400px | ||
:align: center | ||
``` | ||
*Approximate forward models of fluxes and spectra time-series of non-uniform stars.* | ||
|
||
--- | ||
|
||
*spotter* is a Python package to produce forward models of non-uniform stars spectra. It uses the [HEALPix](https://healpix.sourceforge.io/) subdivision scheme and is powered by the high-performance numerical package [JAX](https://jax.readthedocs.io/en/latest/notebooks/quickstart.html), enabling its use on GPUs. | ||
```{warning} | ||
Use at your own risk as the code is completely untested and its API subject to change. | ||
``` | ||
|
||
**Note** | ||
*spotter* uses the [HEALPix](https://healpix.sourceforge.io/) subdivision scheme and is powered by the high-performance numerical package [JAX](https://jax.readthedocs.io/en/latest/notebooks/quickstart.html), enabling its use on GPUs. | ||
|
||
In its beta version, *spotter* is mainly developed to estimate transmission spectra stellar contamination from stellar rotational light curves. Use at your own risk as the code is completely untested and its API subject to change. | ||
|
||
## Features | ||
|
||
- Adjustable surface resolution <span style="color:grey">- *in beta*</span> | ||
- Small-scale surface features modeling (e.g. beyond limitations of [starry]()) <span style="color:grey">- *in beta*</span> | ||
- Small-scale surface features (e.g. beyond limitations of [starry]()) <span style="color:grey"> | ||
- Modeling of any active regions with their limb laws (e.g. limb-brightened faculae) | ||
- GPU compatible <span style="color:grey">- *in beta*</span> | ||
- GPU compatible <span style="color:grey"> | ||
- Possibility to input any stellar spectra model | ||
|
||
```{toctree} | ||
:maxdepth: 1 | ||
:caption: Get started | ||
api | ||
``` | ||
|
||
```{toctree} | ||
:maxdepth: 1 | ||
:caption: Examples | ||
notebooks/simple_example | ||
notebooks/experiments | ||
notebooks/amplitude_constraints.ipynb | ||
notebooks/introduction | ||
``` | ||
|
||
```{toctree} | ||
:maxdepth: 1 | ||
:caption: Notes | ||
:caption: Reference | ||
notebooks/rotation.ipynb | ||
api | ||
``` |
Large diffs are not rendered by default.
Oops, something went wrong.
Large diffs are not rendered by default.
Oops, something went wrong.
Large diffs are not rendered by default.
Oops, something went wrong.
Large diffs are not rendered by default.
Oops, something went wrong.
Large diffs are not rendered by default.
Oops, something went wrong.
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,34 +1,86 @@ | ||
import healpy as hp | ||
import jax | ||
import jax.numpy as jnp | ||
|
||
jax.config.update("jax_enable_x64", True) | ||
|
||
|
||
def hemisphere_mask(thetas): | ||
def mask(phase): | ||
a = (phase + jnp.pi / 2) % (2 * jnp.pi) | ||
b = (phase - jnp.pi / 2) % (2 * jnp.pi) | ||
mask_1 = jnp.logical_and((thetas < a), (thetas > b)) | ||
mask_2 = jnp.logical_or((thetas > b), (thetas < a)) | ||
cond1 = a > phase % (2 * jnp.pi) | ||
cond2 = b < phase % (2 * jnp.pi) | ||
cond = cond1 * cond2 | ||
return jnp.where(cond, mask_1, mask_2) | ||
def hemisphere_mask(theta, phase): | ||
theta = jnp.atleast_1d(theta) | ||
a = (phase + jnp.pi / 2) % (2 * jnp.pi) | ||
b = (phase - jnp.pi / 2) % (2 * jnp.pi) | ||
mask_1 = jnp.logical_and((theta < a), (theta > b)) | ||
mask_2 = jnp.logical_or((theta > b), (theta < a)) | ||
cond1 = a > phase % (2 * jnp.pi) | ||
cond2 = b < phase % (2 * jnp.pi) | ||
cond = cond1 * cond2 | ||
return jnp.where(cond, mask_1, mask_2) | ||
|
||
return mask | ||
|
||
def polynomial_limb_darkening(theta, phi, u=None, phase=0.0): | ||
if u is None: | ||
return 1.0 | ||
else: | ||
theta = jnp.atleast_1d(theta) | ||
phi = jnp.atleast_1d(phi) | ||
u = jnp.atleast_1d(u) | ||
z = jnp.sin(phi) * jnp.cos(theta - phase) | ||
terms = jnp.array([un * (1 - z) ** (n + 1) for n, un in enumerate(u)]) | ||
return 1 - jnp.sum(terms, axis=theta.ndim - 1) | ||
|
||
def polynomial_limb_darkening(thetas, phis): | ||
def ld(u, phase): | ||
z = jnp.sin(phis) * jnp.cos(thetas - phase) | ||
terms = jnp.array([u * (1 - z) ** (n + 1) for n, u in enumerate(u)]) | ||
return 1 - jnp.sum(terms, 0) | ||
|
||
return ld | ||
def projected_area(theta, phi, phase): | ||
return jnp.cos(theta - phase) * jnp.sin(phi) | ||
|
||
|
||
def projected_area(thetas, phis): | ||
def area(phase): | ||
return jnp.cos(thetas - phase) * jnp.sin(phis) | ||
def covering_fraction(x): | ||
return jnp.mean(x > 0) | ||
|
||
return area | ||
|
||
def distance(thetas, phis): | ||
|
||
p1 = phis - jnp.pi / 2 | ||
t1 = thetas | ||
sp1 = jnp.sin(p1) | ||
cp1 = jnp.cos(p1) | ||
|
||
def fun(theta0, phi0): | ||
# https://en.wikipedia.org/wiki/Great-circle_distance | ||
# Vincenty formula | ||
p2 = theta0 - jnp.pi / 2 | ||
t2 = phi0 | ||
dl = jnp.abs((t1 - t2)) | ||
|
||
sp2 = jnp.sin(p2) | ||
cp2 = jnp.cos(p2) | ||
cdl = jnp.cos(dl) | ||
sdl = jnp.sin(dl) | ||
|
||
a = (cp2 * sdl) ** 2 + (cp1 * sp2 - sp1 * cp2 * cdl) ** 2 | ||
b = sp1 * sp2 + cp1 * cp2 * cdl | ||
return jnp.arctan2(jnp.sqrt(a), b) | ||
|
||
return fun | ||
|
||
|
||
def query_disk(thetas, phis): | ||
|
||
distance_fn = distance(thetas, phis) | ||
|
||
def fun(theta, phi, radius): | ||
d = distance_fn(theta, phi) | ||
return jnp.array(d <= radius, dtype=jnp.int8) | ||
|
||
return fun | ||
|
||
|
||
def smooth_spot(thetas, phis): | ||
|
||
distance_fn = distance(thetas, phis) | ||
|
||
def fun(theta, phi, r, c): | ||
A = c * distance_fn(theta, phi) / (2 * r) | ||
C = c / 2 | ||
return 0.5 * jnp.tanh(C - A) + 0.5 * jnp.tanh(C + A) | ||
|
||
return fun |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.