-
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
Fix objective.compile
in Benchmarks
#1483
base: master
Are you sure you want to change the base?
Conversation
| benchmark_name | dt(%) | dt(s) | t_new(s) | t_old(s) |
| -------------------------------------- | ---------------------- | ---------------------- | ---------------------- | ---------------------- |
test_build_transform_fft_lowres | -5.37 +/- 3.56 | -3.12e-02 +/- 2.07e-02 | 5.50e-01 +/- 1.4e-02 | 5.82e-01 +/- 1.5e-02 |
test_equilibrium_init_medres | -3.86 +/- 3.48 | -1.78e-01 +/- 1.60e-01 | 4.44e+00 +/- 1.4e-01 | 4.62e+00 +/- 7.6e-02 |
test_equilibrium_init_highres | -3.25 +/- 2.81 | -1.89e-01 +/- 1.63e-01 | 5.62e+00 +/- 3.4e-02 | 5.81e+00 +/- 1.6e-01 |
test_objective_compile_dshape_current | +3.76 +/- 4.36 | +1.57e-01 +/- 1.82e-01 | 4.33e+00 +/- 8.9e-02 | 4.17e+00 +/- 1.6e-01 |
test_objective_compute_dshape_current | -3.84 +/- 3.27 | -2.07e-04 +/- 1.76e-04 | 5.18e-03 +/- 1.1e-04 | 5.39e-03 +/- 1.4e-04 |
test_objective_jac_dshape_current | -0.74 +/- 7.38 | -3.28e-04 +/- 3.26e-03 | 4.38e-02 +/- 2.3e-03 | 4.42e-02 +/- 2.4e-03 |
test_perturb_2 | +1.07 +/- 2.73 | +2.16e-01 +/- 5.52e-01 | 2.05e+01 +/- 3.8e-01 | 2.02e+01 +/- 4.0e-01 |
test_proximal_freeb_jac | -2.25 +/- 2.52 | -1.72e-01 +/- 1.93e-01 | 7.48e+00 +/- 1.7e-01 | 7.65e+00 +/- 9.5e-02 |
test_solve_fixed_iter | -1.09 +/- 4.33 | -3.63e-01 +/- 1.44e+00 | 3.30e+01 +/- 6.0e-01 | 3.33e+01 +/- 1.3e+00 |
test_LinearConstraintProjection_build | +0.86 +/- 4.13 | +1.25e-01 +/- 5.98e-01 | 1.46e+01 +/- 4.4e-01 | 1.45e+01 +/- 4.0e-01 |
test_build_transform_fft_midres | -1.90 +/- 4.28 | -1.23e-02 +/- 2.75e-02 | 6.31e-01 +/- 1.3e-02 | 6.44e-01 +/- 2.4e-02 |
test_build_transform_fft_highres | -1.25 +/- 2.94 | -1.26e-02 +/- 2.96e-02 | 9.95e-01 +/- 1.4e-02 | 1.01e+00 +/- 2.6e-02 |
test_equilibrium_init_lowres | -1.47 +/- 2.66 | -6.15e-02 +/- 1.11e-01 | 4.11e+00 +/- 9.1e-02 | 4.17e+00 +/- 6.3e-02 |
test_objective_compile_atf | -0.80 +/- 2.83 | -6.93e-02 +/- 2.44e-01 | 8.55e+00 +/- 1.8e-01 | 8.62e+00 +/- 1.7e-01 |
test_objective_compute_atf | -4.83 +/- 5.66 | -8.21e-04 +/- 9.63e-04 | 1.62e-02 +/- 3.6e-04 | 1.70e-02 +/- 8.9e-04 |
test_objective_jac_atf | -1.39 +/- 2.60 | -2.79e-02 +/- 5.21e-02 | 1.98e+00 +/- 3.2e-02 | 2.01e+00 +/- 4.1e-02 |
test_perturb_1 | -1.22 +/- 1.94 | -1.88e-01 +/- 2.99e-01 | 1.52e+01 +/- 2.2e-01 | 1.54e+01 +/- 2.0e-01 |
test_proximal_jac_atf | +1.18 +/- 0.78 | +9.75e-02 +/- 6.44e-02 | 8.37e+00 +/- 5.0e-02 | 8.27e+00 +/- 4.0e-02 |
test_proximal_freeb_compute | -0.50 +/- 1.12 | -1.02e-03 +/- 2.28e-03 | 2.03e-01 +/- 2.0e-03 | 2.04e-01 +/- 1.2e-03 |
test_solve_fixed_iter_compiled | +0.13 +/- 2.45 | +2.77e-02 +/- 5.13e-01 | 2.10e+01 +/- 2.1e-01 | 2.10e+01 +/- 4.7e-01 | |
Codecov ReportAll modified and coverable lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## master #1483 +/- ##
=======================================
Coverage 95.68% 95.68%
=======================================
Files 101 101
Lines 25566 25566
=======================================
Hits 24464 24464
Misses 1102 1102
|
Check out this pull request on See visual diffs & provide feedback on Jupyter Notebooks. Powered by ReviewNB |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This PR looks good to me, although others should review it as I am looking at it with only my Python and GitHub knowledge, without DESC knowledge.
- Workflows (
benchmark.yaml
,notebook_tests.yaml
, andregression_tests.yaml
works the same way as its previous version, except a new step is added,Action Details
, which moves all the debugging-related commands to a separate step. It makes sense. - There is a change in
desc.objectives.objective_funcs.ObjectiveFunction.compile
method, which usescompute_scaled_error
method instead ofcompute_scaled
inlsq
andall
modes. This hasn't been explained in the PR or commit messages. Maybe @YigitElma should explain it, but I am sure it's okay. - The documentation is updated and seems okay.
- Tests haven't been changed algorithmically (except changing
rounds
in benchmarks) but have been cleaned. It looks better, I don't see any errors.
@@ -131,67 +131,53 @@ def build(): | |||
N = 25 | |||
_ = Equilibrium(L=L, M=M, N=N) | |||
|
|||
benchmark.pedantic(build, setup=setup, iterations=1, rounds=50) | |||
benchmark.pedantic(build, setup=setup, iterations=1, rounds=10) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
reducing the number of rounds will make the statistics more noisy, and may lead to more false positives
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I agree. For example, in the last benchmark, this PR shows speed improvement for perturb
but it shouldn't. We can decide on the exact number of rounds, but my intention is to balance the time spent on tests. Previously, these equilibrium initialization tests took more time than fixed_iter_solve
and perturb
tests. Given that benchmark workflow started to take around 50mins, I wanted to reduce them from 50, which is a bit overkill.
|
||
|
||
@pytest.mark.slow | ||
@pytest.mark.benchmark | ||
def test_proximal_freeb_compute(benchmark): | ||
"""Benchmark computing free boundary objective with proximal constraint.""" | ||
jax.clear_caches() |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
why remove this?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This doesn't cause too much difference,(I can re add it) but technically only run
is benchmarked, so clearing the cache here doesn't have much purpose.
|
||
def setup(): | ||
def run(): |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
moving everything to the run function is changing what its actually profiling, this now includes a bunch of other stuff besides building the linear constraints, is that what we want?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The extra stuff is just building individual constraints and objectives, right? Previously, this was effectively just benchmarking factorize_linear_constraints
. Do we usually pass built constraints to the LinearConstraintProjection
? Then I can revert it.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think we usually pass built constraints to it, yes
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
DESC/desc/optimize/optimizer.py
Line 218 in f8c66c7
if linear_constraint is not None and not linear_constraint.built: |
|
||
Caching the Compiled (Jitted) Code | ||
---------------------------------- | ||
Although the compiled code is fast, it still takes time to compile. If you are running the same optimization, or some similar optimization, multiple times, you can save time by caching the compiled code. This automatically happens for a single session (for example, until you restart your kernel in Jupyter Notebook) but once you start using another session, the code will need to be recompiled. Fortunately, there is a way to bypass this. First create a cache directory (i.e. ``jax-caches``), and put the following code at the beginning of your script: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
you have this locally in your backend.py right? so you would not usually need this in every script you run if it is there?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah, if you put it to backend.py
, you shouldn't need it every time. But it can be messy for users, so I didn't mention that.
@@ -21,6 +21,7 @@ | |||
:caption: Tutorials | |||
|
|||
installation | |||
performance_tips |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
for ordering id prefer to keep this at the end, so that going through them in order makes more sense
Some benchmarks were using
obj.compile
andjac_scaled_error
together butobj.compile
only compilesjac_scaled
andcompute_scaled
. This cause some benchmarks to have very different min/max values, like,With the change it is more consistent,
Misc
Action Details
step to tests