Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Bounce averaging #854

Merged
merged 355 commits into from
Sep 3, 2024
Merged
Show file tree
Hide file tree
Changes from 8 commits
Commits
Show all changes
355 commits
Select commit Hold shift + click to select a range
a34764e
Merge branch 'master' into bounce
rahulgaur104 Apr 10, 2024
b3ee158
increasing rtol because quantities that cross zero can have a huge rtol
rahulgaur104 Apr 10, 2024
6f77af3
Merge branch 'bounce' of https://github.com/PlasmaControl/DESC into b…
rahulgaur104 Apr 10, 2024
53142c9
adding pytest.warning
rahulgaur104 Apr 10, 2024
f04523d
override_grid=False fixes coefficient jumps. Should add this to the r…
rahulgaur104 Apr 10, 2024
3515abf
Merge branch 'master' into bounce
rahulgaur104 Apr 10, 2024
530bcbb
Change API for bounce integral to support integrating...
unalmis Apr 11, 2024
f2a6107
Simplify shape broadc in docstring
unalmis Apr 11, 2024
88efe51
Make sure tests_bounce_average_drifts test runs with new API change
unalmis Apr 11, 2024
e8b360a
Fix bug in test where bounce points should be computed from normalize…
unalmis Apr 11, 2024
fc2b59b
Merge branch 'master' into bounce
unalmis Apr 11, 2024
d08b360
Add quadrature test
unalmis Apr 12, 2024
cc20d0b
Add unit change of variables for clari
unalmis Apr 12, 2024
a5b1793
fixing the bounce averaged drifts test
rahulgaur104 Apr 12, 2024
fad449c
Remove test frgrid on meshgrid
unalmis Apr 12, 2024
7d001e0
Use modified tanh sinh quadrature
unalmis Apr 12, 2024
77ddaa4
Remove old root finding bounce point code
unalmis Apr 12, 2024
12ee415
Fix typo in comment
unalmis Apr 12, 2024
fa7a617
Use general automorphism for quadrature and fix change of variable bug
unalmis Apr 13, 2024
990c96a
Switch to sin automorphism to suppress singularity, add lebgauss test
unalmis Apr 13, 2024
ff328c6
Fix typos
unalmis Apr 13, 2024
28b2b19
Improve automorphism test, remove unused code, update requirements
unalmis Apr 14, 2024
5a1bdc4
Fix test failure due to comment change
unalmis Apr 14, 2024
69c5134
Choose better default knots for bounce integral
unalmis Apr 14, 2024
c39a073
Make bounce integration more modular so that custom grid can be used
unalmis Apr 14, 2024
e681c22
Make variables in bounce_integral.py private
unalmis Apr 14, 2024
df41869
Use map_coords in desc_grid_from_field_line_coords now that it uses
unalmis Apr 16, 2024
df5198b
bounce average test modified, scipy's incomplete elliptic integrals s…
rahulgaur104 Apr 18, 2024
85ec3a5
Merge branch 'master' into bounce
rahulgaur104 Apr 18, 2024
b6a0286
Do quadrature instead of using brokescipy.special functions
unalmis Apr 19, 2024
0d74884
small changes to the bounce average test
rahulgaur104 Apr 19, 2024
ae0a6f8
more changes to the bounce average test; most of the numerical values…
rahulgaur104 Apr 19, 2024
d05482c
adding responses to questions
rahulgaur104 Apr 19, 2024
b4604f6
bavg_drift_num has the same dimension as pitch now :)
rahulgaur104 Apr 19, 2024
8666648
Add helper function to compute epsilon effective
unalmis Apr 21, 2024
77c88bf
Make sure nan won't appear in gradient and improve composite linspace…
unalmis Apr 21, 2024
bf6cb73
Simplify composite_linspace function
unalmis Apr 21, 2024
a460ca1
A bug has been caught, but is not yet squashed!
unalmis Apr 21, 2024
df16d7d
Fix interpolation error induced nan propogation
unalmis Apr 22, 2024
ed8dc4f
Add methods for debugging bounce point inversion
unalmis Apr 22, 2024
37f2dd0
Think the splines are failing.
unalmis Apr 22, 2024
130f816
Squash floating point bugs that cause bounce points to not be detecte…
unalmis Apr 23, 2024
64e8b46
Fix all floating point error induced issues for detecting bounce points!
unalmis Apr 23, 2024
9d53735
Improve test_bounce_averaged_drifts
unalmis Apr 23, 2024
33c1249
Clean up bounce_average_drift test
unalmis Apr 23, 2024
81aa30a
Make it simpler to change spline method in test_bounce_averaged_drifts
unalmis Apr 24, 2024
26a9727
Move function definition to stop circular import
unalmis Apr 24, 2024
599eff6
Rename some variables to avoid confusion
unalmis Apr 24, 2024
43cad50
Remove override_grid from eq.compute in bounce_integral.
unalmis Apr 24, 2024
ab9ba6b
Reorder arguments into guard function for consistency
unalmis Apr 24, 2024
22fee12
Use same resolution in quadrature in bounce average drift test
unalmis Apr 24, 2024
cb9c55c
Fix floating point error in automorphism sin
unalmis Apr 25, 2024
9069695
floating point error resistant quadratic root
unalmis Apr 25, 2024
57e2d32
Use clip instead of shifting in arcsin automorph
unalmis Apr 25, 2024
49e87d5
API changes to be able to compute effective ripple in compute_funs
unalmis Apr 25, 2024
c7ec435
Remove override_grid=False, doesn't seem to matter anymore
unalmis Apr 25, 2024
772ed2a
fix bugs in bounce average drift test
unalmis Apr 26, 2024
9767f07
Add back testing assertions to analytic expressions
unalmis Apr 26, 2024
025f09d
Add methods to plot interpolated integrand.
unalmis Apr 27, 2024
74840d5
Merge branch 'master' into bounce
unalmis Apr 27, 2024
4cca3c1
Fix bad merge
unalmis Apr 27, 2024
f303a6e
Add back override_grid=False.
unalmis Apr 27, 2024
4a457c0
corrected errors in the analytical integrals, analytical and numerica…
rahulgaur104 Apr 27, 2024
d6deb24
correcting k2; it's incorrect in Hegna's paper
rahulgaur104 Apr 27, 2024
87f5c2d
replacing dPdrho with alpha_MHD terms; will take a look again later.
rahulgaur104 Apr 27, 2024
5431e0c
adding b dot grad theta in the analytical denominator
rahulgaur104 Apr 27, 2024
767e74a
adding gradpar_theta_analytic = b dot grad theta_PEST for the correct…
rahulgaur104 Apr 28, 2024
a449715
Fix the fourth integral in the bounce average test and add numerical …
unalmis Apr 28, 2024
3a4a384
Make changes to get_extrema to make computing eps_eff easier
unalmis Apr 28, 2024
03754ab
Make sure test_bounce_average_drifts computes things on correct grid
unalmis Apr 28, 2024
8b1d066
Make sure _compute_field_line recomputes field line quantities
unalmis Apr 28, 2024
b508b54
Working now!
unalmis Apr 29, 2024
6dc4a1b
Clean up some code and add image comparison test for drift
unalmis Apr 29, 2024
05465ef
Fix bug with recomputing quantities on incorrect grid
unalmis Apr 29, 2024
c1b6792
Regenerate baseline image for test_drift with pip matplotlib not conda
unalmis Apr 29, 2024
ab74a17
Remove extraneous details from image_comparison test plot in bounce_d…
unalmis Apr 29, 2024
427e5de
Merge branch 'master' into bounce
unalmis Apr 29, 2024
5361c3f
Merge branch 'eq_compute_bug' into bounce
unalmis Apr 29, 2024
22106cc
Add non-batched option to save memory when computing eps_eff
unalmis May 1, 2024
0f82588
Set default batched option to true
unalmis May 1, 2024
a657222
Reduce memory usage in interpolate
unalmis May 1, 2024
fe9da7d
Merge branch 'master' into bounce
rahulgaur104 May 1, 2024
cb2b57f
Simplify bounce quad looped algorithm transposing
unalmis May 1, 2024
31dbb5e
found a sneaky sqrt(2); agreement looks better now :)
rahulgaur104 May 2, 2024
ef86002
forgot to add the sqrt(2) + adding low-order drift expressions for c…
rahulgaur104 May 2, 2024
b5f3c26
removing last pitch points because the analytical integral is not clo…
rahulgaur104 May 2, 2024
c56c7e0
Reduce resolution and remove plotting test since numerical comparison…
unalmis May 2, 2024
29662c4
Merge branch 'master' into bounce
unalmis May 2, 2024
b02be9f
Merge branch 'eq_compute_bug' into bounce
unalmis May 2, 2024
889eb62
Reduce resolution, add back image test, switch default quadrature
unalmis May 2, 2024
fb9cede
Clean up orthax import
unalmis May 2, 2024
71cae5d
Generalize vmap to work with in_axes!=0
unalmis May 2, 2024
7f9eb37
Reduce resolution where possible, increase resolution until convergen…
unalmis May 3, 2024
2aaa35b
Merge branch 'master' into bounce
unalmis May 3, 2024
2c20bb5
Remove changes to grid spacing as that is done in #985
unalmis May 3, 2024
8114551
Make derivative suppression option available
unalmis May 4, 2024
5ef6e95
Tighten tolerance in test after trying out preiciosn things with mpmath
unalmis May 5, 2024
5c4da4e
Merge branch 'master' into bounce and fix stuff that broke from grid …
unalmis May 9, 2024
334562f
Merge branch 'master' into bounce
unalmis May 21, 2024
2279a04
Merge branch 'fieldline_compute' into bounce
unalmis May 21, 2024
68d855b
Merge branch 'fieldline_compute' into bounce
unalmis May 21, 2024
f4710c3
Modify create meshgrid for new grid attributes
unalmis May 21, 2024
d437a1d
Merge branch 'fieldline_compute' into bounce
unalmis May 22, 2024
4961cae
Use source grid attributes in desc_grid_from_field_line_coords
unalmis May 22, 2024
32c6bd2
Merge branch 'fieldline_compute' into bounce
unalmis May 23, 2024
f919bcc
Pass in quadrature points to bounce integral instead of function
unalmis May 26, 2024
7c7a1a6
Merge branch 'fieldline_compute' into bounce
unalmis May 26, 2024
f105ec3
Change keyword argument to batch from batched
unalmis May 28, 2024
1d8609d
Remove sort option from get_extrema
unalmis May 28, 2024
67a26c4
Merge branch 'fieldline_compute' into bounce
unalmis May 30, 2024
db33416
Move things from #1003 into #854
unalmis May 30, 2024
d5a00c8
Make sure dℓ parameterizes the distance along the field line in meter…
unalmis May 30, 2024
6bbaca5
Add g^pa magnetic axis limit
unalmis May 30, 2024
711f734
Remove confusing paranthesis
unalmis May 30, 2024
09a9d18
Merge branch 'fieldline_compute' into bounce
unalmis Jun 1, 2024
8c667bc
Update things after last merge
unalmis Jun 1, 2024
a93b88e
Add get_pitch utility method
unalmis Jun 2, 2024
a05d50c
Merge branch 'fieldline_compute' into bounce
unalmis Jun 2, 2024
9ba02bb
Fix assert statement for shape in get_pitch
unalmis Jun 2, 2024
7a85e87
Merge branch 'fieldline_compute' into bounce
unalmis Jun 3, 2024
61a8c3d
Fix use of rtz_grid() after merge with other branch
unalmis Jun 3, 2024
8518cee
Merge branch 'fieldline_compute' into bounce
unalmis Jun 3, 2024
11f8fe2
Merge branch 'fieldline_compute' into bounce
unalmis Jun 3, 2024
6711df0
Update interpax requirement to 0.3.2 for differentiable spline
unalmis Jun 4, 2024
8077d4e
Avoid complex arithmetic when computing roots to fix bug in effective…
unalmis Jun 10, 2024
b14426a
Clean up some documentation and docstrings
unalmis Jun 11, 2024
deb12d6
Fix type hinting and reorganize order of methods
unalmis Jun 12, 2024
782274d
Merge branch 'fieldline_compute' into bounce
unalmis Jun 17, 2024
4333973
Fix sign of B^zeta and B_z_ra
unalmis Jun 18, 2024
d51aa16
Partially undo previous commit
unalmis Jun 18, 2024
2a5e4b7
Merge branch 'fieldline_compute' into bounce
rahulgaur104 Jun 20, 2024
02afa2c
No more nan in effective ripple gradient
unalmis Jun 22, 2024
1d58463
Merge branch 'fieldline_compute' into bounce
unalmis Jun 22, 2024
3b5e9f9
Add test for finite nonzero derivative
unalmis Jun 22, 2024
ff46b4d
Merge branch 'fieldline_compute' into bounce
unalmis Jun 25, 2024
390e782
move changes from ripple to bounce (make some functions private)
unalmis Jun 25, 2024
8c4d28f
Merge branch 'fieldline_compute' into bounce
unalmis Jun 28, 2024
fd11816
Fix imports after merge
unalmis Jun 28, 2024
4b91a5e
Merge branch 'fieldline_compute' into bounce
unalmis Jun 28, 2024
b9de417
Remove unneeded compute funs
unalmis Jul 1, 2024
670ad66
Change label per Rory's request
unalmis Jul 2, 2024
f07cdae
Fix label
unalmis Jul 2, 2024
3322e94
Remove g^pa per review request
unalmis Jul 2, 2024
c10a59a
Remove old code
unalmis Jul 2, 2024
d1981b2
Merge branch 'fieldline_compute' into bounce
unalmis Jul 5, 2024
718ceb3
Merge branch 'fieldline_compute' into bounce
unalmis Jul 10, 2024
74ff461
Merge branch 'fieldline_compute' into bounce
unalmis Jul 11, 2024
b00ddc5
Merging fieldline_compute branch
unalmis Jul 11, 2024
ba92b47
Merge branch 'master' into bounce
unalmis Jul 20, 2024
e25b4ad
Merge branch 'clebsh_basis' into bounce
unalmis Jul 20, 2024
12219af
Merge branch 'clebsh_basis' into bounce
unalmis Jul 20, 2024
311425b
Clean up desc.backend and add eigh_tridiagonal
unalmis Jul 23, 2024
d921447
Add Guass-Lobatto quadrature for effective ripple, and speed up bounc…
unalmis Jul 23, 2024
6ed9d92
skeleton for fourier bounce integrals
unalmis Jul 24, 2024
24d75e0
Merge branch 'clebsh_basis' into bounce
unalmis Jul 24, 2024
8a20570
Merge branch 'bounce' into ku/fourier_bounce
unalmis Jul 24, 2024
30b7c1b
Move more efficient bounce points computation from fourier bounce to …
unalmis Jul 24, 2024
263930d
Fix dynamic jaxpr shape error induced from previous commit
unalmis Jul 25, 2024
dc1cc86
Merge branch 'bounce' into ku/fourier_bounce
unalmis Jul 25, 2024
95ed8a8
Add num_wells parameter to reduce size of bounce points matrix by fac…
unalmis Jul 25, 2024
1992e15
Specify num_wells expclitly in test to make sure it doesnt affect aut…
unalmis Jul 25, 2024
f316d89
Merge branch 'clebsh_basis' into bounce
unalmis Jul 25, 2024
142c86d
Merge branch 'bounce' into ku/fourier_bounce
unalmis Jul 25, 2024
e6b38bf
Clean up docstring comments
unalmis Jul 26, 2024
6acab01
Merge branch 'bounce' into ku/fourier_bounce
unalmis Jul 26, 2024
ad30aa0
Add remaining fourier bounce methods
unalmis Jul 31, 2024
8349019
Merge branch 'ku/map_coordinates_clebsch' into ku/fourier_bounce
unalmis Jul 31, 2024
689d3be
Merge branch 'ku/map_coordinates_clebsch' into ku/fourier_bounce
unalmis Aug 6, 2024
e5b535b
Merge branch 'clebsh_basis' into bounce
unalmis Aug 7, 2024
8c9c531
Downstream changes needed to implement Nemov's Gamma_c from Gamma_c b…
unalmis Aug 7, 2024
4ef040d
WIP: Commit before merge to save progress
unalmis Aug 7, 2024
289aba2
Merge branch 'bounce' into ku/fourier_bounce
unalmis Aug 7, 2024
e582143
Merge branch 'master' into bounce
unalmis Aug 9, 2024
89a03ee
Merge branch 'bounce' into ku/fourier_bounce
unalmis Aug 9, 2024
239db74
Merge branch 'master' into bounce
f0uriest Aug 9, 2024
a277a19
Merge branch 'master' into bounce
f0uriest Aug 9, 2024
16f5791
Merge branch 'master' into bounce
unalmis Aug 10, 2024
04eb8ab
Merge branch 'bounce' into ku/fourier_bounce
unalmis Aug 10, 2024
f7469e8
merging master test_compute_everyting fails! @unalmis
rahulgaur104 Aug 14, 2024
a8f8e82
Merge remote-tracking branch 'origin' into bounce
unalmis Aug 14, 2024
c914728
Merge commit 'f7469e8' into bounce
unalmis Aug 14, 2024
62219b3
Adding tests part 1
unalmis Aug 15, 2024
6571b8e
Merge branch 'master' into bounce
unalmis Aug 15, 2024
672b163
Making progress on tests
unalmis Aug 15, 2024
ff991cc
Replace einsum with vandermode matrix
unalmis Aug 15, 2024
744540a
Adding tests part 2
unalmis Aug 16, 2024
07eb550
Merge branch 'master' into bounce
rahulgaur104 Aug 18, 2024
ade0a5e
Merge branch 'bounce' into ku/fourier_bounce
unalmis Aug 18, 2024
4658415
Merge branch 'master' into bounce
dpanici Aug 20, 2024
8197f71
Force push with lease to avoid diverging branch with remote due to co…
unalmis Aug 20, 2024
d3f8f6b
Merge branch 'bounce' into ku/fourier_bounce
unalmis Aug 20, 2024
714a8f0
Merge branch 'master' into bounce
unalmis Aug 20, 2024
b6ee838
Merge branch 'bounce' into ku/fourier_bounce
unalmis Aug 21, 2024
8b64e0d
Move integration algorithms to integrals subfolder
unalmis Aug 21, 2024
7f993bf
Merge branch 'integrals' into ku/fourier_bounce
unalmis Aug 21, 2024
14ca329
Merge branch 'integrals' into ku/fourier_bounce
unalmis Aug 21, 2024
7c2d7c2
Simplify some broadcasting add short comments explaining theory
unalmis Aug 21, 2024
ae28995
Merge branch 'integrals' into ku/fourier_bounce
unalmis Aug 22, 2024
3e8a7bf
Merge branch 'integrals' into ku/fourier_bounce
unalmis Aug 22, 2024
c8bb170
Merge branch 'integrals' into ku/fourier_bounce
unalmis Aug 22, 2024
8094209
Make compatible with new meshgrid structure on master
unalmis Aug 22, 2024
2724c5b
Making progress on tests. All the bounce pointand splines
unalmis Aug 22, 2024
7007e9e
Merge branch 'master' into ku/fourier_bounce
unalmis Aug 22, 2024
c683bb8
Fix comment
unalmis Aug 22, 2024
32d64e9
Commit before I start modifying bounce_integral.py
unalmis Aug 25, 2024
819bff2
Major refactoring of bounce integrals
unalmis Aug 25, 2024
baa907d
Fix some stuff from previous commit
unalmis Aug 25, 2024
4b9ff2d
Merge branch 'master' into ku/fourier_bounce
unalmis Aug 25, 2024
cee3da7
Change interp2argmin to expect already reshaped data to be consistent…
unalmis Aug 25, 2024
a1f249c
Containerize and refactor basis used in bounce integrals
unalmis Aug 25, 2024
b7cc0e3
Merge branch 'master' into ku/fourier_bounce
unalmis Aug 25, 2024
540d062
Review algorithm. Fix documentation of integrals and use better names…
unalmis Aug 26, 2024
04f87a3
Debugging fourier bounce stuff
unalmis Aug 26, 2024
1a24a43
Fix bug in Fourier bounce with interpolation of b_sup_z
unalmis Aug 26, 2024
b6ade4c
Preparing merge into bounce branch
unalmis Aug 27, 2024
5fa3758
fix docstrings
unalmis Aug 27, 2024
1180cf9
Merge branch 'master' into bounce
unalmis Aug 27, 2024
f7350e7
Merge branch 'ku/fourier_bounce' into bounce
unalmis Aug 27, 2024
594cbd8
Remove stuff that should be in ku/fourier_bounce that came here after…
unalmis Aug 27, 2024
74e229f
Remove code that should be in fourier_bounce branch
unalmis Aug 27, 2024
dedc01b
Improve tests and fix failing test
unalmis Aug 27, 2024
bc03ab4
Merge branch 'master' into bounce
unalmis Aug 27, 2024
3e57eca
Clean up tests and API
unalmis Aug 27, 2024
3f479bb
Merge branch 'master' into bounce
unalmis Aug 27, 2024
6297d14
Merge branch 'master' into bounce
unalmis Aug 28, 2024
62d553b
Fix plotting bug from recent commits and address review comments part 1
unalmis Aug 28, 2024
afdd826
Merge branch 'master' into bounce
unalmis Aug 28, 2024
90e3596
Merge branch 'master' into bounce
unalmis Aug 28, 2024
5653376
Resolves #1228 on pull request #854
unalmis Aug 28, 2024
add9aaf
Fix claim for number of wells in an unoptimized stellarator
unalmis Aug 28, 2024
b17e513
Add description to test requested by Rory
unalmis Aug 28, 2024
e4dcd2e
Clarify test as requested by @f0uriest
unalmis Aug 29, 2024
1c1fa96
Make Bounce1D pytree and ioable and ensure eigh_tridiagonal is revers…
unalmis Aug 29, 2024
45b7c7a
Use more efficient vectorization
unalmis Aug 29, 2024
03ff0b1
Make super useful plotting function public and super user-friendly
unalmis Aug 29, 2024
6896586
Merge branch 'master' into bounce
unalmis Aug 29, 2024
deff086
Increase tolerance for plotting test
unalmis Aug 29, 2024
8edc317
Finishing touch clean up some docstrings
unalmis Aug 30, 2024
75c13fd
Make pitch optional argument for plot function
unalmis Aug 30, 2024
446c0b7
Address review comments and fix regression in batch argument from re…
unalmis Aug 30, 2024
239e441
Increase coverage
unalmis Aug 30, 2024
8376d03
Make broadcasting simpler for end user
unalmis Sep 1, 2024
2b6e9b6
Merge branch 'master' into bounce
f0uriest Sep 2, 2024
c531a82
Merge branch 'master' into bounce
rahulgaur104 Sep 2, 2024
e39dc14
Pull down changes from ripple branch
unalmis Sep 2, 2024
eb04894
Merge commit 'c531a82' into bounce
unalmis Sep 2, 2024
08e4257
Merge branch 'bounce' into bounce_pitch_shape
unalmis Sep 2, 2024
1436035
Swap vectorization order in bounce integrals (#1242)
unalmis Sep 3, 2024
138f90c
Merge branch 'master' into bounce
unalmis Sep 3, 2024
917ad1c
Tweak documentation as requested in pull request review
unalmis Sep 3, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions desc/backend.py
Original file line number Diff line number Diff line change
Expand Up @@ -599,6 +599,10 @@ def bincount(x, weights=None, minlength=None, length=None):
"""Same as np.bincount but with a dummy parameter to match jnp.bincount API."""
return np.bincount(x, weights, minlength)

def repeat(a, repeats, axis=None, total_repeat_length=None):
"""Same as np.repeat but with a dummy parameter to match jnp.repeat API."""
return np.repeat(a, repeats, axis)

def custom_jvp(fun, *args, **kwargs):
"""Dummy function for custom_jvp without JAX."""
fun.defjvp = lambda *args, **kwargs: None
Expand Down
20 changes: 20 additions & 0 deletions desc/compute/_basis_vectors.py
Original file line number Diff line number Diff line change
Expand Up @@ -504,6 +504,26 @@ def _e_sup_theta(params, transforms, profiles, data, **kwargs):
return data


@register_compute_fun(
name="e^theta_PEST",
label="\\mathbf{e}^{\\theta_{PEST}}",
units="m^{-1}",
units_long="inverse meters",
description="Contravariant straight field line (PEST) poloidal basis vector",
dim=3,
params=[],
transforms={},
profiles=[],
coordinates="rtz",
data=["e_rho", "e_phi", "sqrt(g)_PEST"],
)
def _e_sup_theta_PEST(params, transforms, profiles, data, **kwargs):
data["e^theta_PEST"] = (
cross(data["e_phi"], data["e_rho"]).T / data["sqrt(g)_PEST"]
).T
return data


@register_compute_fun(
name="e^theta*sqrt(g)",
label="\\mathbf{e}^{\\theta} \\sqrt{g}",
Expand Down
23 changes: 23 additions & 0 deletions desc/compute/_core.py
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,29 @@ def _0(params, transforms, profiles, data, **kwargs):
return data


@register_compute_fun(
name="1",
label="1",
units="~",
units_long="None",
description="Ones",
dim=1,
params=[],
transforms={"grid": []},
profiles=[],
coordinates="rtz",
data=[],
parameterization=[
"desc.equilibrium.equilibrium.Equilibrium",
"desc.geometry.core.Surface",
"desc.geometry.core.Curve",
],
)
def _1(params, transforms, profiles, data, **kwargs):
data["1"] = jnp.ones(transforms["grid"].num_nodes)
return data


@register_compute_fun(
name="R",
label="R",
Expand Down
18 changes: 18 additions & 0 deletions desc/compute/_field.py
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,24 @@ def _B_sup_theta(params, transforms, profiles, data, **kwargs):
return data


@register_compute_fun(
name="B^theta_PEST",
label="B^{\\theta}",
units="T \\cdot m^{-1}",
units_long="Tesla / meter",
description="Contravariant straight field line (PEST) component of magnetic field",
dim=1,
params=[],
transforms={},
profiles=[],
coordinates="rtz",
data=["B", "e^theta_PEST"],
)
def _B_sup_theta_PEST(params, transforms, profiles, data, **kwargs):
data["B^theta_PEST"] = dot(data["B"], data["e^theta_PEST"])
return data


@register_compute_fun(
name="B^zeta",
label="B^{\\zeta}",
Expand Down
187 changes: 186 additions & 1 deletion desc/compute/utils.py
unalmis marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -5,10 +5,11 @@
import warnings

import numpy as np
from numpy.polynomial.chebyshev import chebgauss
from termcolor import colored

from desc.backend import cond, fori_loop, jnp, put
from desc.grid import ConcentricGrid, LinearGrid
from desc.grid import ConcentricGrid, Grid, LinearGrid, _meshgrid_expand

from .data_index import data_index

Expand Down Expand Up @@ -1325,6 +1326,190 @@
return grid.expand(mins, surface_label)


def bounce_integral(eq, lambdas, rho=None, alpha=None, resolution=20):
"""Returns a method to compute the bounce integral of any quantity.

The bounce integral is defined as F_ℓ(λ) = ∫ f(ℓ) / √(1 − λ |B|) dℓ, where
dℓ parameterizes the distance along the field line,
λ is a constant proportional to the magnetic moment over energy,
|B| is the norm of the magnetic field,
f(ℓ) is the quantity to integrate along the field line,
and the endpoints of the integration are at the bounce points.
For a particle with fixed λ, bounce points are defined to be the location
on the field line such that the particle's velocity parallel to the
magnetic field is zero, i.e. λ |B| = 1.

Parameters
----------
eq : Equilibrium
Equilibrium on which the bounce integral is defined.
lambdas : ndarray
unalmis marked this conversation as resolved.
Show resolved Hide resolved
λ values to evaluate the bounce integral at.
rho : ndarray
Unique flux surface label coordinates.
alpha : ndarray
Unique field line label coordinates over a constant rho surface.
resolution : int
Number of quadrature points used to compute the bounce integral.

Returns
-------
bi : callable
This callable method computes the bounce integral F_ℓ(λ) for every
specified field line ℓ (constant rho and alpha), for every λ value in
unalmis marked this conversation as resolved.
Show resolved Hide resolved
``lambdas``.

Examples
--------
.. code-block:: python

bi = bounce_integral(eq, lambdas)
F = bi(name)

"""
if rho is None:
rho = jnp.linspace(0, 1, 10)
if alpha is None:
alpha = jnp.linspace(0, 2 * jnp.pi, 20)

Check warning on line 1373 in desc/compute/utils.py

View check run for this annotation

Codecov / codecov/patch

desc/compute/utils.py#L1370-L1373

Added lines #L1370 - L1373 were not covered by tests
unalmis marked this conversation as resolved.
Show resolved Hide resolved

# Use Gauss-Chebyshev quadrature as the integrand blows up at integration boundary.
x, w = chebgauss(deg=resolution)

Check warning on line 1376 in desc/compute/utils.py

View check run for this annotation

Codecov / codecov/patch

desc/compute/utils.py#L1376

Added line #L1376 was not covered by tests
unalmis marked this conversation as resolved.
Show resolved Hide resolved
# TODO: Write code to compute bounce points given lambda.
# Vectorize it for multiple lambdas. Then vectorize coordinate mapping logic
# for multiple lambdas. For now, let's pretend bounce points do not depend on
# lambda so that bounce_point() returns either one or two numbers for
# endpoints of all the integrals.
bp = bounce_point(eq, lambdas)
if bp.size == 1:
zeta = -2 * bp * jnp.arcsin(x) / jnp.pi

Check warning on line 1384 in desc/compute/utils.py

View check run for this annotation

Codecov / codecov/patch

desc/compute/utils.py#L1382-L1384

Added lines #L1382 - L1384 were not covered by tests
else:
zeta = (2 * jnp.arcsin(x) / jnp.pi - 1) / 2 * (bp[1] - bp[0]) + bp[1]

Check warning on line 1386 in desc/compute/utils.py

View check run for this annotation

Codecov / codecov/patch

desc/compute/utils.py#L1386

Added line #L1386 was not covered by tests

r, a, z = jnp.meshgrid(rho, alpha, zeta, copy=False, indexing="ij")
r, a, z = r.ravel(), a.ravel(), z.ravel()

Check warning on line 1389 in desc/compute/utils.py

View check run for this annotation

Codecov / codecov/patch

desc/compute/utils.py#L1388-L1389

Added lines #L1388 - L1389 were not covered by tests
# Now we map these Clebsch-Type field-line coordinates to DESC coordinates.
# Note that the rotational transform can be computed apriori because it is a single
# variable function of rho, and the coordinate mapping does not change rho. Once
# this is known, it is simple to compute theta_PEST from alpha. Then we transform
# from straight field-line coordinates to DESC coordinates with the method
# compute_theta_coords. This is preferred over transforming from Clebsch-Type
# coordinates to DESC coordinates directly with the more general method
# map_coordinates. That method requires an initial guess to be compatible with JIT,
# and generating a reasonable initial guess requires computing the rotational
# transform to approximate theta_PEST and the poloidal stream function anyway.
# TODO: In general, Linear Grid construction is not jit compatible.
# This issue can be worked around with a specific routine for this.
lg = LinearGrid(rho=rho, M=eq.M_grid, N=eq.N_grid, NFP=eq.NFP, sym=eq.sym)
rahulgaur104 marked this conversation as resolved.
Show resolved Hide resolved
lg_data = eq.compute("iota", grid=lg)
p = "desc.equilibrium.equilibrium.Equilibrium"
data = {

Check warning on line 1405 in desc/compute/utils.py

View check run for this annotation

Codecov / codecov/patch

desc/compute/utils.py#L1402-L1405

Added lines #L1402 - L1405 were not covered by tests
d: _meshgrid_expand(lg.compress(lg_data[d]), rho.size, alpha.size, zeta.size)
for d in get_data_deps("iota", obj=p)
if data_index[p][d]["coordinates"] == "r"
}
sfl_coords = jnp.column_stack([r, (a + data["iota"] * z) % (2 * jnp.pi), z])
desc_coords = eq.compute_theta_coords(sfl_coords)
grid = Grid(desc_coords, jitable=True)
data = eq.compute(

Check warning on line 1413 in desc/compute/utils.py

View check run for this annotation

Codecov / codecov/patch

desc/compute/utils.py#L1410-L1413

Added lines #L1410 - L1413 were not covered by tests
names=["B^zeta", "|B|"], grid=grid, data=data, override_grid=False
)

def _bounce_integral(name):

Check warning on line 1417 in desc/compute/utils.py

View check run for this annotation

Codecov / codecov/patch

desc/compute/utils.py#L1417

Added line #L1417 was not covered by tests
"""Compute the bounce integral of the named quantity.

Parameters
----------
name : ndarray
Name of quantity in ``data_index`` to compute the bounce integral of.

Returns
-------
F : ndarray, shape(lambdas.size, alpha.size, rho.size)
Bounce integral evaluated at ``lambdas`` for every field line.

"""
f = eq.compute(name, grid=grid, override_grid=False, data=data)[name]

Check warning on line 1431 in desc/compute/utils.py

View check run for this annotation

Codecov / codecov/patch

desc/compute/utils.py#L1431

Added line #L1431 was not covered by tests
# If lambdas.size is large, we should loop to save memory.
F = f / (data["B^zeta"] * jnp.sqrt(1 - lambdas[:, jnp.newaxis] * data["|B|"]))
F = jnp.sum(F.reshape(lambdas.size, -1, zeta.size) * w, axis=-1)
F = F.reshape(lambdas.size, alpha.size, rho.size)
if bp.size == 1:
F *= -jnp.pi / (2 * bp[0])

Check warning on line 1437 in desc/compute/utils.py

View check run for this annotation

Codecov / codecov/patch

desc/compute/utils.py#L1433-L1437

Added lines #L1433 - L1437 were not covered by tests
else:
F *= jnp.pi / (bp[1] - bp[0])
return F

Check warning on line 1440 in desc/compute/utils.py

View check run for this annotation

Codecov / codecov/patch

desc/compute/utils.py#L1439-L1440

Added lines #L1439 - L1440 were not covered by tests

return _bounce_integral

Check warning on line 1442 in desc/compute/utils.py

View check run for this annotation

Codecov / codecov/patch

desc/compute/utils.py#L1442

Added line #L1442 was not covered by tests


def bounce_average(eq, lambdas, rho=None, alpha=None, resolution=20):
"""Returns a method to compute the bounce average of any quantity.

The bounce average is defined as
G_ℓ(λ) = (∫ g(ℓ) / √(1 − λ |B|) dℓ) / (∫ 1 / √(1 − λ |B|) dℓ), where
dℓ parameterizes the distance along the field line,
λ is a constant proportional to the magnetic moment over energy,
|B| is the norm of the magnetic field,
g(ℓ) is the quantity to integrate along the field line,
and the endpoints of the integration are at the bounce points.
For a particle with fixed λ, bounce points are defined to be the location
on the field line such that the particle's velocity parallel to the
magnetic field is zero, i.e. λ |B| = 1.

Parameters
----------
eq : Equilibrium
Equilibrium on which the bounce integral is defined.
lambdas : ndarray
λ values to evaluate the bounce integral at.
rho : ndarray
Unique flux surface label coordinates.
alpha : ndarray
Unique field line label coordinates over a constant rho surface.
resolution : int
Number of quadrature points used to compute the bounce integral.

Returns
-------
ba : callable
This callable method computes the bounce integral G_ℓ(λ) for every
specified field line ℓ (constant rho and alpha), for every λ value in
``lambdas``.

Examples
--------
.. code-block:: python

ba = bounce_average(eq, lambdas)
G = ba(name)

"""
bi = bounce_integral(eq, lambdas, rho, alpha, resolution)

Check warning on line 1487 in desc/compute/utils.py

View check run for this annotation

Codecov / codecov/patch

desc/compute/utils.py#L1487

Added line #L1487 was not covered by tests

def _bounce_average(name):

Check warning on line 1489 in desc/compute/utils.py

View check run for this annotation

Codecov / codecov/patch

desc/compute/utils.py#L1489

Added line #L1489 was not covered by tests
"""Compute the bounce average of the named quantity.

Parameters
----------
name : ndarray
Name of quantity in ``data_index`` to compute the bounce average of.

Returns
-------
G : ndarray, shape(lambdas.size, alpha.size, rho.size)
Bounce average evaluated at ``lambdas`` for every field line.

"""
return bi(name) / bi("1")

Check warning on line 1503 in desc/compute/utils.py

View check run for this annotation

Codecov / codecov/patch

desc/compute/utils.py#L1503

Added line #L1503 was not covered by tests

return _bounce_average

Check warning on line 1505 in desc/compute/utils.py

View check run for this annotation

Codecov / codecov/patch

desc/compute/utils.py#L1505

Added line #L1505 was not covered by tests


def bounce_point(eq, lambdas):
"""Todo."""
return np.array([])

Check warning on line 1510 in desc/compute/utils.py

View check run for this annotation

Codecov / codecov/patch

desc/compute/utils.py#L1510

Added line #L1510 was not covered by tests


# defines the order in which objective arguments get concatenated into the state vector
arg_order = (
"R_lmn",
Expand Down
3 changes: 1 addition & 2 deletions desc/equilibrium/coords.py
Original file line number Diff line number Diff line change
Expand Up @@ -40,8 +40,7 @@ def map_coordinates( # noqa: C901
eq : Equilibrium
Equilibrium to use
coords : ndarray, shape(k,3)
2D array of input coordinates. Each row is a different
point in space.
2D array of input coordinates. Each row is a different point in space.
inbasis, outbasis : tuple of str
Labels for input and output coordinates, eg ("R", "phi", "Z") or
("rho", "alpha", "zeta") or any combination thereof. Labels should be the
Expand Down
54 changes: 54 additions & 0 deletions desc/grid.py
Original file line number Diff line number Diff line change
Expand Up @@ -1478,3 +1478,57 @@
io = find_most_distant(io_rat, n, a, b, tol=atol, **kwargs)
rho = _find_rho(iota, io, tol=atol)
return rho, io


def _meshgrid_expand(x, rho_size, theta_size, zeta_size, surface_label="rho"):
"""Expand ``x`` by duplicating elements to match a meshgrid pattern.

It is common to construct a meshgrid in the following manner.
.. code-block:: python

# In this meshgrid, the fastest (slowest) changing coordinate is zeta (theta).
r, t, z = jnp.meshgrid(rho, theta, zeta, indexing="ij")
r, t, z = r.ravel(), t.ravel(), z.ravel()
nodes = jnp.column_stack([r, t, z])
grid = Grid(nodes, sort=False, jitable=True)

Since ``jitable=True`` was specified, the attribute ``grid.inverse_*_idx``
is not computed, which is needed for the method ``grid.expand(x)``.
On such grids, this method should be used instead.

Parameters
----------
x : ndarray
Stores the values of a surface function (constant over a surface)
for all unique surfaces of the specified label on the grid.
The length of ``x`` should match the number of unique surfaces of
the corresponding label in this grid. ``x`` should be sorted such
that x[i] corresponds to the value associated with surface_label[i].

Returns
-------
expand_x : ndarray
``x`` expanded to match the meshgrid pattern.

"""
assert surface_label in {"rho", "theta", "zeta"}, (

Check warning on line 1514 in desc/grid.py

View check run for this annotation

Codecov / codecov/patch

desc/grid.py#L1514

Added line #L1514 was not covered by tests
"These labels need not correspond to DESC coordinates. "
"They should correspond to the order the arrays were given to construct "
"the meshgrid as shown in the example code in the docstring."
)
if surface_label == "rho":
assert len(x) == rho_size
return jnp.tile(

Check warning on line 1521 in desc/grid.py

View check run for this annotation

Codecov / codecov/patch

desc/grid.py#L1519-L1521

Added lines #L1519 - L1521 were not covered by tests
jnp.repeat(x, zeta_size, total_repeat_length=rho_size * zeta_size),
theta_size,
)
if surface_label == "theta":
assert len(x) == theta_size
return jnp.repeat(

Check warning on line 1527 in desc/grid.py

View check run for this annotation

Codecov / codecov/patch

desc/grid.py#L1525-L1527

Added lines #L1525 - L1527 were not covered by tests
x,
rho_size * zeta_size,
total_repeat_length=rho_size * theta_size * zeta_size,
)
if surface_label == "zeta":
assert len(x) == zeta_size
return jnp.tile(x, rho_size * theta_size)

Check warning on line 1534 in desc/grid.py

View check run for this annotation

Codecov / codecov/patch

desc/grid.py#L1532-L1534

Added lines #L1532 - L1534 were not covered by tests
2 changes: 0 additions & 2 deletions setup.cfg
Original file line number Diff line number Diff line change
Expand Up @@ -48,8 +48,6 @@ markers=
filterwarnings=
error
ignore::pytest.PytestUnraisableExceptionWarning
ignore::RuntimeWarning:desc.compute
# Ignore division by zero warnings.
ignore:numpy.ndarray size changed:RuntimeWarning
# ignore benign Cython warnings on ndarray size
ignore::DeprecationWarning:ml_dtypes.*
Expand Down
2 changes: 2 additions & 0 deletions tests/test_axis_limits.py
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@
"curvature_k2_zeta",
"e^helical",
"e^theta",
"e^theta_PEST",
"e^theta_r",
"e^theta_t",
"e^theta_z",
Expand All @@ -64,6 +65,7 @@
}
not_implemented_limits = {
# reliant limits will be added to this set automatically
"B^theta_PEST",
"D_current",
"n_rho_z",
"|e_theta x e_zeta|_z",
Expand Down
Loading