view +time/+cdiff/cdiff.m @ 882:14fee299ada2 feature/poroelastic

In Elastic2dVariable: Improve notation for borrowing constants. Update interface constant to match corrected derivation. Tests ok.
author Martin Almquist <malmquist@stanford.edu>
date Fri, 26 Oct 2018 16:35:23 -0700
parents 48b6fb693025
children
line wrap: on
line source

% Takes a step of
%   v_tt = Dv+Ev_t+S
%
%   1/k^2 * (v_next - 2v + v_prev) = Dv  + E 1/(2k)(v_next - v_prev) + S
%
function [v_next, v] = cdiff(v, v_prev, k, D, E, S)
    %   1/k^2 * (v_next - 2v + v_prev) = Dv  + E 1/(2k)(v_next - v_prev) + S
    %       ekv to
    %   A v_next = B v + C v_prev + S
    I = speye(size(D));
    A =  1/k^2 * I - 1/(2*k)*E;
    B =  2/k^2 * I + D;
    C = -1/k^2 * I - 1/(2*k)*E;

    v_next = A\(B*v + C*v_prev + S);
end