@ntf/math 1.0.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 (117) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +41 -0
  3. package/dist/cjs/algebra/function.js +7 -0
  4. package/dist/cjs/algebra/function.js.map +1 -0
  5. package/dist/cjs/algebra/linear.js +42 -0
  6. package/dist/cjs/algebra/linear.js.map +1 -0
  7. package/dist/cjs/algebra/quad.js +53 -0
  8. package/dist/cjs/algebra/quad.js.map +1 -0
  9. package/dist/cjs/common/error.js +14 -0
  10. package/dist/cjs/common/error.js.map +1 -0
  11. package/dist/cjs/common/sign.js +14 -0
  12. package/dist/cjs/common/sign.js.map +1 -0
  13. package/dist/cjs/common/types.js +35 -0
  14. package/dist/cjs/common/types.js.map +1 -0
  15. package/dist/cjs/geometry/angle.js +11 -0
  16. package/dist/cjs/geometry/angle.js.map +1 -0
  17. package/dist/cjs/geometry/bbox.js +87 -0
  18. package/dist/cjs/geometry/bbox.js.map +1 -0
  19. package/dist/cjs/geometry/circle.js +64 -0
  20. package/dist/cjs/geometry/circle.js.map +1 -0
  21. package/dist/cjs/geometry/object.js +3 -0
  22. package/dist/cjs/geometry/object.js.map +1 -0
  23. package/dist/cjs/geometry/rectangle.js +77 -0
  24. package/dist/cjs/geometry/rectangle.js.map +1 -0
  25. package/dist/cjs/geometry/square.js +66 -0
  26. package/dist/cjs/geometry/square.js.map +1 -0
  27. package/dist/cjs/geometry/triangle.js +65 -0
  28. package/dist/cjs/geometry/triangle.js.map +1 -0
  29. package/dist/cjs/index.js +58 -0
  30. package/dist/cjs/index.js.map +1 -0
  31. package/dist/cjs/matrices/mat3.js +184 -0
  32. package/dist/cjs/matrices/mat3.js.map +1 -0
  33. package/dist/cjs/matrices/mat4.js +262 -0
  34. package/dist/cjs/matrices/mat4.js.map +1 -0
  35. package/dist/cjs/quaternion.js +196 -0
  36. package/dist/cjs/quaternion.js.map +1 -0
  37. package/dist/cjs/vectors/vec2.js +151 -0
  38. package/dist/cjs/vectors/vec2.js.map +1 -0
  39. package/dist/cjs/vectors/vec3.js +148 -0
  40. package/dist/cjs/vectors/vec3.js.map +1 -0
  41. package/dist/esm/algebra/function.js +3 -0
  42. package/dist/esm/algebra/function.js.map +1 -0
  43. package/dist/esm/algebra/linear.js +38 -0
  44. package/dist/esm/algebra/linear.js.map +1 -0
  45. package/dist/esm/algebra/quad.js +49 -0
  46. package/dist/esm/algebra/quad.js.map +1 -0
  47. package/dist/esm/common/error.js +10 -0
  48. package/dist/esm/common/error.js.map +1 -0
  49. package/dist/esm/common/sign.js +10 -0
  50. package/dist/esm/common/sign.js.map +1 -0
  51. package/dist/esm/common/types.js +26 -0
  52. package/dist/esm/common/types.js.map +1 -0
  53. package/dist/esm/geometry/angle.js +5 -0
  54. package/dist/esm/geometry/angle.js.map +1 -0
  55. package/dist/esm/geometry/bbox.js +83 -0
  56. package/dist/esm/geometry/bbox.js.map +1 -0
  57. package/dist/esm/geometry/circle.js +60 -0
  58. package/dist/esm/geometry/circle.js.map +1 -0
  59. package/dist/esm/geometry/object.js +2 -0
  60. package/dist/esm/geometry/object.js.map +1 -0
  61. package/dist/esm/geometry/rectangle.js +73 -0
  62. package/dist/esm/geometry/rectangle.js.map +1 -0
  63. package/dist/esm/geometry/square.js +62 -0
  64. package/dist/esm/geometry/square.js.map +1 -0
  65. package/dist/esm/geometry/triangle.js +59 -0
  66. package/dist/esm/geometry/triangle.js.map +1 -0
  67. package/dist/esm/index.js +39 -0
  68. package/dist/esm/index.js.map +1 -0
  69. package/dist/esm/matrices/mat3.js +180 -0
  70. package/dist/esm/matrices/mat3.js.map +1 -0
  71. package/dist/esm/matrices/mat4.js +258 -0
  72. package/dist/esm/matrices/mat4.js.map +1 -0
  73. package/dist/esm/quaternion.js +192 -0
  74. package/dist/esm/quaternion.js.map +1 -0
  75. package/dist/esm/vectors/vec2.js +147 -0
  76. package/dist/esm/vectors/vec2.js.map +1 -0
  77. package/dist/esm/vectors/vec3.js +144 -0
  78. package/dist/esm/vectors/vec3.js.map +1 -0
  79. package/dist/types/algebra/function.d.ts +6 -0
  80. package/dist/types/algebra/function.d.ts.map +1 -0
  81. package/dist/types/algebra/linear.d.ts +14 -0
  82. package/dist/types/algebra/linear.d.ts.map +1 -0
  83. package/dist/types/algebra/quad.d.ts +18 -0
  84. package/dist/types/algebra/quad.d.ts.map +1 -0
  85. package/dist/types/common/error.d.ts +6 -0
  86. package/dist/types/common/error.d.ts.map +1 -0
  87. package/dist/types/common/sign.d.ts +2 -0
  88. package/dist/types/common/sign.d.ts.map +1 -0
  89. package/dist/types/common/types.d.ts +21 -0
  90. package/dist/types/common/types.d.ts.map +1 -0
  91. package/dist/types/geometry/angle.d.ts +5 -0
  92. package/dist/types/geometry/angle.d.ts.map +1 -0
  93. package/dist/types/geometry/bbox.d.ts +35 -0
  94. package/dist/types/geometry/bbox.d.ts.map +1 -0
  95. package/dist/types/geometry/circle.d.ts +26 -0
  96. package/dist/types/geometry/circle.d.ts.map +1 -0
  97. package/dist/types/geometry/object.d.ts +5 -0
  98. package/dist/types/geometry/object.d.ts.map +1 -0
  99. package/dist/types/geometry/rectangle.d.ts +31 -0
  100. package/dist/types/geometry/rectangle.d.ts.map +1 -0
  101. package/dist/types/geometry/square.d.ts +27 -0
  102. package/dist/types/geometry/square.d.ts.map +1 -0
  103. package/dist/types/geometry/triangle.d.ts +42 -0
  104. package/dist/types/geometry/triangle.d.ts.map +1 -0
  105. package/dist/types/index.d.ts +22 -0
  106. package/dist/types/index.d.ts.map +1 -0
  107. package/dist/types/matrices/mat3.d.ts +58 -0
  108. package/dist/types/matrices/mat3.d.ts.map +1 -0
  109. package/dist/types/matrices/mat4.d.ts +84 -0
  110. package/dist/types/matrices/mat4.d.ts.map +1 -0
  111. package/dist/types/quaternion.d.ts +49 -0
  112. package/dist/types/quaternion.d.ts.map +1 -0
  113. package/dist/types/vectors/vec2.d.ts +55 -0
  114. package/dist/types/vectors/vec2.d.ts.map +1 -0
  115. package/dist/types/vectors/vec3.d.ts +53 -0
  116. package/dist/types/vectors/vec3.d.ts.map +1 -0
  117. package/package.json +40 -0
@@ -0,0 +1,196 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Quaternion = void 0;
4
+ const error_1 = require("./common/error");
5
+ const types_1 = require("./common/types");
6
+ const index_1 = require("./index");
7
+ const vec3_1 = require("./vectors/vec3");
8
+ class Quaternion {
9
+ w;
10
+ x;
11
+ y;
12
+ z;
13
+ static is(obj) {
14
+ try {
15
+ this.resolve(obj);
16
+ return true;
17
+ }
18
+ catch (e) {
19
+ return false;
20
+ }
21
+ }
22
+ static resolve(a) {
23
+ if (a == null || typeof a == "undefined")
24
+ throw new error_1.ResolveError("Quaternion", a);
25
+ if ((0, types_1.check_number_array)(a, 4))
26
+ return new this(a[0], a[1], a[2], a[3]);
27
+ if ((0, types_1.has_property)(a, "w", "number") && (0, types_1.has_property)(a, "x", "number") && (0, types_1.has_property)(a, "y", "number") && (0, types_1.has_property)(a, "z", "number"))
28
+ return new this(a.w, a.x, a.y, a.z);
29
+ if ((0, types_1.check_string)(a)) {
30
+ const parts = a.replaceAll(" ", "").split("+");
31
+ if ((0, types_1.check_string_array)(parts, 4)) {
32
+ const [sw, sxi, syj, szk] = parts;
33
+ if (sxi.endsWith("i") && syj.endsWith("j") && szk.endsWith("k"))
34
+ return this.resolve([
35
+ parseFloat(sw),
36
+ parseFloat(sxi.substring(0, sxi.length - 1)),
37
+ parseFloat(syj.substring(0, syj.length - 1)),
38
+ parseFloat(szk.substring(0, szk.length - 1))
39
+ ]);
40
+ }
41
+ }
42
+ throw new error_1.ResolveError("Quaternion", a);
43
+ }
44
+ static fromAxisAngle(axis, angle) {
45
+ const vec = vec3_1.Vec3.resolve(axis);
46
+ const hangle = angle * 0.5;
47
+ const sin2 = Math.sin(hangle);
48
+ const cos2 = Math.cos(hangle);
49
+ const length = sin2 / Math.sqrt(vec.x * vec.x + vec.y * vec.y + vec.z * vec.z);
50
+ return new this(cos2, vec.x * length, vec.y * length, vec.z * length);
51
+ }
52
+ static fromEuler(...args) {
53
+ const vec = vec3_1.Vec3.resolveArgs(args);
54
+ const x2 = vec.x * 0.5, y2 = vec.y * 0.5, z2 = vec.z * 0.5;
55
+ const cx = Math.cos(x2), cy = Math.cos(y2), cz = Math.cos(z2);
56
+ const sx = Math.sin(x2), sy = Math.sin(y2), sz = Math.sin(z2);
57
+ return new Quaternion(cx * cy * cz - sx * sy * sz, sx * cy * cz - sy * sz * cx, sy * cx * cz - sx * sz * cy, sx * sy * cz + sz * cx * cy);
58
+ }
59
+ constructor(w = 0, x = 0, y = 0, z = 0) {
60
+ this.w = w;
61
+ this.x = x;
62
+ this.y = y;
63
+ this.z = z;
64
+ }
65
+ toArray() {
66
+ return [this.w, this.x, this.y, this.z];
67
+ }
68
+ toString() {
69
+ return `${this.w} + ${this.x}i + ${this.y}j + ${this.z}k`;
70
+ }
71
+ toJSON() {
72
+ return {
73
+ w: this.w, x: this.x, y: this.y, z: this.z
74
+ };
75
+ }
76
+ clone() {
77
+ return new Quaternion(this.w, this.x, this.y, this.z);
78
+ }
79
+ add(a) {
80
+ const quat = Quaternion.resolve(a);
81
+ return new Quaternion(this.w + quat.w, this.x + quat.x, this.y + quat.y, this.z + quat.z);
82
+ }
83
+ offset(a) {
84
+ const quat = Quaternion.resolve(a);
85
+ this.w += quat.w;
86
+ this.x += quat.x;
87
+ this.y += quat.y;
88
+ this.z += quat.z;
89
+ return this;
90
+ }
91
+ subtract(a) {
92
+ const quat = Quaternion.resolve(a);
93
+ return new Quaternion(this.w - quat.w, this.x - quat.x, this.y - quat.y, this.z - quat.z);
94
+ }
95
+ negative() {
96
+ return new Quaternion(-this.w, -this.x, -this.y, -this.z);
97
+ }
98
+ length(sqrt = true) {
99
+ const value = this.w * this.w + this.x * this.x + this.y * this.y + this.z * this.z;
100
+ return sqrt ? Math.sqrt(value) : value;
101
+ }
102
+ normalize() {
103
+ let length = this.length();
104
+ if (length < index_1.EPSILON)
105
+ return new Quaternion();
106
+ length = 1 / length;
107
+ return new Quaternion(this.w * length, this.x * length, this.y * length, this.z * length);
108
+ }
109
+ multiply(a) {
110
+ const quat = Quaternion.resolve(a);
111
+ return new Quaternion(this.w * quat.w - this.x * quat.x - this.y * quat.y - this.z * quat.z, this.w * quat.x + this.x * quat.w + this.y * quat.z - this.z * quat.y, this.w * quat.y + this.y * quat.w + this.z * quat.x - this.x * quat.z, this.w * quat.z + this.z * quat.w + this.x * quat.y - this.y * quat.x);
112
+ }
113
+ multiplyVector(...args) {
114
+ const vec = vec3_1.Vec3.resolveArgs(args);
115
+ const ix = this.w * vec.x + this.y * vec.y - this.z * vec.y;
116
+ const iy = this.w * vec.y + this.z * vec.x - this.x * vec.z;
117
+ const iz = this.w * vec.z + this.x * vec.y - this.y * vec.x;
118
+ const iw = -this.w * vec.x - this.y * vec.y - this.z * vec.z;
119
+ return new vec3_1.Vec3(ix * this.w + iw * -this.x + iy * -this.z - iz * -this.y, iy * this.w + iw * -this.y + iz * -this.x - ix * -this.z, iz * this.w + iw * -this.z + ix * -this.y - iy * -this.x);
120
+ }
121
+ scale(scalar) {
122
+ return new Quaternion(this.w * scalar, this.x * scalar, this.y * scalar, this.z * scalar);
123
+ }
124
+ dot(a) {
125
+ const quat = Quaternion.resolve(a);
126
+ return this.w * quat.w + this.x * quat.x + this.y * quat.y + this.z * quat.z;
127
+ }
128
+ inverse() {
129
+ let length = this.length(false);
130
+ if (length == 0)
131
+ return new Quaternion();
132
+ length = 1 / length;
133
+ return new Quaternion(this.w * length, -this.x * length, -this.y * length, -this.z * length);
134
+ }
135
+ divide(a) {
136
+ const quat = Quaternion.resolve(a);
137
+ let length = quat.length(false);
138
+ if (length == 0)
139
+ return new Quaternion();
140
+ length = 1 / length;
141
+ return new Quaternion((this.w * quat.w + this.x * quat.x + this.y * quat.y + this.z * quat.z) * length, (this.x * quat.w - this.w * quat.x - this.y * quat.z + this.z * quat.y) * length, (this.y * quat.w - this.w * quat.y - this.z * quat.x + this.x * quat.z) * length, (this.z * quat.w - this.w * quat.z - this.x * quat.y + this.y * quat.x) * length);
142
+ }
143
+ conjugate() {
144
+ return new Quaternion(this.w, -this.x, -this.y, -this.z);
145
+ }
146
+ exp() {
147
+ const length = Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z);
148
+ const exp = Math.exp(this.w);
149
+ const scale = exp * Math.sin(length) / length;
150
+ if (length == 0)
151
+ return new Quaternion(exp);
152
+ return new Quaternion(exp * Math.cos(length), this.x * scale, this.y * scale, this.z * scale);
153
+ }
154
+ log() {
155
+ if (this.x == 0 && this.z == 0)
156
+ return new Quaternion((0, index_1.log_hypot)(this.w, this.x), Math.atan2(this.x, this.w));
157
+ const length = this.length(false);
158
+ const length2 = Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z);
159
+ const scale = Math.atan2(length2, this.w) / length;
160
+ return new Quaternion(Math.log(length) * 0.5, this.x * scale, this.y * scale, this.z * scale);
161
+ }
162
+ toVector() {
163
+ return new vec3_1.Vec3(this.x, this.y, this.z, this.w);
164
+ }
165
+ toAxisAngle() {
166
+ const sin2 = 1 - this.w * this.w;
167
+ if (sin2 > index_1.EPSILON)
168
+ return new vec3_1.Vec3(this.x, this.y, this.z, 0);
169
+ const isin = 1 / Math.sqrt(sin2);
170
+ const angle = 2 * Math.acos(this.w);
171
+ return new vec3_1.Vec3(this.x * isin, this.y * isin, this.z * isin, angle);
172
+ }
173
+ toEuler() {
174
+ function asin(t) {
175
+ return t >= 1 ? Math.PI / 2 : (t <= -1 ? -Math.PI / 2 : Math.asin(t));
176
+ }
177
+ return new vec3_1.Vec3(-Math.atan2(2 * (this.y * this.z - this.w * this.x), 1 - 2 * (this.x * this.x + this.y * this.y)), asin(2 * (this.x * this.z + this.w * this.y)), -Math.atan2(2 * (this.x * this.y - this.w * this.z), 1 - 2 * (this.y * this.y + this.z * this.z)));
178
+ }
179
+ toMat3() {
180
+ return new index_1.Mat3([
181
+ 1 - 2 * (this.y * this.y + this.z * this.z), 2 * (this.x * this.y - this.w * this.z), 2 * (this.x * this.z + this.w * this.y),
182
+ 2 * (this.x * this.y + this.w * this.z), 1 - 2 * (this.x * this.x + this.z * this.z), 2 * (this.y * this.z - this.w * this.x),
183
+ 2 * (this.x * this.z - this.w * this.y), 2 * (this.y * this.z + this.w * this.x), 1 - 2 * (this.x * this.x + this.y * this.y)
184
+ ]);
185
+ }
186
+ toMat4() {
187
+ return new index_1.Mat4([
188
+ 1 - 2 * (this.y * this.y + this.z * this.z), 2 * (this.x * this.y - this.w * this.z), 2 * (this.x * this.z + this.w * this.y), 0,
189
+ 2 * (this.x * this.y + this.w * this.z), 1 - 2 * (this.x * this.x + this.z * this.z), 2 * (this.y * this.z - this.w * this.x), 0,
190
+ 2 * (this.x * this.z - this.w * this.y), 2 * (this.y * this.z + this.w * this.x), 1 - 2 * (this.x * this.x + this.y * this.y), 0,
191
+ 0, 0, 0, 1
192
+ ]);
193
+ }
194
+ }
195
+ exports.Quaternion = Quaternion;
196
+ //# sourceMappingURL=quaternion.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"quaternion.js","sourceRoot":"","sources":["../../source/quaternion.ts"],"names":[],"mappings":";;;AAAA,0CAA6C;AAC7C,0CAAmG;AACnG,mCAAwD;AACxD,yCAA8D;AAc9D,MAAa,UAAU;IA+DO;IAAqB;IAAqB;IAAqB;IA7DlF,MAAM,CAAC,EAAE,CAAC,GAAY;QAEzB,IACA,CAAC;YACG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAA;YACjB,OAAO,IAAI,CAAA;QACf,CAAC;QACD,OAAM,CAAC,EACP,CAAC;YACG,OAAO,KAAK,CAAA;QAChB,CAAC;IACL,CAAC;IACM,MAAM,CAAC,OAAO,CAAC,CAAU;QAE5B,IAAG,CAAC,IAAI,IAAI,IAAI,OAAO,CAAC,IAAI,WAAW;YACnC,MAAM,IAAI,oBAAY,CAAC,YAAY,EAAC,CAAC,CAAC,CAAA;QAC1C,IAAG,IAAA,0BAAkB,EAAC,CAAC,EAAC,CAAC,CAAC;YACtB,OAAO,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,EAAC,CAAC,CAAC,CAAC,CAAC,EAAC,CAAC,CAAC,CAAC,CAAC,EAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;QACxC,IAAG,IAAA,oBAAY,EAAC,CAAC,EAAC,GAAG,EAAC,QAAQ,CAAC,IAAI,IAAA,oBAAY,EAAC,CAAC,EAAC,GAAG,EAAC,QAAQ,CAAC,IAAI,IAAA,oBAAY,EAAC,CAAC,EAAC,GAAG,EAAC,QAAQ,CAAC,IAAI,IAAA,oBAAY,EAAC,CAAC,EAAC,GAAG,EAAC,QAAQ,CAAC;YAC3H,OAAO,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,EAAC,CAAC,CAAC,CAAC,EAAC,CAAC,CAAC,CAAC,EAAC,CAAC,CAAC,CAAC,CAAC,CAAA;QACpC,IAAG,IAAA,oBAAY,EAAC,CAAC,CAAC,EAClB,CAAC;YACG,MAAM,KAAK,GAAG,CAAC,CAAC,UAAU,CAAC,GAAG,EAAC,EAAE,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;YAC7C,IAAG,IAAA,0BAAkB,EAAC,KAAK,EAAC,CAAC,CAAC,EAC9B,CAAC;gBACG,MAAM,CAAC,EAAE,EAAC,GAAG,EAAC,GAAG,EAAC,GAAG,CAAC,GAAG,KAAK,CAAA;gBAC9B,IAAG,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC;oBAC1D,OAAO,IAAI,CAAC,OAAO,CAAC;wBAChB,UAAU,CAAC,EAAE,CAAC;wBACd,UAAU,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAC,GAAG,CAAC,MAAM,GAAC,CAAC,CAAC,CAAC;wBACzC,UAAU,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAC,GAAG,CAAC,MAAM,GAAC,CAAC,CAAC,CAAC;wBACzC,UAAU,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAC,GAAG,CAAC,MAAM,GAAC,CAAC,CAAC,CAAC;qBAC5C,CAAC,CAAA;YACV,CAAC;QACL,CAAC;QACD,MAAM,IAAI,oBAAY,CAAC,YAAY,EAAC,CAAC,CAAC,CAAA;IAC1C,CAAC;IACM,MAAM,CAAC,aAAa,CAAC,IAAc,EAAC,KAAa;QAEpD,MAAM,GAAG,GAAG,WAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;QAC9B,MAAM,MAAM,GAAG,KAAK,GAAG,GAAG,CAAA;QAC1B,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;QAC7B,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;QAC7B,MAAM,MAAM,GAAG,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAC,GAAG,CAAC,CAAC,GAAC,GAAG,CAAC,CAAC,GAAC,GAAG,CAAC,CAAC,GAAC,GAAG,CAAC,CAAC,GAAC,GAAG,CAAC,CAAC,CAAC,CAAA;QACpE,OAAO,IAAI,IAAI,CAAC,IAAI,EAAC,GAAG,CAAC,CAAC,GAAG,MAAM,EAAC,GAAG,CAAC,CAAC,GAAG,MAAM,EAAC,GAAG,CAAC,CAAC,GAAG,MAAM,CAAC,CAAA;IACtE,CAAC;IAGM,MAAM,CAAC,SAAS,CAAC,GAAG,IAAmB;QAE1C,MAAM,GAAG,GAAG,WAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAA;QAClC,MAAM,EAAE,GAAG,GAAG,CAAC,CAAC,GAAC,GAAG,EAAE,EAAE,GAAG,GAAG,CAAC,CAAC,GAAC,GAAG,EAAE,EAAE,GAAG,GAAG,CAAC,CAAC,GAAC,GAAG,CAAA;QACpD,MAAM,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;QAC7D,MAAM,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;QAC7D,OAAO,IAAI,UAAU,CACjB,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAC3B,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAC3B,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAC3B,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAC9B,CAAA;IACL,CAAC;IACD,YAA0B,IAAY,CAAC,EAAQ,IAAY,CAAC,EAAQ,IAAY,CAAC,EAAQ,IAAY,CAAC;QAA5E,MAAC,GAAD,CAAC,CAAY;QAAQ,MAAC,GAAD,CAAC,CAAY;QAAQ,MAAC,GAAD,CAAC,CAAY;QAAQ,MAAC,GAAD,CAAC,CAAY;IAGtG,CAAC;IACM,OAAO;QAEV,OAAO,CAAC,IAAI,CAAC,CAAC,EAAC,IAAI,CAAC,CAAC,EAAC,IAAI,CAAC,CAAC,EAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IACxC,CAAC;IACM,QAAQ;QAEX,OAAO,GAAG,IAAI,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,OAAO,IAAI,CAAC,CAAC,OAAO,IAAI,CAAC,CAAC,GAAG,CAAA;IAC7D,CAAC;IACM,MAAM;QAET,OAAO;YACH,CAAC,EAAE,IAAI,CAAC,CAAC,EAAC,CAAC,EAAE,IAAI,CAAC,CAAC,EAAC,CAAC,EAAE,IAAI,CAAC,CAAC,EAAC,CAAC,EAAE,IAAI,CAAC,CAAC;SAC1C,CAAA;IACL,CAAC;IACM,KAAK;QAER,OAAO,IAAI,UAAU,CAAC,IAAI,CAAC,CAAC,EAAC,IAAI,CAAC,CAAC,EAAC,IAAI,CAAC,CAAC,EAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IACtD,CAAC;IACM,GAAG,CAAC,CAAiB;QAExB,MAAM,IAAI,GAAG,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,CAAA;QAClC,OAAO,IAAI,UAAU,CACjB,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,EACf,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,EACf,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,EACf,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAClB,CAAA;IACL,CAAC;IACM,MAAM,CAAC,CAAiB;QAE3B,MAAM,IAAI,GAAG,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,CAAA;QAClC,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,CAAA;QAChB,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,CAAA;QAChB,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,CAAA;QAChB,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,CAAA;QAChB,OAAO,IAAI,CAAA;IACf,CAAC;IACM,QAAQ,CAAC,CAAiB;QAE7B,MAAM,IAAI,GAAG,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,CAAA;QAClC,OAAO,IAAI,UAAU,CACjB,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,EACf,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,EACf,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,EACf,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAClB,CAAA;IACL,CAAC;IACM,QAAQ;QAEX,OAAO,IAAI,UAAU,CAAC,CAAC,IAAI,CAAC,CAAC,EAAC,CAAC,IAAI,CAAC,CAAC,EAAC,CAAC,IAAI,CAAC,CAAC,EAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IAC1D,CAAC;IACM,MAAM,CAAC,IAAI,GAAG,IAAI;QAErB,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAA;QACrE,OAAO,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAA;IAC1C,CAAC;IACM,SAAS;QAEZ,IAAI,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE,CAAA;QAC1B,IAAG,MAAM,GAAG,eAAO;YACf,OAAO,IAAI,UAAU,EAAE,CAAA;QAC3B,MAAM,GAAG,CAAC,GAAG,MAAM,CAAA;QACnB,OAAO,IAAI,UAAU,CAAC,IAAI,CAAC,CAAC,GAAC,MAAM,EAAC,IAAI,CAAC,CAAC,GAAC,MAAM,EAAC,IAAI,CAAC,CAAC,GAAC,MAAM,EAAC,IAAI,CAAC,CAAC,GAAC,MAAM,CAAC,CAAA;IAClF,CAAC;IACM,QAAQ,CAAC,CAAiB;QAE7B,MAAM,IAAI,GAAG,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,CAAA;QAClC,OAAO,IAAI,UAAU,CACjB,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,EACrE,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,EACrE,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,EACrE,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CACxE,CAAA;IACL,CAAC;IAGM,cAAc,CAAC,GAAG,IAAmB;QAExC,MAAM,GAAG,GAAG,WAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAA;QAClC,MAAM,EAAE,GAAG,IAAI,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAA;QAC3D,MAAM,EAAE,GAAG,IAAI,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAA;QAC3D,MAAM,EAAE,GAAG,IAAI,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAA;QAC3D,MAAM,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAA;QAC5D,OAAO,IAAI,WAAI,CACX,EAAE,GAAG,IAAI,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC,EACxD,EAAE,GAAG,IAAI,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC,EACxD,EAAE,GAAG,IAAI,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC,CAC3D,CAAA;IACL,CAAC;IACM,KAAK,CAAC,MAAc;QAEvB,OAAO,IAAI,UAAU,CAAC,IAAI,CAAC,CAAC,GAAC,MAAM,EAAC,IAAI,CAAC,CAAC,GAAC,MAAM,EAAC,IAAI,CAAC,CAAC,GAAC,MAAM,EAAC,IAAI,CAAC,CAAC,GAAC,MAAM,CAAC,CAAA;IAClF,CAAC;IACM,GAAG,CAAC,CAAiB;QAExB,MAAM,IAAI,GAAG,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,CAAA;QAClC,OAAO,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAA;IAClE,CAAC;IACM,OAAO;QAEV,IAAI,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;QAC/B,IAAG,MAAM,IAAI,CAAC;YACV,OAAO,IAAI,UAAU,EAAE,CAAA;QAC3B,MAAM,GAAG,CAAC,GAAG,MAAM,CAAA;QACnB,OAAO,IAAI,UAAU,CAAC,IAAI,CAAC,CAAC,GAAG,MAAM,EAAC,CAAC,IAAI,CAAC,CAAC,GAAC,MAAM,EAAC,CAAC,IAAI,CAAC,CAAC,GAAC,MAAM,EAAC,CAAC,IAAI,CAAC,CAAC,GAAC,MAAM,CAAC,CAAA;IACvF,CAAC;IACM,MAAM,CAAC,CAAiB;QAE3B,MAAM,IAAI,GAAG,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,CAAA;QAClC,IAAI,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;QAC/B,IAAG,MAAM,IAAI,CAAC;YAAE,OAAO,IAAI,UAAU,EAAE,CAAA;QACvC,MAAM,GAAG,CAAC,GAAG,MAAM,CAAA;QACnB,OAAO,IAAI,UAAU,CACjB,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,MAAM,EAChF,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,MAAM,EAChF,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,MAAM,EAChF,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,MAAM,CACnF,CAAA;IACL,CAAC;IACM,SAAS;QAEZ,OAAO,IAAI,UAAU,CAAC,IAAI,CAAC,CAAC,EAAC,CAAC,IAAI,CAAC,CAAC,EAAC,CAAC,IAAI,CAAC,CAAC,EAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IACzD,CAAC;IACM,GAAG;QAEN,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QACnE,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QAC5B,MAAM,KAAK,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,MAAM,CAAA;QAC7C,IAAG,MAAM,IAAI,CAAC;YACV,OAAO,IAAI,UAAU,CAAC,GAAG,CAAC,CAAA;QAC9B,OAAO,IAAI,UAAU,CACjB,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,EACtB,IAAI,CAAC,CAAC,GAAG,KAAK,EAAC,IAAI,CAAC,CAAC,GAAG,KAAK,EAAC,IAAI,CAAC,CAAC,GAAG,KAAK,CAC/C,CAAA;IACL,CAAC;IACM,GAAG;QAEN,IAAG,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,CAAC;YACzB,OAAO,IAAI,UAAU,CAAC,IAAA,iBAAS,EAAC,IAAI,CAAC,CAAC,EAAC,IAAI,CAAC,CAAC,CAAC,EAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,EAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAA;QAC7E,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;QACjC,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QACpE,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,EAAC,IAAI,CAAC,CAAC,CAAC,GAAG,MAAM,CAAA;QACjD,OAAO,IAAI,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,GAAG,EAAC,IAAI,CAAC,CAAC,GAAG,KAAK,EAAC,IAAI,CAAC,CAAC,GAAG,KAAK,EAAC,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,CAAA;IAC9F,CAAC;IACM,QAAQ;QAEX,OAAO,IAAI,WAAI,CAAC,IAAI,CAAC,CAAC,EAAC,IAAI,CAAC,CAAC,EAAC,IAAI,CAAC,CAAC,EAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IAChD,CAAC;IACM,WAAW;QAEd,MAAM,IAAI,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAA;QAChC,IAAG,IAAI,GAAG,eAAO;YACb,OAAO,IAAI,WAAI,CAAC,IAAI,CAAC,CAAC,EAAC,IAAI,CAAC,CAAC,EAAC,IAAI,CAAC,CAAC,EAAC,CAAC,CAAC,CAAA;QAC3C,MAAM,IAAI,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QAChC,MAAM,KAAK,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QACnC,OAAO,IAAI,WAAI,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,EAAC,IAAI,CAAC,CAAC,GAAG,IAAI,EAAC,IAAI,CAAC,CAAC,GAAG,IAAI,EAAC,KAAK,CAAC,CAAA;IACpE,CAAC;IACM,OAAO;QAEV,SAAS,IAAI,CAAC,CAAS;YAEnB,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAA;QACzE,CAAC;QACD,OAAO,IAAI,WAAI,CACX,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EACxF,IAAI,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EACzC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAC3F,CAAA;IACL,CAAC;IACM,MAAM;QAET,OAAO,IAAI,YAAI,CAAC;YACZ,CAAC,GAAC,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC;YACjG,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC,GAAC,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC;YACjG,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC,GAAC,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC;SACpG,CAAC,CAAA;IACN,CAAC;IACM,MAAM;QAET,OAAO,IAAI,YAAI,CAAC;YACZ,CAAC,GAAC,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC;YACnG,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC,GAAC,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC;YACnG,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC,GAAC,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,EAAC,CAAC;YACnG,CAAC,EAAC,CAAC,EAAC,CAAC,EAAC,CAAC;SACV,CAAC,CAAA;IACN,CAAC;CACJ;AA7PD,gCA6PC"}
@@ -0,0 +1,151 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Vec2 = void 0;
4
+ const error_1 = require("../common/error");
5
+ const types_1 = require("../common/types");
6
+ const square_1 = require("../geometry/square");
7
+ const index_1 = require("../index");
8
+ class Vec2 {
9
+ x;
10
+ y;
11
+ w;
12
+ static resolve(a) {
13
+ if (a == null || typeof a == "undefined")
14
+ throw new error_1.ResolveError("Vec2", a);
15
+ if ((0, types_1.check_number_array)(a, 2))
16
+ return new this(a[0], a[1], (0, types_1.check_number)(a[2]) ? a[2] : undefined);
17
+ if ((0, types_1.has_property)(a, "x", "number") && (0, types_1.has_property)(a, "y", "number"))
18
+ return new this(a.x, a.y);
19
+ if ((0, types_1.check_string)(a)) {
20
+ const [sxy, sw] = a.split(";");
21
+ if ((0, types_1.check_string)(sxy)) {
22
+ const parts = sxy.split(",");
23
+ if ((0, types_1.check_string_array)(parts, 2))
24
+ return new this(parseFloat(parts[0]), parseFloat(parts[1]), (0, types_1.check_string)(sw) ? parseFloat(sw) : undefined);
25
+ }
26
+ }
27
+ if ((0, types_1.check_number)(a))
28
+ return new this(a, a);
29
+ throw new error_1.ResolveError("Vec2", a);
30
+ }
31
+ static resolveArgs(args) {
32
+ if ((0, types_1.check_number_array)(args, 2))
33
+ return new this(args[0], args[1]);
34
+ return this.resolve(args[0]);
35
+ }
36
+ static is(a) {
37
+ try {
38
+ this.resolve(a);
39
+ }
40
+ catch (e) {
41
+ return false;
42
+ }
43
+ return true;
44
+ }
45
+ static fromPoints(a, b) {
46
+ const veca = this.resolve(a);
47
+ const vecb = this.resolve(b);
48
+ return new this(vecb.x - veca.x, vecb.y - veca.y);
49
+ }
50
+ static clamp(value, min, max) {
51
+ const a = this.resolve(value), b = this.resolve(min), c = this.resolve(max);
52
+ return new this((0, index_1.clamp)(a.x, b.x, c.x), (0, index_1.clamp)(a.y, b.y, c.y));
53
+ }
54
+ constructor(x = 0, y = 0, w = 1) {
55
+ this.x = x;
56
+ this.y = y;
57
+ this.w = w;
58
+ }
59
+ toArray(w = false) {
60
+ return w ? [this.x, this.y] : [this.x, this.y, this.w];
61
+ }
62
+ toJSON() {
63
+ return {
64
+ x: this.x, y: this.y, w: this.w
65
+ };
66
+ }
67
+ toString(w = false) {
68
+ return w ? `${this.x},${this.y}` : `${this.x},${this.y};${this.w}`;
69
+ }
70
+ toSquare() {
71
+ return new square_1.Square(this.x, this.y);
72
+ }
73
+ clone() {
74
+ return new Vec2(this.x, this.y, this.w);
75
+ }
76
+ setX(x) {
77
+ this.x = x;
78
+ return this;
79
+ }
80
+ setY(y) {
81
+ this.y = y;
82
+ return this;
83
+ }
84
+ setW(w) {
85
+ this.w = w;
86
+ return this;
87
+ }
88
+ set(...args) {
89
+ const vec = Vec2.resolveArgs(args);
90
+ return this.setX(vec.x).setY(vec.y);
91
+ }
92
+ add(...args) {
93
+ const vec = Vec2.resolveArgs(args);
94
+ return new Vec2(this.x + vec.x, this.y + vec.y);
95
+ }
96
+ offset(...args) {
97
+ const vec = Vec2.resolveArgs(args);
98
+ this.x += vec.x;
99
+ this.y += vec.y;
100
+ return this;
101
+ }
102
+ subtract(...args) {
103
+ const vec = Vec2.resolveArgs(args);
104
+ return new Vec2(this.x - vec.x, this.y - vec.y);
105
+ }
106
+ multiply(scalar) {
107
+ return new Vec2(this.x * scalar, this.y * scalar);
108
+ }
109
+ naiveMultiply(...args) {
110
+ const vec = Vec2.resolveArgs(args);
111
+ return new Vec2(this.x * vec.x, this.y * vec.y);
112
+ }
113
+ divide(...args) {
114
+ if ((0, types_1.check_number_array)(args, 1))
115
+ return new Vec2(this.x / args[0], this.y / args[0]);
116
+ const vec = Vec2.resolveArgs(args);
117
+ return new Vec2(this.x / vec.x, this.y / vec.y);
118
+ }
119
+ dot(...args) {
120
+ const vec = Vec2.resolveArgs(args);
121
+ return this.x * vec.x + this.y * vec.y;
122
+ }
123
+ distance(...args) {
124
+ const vec = Vec2.resolveArgs(args);
125
+ return Math.pow(vec.x - this.x, 2) + Math.pow(vec.y - this.y, 2);
126
+ }
127
+ distanceSquare(...args) {
128
+ const vec = Vec2.resolveArgs(args);
129
+ return Math.sqrt(Math.pow(vec.x - this.x, 2) + Math.pow(vec.y - this.y, 2));
130
+ }
131
+ length() {
132
+ return Math.sqrt(this.x * this.x + this.y * this.y);
133
+ }
134
+ cartesianify() {
135
+ return new Vec2(this.x * Math.cos(this.y), this.x * Math.sin(this.y));
136
+ }
137
+ polarify() {
138
+ return new Vec2(Math.sqrt(this.x * this.x + this.y * this.y), Math.atan(this.y / this.x));
139
+ }
140
+ normalize() {
141
+ const length = this.length();
142
+ if (length == 0)
143
+ return new Vec2;
144
+ return new Vec2(this.x / length, this.y / length);
145
+ }
146
+ invert() {
147
+ return this.multiply(-1);
148
+ }
149
+ }
150
+ exports.Vec2 = Vec2;
151
+ //# sourceMappingURL=vec2.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vec2.js","sourceRoot":"","sources":["../../../source/vectors/vec2.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,148 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Vec3 = void 0;
4
+ const error_1 = require("../common/error");
5
+ const types_1 = require("../common/types");
6
+ const index_1 = require("../index");
7
+ class Vec3 {
8
+ x;
9
+ y;
10
+ z;
11
+ w;
12
+ static resolve(a) {
13
+ if (a == null || typeof a == "undefined")
14
+ throw new error_1.ResolveError("Vec3", a);
15
+ if ((0, types_1.check_number_array)(a, 3))
16
+ return new this(a[0], a[1], a[2], (0, types_1.check_number)(a[3]) ? a[3] : undefined);
17
+ if ((0, types_1.has_property)(a, "x", "number") && (0, types_1.has_property)(a, "y", "number") && (0, types_1.has_property)(a, "z", "number"))
18
+ return new this(a.x, a.y, a.z, (0, types_1.has_property)(a, "w", "number") ? a.w : undefined);
19
+ if ((0, types_1.check_string)(a)) {
20
+ const [sxyz, sw] = a.split(";");
21
+ if ((0, types_1.check_string)(sxyz)) {
22
+ const parts = sxyz.split(",");
23
+ if ((0, types_1.check_string_array)(parts, 3))
24
+ return new this(parseFloat(parts[0]), parseFloat(parts[1]), parseFloat(parts[2]), (0, types_1.check_string)(sw) ? parseFloat(sw) : undefined);
25
+ }
26
+ }
27
+ if ((0, types_1.check_number)(a))
28
+ return new this(a, a, a);
29
+ throw new error_1.ResolveError("Vec3", a);
30
+ }
31
+ static resolveArgs(args) {
32
+ if ((0, types_1.check_number_array)(args, 3))
33
+ return new this(args[0], args[1], args[2]);
34
+ return this.resolve(args[0]);
35
+ }
36
+ static is(a) {
37
+ try {
38
+ this.resolve(a);
39
+ }
40
+ catch (e) {
41
+ return false;
42
+ }
43
+ return true;
44
+ }
45
+ static fromPoints(a, b) {
46
+ const veca = this.resolve(a);
47
+ const vecb = this.resolve(b);
48
+ return new this(vecb.x - veca.x, vecb.y - veca.y, vecb.z - veca.z);
49
+ }
50
+ static clamp(value, min, max) {
51
+ const a = this.resolve(value), b = this.resolve(min), c = this.resolve(max);
52
+ return new this((0, index_1.clamp)(a.x, b.x, c.x), (0, index_1.clamp)(a.y, b.y, c.y), (0, index_1.clamp)(a.z, b.z, c.z));
53
+ }
54
+ constructor(x = 0, y = 0, z = 0, w = 1) {
55
+ this.x = x;
56
+ this.y = y;
57
+ this.z = z;
58
+ this.w = w;
59
+ }
60
+ toArray(w = false) {
61
+ return w ? [this.x, this.y, this.z] : [this.x, this.y, this.z, this.w];
62
+ }
63
+ toJSON() {
64
+ return {
65
+ x: this.x, y: this.y, z: this.z, w: this.w
66
+ };
67
+ }
68
+ toString(w = false) {
69
+ return w ? `${this.x},${this.y},${this.z}` : `${this.x},${this.y},${this.z};${this.w}`;
70
+ }
71
+ clone() {
72
+ return new Vec3(this.x, this.y, this.z, this.w);
73
+ }
74
+ setX(x) {
75
+ this.x = x;
76
+ return this;
77
+ }
78
+ setY(y) {
79
+ this.y = y;
80
+ return this;
81
+ }
82
+ setZ(z) {
83
+ this.z = z;
84
+ return this;
85
+ }
86
+ set(...args) {
87
+ const vec = Vec3.resolveArgs(args);
88
+ return this.setX(vec.x).setY(vec.y).setZ(vec.z);
89
+ }
90
+ add(...args) {
91
+ const vec = Vec3.resolveArgs(args);
92
+ return new Vec3(this.x + vec.x, this.y + vec.y, this.z + vec.z);
93
+ }
94
+ offset(...args) {
95
+ const vec = Vec3.resolveArgs(args);
96
+ this.x += vec.x;
97
+ this.y += vec.y;
98
+ this.z += vec.z;
99
+ return this;
100
+ }
101
+ subtract(...args) {
102
+ const vec = Vec3.resolveArgs(args);
103
+ return new Vec3(this.x - vec.x, this.y - vec.y, this.z - vec.z);
104
+ }
105
+ multiply(scalar) {
106
+ return new Vec3(this.x * scalar, this.y * scalar, this.z * scalar);
107
+ }
108
+ naiveMultiply(...args) {
109
+ const vec = Vec3.resolveArgs(args);
110
+ return new Vec3(this.x * vec.x, this.y * vec.y, this.z * vec.z);
111
+ }
112
+ divide(...args) {
113
+ if ((0, types_1.check_number_array)(args, 1))
114
+ return new Vec3(this.x / args[0], this.y / args[0], this.z / args[0]);
115
+ const vec = Vec3.resolveArgs(args);
116
+ return new Vec3(this.x / vec.x, this.y / vec.y, this.z / vec.z);
117
+ }
118
+ dot(...args) {
119
+ const vec = Vec3.resolveArgs(args);
120
+ return this.x * vec.x + this.y * vec.y + this.z * vec.z;
121
+ }
122
+ cross(...args) {
123
+ const vec = Vec3.resolveArgs(args);
124
+ return new Vec3(this.y * vec.z - this.z * vec.y, this.z * vec.x - this.x * vec.z, this.x * vec.y - this.y * vec.x);
125
+ }
126
+ distance(...args) {
127
+ const vec = Vec3.resolveArgs(args);
128
+ return Math.pow(vec.x - this.x, 2) + Math.pow(vec.y - this.y, 2) + Math.pow(vec.z - this.z, 2);
129
+ }
130
+ distanceSquare(...args) {
131
+ const vec = Vec3.resolveArgs(args);
132
+ return Math.sqrt(Math.pow(vec.x - this.x, 2) + Math.pow(vec.y - this.y, 2) + Math.pow(vec.z - this.z, 2));
133
+ }
134
+ length() {
135
+ return Math.sqrt(this.x * this.x + this.y * this.y + this.z * this.z);
136
+ }
137
+ normalize() {
138
+ const length = this.length();
139
+ if (length == 0)
140
+ return new Vec3;
141
+ return new Vec3(this.x / length, this.y / length, this.z / length);
142
+ }
143
+ invert() {
144
+ return this.multiply(-1);
145
+ }
146
+ }
147
+ exports.Vec3 = Vec3;
148
+ //# sourceMappingURL=vec3.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vec3.js","sourceRoot":"","sources":["../../../source/vectors/vec3.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ export class MathFunction {
2
+ }
3
+ //# sourceMappingURL=function.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"function.js","sourceRoot":"","sources":["../../../source/algebra/function.ts"],"names":[],"mappings":"AAEA,MAAM,OAAgB,YAAY;CAIjC"}
@@ -0,0 +1,38 @@
1
+ import { sign_char } from "../common/sign.js";
2
+ import { Vec2 } from "../vectors/vec2.js";
3
+ import { MathFunction } from "./function.js";
4
+ export class LinearFunction extends MathFunction {
5
+ m;
6
+ b;
7
+ static get(m, b, x) {
8
+ return new this(m, b).get(x);
9
+ }
10
+ static fromPoints(a, b) {
11
+ const veca = Vec2.resolve(a);
12
+ const vecb = Vec2.resolve(b);
13
+ const m = (vecb.y - veca.y) / (vecb.x - veca.x);
14
+ const h = -m * veca.x + veca.y;
15
+ return new this(m, h);
16
+ }
17
+ constructor(m, b) {
18
+ super();
19
+ this.m = m;
20
+ this.b = b;
21
+ }
22
+ get(x) {
23
+ return this.m;
24
+ }
25
+ roots() {
26
+ const x = -(this.b) / this.m;
27
+ if (!isNaN(x))
28
+ return [new Vec2(x)];
29
+ return [];
30
+ }
31
+ toString() {
32
+ const bsign = sign_char(this.b);
33
+ if (bsign)
34
+ return `f(x) = ${this.m} * x ${bsign} ${Math.abs(this.b)}`;
35
+ return `f(x) = ${this.m} * x`;
36
+ }
37
+ }
38
+ //# sourceMappingURL=linear.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"linear.js","sourceRoot":"","sources":["../../../source/algebra/linear.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAC1C,OAAO,EAAY,IAAI,EAAE,MAAM,iBAAiB,CAAA;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA;AAIzC,MAAM,OAAO,cAAe,SAAQ,YAAsB;IAc5B;IAAiB;IAZpC,MAAM,CAAC,GAAG,CAAC,CAAS,EAAC,CAAS,EAAC,CAAS;QAE3C,OAAO,IAAI,IAAI,CAAC,CAAC,EAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAA;IAC/B,CAAC;IACM,MAAM,CAAC,UAAU,CAAC,CAAW,EAAC,CAAW;QAE5C,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAA;QAC5B,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAA;QAC5B,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,GAAC,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAA;QAC7C,MAAM,CAAC,GAAG,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAA;QAC1B,OAAO,IAAI,IAAI,CAAC,CAAC,EAAC,CAAC,CAAC,CAAA;IACxB,CAAC;IACD,YAA0B,CAAS,EAAQ,CAAS;QAEhD,KAAK,EAAE,CAAA;QAFe,MAAC,GAAD,CAAC,CAAQ;QAAQ,MAAC,GAAD,CAAC,CAAQ;IAGpD,CAAC;IACM,GAAG,CAAC,CAAS;QAEhB,OAAO,IAAI,CAAC,CAAC,CAAA;IACjB,CAAC;IACM,KAAK;QAER,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAA;QAC1B,IAAG,CAAC,KAAK,CAAC,CAAC,CAAC;YACR,OAAO,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAA;QACxB,OAAO,EAAE,CAAA;IACb,CAAC;IACM,QAAQ;QAEX,MAAM,KAAK,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QAC/B,IAAG,KAAK;YACJ,OAAO,UAAU,IAAI,CAAC,CAAC,QAAQ,KAAK,IAAI,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAA;QAC9D,OAAO,UAAU,IAAI,CAAC,CAAC,MAAM,CAAA;IACjC,CAAC;CACJ"}
@@ -0,0 +1,49 @@
1
+ import { sign_char } from "../common/sign.js";
2
+ import { Vec2 } from "../vectors/vec2.js";
3
+ import { MathFunction } from "./function.js";
4
+ export class QuadFunction extends MathFunction {
5
+ a;
6
+ b;
7
+ c;
8
+ static get(a, b, c, x) {
9
+ return new this(a, b, c).get(x);
10
+ }
11
+ constructor(a, b, c) {
12
+ super();
13
+ this.a = a;
14
+ this.b = b;
15
+ this.c = c;
16
+ if (a == 0)
17
+ throw new Error("'a' cannot be 0");
18
+ }
19
+ get(x) {
20
+ return this.a * x * x + this.b * x + this.c;
21
+ }
22
+ roots() {
23
+ const roots = new Array;
24
+ const discriminant = this.b * this.b - 4 * this.a * this.c;
25
+ const n0 = (-this.b + Math.sqrt(discriminant)) / (2 * this.a);
26
+ const n1 = (-this.b + Math.sqrt(discriminant)) / (2 * this.a);
27
+ if (!isNaN(n0))
28
+ roots.push(new Vec2(n0));
29
+ if (!isNaN(n1) && n0 != n1)
30
+ roots.push(new Vec2(n1));
31
+ return roots;
32
+ }
33
+ toString(type = "standard") {
34
+ switch (type) {
35
+ default:
36
+ case "standard":
37
+ {
38
+ const bsign = sign_char(this.b);
39
+ const csign = sign_char(this.c);
40
+ if (bsign && csign)
41
+ return `f(x) = ${this.a}x^2 ${bsign} ${Math.abs(this.b)}x ${csign} ${Math.abs(this.c)}`;
42
+ if (bsign)
43
+ return `f(x) = ${this.a}x^2 ${bsign} ${Math.abs(this.b)}x`;
44
+ return `f(x) = ${this.a}x^2`;
45
+ }
46
+ }
47
+ }
48
+ }
49
+ //# sourceMappingURL=quad.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"quad.js","sourceRoot":"","sources":["../../../source/algebra/quad.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAA;AAC1C,OAAO,EAAE,IAAI,EAAY,MAAM,iBAAiB,CAAA;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA;AAQzC,MAAM,OAAO,YAAa,SAAQ,YAAsB;IAM1B;IAAiB;IAAiB;IAJrD,MAAM,CAAC,GAAG,CAAC,CAAS,EAAC,CAAS,EAAC,CAAS,EAAC,CAAS;QAErD,OAAO,IAAI,IAAI,CAAC,CAAC,EAAC,CAAC,EAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAA;IACjC,CAAC;IACD,YAA0B,CAAS,EAAQ,CAAS,EAAQ,CAAS;QAEjE,KAAK,EAAE,CAAA;QAFe,MAAC,GAAD,CAAC,CAAQ;QAAQ,MAAC,GAAD,CAAC,CAAQ;QAAQ,MAAC,GAAD,CAAC,CAAQ;QAGjE,IAAG,CAAC,IAAI,CAAC;YACL,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAA;IAC1C,CAAC;IACM,GAAG,CAAC,CAAS;QAEhB,OAAO,IAAI,CAAC,CAAC,GAAC,CAAC,GAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAA;IACzC,CAAC;IACM,KAAK;QAER,MAAM,KAAK,GAAG,IAAI,KAAW,CAAA;QAE7B,MAAM,YAAY,GAAG,IAAI,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAA;QACxD,MAAM,EAAE,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,GAAC,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QACzD,MAAM,EAAE,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,GAAC,CAAC,CAAC,GAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QAEzD,IAAG,CAAC,KAAK,CAAC,EAAE,CAAC;YACT,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,EAAE,CAAC,CAAC,CAAA;QAC5B,IAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE;YACrB,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,EAAE,CAAC,CAAC,CAAA;QAE5B,OAAO,KAAK,CAAA;IAChB,CAAC;IACM,QAAQ,CAA6B,OAAU,UAAe;QAEjE,QAAO,IAAI,EACX,CAAC;YACG,QAAQ;YACR,KAAK,UAAU;gBACf,CAAC;oBACG,MAAM,KAAK,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;oBAC/B,MAAM,KAAK,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;oBAC/B,IAAG,KAAK,IAAI,KAAK;wBACb,OAAO,UAAU,IAAI,CAAC,CAAC,OAAO,KAAK,IAAI,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,KAAK,IAAI,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAA;oBAC3F,IAAG,KAAK;wBACJ,OAAO,UAAU,IAAI,CAAC,CAAC,OAAO,KAAK,IAAI,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAA;oBAC9D,OAAO,UAAU,IAAI,CAAC,CAAC,KAAK,CAAA;gBAChC,CAAC;QACL,CAAC;IACL,CAAC;CACJ"}