-
Notifications
You must be signed in to change notification settings - Fork 114
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
PERK4 standalone #2147
base: main
Are you sure you want to change the base?
PERK4 standalone #2147
Conversation
Review checklistThis checklist is meant to assist creators of PRs (to let them know what reviewers will typically look for) and reviewers (to guide them in a structured review process). Items do not need to be checked explicitly for a PR to be eligible for merging. Purpose and scope
Code quality
Documentation
Testing
Performance
Verification
Created with ❤️ by the Trixi.jl community. |
@warisa-r Can you take a first look? |
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## main #2147 +/- ##
===========================================
+ Coverage 70.19% 96.40% +26.21%
===========================================
Files 486 488 +2
Lines 39102 39362 +260
===========================================
+ Hits 27445 37944 +10499
+ Misses 11657 1418 -10239
Flags with carried forward coverage won't be shown. Click here to find out more. ☔ View full report in Codecov by Sentry. |
I'm on it! |
src/time_integration/paired_explicit_runge_kutta/methods_PERK2.jl
Outdated
Show resolved
Hide resolved
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.
Here is what I get from the brief look! I hope I could be of some help. Some might be totally non-sensical or out of ignorance. Apologies in advance!
src/time_integration/paired_explicit_runge_kutta/methods_PERK4.jl
Outdated
Show resolved
Hide resolved
This should wait for #2180 |
… into PERK4_Standalone
Two more refinement runs for the isentropic vortex example: ####################################################################################################
l2
rho rho_v1 rho_v2 rho_e
error EOC error EOC error EOC error EOC
1.85e-04 - 4.25e-04 - 3.72e-04 - 2.67e-03 -
1.55e-05 3.58 3.22e-05 3.73 2.80e-05 3.73 2.15e-04 3.64
9.85e-07 3.97 1.80e-06 4.16 1.85e-06 3.92 1.34e-05 4.00
mean 3.78 mean 3.94 mean 3.83 mean 3.82
----------------------------------------------------------------------------------------------------
linf
rho rho_v1 rho_v2 rho_e
error EOC error EOC error EOC error EOC
2.50e-03 - 9.27e-03 - 9.88e-03 - 3.07e-02 -
3.85e-04 2.70 7.86e-04 3.56 7.82e-04 3.66 5.33e-03 2.53
2.52e-05 3.93 6.55e-05 3.59 6.78e-05 3.53 3.63e-04 3.88
mean 3.32 mean 3.57 mean 3.59 mean 3.20
---------------------------------------------------------------------------------------------------- |
… into PERK4_Standalone
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.
Again, only a brief review.
src/time_integration/paired_explicit_runge_kutta/methods_PERK4.jl
Outdated
Show resolved
Hide resolved
Co-authored-by: Joshua Lampert <[email protected]>
ext/TrixiConvexECOSExt.jl
Outdated
# Specialized form of the stability polynomials for fourth-order PERK schemes. | ||
function stability_polynomials_PERK4!(pnoms, num_stage_evals, | ||
num_eig_vals, | ||
normalized_powered_eigvals, | ||
gamma, | ||
dt, cS3) |
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.
Is this basically an optimized version of stability_polynomials!
specifically for the PERK4 family or does it do something that cannot be achieved using the existing function?
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.
So the latter is true: For the 4th order scheme, the optimization is essentially directly done in the Butcher Array coefficients
# Contribution from free coefficients
for k in 1:(num_stage_evals - 5)
pnoms += (k2 * dt^(k + 4) * view(normalized_powered_eigvals, :, k + 4) *
gamma[k] +
k1 * dt^(k + 5) * view(normalized_powered_eigvals, :, k + 5) *
gamma[k] *
(k + 5))
end
while for the other schemes, the monomial coefficients of the stability polynomial are simply optimized
# Contribution from free coefficients
for k in (consistency_order + 1):num_stage_evals
pnoms += gamma[k - consistency_order] *
view(normalized_powered_eigvals_scaled, :, k)
end
src/time_integration/paired_explicit_runge_kutta/methods_PERK2.jl
Outdated
Show resolved
Hide resolved
src/time_integration/paired_explicit_runge_kutta/methods_PERK3.jl
Outdated
Show resolved
Hide resolved
src/time_integration/paired_explicit_runge_kutta/methods_PERK4.jl
Outdated
Show resolved
Hide resolved
Co-authored-by: Hendrik Ranocha <[email protected]>
This concludes (as of now) the set of standalone PERK methods.
Xref: #21