Mercurial > repos > public > sbplib
view copyWithDefault.m @ 1012:1e437c9e5132 feature/advectionRV
Create residual viscosity package +rv and generalize the ResidualViscosity class
- Generalize residual viscosity, by passing user-defined flux and calculating the time derivative outside of the update.
- Create separate RungekuttaRV specifically using interior RV updates
- Separate the artifical dissipation operator from the scheme AdvectionRV1D so that the same scheme can be reused for creating the diff op used by the ResidualViscosity class
author | Vidar Stiernström <vidar.stiernstrom@it.uu.se> |
---|---|
date | Wed, 05 Dec 2018 13:44:10 +0100 |
parents | 499653b553b8 |
children |
line wrap: on
line source
% Copy the struct src to dest with default values from default % dest = copyWithDefault(src, default) function dest = copyWithDefault(src, default) % src does not have a value => use default if isempty(src) dest = default; return end % src has a value and is not a struct => use src % src has a value and default is not a struct => use src if ~isstruct(src) || ~isstruct(default) dest = src; return end % src has a value and is a struct => add all default fields dest = src; fn = fieldnames(default); for i = 1:length(fn) if isfield(src, fn{i}) srcField = src.(fn{i}); else srcField = []; end dest.(fn{i}) = copyWithDefault(srcField, default.(fn{i})); end end