Hi mathieumorlighem !
I hope it's okay to resurrect this old thread rather than make a new one!
I have been playing with this, but I'm running into some issues. I have a transient model that works fine when md.transient.ismovingfront = 0
. However, when I set md.transient.ismovingfront = 1
and specify md.levelset.spclevelset
for each timestep, the model fails on the second iteration.
I get this error and I'm not sure what this might mean, or how best to go about rectifying it...
call computational core:
iteration 1/300 time [yr]: 0.08 (time step: 0.08)
computing new velocity
computing slope of levelset function...
computing calving and undercutting
computing new ice front position
extrapolation of Vx:
extrapolation of Vy:
extrapolation of Thickness:
call computational core:
looking for icebergs to kill
reinitializing level set after killing 3 icebergs
updating boundary conditions...
computing basal mass balance
computing mass transport
call computational core
computing new grounding line position
updating vertices positions
computing transient requested outputs
saving temporary results
iteration 2/300 time [yr]: 0.17 (time step: 0.08)
computing new velocity
solver residue too high!: norm(KU-F)/norm(F)=0.00543691 > 1e-06 (md.settings.solver_residue_threshold)
WARNING: Solver failed, Trying Recovery Mode
solver residue too high!: norm(KU-F)/norm(F)=0.00543691 > 1e-06 (md.settings.solver_residue_threshold)
[5] ??? Error using ==> ./modules/Solverx/Solverx.cpp:32
[5] Solverx error message: Recovery solver failed...
[18] ??? Error using ==> ./modules/Solverx/Solverx.cpp:32
[18] Solverx error message: Recovery solver failed...
Themd.transient.levelset
object is simply an array of ice masks (one for each timestep), with -1 where ice exists and -1 for ocean nodes. md.levelset
looks like this (default values used):
Level-set parameters:
stabilization : 1 -- 0: no, 1: artificial_diffusivity, 2: streamline upwinding
spclevelset : (53149x300) -- Levelset constraints (NaN means no constraint)
reinit_frequency : 5 -- Amount of time steps after which the levelset function in re-initialized
kill_icebergs : 1 -- remove floating icebergs to prevent rigid body motions (1: true, 0: false)
migration_max : 1000000000000 -- maximum allowed migration rate (m/a)
fe : 'P1' -- Finite Element type: 'P1' (default), or 'P2'
Any tips would be appreciated!
Cheers,
Lawrence