dgeoutils 2.4.0 → 2.4.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/DCircle.js +52 -63
- package/dist/cjs/DLine.js +132 -181
- package/dist/cjs/DNumbers.js +16 -20
- package/dist/cjs/DPlane.js +56 -79
- package/dist/cjs/DPoint.js +240 -338
- package/dist/cjs/DPolygon.js +635 -1151
- package/dist/cjs/DPolygonLoop.js +138 -143
- package/dist/cjs/FastSearch.js +13 -37
- package/dist/cjs/TraceMatrix.js +87 -139
- package/dist/cjs/utils.js +61 -103
- package/package.json +2 -2
package/dist/cjs/DPlane.js
CHANGED
|
@@ -1,30 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __read = (this && this.__read) || function (o, n) {
|
|
3
|
-
var m = typeof Symbol === "function" && o[Symbol.iterator];
|
|
4
|
-
if (!m) return o;
|
|
5
|
-
var i = m.call(o), r, ar = [], e;
|
|
6
|
-
try {
|
|
7
|
-
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
|
|
8
|
-
}
|
|
9
|
-
catch (error) { e = { error: error }; }
|
|
10
|
-
finally {
|
|
11
|
-
try {
|
|
12
|
-
if (r && !r.done && (m = i["return"])) m.call(i);
|
|
13
|
-
}
|
|
14
|
-
finally { if (e) throw e.error; }
|
|
15
|
-
}
|
|
16
|
-
return ar;
|
|
17
|
-
};
|
|
18
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
19
3
|
exports.DPlane = void 0;
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
if (p1 === void 0) { p1 = DPoint_1.DPoint.zero(); }
|
|
26
|
-
if (p2 === void 0) { p2 = DPoint_1.DPoint.zero(); }
|
|
27
|
-
if (p3 === void 0) { p3 = DPoint_1.DPoint.zero(); }
|
|
4
|
+
const DPoint_1 = require("./DPoint");
|
|
5
|
+
const utils_1 = require("./utils");
|
|
6
|
+
const DNumbers_1 = require("./DNumbers");
|
|
7
|
+
class DPlane {
|
|
8
|
+
constructor(a, b, c, d, p1 = DPoint_1.DPoint.zero(), p2 = DPoint_1.DPoint.zero(), p3 = DPoint_1.DPoint.zero()) {
|
|
28
9
|
this.a = a;
|
|
29
10
|
this.b = b;
|
|
30
11
|
this.c = c;
|
|
@@ -33,7 +14,7 @@ var DPlane = (function () {
|
|
|
33
14
|
this.p2 = p2;
|
|
34
15
|
this.p3 = p3;
|
|
35
16
|
}
|
|
36
|
-
|
|
17
|
+
static find(p1, p2, p3) {
|
|
37
18
|
if (p1.x === p2.x && p2.x === p3.x) {
|
|
38
19
|
return new DPlane(1, 0, 0, -p1.x, p1, p2, p3);
|
|
39
20
|
}
|
|
@@ -43,90 +24,86 @@ var DPlane = (function () {
|
|
|
43
24
|
if (p1.z === p2.z && p2.z === p3.z) {
|
|
44
25
|
return new DPlane(0, 0, 1, -p1.z, p1, p2, p3);
|
|
45
26
|
}
|
|
46
|
-
|
|
47
|
-
|
|
27
|
+
const d = 1;
|
|
28
|
+
const [a, b, c] = (0, utils_1.gaussianElimination)([
|
|
48
29
|
[p1.x, p1.y, p1.z, -d],
|
|
49
30
|
[p2.x, p2.y, p2.z, -d],
|
|
50
31
|
[p3.x, p3.y, p3.z, -d]
|
|
51
|
-
])
|
|
32
|
+
]);
|
|
52
33
|
return new DPlane(a, b, c, d, p1, p2, p3);
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
var _this = this;
|
|
34
|
+
}
|
|
35
|
+
x(p) {
|
|
56
36
|
if (p instanceof DPoint_1.DPoint) {
|
|
57
|
-
|
|
58
|
-
|
|
37
|
+
const { a, b, c, d } = this;
|
|
38
|
+
const { y, z } = p;
|
|
59
39
|
p.x = -(b * y + c * z + d) / a;
|
|
60
40
|
return p;
|
|
61
41
|
}
|
|
62
|
-
return p.map(
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
var _this = this;
|
|
42
|
+
return p.map((t) => this.x(t));
|
|
43
|
+
}
|
|
44
|
+
y(p) {
|
|
66
45
|
if (p instanceof DPoint_1.DPoint) {
|
|
67
|
-
|
|
68
|
-
|
|
46
|
+
const { a, b, c, d } = this;
|
|
47
|
+
const { x, z } = p;
|
|
69
48
|
p.y = -(a * x + c * z + d) / b;
|
|
70
49
|
return p;
|
|
71
50
|
}
|
|
72
|
-
return p.map(
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
var _this = this;
|
|
51
|
+
return p.map((t) => this.y(t));
|
|
52
|
+
}
|
|
53
|
+
z(p) {
|
|
76
54
|
if (p instanceof DPoint_1.DPoint) {
|
|
77
|
-
|
|
78
|
-
|
|
55
|
+
const { a, b, c, d } = this;
|
|
56
|
+
const { x, y } = p;
|
|
79
57
|
p.z = -(a * x + b * y + d) / c;
|
|
80
58
|
return p;
|
|
81
59
|
}
|
|
82
|
-
return p.map(
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
|
|
60
|
+
return p.map((t) => this.z(t));
|
|
61
|
+
}
|
|
62
|
+
clone() {
|
|
63
|
+
const { a, b, c, d, p1, p2, p3 } = this;
|
|
86
64
|
return new DPlane(a, b, c, d, p1, p2, p3);
|
|
87
|
-
}
|
|
88
|
-
|
|
65
|
+
}
|
|
66
|
+
distance(p) {
|
|
89
67
|
if (p instanceof DPoint_1.DPoint) {
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
return Math.abs(
|
|
68
|
+
const { x, y, z } = p;
|
|
69
|
+
const { a, b, c, d } = this;
|
|
70
|
+
return Math.abs(a * x + b * y + c * z + d) / Math.sqrt(a * a + b * b + c * c);
|
|
93
71
|
}
|
|
94
|
-
|
|
95
|
-
|
|
72
|
+
const { a, b, c, d } = p;
|
|
73
|
+
const { d: r } = this;
|
|
96
74
|
return Math.abs(d - r) / Math.sqrt(a * a + b * b + c * c);
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
75
|
+
}
|
|
76
|
+
equal(p) {
|
|
77
|
+
const { a, b, c, d } = p;
|
|
78
|
+
const { a: q, b: w, c: e, d: r } = this;
|
|
101
79
|
return DNumbers_1.DNumbers.like(a, q) &&
|
|
102
80
|
DNumbers_1.DNumbers.like(b, w) &&
|
|
103
81
|
DNumbers_1.DNumbers.like(c, e) &&
|
|
104
82
|
DNumbers_1.DNumbers.like(d, r);
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
83
|
+
}
|
|
84
|
+
same(p) {
|
|
85
|
+
const { a, b, c, d } = p;
|
|
86
|
+
const { a: q, b: w, c: e, d: r } = this;
|
|
87
|
+
const t = a / q;
|
|
88
|
+
const y = b / w;
|
|
89
|
+
const u = c / e;
|
|
90
|
+
const i = d / r;
|
|
113
91
|
return DNumbers_1.DNumbers.like(t, y) &&
|
|
114
92
|
DNumbers_1.DNumbers.like(t, u) &&
|
|
115
93
|
DNumbers_1.DNumbers.like(t, c) &&
|
|
116
94
|
DNumbers_1.DNumbers.like(t, i);
|
|
117
|
-
}
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
95
|
+
}
|
|
96
|
+
parallel(p) {
|
|
97
|
+
const { a, b, c, d } = p;
|
|
98
|
+
const { a: q, b: w, c: e, d: r } = this;
|
|
99
|
+
const t = a / q;
|
|
100
|
+
const y = b / w;
|
|
101
|
+
const u = c / e;
|
|
102
|
+
const i = d / r;
|
|
125
103
|
return DNumbers_1.DNumbers.like(t, y) &&
|
|
126
104
|
DNumbers_1.DNumbers.like(t, u) &&
|
|
127
105
|
DNumbers_1.DNumbers.like(t, c) &&
|
|
128
106
|
!DNumbers_1.DNumbers.like(t, i);
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
}());
|
|
107
|
+
}
|
|
108
|
+
}
|
|
132
109
|
exports.DPlane = DPlane;
|