Mercurial > hg > ishara
annotate general/funutils/@function_handle/and.m @ 38:9d24b616bb06
Added function algebra.
author | samer |
---|---|
date | Tue, 29 Jan 2013 15:59:01 +0000 |
parents | |
children | c388f1c70669 |
rev | line source |
---|---|
samer@38 | 1 % and - function combinator, f&g (...) = f(...); return g(...) |
samer@38 | 2 % |
samer@38 | 3 % and :: |
samer@38 | 4 % (A{:} => B{:}), |
samer@38 | 5 % (A{:} => C{:}) |
samer@38 | 6 % -> (A{:} => C{:}). |
samer@38 | 7 % |
samer@38 | 8 % and :: |
samer@38 | 9 % (A{1:N} => B{:}), |
samer@38 | 10 % (A{1:N} => C{1:M}), |
samer@38 | 11 % N:natural, |
samer@38 | 12 % M:natural |
samer@38 | 13 % -> (A{1:N} => C{1:M}). |
samer@38 | 14 function h=and(f,g,nin,nout) |
samer@38 | 15 if nargin<4, nout=nargout(g); end |
samer@38 | 16 if nargin<3, nin=nargin(g); end |
samer@38 | 17 fns = { @q11, @q1n; @qn1, @qnn }; |
samer@38 | 18 h=fns{acount(nin,1),acount(nout,1)}; |
samer@38 | 19 function y=q11(x), f(x); y=g(x); end |
samer@38 | 20 function y=qn1(varargin), f(varargin{:}); y=g(varargin{:}); end |
samer@38 | 21 function varargout=q1n(x), f(x); [varargout{1:nargout}]=g(x); end |
samer@38 | 22 function varargout=qnn(varargin), f(varargin{:}); [varargout{1:nargout}]=g(varargin{:}); end |
samer@38 | 23 end |