Commit 6c439858 authored by Davide Torlo's avatar Davide Torlo
Browse files

set the reproducibility report with all the notebooks. The supplementary...

set the reproducibility report with all the notebooks. The supplementary material file must be updated
parent ccccd891
MIT License
Copyright (c) 2021 Davide Torlo, Philipp Öffner and Hendrik Ranocha
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
# Stability of Positivity Preserving Patankar-Type Schemes # Stability of Positivity Preserving Patankar-Type Schemes
This repository contains the code for the reproducibility of "A new Stability Approach for Positivity-Preserving Patankar-type Schemes" by D. Torlo, P. Öffner and H. Ranocha. [![License: MIT](https://img.shields.io/badge/License-MIT-success.svg)](https://opensource.org/licenses/MIT)
\ No newline at end of file
This repository contains the code for the reproducibility of "A new Stability Approach for Positivity-Preserving Patankar-type Schemes" by D. Torlo, P. Öffner and H. Ranocha [arXiv preprint](https://arxiv.org).
We provide some *Julia* codes and Jupyter notebooks to reproduce the simulations of the paper, some *Mathematica* notebook to reproduce the symbolic computations and the results of the paper, and the supplementary material file with all the results that could not fit in the article.
### Julia codes
In folder [simulations](simulations/) there are:
* the implementations of all the Patankar and modified Patankar schemes ([Patankar Runge--Kutta](simulations/mPRK.jl) and [modified Patankar Deferred Correction](simulations/mPDeC.jl)) and some auxiliary functions ([Lagrange polynomials file](simulations/Lagrange_polynomials.jl))
* the study of the general **linear $2\times 2$ system** searching for the maximum $\Delta t$ bound for which we do not observe oscillations for all the schemes is in the [CFL notebook](simulations/SearchingCFLconditions.ipynb)
* the study of the spurious steady state for all the methods is in the [Inconsistency notebook](simulations/Inconsistency.ipynb)
* the test of the stability bound previously found on **scalar nonlinear problem** is in [Nonlinear Problem notebook](simulations/Nonlinear_Problems.ipynb)
* the test of the inconsistency on **Robertson problem** is in [Robertson notebook](simulations/Robertson_Problem.ipynb)
* the test of the inconsistency on **HIRES problem** is in [HIRES notebook](simulations/Problem_HIRES.ipynb)
### Mathematica notebooks
In folder [symbolic_computations](simbolic_computations/) contains:
* the computations of the $\Delta t$ bound on the general **linear $2\times 2$ system** for the **MPRK(2,2,1)** scheme is in the [MPRK(2,2,1) notebook](simbolic_computations/MPRK_2_2_1_generalSystem.nb)
* the computations of the $\Delta t$ bound and the Taylor expansion to understand which scheme has inconsistency on the **symmetric linear $2\times 2$ system** for some of the **MPRK(2,2,$\alpha$)** schemes is in the [MPRK(2,2,$\alpha$) notebook](simbolic_computations/MPRK_2_2_alpha.nb)
* the Taylor expansion to understand if **MPRK(3,2)** has inconsistency on the **symmetric linear $2\times 2$ system** is in the [MPRK(3,2) notebook](simbolic_computations/MPRK_3_2.nb)
* the Taylor expansion to understand if **mPDeC2** and **mPDeC3** have inconsistencies on the **symmetric linear $2\times 2$ system** is in the [MPDeC notebook](simbolic_computations/MPDeC.nb)
### Supplementary material
In folder [supplementary_material](supplementary_material/) there is the [file](supplementary_material/supplementary_material.pdf) with the supplementary results which are only described in the report
## Disclaimer
Everything is provided as-is and without warranty. Use at your own risk!
This source diff could not be displayed because it is too large. You can view the blob instead.
%% Cell type:code id: tags:
``` julia
ENV["PYCALL_JL_RUNTIME_PYTHON"]="/compute/dtorlo/julia/JuliaVEnv/bin/python3"
```
%%%% Output: execute_result
"/compute/dtorlo/julia/JuliaVEnv/bin/python3"
%% Cell type:code id: tags:
``` julia
using PyPlot; plt=PyPlot
using PyCall
using FastGaussQuadrature, Compat
using LinearAlgebra
# line cyclers adapted to colourblind people
cycler = pyimport("cycler").cycler
line_cycler = (cycler(color=["#E69F00", "#56B4E9", "#009E73", "#0072B2", "#D55E00", "#CC79A7", "#F0E442","#E69F00", "#56B4E9", "#009E73", "#0072B2", "#D55E00", "#CC79A7", "#F0E442"]) +
cycler(linestyle=["-", "--", "-.", ":", "-", "--", "-.", ":","-", "--", "-.", ":", "-", "--"]))
marker_cycler = (cycler(color=["#E69F00", "#56B4E9", "#009E73", "#0072B2", "#D55E00", "#CC79A7", "#F0E442"]) +
cycler(linestyle=["none", "none", "none", "none", "none", "none", "none"]) +
cycler(marker=["4", "2", "3", "1", "+", "x", "."]))
# matplotlib's standard cycler
standard_cycler = cycler("color", ["#1f77b4", "#ff7f0e", "#2ca02c", "#d62728", "#9467bd", "#8c564b", "#e377c2", "#7f7f7f", "#bcbd22", "#17becf"])
plt.rc("axes", prop_cycle=line_cycler)
include("mPDeC.jl")
include("mPRK.jl")
function overshootMeasure(u1)
if u1>0.9
return 1.
else
return 0.
end
end
```
%%%% Output: execute_result
overshootMeasure (generic function with 1 method)
%% Cell type:markdown id: tags:
## Fix a 2x2 linear system
$$
\begin{cases}
u_1'= -\theta u_1 + (1-\theta) u_2\\
u_1'= +\theta u_1 - (1-\theta) u_2
\end{cases}
$$
with $\theta = 0.9$.
A general initial condition is
$$
\begin{pmatrix}
u_1^0\\u_2^0
\end{pmatrix}
=\begin{pmatrix}
1-\varepsilon\\\varepsilon
\end{pmatrix}
$$
with $\varepsilon = 10^{-300}$.
Fix the timestep to $\Delta t =1$.
The method is inconsistent if $u^1_2 \approx \varepsilon$ instead of the exact solution $u_2(\Delta t) \approx 0.43$
%% Cell type:code id: tags:
``` julia
θ=0.9
param_a,param_b= (1-θ),θ #10^2, 10^2 # 1, 1 #
function prod_dest(c)
d= length(c)
p=zeros(d,d)
d=zeros(d,d)
p[1,2]=param_a*c[2]
d[2,1]=param_a*c[2]
p[2,1]=param_b*c[1]
d[1,2]=param_b*c[1]
return p, d
end
uInf=[param_a param_b]
function exact_solution(c0,time)
c_exact=zeros(size(c0)[1],size(time)[1])
a=param_a
b=param_b
A= [ -b a; b -a]
for it=1:length(time)
t=time[it]
c_exact[:,it] = c0+(1- exp(-(a+b)*t))/(a+b).*(A*c0)
end
return c_exact
end
function rhs_function(u)
return zeros(length(u))
end
function SIf(c)
#Production terms
d=length(c)
f=zeros(d)
f[1]=param_a*c[2]
f[2]=param_b*c[1]
return f
end
function SIg(c)
#Destruction terms divided by c
d=length(c)
g=zeros(d)
g[1]=param_b
g[2]=param_a
return -g
end
ep=1e-300
u0=[1-ep; ep]
dt=2
tt=0:dt:dt
a=param_a
b=param_b
A= [ -b a; b -a]
u_exact = u0+(1- exp(-(a+b)*dt))/(a+b).*(A*u0)
u_exact
```
%%%% Output: execute_result
2-element Array{Float64,1}:
0.2218017549129514
0.7781982450870486
%% Cell type:markdown id: tags:
#### MPRK22($\alpha$) method for this system
%% Cell type:code id: tags:
``` julia
problem="system2"
folder="Simulations/searchingCFL/Inconsistency"
order=2
mkpath(folder)
folder = string(folder,"system2/")
mkpath(folder)
αs = range(0.5,stop=4,length=36)
l1=length(αs)
AA=zeros(l1)
QQ=zeros(l1)
Threads.@threads for i1=1:l1
α=αs[i1]
print(i1)
AA[i1]=α
try
tout,uu=mPRK22(prod_dest, rhs_function, tt,u0, α)
QQ[i1]= overshootMeasure(uu[1,2])
if isnan(tmp)
QQ[i1]=1.0
end
catch e
QQ[i1]=1.0
end
end
```
%%%% Output: stream
291633212511612223032331244325262728171218192013141534735368910
%% Cell type:code id: tags:
``` julia
plt.plot(αs[QQ.>0.5],QQ[QQ.>0.5],"rx")
plt.plot(αs[QQ.<0.5],QQ[QQ.<0.5],"go")
plt.xlabel(L"\alpha")
plt.ylabel(L"Inconsistent")
plt.savefig(string(folder,"RK2Inconsistency.pdf"))
```
%%%% Output: display_data
![]()
%% Cell type:markdown id: tags:
#### DeC equispaced all orders
%% Cell type:code id: tags:
``` julia
tout,uu=dec_correction(prod_dest, rhs_function, tt,u0, 11,12,"equispaced")
```
%%%% Output: execute_result
(0:2:2, [1.0 1.0000000000000009; 1.0e-300 5.170604644494139e-293])
%% Cell type:code id: tags:
``` julia
distributions=["equispaced","gaussLobatto"]
distrShort=["eq","glb"]
for (idist, dist) in enumerate(distributions)
incons=zeros(30)
print(dist)
open(string(folder,"InconsistencyDeC$(distrShort[idist])AllSystems.tex"), "w") do io
write(io,"Order & Inconsistency \\\\ \\hline \n")
for order=1:30
print("Order $(order) ")
try
tout,uu=dec_correction(prod_dest, rhs_function, tt,u0, max(order-1,1),order,dist)
incons[order]= overshootMeasure(uu[1,2])
if isnan(incons[order])
incons[order]=1.0
end
catch e
incons[order]=1.0
end
println("Order $(order) Inconsistency $(incons[order])")
write(io, " $(order) & $(incons[order]) \\\\ \n")
end
end
end
```
%%%% Output: stream
equispacedOrder 1 Order 1 Inconsistency 0.0
Order 2 Order 2 Inconsistency 0.0
Order 3 Order 3 Inconsistency 0.0
Order 4 Order 4 Inconsistency 0.0
Order 5 Order 5 Inconsistency 0.0
Order 6 Order 6 Inconsistency 0.0
Order 7 Order 7 Inconsistency 0.0
Order 8 Order 8 Inconsistency 0.0
Order 9 Order 9 Inconsistency 1.0
Order 10 Order 10 Inconsistency 0.0
Order 11 Order 11 Inconsistency 1.0
Order 12 Order 12 Inconsistency 1.0
Order 13 Order 13 Inconsistency 1.0
Order 14 Order 14 Inconsistency 1.0
Order 15 Order 15 Inconsistency 1.0
Order 16 Order 16 Inconsistency 1.0
Order 17 Order 17 Inconsistency 1.0
Order 18 Order 18 Inconsistency 1.0
Order 19 Order 19 Inconsistency 1.0
Order 20 Order 20 Inconsistency 1.0
Order 21 Order 21 Inconsistency 1.0
Order 22 Order 22 Inconsistency 1.0
Order 23 Order 23 Inconsistency 1.0
Order 24 Order 24 Inconsistency 1.0
Order 25 Order 25 Inconsistency 1.0
Order 26 Order 26 Inconsistency 1.0
Order 27 Order 27 Inconsistency 1.0
Order 28 Order 28 Inconsistency 1.0
Order 29 Order 29 Inconsistency 1.0
Order 30 Order 30 Inconsistency 1.0
gaussLobattoOrder 1 Order 1 Inconsistency 0.0
Order 2 Order 2 Inconsistency 0.0
Order 3 Order 3 Inconsistency 0.0
Order 4 Order 4 Inconsistency 0.0
Order 5 Order 5 Inconsistency 0.0
Order 6 Order 6 Inconsistency 0.0
Order 7 Order 7 Inconsistency 0.0
Order 8 Order 8 Inconsistency 0.0
Order 9 Order 9 Inconsistency 0.0
Order 10 Order 10 Inconsistency 0.0
Order 11 Order 11 Inconsistency 0.0
Order 12 Order 12 Inconsistency 0.0
Order 13 Order 13 Inconsistency 0.0
Order 14 Order 14 Inconsistency 0.0
Order 15 Order 15 Inconsistency 0.0
Order 16 Order 16 Inconsistency 0.0
Order 17 Order 17 Inconsistency 0.0
Order 18 Order 18 Inconsistency 0.0
Order 19 Order 19 Inconsistency 0.0
Order 20 Order 20 Inconsistency 0.0
Order 21 Order 21 Inconsistency 0.0
Order 22 Order 22 Inconsistency 0.0
Order 23 Order 23 Inconsistency 0.0
Order 24 Order 24 Inconsistency 0.0
Order 25 Order 25 Inconsistency 0.0
Order 26 Order 26 Inconsistency 0.0
Order 27 Order 27 Inconsistency 0.0
Order 28 Order 28 Inconsistency 0.0
Order 29 Order 29 Inconsistency 0.0
Order 30 Order 30 Inconsistency 0.0
%% Cell type:markdown id: tags:
### MPRKSO(4,3)
%% Cell type:code id: tags:
``` julia
tout,uu=mPRKSO3(prod_dest, rhs_function, tt,u0)
tmp= overshootMeasure(uu[1,2])
print(tmp)
```
%%%% Output: stream
0.0
%% Cell type:markdown id: tags:
## MPRK(3,2) inspired from a SSPRK(3,3)
%% Cell type:code id: tags:
``` julia
tout,uu=mPRK32(prod_dest, rhs_function, tt,u0)
tmp= overshootMeasure(uu[1,2])
println(tmp)
```
%%%% Output: stream
0.0
%% Cell type:markdown id: tags:
### MPRKSO22($\alpha$,$\beta$)
%% Cell type:code id: tags:
``` julia
l1=201
l2=201
as=range(0.,stop=0.5,length=l1)
bs=range(0.,stop=10,length=l2)
AA=zeros(l1,l2)
BB=zeros(l1,l2)
QQ=zeros(l1,l2)
Threads.@threads for k=1:l1
print(k)
for j= 1:l2
AA[k,j]=as[k]
BB[k,j]=bs[j]
try
tout,uu=mPRKSO2(prod_dest,rhs_function, tt,u0, as[k],bs[j])
QQ[k,j]= overshootMeasure(uu[1,2])
if isnan(QQ[k,j])
QQ[k,j]=1.0
end
catch e
QQ[k,j]=1.0
end
end
end
```
%%%% Output: stream
117727127102771525223456787879910801112138114151617188219178202122238324252617984128851801031298618110487130282930153313210533182881313453353637154543810689391325540183414256431559010744571334518446589147156108594892134496018510950157936151135186110629415863136111187649515911213765961881606611397138671891616898114139691901629911514070116163191100711411171647210119214273118165143193741191667514412019476167145121195146168122196169123147170197124148125171198149126172199150173151200174201175176
%% Cell type:code id: tags:
``` julia
nLevels=4
colls=zeros(nLevels,3)
colls[:,1]=[x for x in range(0,stop=1,length=nLevels)]
colls[:,2]=[1-sqrt.(2*x*(1-x)) for x in range(0,stop=1,length=nLevels)]
colls[:,3]=[1-x for x in range(0,stop=1,length=nLevels)]
levels=[0
0.2
0.5
1.1]
#levels=[0
# 0.0005
# 0.001
# range(6,stop=11,length=13)
# 16]
PyPlot.contourf(AA,BB,QQ,levels, colors=colls)
#PyPlot.colorbar()
PyPlot.xlabel(L"\alpha")
PyPlot.ylabel(L"$\beta$")
#PyPlot.title("log10 Variation Lyapunov mPRK3")
PyPlot.savefig(string(folder,"InconsistencyRKSO2.pdf"))
PyPlot.show()
```
%%%% Output: display_data
![]()
%% Cell type:markdown id: tags:
### MPRK43($\alpha,\beta$)
%% Cell type:code id: tags:
``` julia
l1=201
l2=201
as=range(1/3,stop=3,length=l1)
bs=range(0.28,stop=0.75,length=l2)
AA=zeros(l1,l2)
BB=zeros(l1,l2)
QQ=zeros(l1,l2)
Threads.@threads for k=1:l1
print(k)
for j= 1:l2
AA[k,j]=as[k]
BB[k,j]=bs[j]
try
tout,uu=mPRK3(prod_dest,rhs_function, tt,u0, as[k],bs[j])
QQ[k,j]= overshootMeasure(uu[1,2])
if isnan(QQ[k,j])
QQ[k,j]=1.0
end
catch e
QQ[k,j]=1.0
end
end
end
```
%%%% Output: stream
521522717717710212723281531031781285378541291041547917929554105801555613018010681156305713151811075813282157108182596833113315860109841341831593261110785184135160621113386136185631611128876413718634113162886591381871148916366351156790188139101643691681161401651896992111173716619014170118931671219138711421199416872391921314395120731694019396144121417417014429719414512275431714498195157612314645172461249919614747161734810012519714849174101126175019814951175181501991761512001920120212223242526
%% Cell type:code id: tags:
``` julia
problem="system2"
folder="Simulations/searchingCFL/Inconsistency"
order=2
mkpath(folder)
folder = string(folder,"system2/")
mkpath(folder)
nLevels=4
colls=zeros(nLevels,3)
colls[:,1]=[x for x in range(0,stop=1,length=nLevels)]
colls[:,2]=[1-sqrt.(2*x*(1-x)) for x in range(0,stop=1,length=nLevels)]
colls[:,3]=[1-x for x in range(0,stop=1,length=nLevels)]
levels=[0
0.2
0.7
1.1]
#levels=[0
# 0.0005
# 0.001
# range(6,stop=11,length=13)
# 16]
PyPlot.contourf(AA,BB,QQ,levels, colors=colls)
#PyPlot.colorbar()
PyPlot.xlabel(L"\alpha")
PyPlot.ylabel(L"$\beta$")
#PyPlot.title("log10 Variation Lyapunov mPRK3")
PyPlot.savefig(string(folder,"InconsistencyRK43.pdf"))
PyPlot.show()
println(maximum(QQ))
```
%%%% Output: display_data
![]()
%%%% Output: stream
1.0
%% Cell type:markdown id: tags:
#### MPRK(4,3,$\alpha,\beta$) on the purple line of the original paper
%% Cell type:code id: tags:
``` julia
problem="system2"
folder="Simulations/searchingCFL/Inconsistency"
order=3
mkpath(folder)
folder = string(folder,"system2/")
mkpath(folder)
αs = range(0.89255,stop=10,length=100)
βs= max.(3*αs.*(1 .-αs),(3*αs.-2.)./(6*αs.-3.))
l1=length(αs)
AA=zeros(l1)
QQ=zeros(l1)
Threads.@threads for i1=1:l1
α=αs[i1]
print(i1)
AA[i1]=α
try
tout,uu=mPRK3(prod_dest, rhs_function, tt,u0, α,β)
QQ[i1]= overshootMeasure(uu[1,2])
if isnan(tmp)
QQ[i1]=1.0
end
catch e
QQ[i1]=1.0
end
end
```
%%%% Output: stream
146577895327140151666545556786790919257689379808158697017822719459288384603957229304118858661311996427332208797984628874432133575224499663457610034467642347835249364825371026493811503912511352
%% Cell type:code id: tags:
``` julia