Mercurial > hg > octave-nkf
view examples/@polynomial/subsasgn.m @ 17173:3a23cbde59d5
interpft.m: Fix interpolation to preserve spectral symmetry (bug #39566)
* interpft.m: Fix interpolation to preserve spectral symmetry, be compatible
with Matlab. Add test cases.
author | Mike Miller <mtmiller@ieee.org> |
---|---|
date | Sun, 04 Aug 2013 17:27:40 -0400 |
parents | bf6da2fbfa4e |
children | 446c46af4b42 |
line wrap: on
line source
function p = subsasgn (p, s, val) if (length (s) < 1) error ("polynomial: needs index"); endif switch (s(1).type) case "{}" ind = s(1).subs; if (numel (ind) != 1) error ("polynomial: need exactly one index"); else if (length (s) == 1) if (isnumeric (ind{1})) p.poly(ind{1}+1) = val; else p.poly(ind{1}) = val; endif else error ("polynomial: chained subscripts not allowed for {}"); endif endif case "." fld = s(1).subs; if (strcmp (fld, "poly")) if (length (s) == 1) p.poly = val; else p.poly = subsasgn (p.poly, s(2:end), val); endif else error ("@polynomial/subsref: invalid property \"%s\"", fld); endif otherwise error ("invalid subscript type"); endswitch endfunction