125: Terminal flux calculation via test functions
For a rather comprehensive explanation see 225: Terminal flux calculation via test functions, nD
module Example125_TestFunctions1D
using Printf
using VoronoiFVM
using ExtendableGrids
using GridVisualize
function main(; n = 100, Plotter = nothing, verbose = false, unknown_storage = :sparse, assembly = :edgewise)
h = 1 / n
grid = simplexgrid(collect(0:h:1))
eps::Vector{Float64} = [1, 1.0e-1]
physics = VoronoiFVM.Physics(
; reaction = function (f, u, node, data)
f[1] = 10 * (u[1] - u[2])
f[2] = 10 * (u[2] - u[1])
return nothing
end, flux = function (f, u, edge, data)
f[1] = eps[1] * (u[1, 1] - u[1, 2])
f[2] = eps[2] * (u[2, 1] - u[2, 2])
return nothing
end, storage = function (f, u, node, data)
f[1] = u[1]
f[2] = u[2]
return nothing
end
)
sys = VoronoiFVM.System(grid, physics; unknown_storage = unknown_storage, assembly = assembly)
enable_species!(sys, 1, [1])
enable_species!(sys, 2, [1])
boundary_neumann!(sys, 1, 1, 0.01)
boundary_dirichlet!(sys, 2, 2, 0.0)
factory = TestFunctionFactory(sys)
tf1 = testfunction(factory, [2], [1])
tf2 = testfunction(factory, [1], [2])
inival = unknowns(sys)
inival[2, :] .= 0.1
inival[1, :] .= 0.1
control = VoronoiFVM.NewtonControl()
control.verbose = verbose
control.damp_initial = 0.1
I1 = 0
p = GridVisualizer(; Plotter = Plotter, layout = (2, 1))
for xeps in [1.0, 0.1, 0.01]
eps = [xeps, xeps]
U = solve(sys; inival, control)
I1 = integrate(sys, tf1, U)
coord = coordinates(grid)
inival .= U
scalarplot!(p[1, 1], grid, U[1, :])
scalarplot!(p[2, 1], grid, U[2, :])
reveal(p)
u5 = U[5]
end
return I1[1]
end
using Test
function runtests()
testval = 0.01
@test main(; unknown_storage = :sparse, assembly = :edgewise) ≈ testval
@test main(; unknown_storage = :sparse, assembly = :cellwise) ≈ testval
@test main(; unknown_storage = :dense, assembly = :cellwise) ≈ testval
@test main(; unknown_storage = :dense, assembly = :edgewise) ≈ testval
return nothing
end
end
This page was generated using Literate.jl.