dgeoutils 2.4.48 → 2.5.0

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.
Files changed (52) hide show
  1. package/dist/cjs/DCircle.d.ts +18 -0
  2. package/dist/cjs/DCircle.js +102 -0
  3. package/dist/cjs/DLine.d.ts +39 -0
  4. package/dist/cjs/DLine.js +343 -0
  5. package/dist/cjs/DNumbers.d.ts +8 -0
  6. package/dist/cjs/DNumbers.js +30 -0
  7. package/dist/cjs/DPlane.d.ts +25 -0
  8. package/dist/cjs/DPlane.js +132 -0
  9. package/dist/cjs/DPoint.d.ts +139 -0
  10. package/dist/cjs/DPoint.js +820 -0
  11. package/dist/cjs/DPolygon.d.ts +139 -0
  12. package/dist/cjs/DPolygon.js +1774 -0
  13. package/dist/cjs/DPolygonLoop.d.ts +60 -0
  14. package/dist/cjs/DPolygonLoop.js +439 -0
  15. package/dist/cjs/FastSearch.d.ts +6 -0
  16. package/dist/cjs/FastSearch.js +53 -0
  17. package/dist/cjs/InterpolationMatrix.d.ts +24 -0
  18. package/dist/cjs/InterpolationMatrix.js +173 -0
  19. package/dist/cjs/TraceMatrix.d.ts +22 -0
  20. package/dist/cjs/TraceMatrix.js +285 -0
  21. package/dist/cjs/index.d.ts +11 -0
  22. package/dist/cjs/index.js +37 -0
  23. package/dist/cjs/utils.d.ts +49 -0
  24. package/dist/cjs/utils.js +281 -0
  25. package/dist/es2015/DCircle.js +87 -0
  26. package/dist/es2015/DLine.js +290 -0
  27. package/dist/es2015/DNumbers.js +22 -0
  28. package/dist/es2015/DPlane.js +105 -0
  29. package/dist/es2015/DPoint.js +693 -0
  30. package/dist/es2015/DPolygon.js +1203 -0
  31. package/dist/es2015/DPolygonLoop.js +430 -0
  32. package/dist/es2015/FastSearch.js +25 -0
  33. package/dist/es2015/InterpolationMatrix.js +128 -0
  34. package/dist/es2015/TraceMatrix.js +229 -0
  35. package/dist/es2015/index.js +11 -0
  36. package/dist/es2015/utils.js +208 -0
  37. package/dist/esm/DCircle.js +99 -0
  38. package/dist/esm/DLine.js +340 -0
  39. package/dist/esm/DNumbers.js +27 -0
  40. package/dist/esm/DPlane.js +129 -0
  41. package/dist/esm/DPoint.js +817 -0
  42. package/dist/esm/DPolygon.js +1771 -0
  43. package/dist/esm/DPolygonLoop.js +436 -0
  44. package/dist/esm/FastSearch.js +50 -0
  45. package/dist/esm/InterpolationMatrix.js +170 -0
  46. package/dist/esm/TraceMatrix.js +282 -0
  47. package/dist/esm/index.js +11 -0
  48. package/dist/esm/utils.js +266 -0
  49. package/dist/umd/dgeoutils.js +4394 -0
  50. package/dist/umd/dgeoutils.min.js +1 -0
  51. package/dist/umd/dgeoutils.min.js.map +1 -0
  52. package/package.json +9 -1
@@ -0,0 +1,105 @@
1
+ import { DPoint } from './DPoint';
2
+ import { gaussianElimination } from './utils';
3
+ import { DNumbers } from './DNumbers';
4
+ export class DPlane {
5
+ constructor(a, b, c, d, p1 = DPoint.zero(), p2 = DPoint.zero(), p3 = DPoint.zero()) {
6
+ this.a = a;
7
+ this.b = b;
8
+ this.c = c;
9
+ this.d = d;
10
+ this.p1 = p1;
11
+ this.p2 = p2;
12
+ this.p3 = p3;
13
+ }
14
+ static find(p1, p2, p3) {
15
+ if (p1.x === p2.x && p2.x === p3.x) {
16
+ return new DPlane(1, 0, 0, -p1.x, p1, p2, p3);
17
+ }
18
+ if (p1.y === p2.y && p2.y === p3.y) {
19
+ return new DPlane(0, 1, 0, -p1.y, p1, p2, p3);
20
+ }
21
+ if (p1.z === p2.z && p2.z === p3.z) {
22
+ return new DPlane(0, 0, 1, -p1.z, p1, p2, p3);
23
+ }
24
+ const d = 1;
25
+ const [a, b, c] = gaussianElimination([
26
+ [p1.x, p1.y, p1.z, -d],
27
+ [p2.x, p2.y, p2.z, -d],
28
+ [p3.x, p3.y, p3.z, -d]
29
+ ]);
30
+ return new DPlane(a, b, c, d, p1, p2, p3);
31
+ }
32
+ x(p) {
33
+ if (p instanceof DPoint) {
34
+ const { a, b, c, d } = this;
35
+ const { y, z } = p;
36
+ p.x = -(b * y + c * z + d) / a;
37
+ return p;
38
+ }
39
+ return p.map((t) => this.x(t));
40
+ }
41
+ y(p) {
42
+ if (p instanceof DPoint) {
43
+ const { a, b, c, d } = this;
44
+ const { x, z } = p;
45
+ p.y = -(a * x + c * z + d) / b;
46
+ return p;
47
+ }
48
+ return p.map((t) => this.y(t));
49
+ }
50
+ z(p) {
51
+ if (p instanceof DPoint) {
52
+ const { a, b, c, d } = this;
53
+ const { x, y } = p;
54
+ p.z = -(a * x + b * y + d) / c;
55
+ return p;
56
+ }
57
+ return p.map((t) => this.z(t));
58
+ }
59
+ clone() {
60
+ const { a, b, c, d, p1, p2, p3 } = this;
61
+ return new DPlane(a, b, c, d, p1, p2, p3);
62
+ }
63
+ distance(p) {
64
+ if (p instanceof DPoint) {
65
+ const { x, y, z } = p;
66
+ const { a, b, c, d } = this;
67
+ return Math.abs(a * x + b * y + c * z + d) / Math.sqrt(a * a + b * b + c * c);
68
+ }
69
+ const { a, b, c, d } = p;
70
+ const { d: r } = this;
71
+ return Math.abs(d - r) / Math.sqrt(a * a + b * b + c * c);
72
+ }
73
+ equal(p) {
74
+ const { a, b, c, d } = p;
75
+ const { a: q, b: w, c: e, d: r } = this;
76
+ return DNumbers.like(a, q) &&
77
+ DNumbers.like(b, w) &&
78
+ DNumbers.like(c, e) &&
79
+ DNumbers.like(d, r);
80
+ }
81
+ same(p) {
82
+ const { a, b, c, d } = p;
83
+ const { a: q, b: w, c: e, d: r } = this;
84
+ const t = a / q;
85
+ const y = b / w;
86
+ const u = c / e;
87
+ const i = d / r;
88
+ return DNumbers.like(t, y) &&
89
+ DNumbers.like(t, u) &&
90
+ DNumbers.like(t, c) &&
91
+ DNumbers.like(t, i);
92
+ }
93
+ parallel(p) {
94
+ const { a, b, c, d } = p;
95
+ const { a: q, b: w, c: e, d: r } = this;
96
+ const t = a / q;
97
+ const y = b / w;
98
+ const u = c / e;
99
+ const i = d / r;
100
+ return DNumbers.like(t, y) &&
101
+ DNumbers.like(t, u) &&
102
+ DNumbers.like(t, c) &&
103
+ !DNumbers.like(t, i);
104
+ }
105
+ }