Prebuilt module for commit 9d6aab3802

This commit is contained in:
Paper.js Bot 2016-07-09 11:31:43 +00:00
parent f11458e319
commit 16cd46fcbd
5 changed files with 160 additions and 139 deletions

View file

@ -9,7 +9,7 @@
* *
* All rights reserved. * All rights reserved.
* *
* Date: Sat Jul 9 12:54:17 2016 +0200 * Date: Sat Jul 9 13:28:50 2016 +0200
* *
*** ***
* *
@ -976,11 +976,11 @@ var Numerical = new function() {
} }
function getDiscriminant(a, b, c) { function getDiscriminant(a, b, c) {
function split(a) { function split(v) {
var x = a * 134217729, var x = v * 134217729,
y = a - x, y = v - x,
hi = y + x, hi = y + x,
lo = a - hi; lo = v - hi;
return [hi, lo]; return [hi, lo];
} }
@ -1000,8 +1000,11 @@ var Numerical = new function() {
return D; return D;
} }
function getNormalizationFactor(x) { function getNormalizationFactor() {
return pow(2, -Math.round(log2(x || MACHINE_EPSILON))); var max = Math.max.apply(Math, arguments);
return max && (max < 1e-8 || max > 1e8)
? pow(2, -Math.round(log2(max)))
: 0;
} }
return { return {
@ -1055,48 +1058,51 @@ var Numerical = new function() {
}, },
solveQuadratic: function(a, b, c, roots, min, max) { solveQuadratic: function(a, b, c, roots, min, max) {
var count = 0, var x1, x2 = Infinity;
eMin = min - EPSILON,
eMax = max + EPSILON,
x1, x2 = Infinity,
B = b * -0.5,
D = getDiscriminant(a, B, c);
if (D && abs(D) < MACHINE_EPSILON) {
var f = getNormalizationFactor(abs(a) + abs(B) + abs(c));
a *= f;
b *= f;
c *= f;
B *= f;
D = getDiscriminant(a, B, c);
}
if (abs(a) < EPSILON) { if (abs(a) < EPSILON) {
if (abs(b) < EPSILON) if (abs(b) < EPSILON)
return abs(c) < EPSILON ? -1 : 0; return abs(c) < EPSILON ? -1 : 0;
x1 = -c / b; x1 = -c / b;
} else if (D >= -MACHINE_EPSILON) { } else {
var Q = D < 0 ? 0 : sqrt(D), b *= -0.5;
R = B + (B < 0 ? -Q : Q); var D = getDiscriminant(a, b, c);
if (R === 0) { if (D && abs(D) < MACHINE_EPSILON) {
x1 = c / a; var f = getNormalizationFactor(abs(a), abs(b), abs(c));
x2 = -x1; if (f) {
} else { a *= f;
x1 = R / a; b *= f;
x2 = c / R; c *= f;
D = getDiscriminant(a, b, c);
}
}
if (D >= -MACHINE_EPSILON) {
var Q = D < 0 ? 0 : sqrt(D),
R = b + (b < 0 ? -Q : Q);
if (R === 0) {
x1 = c / a;
x2 = -x1;
} else {
x1 = R / a;
x2 = c / R;
}
} }
} }
if (isFinite(x1) && (min == null || x1 > eMin && x1 < eMax)) var count = 0,
roots[count++] = min == null ? x1 : clamp(x1, min, max); boundless = min == null,
minB = min - EPSILON,
maxB = max + EPSILON;
if (isFinite(x1) && (boundless || x1 > minB && x1 < maxB))
roots[count++] = boundless ? x1 : clamp(x1, min, max);
if (x2 !== x1 if (x2 !== x1
&& isFinite(x2) && (min == null || x2 > eMin && x2 < eMax)) && isFinite(x2) && (boundless || x2 > minB && x2 < maxB))
roots[count++] = min == null ? x2 : clamp(x2, min, max); roots[count++] = boundless ? x2 : clamp(x2, min, max);
return count; return count;
}, },
solveCubic: function(a, b, c, d, roots, min, max) { solveCubic: function(a, b, c, d, roots, min, max) {
var x, b1, c2, var f = getNormalizationFactor(abs(a), abs(b), abs(c), abs(d)),
s = Math.max(abs(a), abs(b), abs(c), abs(d)); x, b1, c2;
if (s < 1e-8 || s > 1e8) { if (f) {
var f = getNormalizationFactor(s);
a *= f; a *= f;
b *= f; b *= f;
c *= f; c *= f;
@ -1142,11 +1148,12 @@ var Numerical = new function() {
} }
} }
} }
var count = Numerical.solveQuadratic(a, b1, c2, roots, min, max); var count = Numerical.solveQuadratic(a, b1, c2, roots, min, max),
boundless = min == null;
if (isFinite(x) && (count === 0 if (isFinite(x) && (count === 0
|| count > 0 && x !== roots[0] && x !== roots[1]) || count > 0 && x !== roots[0] && x !== roots[1])
&& (min == null || x > min - EPSILON && x < max + EPSILON)) && (boundless || x > min - EPSILON && x < max + EPSILON))
roots[count++] = min == null ? x : clamp(x, min, max); roots[count++] = boundless ? x : clamp(x, min, max);
return count; return count;
} }
}; };

89
dist/paper-core.js vendored
View file

@ -9,7 +9,7 @@
* *
* All rights reserved. * All rights reserved.
* *
* Date: Sat Jul 9 12:54:17 2016 +0200 * Date: Sat Jul 9 13:28:50 2016 +0200
* *
*** ***
* *
@ -976,11 +976,11 @@ var Numerical = new function() {
} }
function getDiscriminant(a, b, c) { function getDiscriminant(a, b, c) {
function split(a) { function split(v) {
var x = a * 134217729, var x = v * 134217729,
y = a - x, y = v - x,
hi = y + x, hi = y + x,
lo = a - hi; lo = v - hi;
return [hi, lo]; return [hi, lo];
} }
@ -1000,8 +1000,11 @@ var Numerical = new function() {
return D; return D;
} }
function getNormalizationFactor(x) { function getNormalizationFactor() {
return pow(2, -Math.round(log2(x || MACHINE_EPSILON))); var max = Math.max.apply(Math, arguments);
return max && (max < 1e-8 || max > 1e8)
? pow(2, -Math.round(log2(max)))
: 0;
} }
return { return {
@ -1055,48 +1058,51 @@ var Numerical = new function() {
}, },
solveQuadratic: function(a, b, c, roots, min, max) { solveQuadratic: function(a, b, c, roots, min, max) {
var count = 0, var x1, x2 = Infinity;
eMin = min - EPSILON,
eMax = max + EPSILON,
x1, x2 = Infinity,
B = b * -0.5,
D = getDiscriminant(a, B, c);
if (D && abs(D) < MACHINE_EPSILON) {
var f = getNormalizationFactor(abs(a) + abs(B) + abs(c));
a *= f;
b *= f;
c *= f;
B *= f;
D = getDiscriminant(a, B, c);
}
if (abs(a) < EPSILON) { if (abs(a) < EPSILON) {
if (abs(b) < EPSILON) if (abs(b) < EPSILON)
return abs(c) < EPSILON ? -1 : 0; return abs(c) < EPSILON ? -1 : 0;
x1 = -c / b; x1 = -c / b;
} else if (D >= -MACHINE_EPSILON) { } else {
var Q = D < 0 ? 0 : sqrt(D), b *= -0.5;
R = B + (B < 0 ? -Q : Q); var D = getDiscriminant(a, b, c);
if (R === 0) { if (D && abs(D) < MACHINE_EPSILON) {
x1 = c / a; var f = getNormalizationFactor(abs(a), abs(b), abs(c));
x2 = -x1; if (f) {
} else { a *= f;
x1 = R / a; b *= f;
x2 = c / R; c *= f;
D = getDiscriminant(a, b, c);
}
}
if (D >= -MACHINE_EPSILON) {
var Q = D < 0 ? 0 : sqrt(D),
R = b + (b < 0 ? -Q : Q);
if (R === 0) {
x1 = c / a;
x2 = -x1;
} else {
x1 = R / a;
x2 = c / R;
}
} }
} }
if (isFinite(x1) && (min == null || x1 > eMin && x1 < eMax)) var count = 0,
roots[count++] = min == null ? x1 : clamp(x1, min, max); boundless = min == null,
minB = min - EPSILON,
maxB = max + EPSILON;
if (isFinite(x1) && (boundless || x1 > minB && x1 < maxB))
roots[count++] = boundless ? x1 : clamp(x1, min, max);
if (x2 !== x1 if (x2 !== x1
&& isFinite(x2) && (min == null || x2 > eMin && x2 < eMax)) && isFinite(x2) && (boundless || x2 > minB && x2 < maxB))
roots[count++] = min == null ? x2 : clamp(x2, min, max); roots[count++] = boundless ? x2 : clamp(x2, min, max);
return count; return count;
}, },
solveCubic: function(a, b, c, d, roots, min, max) { solveCubic: function(a, b, c, d, roots, min, max) {
var x, b1, c2, var f = getNormalizationFactor(abs(a), abs(b), abs(c), abs(d)),
s = Math.max(abs(a), abs(b), abs(c), abs(d)); x, b1, c2;
if (s < 1e-8 || s > 1e8) { if (f) {
var f = getNormalizationFactor(s);
a *= f; a *= f;
b *= f; b *= f;
c *= f; c *= f;
@ -1142,11 +1148,12 @@ var Numerical = new function() {
} }
} }
} }
var count = Numerical.solveQuadratic(a, b1, c2, roots, min, max); var count = Numerical.solveQuadratic(a, b1, c2, roots, min, max),
boundless = min == null;
if (isFinite(x) && (count === 0 if (isFinite(x) && (count === 0
|| count > 0 && x !== roots[0] && x !== roots[1]) || count > 0 && x !== roots[0] && x !== roots[1])
&& (min == null || x > min - EPSILON && x < max + EPSILON)) && (boundless || x > min - EPSILON && x < max + EPSILON))
roots[count++] = min == null ? x : clamp(x, min, max); roots[count++] = boundless ? x : clamp(x, min, max);
return count; return count;
} }
}; };

File diff suppressed because one or more lines are too long

89
dist/paper-full.js vendored
View file

@ -9,7 +9,7 @@
* *
* All rights reserved. * All rights reserved.
* *
* Date: Sat Jul 9 12:54:17 2016 +0200 * Date: Sat Jul 9 13:28:50 2016 +0200
* *
*** ***
* *
@ -976,11 +976,11 @@ var Numerical = new function() {
} }
function getDiscriminant(a, b, c) { function getDiscriminant(a, b, c) {
function split(a) { function split(v) {
var x = a * 134217729, var x = v * 134217729,
y = a - x, y = v - x,
hi = y + x, hi = y + x,
lo = a - hi; lo = v - hi;
return [hi, lo]; return [hi, lo];
} }
@ -1000,8 +1000,11 @@ var Numerical = new function() {
return D; return D;
} }
function getNormalizationFactor(x) { function getNormalizationFactor() {
return pow(2, -Math.round(log2(x || MACHINE_EPSILON))); var max = Math.max.apply(Math, arguments);
return max && (max < 1e-8 || max > 1e8)
? pow(2, -Math.round(log2(max)))
: 0;
} }
return { return {
@ -1055,48 +1058,51 @@ var Numerical = new function() {
}, },
solveQuadratic: function(a, b, c, roots, min, max) { solveQuadratic: function(a, b, c, roots, min, max) {
var count = 0, var x1, x2 = Infinity;
eMin = min - EPSILON,
eMax = max + EPSILON,
x1, x2 = Infinity,
B = b * -0.5,
D = getDiscriminant(a, B, c);
if (D && abs(D) < MACHINE_EPSILON) {
var f = getNormalizationFactor(abs(a) + abs(B) + abs(c));
a *= f;
b *= f;
c *= f;
B *= f;
D = getDiscriminant(a, B, c);
}
if (abs(a) < EPSILON) { if (abs(a) < EPSILON) {
if (abs(b) < EPSILON) if (abs(b) < EPSILON)
return abs(c) < EPSILON ? -1 : 0; return abs(c) < EPSILON ? -1 : 0;
x1 = -c / b; x1 = -c / b;
} else if (D >= -MACHINE_EPSILON) { } else {
var Q = D < 0 ? 0 : sqrt(D), b *= -0.5;
R = B + (B < 0 ? -Q : Q); var D = getDiscriminant(a, b, c);
if (R === 0) { if (D && abs(D) < MACHINE_EPSILON) {
x1 = c / a; var f = getNormalizationFactor(abs(a), abs(b), abs(c));
x2 = -x1; if (f) {
} else { a *= f;
x1 = R / a; b *= f;
x2 = c / R; c *= f;
D = getDiscriminant(a, b, c);
}
}
if (D >= -MACHINE_EPSILON) {
var Q = D < 0 ? 0 : sqrt(D),
R = b + (b < 0 ? -Q : Q);
if (R === 0) {
x1 = c / a;
x2 = -x1;
} else {
x1 = R / a;
x2 = c / R;
}
} }
} }
if (isFinite(x1) && (min == null || x1 > eMin && x1 < eMax)) var count = 0,
roots[count++] = min == null ? x1 : clamp(x1, min, max); boundless = min == null,
minB = min - EPSILON,
maxB = max + EPSILON;
if (isFinite(x1) && (boundless || x1 > minB && x1 < maxB))
roots[count++] = boundless ? x1 : clamp(x1, min, max);
if (x2 !== x1 if (x2 !== x1
&& isFinite(x2) && (min == null || x2 > eMin && x2 < eMax)) && isFinite(x2) && (boundless || x2 > minB && x2 < maxB))
roots[count++] = min == null ? x2 : clamp(x2, min, max); roots[count++] = boundless ? x2 : clamp(x2, min, max);
return count; return count;
}, },
solveCubic: function(a, b, c, d, roots, min, max) { solveCubic: function(a, b, c, d, roots, min, max) {
var x, b1, c2, var f = getNormalizationFactor(abs(a), abs(b), abs(c), abs(d)),
s = Math.max(abs(a), abs(b), abs(c), abs(d)); x, b1, c2;
if (s < 1e-8 || s > 1e8) { if (f) {
var f = getNormalizationFactor(s);
a *= f; a *= f;
b *= f; b *= f;
c *= f; c *= f;
@ -1142,11 +1148,12 @@ var Numerical = new function() {
} }
} }
} }
var count = Numerical.solveQuadratic(a, b1, c2, roots, min, max); var count = Numerical.solveQuadratic(a, b1, c2, roots, min, max),
boundless = min == null;
if (isFinite(x) && (count === 0 if (isFinite(x) && (count === 0
|| count > 0 && x !== roots[0] && x !== roots[1]) || count > 0 && x !== roots[0] && x !== roots[1])
&& (min == null || x > min - EPSILON && x < max + EPSILON)) && (boundless || x > min - EPSILON && x < max + EPSILON))
roots[count++] = min == null ? x : clamp(x, min, max); roots[count++] = boundless ? x : clamp(x, min, max);
return count; return count;
} }
}; };

File diff suppressed because one or more lines are too long