Skip to content

Using IncompressibleNavierStokes in SciML

The SciML organization is a collection of tools for solving equations and modeling systems. It has a coherent development principle, unified APIs over large collections of equation solvers, pervasive differentiability and sensitivity analysis, and features many of the highest performance and parallel implementations one can find.

In particular, DifferentialEquations.jl contains tools to solve differential equations defined as dudt=f(u,t) that include a large collection of solvers, sensitivity analysis, and more.

Using IncompressibleNavierStokes it is possible to write the momentum equations without the pressure by explicitly solving the discrete Poisson equation and obtaining:

duhdt=(IGL1WM)(F(uh)yG)GL1WdyMdt=f(uh).

The derivation and the drawbacks of this approach are discussed in the documentation.

This projected right-hand side can be used in the SciML solvers to solve the Navier-Stokes equations. The following example shows how to use the SciML solvers to solve the ODEs obtained from the Navier-Stokes equations.

OrdinaryDiffEqTsit5

We here use the explicit solver Tsit5 from OrdinaryDiffEqTsit5 directly to skip loading all the toolchains for implicit solvers, which takes a while to install on GitHub.

julia
using OrdinaryDiffEqTsit5
using IncompressibleNavierStokes
ax = range(0, 1, 101)
setup = Setup(; x = (ax, ax), Re = 500.0)
psolver = default_psolver(setup)
f = create_right_hand_side(setup, psolver)
u0 = random_field(setup)
tspan = (0.0, 1.0)     # time span where to solve.
problem = ODEProblem(f, u0, tspan) #SciMLBase.ODEProblem
sol = solve(problem, Tsit5(), reltol = 1e-8, abstol = 1e-8) # sol: SciMLBase.ODESolution
retcode: Success
Interpolation: specialized 4th order "free" interpolation
t: 223-element Vector{Float64}:
 0.0
 0.0017233135286362192
 0.0025196501829080923
 0.0038011153511746977
 0.00488553713804054
 0.0061389163000040185
 0.007365181326216588
 0.008659561731735106
 0.00996600143115375
 0.01130764831934155

 0.9069553647962909
 0.9185914073970664
 0.9303476594191158
 0.9422237820732332
 0.9542194541100989
 0.9663339226202735
 0.9785663156283005
 0.9909156420050773
 1.0
u: 223-element Vector{Array{Float64, 3}}:
 [-0.016585188699801495 -0.0798801430638239 … -0.016585188699801495 -0.0798801430638239; -0.07635757697545345 -0.12467960646199033 … -0.07635757697545345 -0.12467960646199033; … ; -0.016585188699801495 -0.0798801430638239 … -0.016585188699801495 -0.0798801430638239; -0.07635757697545345 -0.12467960646199033 … -0.07635757697545345 -0.12467960646199033;;; -1.6266332458385584 -1.4846748915627952 … -1.6266332458385584 -1.4846748915627952; -1.2632298239297675 -1.2184303605315905 … -1.2632298239297675 -1.2184303605315905; … ; -1.6266332458385584 -1.4846748915627952 … -1.6266332458385584 -1.4846748915627952; -1.2632298239297675 -1.2184303605315905 … -1.2632298239297675 -1.2184303605315905]
 [-0.03894323312859317 -0.06491129062044468 … -0.03894323312859317 -0.06491129062044468; -0.08916331290283666 -0.11837646938331858 … -0.09897101481281162 -0.10839976652458264; … ; -0.03894323312859317 -0.06844803521297667 … -0.038931169036750396 -0.06491129062044468; -0.08916331290283666 -0.10839976652458264 … -0.08916331290283666 -0.10839976652458264;;; -1.5796136020732412 -1.4406554167493064 … -1.5796136020732412 -1.4406554167493064; -1.2418162722700767 -1.2415838946872053 … -1.2915123288575576 -1.203760426561636; … ; -1.5796136020732412 -1.475888364849297 … -1.6257608499763472 -1.4406554167493064; -1.2418162722700767 -1.203760426561636 … -1.2418162722700767 -1.203760426561636]
 [-0.04664030769254039 -0.05543029254672245 … -0.04664030769254039 -0.05543029254672245; -0.09359430166274557 -0.11422503352813275 … -0.10804990892231012 -0.09931758313147841; … ; -0.04664030769254039 -0.06151344736256365 … -0.04745392663862116 -0.05543029254672245; -0.09359430166274557 -0.09931758313147841 … -0.09359430166274557 -0.09931758313147841;;; -1.5570309932541435 -1.41962667258555 … -1.5570309932541435 -1.41962667258555; -1.2313515590520756 -1.2511603318796565 … -1.3038719180452365 -1.1965328710092051; … ; -1.5570309932541435 -1.4705273424132241 … -1.624281816377544 -1.41962667258555; -1.2313515590520756 -1.1965328710092051 … -1.2313515590520756 -1.1965328710092051]
 [-0.055436082522253 -0.036875964164352557 … -0.055436082522253 -0.036875964164352557; -0.09863284062284612 -0.1060204416446936 … -0.12082591867629364 -0.08264656143133597; … ; -0.055436082522253 -0.04832698100311482 … -0.05877527614372206 -0.036875964164352557; -0.09863284062284612 -0.08264656143133597 … -0.09863284062284612 -0.08264656143133597;;; -1.5195882535588283 -1.3847719704209072 … -1.5195882535588283 -1.3847719704209072; -1.2137695656755425 -1.2650047472029753 … -1.3226982078445648 -1.1842250360576716; … ; -1.5195882535588283 -1.460130062015837 … -1.6204050725105577 -1.3847719704209072; -1.2137695656755425 -1.1842250360576716 … -1.2137695656755425 -1.1842250360576716]
 [-0.05937302763569471 -0.018099005799648682 … -0.05937302763569471 -0.018099005799648682; -0.10080322855419457 -0.09771081329655291 … -0.1298760782546129 -0.06658080912268888; … ; -0.05937302763569471 -0.03535407031521114 … -0.06607085727586144 -0.018099005799648682; -0.10080322855419457 -0.06658080912268888 … -0.10080322855419457 -0.06658080912268888;;; -1.4868575244853455 -1.3542152796614213 … -1.4868575244853455 -1.3542152796614213; -1.1981788788089458 -1.275158363661718 … -1.3375151066430715 -1.1730880108081303; … ; -1.4868575244853455 -1.4496003967766422 … -1.6156365174440754 -1.3542152796614213; -1.1981788788089458 -1.1730880108081303 … -1.1981788788089458 -1.1730880108081303]
 [-0.059890779340223486 0.0069658616274991675 … -0.059890779340223486 0.0069658616274991675; -0.10084043223038781 -0.08668328981377806 … -0.13835109642183094 -0.04581863477392755; … ; -0.059890779340223486 -0.018474901117995053 … -0.07194471423991697 0.0069658616274991675; -0.10084043223038781 -0.04581863477392755 … -0.10084043223038781 -0.04581863477392755;;; -1.44784688114581 -1.317579581576418 … -1.44784688114581 -1.317579581576418; -1.1793407255623218 -1.2850495414723802 … -1.3532579301681749 -1.1592986492600796; … ; -1.44784688114581 -1.4354322222910563 … -1.6083772579058624 -1.317579581576418; -1.1793407255623218 -1.1592986492600796 … -1.1793407255623218 -1.1592986492600796]
 [-0.05621953089482402 0.03480860474047051 … -0.05621953089482402 0.03480860474047051; -0.09825357090404405 -0.07456009742847991 … -0.14462919671152924 -0.023286621779307407; … ; -0.05621953089482402 -0.00019673422647761493 … -0.07511218974037769 0.03480860474047051; -0.09825357090404405 -0.023286621779307407 … -0.09825357090404405 -0.023286621779307407;;; -1.4084601943451234 -1.2802668382978164 … -1.4084601943451234 -1.2802668382978164; -1.1600465461086653 -1.2927604581674998 … -1.3671238213695145 -1.1447595494063996; … ; -1.4084601943451234 -1.4194898543848213 … -1.5994247894845781 -1.2802668382978164; -1.1600465461086653 -1.1447595494063996 … -1.1600465461086653 -1.1447595494063996]
 [-0.04790734205150607 0.06755488556111933 … -0.04790734205150607 0.06755488556111933; -0.09266771567395471 -0.06049333116292045 … -0.14916776801452172 0.0028001812694814047; … ; -0.04790734205150607 0.02077455123572897 … -0.07579657203443532 0.06755488556111933; -0.09266771567395471 0.0028001812694814047 … -0.09266771567395471 0.0028001812694814047;;; -1.3655741696294543 -1.239200724186793 … -1.3655741696294543 -1.239200724186793; -1.138728494956029 -1.2987405675021189 … -1.3800084499007808 -1.1281791590239638; … ; -1.3655741696294543 -1.400437247980388 … -1.587963020231745 -1.239200724186793; -1.138728494956029 -1.1281791590239638 … -1.138728494956029 -1.1281791590239638]
 [-0.034983521397125454 0.1038751280955874 … -0.034983521397125454 0.1038751280955874; -0.08404097967266246 -0.045139425570053224 … -0.15166837519815793 0.03143448487229207; … ; -0.034983521397125454 0.04346882847363012 … -0.07385327544207582 0.1038751280955874; -0.08404097967266246 0.03143448487229207 … -0.08404097967266246 0.03143448487229207;;; -1.3209139386454891 -1.1959090440286744 … -1.3209139386454891 -1.1959090440286744; -1.1161844697416272 -1.302486211946443 … -1.3910944659901396 -1.110046523650576; … ; -1.3209139386454891 -1.3789170092147638 … -1.5742873893169946 -1.1959090440286744; -1.1161844697416272 -1.110046523650576 … -1.1161844697416272 -1.110046523650576]
 [-0.01710098760669825 0.14434125454040517 … -0.01710098760669825 0.14434125454040517; -0.0720683348969286 -0.028335230526979907 … -0.15217888985758 0.063137976079751; … ; -0.01710098760669825 0.06814724577500576 … -0.06926611763798662 0.14434125454040517; -0.0720683348969286 0.063137976079751 … -0.0720683348969286 0.063137976079751;;; -1.2736001326806214 -1.1494470572966533 … -1.2736001326806214 -1.1494470572966533; -1.0919123408194347 -1.3039040954747683 … -1.4003865717767683 -1.0898467092777868; … ; -1.2736001326806214 -1.3544715575811395 … -1.558045484903844 -1.1494470572966533; -1.0919123408194347 -1.0898467092777868 … -1.0919123408194347 -1.0898467092777868]

 [3.7371334290296714 3.9767663781132416 … 3.7371334290296714 3.9767663781132416; 4.187732294854696 -0.07706756796669216 … -0.029990381725024336 4.659417494512923; … ; 3.7371334290296714 -0.08857837995873055 … -0.04174639916530164 3.9767663781132416; 4.187732294854696 4.659417494512923 … 4.187732294854696 4.659417494512923;;; -2.945632993639145 -2.762724965501477 … -2.945632993639145 -2.762724965501477; -2.5600062274735533 0.08740556567089611 … 0.09891637766291235 -2.4532500879911234; … ; -2.945632993639145 -0.012446689227437458 … -0.0002454586256852281 -2.762724965501477; -2.5600062274735533 -2.4532500879911234 … -2.5600062274735533 -2.4532500879911234]
 [3.739888566252971 3.9803193573597264 … 3.739888566252971 3.9803193573597264; 4.194550141824548 -0.0809305609928456 … -0.03607264182531674 4.667240874351677; … ; 3.739888566252971 -0.09173495368866666 … -0.047152653326400805 3.9803193573597264; 4.194550141824548 4.667240874351677 … 4.194550141824548 4.667240874351677;;; -2.938297457889789 -2.7497803839111703 … -2.938297457889789 -2.7497803839111703; -2.555189926681856 0.08681788465648174 … 0.09762227735228081 -2.4431925470118414; … ; -2.938297457889789 -0.011934906642453126 … -0.00047216238663632906 -2.7497803839111703; -2.555189926681856 -2.4431925470118414 … -2.555189926681856 -2.4431925470118414]
 [3.742568622523424 3.9837513817130406 … 3.742568622523424 3.9837513817130406; 4.201073590339989 -0.08486570170640399 … -0.0421813004440543 4.6747102084119865; … ; 3.742568622523424 -0.0949240122515861 … -0.052551050622440004 3.9837513817130406; 4.201073590339989 4.6747102084119865 … 4.201073590339989 4.6747102084119865;;; -2.9305850554682897 -2.736710918838763 … -2.9305850554682897 -2.736710918838763; -2.5500644387116993 0.08602720329304174 … 0.09608551383820294 -2.433073017018784; … ; -2.9305850554682897 -0.01155381496451957 … -0.0008793820996299347 -2.736710918838763; -2.5500644387116993 -2.433073017018784 … -2.5500644387116993 -2.433073017018784]
 [3.7451564620240307 3.9870452930601084 … 3.7451564620240307 3.9870452930601084; 4.20728998012033 -0.08885976350512965 … -0.04830182929303653 4.681813590786703; … ; 3.7451564620240307 -0.09813623326602718 … -0.0579298029823557 3.9870452930601084; 4.20728998012033 4.681813590786703 … 4.20728998012033 4.681813590786703;;; -2.922505402386551 -2.7235277456308835 … -2.922505402386551 -2.7235277456308835; -2.544638518501101 0.08503730404293997 … 0.09431377380381596 -2.422900642686562; … ; -2.922505402386551 -0.011298484274614723 … -0.0014578487618904937 -2.7235277456308835; -2.544638518501101 -2.422900642686562 … -2.544638518501101 -2.422900642686562]
 [3.74763581102202 3.990184950189635 … 3.74763581102202 3.990184950189635; 4.21318795127207 -0.09289888219041696 … -0.05441909173846192 4.68854057161344; … ; 3.74763581102202 -0.10136173838152558 … -0.06327664714098458 3.990184950189635; 4.21318795127207 4.68854057161344 … 4.21318795127207 4.68854057161344;;; -2.9140698507553777 -2.710243293876679 … -2.9140698507553777 -2.710243293876679; -2.538922185617602 0.08385233714331942 … 0.09231519333440673 -2.4126853422466215; … ; -2.9140698507553777 -0.011164165836851305 … -0.002198241395218843 -2.710243293876679; -2.538922185617602 -2.4126853422466215 … -2.538922185617602 -2.4126853422466215]
 [3.7499912128322554 3.9931551588649117 … 3.7499912128322554 3.9931551588649117; 4.218757275644795 -0.09696855640360495 … -0.060517259074199456 4.694881934962609; … ; 3.7499912128322554 -0.10459012203407998 … -0.0685788135466407 3.9931551588649117; 4.218757275644795 4.694881934962609 … 4.218757275644795 4.694881934962609;;; -2.905291851526564 -2.6968717371773376 … -2.905291851526564 -2.6968717371773376; -2.5329269625189434 0.08247680335935312 … 0.09009836898980707 -2.402438188178302; … ; -2.905291851526564 -0.011146380522802143 … -0.0030912654977244755 -2.6968717371773376; -2.5329269625189434 -2.402438188178302 … -2.5329269625189434 -2.402438188178302]
 [3.7522081606134576 3.99594182278191 … 3.7522081606134576 3.99594182278191; 4.223989092353326 -0.10105389388208459 … -0.06658011919128812 4.700829940062144; … ; 3.7522081606134576 -0.10781067492233996 … -0.07382333355495072 3.99594182278191; 4.223989092353326 4.700829940062144 … 4.223989092353326 4.700829940062144;;; -2.8961867626984286 -2.683428605686987 … -2.8961867626984286 -2.683428605686987; -2.5266657352900204 0.08091547939178073 … 0.08767226043201534 -2.392171110351225; … ; -2.8961867626984286 -0.01124098139892505 … -0.004127763440557729 -2.683428605686987; -2.5266657352900204 -2.392171110351225 … -2.5266657352900204 -2.392171110351225]
 [3.754273166467631 3.9985320080877456 … 3.754273166467631 3.9985320080877456; 4.228875966843709 -0.10513974251661155 … -0.07259122096216204 4.706378363016628; … ; 3.754273166467631 -0.11101250986480429 … -0.07899719290437889 3.9985320080877456; 4.228875966843709 4.706378363016628 … 4.228875966843709 4.706378363016628;;; -2.8867718218802882 -2.6699307156297527 … -2.8867718218802882 -2.6699307156297527; -2.520152718644898 0.07917337148580232 … 0.08504613883397427 -2.381896844696191; … ; -2.8867718218802882 -0.01144421386661866 … -0.005298805820882011 -2.6699307156297527; -2.520152718644898 -2.381896844696191 … -2.520152718644898 -2.381896844696191]
 [3.7556769369626397 4.000291283535316 … 3.7556769369626397 4.000291283535316; 4.232220718992431 -0.10811269609448647 … -0.07693530569503322 4.710172096258441; … ; 3.7556769369626397 -0.11333076000678784 … -0.08272049747832054 4.000291283535316; 4.232220718992431 4.710172096258441 … 4.232220718992431 4.710172096258441;;; -2.8797171539872792 -2.6600571584118757 … -2.8797171539872792 -2.6600571584118757; -2.515250171572372 0.07779106270950507 … 0.08300912662178553 -2.3744029721929407; … ; -2.8797171539872792 -0.01165914092958288 … -0.006233246691983851 -2.6600571584118757; -2.515250171572372 -2.3744029721929407 … -2.515250171572372 -2.3744029721929407]

Alternatively, it is also possible to use an in-place formulation

julia
f!(du,u,p,t) = right_hand_side!(du, u, Ref([setup, psolver]), t)
u = similar(u0)
du = similar(u0)
p = nothing
t = 0.0
f!(du,u,p,t)

that is usually faster than the out-of-place formulation.

You can look here for more information on how to use the SciML solvers and all the options available.

API

IncompressibleNavierStokes.create_right_hand_side Method
julia
create_right_hand_side(
    setup,
    psolver
) -> IncompressibleNavierStokes.var"#right_hand_side#343"
create_right_hand_side(setup, psolver)

Creates a function that computes the right-hand side of the Navier-Stokes equations for a given setup and pressure solver.

Arguments

  • setup: The simulation setup containing grid and boundary conditions.

  • psolver: The pressure solver to be used.

Returns

A function that computes the right-hand side of the Navier-Stokes equations.

source

IncompressibleNavierStokes.right_hand_side! Method
julia
right_hand_side!(dudt, u, params_ref, t)
right_hand_side!(dudt, u, params_ref, t)

Computes the right-hand side of the Navier-Stokes equations in-place.

Arguments

  • dudt: The array to store the computed right-hand side.

  • u: The current velocity field.

  • params_ref: A reference to the parameters containing the setup and pressure solver.

  • t: The current time.

Returns

Nothing. The result is stored in dudt.

source