Mercurial > repos > public > sbplib
view +time/+cdiff/cdiff.m @ 86:3c39dd714fb6
In Curve: Added numerical FD differentiation if derivative is not supplied. Added arc length computation based on the derivative. Added arc length parameterization (but this function is very slow.). In +util: Added fzero_vec.m and integral_vec.m, which call fzero and integral but take vector arguments.
author | Martin Almquist <martin.almquist@it.uu.se> |
---|---|
date | Sun, 29 Nov 2015 14:28:53 +0100 |
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