view examples/code/@polynomial/subsasgn.m @ 19631:aee5fea8a03e

compute condition number when solving triangular systems (bug #43875) * dMatrix.cc (Matrix::solve): Pass true for calc_rcond in calls to utsolve and ltsolve. * CMatrix.cc (ComplexMatrix::solve): Likewise. * fCMatrix.cc (FloatComplexMatrix::solve): Likewise. * fMatrix.cc (FloatMatrix::solve): Likeiwse.
author John W. Eaton <jwe@octave.org>
date Fri, 26 Dec 2014 14:35:46 -0500
parents c8240a60dd01
children 0e1f5a750d00
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