2011-03-06 19:50:44 -05:00
|
|
|
|
/*
|
|
|
|
|
* Paper.js
|
|
|
|
|
*
|
|
|
|
|
* This file is part of Paper.js, a JavaScript Vector Graphics Library,
|
|
|
|
|
* based on Scriptographer.org and designed to be largely API compatible.
|
2011-03-07 20:41:50 -05:00
|
|
|
|
* http://paperjs.org/
|
2011-03-06 19:50:44 -05:00
|
|
|
|
* http://scriptographer.org/
|
|
|
|
|
*
|
2011-03-07 20:41:50 -05:00
|
|
|
|
* Distributed under the MIT license. See LICENSE file for details.
|
|
|
|
|
*
|
2011-03-06 19:50:44 -05:00
|
|
|
|
* Copyright (c) 2011, Juerg Lehni & Jonathan Puckey
|
|
|
|
|
* http://lehni.org/ & http://jonathanpuckey.com/
|
|
|
|
|
*
|
2011-03-07 20:41:50 -05:00
|
|
|
|
* All rights reserved.
|
2011-03-06 19:50:44 -05:00
|
|
|
|
*/
|
|
|
|
|
|
2011-03-06 19:21:04 -05:00
|
|
|
|
var Numerical = new function() {
|
2011-03-06 19:40:48 -05:00
|
|
|
|
|
2011-03-06 18:24:33 -05:00
|
|
|
|
var abscissa = [
|
|
|
|
|
-0.5773502692, 0.5773502692,
|
2011-03-06 19:38:33 -05:00
|
|
|
|
-0.7745966692, 0.7745966692, 0,
|
2011-03-06 18:24:33 -05:00
|
|
|
|
-0.8611363116, 0.8611363116, -0.3399810436, 0.3399810436,
|
2011-03-06 19:38:33 -05:00
|
|
|
|
-0.9061798459, 0.9061798459, -0.5384693101, 0.5384693101, 0.0000000000,
|
2011-03-06 18:24:33 -05:00
|
|
|
|
-0.9324695142, 0.9324695142, -0.6612093865, 0.6612093865, -0.2386191861, 0.2386191861,
|
2011-03-06 19:38:33 -05:00
|
|
|
|
-0.9491079123, 0.9491079123, -0.7415311856, 0.7415311856, -0.4058451514, 0.4058451514, 0.0000000000,
|
2011-03-06 18:24:33 -05:00
|
|
|
|
-0.9602898565, 0.9602898565, -0.7966664774, 0.7966664774, -0.5255324099, 0.5255324099, -0.1834346425, 0.1834346425
|
2011-03-07 11:49:02 -05:00
|
|
|
|
],
|
2011-02-26 11:26:54 -05:00
|
|
|
|
|
2011-03-07 11:49:02 -05:00
|
|
|
|
weight = [
|
2011-03-06 19:38:33 -05:00
|
|
|
|
1, 1,
|
2011-03-06 18:24:33 -05:00
|
|
|
|
0.5555555556, 0.5555555556, 0.8888888888,
|
|
|
|
|
0.3478548451, 0.3478548451, 0.6521451549, 0.6521451549,
|
|
|
|
|
0.2369268851, 0.2369268851, 0.4786286705, 0.4786286705, 0.5688888888,
|
|
|
|
|
0.1713244924, 0.1713244924, 0.3607615730, 0.3607615730, 0.4679139346, 0.4679139346,
|
|
|
|
|
0.1294849662, 0.1294849662, 0.2797053915, 0.2797053915, 0.3818300505, 0.3818300505, 0.4179591837,
|
|
|
|
|
0.1012285363, 0.1012285363, 0.2223810345, 0.2223810345, 0.3137066459, 0.3137066459, 0.3626837834, 0.3626837834
|
2011-03-07 11:49:02 -05:00
|
|
|
|
],
|
|
|
|
|
|
|
|
|
|
max = Math.max,
|
|
|
|
|
min = Math.min,
|
|
|
|
|
abs = Math.abs;
|
2011-02-26 11:26:54 -05:00
|
|
|
|
|
2011-03-06 18:24:33 -05:00
|
|
|
|
return {
|
2011-03-06 19:17:32 -05:00
|
|
|
|
TOLERANCE: 10e-6,
|
2011-02-26 11:26:54 -05:00
|
|
|
|
|
2011-03-06 19:40:48 -05:00
|
|
|
|
/**
|
|
|
|
|
* Gauss-Legendre Numerical Integration, ported from Singularity:
|
|
|
|
|
*
|
|
|
|
|
* Copyright (c) 2006-2007, Jim Armstrong (www.algorithmist.net)
|
|
|
|
|
* All Rights Reserved.
|
|
|
|
|
*/
|
2011-03-07 06:12:00 -05:00
|
|
|
|
integrate: function(f, a, b, n) {
|
2011-03-07 11:49:02 -05:00
|
|
|
|
n = min(max(n, 2), 8);
|
2011-03-06 18:24:33 -05:00
|
|
|
|
|
|
|
|
|
var l = n == 2 ? 0 : n * (n - 1) / 2 - 1,
|
|
|
|
|
sum = 0,
|
|
|
|
|
mul = 0.5 * (b - a),
|
|
|
|
|
ab2 = mul + a;
|
|
|
|
|
for(var i = 0; i < n; i++)
|
|
|
|
|
sum += f(ab2 + mul * abscissa[l + i]) * weight[l + i];
|
2011-02-26 11:26:54 -05:00
|
|
|
|
|
2011-03-06 18:24:33 -05:00
|
|
|
|
return mul * sum;
|
2011-03-06 18:25:57 -05:00
|
|
|
|
},
|
|
|
|
|
|
2011-03-06 19:40:48 -05:00
|
|
|
|
/**
|
|
|
|
|
* Van Wijngaarden–Dekker–Brent method for root finding, implementation
|
|
|
|
|
* based on Numerical Recipes in C
|
|
|
|
|
*/
|
2011-03-07 06:59:43 -05:00
|
|
|
|
findRoot: function(f, a, b, n, tol) {
|
2011-03-06 18:25:57 -05:00
|
|
|
|
var c = b, d = 0, e = 0,
|
|
|
|
|
fa = f(a),
|
|
|
|
|
fb = f(b),
|
|
|
|
|
fc = fb;
|
|
|
|
|
|
2011-03-07 06:59:43 -05:00
|
|
|
|
for (var i = 0; i < n; i++) {
|
2011-03-06 21:43:07 -05:00
|
|
|
|
if ((fb > 0 && fc > 0) || (fb < 0 && fc < 0)) {
|
2011-03-06 18:25:57 -05:00
|
|
|
|
c = a;
|
|
|
|
|
fc = fa;
|
|
|
|
|
e = d = b - a;
|
|
|
|
|
}
|
2011-03-07 11:49:02 -05:00
|
|
|
|
if (abs(fc) < abs(fb)) {
|
2011-03-06 18:25:57 -05:00
|
|
|
|
a = b;
|
|
|
|
|
b = c;
|
|
|
|
|
c = a;
|
|
|
|
|
fa = fb;
|
|
|
|
|
fb = fc;
|
|
|
|
|
fc = fa;
|
|
|
|
|
}
|
2011-03-07 11:49:02 -05:00
|
|
|
|
var tol1 = 2 * Number.MIN_VALUE * abs(b) + 0.5 * tol,
|
2011-03-06 18:25:57 -05:00
|
|
|
|
xm = 0.5 * (c - b);
|
2011-03-07 11:49:02 -05:00
|
|
|
|
if (abs(xm) <= tol1 || fb == 0) {
|
2011-03-06 18:25:57 -05:00
|
|
|
|
return b;
|
|
|
|
|
}
|
2011-03-07 11:49:02 -05:00
|
|
|
|
if (abs(e) >= tol1 && abs(fa) > abs(fb)) {
|
2011-03-06 18:25:57 -05:00
|
|
|
|
var p, q, r,
|
|
|
|
|
s = fb / fa;
|
|
|
|
|
if (a == c) {
|
2011-03-06 21:43:07 -05:00
|
|
|
|
p = 2 * xm * s;
|
|
|
|
|
q = 1 - s;
|
2011-03-06 18:25:57 -05:00
|
|
|
|
} else {
|
|
|
|
|
q = fa / fc;
|
|
|
|
|
r = fb / fc;
|
2011-03-06 21:43:07 -05:00
|
|
|
|
p = s * (2 * xm * q * (q - r) - (b - a) * (r - 1));
|
|
|
|
|
q = (q - 1) * (r - 1) * (s - 1);
|
2011-03-06 18:25:57 -05:00
|
|
|
|
}
|
2011-03-06 21:43:07 -05:00
|
|
|
|
if (p > 0)
|
2011-03-06 18:25:57 -05:00
|
|
|
|
q = -q;
|
2011-03-07 11:49:02 -05:00
|
|
|
|
p = abs(p);
|
|
|
|
|
var min1 = 3 * xm * q - abs(tol1 * q),
|
|
|
|
|
min2 = abs(e * q);
|
2011-03-06 21:43:07 -05:00
|
|
|
|
if (2 * p < (min1 < min2 ? min1 : min2)) {
|
2011-03-06 18:25:57 -05:00
|
|
|
|
e = d;
|
|
|
|
|
d = p / q;
|
|
|
|
|
} else {
|
|
|
|
|
d = xm;
|
|
|
|
|
e = d;
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
d = xm;
|
|
|
|
|
e = d;
|
|
|
|
|
}
|
|
|
|
|
a = b;
|
|
|
|
|
fa = fb;
|
2011-03-07 11:49:02 -05:00
|
|
|
|
if (abs(d) > tol1)
|
2011-03-06 18:25:57 -05:00
|
|
|
|
b += d;
|
|
|
|
|
else
|
2011-03-07 11:49:02 -05:00
|
|
|
|
b += xm >= 0 ? abs(tol1) : -abs(tol1);
|
2011-03-06 18:25:57 -05:00
|
|
|
|
fb = f(b);
|
|
|
|
|
}
|
|
|
|
|
return b;
|
2011-02-26 11:26:54 -05:00
|
|
|
|
}
|
|
|
|
|
}
|
2011-03-03 11:32:39 -05:00
|
|
|
|
};
|