-
Notifications
You must be signed in to change notification settings - Fork 26
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
Integrate on boundary to compute length scale quantities #1094
Draft
unalmis
wants to merge
47
commits into
master
Choose a base branch
from
integrate_on_boundary
base: master
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
+386
−218
Conversation
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
| benchmark_name | dt(%) | dt(s) | t_new(s) | t_old(s) |
| -------------------------------------- | ---------------------- | ---------------------- | ---------------------- | ---------------------- |
test_build_transform_fft_lowres | +2.47 +/- 5.96 | +1.33e-02 +/- 3.22e-02 | 5.54e-01 +/- 2.9e-02 | 5.40e-01 +/- 1.4e-02 |
test_equilibrium_init_medres | -1.34 +/- 4.36 | -5.70e-02 +/- 1.85e-01 | 4.19e+00 +/- 1.4e-01 | 4.24e+00 +/- 1.2e-01 |
test_equilibrium_init_highres | +0.14 +/- 1.77 | +7.77e-03 +/- 9.67e-02 | 5.49e+00 +/- 7.2e-02 | 5.48e+00 +/- 6.4e-02 |
test_objective_compile_dshape_current | -0.05 +/- 2.47 | -2.08e-03 +/- 9.88e-02 | 3.99e+00 +/- 3.8e-02 | 3.99e+00 +/- 9.1e-02 |
test_objective_compute_dshape_current | +1.24 +/- 2.04 | +6.37e-05 +/- 1.05e-04 | 5.19e-03 +/- 9.6e-05 | 5.13e-03 +/- 4.0e-05 |
test_objective_jac_dshape_current | +3.48 +/- 10.19 | +1.51e-03 +/- 4.43e-03 | 4.50e-02 +/- 3.1e-03 | 4.35e-02 +/- 3.2e-03 |
test_perturb_2 | -0.02 +/- 3.70 | -4.31e-03 +/- 7.39e-01 | 1.99e+01 +/- 5.8e-01 | 2.00e+01 +/- 4.6e-01 |
test_proximal_freeb_jac | +0.11 +/- 1.04 | +8.31e-03 +/- 7.74e-02 | 7.43e+00 +/- 6.1e-02 | 7.43e+00 +/- 4.7e-02 |
test_solve_fixed_iter | +0.09 +/- 3.69 | +3.05e-02 +/- 1.20e+00 | 3.26e+01 +/- 1.2e+00 | 3.25e+01 +/- 1.9e-01 |
test_LinearConstraintProjection_build | +1.34 +/- 3.18 | +1.38e-01 +/- 3.29e-01 | 1.05e+01 +/- 2.4e-01 | 1.04e+01 +/- 2.2e-01 |
test_build_transform_fft_midres | +0.07 +/- 3.31 | +4.54e-04 +/- 2.04e-02 | 6.16e-01 +/- 1.2e-02 | 6.16e-01 +/- 1.6e-02 |
test_build_transform_fft_highres | -0.42 +/- 3.17 | -4.11e-03 +/- 3.12e-02 | 9.80e-01 +/- 1.6e-02 | 9.85e-01 +/- 2.7e-02 |
test_equilibrium_init_lowres | +0.98 +/- 1.87 | +3.86e-02 +/- 7.34e-02 | 3.96e+00 +/- 5.5e-02 | 3.92e+00 +/- 4.8e-02 |
test_objective_compile_atf | -0.56 +/- 1.02 | -4.65e-02 +/- 8.44e-02 | 8.19e+00 +/- 3.5e-02 | 8.24e+00 +/- 7.7e-02 |
test_objective_compute_atf | +2.37 +/- 3.45 | +3.79e-04 +/- 5.51e-04 | 1.63e-02 +/- 3.3e-04 | 1.60e-02 +/- 4.4e-04 |
test_objective_jac_atf | +2.24 +/- 2.58 | +4.43e-02 +/- 5.09e-02 | 2.02e+00 +/- 2.8e-02 | 1.98e+00 +/- 4.3e-02 |
test_perturb_1 | -0.20 +/- 1.25 | -2.94e-02 +/- 1.87e-01 | 1.50e+01 +/- 9.8e-02 | 1.50e+01 +/- 1.6e-01 |
test_proximal_jac_atf | -0.97 +/- 0.95 | -8.06e-02 +/- 7.87e-02 | 8.23e+00 +/- 6.3e-02 | 8.31e+00 +/- 4.8e-02 |
test_proximal_freeb_compute | -0.39 +/- 1.04 | -7.83e-04 +/- 2.09e-03 | 2.01e-01 +/- 1.2e-03 | 2.01e-01 +/- 1.7e-03 |
test_solve_fixed_iter_compiled | +0.36 +/- 0.98 | +7.50e-02 +/- 2.02e-01 | 2.07e+01 +/- 1.7e-01 | 2.07e+01 +/- 1.0e-01 | |
These differences are because, prior to the changes in this PR, these length scale quantities would get computed on a full resolution quadrature grid in test_compute_everything. Now thare computed on the same low resolution used in the test that is used for everything else. Not equal to tolerance rtol=1e-10, atol=1e-10 Parameterization: desc.equilibrium.equilibrium.Equilibrium. Name: A. Mismatched elements: 1 / 1 (100%) Max absolute difference: 1.63995582e-05 Max relative difference: 2.03987171e-05 x: array(0.803967) y: array(0.80395) Not equal to tolerance rtol=1e-10, atol=1e-10 Parameterization: desc.equilibrium.equilibrium.Equilibrium. Name: S. Mismatched elements: 1 / 1 (100%) Max absolute difference: 0.16850603 Max relative difference: 0.00125191 x: array(134.767312) y: array(134.598806) Not equal to tolerance rtol=1e-10, atol=1e-10 Parameterization: desc.equilibrium.equilibrium.Equilibrium. Name: A(z). Mismatched elements: 660 / 660 (100%) Max absolute difference: 0.63797977 Max relative difference: 0.80369303 x: array([0.763363, 0.763363, 0.763363, 0.763363, 0.763363, 0.763363, 0.763363, 0.763363, 0.763363, 0.763363, 0.763363, 0.763363, 0.763363, 0.763363, 0.763363, 0.763363, 0.763363, 0.763363,... y: array([0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978,... Not equal to tolerance rtol=1e-10, atol=1e-10 Parameterization: desc.equilibrium.equilibrium.Equilibrium. Name: R0. Mismatched elements: 1 / 1 (100%) Max absolute difference: 0.00011245 Max relative difference: 2.0398301e-05 x: array(5.51284) y: array(5.512953) Not equal to tolerance rtol=1e-10, atol=1e-10 Parameterization: desc.equilibrium.equilibrium.Equilibrium. Name: A(r). Mismatched elements: 594 / 660 (90%) Max absolute difference: 1.63995582e-05 Max relative difference: 2.03987171e-05 x: array([0. , 0. , 0. , 0. , 0. , 0. , 0.010291, 0.010291, 0.010291, 0.010291, 0.010291, 0.010291, 0.041077, 0.041077, 0.041077, 0.041077, 0.041077, 0.041077,... y: array([0. , 0. , 0. , 0. , 0. , 0. , 0.010291, 0.010291, 0.010291, 0.010291, 0.010291, 0.010291, 0.041077, 0.041077, 0.041077, 0.041077, 0.041077, 0.041077,... Not equal to tolerance rtol=1e-10, atol=1e-10 Parameterization: desc.equilibrium.equilibrium.Equilibrium. Name: a. Mismatched elements: 1 / 1 (100%) Max absolute difference: 5.15953253e-06 Max relative difference: 1.01993065e-05 x: array(0.505876) y: array(0.505871) Not equal to tolerance rtol=1e-10, atol=1e-10 Parameterization: desc.equilibrium.equilibrium.Equilibrium. Name: R0/a. Mismatched elements: 1 / 1 (100%) Max absolute difference: 0.00033345 Max relative difference: 3.05972954e-05 x: array(10.89761) y: array(10.897944) Not equal to tolerance rtol=1e-10, atol=1e-10 Parameterization: desc.equilibrium.equilibrium.Equilibrium. Name: a_major/a_minor. Mismatched elements: 660 / 660 (100%) Max absolute difference: 10.92082022 Max relative difference: 4.88235767 x: array([ 4.007305, 4.007305, 4.007305, 4.007305, 4.007305, 4.007305, 4.007305, 4.007305, 4.007305, 4.007305, 4.007305, 4.007305, 4.007305, 4.007305, 4.007305, 4.007305, 4.007305, 4.007305,... y: array([4.009882, 4.009882, 4.009882, 4.009882, 4.009882, 4.009882, 4.009882, 4.009882, 4.009882, 4.009882, 4.009882, 4.009882, 4.009882, 4.009882, 4.009882, 4.009882, 4.009882, 4.009882,...
Some of the master compute data changes with this commit. The changes which are not due to floating point differences or simply grid resolution differences (recall the grid used in test_compute_everything has L = 9, M=N=5 which is less than required for convergence to true integral quantities on that equilbrium) are given below: Not equal to tolerance rtol=1e-10, atol=1e-10 Parameterization: desc.equilibrium.equilibrium.Equilibrium. Name: A(z). Mismatched elements: 660 / 660 (100%) Max absolute difference: 0.6494644 Max relative difference: 0.81816076 x: array([0.792591, 0.792591, 0.792591, 0.792591, 0.792591, 0.792591, 0.792591, 0.792591, 0.792591, 0.792591, 0.792591, 0.792591, 0.792591, 0.792591, 0.792591, 0.792591, 0.792591, 0.792591,... y: array([0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978, 0.762978,... Not equal to tolerance rtol=1e-10, atol=1e-10 Parameterization: desc.equilibrium.equilibrium.Equilibrium. Name: a_major/a_minor. Mismatched elements: 660 / 660 (100%) Max absolute difference: 11.33931768 Max relative difference: 4.99527722 x: array([ 3.864152, 3.864152, 3.864152, 3.864152, 3.864152, 3.864152, 3.864152, 3.864152, 3.864152, 3.864152, 3.864152, 3.864152, 3.864152, 3.864152, 3.864152, 3.864152, 3.864152, 3.864152,... y: array([4.057173, 4.057173, 4.057173, 4.057173, 4.057173, 4.057173, 4.057173, 4.057173, 4.057173, 4.057173, 4.057173, 4.057173, 4.057173, 4.057173, 4.057173, 4.057173, 4.057173, 4.057173,... NOTE that both quanties are incorrect, because in general we cannot compute these quantities accuratly on grids that do not sample the full poloidal domain.
unalmis
added
documentation
Add documentation or better warnings etc.
bug fix
Something was fixed
and removed
bug fix
Something was fixed
labels
Jul 12, 2024
unalmis
added
P2
Medium Priority, not urgent but should be on the near-term agend
and removed
P2
Medium Priority, not urgent but should be on the near-term agend
labels
Dec 4, 2024
unalmis
added
P1
Lowest Priority, will get to eventually
and removed
P2
Medium Priority, not urgent but should be on the near-term agend
labels
Dec 7, 2024
unalmis
added
waiting for other PRs
and removed
P1
Lowest Priority, will get to eventually
labels
Dec 12, 2024
Check out this pull request on See visual diffs & provide feedback on Jupyter Notebooks. Powered by ReviewNB |
unalmis
force-pushed
the
integrate_on_boundary
branch
from
January 5, 2025 22:30
d202f7f
to
a7f233c
Compare
unalmis
force-pushed
the
integrate_on_boundary
branch
from
January 5, 2025 22:31
a7f233c
to
eb8b50c
Compare
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Labels
bug fix
Something was fixed
performance
New feature or request to make the code faster
waiting for other PRs
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This pull request is waiting on #1127 .
See #1101, in particular this comment for some of other changes.
Some quantities like the plasma volume
V
, major radiusR0
, minor radiusa
etc. can be computed via stoke's theorem on the last closed flux surface. This pull request modifies the compute functions to default to such an integration on the boundary rather than throughout the volume so that the length scale quantities can be computed accurately on grids other thanQuadratureGrid
. This lets us avoid building transforms forQuadratureGrid
in objectives, saving memory.Also, might have some improvements in general