algorithms for 'invert', was: program works with maxima 5.29.1 but freezes with maxima 5.30.0



I believe adjoint was chosen as the default because it works well in the
symbolic case.

According to Henry, LU is better for floats (but not rationals).  Perhaps
the right policy is: if matrix is entirely float or bfloat, use LU,
otherwise use adjoint.

If adjoint produces simpler results, it sounds like the right algorithm for
symbolic matrices regardless of size, as a first cut at least.  An unwieldy
symbolic result returned fast is probably less useful to most users than a
tractable symbolic result that takes longer.

Perhaps there are more sophisticated policies possible (depending on
sparseness or proportion of symbolic vs. small integer entries, etc.), but
it seems like a good start.

           -s



On Fri, Apr 19, 2013 at 12:27 PM, Robert Dodier <robert.dodier at gmail.com>wrote:

> On 2013-04-19, Henry Baker <hbaker1 at pipeline.com> wrote:
>
> > So it depends upon what you're trying to achieve, and which fields/rings
> are involved.
>
> > The advantages of certain 'efficient' matrix operations like LU quickly
> disappear when
> > operating with rings other than floating point numbers.
>
> Can we derive from these considerations a policy for automatically
> choosing which algorithm to use? E.g. if small then adjoint method, else
> if numerical then LU, otherwise print a warning message ("umm, it might
> or might not work") and use either one. Each method should be available
> as a separate function (e.g. invert_by_adjoint) so that the user can
> explicitly choose one or another.
>
> I realize that such heuristics are not foolproof, but it would be an
> improvement on the current situation, and in any event it is
> unreasonable to expect users to have any idea how to choose among
> algorithms.
>
> best
>
> Robert Dodier
>
> _______________________________________________
> Maxima mailing list
> Maxima at math.utexas.edu
> http://www.math.utexas.edu/mailman/listinfo/maxima
>