Mercurial > repos > public > sbplib
view +multiblock/evalOn.m @ 884:7d4f57725192 feature/poroelastic
Add a getBoundaryOperator method in multiblock.DiffOp that uses the the diffop get_boundary_operator method rather than its properties. Werpers might not like this.
author | Martin Almquist <malmquist@stanford.edu> |
---|---|
date | Fri, 02 Nov 2018 10:47:03 -0700 |
parents | 442ec6c77c3f |
children | 92dc0a3b5d5d |
line wrap: on
line source
% Evaluate different function handle for each block in a multiblock.Grid % Function handles may optionaly take a time argument % f -- cell array of function handles % f{i} = f_i(t,x,y,...) % t -- optional time point. If not specified, it is assumed that the functions take only spatial arguments. function gf = evalOn(g, f, t) assertType(g, 'multiblock.Grid'); assertType(f, 'cell'); default_arg('t', []); grids = g.grids; nBlocks = length(grids); gf = cell(nBlocks, 1); if isempty(t) for i = 1:nBlocks gf{i} = grid.evalOn(grids{i}, f{i}); end else for i = 1:nBlocks gf{i} = grid.evalOn(grids{i}, @(varargin)f{i}(t,varargin{:})); end end gf = blockmatrix.toMatrix(gf); end