From b99ecd08c500361dfaa2b66ae0ba9fd366b20b02 Mon Sep 17 00:00:00 2001 From: Chris Rackauckas Date: Fri, 29 May 2020 20:29:09 -0400 Subject: [PATCH] add sensitivity solution constructor --- Project.toml | 2 +- src/composite_solution.jl | 26 +++++++++++++++++++++++--- 2 files changed, 24 insertions(+), 4 deletions(-) diff --git a/Project.toml b/Project.toml index f7d2868eed..f41eb7fd40 100644 --- a/Project.toml +++ b/Project.toml @@ -26,7 +26,7 @@ UnPack = "3a884ed6-31ef-47d7-9d2a-63182c4928ed" [compat] ArrayInterface = "2.7" DataStructures = "0.17" -DiffEqBase = "6.33" +DiffEqBase = "6.36" ExponentialUtilities = "1.2" FiniteDiff = "2" ForwardDiff = "0.10.3" diff --git a/src/composite_solution.jl b/src/composite_solution.jl index a43e988ee1..946452bb5a 100644 --- a/src/composite_solution.jl +++ b/src/composite_solution.jl @@ -62,12 +62,32 @@ function DiffEqBase.solution_new_retcode(sol::ODECompositeSolution{T,N,uType,uTy sol.u,sol.u_analytic,sol.errors,sol.t,sol.k,sol.prob, sol.alg,sol.interp,sol.alg_choice,sol.dense,sol.tslocation, sol.destats,retcode) - end +end - function DiffEqBase.solution_new_tslocation(sol::ODECompositeSolution{ +function DiffEqBase.solution_new_tslocation(sol::ODECompositeSolution{ T,N,uType,uType2,EType,tType,rateType,P,A,IType,DE},tslocation) where {T,N,uType,uType2,EType,tType,rateType,P,A,IType,DE} ODECompositeSolution{T,N,uType,uType2,EType,tType,rateType,P,A,IType,DE}( sol.u,sol.u_analytic,sol.errors,sol.t,sol.k,sol.prob, sol.alg,sol.interp,sol.alg_choice,sol.dense,tslocation, sol.destats,sol.retcode) - end +end + +function DiffEqBase.sensitivity_solution(sol::ODECompositeSolution,u,t) + T = eltype(eltype(u)) + N = length((size(sol.prob.u0)..., length(u))) + interp = if typeof(sol.interp) <: LinearInterpolation + LinearInterpolation(t,u) + elseif typeof(sol.interp) <: ConstantInterpolation + ConstantInterpolation(t,u) + else + SensitivityInterpolation(t,u) + end + + ODECompositeSolution{T,N,typeof(u),typeof(sol.u_analytic),typeof(sol.errors), + typeof(t),Nothing,typeof(sol.prob),typeof(sol.alg), + typeof(interp),typeof(sol.destats)}( + u,sol.u_analytic,sol.errors,t,nothing,sol.prob, + sol.alg,interp,sol.alg_choice, + sol.dense,sol.tslocation, + sol.destats,sol.retcode) +end