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

[restructure/plasma] Cleanup plasma assembly #2748

Merged

Conversation

wkerzendorf
Copy link
Member

@wkerzendorf wkerzendorf commented Jul 26, 2024

another cleanup PR. Requires merging of #2675

…ace.py, transport_montecarlo_numba_interface.py, conftest.py, formal_integral.py, base.py, and macro_atom.py
@wkerzendorf wkerzendorf marked this pull request as ready for review July 30, 2024 12:27
@andrewfullard
Copy link
Contributor

Please merge master and resolve merge conflicts so I can review this

@andrewfullard andrewfullard marked this pull request as draft July 31, 2024 19:52
@tardis-bot
Copy link
Contributor

tardis-bot commented Jul 31, 2024

*beep* *bop*
Hi human,
I ran benchmarks as you asked comparing master (63eb762) and the latest commit (573b5e5).
Here are the logs produced by ASV.
Results can also be downloaded as artifacts here.

Significantly changed benchmarks:

All benchmarks:

Benchmarks that have stayed the same:

| Change   | Before [63eb7625] <master>   | After [573b5e5c]    | Ratio   | Benchmark (Parameter)                                                                                                               |
|----------|------------------------------|---------------------|---------|-------------------------------------------------------------------------------------------------------------------------------------|
|          | 3.62±0.01ms                  | 4.40±0.3ms          | ~1.22   | opacities_opacity_state.BenchmarkOpacitiesOpacityState.time_opacity_state_initialize('macroatom')                                   |
|          | 2.79±0.6μs                   | 3.39±0.5μs          | ~1.22   | transport_montecarlo_vpacket.BenchmarkMontecarloMontecarloNumbaVpacket.time_trace_bad_vpacket                                       |
|          | 51.9±20μs                    | 59.6±10μs           | ~1.15   | transport_montecarlo_interaction.BenchmarkTransportMontecarloInteraction.time_line_emission                                         |
|          | 561±200ns                    | 501±200ns           | ~0.89   | opacities_opacity.BenchmarkMontecarloMontecarloNumbaOpacities.time_compton_opacity_calculation                                      |
|          | 3.57±0.9ms                   | 2.97±0.7ms          | ~0.83   | transport_montecarlo_single_packet_loop.BenchmarkTransportMontecarloSinglePacketLoop.time_single_packet_loop                        |
|          | 735±0.6ns                    | 761±1ns             | 1.04    | transport_montecarlo_interaction.BenchmarkTransportMontecarloInteraction.time_thomson_scatter                                       |
|          | 1.69±0.01ms                  | 1.75±0ms            | 1.04    | transport_montecarlo_main_loop.BenchmarkTransportMontecarloMontecarloMainLoop.time_montecarlo_main_loop                             |
|          | 38.4±0s                      | 39.1±0.02s          | 1.02    | run_tardis.BenchmarkRunTardis.time_run_tardis                                                                                       |
|          | 30.5±0μs                     | 31.1±0.01μs         | 1.02    | transport_montecarlo_packet_trackers.BenchmarkTransportMontecarloPacketTrackers.time_generate_rpacket_tracker_list                  |
|          | 7.60±2μs                     | 7.76±2μs            | 1.02    | transport_montecarlo_vpacket.BenchmarkMontecarloMontecarloNumbaVpacket.time_trace_vpacket_volley                                    |
|          | 45.2±20μs                    | 45.8±30μs           | 1.01    | transport_montecarlo_interaction.BenchmarkTransportMontecarloInteraction.time_line_scatter                                          |
|          | 541±200ns                    | 541±200ns           | 1.00    | opacities_opacity.BenchmarkMontecarloMontecarloNumbaOpacities.time_pair_creation_opacity_calculation                                |
|          | 2.71±0.01ms                  | 2.72±0ms            | 1.00    | opacities_opacity_state.BenchmarkOpacitiesOpacityState.time_opacity_state_initialize('scatter')                                     |
|          | 1.05±0m                      | 1.05±0m             | 1.00    | run_tardis.BenchmarkRunTardis.time_run_tardis_rpacket_tracking                                                                      |
|          | 2.07±0m                      | 2.07±0m             | 1.00    | spectrum_formal_integral.BenchmarkTransportMontecarloFormalIntegral.time_FormalIntegrator_functions                                 |
|          | 63.4±0.05ms                  | 62.6±0.2ms          | 0.99    | transport_montecarlo_packet_trackers.BenchmarkTransportMontecarloPacketTrackers.time_rpacket_trackers_to_dataframe                  |
|          | 211±1ns                      | 207±0.02ns          | 0.98    | spectrum_formal_integral.BenchmarkTransportMontecarloFormalIntegral.time_intensity_black_body                                       |
|          | 20.1±4μs                     | 19.7±4μs            | 0.98    | transport_montecarlo_packet_trackers.BenchmarkTransportMontecarloPacketTrackers.time_generate_rpacket_last_interaction_tracker_list |
|          | 3.50±0.7μs                   | 3.37±0.5μs          | 0.96    | transport_montecarlo_vpacket.BenchmarkMontecarloMontecarloNumbaVpacket.time_trace_vpacket_within_shell                              |
|          | 1.52±0.3μs                   | 1.44±0.5μs          | 0.95    | transport_geometry_calculate_distances.BenchmarkTransportGeometryCalculateDistances.time_calculate_distance_line                    |
|          | 6.96±1μs                     | 6.60±1μs            | 0.95    | transport_montecarlo_vpacket.BenchmarkMontecarloMontecarloNumbaVpacket.time_trace_vpacket                                           |
|          | 2.27±2μs                     | 2.13±1μs            | 0.94    | transport_montecarlo_estimators_radfield_estimator_calcs.BenchmarkMontecarloMontecarloNumbaPacket.time_update_line_estimators       |
|          | 581±200ns                    | 541±200ns           | 0.93    | opacities_opacity.BenchmarkMontecarloMontecarloNumbaOpacities.time_photoabsorption_opacity_calculation                              |
|          | 1.25±0.01μs                  | 1.15±0μs            | 0.92    | transport_geometry_calculate_distances.BenchmarkTransportGeometryCalculateDistances.time_calculate_distance_boundary                |

If you want to see the graph of the results, you can check it here

@wkerzendorf wkerzendorf marked this pull request as ready for review August 7, 2024 00:58
Copy link

codecov bot commented Aug 7, 2024

Codecov Report

Attention: Patch coverage is 89.74359% with 20 lines in your changes missing coverage. Please review.

Project coverage is 69.32%. Comparing base (63eb762) to head (573b5e5).

Files Patch % Lines
tardis/plasma/assembly/base.py 88.76% 20 Missing ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##           master    #2748      +/-   ##
==========================================
- Coverage   70.29%   69.32%   -0.98%     
==========================================
  Files         203      205       +2     
  Lines       15255    15440     +185     
==========================================
- Hits        10724    10704      -20     
- Misses       4531     4736     +205     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

andrewfullard
andrewfullard previously approved these changes Aug 7, 2024
Copy link
Contributor

@andrewfullard andrewfullard left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good, some additional tests/docs may be nice but I know we don't usually have time for that.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is this intended to be useful documentation? Not sure what "SCRUN MAGIC" is.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'll remove it

tardis/opacities/opacity_solver.py Show resolved Hide resolved
NLTEPopulationSolverLU,
NLTEPopulationSolverRoot,
)
from tardis.plasma.properties.property_collections import (
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

For clarity, could we import property_collections as pc or something like that? This is a large file and it isn't immediately clear where the variables come from all the time

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

as I said - I'm in the process of rewriting large chunks of this.



class PlasmaSolverFactory:

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This class needs docstrings

tardis/plasma/assembly/base.py Show resolved Hide resolved
tardis/plasma/assembly/base.py Show resolved Hide resolved

"""
atomic_numbers = simulation_state.abundance.index
plasma_solver_factory = PlasmaSolverFactory(
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should the config really need to be passed twice?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this will change in the future - likely. I'm just rewriting all of it.

@Rodot-
Copy link
Contributor

Rodot- commented Aug 9, 2024

Stardis tests are also failing, should @jvshields be looped in?

@wkerzendorf
Copy link
Member Author

Stardis tests are also failing, should @jvshields be looped in?

no - @jvshields is not going to be involved until the plasma has settled.

Refactor the `PlasmaSolverFactory` class in `tardis/plasma/assembly/base.py` to improve code organization and readability. Remove unused imports and reformat the code using the black linter. Also, remove the unnecessary code block in the Jupyter notebook `docs/physics/plasma/construction_simple_plasma.ipynb`. These changes aim to enhance the maintainability and clarity of the codebase.
@andrewfullard andrewfullard merged commit 2df54e5 into tardis-sn:master Aug 12, 2024
15 of 17 checks passed
@wkerzendorf wkerzendorf deleted the restructure/assemble_plasma_cleanup branch August 12, 2024 20:32
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants