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

Implement Part 1 Of Adaptive Radau Method #2450

Merged
merged 87 commits into from
Sep 20, 2024
Merged
Show file tree
Hide file tree
Changes from 72 commits
Commits
Show all changes
87 commits
Select commit Hold shift + click to select a range
84ef783
rename
Shreyas-Ekanathan Jul 24, 2024
0ba696d
Merge branch 'master' into head
Shreyas-Ekanathan Jul 24, 2024
b9083ff
Merge pull request #3 from Shreyas-Ekanathan/head
Shreyas-Ekanathan Jul 24, 2024
fdc92bb
Delete src/algorithms/explicit_rk_pde.jl
Shreyas-Ekanathan Jul 25, 2024
3a48a6e
Delete src/caches/extrapolation_caches.jl
Shreyas-Ekanathan Jul 25, 2024
5400ec8
Delete src/caches/feagin_caches.jl
Shreyas-Ekanathan Jul 25, 2024
38ad679
Delete src/caches/low_storage_rk_caches.jl
Shreyas-Ekanathan Jul 25, 2024
b011f36
Delete src/caches/rkc_caches.jl
Shreyas-Ekanathan Jul 25, 2024
075885b
Delete src/caches/rkn_caches.jl
Shreyas-Ekanathan Jul 25, 2024
ec9c8b3
Delete src/caches/ssprk_caches.jl
Shreyas-Ekanathan Jul 25, 2024
2222a9c
Delete src/caches/symplectic_caches.jl
Shreyas-Ekanathan Jul 25, 2024
e9421a9
Delete src/caches/verner_caches.jl
Shreyas-Ekanathan Jul 25, 2024
19e524e
Delete src/dense/verner_addsteps.jl
Shreyas-Ekanathan Jul 25, 2024
7f8de0b
Delete src/perform_step/extrapolation_perform_step.jl
Shreyas-Ekanathan Jul 25, 2024
2eb16b6
Delete src/perform_step/feagin_rk_perform_step.jl
Shreyas-Ekanathan Jul 25, 2024
82cc872
Delete src/perform_step/low_storage_rk_perform_step.jl
Shreyas-Ekanathan Jul 25, 2024
7d75164
Delete src/perform_step/rkc_perform_step.jl
Shreyas-Ekanathan Jul 25, 2024
4112f61
Delete src/perform_step/rkn_perform_step.jl
Shreyas-Ekanathan Jul 25, 2024
28759d0
Delete src/perform_step/ssprk_perform_step.jl
Shreyas-Ekanathan Jul 25, 2024
8372fe0
Delete src/perform_step/symplectic_perform_step.jl
Shreyas-Ekanathan Jul 25, 2024
84158ab
Delete src/perform_step/verner_rk_perform_step.jl
Shreyas-Ekanathan Jul 25, 2024
0baa146
Delete src/rkc_utils.jl
Shreyas-Ekanathan Jul 25, 2024
1aafef3
Delete src/tableaus/feagin_tableaus.jl
Shreyas-Ekanathan Jul 25, 2024
2dd0999
Delete src/tableaus/rkc_tableaus.jl
Shreyas-Ekanathan Jul 25, 2024
47ea1ef
Delete src/tableaus/rkn_tableaus.jl
Shreyas-Ekanathan Jul 25, 2024
aa29690
Delete src/tableaus/symplectic_tableaus.jl
Shreyas-Ekanathan Jul 25, 2024
131ea9c
Delete src/tableaus/verner_tableaus.jl
Shreyas-Ekanathan Jul 25, 2024
f6dac89
Delete test/algconvergence/ode_extrapolation_tests.jl
Shreyas-Ekanathan Jul 25, 2024
01688f1
Delete test/algconvergence/ode_feagin_tests.jl
Shreyas-Ekanathan Jul 25, 2024
95a7fd4
Delete test/algconvergence/ode_low_storage_rk_tests.jl
Shreyas-Ekanathan Jul 25, 2024
0a99b48
Delete test/algconvergence/ode_ssprk_tests.jl
Shreyas-Ekanathan Jul 25, 2024
f896f73
Delete test/algconvergence/rkc_tests.jl
Shreyas-Ekanathan Jul 25, 2024
459ccf3
Delete test/algconvergence/symplectic_tests.jl
Shreyas-Ekanathan Jul 25, 2024
798fef8
Update ode_firk_tests.jl
Shreyas-Ekanathan Jul 25, 2024
2020765
Merge pull request #4 from Shreyas-Ekanathan/master
Shreyas-Ekanathan Jul 25, 2024
9378160
Merge pull request #5 from Shreyas-Ekanathan/upstream
Shreyas-Ekanathan Jul 25, 2024
d3c8a52
Merge branch 'master' of https://github.com/Shreyas-Ekanathan/Ordinar…
Shreyas-Ekanathan Jul 27, 2024
cf648e8
Update firk_tableaus.jl
Shreyas-Ekanathan Jul 27, 2024
5b0cbe1
Merge branch 'master' of https://github.com/Shreyas-Ekanathan/Ordinar…
Shreyas-Ekanathan Aug 6, 2024
c887941
add to tableau, create cache, oop method
Shreyas-Ekanathan Aug 6, 2024
1598f04
format
Shreyas-Ekanathan Aug 6, 2024
45641a3
calculate T
Shreyas-Ekanathan Aug 9, 2024
a685028
add in-place
Shreyas-Ekanathan Aug 10, 2024
91cd34b
Update firk_perform_step.jl
Shreyas-Ekanathan Aug 11, 2024
d5beb29
Update integrator_interface.jl
Shreyas-Ekanathan Aug 11, 2024
9fee28b
Update integrator_interface.jl
Shreyas-Ekanathan Aug 11, 2024
67bb0fe
rename, formatting
Shreyas-Ekanathan Aug 13, 2024
30cc947
Merge branch 'upstream' of https://github.com/Shreyas-Ekanathan/Ordin…
Shreyas-Ekanathan Aug 15, 2024
f182b38
Merge pull request #7 from Shreyas-Ekanathan/master
Shreyas-Ekanathan Aug 15, 2024
1125bc1
Merge pull request #9 from Shreyas-Ekanathan/upstream
Shreyas-Ekanathan Aug 15, 2024
d836402
Merge pull request #10 from SciML/master
Shreyas-Ekanathan Aug 15, 2024
3d09fa2
lots of edits
Shreyas-Ekanathan Aug 21, 2024
de394f3
Merge branch 'master' into upstream
Shreyas-Ekanathan Aug 21, 2024
4228c83
Merge pull request #11 from Shreyas-Ekanathan/upstream
Shreyas-Ekanathan Aug 21, 2024
6df8b72
tweaks
Shreyas-Ekanathan Aug 22, 2024
51d2012
Merge pull request #12 from Shreyas-Ekanathan/upstream
Shreyas-Ekanathan Aug 22, 2024
9eb4538
fix collocation on radauIIA9
Shreyas-Ekanathan Aug 23, 2024
1d7a4bd
fix collocation on adaptive radau
Shreyas-Ekanathan Aug 23, 2024
c69f1c1
oop works!
Shreyas-Ekanathan Aug 24, 2024
f1ae02f
Merge pull request #13 from Shreyas-Ekanathan/upstream
Shreyas-Ekanathan Aug 25, 2024
2d6b5f6
fixes
Shreyas-Ekanathan Aug 25, 2024
aaeed16
Merge branch 'master' of https://github.com/Shreyas-Ekanathan/Ordinar…
Shreyas-Ekanathan Aug 25, 2024
064c77d
Update ode_firk_tests.jl
Shreyas-Ekanathan Aug 27, 2024
bff13df
clean up
Shreyas-Ekanathan Aug 30, 2024
55259d5
IN PLACE
Shreyas-Ekanathan Sep 1, 2024
ff10299
Update ode_firk_tests.jl
Shreyas-Ekanathan Sep 1, 2024
df3063f
cached tableaus
Shreyas-Ekanathan Sep 2, 2024
e8ba6c7
fix types
Shreyas-Ekanathan Sep 2, 2024
52613d3
clean up
Shreyas-Ekanathan Sep 2, 2024
d9545fd
tweaks
Shreyas-Ekanathan Sep 3, 2024
2ee7782
Merge branch 'SciML:master' into upstream
Shreyas-Ekanathan Sep 3, 2024
0740aea
Merge pull request #14 from Shreyas-Ekanathan/upstream
Shreyas-Ekanathan Sep 3, 2024
8574f04
edits
Shreyas-Ekanathan Sep 3, 2024
71e13ef
Update firk_perform_step.jl
Shreyas-Ekanathan Sep 3, 2024
f17907a
types
Shreyas-Ekanathan Sep 3, 2024
f52c9e4
fix tableaus
Shreyas-Ekanathan Sep 4, 2024
42f5280
edits
Shreyas-Ekanathan Sep 6, 2024
40baa62
minor fixes
oscardssmith Sep 6, 2024
12630e0
little things
Shreyas-Ekanathan Sep 6, 2024
4252639
fix types
Shreyas-Ekanathan Sep 7, 2024
3318e37
explicitly perform multiplications
Shreyas-Ekanathan Sep 8, 2024
9c15269
caches
Shreyas-Ekanathan Sep 12, 2024
75168c8
small edits
Shreyas-Ekanathan Sep 14, 2024
533f9a8
@..
Shreyas-Ekanathan Sep 15, 2024
fed9fc5
add adaptivity
Shreyas-Ekanathan Sep 18, 2024
c0b5936
Update ode_firk_tests.jl
Shreyas-Ekanathan Sep 18, 2024
bdb0a63
Update ode_firk_tests.jl
Shreyas-Ekanathan Sep 19, 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
5 changes: 5 additions & 0 deletions lib/OrdinaryDiffEqFIRK/Project.toml
Original file line number Diff line number Diff line change
Expand Up @@ -6,15 +6,20 @@ version = "1.1.0"
[deps]
DiffEqBase = "2b5f629d-d688-5b77-993f-72d75c75574e"
FastBroadcast = "7034ab61-46d4-4ed7-9d0f-46aef9175898"
GenericLinearAlgebra = "14197337-ba66-59df-a3e3-ca00e7dcff7a"
Copy link
Member

Choose a reason for hiding this comment

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

This is a pretty big set of dependencies, are we sure we want to include them by default? OrdinaryDiffEqFIRKDeriver or something that can be optionally added?

GenericSchur = "c145ed77-6b09-5dd9-b285-bf645a82121e"
LinearAlgebra = "37e2e46d-f89d-539d-b4ee-838fcccc9c8e"
LinearSolve = "7ed4a6bd-45f5-4d41-b270-4a48e9bafcae"
MuladdMacro = "46d2c3a1-f734-5fdb-9937-b9b9aeba4221"
OrdinaryDiffEqCore = "bbf590c4-e513-4bbe-9b18-05decba2e5d8"
OrdinaryDiffEqDifferentiation = "4302a76b-040a-498a-8c04-15b101fed76b"
OrdinaryDiffEqNonlinearSolve = "127b3ac7-2247-4354-8eb6-78cf4e7c58e8"
Polynomials = "f27b6e38-b328-58d1-80ce-0feddd5e7a45"
RecursiveArrayTools = "731186ca-8d62-57ce-b412-fbd966d074cd"
Reexport = "189a3867-3050-52da-a836-e630ba90ab69"
RootedTrees = "47965b36-3f3e-11e9-0dcf-4570dfd42a8c"
SciMLOperators = "c0aeaf25-5076-4817-a8d5-81caf7dfa961"
Symbolics = "0c5d862f-8b57-4792-8d23-62f2024744c7"
Shreyas-Ekanathan marked this conversation as resolved.
Show resolved Hide resolved

[compat]
DiffEqBase = "6.152.2"
Expand Down
3 changes: 2 additions & 1 deletion lib/OrdinaryDiffEqFIRK/src/OrdinaryDiffEqFIRK.jl
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ import OrdinaryDiffEqCore: alg_order, calculate_residuals!,
get_current_adaptive_order, get_fsalfirstlast,
isfirk, generic_solver_docstring
using MuladdMacro, DiffEqBase, RecursiveArrayTools
using Polynomials, GenericLinearAlgebra, GenericSchur
using SciMLOperators: AbstractSciMLOperator
using LinearAlgebra: I, UniformScaling, mul!, lu
import LinearSolve
Expand All @@ -42,6 +43,6 @@ include("firk_tableaus.jl")
include("firk_perform_step.jl")
include("integrator_interface.jl")

export RadauIIA3, RadauIIA5, RadauIIA9
export RadauIIA3, RadauIIA5, RadauIIA9, AdaptiveRadau

end
2 changes: 2 additions & 0 deletions lib/OrdinaryDiffEqFIRK/src/alg_utils.jl
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,12 @@ qmax_default(alg::Union{RadauIIA3, RadauIIA5, RadauIIA9}) = 8
alg_order(alg::RadauIIA3) = 3
alg_order(alg::RadauIIA5) = 5
alg_order(alg::RadauIIA9) = 9
alg_order(alg::AdaptiveRadau) = 5

isfirk(alg::RadauIIA3) = true
isfirk(alg::RadauIIA5) = true
isfirk(alg::RadauIIA9) = true
isfirk(alg::AdaptiveRadau) = true

alg_adaptive_order(alg::RadauIIA3) = 1
alg_adaptive_order(alg::RadauIIA5) = 3
Expand Down
39 changes: 39 additions & 0 deletions lib/OrdinaryDiffEqFIRK/src/algorithms.jl
Original file line number Diff line number Diff line change
Expand Up @@ -150,3 +150,42 @@ function RadauIIA9(; chunk_size = Val{0}(), autodiff = Val{true}(),
controller,
step_limiter!)
end

struct AdaptiveRadau{CS, AD, F, P, FDT, ST, CJ, Tol, C1, C2, StepLimiter} <:
OrdinaryDiffEqNewtonAdaptiveAlgorithm{CS, AD, FDT, ST, CJ}
linsolve::F
precs::P
smooth_est::Bool
extrapolant::Symbol
κ::Tol
maxiters::Int
fast_convergence_cutoff::C1
new_W_γdt_cutoff::C2
controller::Symbol
step_limiter!::StepLimiter
num_stages::Int
end

function AdaptiveRadau(; chunk_size = Val{0}(), autodiff = Val{true}(),
standardtag = Val{true}(), concrete_jac = nothing,
diff_type = Val{:forward}, num_stages = 3,
linsolve = nothing, precs = DEFAULT_PRECS,
extrapolant = :dense, fast_convergence_cutoff = 1 // 5,
new_W_γdt_cutoff = 1 // 5,
controller = :Predictive, κ = nothing, maxiters = 10, smooth_est = true,
step_limiter! = trivial_limiter!)
AdaptiveRadau{_unwrap_val(chunk_size), _unwrap_val(autodiff), typeof(linsolve),
typeof(precs), diff_type, _unwrap_val(standardtag), _unwrap_val(concrete_jac),
typeof(κ), typeof(fast_convergence_cutoff),
typeof(new_W_γdt_cutoff), typeof(step_limiter!)}(linsolve,
precs,
smooth_est,
extrapolant,
κ,
maxiters,
fast_convergence_cutoff,
new_W_γdt_cutoff,
controller,
step_limiter!, num_stages)
end

185 changes: 183 additions & 2 deletions lib/OrdinaryDiffEqFIRK/src/firk_caches.jl
Original file line number Diff line number Diff line change
Expand Up @@ -287,6 +287,7 @@ mutable struct RadauIIA9ConstantCache{F, Tab, Tol, Dt, U, JType} <:
cont2::U
cont3::U
cont4::U
cont5::U
dtprev::Dt
W_γdt::Dt
status::NLStatus
Expand All @@ -304,7 +305,7 @@ function alg_cache(alg::RadauIIA9, u, rate_prototype, ::Type{uEltypeNoUnits},
κ = alg.κ !== nothing ? convert(uToltype, alg.κ) : convert(uToltype, 1 // 100)
J = false .* _vec(rate_prototype) .* _vec(rate_prototype)'

RadauIIA9ConstantCache(uf, tab, κ, one(uToltype), 10000, u, u, u, u, dt, dt,
RadauIIA9ConstantCache(uf, tab, κ, one(uToltype), 10000, u, u, u, u, u, dt, dt,
Convergence, J)
end

Expand Down Expand Up @@ -333,6 +334,7 @@ mutable struct RadauIIA9Cache{uType, cuType, uNoUnitsType, rateType, JType, W1Ty
cont2::uType
cont3::uType
cont4::uType
cont5::uType
du1::rateType
fsalfirst::rateType
k::rateType
Expand Down Expand Up @@ -407,6 +409,7 @@ function alg_cache(alg::RadauIIA9, u, rate_prototype, ::Type{uEltypeNoUnits},
cont2 = zero(u)
cont3 = zero(u)
cont4 = zero(u)
cont5 = zero(u)

fsalfirst = zero(rate_prototype)
k = zero(rate_prototype)
Expand Down Expand Up @@ -462,11 +465,189 @@ function alg_cache(alg::RadauIIA9, u, rate_prototype, ::Type{uEltypeNoUnits},

RadauIIA9Cache(u, uprev,
z1, z2, z3, z4, z5, w1, w2, w3, w4, w5,
dw1, ubuff, dw23, dw45, cubuff1, cubuff2, cont1, cont2, cont3, cont4,
dw1, ubuff, dw23, dw45, cubuff1, cubuff2, cont1, cont2, cont3, cont4, cont5,
du1, fsalfirst, k, k2, k3, k4, k5, fw1, fw2, fw3, fw4, fw5,
J, W1, W2, W3,
uf, tab, κ, one(uToltype), 10000,
tmp, tmp2, tmp3, tmp4, tmp5, tmp6, atmp, jac_config,
linsolve1, linsolve2, linsolve3, rtol, atol, dt, dt,
Convergence, alg.step_limiter!)
end

mutable struct AdaptiveRadauConstantCache{F, Tab, Tol, Dt, U, JType} <:
OrdinaryDiffEqConstantCache
uf::F
tab::Tab
κ::Tol
ηold::Tol
iter::Int
cont::AbstractVector{U}
dtprev::Dt
W_γdt::Dt
status::NLStatus
J::JType
end

function alg_cache(alg::AdaptiveRadau, u, rate_prototype, ::Type{uEltypeNoUnits},
::Type{uBottomEltypeNoUnits},
::Type{tTypeNoUnits}, uprev, uprev2, f, t, dt, reltol, p, calck,
::Val{false}) where {uEltypeNoUnits, uBottomEltypeNoUnits, tTypeNoUnits}
uf = UDerivativeWrapper(f, t, p)
uToltype = constvalue(uBottomEltypeNoUnits)
num_stages = alg.num_stages

if (num_stages == 3)
tab = BigRadauIIA5Tableau(uToltype, constvalue(tTypeNoUnits), Int)
elseif (num_stages == 5)
tab = BigRadauIIA9Tableau(uToltype, constvalue(tTypeNoUnits), Int)
elseif (num_stages == 7)
tab = BigRadauIIA13Tableau(uToltype, constvalue(tTypeNoUnits), Int)
else
tab = adaptiveRadauTableau(uToltype, constvalue(tTypeNoUnits), num_stages)
end

cont = Vector{typeof(u)}(undef, num_stages)
for i in 1: num_stages
cont[i] = zero(u)
end

κ = alg.κ !== nothing ? convert(uToltype, alg.κ) : convert(uToltype, 1 // 100)
J = false .* _vec(rate_prototype) .* _vec(rate_prototype)'

AdaptiveRadauConstantCache(uf, tab, κ, one(uToltype), 10000, cont, dt, dt,
Convergence, J)
end

mutable struct AdaptiveRadauCache{uType, cuType, uNoUnitsType, rateType, JType, W1Type, W2Type,
UF, JC, F1, F2, Tab, Tol, Dt, rTol, aTol, StepLimiter} <:
FIRKMutableCache
u::uType
uprev::uType
z::AbstractVector{uType}
w::AbstractVector{uType}
dw1::uType
ubuff::uType
dw2::AbstractVector{cuType}
cubuff::AbstractVector{cuType}
cont::AbstractVector{uType}
du1::rateType
fsalfirst::rateType
ks::AbstractVector{rateType}
k::rateType
fw::AbstractVector{rateType}
J::JType
W1::W1Type #real
W2::AbstractVector{W2Type} #complex
uf::UF
tab::Tab
κ::Tol
ηold::Tol
iter::Int
tmp::uType
atmp::uNoUnitsType
jac_config::JC
linsolve1::F1 #real
linsolve2::AbstractVector{F2} #complex
rtol::rTol
atol::aTol
dtprev::Dt
W_γdt::Dt
status::NLStatus
step_limiter!::StepLimiter
end

function alg_cache(alg::AdaptiveRadau, u, rate_prototype, ::Type{uEltypeNoUnits},
::Type{uBottomEltypeNoUnits},
::Type{tTypeNoUnits}, uprev, uprev2, f, t, dt, reltol, p, calck,
::Val{true}) where {uEltypeNoUnits, uBottomEltypeNoUnits, tTypeNoUnits}
uf = UJacobianWrapper(f, t, p)
uToltype = constvalue(uBottomEltypeNoUnits)
num_stages = alg.num_stages

if (num_stages == 3)
tab = BigRadauIIA5Tableau(uToltype, constvalue(tTypeNoUnits), Int)
elseif (num_stages == 5)
tab = BigRadauIIA9Tableau(uToltype, constvalue(tTypeNoUnits), Int)
elseif (num_stages == 7)
tab = BigRadauIIA13Tableau(uToltype, constvalue(tTypeNoUnits), Int)
else
tab = adaptiveRadauTableau(uToltype, constvalue(tTypeNoUnits), num_stages)
end

κ = alg.κ !== nothing ? convert(uToltype, alg.κ) : convert(uToltype, 1 // 100)

z = Vector{typeof(u)}(undef, num_stages)
w = Vector{typeof(u)}(undef, num_stages)
for i in 1 : num_stages
z[i] = w[i] = zero(u)
end

dw1 = zero(u)
ubuff = zero(u)
dw2 = Vector{Any}(undef, floor(Int, num_stages / 2))
for i in 1 : floor(Int, num_stages / 2)
dw2[i] = similar(u, Complex{eltype(u)})
recursivefill!(dw2[i], false)
end
cubuff = Vector{Any}(undef, floor(Int, num_stages / 2))
for i in 1 : floor(Int, num_stages / 2)
cubuff[i] = similar(u, Complex{eltype(u)})
recursivefill!(cubuff[i], false)
end

cont = Vector{typeof(u)}(undef, num_stages)
for i in 1: num_stages
cont[i] = zero(u)
end

fsalfirst = zero(rate_prototype)
fw = Vector{typeof(rate_prototype)}(undef, num_stages)
ks = Vector{typeof(rate_prototype)}(undef, num_stages)
for i in 1: num_stages
ks[i] = fw[i] = zero(rate_prototype)
end
k = ks[1]

J, W1 = build_J_W(alg, u, uprev, p, t, dt, f, uEltypeNoUnits, Val(true))
if J isa AbstractSciMLOperator
error("Non-concrete Jacobian not yet supported by RadauIIA5.")
end
W2 = Vector{Any}(undef, floor(Int, num_stages / 2))
for i in 1 : floor(Int, num_stages / 2)
W2[i] = similar(J, Complex{eltype(W1)})
recursivefill!(W2[i], false)
end

du1 = zero(rate_prototype)

tmp = zero(u)

atmp = similar(u, uEltypeNoUnits)
recursivefill!(atmp, false)

jac_config = build_jac_config(alg, f, uf, du1, uprev, u, zero(u), dw1)

linprob = LinearProblem(W1, _vec(ubuff); u0 = _vec(dw1))
linsolve1 = init(linprob, alg.linsolve, alias_A = true, alias_b = true,
assumptions = LinearSolve.OperatorAssumptions(true))

linsolve2 = Vector{Any}(undef, floor(Int, num_stages / 2))
for i in 1 : floor(Int, num_stages / 2)
linprob = LinearProblem(W2[i], _vec(cubuff[i]); u0 = _vec(dw2[i]))
linsolve2[i] = init(linprob, alg.linsolve, alias_A = true, alias_b = true,
assumptions = LinearSolve.OperatorAssumptions(true))
end

rtol = reltol isa Number ? reltol : zero(reltol)
atol = reltol isa Number ? reltol : zero(reltol)

AdaptiveRadauCache(u, uprev,
z, w, dw1, ubuff, dw2, cubuff, cont,
du1, fsalfirst, ks, k, fw,
J, W1, W2,
uf, tab, κ, one(uToltype), 10000, tmp,
atmp, jac_config,
linsolve1, linsolve2, rtol, atol, dt, dt,
Convergence, alg.step_limiter!)
end

Loading
Loading