Skip to content

Commit

Permalink
Add initialize! method and uncomment a test (#118)
Browse files Browse the repository at this point in the history
* Add initialize! method and uncomment a test

* Bump patch version
  • Loading branch information
lbenet authored May 27, 2021
1 parent ff84903 commit 7010459
Show file tree
Hide file tree
Showing 3 changed files with 46 additions and 29 deletions.
2 changes: 1 addition & 1 deletion Project.toml
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
name = "TaylorModels"
uuid = "314ce334-5f6e-57ae-acf6-00b6e903104a"
repo = "https://github.com/JuliaIntervals/TaylorModels.jl.git"
version = "0.3.11"
version = "0.3.12"

[deps]
IntervalArithmetic = "d1acc4aa-44c8-5952-acd4-ba5d80a2a253"
Expand Down
49 changes: 33 additions & 16 deletions src/validatedODEs.jl
Original file line number Diff line number Diff line change
Expand Up @@ -452,13 +452,6 @@ function initialize!(X0::IntervalBox{N,T}, orderQ, orderT, x, dx, xTMN, xI, dxI,
end
return nothing
end

"""
initialize!(X0::IntervalBox{N, T}, orderQ, orderT, x, dx, xTMN, rem, xTM1v) where {N, T}
Initialize the auxiliary integration variables and normalize the given interval
box to the domain `[-1, 1]^n`.
"""
function initialize!(X0::IntervalBox{N,T}, orderQ, orderT, x, dx, xTMN, rem, xTM1v) where {N,T}
@assert N == get_numvars()
q0 = mid.(X0)
Expand Down Expand Up @@ -511,6 +504,29 @@ function initialize!(X0::Vector{TaylorModel1{TaylorN{T},T}}, orderQ, orderT, x,
end
return nothing
end
function initialize!(X0::Vector{TaylorModel1{TaylorN{T},T}}, orderQ, orderT, x, dx, xTMN, rem, xTM1v) where {T}
# nomalized domain
N = get_numvars()
zI = zero_interval(T)
zB = zero_box(N, T)
S = symmetric_box(N, T)

qaux = constant_term.(polynomial.(X0))
x0t = expansion_point(X0[1])
domt = domain(X0[1])
@. begin
x = Taylor1(qaux, orderT)
dx = x
xTMN = TaylorModelN(qaux, zI, (zB,), (S,))

# remainder
rem = remainder(X0)

# output vector
xTM1v[:, 1] = TaylorModel1(deepcopy(x), rem, x0t, domt)
end
return nothing
end

function validated_integ(f!, X0, t0::T, tmax::T, orderQ::Int, orderT::Int, abstol::T, params=nothing;
maxsteps::Int=2000, parse_eqs::Bool=true,
Expand All @@ -523,6 +539,7 @@ function validated_integ(f!, X0, t0::T, tmax::T, orderQ::Int, orderT::Int, absto
dof = N

# Some variables
zt = zero(t0)
zI = zero_interval(T)
zB = zero_box(N, T)
S = symmetric_box(N, T)
Expand Down Expand Up @@ -559,7 +576,6 @@ function validated_integ(f!, X0, t0::T, tmax::T, orderQ::Int, orderT::Int, absto
parse_eqs = TaylorIntegration._determine_parsing!(parse_eqs, f!, t, x, dx, params)

local _success # if true, the validation step succeeded
local _t0 # represents how much the integration could advance until validation failed
setformat(:full)
red_abstol = abstol

Expand All @@ -573,14 +589,14 @@ function validated_integ(f!, X0, t0::T, tmax::T, orderQ::Int, orderT::Int, absto
nsteps, orderT, red_abstol, params,
parse_eqs, adaptive, minabstol,
absorb, check_property)
δtI = sign_tstep * Interval{T}(0, sign_tstep*δt)
δtI = sign_tstep * Interval(zt, sign_tstep*δt)

# New initial conditions and time
# New initial conditions and time, and output vectors
nsteps += 1
@inbounds tv[nsteps] = t0
t0 += δt
@inbounds t[0] = t0
@inbounds tI[0] = t0
@inbounds tv[nsteps] = t0
@. begin
xTM1v[:, nsteps] = TaylorModel1(x, rem, zI, δtI) # deepcopy?
x = Taylor1(evaluate(x, δt), orderT)
Expand Down Expand Up @@ -736,6 +752,7 @@ function _validate_step!(xTM1K, f!, dx, x0, params, x, t, box, dof, rem, abstol,
δt = $(δt)
Δx = $(E)
""")
break
end
end
end
Expand Down Expand Up @@ -777,6 +794,7 @@ function validated_integ2(f!, X0, t0::T, tf::T, orderQ::Int, orderT::Int,
N = get_numvars()
dof = N

zt = zero(t0)
zI = zero_interval(T)
zB = zero_box(N, T)
S = symmetric_box(N, T)
Expand Down Expand Up @@ -829,15 +847,14 @@ function validated_integ2(f!, X0, t0::T, tf::T, orderQ::Int, orderT::Int,
adaptive, minabstol,
ε=ε, δ=δ,
validatesteps=validatesteps)
domt = sign_tstep * Interval{T}(0, sign_tstep*δt)
domt = sign_tstep * Interval(zt, sign_tstep*δt)

# δtI = (δt .. δt) ∩ domt # assure it is inside the domain in t
t0 += δt
nsteps += 1

@inbounds t[0] = t0
@inbounds tv[nsteps] = t0

t0 += δt
@inbounds t[0] = t0

# Flowpipe
@. begin
rem = remainder(xTM1)
Expand Down
24 changes: 12 additions & 12 deletions test/validated_integ.jl
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,7 @@ end
# Random.seed!(1)
for it = 1:_num_tests
n = rand(2:end_idx)
@test test_integ((t,x)->exactsol(t,tini,x), tTM[n-1], qTM[:,n], q0, δq0)
@test test_integ((t,x)->exactsol(t,tini,x), tTM[n], qTM[:,n], q0, δq0)
end

tTMf, qvf, qTMf = validated_integ(falling_ball!, X0, tini, tend, orderQ, orderT, abstol,
Expand All @@ -90,13 +90,13 @@ end
end_idx = lastindex(tTM)
for it = 1:_num_tests
n = rand(2:end_idx)
@test test_integ((t,x)->exactsol(t,tini,x), tTM[n-1], qTM[:,n], q0, δq0)
@test test_integ((t,x)->exactsol(t,tini,x), tTM[n], qTM[:,n], q0, δq0)
end

# # initializaton with a Taylor model
# X0tm = qTM[:, 1]
# tTM2, qv2, qTM2 = validated_integ2(falling_ball!, X0tm, tini, tend, orderQ, orderT, abstol)
# @test qTM == qTM2
# initializaton with a Taylor model
X0tm = qTM[:, 1]
tTM2, qv2, qTM2 = validated_integ2(falling_ball!, X0tm, tini, tend, orderQ, orderT, abstol)
@test qTM == qTM2
end

# Initial conditions
Expand All @@ -114,7 +114,7 @@ end
end_idx = lastindex(tTM)
for it = 1:_num_tests
n = rand(2:end_idx)
@test test_integ((t,x)->exactsol(t,tini,x), tTM[n-1], qTM[:,n], q0, δq0)
@test test_integ((t,x)->exactsol(t,tini,x), tTM[n], qTM[:,n], q0, δq0)
end

tTMf, qvf, qTMf = validated_integ(falling_ball!, X0, tini, tend, orderQ, orderT, abstol,
Expand Down Expand Up @@ -143,7 +143,7 @@ end
end_idx = lastindex(tTM)
for it = 1:_num_tests
n = rand(2:end_idx)
@test test_integ((t,x)->exactsol(t,tini,x), tTM[n-1], qTM[:,n], q0, δq0)
@test test_integ((t,x)->exactsol(t,tini,x), tTM[n], qTM[:,n], q0, δq0)
end
end
end
Expand Down Expand Up @@ -174,8 +174,8 @@ end
# Random.seed!(1)
end_idx = lastindex(tTM)
for it = 1:_num_tests
n = rand(2:end_idx)
@test test_integ((t,x)->exactsol(t,x), tTM[n-1], qTM[:,n], q0, δq0)
n = rand(1:end_idx)
@test test_integ((t,x)->exactsol(t,x), tTM[n], qTM[:,n], q0, δq0)
end

tTMf, qvf, qTMf = validated_integ(x_square!, X0, tini, tend, orderQ, orderT, abstol,
Expand All @@ -197,8 +197,8 @@ end
# Random.seed!(1)
end_idx = lastindex(tTM)
for it = 1:_num_tests
n = rand(2:end_idx)
@test test_integ((t,x)->exactsol(t,x), tTM[n-1], qTM[:,n], q0, δq0)
n = rand(1:end_idx)
@test test_integ((t,x)->exactsol(t,x), tTM[n], qTM[:,n], q0, δq0)
end
end
end
Expand Down

2 comments on commit 7010459

@lbenet
Copy link
Member Author

@lbenet lbenet commented on 7010459 May 27, 2021

Choose a reason for hiding this comment

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

@JuliaRegistrator
Copy link

Choose a reason for hiding this comment

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

Registration pull request created: JuliaRegistries/General/37690

After the above pull request is merged, it is recommended that a tag is created on this repository for the registered package version.

This will be done automatically if the Julia TagBot GitHub Action is installed, or can be done manually through the github interface, or via:

git tag -a v0.3.12 -m "<description of version>" 7010459fd707803654ff5defd394967415a74c34
git push origin v0.3.12

Please sign in to comment.