On Tue, Jun 3, 2014 at 6:06 AM, Benoit Jacob <jacob.benoi...@gmail.com>
wrote:

>
>
>
> 2014-06-03 3:34 GMT-04:00 Dirk Schulze <dschu...@adobe.com>:
>
>
>> On Jun 2, 2014, at 12:11 AM, Benoit Jacob <jacob.benoi...@gmail.com>
>> wrote:
>>
>> > Objection #6:
>> >
>> > The determinant() method, being in this API the only easy way to get
>> > something that looks roughly like a measure of invertibility, will
>> probably
>> > be (mis-)used as a measure of invertibility. So I'm quite confident
>> that it
>> > has a strong mis-use case. Does it have a strong good use case? Does it
>> > outweigh that? Note that if the intent is precisely to offer some kind
>> of
>> > measure of invertibility, then that is yet another thing that would be
>> best
>> > done with a singular values decomposition (along with solving, and with
>> > computing a polar decomposition, useful for interpolating matrices), by
>> > returning the ratio between the lowest and the highest singular value.
>>
>> Looking at use cases, then determinant() is indeed often used for:
>>
>> * Checking if a matrix is invertible.
>> * Part of actually inverting the matrix.
>> * Part of some decomposing algorithms as the one in CSS Transforms.
>>
>> I should note that the determinant is the most common way to check for
>> invertibility of a matrix and part of actually inverting the matrix. Even
>> Cairo Graphics, Skia and Gecko’s representation of matrix3x3 do use the
>> determinant for these operations.
>>
>
> I didn't say that determinant had no good use case. I said that it had
> more bad use cases than it had good ones. If its only use case if checking
> whether the cofactors formula will succeed in computing the inverse, then
> make that part of the inversion API so you don't compute the determinant
> twice.
>
> Here is a good use case of determinant, except it's bad because it
> computes the determinant twice:
>
>   if (matrix.determinant() != 0) {    // once
>     result = matrix.inverse();         // twice
>   }
>
> If that's the only thing we use the determinant for, then we're better
> served by an API like this, allowing to query success status:
>
>   var matrixInversionResult = matrix.inverse();   // once
>   if (matrixInversionResult.invertible()) {
>     result = matrixInversionResult.inverse();
>   }
>
> Typical bad uses of the determinant as "measures of invertibility"
> typically occur in conjunction with people thinking they do the right thing
> with "fuzzy compares", like this typical bad pattern:
>
>   if (matrix.determinant() < 1e-6) {
>     return error;
>   }
>   result = matrix.inverse();
>
> Multiple things are wrong here:
>
>  1. First, as mentioned above, the determinant is being computed twice
> here.
>
>  2. Second, floating-point scale invariance is broken: floating point
> computations should generally work for all values across the whole exponent
> range, which for doubles goes from 1e-300 to 1e+300 roughly. Take the
> matrix that's 0.01*identity, and suppose we're dealing with 4x4 matrices.
> The determinant of that matrix is 1e-8, so that matrix is incorrectly
> treated as non-invertible here.
>
>  3. Third, if the primary use for the determinant is invertibility and
> inversion is implemented by cofactors (as it would be for 4x4 matrices)
> then in that case only an exact comparison of the determinant to 0 is
> relevant. That's a case where no fuzzy comparison is meaningful. If one
> wanted to guard against cancellation-induced imprecision, one would have to
> look at cofactors themselves, not just at the determinant.
>
> In full generality, the determinant is just the volume of the unit cube
> under the matrix transformation. It is exactly zero if and only if the
> matrix is singular. That doesn't by itself give any interpretation of other
> nonzero values of the determinant, not even "very small" ones.
>
> For special classes of matrices, things are different. Some classes of
> matrices have a specific determinant, for example rotations have
> determinant one, which can be used to do useful things. So in a
> sufficiently advanced or specialized matrix API, the determinant is useful
> to expose. DOMMatrix is special in that it is not advanced and not
> specialized.
>

I agree with your points. Let's drop determinant for now.
If authors start to demand it, we can add it back in later.
_______________________________________________
dev-platform mailing list
dev-platform@lists.mozilla.org
https://lists.mozilla.org/listinfo/dev-platform

Reply via email to