deeptwins-cesium-engine 0.1.2 → 0.1.4

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 (219) hide show
  1. package/Build/Workers/chunk-2HWLF3FT.js +837 -0
  2. package/Build/Workers/chunk-2KXMJ5XS.js +3792 -0
  3. package/Build/Workers/chunk-2NPCLB3H.js +56 -0
  4. package/Build/Workers/chunk-2ZHQTIBH.js +1483 -0
  5. package/Build/Workers/chunk-3GLYOW63.js +352 -0
  6. package/Build/Workers/chunk-3L22KMPU.js +219 -0
  7. package/Build/Workers/chunk-3Q6V2B2I.js +73 -0
  8. package/Build/Workers/chunk-3QOKKRIG.js +387 -0
  9. package/Build/Workers/chunk-44YZFGRH.js +1800 -0
  10. package/Build/Workers/chunk-45VV4SBO.js +2342 -0
  11. package/Build/Workers/chunk-4EJ4AA2S.js +368 -0
  12. package/Build/Workers/chunk-4IJFHUL6.js +414 -0
  13. package/Build/Workers/chunk-4K3V5CGW.js +454 -0
  14. package/Build/Workers/chunk-4M4QL6KJ.js +305 -0
  15. package/Build/Workers/chunk-4YNRIEQ6.js +288 -0
  16. package/Build/Workers/chunk-56CVDPH5.js +352 -0
  17. package/Build/Workers/chunk-5CTAAPXH.js +1483 -0
  18. package/Build/Workers/chunk-5ISZ6NJD.js +102 -0
  19. package/Build/Workers/chunk-5SDHYIOS.js +56 -0
  20. package/Build/Workers/chunk-66TGUMCU.js +2719 -0
  21. package/Build/Workers/chunk-6EJMTDQJ.js +163 -0
  22. package/Build/Workers/chunk-6VWXYSMH.js +959 -0
  23. package/Build/Workers/chunk-6VZ7VB2Q.js +241 -0
  24. package/Build/Workers/chunk-7AMRE57Q.js +301 -0
  25. package/Build/Workers/chunk-7DH6C33H.js +398 -0
  26. package/Build/Workers/chunk-7VUS3FVE.js +38 -0
  27. package/Build/Workers/chunk-7Y3ZA6H3.js +198 -0
  28. package/Build/Workers/chunk-A6BMHZNA.js +38 -0
  29. package/Build/Workers/chunk-A7XY2MN7.js +171 -0
  30. package/Build/Workers/chunk-AC7ND63S.js +57 -0
  31. package/Build/Workers/chunk-AHCZ757M.js +9230 -0
  32. package/Build/Workers/chunk-ANOA7E7F.js +56 -0
  33. package/Build/Workers/chunk-AYO5HHV6.js +789 -0
  34. package/Build/Workers/chunk-BE2N56VZ.js +1344 -0
  35. package/Build/Workers/chunk-BR3BPM64.js +9230 -0
  36. package/Build/Workers/chunk-BVMRWGOK.js +455 -0
  37. package/Build/Workers/chunk-BXEL2NX7.js +455 -0
  38. package/Build/Workers/chunk-C5BO2JCG.js +278 -0
  39. package/Build/Workers/chunk-CIRQNZVR.js +301 -0
  40. package/Build/Workers/chunk-CM67CQME.js +305 -0
  41. package/Build/Workers/chunk-D3QIW4DH.js +630 -0
  42. package/Build/Workers/chunk-E5W7QIGZ.js +511 -0
  43. package/Build/Workers/chunk-E6CYGUJI.js +1054 -0
  44. package/Build/Workers/chunk-EIZ23IOX.js +414 -0
  45. package/Build/Workers/chunk-EIZJUMQY.js +101 -0
  46. package/Build/Workers/chunk-EXTMZJXB.js +82 -0
  47. package/Build/Workers/chunk-EYOOSIBW.js +682 -0
  48. package/Build/Workers/chunk-F37WADVC.js +1054 -0
  49. package/Build/Workers/chunk-FIWPJFHX.js +101 -0
  50. package/Build/Workers/chunk-FM32TNGT.js +198 -0
  51. package/Build/Workers/chunk-FOMYIEIB.js +476 -0
  52. package/Build/Workers/chunk-FWYDLSVQ.js +97 -0
  53. package/Build/Workers/chunk-HGZR6CZF.js +1067 -0
  54. package/Build/Workers/chunk-HIXHDABG.js +288 -0
  55. package/Build/Workers/chunk-HMCCZZWE.js +97 -0
  56. package/Build/Workers/chunk-HW54WHGM.js +2719 -0
  57. package/Build/Workers/chunk-IHYAI7GF.js +973 -0
  58. package/Build/Workers/chunk-INLQ7LVK.js +837 -0
  59. package/Build/Workers/chunk-IQMESTCB.js +124 -0
  60. package/Build/Workers/chunk-J4PISUNT.js +2342 -0
  61. package/Build/Workers/chunk-JSWU557I.js +693 -0
  62. package/Build/Workers/chunk-KHONDSQ7.js +693 -0
  63. package/Build/Workers/chunk-KLUL2SOE.js +352 -0
  64. package/Build/Workers/chunk-KMBLKQCC.js +1992 -0
  65. package/Build/Workers/chunk-KOTWWQN7.js +171 -0
  66. package/Build/Workers/chunk-KWV6ZTF4.js +163 -0
  67. package/Build/Workers/chunk-LSEFPQHG.js +476 -0
  68. package/Build/Workers/chunk-M66X4O24.js +44 -0
  69. package/Build/Workers/chunk-M6IXKBC7.js +1992 -0
  70. package/Build/Workers/chunk-MFUC3D5C.js +162 -0
  71. package/Build/Workers/chunk-MRMNELAH.js +82 -0
  72. package/Build/Workers/chunk-N3NUA5H2.js +3792 -0
  73. package/Build/Workers/chunk-NFB2NXJN.js +138 -0
  74. package/Build/Workers/chunk-NQAXBK4K.js +789 -0
  75. package/Build/Workers/chunk-NUGQWV6S.js +352 -0
  76. package/Build/Workers/chunk-O7S7WL7K.js +278 -0
  77. package/Build/Workers/chunk-ODZYB26X.js +1287 -0
  78. package/Build/Workers/chunk-OEHJY463.js +3201 -0
  79. package/Build/Workers/chunk-OMMRNMXF.js +44 -0
  80. package/Build/Workers/chunk-OZ3CQDO3.js +138 -0
  81. package/Build/Workers/chunk-PNXBG64I.js +219 -0
  82. package/Build/Workers/chunk-PYR35GK4.js +973 -0
  83. package/Build/Workers/chunk-Q4CXGW74.js +57 -0
  84. package/Build/Workers/chunk-QGISLKCW.js +147 -0
  85. package/Build/Workers/chunk-QQHVOJW6.js +497 -0
  86. package/Build/Workers/chunk-QWCMMRJW.js +58 -0
  87. package/Build/Workers/chunk-RDEZCHF4.js +398 -0
  88. package/Build/Workers/chunk-SJTE7FVN.js +778 -0
  89. package/Build/Workers/chunk-SM5T67LR.js +162 -0
  90. package/Build/Workers/chunk-T27NNXEU.js +58 -0
  91. package/Build/Workers/chunk-T4J5BWUO.js +511 -0
  92. package/Build/Workers/chunk-T6JS4BRN.js +140 -0
  93. package/Build/Workers/chunk-UH6DUQBW.js +140 -0
  94. package/Build/Workers/chunk-UJAH6XKF.js +73 -0
  95. package/Build/Workers/chunk-UKSTJ2PH.js +454 -0
  96. package/Build/Workers/chunk-UQCDCCZ7.js +368 -0
  97. package/Build/Workers/chunk-UXIFNEA3.js +1287 -0
  98. package/Build/Workers/chunk-UXJ6J5L7.js +56 -0
  99. package/Build/Workers/chunk-V4VUAZXI.js +1800 -0
  100. package/Build/Workers/chunk-VQH2YXO2.js +497 -0
  101. package/Build/Workers/chunk-VXKCLSE4.js +241 -0
  102. package/Build/Workers/chunk-W3U6YBEI.js +280 -0
  103. package/Build/Workers/chunk-W75ZVFKP.js +778 -0
  104. package/Build/Workers/chunk-WCDFJYFB.js +1344 -0
  105. package/Build/Workers/chunk-WME5M6W3.js +630 -0
  106. package/Build/Workers/chunk-XDQBQB64.js +1067 -0
  107. package/Build/Workers/chunk-Y6HOIWE5.js +959 -0
  108. package/Build/Workers/chunk-YEMC2ZOR.js +147 -0
  109. package/Build/Workers/chunk-YWNF3TPE.js +682 -0
  110. package/Build/Workers/chunk-Z55VGWJP.js +280 -0
  111. package/Build/Workers/chunk-Z5YWP24C.js +124 -0
  112. package/Build/Workers/chunk-ZHXCWUJB.js +387 -0
  113. package/Build/Workers/chunk-ZIMPUF2I.js +102 -0
  114. package/Build/Workers/chunk-ZKDWYQKC.js +3201 -0
  115. package/Build/Workers/combineGeometry.js +24 -22
  116. package/Build/Workers/createBoxGeometry.js +18 -16
  117. package/Build/Workers/createBoxOutlineGeometry.js +23 -25
  118. package/Build/Workers/createCircleGeometry.js +29 -27
  119. package/Build/Workers/createCircleOutlineGeometry.js +22 -20
  120. package/Build/Workers/createCoplanarPolygonGeometry.js +43 -43
  121. package/Build/Workers/createCoplanarPolygonOutlineGeometry.js +37 -35
  122. package/Build/Workers/createCorridorGeometry.js +46 -49
  123. package/Build/Workers/createCorridorOutlineGeometry.js +40 -43
  124. package/Build/Workers/createCylinderGeometry.js +20 -18
  125. package/Build/Workers/createCylinderOutlineGeometry.js +27 -25
  126. package/Build/Workers/createEllipseGeometry.js +28 -25
  127. package/Build/Workers/createEllipseOutlineGeometry.js +21 -18
  128. package/Build/Workers/createEllipsoidGeometry.js +19 -17
  129. package/Build/Workers/createEllipsoidOutlineGeometry.js +18 -16
  130. package/Build/Workers/createFrustumGeometry.js +18 -16
  131. package/Build/Workers/createFrustumOutlineGeometry.js +21 -21
  132. package/Build/Workers/createGeometry.js +31 -26
  133. package/Build/Workers/createGroundPolylineGeometry.js +188 -135
  134. package/Build/Workers/createPlaneGeometry.js +22 -21
  135. package/Build/Workers/createPlaneOutlineGeometry.js +15 -13
  136. package/Build/Workers/createPolygonGeometry.js +51 -52
  137. package/Build/Workers/createPolygonOutlineGeometry.js +43 -44
  138. package/Build/Workers/createPolylineGeometry.js +37 -40
  139. package/Build/Workers/createPolylineVolumeGeometry.js +41 -44
  140. package/Build/Workers/createPolylineVolumeOutlineGeometry.js +36 -39
  141. package/Build/Workers/createRectangleGeometry.js +47 -53
  142. package/Build/Workers/createRectangleOutlineGeometry.js +32 -33
  143. package/Build/Workers/createSimplePolylineGeometry.js +33 -34
  144. package/Build/Workers/createSphereGeometry.js +20 -20
  145. package/Build/Workers/createSphereOutlineGeometry.js +19 -19
  146. package/Build/Workers/createTaskProcessorWorker.js +3 -3
  147. package/Build/Workers/createVectorTileClampedPolylines.js +16 -14
  148. package/Build/Workers/createVectorTileGeometries.js +24 -22
  149. package/Build/Workers/createVectorTilePoints.js +15 -13
  150. package/Build/Workers/createVectorTilePolygons.js +24 -21
  151. package/Build/Workers/createVectorTilePolylines.js +16 -14
  152. package/Build/Workers/createVerticesFromCesium3DTilesTerrain.js +25 -25
  153. package/Build/Workers/createVerticesFromGoogleEarthEnterpriseBuffer.js +29 -27
  154. package/Build/Workers/createVerticesFromHeightmap.js +42 -63
  155. package/Build/Workers/createVerticesFromQuantizedTerrainMesh.js +26 -280
  156. package/Build/Workers/createWallGeometry.js +35 -36
  157. package/Build/Workers/createWallOutlineGeometry.js +33 -34
  158. package/Build/Workers/decodeDraco.js +10 -11
  159. package/Build/Workers/decodeGoogleEarthEnterprisePacket.js +5 -5
  160. package/Build/Workers/decodeI3S.js +16 -20
  161. package/Build/Workers/gaussianSplatSorter.js +4 -4
  162. package/Build/Workers/gaussianSplatTextureGenerator.js +4 -4
  163. package/Build/Workers/incrementallyBuildTerrainPicker.js +20 -12
  164. package/Build/Workers/transcodeKTX2.js +42 -14
  165. package/Build/Workers/transferTypedArrayTest.js +1 -1
  166. package/Build/Workers/upsampleQuantizedTerrainMesh.js +24 -21
  167. package/Build/Workers/upsampleVerticesFromCesium3DTilesTerrain.js +25 -25
  168. package/Source/Shaders/BillboardCollectionFS.js +85 -81
  169. package/Source/Shaders/BillboardCollectionVS.js +60 -118
  170. package/Source/Shaders/Builtin/Constants/passCesium3DTile.js +1 -1
  171. package/Source/Shaders/Builtin/Constants/passCesium3DTileClassification.js +1 -1
  172. package/Source/Shaders/Builtin/Constants/passCesium3DTileClassificationIgnoreShow.js +1 -1
  173. package/Source/Shaders/Builtin/Constants/passCesium3DTileEdges.js +12 -0
  174. package/Source/Shaders/Builtin/Constants/passCesium3DTileEdgesDirect.js +11 -0
  175. package/Source/Shaders/Builtin/Constants/passGaussianSplats.js +11 -0
  176. package/Source/Shaders/Builtin/Constants/passOpaque.js +1 -1
  177. package/Source/Shaders/Builtin/Constants/passOverlay.js +1 -1
  178. package/Source/Shaders/Builtin/Constants/passTranslucent.js +1 -1
  179. package/Source/Shaders/Builtin/Constants/passVoxels.js +1 -1
  180. package/Source/Shaders/Builtin/CzmBuiltins.js +12 -0
  181. package/Source/Shaders/Builtin/Functions/columbusViewMorph.js +8 -1
  182. package/Source/Shaders/Builtin/Functions/computeTextureTransform.js +25 -0
  183. package/Source/Shaders/Builtin/Functions/decodeRGB8.js +24 -0
  184. package/Source/Shaders/Builtin/Functions/modelToWindowCoordinates.js +2 -1
  185. package/Source/Shaders/Builtin/Functions/unpackTexture.js +37 -0
  186. package/Source/Shaders/Builtin/Functions/windowToEyeCoordinates.js +0 -1
  187. package/Source/Shaders/EllipsoidVS.js +4 -4
  188. package/Source/Shaders/FXAA3_11.js +2 -0
  189. package/Source/Shaders/GlobeFS.js +22 -0
  190. package/Source/Shaders/GlobeVS.js +3 -2
  191. package/Source/Shaders/Model/MaterialStageFS.js +50 -20
  192. package/Source/Shaders/Model/MetadataStageFS.js +2 -1
  193. package/Source/Shaders/Model/MetadataStageVS.js +2 -1
  194. package/Source/Shaders/Model/ModelFS.js +32 -2
  195. package/Source/Shaders/Model/ModelVS.js +15 -1
  196. package/Source/Shaders/Model/PointCloudStylingStageVS.js +2 -1
  197. package/Source/Shaders/Model/PrimitiveOutlineStageFS.js +0 -1
  198. package/Source/Shaders/PointPrimitiveCollectionVS.js +8 -39
  199. package/Source/Shaders/PolygonSignedDistanceFS.js +64 -33
  200. package/Source/Shaders/PolylineCommon.js +1 -1
  201. package/Source/Shaders/ShadowVolumeAppearanceFS.js +7 -15
  202. package/Source/Shaders/SkyAtmosphereVS.js +2 -1
  203. package/Source/Shaders/Voxels/IntersectBox.js +20 -33
  204. package/Source/Shaders/Voxels/IntersectCylinder.js +28 -32
  205. package/Source/Shaders/Voxels/IntersectDepth.js +10 -6
  206. package/Source/Shaders/Voxels/IntersectEllipsoid.js +12 -20
  207. package/Source/Shaders/Voxels/IntersectLongitude.js +21 -9
  208. package/Source/Shaders/Voxels/Intersection.js +3 -5
  209. package/Source/Shaders/Voxels/IntersectionUtils.js +2 -1
  210. package/Source/Shaders/Voxels/Megatexture.js +15 -83
  211. package/Source/Shaders/Voxels/Octree.js +53 -61
  212. package/Source/Shaders/Voxels/VoxelFS.js +67 -52
  213. package/Source/Shaders/Voxels/VoxelUtils.js +0 -19
  214. package/index.js +346 -261
  215. package/package.json +1 -1
  216. package/Source/Shaders/Voxels/IntersectClippingPlanes.js +0 -80
  217. package/Source/Shaders/Voxels/convertUvToBox.js +0 -46
  218. package/Source/Shaders/Voxels/convertUvToCylinder.js +0 -101
  219. package/Source/Shaders/Voxels/convertUvToEllipsoid.js +0 -141
@@ -0,0 +1,3792 @@
1
+ /**
2
+ * @license
3
+ * Cesium - https://github.com/CesiumGS/cesium
4
+ * Version 0.1.4
5
+ *
6
+ * Copyright 2011-2022 Cesium Contributors
7
+ *
8
+ * Licensed under the Apache License, Version 2.0 (the "License");
9
+ * you may not use this file except in compliance with the License.
10
+ * You may obtain a copy of the License at
11
+ *
12
+ * http://www.apache.org/licenses/LICENSE-2.0
13
+ *
14
+ * Unless required by applicable law or agreed to in writing, software
15
+ * distributed under the License is distributed on an "AS IS" BASIS,
16
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17
+ * See the License for the specific language governing permissions and
18
+ * limitations under the License.
19
+ *
20
+ * Columbus View (Pat. Pend.)
21
+ *
22
+ * Portions licensed separately.
23
+ * See https://github.com/CesiumGS/cesium/blob/main/LICENSE.md for full licensing details.
24
+ */
25
+
26
+ import {
27
+ TerrainProvider_default
28
+ } from "./chunk-56CVDPH5.js";
29
+ import {
30
+ EllipsoidalOccluder_default,
31
+ TerrainEncoding_default,
32
+ VerticalExaggeration_default
33
+ } from "./chunk-NQAXBK4K.js";
34
+ import {
35
+ WebMercatorProjection_default
36
+ } from "./chunk-QGISLKCW.js";
37
+ import {
38
+ OrientedBoundingBox_default
39
+ } from "./chunk-2HWLF3FT.js";
40
+ import {
41
+ AttributeCompression_default
42
+ } from "./chunk-4K3V5CGW.js";
43
+ import {
44
+ AxisAlignedBoundingBox_default
45
+ } from "./chunk-MFUC3D5C.js";
46
+ import {
47
+ IntersectionTests_default,
48
+ Ray_default
49
+ } from "./chunk-BE2N56VZ.js";
50
+ import {
51
+ BoundingSphere_default,
52
+ Interval_default
53
+ } from "./chunk-ODZYB26X.js";
54
+ import {
55
+ Event_default,
56
+ Rectangle_default,
57
+ Resource_default,
58
+ Transforms_default,
59
+ binarySearch_default,
60
+ buildModuleUrl_default,
61
+ isCrossOriginUrl_default,
62
+ require_URI
63
+ } from "./chunk-BR3BPM64.js";
64
+ import {
65
+ Matrix4_default
66
+ } from "./chunk-OEHJY463.js";
67
+ import {
68
+ ComponentDatatype_default
69
+ } from "./chunk-C5BO2JCG.js";
70
+ import {
71
+ RuntimeError_default
72
+ } from "./chunk-T27NNXEU.js";
73
+ import {
74
+ Cartesian2_default,
75
+ Cartographic_default,
76
+ Ellipsoid_default,
77
+ FeatureDetection_default
78
+ } from "./chunk-M6IXKBC7.js";
79
+ import {
80
+ Cartesian3_default,
81
+ Frozen_default,
82
+ Matrix3_default
83
+ } from "./chunk-J4PISUNT.js";
84
+ import {
85
+ Math_default
86
+ } from "./chunk-VQH2YXO2.js";
87
+ import {
88
+ Check_default,
89
+ DeveloperError_default
90
+ } from "./chunk-KWV6ZTF4.js";
91
+ import {
92
+ __toESM,
93
+ defined_default
94
+ } from "./chunk-MRMNELAH.js";
95
+
96
+ // packages/engine/node_modules/meshoptimizer/meshopt_encoder.js
97
+ var MeshoptEncoder = (function() {
98
+ var wasm = "b9H79Tebbbe9ok9Geueu9Geub9Gbb9Gruuuuuuueu9Gvuuuuueu9Gduueu9Gluuuueu9Gvuuuuub9Gouuuuuub9Gluuuub9GiuuueuiE8AdilveoveovrrwrrrDDoDrbqqbelve9Weiiviebeoweuecj:Gdkr:PlCo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bb8F9TW79O9V9Wt9FW9U9J9V9KW9wWVtW949c919M9MWV9mW4W2be8A9TW79O9V9Wt9FW9U9J9V9KW9wWVtW949c919M9MWVbd8F9TW79O9V9Wt9FW9U9J9V9KW9wWVtW949c919M9MWV9c9V919U9KbiE9TW79O9V9Wt9FW9U9J9V9KW9wWVtW949wWV79P9V9UblY9TW79O9V9Wt9FW9U9J9V9KW69U9KW949c919M9MWVbv8E9TW79O9V9Wt9FW9U9J9V9KW69U9KW949c919M9MWV9c9V919U9Kbo8A9TW79O9V9Wt9FW9U9J9V9KW69U9KW949wWV79P9V9UbrE9TW79O9V9Wt9FW9U9J9V9KW69U9KW949tWG91W9U9JWbwa9TW79O9V9Wt9FW9U9J9V9KW69U9KW949tWG91W9U9JW9c9V919U9KbDL9TW79O9V9Wt9FW9U9J9V9KWS9P2tWV9p9JtbqK9TW79O9V9Wt9FW9U9J9V9KWS9P2tWV9r919HtbkL9TW79O9V9Wt9FW9U9J9V9KWS9P2tWVT949WbxY9TW79O9V9Wt9FW9U9J9V9KWS9P2tWVJ9V29VVbmE9TW79O9V9Wt9F9V9Wt9P9T9P96W9wWVtW94J9H9J9OWbza9TW79O9V9Wt9F9V9Wt9P9T9P96W9wWVtW94J9H9J9OW9ttV9P9WbHa9TW79O9V9Wt9F9V9Wt9P9T9P96W9wWVtW94SWt9J9O9sW9T9H9WbOK9TW79O9V9Wt9F79W9Ht9P9H29t9VVt9sW9T9H9WbAl79IV9RbXDwebcekdKYq:zf8Adbk;wadhud9:8Jjjjjbc;qw9Rgr8KjjjjbcbhwdnaeTmbabcbyd;i:I:cjbaoaocb9iEgDc:GeV86bbarc;adfcbcjdz:xjjjb8AdnaiTmbarc;adfadalz:wjjjb8Akarc;abfalfcbcbcjdal9RalcFe0Ez:xjjjb8Aarc;abfarc;adfalz:wjjjb8Aar9cb83iUar9cb83i8War9cb83iyar9cb83iaar9cb83iKar9cb83izar9cb83iwar9cb83ibcj;abal9Uc;WFbGcjdalca0Ehqdnaicd6mbavcd9imbaDTmbadcefhkaqci2gxal2hmarc;alfclfhParc;qlfceVhsarc;qofclVhzcbhHincdhOcbhAdnavci6mbar9cb83i;Ooar9cb83i;Goar9cb83i;yoar9cb83i;qoadaHfgoybbhCcbhXincbhwcbhQdninaoalfhLaoybbgKaC7aQVhQawcP0meaLhoaKhCawcefgwaXfai6mbkkcbhCarc;qofhwincwhYcwh8AdnaQaC93gocFeGgEcs0mbclh8AaEci0mbcdcbaEEh8Akdnaocw4cFeGgEcs0mbclhYaEci0mbcdcbaEEhYkaYa8AfhEawydbh3cwhYcwh8Adnaocz4cFeGg5cs0mbclh8Aa5ci0mbcdcba5Eh8AkaEa3fhEdnaocFFFFb0mbclhYaocFFF8F0mbcbcdaocjjjw6EhYkawaEa8AfaYfBdbawclfhwaCcefgCcw9hmbkaLhoaKhCaXczfgXai6mbkcbhocehwazhQinawaoaQydbarc;qofaocdtfydb6EhoaQclfhQawcefgwcw9hmbkaoclthAcihOkcbhEarc;qlfcbcjdz:xjjjb8AarcbBd;ilar9cb83i;aladh8Eaqh8Fakh3inarc;qlfadaEaEcb9h9Ral2falz:wjjjb8Aaia8Faia8F6EhadnaqaiaE9RaEaqfai6EgKcsfc9WGgoaK9nmbarc;qofaKfcbaoaK9Rz:xjjjb8AkadaEal2fhhcbhginagaAVcl4hXarc;alfagcdtfh8JaHh8Kcbh8Lina8LaHfhwdndndndndndndnagPlbedibkaKTmvahawfhoarc;qlfawfRbbhQarc;qofhwaahCinawaoRbbgYaQ9RgQcetaQcKtc8F91786bbawcefhwaoalfhoaYhQaEaCcufgC9hmbxvkkaKTmla8Kc9:Ghoa8LcitcwGh8Aarc;qlfawceVfRbbcwtarc;qlfawc9:GfRbbVhQarc;qofhwaahCinawa3aofRbbcwta8EaofRbbVgYaQ9RgQcetaQcztc8F917cFFiGa8A486bbaoalfhoawcefhwaYhQaEaCcufgC9hmbxlkkasa8Kc98GgQfhoa3aQfhYarc;qlfawc98GgQfRbbhCcwhwinaoRbbawtaCVhCaocefhoawcwfgwca9hmbxdkkaKTmdxekaKTmea8Lcith5ahaQfh8AcbhLina8ARbbhQcwhoaYhwinawRbbaotaQVhQawcefhwaocwfgoca9hmbkarc;qofaLfaQaC7aX93a5486bbaYalfhYa8Aalfh8AaQhCaLcefgLaK9hmbkka8Jydbh8AcbhLarc;qofhoincdhQcbhwinaQaoawfRbbcb9hfhQawcefgwcz9hmbkclhCcbhwinaCaoawfRbbcd0fhCawcefgwcz9hmbkcwhYcbhwinaYaoawfRbbcP0fhYawcefgwcz9hmbkaQaCaQaC6EgwaYawaY6Egwczawcz6Ea8Afh8AaoczfhoaLczfgLaK6mbka8Ja8ABdbka8Kcefh8Ka8Lcefg8Lcl9hmbkagcefggaO9hmbka8Eamfh8Ea8Faxfh8Fa3amfh3aEaxfgEai6mbkcbhocehwaPhQinawaoaQydbarc;alfaocdtfydb6EhoaQclfhQaOawcefgw9hmbkaraHcd4faAcdVaoaocdSE86bbaHclfgHal6mbkkabaefhgabcefhoalcd4g8McbaDEhkadcefh8Narc;abfceVhecbhmdndninaiam9nmearc;qofcbcjdz:xjjjb8Aagao9Rak6mdadamal2gwfhxcbhHa8Nawfhzaocbakz:xjjjbg8Fakfh3aqaiam9Ramaqfai6Egscsfgocl4cifcd4hOaoc9WGg8JThPindndndndndndndndndndnaDTmbaraHcd4fRbbgQciGPlbedlbkasTmdaxaHfhoarc;abfaHfRbbhQarc;qofhwashCinawaoRbbgYaQ9RgQcetaQcKtc8F91786bbawcefhwaoalfhoaYhQaCcufgCmbxikkasTmiaHcitcwGh8Aarc;abfaHceVfRbbcwtarc;abfaHc9:GgofRbbVhQaxaofhoarc;qofhwashCinawao8VbbgYaQ9RgQcetaQcztc8F917cFFiGa8A486bbawcefhwaoalfhoaYhQaCcufgCmbxikkaeaHc98Gg8Afhoaza8AfhYarc;abfa8AfRbbhCcwhwinaoRbbawtaCVhCaocefhoawcwfgwca9hmbkasTmdaQcl4hKaHcitcKGhEaxa8Afh8AcbhLina8ARbbhQcwhoaYhwinawRbbaotaQVhQawcefhwaocwfgoca9hmbkarc;qofaLfaQaC7aK93aE486bbaYalfhYa8Aalfh8AaQhCaLcefgLas9hmbkkaDmbcbhoxlka8JTmbcbhodninarc;qofaofgwcwf8Pibaw8Pib:e9qTmeaoczfgoa8J9pmdxbkkdnavmbcehoxikcbh8AaOhLaOhKinarc;qofa8Afgocwf8Pibhyao8Pibh8PcdhQcbhwinaQaoawfRbbcb9hfhQawcefgwcz9hmbkclhCcbhwinaCaoawfRbbcd0fhCawcefgwcz9hmbkcwhYcbhwinaYaoawfRbbcP0fhYawcefgwcz9hmbkaQaCaQaC6EgoaYaoaY6Egoczaocz6EaKfhKaocucbaya8P:e9cb9sEgwaoaw6EaLfhLa8Aczfg8Aa8J9pmdxbkka8FaHcd4fgoaoRbbcdaHcetcoGtV86bbxikdnaLas6mbaKas6mba8FaHcd4fgoaoRbbciaHcetcoGtV86bbaga39Ras6mra3arc;qofasz:wjjjbasfh3xikaLaK9phoka8FaHcd4fgwawRbbaoaHcetcoGtV86bbkaga39RaO6mla3cbaOz:xjjjbgaaOfhKdndna8JmbaPhoxekdnagaK9RcK9pmbaPhoxekaocdtc:q:G:cjbfcj:G:cjbaDEg3ydxghcetc;:FFFeGhAcuhEcuahtcu7cFeGh8Ecbh8Karc;qofhQinarc;qofa8KfhXczh8AdndndnahPDbeeeeeeedekcucbaXcwf8PibaX8Pib:e9cb9sEh8AxekcbhoaAh8Aina8Aa8EaQaofRbb9nfh8Aaocefgocz9hmbkkcih5cbhYinczhwdndndna3aYcdtfydbgLPDbeeeeeeedekcucbaXcwf8PibaX8Pib:e9cb9sEhwxekaLcetc;:FFFeGhwcuaLtcu7cFeGhCcbhoinawaCaQaofRbb9nfhwaocefgocz9hmbkkdndnawa8A6mbaLaE9hmeawa8A9hmea3a5cdtfydbcwSmekaYh5awh8AkaYcefgYci9hmbkaaa8Kco4fgoaoRbba5a8Kci4coGtV86bbdndndna3a5cdtfydbgEPDdbbbbbbbebkdncwaE9Tg5TmbcuaEtcu7hwdndnaEceSmbcbh8LaQhXinaXhoa5hYcbhCinaoRbbg8AawcFeGgLa8AaL6EaCaEtVhCaocefhoaYcufgYmbkaKaC86bbaXa5fhXaKcefhKa8La5fg8Lcz6mbxdkkcbh8LaQhXinaXhoa5hYcbhCinaoRbbg8AawcFeGgLa8AaL6EaCcetVhCaocefhoaYcufgYmbkaKaC:T9cFe:d9c:c:qj:bw9:9c:q;c1:I1e:d9c:b:c:e1z9:9ca188bbaXa5fhXaKcefhKa8La5fg8Lcz6mbkkcbhoinaKaQaofRbbgC86bbaKaCawcFeG9pfhKaocefgocz9hmbxikkdnaEceSmbinaKcb86bbaKcefhKxbkkinaKcb86bbaKcefhKxbkkaKaX8Pbw83bwaKaX8Pbb83bbaKczfhKka8Kczfg8Ka8J9pgomeaQczfhQagaK9RcK9pmbkkaoTmlaKh3aKTmlkaHcefgHal9hmbkarc;abfaxascufal2falz:wjjjb8Aasamfhma3hoa3mbkcbhwxdkdnagao9RakalfgwcKcaaDEgQawaQ0EgC9pmbcbhwxdkdnawaQ9pmbaocbaCaw9Rgwz:xjjjbawfhokaoarc;adfalz:wjjjbalfhodnaDTmbaoara8Mz:wjjjba8Mfhokaoab9Rhwxekcbhwkarc;qwf8Kjjjjbawk5babaeadaialcdcbyd;i:I:cjbz:bjjjbk9reduaecd4gdaefgicaaica0Eabcj;abae9Uc;WFbGcjdaeca0Egifcufai9Uae2aiadfaicl4cifcd4f2fcefkmbcbabBd;i:I:cjbk;HPeLu8Jjjjjbc;ae9Rgl8Kjjjjbcbhvdnaeaici9UgocHf6mbabcbyd;m:I:cjbgrc;GeV86bbalc;abfcFecjez:xjjjb8Aal9cu83iUal9cu83i8Wal9cu83iyal9cu83iaal9cu83iKal9cu83izal9cu83iwal9cu83ibabaefc9WfhwabcefgDaofhednaiTmbcmcsarcb9kgqEhkcbhxcbhmcbhPcbhscbhzindnaeaw9nmbcbhvxikazcufhvadaPcdtfgHydbhOaHcwfydbhAaHclfydbhCcbhXdndndninalc;abfavcsGcitfgoydlhQdndndnaoydbgoaO9hmbaQaCSmekdnaoaC9hmbaQaA9hmbaXcefhXxekaoaA9hmeaQaO9hmeaXcdfhXkaXc870mdascufhvaHaXcdtgAcxGgoyd:4:G:cjbcdtfydbhQaHaoyd:0:G:cjbcdtfydbhCaHaoyd:W:G:cjbcdtfydbhOcbhodnindnalavcsGcdtfydbaQ9hmbaohXxdkcuhXavcufhvaocefgocz9hmbkkaxaQaxSgvaXce9iaXak9oVgoGfhxdndndncbcsavEaXaoEgvcs9hmbarce9imbaQaQamaQcefamSgvEgmcefSmecmcsavEhvkaDavaAc;WeGV86bbavcs9hmeaQam9Rgvcetavc8F917hvinaecbcjeavcje6EavcFbGV86bbaecefheavcr4gvmbkaQhmxvkcPhvaDaAcPV86bbaQhmkavTmiavak9omicdhocehXazhAxlkavcufhvaXclfgXc;ab9hmbkkdnaHcecdcbaAaxSEaCaxSEcdtgvyd:W:G:cjbcdtfydbgOTaHavyd:0:G:cjbcdtfydbgCceSGaHavyd:4:G:cjbcdtfydbgQcdSGaxcb9hGaqGgLce9hmbal9cu83iUal9cu83i8Wal9cu83iyal9cu83iaal9cu83iKal9cu83izal9cu83iwal9cu83ibcbhxkcbhXascufgvhodnindnalaocsGcdtfydbaC9hmbaXhAxdkcuhAaocufhoaXcefgXcz9hmbkkcbhodnindnalavcsGcdtfydbaQ9hmbaohXxdkcuhXavcufhvaocefgocz9hmbkkaxaOaxSgKfhHdndnaAcm0mbaAcefhAxekcbcsaCaHSgvEhAaHavfhHkdndnaXcm0mbaXcefhXxekcbcsaQaHSgvEhXaHavfhHkc9:cuaKEhYcbhvaXaAcltVg8AcFeGhodndndninavc;q:G:cjbfRbbaoSmeavcefgvcz9hmbxdkkaLaOax9havcm0VVmbaDavc;WeV86bbxekaDaY86bbaea8A86bbaecefhekdnaKmbaOam9Rgvcetavc8F917hvinaecbcjeavcje6EavcFbGV86bbaecefheavcr4gvmbkaOhmkdnaAcs9hmbaCam9Rgvcetavc8F917hvinaecbcjeavcje6EavcFbGV86bbaecefheavcr4gvmbkaChmkdnaXcs9hmbaQam9Rgvcetavc8F917hvinaecbcjeavcje6EavcFbGV86bbaecefheavcr4gvmbkaQhmkalascdtfaOBdbascefcsGhvdndnaAPzbeeeeeeeeeeeeeebekalavcdtfaCBdbascdfcsGhvkdndnaXPzbeeeeeeeeeeeeeebekalavcdtfaQBdbavcefcsGhvkcihoalc;abfazcitfgXaOBdlaXaCBdbazcefcsGhAcdhXavhsaHhxxekcdhoalascdtfaQBdbcehXascefcsGhsazhAkalc;abfaAcitfgvaCBdlavaQBdbalc;abfazaXfcsGcitfgvaQBdlavaOBdbaDcefhDazaofcsGhzaPcifgPai6mbkkdnaeaw9nmbcbhvxekcbhvinaeavfavc;q:G:cjbfRbb86bbavcefgvcz9hmbkaeab9Ravfhvkalc;aef8KjjjjbavkZeeucbhddninadcefgdc8F0meaeceadt0mbkkadcrfcFeGcr9Uci2cdfabci9U2cHfkmbcbabBd;m:I:cjbk:zderu8Jjjjjbcz9Rhlcbhvdnaeaicvf6mbabcbRb;m:I:cjbc;qeV86bbal9cb83iwabcefhvabaefc98fhodnaiTmbcbhecbhrcbhwindnavao6mbcbskadawcdtfydbgDalcwfaraDae9Rgeaec8F91ge7ae9Rc507grcdtfgqydb9Rgec8E91c9:Gaecdt7arVheinavcbcjeaecje6EaecFbGV86bbavcefhvaecr4gembkaqaDBdbaDheawcefgwai9hmbkkdnavao9nmbcbskavcbBbbavab9RclfhvkavkBeeucbhddninadcefgdc8F0meaeceadt0mbkkabadcwfcFeGcr9U2cvfk:dvli99dui99ludnaeTmbcuadcetcuftcu7:Zhvdndncuaicuftcu7:ZgoJbbbZMgr:lJbbb9p9DTmbar:Ohwxekcjjjj94hwkcbhicbhDinalclfIdbgrJbbbbJbbjZalIdbgq:lar:lMalcwfIdbgk:lMgr:varJbbbb9BEgrNhxaqarNhralcxfIdbhqdndnakJbbbb9GTmbaxhkxekJbbjZar:l:tgkak:maxJbbbb9GEhkJbbjZax:l:tgxax:marJbbbb9GEhrkdndnaqJbbj:;aqJbbj:;9GEgxJbbjZaxJbbjZ9FEavNJbbbZJbbb:;aqJbbbb9GEMgq:lJbbb9p9DTmbaq:Ohmxekcjjjj94hmkdndnakJbbj:;akJbbj:;9GEgqJbbjZaqJbbjZ9FEaoNJbbbZJbbb:;akJbbbb9GEMgq:lJbbb9p9DTmbaq:OhPxekcjjjj94hPkdndnarJbbj:;arJbbj:;9GEgqJbbjZaqJbbjZ9FEaoNJbbbZJbbb:;arJbbbb9GEMgr:lJbbb9p9DTmbar:Ohsxekcjjjj94hskdndnadcl9hmbabaDfgzas86bbazcifam86bbazcdfaw86bbazcefaP86bbxekabaifgzas87ebazcofam87ebazclfaw87ebazcdfaP87ebkaicwfhiaDclfhDalczfhlaecufgembkkk;hlld99eud99eudnaeTmbdndncuaicuftcu7:ZgvJbbbZMgo:lJbbb9p9DTmbao:Ohixekcjjjj94hikaic;8FiGhrinabcofcicdalclfIdb:lalIdb:l9EgialcwfIdb:lalaicdtfIdb:l9EEgialcxfIdb:lalaicdtfIdb:l9EEgiarV87ebdndnJbbj:;JbbjZalaicdtfIdbJbbbb9DEgoalaicd7cdtfIdbJ;Zl:1ZNNgwJbbj:;awJbbj:;9GEgDJbbjZaDJbbjZ9FEavNJbbbZJbbb:;awJbbbb9GEMgw:lJbbb9p9DTmbaw:Ohqxekcjjjj94hqkabcdfaq87ebdndnalaicefciGcdtfIdbJ;Zl:1ZNaoNgwJbbj:;awJbbj:;9GEgDJbbjZaDJbbjZ9FEavNJbbbZJbbb:;awJbbbb9GEMgw:lJbbb9p9DTmbaw:Ohqxekcjjjj94hqkabaq87ebdndnaoalaicufciGcdtfIdbJ;Zl:1ZNNgoJbbj:;aoJbbj:;9GEgwJbbjZawJbbjZ9FEavNJbbbZJbbb:;aoJbbbb9GEMgo:lJbbb9p9DTmbao:Ohixekcjjjj94hikabclfai87ebabcwfhbalczfhlaecufgembkkk;gvdDue998Jjjjjbcjd9Rgo8Kjjjjbdndndnadcd4grTmbc:CucbavEhwaohdarhDinadawBdbadclfhdaDcufgDmbkavcd9hmbaeTmbarcdthqcbhkalhxinaohdaxhDarhwinadadydbgmaDydbcL4cFeGc:cufgPamaP9kEBdbaDclfhDadclfhdawcufgwmbkaxaqfhxakcefgkae9hmbxdkkaeTmekarcdthxavce9hhqcbhkindndndnaqmbarTmdc:CuhDalhdarhwinaDadydbcL4cFeGc:cufgmaDam9kEhDadclfhdawcufgwmbxdkkdndndndnavPleddbdkarTmlaohdalhDarhwinadcbaDydbcL4cFeGgmc:cufgPaPam0EBdbadclfhdaDclfhDawcufgwmbxikkarTmicbhdarhDindnaladfIdbgsJbbbb9Bmbaoadfas:8cL4cFeGgwc8Aawc8A0Ec:cufBdbkadclfhdaDcufgDmbxdkkarTmdkc:CuhDkcbhdarhminaDhwdnavceSmbaoadfydbhwkdndnaladfIdbgscjjj;8iawai9RcefgwcLt9R::NJbbbZJbbb:;asJbbbb9GEMgs:lJbbb9p9DTmbas:OhPxekcjjjj94hPkabadfaPcFFFrGawcKtVBdbadclfhdamcufgmmbkkabaxfhbalaxfhlakcefgkae9hmbkkaocjdf8Kjjjjbk:Olveue99iue99iudnaeTmbceaicufthvcuaitcu7:Zhocbhradcl9hhwcbhDindndnalcwfIdbgqJbbbbaqJbbbb9GEgqJbbjZaqJbbjZ9FEaoNJbbbZMgq:lJbbb9p9DTmbaq:Ohixekcjjjj94hikdndnalIdbgqJbbbbaqJbbbb9GEgqJbbjZaqJbbjZ9FEaoNJbbbZMgq:lJbbb9p9DTmbaq:Ohdxekcjjjj94hdkadai9Rcd9TgkaifhidndnalclfIdbgqJbbbbaqJbbbb9GEgqJbbjZaqJbbjZ9FEaoNJbbbZMgq:lJbbb9p9DTmbaq:Ohdxekcjjjj94hdkadai9Rcd9ThddndnalcxfIdbgqJbbbbaqJbbbb9GEgqJbbjZaqJbbjZ9FEaoNJbbbZMgq:lJbbb9p9DTmbaq:Ohxxekcjjjj94hxkadaifhiaxce91avVhxdndnawmbabaDfgmai86bbamcifax86bbamcdfad86bbamcefak86bbxekabarfgmai87ebamcofax87ebamclfad87ebamcdfak87ebkarcwfhraDclfhDalczfhlaecufgembkkk;mqdQui998Jjjjjbc:qd9Rgv8Kjjjjbavc:Sefcbc;Kbz:xjjjb8AdnadTmbaiTmbdndnabaeSmbaehoxekavcuadcdtgradcFFFFi0Ecbyd;q:I:cjbHjjjjbbgoBd:SeavceBd:mdaoaearz:wjjjb8AkavcbBd:Oeav9cb83i:Geavc:Gefaoadaiavc:Sefz:pjjjbavyd:Gehwadci9UgDcbyd;q:I:cjbHjjjjbbheavc:Sefavyd:mdgqcdtfaeBdbavaqcefgrBd:mdaecbaDz:xjjjbhkavc:SefarcdtfcuaicdtaicFFFFi0Ecbyd;q:I:cjbHjjjjbbgxBdbavaqcdfgmBd:mdalc;ebfhPawheaxhrinaralIdbaPaeydbgscwascw6EcdtfIdbMUdbaeclfhearclfhraicufgimbkavc:SefamcdtfcuaDcdtadcFFFF970Ecbyd;q:I:cjbHjjjjbbgmBdbdnadci6mbaoheamhraDhiinaraxaeydbcdtfIdbaxaeclfydbcdtfIdbMaxaecwfydbcdtfIdbMUdbaecxfhearclfhraicufgimbkkaqcifhzalc;ebfhHavc;qbfhOavheavyd:KehAavyd:OehCcbhscbhrcbhXcehQinaehLaoarcx2fgKydbhPaKclfydbhdabaXcx2fgecwfaKcwfydbgYBdbaeclfadBdbaeaPBdbakarfce86bbaOaYBdwaOadBdlaOaPBdbamarcdtfcbBdbcih8AdnasTmbaLhiinaOa8AcdtfaiydbgeBdba8AaeaY9haeaP9haead9hGGfh8AaiclfhiascufgsmbkkaXcefhXcbhsinaCaAaKascdtfydbcdtgifydbcdtfgYheawaifgdydbgPhidnaPTmbdninaeydbarSmeaeclfheaicufgiTmdxbkkaeaYaPcdtfc98fydbBdbadadydbcufBdbkascefgsci9hmbkdndndna8ATmbcuhrJbbbbhEcbhdavyd:KehYavyd:OehKindnawaOadcdtfydbcdtgsfydbgeTmbaxasfgiIdbh3aialcuadadcs0EcdtfclfIdbaHaecwaecw6EcdtfIdbMg5Udba5a3:th5aecdthiaKaYasfydbcdtfheinamaeydbgscdtfgPa5aPIdbMg3Udba3aEaEa39DgPEhEasaraPEhraeclfheaic98fgimbkkadcefgda8A9hmbkarcu9hmekaQaD9pmeindnakaQfRbbmbaQhrxdkaDaQcefgQ9hmbxdkka8Acza8Acz6EhsaOheaLhOarcu9hmekkazTmbaqcdtavc:Seffcwfheinaeydbcbyd;u:I:cjbH:bjjjbbaec98fheazcufgzmbkkavc:qdf8Kjjjjbk:0leoucuaicdtgvaicFFFFi0Egocbyd;q:I:cjbHjjjjbbhralalyd9GgwcdtfarBdbalawcefBd9GabarBdbaocbyd;q:I:cjbHjjjjbbhralalyd9GgocdtfarBdbalaocefBd9GabarBdlcuadcdtadcFFFFi0Ecbyd;q:I:cjbHjjjjbbhralalyd9GgocdtfarBdbalaocefBd9GabarBdwabydbcbavz:xjjjb8AabydbhraehladhvinaralydbcdtfgoaoydbcefBdbalclfhlavcufgvmbkcbhvabydlglhoarhwaihDinaoavBdbaoclfhoawydbavfhvawclfhwaDcufgDmbkadci9Uhqdnadcd9nmbabydwhocbhvinaecwfydbhwaeclfydbhDalaeydbcdtfgbabydbgbcefBdbaoabcdtfavBdbalaDcdtfgDaDydbgDcefBdbaoaDcdtfavBdbalawcdtfgwawydbgwcefBdbaoawcdtfavBdbaecxfheaqavcefgv9hmbkkinalalydbarydb9RBdbarclfhralclfhlaicufgimbkkQbabaeadaic;G:G:cjbz:ojjjbkQbabaeadaic;i:H:cjbz:ojjjbk9DeeuabcFeaicdtz:xjjjbhlcbhbdnadTmbindnalaeydbcdtfgiydbcu9hmbaiabBdbabcefhbkaeclfheadcufgdmbkkabk:3vioud9:du8Jjjjjbc;Wa9Rgl8Kjjjjbcbhvalcxfcbc;Kbz:xjjjb8AalcuadcitgoadcFFFFe0Ecbyd;q:I:cjbHjjjjbbgrBdxalceBd2araeadaicezNjjjbalcuaoadcjjjjoGEcbyd;q:I:cjbHjjjjbbgwBdzadcdthednadTmbabhiinaiavBdbaiclfhiadavcefgv9hmbkkawaefhDalabBdwalawBdl9cbhqindnadTmbaq9cq9:hkarhvaDhiadheinaiav8Pibak1:NcFrG87ebavcwfhvaicdfhiaecufgembkkalclfaq:NceGcdtfydbhxalclfaq9ce98gq:NceGcdtfydbhmalc;Wbfcbcjaz:xjjjb8AaDhvadhidnadTmbinalc;Wbfav8VebcdtfgeaeydbcefBdbavcdfhvaicufgimbkkcbhvcbhiinalc;WbfavfgeydbhoaeaiBdbaoaifhiavclfgvcja9hmbkadhvdndnadTmbinalc;WbfaDamydbgicetf8VebcdtfgeaeydbgecefBdbaxaecdtfaiBdbamclfhmavcufgvmbkaq9cv9smdcbhvinabawydbcdtfavBdbawclfhwadavcefgv9hmbxdkkaq9cv9smekkcwhvcbhiinalcxfavfc98fydbcbyd;u:I:cjbH:bjjjbbaiceGheclhvcehiaeTmbkalc;Waf8Kjjjjbk:Awliuo99iud9:cbhv8Jjjjjbca9Rgocbyd:4:I:cjbBdKaocb8Pd:W:I:cjb83izaocbyd;e:I:cjbBdwaocb8Pd:8:I:cjb83ibaicd4hrdndnadmbJFFuFhwJFFuuhDJFFuuhqJFFuFhkJFFuuhxJFFuFhmxekarcdthPaehsincbhiinaoczfaifgzasaifIdbgwazIdbgDaDaw9EEUdbaoaifgzawazIdbgDaDaw9DEUdbaiclfgicx9hmbkasaPfhsavcefgvad9hmbkaoIdKhDaoIdwhwaoIdChqaoIdlhkaoIdzhxaoIdbhmkdnadTmbJbbbbJbFu9hJbbbbamax:tgmamJbbbb9DEgmakaq:tgkakam9DEgkawaD:tgwawak9DEgw:vawJbbbb9BEhwdnalmbarcdthoindndnaeclfIdbaq:tawNJbbbZMgk:lJbbb9p9DTmbak:Ohixekcjjjj94hikai:S9cC:ghHdndnaeIdbax:tawNJbbbZMgk:lJbbb9p9DTmbak:Ohixekcjjjj94hikaHai:S:ehHdndnaecwfIdbaD:tawNJbbbZMgk:lJbbb9p9DTmbak:Ohixekcjjjj94hikabaHai:T9cy:g:e83ibaeaofheabcwfhbadcufgdmbxdkkarcdthoindndnaeIdbax:tawNJbbbZMgk:lJbbb9p9DTmbak:Ohixekcjjjj94hikai:SgH9ca:gaH9cz:g9cjjj;4s:d:eaH9cFe:d:e9cF:bj;4:pj;ar:d9c:bd9:9c:p;G:d;4j:E;ar:d9cH9:9c;d;H:W:y:m:g;d;Hb:d9cv9:9c;j:KM;j:KM;j:Kd:dhOdndnaeclfIdbaq:tawNJbbbZMgk:lJbbb9p9DTmbak:Ohixekcjjjj94hikai:SgH9ca:gaH9cz:g9cjjj;4s:d:eaH9cFe:d:e9cF:bj;4:pj;ar:d9c:bd9:9c:p;G:d;4j:E;ar:d9cH9:9c;d;H:W:y:m:g;d;Hb:d9cq9:9cM;j:KM;j:KM;jl:daO:ehOdndnaecwfIdbaD:tawNJbbbZMgk:lJbbb9p9DTmbak:Ohixekcjjjj94hikabaOai:SgH9ca:gaH9cz:g9cjjj;4s:d:eaH9cFe:d:e9cF:bj;4:pj;ar:d9c:bd9:9c:p;G:d;4j:E;ar:d9cH9:9c;d;H:W:y:m:g;d;Hb:d9cC9:9c:KM;j:KM;j:KMD:d:e83ibaeaofheabcwfhbadcufgdmbkkk9teiucbcbyd;y:I:cjbgeabcifc98GfgbBd;y:I:cjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaik;LeeeudndnaeabVciGTmbabhixekdndnadcz9pmbabhixekabhiinaiaeydbBdbaiclfaeclfydbBdbaicwfaecwfydbBdbaicxfaecxfydbBdbaeczfheaiczfhiadc9Wfgdcs0mbkkadcl6mbinaiaeydbBdbaeclfheaiclfhiadc98fgdci0mbkkdnadTmbinaiaeRbb86bbaicefhiaecefheadcufgdmbkkabk;aeedudndnabciGTmbabhixekaecFeGc:b:c:ew2hldndnadcz9pmbabhixekabhiinaialBdbaicxfalBdbaicwfalBdbaiclfalBdbaiczfhiadc9Wfgdcs0mbkkadcl6mbinaialBdbaiclfhiadc98fgdci0mbkkdnadTmbinaiae86bbaicefhiadcufgdmbkkabk9teiucbcbyd;y:I:cjbgeabcrfc94GfgbBd;y:I:cjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaikTeeucbabcbyd;y:I:cjbge9Rcifc98GaefgbBd;y:I:cjbdnabZbcztge9nmbabae9RcFFifcz4nb8Akkk;Sddbcj:Gdk;idbbbbdbbblbbbwbbbbbbbebbbdbbblbbbwbbbbbbbbbbbbbbbbbbbebbbdbbbbbbbebbbbbbbbbbbbbbbb4:h9w9N94:P:gW:j9O:ye9Pbbbbbb:l29hZ;69:9kZ;N;76Z;rg97Z;z;o9xZ8J;B85Z;:;u9yZ;b;k9HZ:2;Z9DZ9e:l9mZ59A8KZ:r;T3Z:A:zYZ79OHZ;j4::8::Y:D9V8:bbbb9s:49:Z8R:hBZ9M9M;M8:L;z;o8:;8:PG89q;x:J878R:hQ8::M:B;e87bbbbbbjZbbjZbbjZ:E;V;N8::Y:DsZ9i;H;68:xd;R8:;h0838:;W:NoZbbbb:WV9O8:uf888:9i;H;68:9c9G;L89;n;m9m89;D8Ko8:bbbbf:8tZ9m836ZS:2AZL;zPZZ818EZ9e:lxZ;U98F8:819E;68:FFuuFFuuFFuuFFuFFFuFFFuFbc;i:IdkCebbbebbbebbbdbbb9G:rbb";
99
+ var wasmpack = new Uint8Array([
100
+ 32,
101
+ 0,
102
+ 65,
103
+ 2,
104
+ 1,
105
+ 106,
106
+ 34,
107
+ 33,
108
+ 3,
109
+ 128,
110
+ 11,
111
+ 4,
112
+ 13,
113
+ 64,
114
+ 6,
115
+ 253,
116
+ 10,
117
+ 7,
118
+ 15,
119
+ 116,
120
+ 127,
121
+ 5,
122
+ 8,
123
+ 12,
124
+ 40,
125
+ 16,
126
+ 19,
127
+ 54,
128
+ 20,
129
+ 9,
130
+ 27,
131
+ 255,
132
+ 113,
133
+ 17,
134
+ 42,
135
+ 67,
136
+ 24,
137
+ 23,
138
+ 146,
139
+ 148,
140
+ 18,
141
+ 14,
142
+ 22,
143
+ 45,
144
+ 70,
145
+ 69,
146
+ 56,
147
+ 114,
148
+ 101,
149
+ 21,
150
+ 25,
151
+ 63,
152
+ 75,
153
+ 136,
154
+ 108,
155
+ 28,
156
+ 118,
157
+ 29,
158
+ 73,
159
+ 115
160
+ ]);
161
+ if (typeof WebAssembly !== "object") {
162
+ return {
163
+ supported: false
164
+ };
165
+ }
166
+ var instance;
167
+ var ready = WebAssembly.instantiate(unpack(wasm), {}).then(function(result) {
168
+ instance = result.instance;
169
+ instance.exports.__wasm_call_ctors();
170
+ instance.exports.meshopt_encodeVertexVersion(1);
171
+ instance.exports.meshopt_encodeIndexVersion(1);
172
+ });
173
+ function unpack(data) {
174
+ var result = new Uint8Array(data.length);
175
+ for (var i = 0; i < data.length; ++i) {
176
+ var ch = data.charCodeAt(i);
177
+ result[i] = ch > 96 ? ch - 97 : ch > 64 ? ch - 39 : ch + 4;
178
+ }
179
+ var write = 0;
180
+ for (var i = 0; i < data.length; ++i) {
181
+ result[write++] = result[i] < 60 ? wasmpack[result[i]] : (result[i] - 60) * 64 + result[++i];
182
+ }
183
+ return result.buffer.slice(0, write);
184
+ }
185
+ function assert(cond) {
186
+ if (!cond) {
187
+ throw new Error("Assertion failed");
188
+ }
189
+ }
190
+ function bytes(view) {
191
+ return new Uint8Array(view.buffer, view.byteOffset, view.byteLength);
192
+ }
193
+ function reorder(fun, indices, vertices, optf) {
194
+ var sbrk = instance.exports.sbrk;
195
+ var ip = sbrk(indices.length * 4);
196
+ var rp = sbrk(vertices * 4);
197
+ var heap = new Uint8Array(instance.exports.memory.buffer);
198
+ var indices8 = bytes(indices);
199
+ heap.set(indices8, ip);
200
+ if (optf) {
201
+ optf(ip, ip, indices.length, vertices);
202
+ }
203
+ var unique = fun(rp, ip, indices.length, vertices);
204
+ heap = new Uint8Array(instance.exports.memory.buffer);
205
+ var remap = new Uint32Array(vertices);
206
+ new Uint8Array(remap.buffer).set(heap.subarray(rp, rp + vertices * 4));
207
+ indices8.set(heap.subarray(ip, ip + indices.length * 4));
208
+ sbrk(ip - sbrk(0));
209
+ for (var i = 0; i < indices.length; ++i) indices[i] = remap[indices[i]];
210
+ return [remap, unique];
211
+ }
212
+ function spatialsort(fun, positions, count, stride) {
213
+ var sbrk = instance.exports.sbrk;
214
+ var ip = sbrk(count * 4);
215
+ var sp = sbrk(count * stride);
216
+ var heap = new Uint8Array(instance.exports.memory.buffer);
217
+ heap.set(bytes(positions), sp);
218
+ fun(ip, sp, count, stride);
219
+ heap = new Uint8Array(instance.exports.memory.buffer);
220
+ var remap = new Uint32Array(count);
221
+ new Uint8Array(remap.buffer).set(heap.subarray(ip, ip + count * 4));
222
+ sbrk(ip - sbrk(0));
223
+ return remap;
224
+ }
225
+ function encode(fun, bound, source, count, size, level, version) {
226
+ var sbrk = instance.exports.sbrk;
227
+ var tp = sbrk(bound);
228
+ var sp = sbrk(count * size);
229
+ var heap = new Uint8Array(instance.exports.memory.buffer);
230
+ heap.set(bytes(source), sp);
231
+ var res = fun(tp, bound, sp, count, size, level, version);
232
+ var target = new Uint8Array(res);
233
+ target.set(heap.subarray(tp, tp + res));
234
+ sbrk(tp - sbrk(0));
235
+ return target;
236
+ }
237
+ function maxindex(source) {
238
+ var result = 0;
239
+ for (var i = 0; i < source.length; ++i) {
240
+ var index = source[i];
241
+ result = result < index ? index : result;
242
+ }
243
+ return result;
244
+ }
245
+ function index32(source, size) {
246
+ assert(size == 2 || size == 4);
247
+ if (size == 4) {
248
+ return new Uint32Array(source.buffer, source.byteOffset, source.byteLength / 4);
249
+ } else {
250
+ var view = new Uint16Array(source.buffer, source.byteOffset, source.byteLength / 2);
251
+ return new Uint32Array(view);
252
+ }
253
+ }
254
+ function filter(fun, source, count, stride, bits, insize, mode) {
255
+ var sbrk = instance.exports.sbrk;
256
+ var tp = sbrk(count * stride);
257
+ var sp = sbrk(count * insize);
258
+ var heap = new Uint8Array(instance.exports.memory.buffer);
259
+ heap.set(bytes(source), sp);
260
+ fun(tp, count, stride, bits, sp, mode);
261
+ var target = new Uint8Array(count * stride);
262
+ target.set(heap.subarray(tp, tp + count * stride));
263
+ sbrk(tp - sbrk(0));
264
+ return target;
265
+ }
266
+ return {
267
+ ready,
268
+ supported: true,
269
+ reorderMesh: function(indices, triangles, optsize) {
270
+ assert(indices instanceof Uint32Array || indices instanceof Int32Array);
271
+ assert(!triangles || indices.length % 3 == 0);
272
+ var optf = triangles ? optsize ? instance.exports.meshopt_optimizeVertexCacheStrip : instance.exports.meshopt_optimizeVertexCache : void 0;
273
+ return reorder(instance.exports.meshopt_optimizeVertexFetchRemap, indices, maxindex(indices) + 1, optf);
274
+ },
275
+ reorderPoints: function(positions, positions_stride) {
276
+ assert(positions instanceof Float32Array);
277
+ assert(positions.length % positions_stride == 0);
278
+ assert(positions_stride >= 3);
279
+ return spatialsort(instance.exports.meshopt_spatialSortRemap, positions, positions.length / positions_stride, positions_stride * 4);
280
+ },
281
+ encodeVertexBuffer: function(source, count, size) {
282
+ assert(size > 0 && size <= 256);
283
+ assert(size % 4 == 0);
284
+ var bound = instance.exports.meshopt_encodeVertexBufferBound(count, size);
285
+ return encode(instance.exports.meshopt_encodeVertexBuffer, bound, source, count, size);
286
+ },
287
+ encodeVertexBufferLevel: function(source, count, size, level, version) {
288
+ assert(size > 0 && size <= 256);
289
+ assert(size % 4 == 0);
290
+ assert(level >= 0 && level <= 3);
291
+ assert(version === void 0 || version == 0 || version == 1);
292
+ var bound = instance.exports.meshopt_encodeVertexBufferBound(count, size);
293
+ return encode(instance.exports.meshopt_encodeVertexBufferLevel, bound, source, count, size, level, version === void 0 ? -1 : version);
294
+ },
295
+ encodeIndexBuffer: function(source, count, size) {
296
+ assert(size == 2 || size == 4);
297
+ assert(count % 3 == 0);
298
+ var indices = index32(source, size);
299
+ var bound = instance.exports.meshopt_encodeIndexBufferBound(count, maxindex(indices) + 1);
300
+ return encode(instance.exports.meshopt_encodeIndexBuffer, bound, indices, count, 4);
301
+ },
302
+ encodeIndexSequence: function(source, count, size) {
303
+ assert(size == 2 || size == 4);
304
+ var indices = index32(source, size);
305
+ var bound = instance.exports.meshopt_encodeIndexSequenceBound(count, maxindex(indices) + 1);
306
+ return encode(instance.exports.meshopt_encodeIndexSequence, bound, indices, count, 4);
307
+ },
308
+ encodeGltfBuffer: function(source, count, size, mode, version) {
309
+ var table = {
310
+ ATTRIBUTES: this.encodeVertexBufferLevel,
311
+ TRIANGLES: this.encodeIndexBuffer,
312
+ INDICES: this.encodeIndexSequence
313
+ };
314
+ assert(table[mode]);
315
+ return table[mode](
316
+ source,
317
+ count,
318
+ size,
319
+ /* level= */
320
+ 2,
321
+ version === void 0 ? 0 : version
322
+ );
323
+ },
324
+ encodeFilterOct: function(source, count, stride, bits) {
325
+ assert(stride == 4 || stride == 8);
326
+ assert(bits >= 2 && bits <= 16);
327
+ return filter(instance.exports.meshopt_encodeFilterOct, source, count, stride, bits, 16);
328
+ },
329
+ encodeFilterQuat: function(source, count, stride, bits) {
330
+ assert(stride == 8);
331
+ assert(bits >= 4 && bits <= 16);
332
+ return filter(instance.exports.meshopt_encodeFilterQuat, source, count, stride, bits, 16);
333
+ },
334
+ encodeFilterExp: function(source, count, stride, bits, mode) {
335
+ assert(stride > 0 && stride % 4 == 0);
336
+ assert(bits >= 1 && bits <= 24);
337
+ var table = {
338
+ Separate: 0,
339
+ SharedVector: 1,
340
+ SharedComponent: 2,
341
+ Clamped: 3
342
+ };
343
+ assert(!mode || mode in table);
344
+ return filter(instance.exports.meshopt_encodeFilterExp, source, count, stride, bits, stride, mode ? table[mode] : 1);
345
+ },
346
+ encodeFilterColor: function(source, count, stride, bits) {
347
+ assert(stride == 4 || stride == 8);
348
+ assert(bits >= 2 && bits <= 16);
349
+ return filter(instance.exports.meshopt_encodeFilterColor, source, count, stride, bits, 16);
350
+ }
351
+ };
352
+ })();
353
+
354
+ // packages/engine/node_modules/meshoptimizer/meshopt_decoder.mjs
355
+ var MeshoptDecoder = (function() {
356
+ var wasm_base = "b9H79Tebbbe8Fv9Gbb9Gvuuuuueu9Giuuub9Geueu9Giuuueuixkbeeeddddillviebeoweuecj:Gdkr;Neqo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bb8A9TW79O9V9Wt9F9KW9J9V9KW9wWVtW949c919M9MWVbeY9TW79O9V9Wt9F9KW9J9V9KW69U9KW949c919M9MWVbdE9TW79O9V9Wt9F9KW9J9V9KW69U9KW949tWG91W9U9JWbiL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9p9JtblK9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9r919HtbvL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWVT949WboY9TW79O9V9Wt9F9KW9J9V9KWS9P2tWVJ9V29VVbrl79IV9Rbwq1Zkdbk:kYi5ud9:du8Jjjjjbcjq9Rgv8Kjjjjbc9:hodnalTmbcuhoaiRbbgrc;WeGc:Ge9hmbarcsGgwce0mbc9:hoalcufadcd4cbawEgDadfgrcKcaawEgqaraq0Egk6mbaicefhxcj;abad9Uc;WFbGcjdadca0EhmaialfgPar9Rgoadfhsavaoadz:jjjjbgzceVhHcbhOdndninaeaO9nmeaPax9RaD6mdamaeaO9RaOamfgoae6EgAcsfglc9WGhCaAcethXaxaDfhiaOaeaoaeao6E9RhQalcl4cifcd4hLazcjdfaAfhKcbhYabaOad2fg8AhEaHh3incbh5dnawTmbaxaYcd4fRbbh5kcbh8Eazcjdfhqinaih8Fdndndndna5a8Ecet4ciGgoc9:fPdebdkaPa8F9RaA6mrazcjdfa8EaA2fa8FaAz:jjjjb8Aa8FaAfhixdkazcjdfa8EaA2fcbaAz:kjjjb8Aa8FhixekaPa8F9RaL6mva8FaLfhidnaCTmbaPai9RcK6mbaocdtc:q:G:cjbfcj:G:cjbawEhaczhrcbhlinargoc9Wfghaqfhrdndndndndndnaaa8Fahco4fRbbalcoG4ciGcdtfydbPDbedvivvvlvkar9cb83bwar9cb83bbxlkarcbaiRbdai8Xbb9c:c:qj:bw9:9c:q;c1:I1e:d9c:b:c:e1z9:gg9cjjjjjz:dg8J9qE86bbaqaofgrcGfcbaicdfa8J9c8N1:NfghRbbag9cjjjjjw:dg8J9qE86bbarcVfcbaha8J9c8M1:NfghRbbag9cjjjjjl:dg8J9qE86bbarc7fcbaha8J9c8L1:NfghRbbag9cjjjjjd:dg8J9qE86bbarctfcbaha8J9c8K1:NfghRbbag9cjjjjje:dg8J9qE86bbarc91fcbaha8J9c8J1:NfghRbbag9cjjjj;ab:dg8J9qE86bbarc4fcbaha8J9cg1:NfghRbbag9cjjjja:dg8J9qE86bbarc93fcbaha8J9ch1:NfghRbbag9cjjjjz:dgg9qE86bbarc94fcbahag9ca1:NfghRbbai8Xbe9c:c:qj:bw9:9c:q;c1:I1e:d9c:b:c:e1z9:gg9cjjjjjz:dg8J9qE86bbarc95fcbaha8J9c8N1:NfgiRbbag9cjjjjjw:dg8J9qE86bbarc96fcbaia8J9c8M1:NfgiRbbag9cjjjjjl:dg8J9qE86bbarc97fcbaia8J9c8L1:NfgiRbbag9cjjjjjd:dg8J9qE86bbarc98fcbaia8J9c8K1:NfgiRbbag9cjjjjje:dg8J9qE86bbarc99fcbaia8J9c8J1:NfgiRbbag9cjjjj;ab:dg8J9qE86bbarc9:fcbaia8J9cg1:NfgiRbbag9cjjjja:dg8J9qE86bbarcufcbaia8J9ch1:NfgiRbbag9cjjjjz:dgg9qE86bbaiag9ca1:NfhixikaraiRblaiRbbghco4g8Ka8KciSg8KE86bbaqaofgrcGfaiclfa8Kfg8KRbbahcl4ciGg8La8LciSg8LE86bbarcVfa8Ka8Lfg8KRbbahcd4ciGg8La8LciSg8LE86bbarc7fa8Ka8Lfg8KRbbahciGghahciSghE86bbarctfa8Kahfg8KRbbaiRbeghco4g8La8LciSg8LE86bbarc91fa8Ka8Lfg8KRbbahcl4ciGg8La8LciSg8LE86bbarc4fa8Ka8Lfg8KRbbahcd4ciGg8La8LciSg8LE86bbarc93fa8Ka8Lfg8KRbbahciGghahciSghE86bbarc94fa8Kahfg8KRbbaiRbdghco4g8La8LciSg8LE86bbarc95fa8Ka8Lfg8KRbbahcl4ciGg8La8LciSg8LE86bbarc96fa8Ka8Lfg8KRbbahcd4ciGg8La8LciSg8LE86bbarc97fa8Ka8Lfg8KRbbahciGghahciSghE86bbarc98fa8KahfghRbbaiRbigico4g8Ka8KciSg8KE86bbarc99faha8KfghRbbaicl4ciGg8Ka8KciSg8KE86bbarc9:faha8KfghRbbaicd4ciGg8Ka8KciSg8KE86bbarcufaha8KfgrRbbaiciGgiaiciSgiE86bbaraifhixdkaraiRbwaiRbbghcl4g8Ka8KcsSg8KE86bbaqaofgrcGfaicwfa8Kfg8KRbbahcsGghahcsSghE86bbarcVfa8KahfghRbbaiRbeg8Kcl4g8La8LcsSg8LE86bbarc7faha8LfghRbba8KcsGg8Ka8KcsSg8KE86bbarctfaha8KfghRbbaiRbdg8Kcl4g8La8LcsSg8LE86bbarc91faha8LfghRbba8KcsGg8Ka8KcsSg8KE86bbarc4faha8KfghRbbaiRbig8Kcl4g8La8LcsSg8LE86bbarc93faha8LfghRbba8KcsGg8Ka8KcsSg8KE86bbarc94faha8KfghRbbaiRblg8Kcl4g8La8LcsSg8LE86bbarc95faha8LfghRbba8KcsGg8Ka8KcsSg8KE86bbarc96faha8KfghRbbaiRbvg8Kcl4g8La8LcsSg8LE86bbarc97faha8LfghRbba8KcsGg8Ka8KcsSg8KE86bbarc98faha8KfghRbbaiRbog8Kcl4g8La8LcsSg8LE86bbarc99faha8LfghRbba8KcsGg8Ka8KcsSg8KE86bbarc9:faha8KfghRbbaiRbrgicl4g8Ka8KcsSg8KE86bbarcufaha8KfgrRbbaicsGgiaicsSgiE86bbaraifhixekarai8Pbw83bwarai8Pbb83bbaiczfhikdnaoaC9pmbalcdfhlaoczfhraPai9RcL0mekkaoaC6moaimexokaCmva8FTmvkaqaAfhqa8Ecefg8Ecl9hmbkdndndndnawTmbasaYcd4fRbbgociGPlbedrbkaATmdazaYfh8Fazcjdfhhcbh8EaEhaina8FRbbhraahocbhlinaoahalfRbbgqce4cbaqceG9R7arfgr86bbaoadfhoaAalcefgl9hmbkaacefhaa8Fcefh8FahaAfhha8Ecefg8Ecl9hmbxikkaATmeazaYfhaazcjdfhhcbhoceh8EaKh8FinaEaofhlaa8Vbbhrcbhoinala8FaofRbbcwtahaofRbbgqVc;:FiGce4cbaqceG9R7arfgr87bbaladfhlaQaocefgofmbka8FaXfh8FcdhoaacdfhaahaXfhha8EceGhlcbh8EalmbxdkkaATmbaocl4h8EazaYfRbbhqcwhoa3hlinalRbbaotaqVhqalcefhlaocwfgoca9hmbkcbhhaEh8FaKhainazcjdfahfRbbhrcwhoaahlinalRbbaotarVhralaAfhlaocwfgoca9hmbkara8E94aq7hqcbhoa8Fhlinalaqao486bbalcefhlaocwfgoca9hmbka8Fadfh8FaacefhaahcefghaA9hmbkkaEclfhEa3clfh3aYclfgYad6mbkaza8AaAcufad2fadz:jjjjb8AaAaOfhOaihxaimbkc9:hoxdkcbc99aPax9RakSEhoxekc9:hokavcjqf8Kjjjjbaok:ysezu8Jjjjjbc;ae9Rgv8Kjjjjbc9:hodnalaeci9UgrcHf6mbcuhoaiRbbgwc;WeGc;Ge9hmbawcsGgDce0mbavc;abfcFecjez:kjjjb8Aav9cu83iUav9cu83i8Wav9cu83iyav9cu83iaav9cu83iKav9cu83izav9cu83iwav9cu83ibaialfc9WfhqaicefgwarfhldnaeTmbcmcsaDceSEhkcbhxcbhmcbhrcbhicbhoindnalaq9nmbc9:hoxikdndnawRbbgDc;Ve0mbavc;abfaoaDcu7gPcl4fcsGcitfgsydlhzasydbhHdndnaDcsGgsak9pmbavaiaPfcsGcdtfydbaxasEhDaxasTgOfhxxekdndnascsSmbcehOasc987asamffcefhDxekalcefhDal8SbbgscFeGhPdndnascu9mmbaDhlxekalcvfhlaPcFbGhPcrhsdninaD8SbbgOcFbGastaPVhPaOcu9kmeaDcefhDascrfgsc8J9hmbxdkkaDcefhlkcehOaPce4cbaPceG9R7amfhDkaDhmkavc;abfaocitfgsaDBdbasazBdlavaicdtfaDBdbavc;abfaocefcsGcitfgsaHBdbasaDBdlaocdfhoaOaifhidnadcd9hmbabarcetfgsaH87ebasclfaD87ebascdfaz87ebxdkabarcdtfgsaHBdbascwfaDBdbasclfazBdbxekdnaDcpe0mbavaiaqaDcsGfRbbgscl4gP9RcsGcdtfydbaxcefgOaPEhDavaias9RcsGcdtfydbaOaPTgzfgOascsGgPEhsaPThPdndnadcd9hmbabarcetfgHax87ebaHclfas87ebaHcdfaD87ebxekabarcdtfgHaxBdbaHcwfasBdbaHclfaDBdbkavaicdtfaxBdbavc;abfaocitfgHaDBdbaHaxBdlavaicefgicsGcdtfaDBdbavc;abfaocefcsGcitfgHasBdbaHaDBdlavaiazfgicsGcdtfasBdbavc;abfaocdfcsGcitfgDaxBdbaDasBdlaocifhoaiaPfhiaOaPfhxxekaxcbalRbbgsEgHaDc;:eSgDfhOascsGhAdndnascl4gCmbaOcefhzxekaOhzavaiaC9RcsGcdtfydbhOkdndnaAmbazcefhxxekazhxavaias9RcsGcdtfydbhzkdndnaDTmbalcefhDxekalcdfhDal8SbegPcFeGhsdnaPcu9kmbalcofhHascFbGhscrhldninaD8SbbgPcFbGaltasVhsaPcu9kmeaDcefhDalcrfglc8J9hmbkaHhDxekaDcefhDkasce4cbasceG9R7amfgmhHkdndnaCcsSmbaDhsxekaDcefhsaD8SbbglcFeGhPdnalcu9kmbaDcvfhOaPcFbGhPcrhldninas8SbbgDcFbGaltaPVhPaDcu9kmeascefhsalcrfglc8J9hmbkaOhsxekascefhskaPce4cbaPceG9R7amfgmhOkdndnaAcsSmbashlxekascefhlas8SbbgDcFeGhPdnaDcu9kmbascvfhzaPcFbGhPcrhDdninal8SbbgscFbGaDtaPVhPascu9kmealcefhlaDcrfgDc8J9hmbkazhlxekalcefhlkaPce4cbaPceG9R7amfgmhzkdndnadcd9hmbabarcetfgDaH87ebaDclfaz87ebaDcdfaO87ebxekabarcdtfgDaHBdbaDcwfazBdbaDclfaOBdbkavc;abfaocitfgDaOBdbaDaHBdlavaicdtfaHBdbavc;abfaocefcsGcitfgDazBdbaDaOBdlavaicefgicsGcdtfaOBdbavc;abfaocdfcsGcitfgDaHBdbaDazBdlavaiaCTaCcsSVfgicsGcdtfazBdbaiaATaAcsSVfhiaocifhokawcefhwaocsGhoaicsGhiarcifgrae6mbkkcbc99alaqSEhokavc;aef8Kjjjjbaok:clevu8Jjjjjbcz9Rhvdnalaecvf9pmbc9:skdnaiRbbc;:eGc;qeSmbcuskav9cb83iwaicefhoaialfc98fhrdnaeTmbdnadcdSmbcbhwindnaoar6mbc9:skaocefhlao8SbbgicFeGhddndnaicu9mmbalhoxekaocvfhoadcFbGhdcrhidninal8SbbgDcFbGaitadVhdaDcu9kmealcefhlaicrfgic8J9hmbxdkkalcefhokabawcdtfadc8Etc8F91adcd47avcwfadceGcdtVglydbfgiBdbalaiBdbawcefgwae9hmbxdkkcbhwindnaoar6mbc9:skaocefhlao8SbbgicFeGhddndnaicu9mmbalhoxekaocvfhoadcFbGhdcrhidninal8SbbgDcFbGaitadVhdaDcu9kmealcefhlaicrfgic8J9hmbxdkkalcefhokabawcetfadc8Etc8F91adcd47avcwfadceGcdtVglydbfgi87ebalaiBdbawcefgwae9hmbkkcbc99aoarSEk:Lvoeue99dud99eud99dndnadcl9hmbaeTmeindndnabcdfgd8Sbb:Yab8Sbbgi:Ygl:l:tabcefgv8Sbbgo:Ygr:l:tgwJbb;:9cawawNJbbbbawawJbbbb9GgDEgq:mgkaqaicb9iEalMgwawNakaqaocb9iEarMgqaqNMM:r:vglNJbbbZJbbb:;aDEMgr:lJbbb9p9DTmbar:Ohixekcjjjj94hikadai86bbdndnaqalNJbbbZJbbb:;aqJbbbb9GEMgq:lJbbb9p9DTmbaq:Ohdxekcjjjj94hdkavad86bbdndnawalNJbbbZJbbb:;awJbbbb9GEMgw:lJbbb9p9DTmbaw:Ohdxekcjjjj94hdkabad86bbabclfhbaecufgembxdkkaeTmbindndnabclfgd8Ueb:Yab8Uebgi:Ygl:l:tabcdfgv8Uebgo:Ygr:l:tgwJb;:FSawawNJbbbbawawJbbbb9GgDEgq:mgkaqaicb9iEalMgwawNakaqaocb9iEarMgqaqNMM:r:vglNJbbbZJbbb:;aDEMgr:lJbbb9p9DTmbar:Ohixekcjjjj94hikadai87ebdndnaqalNJbbbZJbbb:;aqJbbbb9GEMgq:lJbbb9p9DTmbaq:Ohdxekcjjjj94hdkavad87ebdndnawalNJbbbZJbbb:;awJbbbb9GEMgw:lJbbb9p9DTmbaw:Ohdxekcjjjj94hdkabad87ebabcwfhbaecufgembkkk:4ioiue99dud99dud99dnaeTmbcbhiabhlindndnal8Uebgv:YgoJ:ji:1Salcof8UebgrciVgw:Y:vgDNJbbbZJbbb:;avcu9kEMgq:lJbbb9p9DTmbaq:Ohkxekcjjjj94hkkalclf8Uebhvalcdf8UebhxalarcefciGcetfak87ebdndnax:YgqaDNJbbbZJbbb:;axcu9kEMgm:lJbbb9p9DTmbam:Ohxxekcjjjj94hxkabaiarciGgkfcd7cetfax87ebdndnav:YgmaDNJbbbZJbbb:;avcu9kEMgP:lJbbb9p9DTmbaP:Ohvxekcjjjj94hvkalarcufciGcetfav87ebdndnawaw2:ZgPaPMaoaoN:taqaqN:tamamN:tgoJbbbbaoJbbbb9GE:raDNJbbbZMgD:lJbbb9p9DTmbaD:Ohrxekcjjjj94hrkalakcetfar87ebalcwfhlaiclfhiaecufgembkkk9mbdnadcd4ae2gdTmbinababydbgecwtcw91:Yaece91cjjj98Gcjjj;8if::NUdbabclfhbadcufgdmbkkk:Tvirud99eudndnadcl9hmbaeTmeindndnabRbbgiabcefgl8Sbbgvabcdfgo8Sbbgrf9R:YJbbuJabcifgwRbbgdce4adVgDcd4aDVgDcl4aDVgD:Z:vgqNJbbbZMgk:lJbbb9p9DTmbak:Ohxxekcjjjj94hxkaoax86bbdndnaraif:YaqNJbbbZMgk:lJbbb9p9DTmbak:Ohoxekcjjjj94hokalao86bbdndnavaifar9R:YaqNJbbbZMgk:lJbbb9p9DTmbak:Ohixekcjjjj94hikabai86bbdndnaDadcetGadceGV:ZaqNJbbbZMgq:lJbbb9p9DTmbaq:Ohdxekcjjjj94hdkawad86bbabclfhbaecufgembxdkkaeTmbindndnab8Vebgiabcdfgl8Uebgvabclfgo8Uebgrf9R:YJbFu9habcofgw8Vebgdce4adVgDcd4aDVgDcl4aDVgDcw4aDVgD:Z:vgqNJbbbZMgk:lJbbb9p9DTmbak:Ohxxekcjjjj94hxkaoax87ebdndnaraif:YaqNJbbbZMgk:lJbbb9p9DTmbak:Ohoxekcjjjj94hokalao87ebdndnavaifar9R:YaqNJbbbZMgk:lJbbb9p9DTmbak:Ohixekcjjjj94hikabai87ebdndnaDadcetGadceGV:ZaqNJbbbZMgq:lJbbb9p9DTmbaq:Ohdxekcjjjj94hdkawad87ebabcwfhbaecufgembkkk9teiucbcbyd:K:G:cjbgeabcifc98GfgbBd:K:G:cjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaik;LeeeudndnaeabVciGTmbabhixekdndnadcz9pmbabhixekabhiinaiaeydbBdbaiclfaeclfydbBdbaicwfaecwfydbBdbaicxfaecxfydbBdbaeczfheaiczfhiadc9Wfgdcs0mbkkadcl6mbinaiaeydbBdbaeclfheaiclfhiadc98fgdci0mbkkdnadTmbinaiaeRbb86bbaicefhiaecefheadcufgdmbkkabk;aeedudndnabciGTmbabhixekaecFeGc:b:c:ew2hldndnadcz9pmbabhixekabhiinaialBdbaicxfalBdbaicwfalBdbaiclfalBdbaiczfhiadc9Wfgdcs0mbkkadcl6mbinaialBdbaiclfhiadc98fgdci0mbkkdnadTmbinaiae86bbaicefhiadcufgdmbkkabkk83dbcj:Gdk8Kbbbbdbbblbbbwbbbbbbbebbbdbbblbbbwbbbbc:K:Gdkl8W:qbb";
357
+ var wasm_simd = "b9H79TebbbeKl9Gbb9Gvuuuuueu9Giuuub9Geueuixkbbebeeddddilve9Weeeviebeoweuecj:Gdkr;Neqo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bb8A9TW79O9V9Wt9F9KW9J9V9KW9wWVtW949c919M9MWVbdY9TW79O9V9Wt9F9KW9J9V9KW69U9KW949c919M9MWVblE9TW79O9V9Wt9F9KW9J9V9KW69U9KW949tWG91W9U9JWbvL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9p9JtboK9TW79O9V9Wt9F9KW9J9V9KWS9P2tWV9r919HtbrL9TW79O9V9Wt9F9KW9J9V9KWS9P2tWVT949WbwY9TW79O9V9Wt9F9KW9J9V9KWS9P2tWVJ9V29VVbDl79IV9Rbqq:59Dklbzik94evu8Jjjjjbcz9Rhbcbheincbhdcbhiinabcwfadfaicjuaead4ceGglE86bbaialfhiadcefgdcw9hmbkaeai86b:q:W:cjbaecitab8Piw83i:q:G:cjbaecefgecjd9hmbkk:SBlEud97dur978Jjjjjbcj;kb9Rgv8Kjjjjbc9:hodnalTmbcuhoaiRbbgrc;WeGc:Ge9hmbarcsGgwce0mbc9:hoalcufadcd4cbawEgDadfgrcKcaawEgqaraq0Egk6mbaialfgxar9RhodnadTgmmbavaoad;8qbbkaicefhPcj;abad9Uc;WFbGcjdadca0EhsdndndnadTmbaoadfhzcbhHinaeaH9nmdaxaP9RaD6miabaHad2fgOavcjdfasaeaH9RaHasfae6EgAaAcsfgoc9WGgCSEhXaPaDfhQaocl4cifcd4hLavcj;cbfaCcetfhKavcj;cbfaCci2fhYavcj;cbfaCfh8AcbhEaoc;ab6h3incbh5dnawTmbaPaEcd4fRbbh5kcbh8Eavcj;cbfh8Findndndndna5a8Ecet4ciGgoc9:fPdebdkaxaQ9RaC6mwdnaCTmbavcj;cbfa8EaC2faQaC;8qbbkaQaAfhQxdkaCTmeavcj;cbfa8EaC2fcbaC;8kbxekaxaQ9RaL6moaoclVcbawEhraQaLfhocbhidna3mbaxao9Rc;Gb6mbcbhlina8FalfhidndndndndndnaQalco4fRbbgqciGarfPDbedibledibkaipxbbbbbbbbbbbbbbbbpklbxlkaiaopbblaopbbbgaclp:meaapmbzeHdOiAlCvXoQrLgacdp:meaapmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9oghpxiiiiiiiiiiiiiiiip8Jgap5b9cjF;8;4;W;G;ab9:9cU1:Nggcitpbi:q:G:cjbagRb:q:W:cjbggpsaap5e9cjF;8;4;W;G;ab9:9cU1:Ng8Jcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPahaap9spklbagaoclffa8JRb:q:W:cjbfhoxikaiaopbbwaopbbbgaclp:meaapmbzeHdOiAlCvXoQrLpxssssssssssssssssp9oghpxssssssssssssssssp8Jgap5b9cjF;8;4;W;G;ab9:9cU1:Nggcitpbi:q:G:cjbagRb:q:W:cjbggpsaap5e9cjF;8;4;W;G;ab9:9cU1:Ng8Jcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPahaap9spklbagaocwffa8JRb:q:W:cjbfhoxdkaiaopbbbpklbaoczfhoxekaiaopbbdaoRbbggcitpbi:q:G:cjbagRb:q:W:cjbggpsaoRbeg8Jcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPpklbagaocdffa8JRb:q:W:cjbfhokdndndndndndnaqcd4ciGarfPDbedibledibkaiczfpxbbbbbbbbbbbbbbbbpklbxlkaiczfaopbblaopbbbgaclp:meaapmbzeHdOiAlCvXoQrLgacdp:meaapmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9oghpxiiiiiiiiiiiiiiiip8Jgap5b9cjF;8;4;W;G;ab9:9cU1:Nggcitpbi:q:G:cjbagRb:q:W:cjbggpsaap5e9cjF;8;4;W;G;ab9:9cU1:Ng8Jcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPahaap9spklbagaoclffa8JRb:q:W:cjbfhoxikaiczfaopbbwaopbbbgaclp:meaapmbzeHdOiAlCvXoQrLpxssssssssssssssssp9oghpxssssssssssssssssp8Jgap5b9cjF;8;4;W;G;ab9:9cU1:Nggcitpbi:q:G:cjbagRb:q:W:cjbggpsaap5e9cjF;8;4;W;G;ab9:9cU1:Ng8Jcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPahaap9spklbagaocwffa8JRb:q:W:cjbfhoxdkaiczfaopbbbpklbaoczfhoxekaiczfaopbbdaoRbbggcitpbi:q:G:cjbagRb:q:W:cjbggpsaoRbeg8Jcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPpklbagaocdffa8JRb:q:W:cjbfhokdndndndndndnaqcl4ciGarfPDbedibledibkaicafpxbbbbbbbbbbbbbbbbpklbxlkaicafaopbblaopbbbgaclp:meaapmbzeHdOiAlCvXoQrLgacdp:meaapmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9oghpxiiiiiiiiiiiiiiiip8Jgap5b9cjF;8;4;W;G;ab9:9cU1:Nggcitpbi:q:G:cjbagRb:q:W:cjbggpsaap5e9cjF;8;4;W;G;ab9:9cU1:Ng8Jcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPahaap9spklbagaoclffa8JRb:q:W:cjbfhoxikaicafaopbbwaopbbbgaclp:meaapmbzeHdOiAlCvXoQrLpxssssssssssssssssp9oghpxssssssssssssssssp8Jgap5b9cjF;8;4;W;G;ab9:9cU1:Nggcitpbi:q:G:cjbagRb:q:W:cjbggpsaap5e9cjF;8;4;W;G;ab9:9cU1:Ng8Jcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPahaap9spklbagaocwffa8JRb:q:W:cjbfhoxdkaicafaopbbbpklbaoczfhoxekaicafaopbbdaoRbbggcitpbi:q:G:cjbagRb:q:W:cjbggpsaoRbeg8Jcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPpklbagaocdffa8JRb:q:W:cjbfhokdndndndndndnaqco4arfPDbedibledibkaic8Wfpxbbbbbbbbbbbbbbbbpklbxlkaic8Wfaopbblaopbbbgaclp:meaapmbzeHdOiAlCvXoQrLgacdp:meaapmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9oghpxiiiiiiiiiiiiiiiip8Jgap5b9cjF;8;4;W;G;ab9:9cU1:Ngicitpbi:q:G:cjbaiRb:q:W:cjbgipsaap5e9cjF;8;4;W;G;ab9:9cU1:Ngqcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPahaap9spklbaiaoclffaqRb:q:W:cjbfhoxikaic8Wfaopbbwaopbbbgaclp:meaapmbzeHdOiAlCvXoQrLpxssssssssssssssssp9oghpxssssssssssssssssp8Jgap5b9cjF;8;4;W;G;ab9:9cU1:Ngicitpbi:q:G:cjbaiRb:q:W:cjbgipsaap5e9cjF;8;4;W;G;ab9:9cU1:Ngqcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPahaap9spklbaiaocwffaqRb:q:W:cjbfhoxdkaic8Wfaopbbbpklbaoczfhoxekaic8WfaopbbdaoRbbgicitpbi:q:G:cjbaiRb:q:W:cjbgipsaoRbegqcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPpklbaiaocdffaqRb:q:W:cjbfhokalc;abfhialcjefaC0meaihlaxao9Rc;Fb0mbkkdnaiaC9pmbaici4hlinaxao9RcK6mwa8FaifhqdndndndndndnaQaico4fRbbalcoG4ciGarfPDbedibledibkaqpxbbbbbbbbbbbbbbbbpkbbxlkaqaopbblaopbbbgaclp:meaapmbzeHdOiAlCvXoQrLgacdp:meaapmbzeHdOiAlCvXoQrLpxiiiiiiiiiiiiiiiip9oghpxiiiiiiiiiiiiiiiip8Jgap5b9cjF;8;4;W;G;ab9:9cU1:Nggcitpbi:q:G:cjbagRb:q:W:cjbggpsaap5e9cjF;8;4;W;G;ab9:9cU1:Ng8Jcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPahaap9spkbbagaoclffa8JRb:q:W:cjbfhoxikaqaopbbwaopbbbgaclp:meaapmbzeHdOiAlCvXoQrLpxssssssssssssssssp9oghpxssssssssssssssssp8Jgap5b9cjF;8;4;W;G;ab9:9cU1:Nggcitpbi:q:G:cjbagRb:q:W:cjbggpsaap5e9cjF;8;4;W;G;ab9:9cU1:Ng8Jcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPahaap9spkbbagaocwffa8JRb:q:W:cjbfhoxdkaqaopbbbpkbbaoczfhoxekaqaopbbdaoRbbggcitpbi:q:G:cjbagRb:q:W:cjbggpsaoRbeg8Jcitpbi:q:G:cjbp9UpmbedilvorzHOACXQLpPpkbbagaocdffa8JRb:q:W:cjbfhokalcdfhlaiczfgiaC6mbkkaohQaoTmoka8FaCfh8Fa8Ecefg8Ecl9hmbkdndndndnawTmbazaEcd4fRbbglciGPlbedwbkaCTmdaXaEfhlavaEfpbdbh8Kcbhoinalavcj;cbfaofpblbg8La8Aaofpblbg8MpmbzeHdOiAlCvXoQrLg8NaKaofpblbgyaYaofpblbg8PpmbzeHdOiAlCvXoQrLgIpmbezHdiOAlvCXorQLgacep9Taapxeeeeeeeeeeeeeeeeghp9op9Hp9rgaa8Kp9Ug8Kp9Abbbaladfgla8Kaaaapmlvorlvorlvorlvorp9Ug8Kp9Abbbaladfgla8KaaaapmwDqkwDqkwDqkwDqkp9Ug8Kp9Abbbaladfgla8KaaaapmxmPsxmPsxmPsxmPsp9Ug8Kp9Abbbaladfgla8Ka8NaIpmwDKYqk8AExm35Ps8E8Fgacep9Taaahp9op9Hp9rgap9Ug8Kp9Abbbaladfgla8Kaaaapmlvorlvorlvorlvorp9Ug8Kp9Abbbaladfgla8KaaaapmwDqkwDqkwDqkwDqkp9Ug8Kp9Abbbaladfgla8KaaaapmxmPsxmPsxmPsxmPsp9Ug8Kp9Abbbaladfgla8Ka8La8MpmwKDYq8AkEx3m5P8Es8Fg8Laya8PpmwKDYq8AkEx3m5P8Es8Fg8MpmbezHdiOAlvCXorQLgacep9Taaahp9op9Hp9rgap9Ug8Kp9Abbbaladfgla8Kaaaapmlvorlvorlvorlvorp9Ug8Kp9Abbbaladfgla8KaaaapmwDqkwDqkwDqkwDqkp9Ug8Kp9Abbbaladfgla8KaaaapmxmPsxmPsxmPsxmPsp9Ug8Kp9Abbbaladfgla8Ka8La8MpmwDKYqk8AExm35Ps8E8Fgacep9Taaahp9op9Hp9rgap9Ughp9Abbbaladfglahaaaapmlvorlvorlvorlvorp9Ughp9AbbbaladfglahaaaapmwDqkwDqkwDqkwDqkp9Ughp9AbbbaladfglahaaaapmxmPsxmPsxmPsxmPsp9Ug8Kp9AbbbaladfhlaoczfgoaC6mbxikkaCTmeaXaEfhlavaEfpbdbh8Kcbhoinalavcj;cbfaofpblbg8La8Aaofpblbg8MpmbzeHdOiAlCvXoQrLg8NaKaofpblbgyaYaofpblbg8PpmbzeHdOiAlCvXoQrLgIpmbezHdiOAlvCXorQLgacep:neaapxebebebebebebebebghp9op:bep9rgaa8Kp:oeg8Kp9Abbbaladfgla8Kaaaapmlvorlvorlvorlvorp:oeg8Kp9Abbbaladfgla8KaaaapmwDqkwDqkwDqkwDqkp:oeg8Kp9Abbbaladfgla8KaaaapmxmPsxmPsxmPsxmPsp:oeg8Kp9Abbbaladfgla8Ka8NaIpmwDKYqk8AExm35Ps8E8Fgacep:neaaahp9op:bep9rgap:oeg8Kp9Abbbaladfgla8Kaaaapmlvorlvorlvorlvorp:oeg8Kp9Abbbaladfgla8KaaaapmwDqkwDqkwDqkwDqkp:oeg8Kp9Abbbaladfgla8KaaaapmxmPsxmPsxmPsxmPsp:oeg8Kp9Abbbaladfgla8Ka8La8MpmwKDYq8AkEx3m5P8Es8Fg8Laya8PpmwKDYq8AkEx3m5P8Es8Fg8MpmbezHdiOAlvCXorQLgacep:neaaahp9op:bep9rgap:oeg8Kp9Abbbaladfgla8Kaaaapmlvorlvorlvorlvorp:oeg8Kp9Abbbaladfgla8KaaaapmwDqkwDqkwDqkwDqkp:oeg8Kp9Abbbaladfgla8KaaaapmxmPsxmPsxmPsxmPsp:oeg8Kp9Abbbaladfgla8Ka8La8MpmwDKYqk8AExm35Ps8E8Fgacep:neaaahp9op:bep9rgap:oeghp9Abbbaladfglahaaaapmlvorlvorlvorlvorp:oeghp9AbbbaladfglahaaaapmwDqkwDqkwDqkwDqkp:oeghp9AbbbaladfglahaaaapmxmPsxmPsxmPsxmPsp:oeg8Kp9AbbbaladfhlaoczfgoaC6mbxdkkaCTmbaXaEfhrcbhocbalcl4gl9Rc8FGhiavaEfpbdbhhinaravcj;cbfaofpblbg8Ka8Aaofpblbg8LpmbzeHdOiAlCvXoQrLg8MaKaofpblbg8NaYaofpblbgypmbzeHdOiAlCvXoQrLg8PpmbezHdiOAlvCXorQLgaaip:Reaaalp:Tep9qgaahp9rghp9Abbbaradfgrahaaaapmlvorlvorlvorlvorp9rghp9AbbbaradfgrahaaaapmwDqkwDqkwDqkwDqkp9rghp9AbbbaradfgrahaaaapmxmPsxmPsxmPsxmPsp9rghp9Abbbaradfgraha8Ma8PpmwDKYqk8AExm35Ps8E8Fgaaip:Reaaalp:Tep9qgap9rghp9Abbbaradfgrahaaaapmlvorlvorlvorlvorp9rghp9AbbbaradfgrahaaaapmwDqkwDqkwDqkwDqkp9rghp9AbbbaradfgrahaaaapmxmPsxmPsxmPsxmPsp9rghp9Abbbaradfgraha8Ka8LpmwKDYq8AkEx3m5P8Es8Fg8Ka8NaypmwKDYq8AkEx3m5P8Es8Fg8LpmbezHdiOAlvCXorQLgaaip:Reaaalp:Tep9qgap9rghp9Abbbaradfgrahaaaapmlvorlvorlvorlvorp9rghp9AbbbaradfgrahaaaapmwDqkwDqkwDqkwDqkp9rghp9AbbbaradfgrahaaaapmxmPsxmPsxmPsxmPsp9rghp9Abbbaradfgraha8Ka8LpmwDKYqk8AExm35Ps8E8Fgaaip:Reaaalp:Tep9qgap9rghp9Abbbaradfgrahaaaapmlvorlvorlvorlvorp9rghp9AbbbaradfgrahaaaapmwDqkwDqkwDqkwDqkp9rghp9AbbbaradfgrahaaaapmxmPsxmPsxmPsxmPsp9rghp9AbbbaradfhraoczfgoaC6mbkkaEclfgEad6mbkdnaXavcjdf9hmbaAad2goTmbaOavcjdfao;8qbbkdnammbavaXaAcufad2fad;8qbbkaAaHfhHc9:hoaQhPaQmbxlkkaeTmbaDalfhrcbhocuhlinaralaD9RglfaD6mdasaeao9Raoasfae6Eaofgoae6mbkaial9RhPkcbc99axaP9RakSEhoxekc9:hokavcj;kbf8Kjjjjbaokwbz:bjjjbkNsezu8Jjjjjbc;ae9Rgv8Kjjjjbc9:hodnalaeci9UgrcHf6mbcuhoaiRbbgwc;WeGc;Ge9hmbawcsGgDce0mbavc;abfcFecje;8kbav9cu83iUav9cu83i8Wav9cu83iyav9cu83iaav9cu83iKav9cu83izav9cu83iwav9cu83ibaialfc9WfhqaicefgwarfhldnaeTmbcmcsaDceSEhkcbhxcbhmcbhrcbhicbhoindnalaq9nmbc9:hoxikdndnawRbbgDc;Ve0mbavc;abfaoaDcu7gPcl4fcsGcitfgsydlhzasydbhHdndnaDcsGgsak9pmbavaiaPfcsGcdtfydbaxasEhDaxasTgOfhxxekdndnascsSmbcehOasc987asamffcefhDxekalcefhDal8SbbgscFeGhPdndnascu9mmbaDhlxekalcvfhlaPcFbGhPcrhsdninaD8SbbgOcFbGastaPVhPaOcu9kmeaDcefhDascrfgsc8J9hmbxdkkaDcefhlkcehOaPce4cbaPceG9R7amfhDkaDhmkavc;abfaocitfgsaDBdbasazBdlavaicdtfaDBdbavc;abfaocefcsGcitfgsaHBdbasaDBdlaocdfhoaOaifhidnadcd9hmbabarcetfgsaH87ebasclfaD87ebascdfaz87ebxdkabarcdtfgsaHBdbascwfaDBdbasclfazBdbxekdnaDcpe0mbavaiaqaDcsGfRbbgscl4gP9RcsGcdtfydbaxcefgOaPEhDavaias9RcsGcdtfydbaOaPTgzfgOascsGgPEhsaPThPdndnadcd9hmbabarcetfgHax87ebaHclfas87ebaHcdfaD87ebxekabarcdtfgHaxBdbaHcwfasBdbaHclfaDBdbkavaicdtfaxBdbavc;abfaocitfgHaDBdbaHaxBdlavaicefgicsGcdtfaDBdbavc;abfaocefcsGcitfgHasBdbaHaDBdlavaiazfgicsGcdtfasBdbavc;abfaocdfcsGcitfgDaxBdbaDasBdlaocifhoaiaPfhiaOaPfhxxekaxcbalRbbgsEgHaDc;:eSgDfhOascsGhAdndnascl4gCmbaOcefhzxekaOhzavaiaC9RcsGcdtfydbhOkdndnaAmbazcefhxxekazhxavaias9RcsGcdtfydbhzkdndnaDTmbalcefhDxekalcdfhDal8SbegPcFeGhsdnaPcu9kmbalcofhHascFbGhscrhldninaD8SbbgPcFbGaltasVhsaPcu9kmeaDcefhDalcrfglc8J9hmbkaHhDxekaDcefhDkasce4cbasceG9R7amfgmhHkdndnaCcsSmbaDhsxekaDcefhsaD8SbbglcFeGhPdnalcu9kmbaDcvfhOaPcFbGhPcrhldninas8SbbgDcFbGaltaPVhPaDcu9kmeascefhsalcrfglc8J9hmbkaOhsxekascefhskaPce4cbaPceG9R7amfgmhOkdndnaAcsSmbashlxekascefhlas8SbbgDcFeGhPdnaDcu9kmbascvfhzaPcFbGhPcrhDdninal8SbbgscFbGaDtaPVhPascu9kmealcefhlaDcrfgDc8J9hmbkazhlxekalcefhlkaPce4cbaPceG9R7amfgmhzkdndnadcd9hmbabarcetfgDaH87ebaDclfaz87ebaDcdfaO87ebxekabarcdtfgDaHBdbaDcwfazBdbaDclfaOBdbkavc;abfaocitfgDaOBdbaDaHBdlavaicdtfaHBdbavc;abfaocefcsGcitfgDazBdbaDaOBdlavaicefgicsGcdtfaOBdbavc;abfaocdfcsGcitfgDaHBdbaDazBdlavaiaCTaCcsSVfgicsGcdtfazBdbaiaATaAcsSVfhiaocifhokawcefhwaocsGhoaicsGhiarcifgrae6mbkkcbc99alaqSEhokavc;aef8Kjjjjbaok:clevu8Jjjjjbcz9Rhvdnalaecvf9pmbc9:skdnaiRbbc;:eGc;qeSmbcuskav9cb83iwaicefhoaialfc98fhrdnaeTmbdnadcdSmbcbhwindnaoar6mbc9:skaocefhlao8SbbgicFeGhddndnaicu9mmbalhoxekaocvfhoadcFbGhdcrhidninal8SbbgDcFbGaitadVhdaDcu9kmealcefhlaicrfgic8J9hmbxdkkalcefhokabawcdtfadc8Etc8F91adcd47avcwfadceGcdtVglydbfgiBdbalaiBdbawcefgwae9hmbxdkkcbhwindnaoar6mbc9:skaocefhlao8SbbgicFeGhddndnaicu9mmbalhoxekaocvfhoadcFbGhdcrhidninal8SbbgDcFbGaitadVhdaDcu9kmealcefhlaicrfgic8J9hmbxdkkalcefhokabawcetfadc8Etc8F91adcd47avcwfadceGcdtVglydbfgi87ebalaiBdbawcefgwae9hmbkkcbc99aoarSEk;Toio97eue97aec98Ghedndnadcl9hmbaeTmecbhdinababpbbbgicKp:RecKp:Sep;6eglaicwp:RecKp:Sep;6ealp;Geaiczp:RecKp:Sep;6egvp;Gep;Kep;Legopxbbbbbbbbbbbbbbbbp:2egralpxbbbjbbbjbbbjbbbjgwp9op9rp;Keglpxbb;:9cbb;:9cbb;:9cbb;:9calalp;Meaoaop;Meavaravawp9op9rp;Keglalp;Mep;Kep;Kep;Jep;Negvp;Mepxbbn0bbn0bbn0bbn0grp;KepxFbbbFbbbFbbbFbbbp9oaipxbbbFbbbFbbbFbbbFp9op9qalavp;Mearp;Kecwp:RepxbFbbbFbbbFbbbFbbp9op9qaoavp;Mearp;Keczp:RepxbbFbbbFbbbFbbbFbp9op9qpkbbabczfhbadclfgdae6mbxdkkaeTmbcbhdinabczfgDaDpbbbgipxbbbbbbFFbbbbbbFFgwp9oabpbbbgoaipmbediwDqkzHOAKY8AEgvczp:Reczp:Sep;6eglaoaipmlvorxmPsCXQL358E8FpxFubbFubbFubbFubbp9op;6eavczp:Sep;6egvp;Gealp;Gep;Kep;Legipxbbbbbbbbbbbbbbbbp:2egralpxbbbjbbbjbbbjbbbjgqp9op9rp;Keglpxb;:FSb;:FSb;:FSb;:FSalalp;Meaiaip;Meavaravaqp9op9rp;Keglalp;Mep;Kep;Kep;Jep;Negvp;Mepxbbn0bbn0bbn0bbn0grp;KepxFFbbFFbbFFbbFFbbp9oaiavp;Mearp;Keczp:Rep9qgialavp;Mearp;KepxFFbbFFbbFFbbFFbbp9oglpmwDKYqk8AExm35Ps8E8Fp9qpkbbabaoawp9oaialpmbezHdiOAlvCXorQLp9qpkbbabcafhbadclfgdae6mbkkk;2ileue97euo97dnaec98GgiTmbcbheinabcKfpx:ji:1S:ji:1S:ji:1S:ji:1SabpbbbglabczfgvpbbbgopmlvorxmPsCXQL358E8Fgrczp:Segwpxibbbibbbibbbibbbp9qp;6egDp;NegqaDaDp;MegDaDp;KealaopmbediwDqkzHOAKY8AEgDczp:Reczp:Sep;6eglalp;MeaDczp:Sep;6egoaop;Mearczp:Reczp:Sep;6egrarp;Mep;Kep;Kep;Lepxbbbbbbbbbbbbbbbbp:4ep;Jep;Mepxbbn0bbn0bbn0bbn0gDp;KepxFFbbFFbbFFbbFFbbgkp9oaqaop;MeaDp;Keczp:Rep9qgoaqalp;MeaDp;Keakp9oaqarp;MeaDp;Keczp:Rep9qgDpmwDKYqk8AExm35Ps8E8Fglp5eawclp:RegqpEi:T:j83ibavalp5baqpEd:T:j83ibabcwfaoaDpmbezHdiOAlvCXorQLgDp5eaqpEe:T:j83ibabaDp5baqpEb:T:j83ibabcafhbaeclfgeai6mbkkkuee97dnadcd4ae2c98GgeTmbcbhdinababpbbbgicwp:Recwp:Sep;6eaicep:SepxbbjFbbjFbbjFbbjFp9opxbbjZbbjZbbjZbbjZp:Uep;Mepkbbabczfhbadclfgdae6mbkkk:Sodw97euaec98Ghedndnadcl9hmbaeTmecbhdinabpxbbuJbbuJbbuJbbuJabpbbbgicKp:TeglaicYp:Tep9qgvcdp:Teavp9qgvclp:Teavp9qgop;6ep;Negvaicwp:RecKp:SegraipxFbbbFbbbFbbbFbbbgwp9ogDp:Uep;6ep;Mepxbbn0bbn0bbn0bbn0gqp;Kecwp:RepxbFbbbFbbbFbbbFbbp9oavaDarp:Xeaiczp:RecKp:Segip:Uep;6ep;Meaqp;Keawp9op9qavaDaraip:Uep:Xep;6ep;Meaqp;Keczp:RepxbbFbbbFbbbFbbbFbp9op9qavaoalcep:Rep9oalpxebbbebbbebbbebbbp9op9qp;6ep;Meaqp;KecKp:Rep9qpkbbabczfhbadclfgdae6mbxdkkaeTmbcbhdinabczfgkpxbFu9hbFu9hbFu9hbFu9habpbbbglakpbbbgrpmlvorxmPsCXQL358E8Fgvczp:TegqavcHp:Tep9qgicdp:Teaip9qgiclp:Teaip9qgicwp:Teaip9qgop;6ep;NegialarpmbediwDqkzHOAKY8AEgDpxFFbbFFbbFFbbFFbbglp9ograDczp:Segwp:Ueavczp:Reczp:SegDp:Xep;6ep;Mepxbbn0bbn0bbn0bbn0gvp;Kealp9oaiarawaDp:Uep:Xep;6ep;Meavp;Keczp:Rep9qgwaiaoaqcep:Rep9oaqpxebbbebbbebbbebbbp9op9qp;6ep;Meavp;Keczp:ReaiaDarp:Uep;6ep;Meavp;Kealp9op9qgipmwDKYqk8AExm35Ps8E8FpkbbabawaipmbezHdiOAlvCXorQLpkbbabcafhbadclfgdae6mbkkk9teiucbcbydj:G:cjbgeabcifc98GfgbBdj:G:cjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaikkxebcj:Gdklz:zbb";
358
+ var detector = new Uint8Array([
359
+ 0,
360
+ 97,
361
+ 115,
362
+ 109,
363
+ 1,
364
+ 0,
365
+ 0,
366
+ 0,
367
+ 1,
368
+ 4,
369
+ 1,
370
+ 96,
371
+ 0,
372
+ 0,
373
+ 3,
374
+ 3,
375
+ 2,
376
+ 0,
377
+ 0,
378
+ 5,
379
+ 3,
380
+ 1,
381
+ 0,
382
+ 1,
383
+ 12,
384
+ 1,
385
+ 0,
386
+ 10,
387
+ 22,
388
+ 2,
389
+ 12,
390
+ 0,
391
+ 65,
392
+ 0,
393
+ 65,
394
+ 0,
395
+ 65,
396
+ 0,
397
+ 252,
398
+ 10,
399
+ 0,
400
+ 0,
401
+ 11,
402
+ 7,
403
+ 0,
404
+ 65,
405
+ 0,
406
+ 253,
407
+ 15,
408
+ 26,
409
+ 11
410
+ ]);
411
+ var wasmpack = new Uint8Array([
412
+ 32,
413
+ 0,
414
+ 65,
415
+ 2,
416
+ 1,
417
+ 106,
418
+ 34,
419
+ 33,
420
+ 3,
421
+ 128,
422
+ 11,
423
+ 4,
424
+ 13,
425
+ 64,
426
+ 6,
427
+ 253,
428
+ 10,
429
+ 7,
430
+ 15,
431
+ 116,
432
+ 127,
433
+ 5,
434
+ 8,
435
+ 12,
436
+ 40,
437
+ 16,
438
+ 19,
439
+ 54,
440
+ 20,
441
+ 9,
442
+ 27,
443
+ 255,
444
+ 113,
445
+ 17,
446
+ 42,
447
+ 67,
448
+ 24,
449
+ 23,
450
+ 146,
451
+ 148,
452
+ 18,
453
+ 14,
454
+ 22,
455
+ 45,
456
+ 70,
457
+ 69,
458
+ 56,
459
+ 114,
460
+ 101,
461
+ 21,
462
+ 25,
463
+ 63,
464
+ 75,
465
+ 136,
466
+ 108,
467
+ 28,
468
+ 118,
469
+ 29,
470
+ 73,
471
+ 115
472
+ ]);
473
+ if (typeof WebAssembly !== "object") {
474
+ return {
475
+ supported: false
476
+ };
477
+ }
478
+ var wasm = WebAssembly.validate(detector) ? unpack(wasm_simd) : unpack(wasm_base);
479
+ var instance;
480
+ var ready = WebAssembly.instantiate(wasm, {}).then(function(result) {
481
+ instance = result.instance;
482
+ instance.exports.__wasm_call_ctors();
483
+ });
484
+ function unpack(data) {
485
+ var result = new Uint8Array(data.length);
486
+ for (var i = 0; i < data.length; ++i) {
487
+ var ch = data.charCodeAt(i);
488
+ result[i] = ch > 96 ? ch - 97 : ch > 64 ? ch - 39 : ch + 4;
489
+ }
490
+ var write = 0;
491
+ for (var i = 0; i < data.length; ++i) {
492
+ result[write++] = result[i] < 60 ? wasmpack[result[i]] : (result[i] - 60) * 64 + result[++i];
493
+ }
494
+ return result.buffer.slice(0, write);
495
+ }
496
+ function decode(instance2, fun, target, count, size, source, filter) {
497
+ var sbrk = instance2.exports.sbrk;
498
+ var count4 = count + 3 & ~3;
499
+ var tp = sbrk(count4 * size);
500
+ var sp = sbrk(source.length);
501
+ var heap = new Uint8Array(instance2.exports.memory.buffer);
502
+ heap.set(source, sp);
503
+ var res = fun(tp, count, size, sp, source.length);
504
+ if (res == 0 && filter) {
505
+ filter(tp, count4, size);
506
+ }
507
+ target.set(heap.subarray(tp, tp + count * size));
508
+ sbrk(tp - sbrk(0));
509
+ if (res != 0) {
510
+ throw new Error("Malformed buffer data: " + res);
511
+ }
512
+ }
513
+ var filters = {
514
+ NONE: "",
515
+ OCTAHEDRAL: "meshopt_decodeFilterOct",
516
+ QUATERNION: "meshopt_decodeFilterQuat",
517
+ EXPONENTIAL: "meshopt_decodeFilterExp",
518
+ COLOR: "meshopt_decodeFilterColor"
519
+ };
520
+ var decoders = {
521
+ ATTRIBUTES: "meshopt_decodeVertexBuffer",
522
+ TRIANGLES: "meshopt_decodeIndexBuffer",
523
+ INDICES: "meshopt_decodeIndexSequence"
524
+ };
525
+ var workers = [];
526
+ var requestId = 0;
527
+ function createWorker2(url) {
528
+ var worker = {
529
+ object: new Worker(url),
530
+ pending: 0,
531
+ requests: {}
532
+ };
533
+ worker.object.onmessage = function(event) {
534
+ var data = event.data;
535
+ worker.pending -= data.count;
536
+ worker.requests[data.id][data.action](data.value);
537
+ delete worker.requests[data.id];
538
+ };
539
+ return worker;
540
+ }
541
+ function initWorkers(count) {
542
+ var source = "self.ready = WebAssembly.instantiate(new Uint8Array([" + new Uint8Array(wasm) + "]), {}).then(function(result) { result.instance.exports.__wasm_call_ctors(); return result.instance; });self.onmessage = " + workerProcess.name + ";" + decode.toString() + workerProcess.toString();
543
+ var blob = new Blob([source], { type: "text/javascript" });
544
+ var url = URL.createObjectURL(blob);
545
+ for (var i = workers.length; i < count; ++i) {
546
+ workers[i] = createWorker2(url);
547
+ }
548
+ for (var i = count; i < workers.length; ++i) {
549
+ workers[i].object.postMessage({});
550
+ }
551
+ workers.length = count;
552
+ URL.revokeObjectURL(url);
553
+ }
554
+ function decodeWorker(count, size, source, mode, filter) {
555
+ var worker = workers[0];
556
+ for (var i = 1; i < workers.length; ++i) {
557
+ if (workers[i].pending < worker.pending) {
558
+ worker = workers[i];
559
+ }
560
+ }
561
+ return new Promise(function(resolve, reject) {
562
+ var data = new Uint8Array(source);
563
+ var id = ++requestId;
564
+ worker.pending += count;
565
+ worker.requests[id] = { resolve, reject };
566
+ worker.object.postMessage({ id, count, size, source: data, mode, filter }, [data.buffer]);
567
+ });
568
+ }
569
+ function workerProcess(event) {
570
+ var data = event.data;
571
+ self.ready.then(function(instance2) {
572
+ if (!data.id) {
573
+ return self.close();
574
+ }
575
+ try {
576
+ var target = new Uint8Array(data.count * data.size);
577
+ decode(instance2, instance2.exports[data.mode], target, data.count, data.size, data.source, instance2.exports[data.filter]);
578
+ self.postMessage({ id: data.id, count: data.count, action: "resolve", value: target }, [target.buffer]);
579
+ } catch (error) {
580
+ self.postMessage({ id: data.id, count: data.count, action: "reject", value: error });
581
+ }
582
+ });
583
+ }
584
+ return {
585
+ ready,
586
+ supported: true,
587
+ useWorkers: function(count) {
588
+ initWorkers(count);
589
+ },
590
+ decodeVertexBuffer: function(target, count, size, source, filter) {
591
+ decode(instance, instance.exports.meshopt_decodeVertexBuffer, target, count, size, source, instance.exports[filters[filter]]);
592
+ },
593
+ decodeIndexBuffer: function(target, count, size, source) {
594
+ decode(instance, instance.exports.meshopt_decodeIndexBuffer, target, count, size, source);
595
+ },
596
+ decodeIndexSequence: function(target, count, size, source) {
597
+ decode(instance, instance.exports.meshopt_decodeIndexSequence, target, count, size, source);
598
+ },
599
+ decodeGltfBuffer: function(target, count, size, source, mode, filter) {
600
+ decode(instance, instance.exports[decoders[mode]], target, count, size, source, instance.exports[filters[filter]]);
601
+ },
602
+ decodeGltfBufferAsync: function(count, size, source, mode, filter) {
603
+ if (workers.length > 0) {
604
+ return decodeWorker(count, size, source, decoders[mode], filters[filter]);
605
+ }
606
+ return ready.then(function() {
607
+ var target = new Uint8Array(count * size);
608
+ decode(instance, instance.exports[decoders[mode]], target, count, size, source, instance.exports[filters[filter]]);
609
+ return target;
610
+ });
611
+ }
612
+ };
613
+ })();
614
+
615
+ // packages/engine/node_modules/meshoptimizer/meshopt_simplifier.js
616
+ var MeshoptSimplifier = (function() {
617
+ var wasm = "b9H79Tebbbe:6eO9Geueu9Geub9Gbb9Gsuuuuuuuuuuuu99uueu9Gvuuuuub9Gruuuuuuub9Gouuuuuue999Gvuuuuueu9Gzuuuuuuuuuuu99uuuub9Gquuuuuuu99uueu9GPuuuuuuuuuuu99uueu9Gquuuuuuuu99ueu9Gruuuuuu99eu9Gwuuuuuu99ueu9Giuuue999Gluuuueu9Gluuuub9GiuuueuiLQdilvorlwDiqkxmPszbHHbelve9Weiiviebeoweuecj:Gdkr:Bdxo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bbz9TW79O9V9Wt9F79P9T9W29P9M95bw8E9TW79O9V9Wt9F79P9T9W29P9M959x9Pt9OcttV9P9I91tW7bD8A9TW79O9V9Wt9F79P9T9W29P9M959x9Pt9O9v9W9K9HtWbqQ9TW79O9V9Wt9F79P9T9W29P9M959t29V9W9W95bkX9TW79O9V9Wt9F79P9T9W29P9M959qV919UWbxQ9TW79O9V9Wt9F79P9T9W29P9M959q9V9P9Ut7bmX9TW79O9V9Wt9F79P9T9W29P9M959t9J9H2WbPa9TW79O9V9Wt9F9V9Wt9P9T9P96W9wWVtW94SWt9J9O9sW9T9H9Wbs59TW79O9V9Wt9F9NW9UWV9HtW9q9V79Pt9P9V9U9sW9T9H9Wbzl79IV9RbHDwebcekdCXq;y;WeQdbk;r:herYue99iuY99Xue9:D998Jjjjjbcj;sb9Rgs8Kjjjjbcbhzasc:Cefcbc;Kbz:tjjjb8AdnabaeSmbabaeadcdtzMjjjb8AkdnamcdGTmbalcrfci4cbyd1:H:cjbHjjjjbbhHasc:Cefasyd;8egecdtfaHBdbasaecefBd;8ecbhlcbhednadTmbabheadhOinaHaeydbci4fcb86bbaeclfheaOcufgOmbkcbhlabheadhOinaHaeydbgAci4fgCaCRbbgCceaAcrGgAtV86bbaCcu7aA4ceGalfhlaeclfheaOcufgOmbkcualcdtalcFFFFi0Ehekaecbyd1:H:cjbHjjjjbbhzasc:Cefasyd;8egecdtfazBdbasaecefBd;8ealcd4alfhOcehHinaHgecethHaeaO6mbkcbhXcuaecdtgOaecFFFFi0Ecbyd1:H:cjbHjjjjbbhHasc:Cefasyd;8egAcdtfaHBdbasaAcefBd;8eaHcFeaOz:tjjjbhQdnadTmbaecufhLcbhKindndnaQabaKcdtfgYydbgAc:v;t;h;Ev2aLGgOcdtfgCydbgHcuSmbceheinazaHcdtfydbaASmdaOaefhHaecefheaQaHaLGgOcdtfgCydbgHcu9hmbkkazaXcdtfaABdbaCaXBdbaXhHaXcefhXkaYaHBdbaKcefgKad9hmbkkaQcbyd:m:H:cjbH:bjjjbbasasyd;8ecufBd;8ekcbh8AcualcefgecdtaecFFFFi0Ecbyd1:H:cjbHjjjjbbhLasc:Cefasyd;8egecdtfaLBdbasaLBdNeasaecefBd;8ecuadcitadcFFFFe0Ecbyd1:H:cjbHjjjjbbhEasc:Cefasyd;8egecdtfaEBdbasaEBd:yeasaecefBd;8eascNefabadalcbz:cjjjbcualcdtgealcFFFFi0Eg3cbyd1:H:cjbHjjjjbbhOasc:Cefasyd;8egHcdtfaOBdbasaHcefBd;8ea3cbyd1:H:cjbHjjjjbbhQasc:Cefasyd;8egHcdtfaQBdbasaHcefBd;8eaOaQaialavazasc:Cefz:djjjbalcbyd1:H:cjbHjjjjbbhYasc:Cefasyd;8egHcdtfaYBdbasaHcefBd;8ea3cbyd1:H:cjbHjjjjbbhHasc:Cefasyd;8egAcdtfaHBdbasaAcefBd;8ea3cbyd1:H:cjbHjjjjbbhAasc:Cefasyd;8egCcdtfaABdbasaCcefBd;8eaHcFeaez:tjjjbh5aAcFeaez:tjjjbh8EdnalTmbindnaLa8AgAcefg8AcdtfydbgCaLaAcdtgefydbgHSmbaCaH9Rh8FaEaHcitfhaa8Eaefhha5aefhKcbhCindndnaaaCcitfydbgXaA9hmbaKaABdbahaABdbxekdnaLaXcdtggfgeclfydbgHaeydbgeSmbaHae9RhHaEaecitfheinaeydbaASmdaecwfheaHcufgHmbkka8EagfgeaAaXaeydbcuSEBdbaKaXaAaKydbcuSEBdbkaCcefgCa8F9hmbkka8Aal9hmbkaOhHaQhAa5hXa8EhCcbheindndnaeaHydbgK9hmbdnaeaAydbgK9hmbaXydbhKdnaCydbg8Fcu9hmbaKcu9hmbaYaefcb86bbxikdna8FcuSmbaKcuSmbaea8FSmbaOa8FcdtfydbaOaKcdtfydb9hmbaYaefcd86bbxikaYaefhadnaea8FSmbaeaKSmbaace86bbxikaacl86bbxdkdnaeaQaKcdtg8Ffydb9hmbdnaCydbgacuSmbaeaaSmbaXydbggcuSmbaeagSmba8Ea8FfydbghcuSmbahaKSmba5a8Ffydbg8FcuSmba8FaKSmbdnaOaacdtfydbgKaOa8Fcdtfydb9hmbaKaOagcdtfydbg8FSmba8FaOahcdtfydb9hmbaYaefcd86bbxlkaYaefcl86bbxikaYaefcl86bbxdkaYaefcl86bbxekaYaefaYaKfRbb86bbkaHclfhHaAclfhAaXclfhXaCclfhCalaecefge9hmbkdnamcaGTmbcbh8JindndnaYa8Jfg8KRbbg8Lc9:fPibebekdndndnaOa8Jcdtfydbgea8J9hmbdnaqmbcbh8FxdkdnazTmbcbh8Fa8JheinaqazaecdtgefydbfRbbce4a8FVceGh8FaQaefydbgea8J9hmbxikkcbh8Fa8JheinaqaefRbbce4a8FVceGh8FaQaecdtfydbgea8J9hmbxdkkaYaefRbbhexeka8JheindnaLaecdtg8AfgeclfydbgHaeydbgeSmbaHae9RhgaEaecitfhhaOa8AfhacbhKinahaKcitfydbgXhednindnaLaecdtgCfgeclfydbgHaeydbgeSmbaHae9RhHaEaecitfheaaydbhAdninaOaeydbcdtfydbaASmeaecwfheaHcufgHTmdxbkkcbhexdkaQaCfydbgeaX9hmbkceheka8FaeVh8FaKcefgKag9hmbkkaQa8Afydbgea8J9hmbka8Lcia8FceGEheka8Kae86bbka8Jcefg8Jal9hmbkkdnaqTmbdndnazTmbazheaOhHalhAindnaqaeydbfRbbceGTmbaYaHydbfcl86bbkaeclfheaHclfhHaAcufgAmbxdkkaqheaOhHalhAindnaeRbbceGTmbaYaHydbfcl86bbkaecefheaHclfhHaAcufgAmbkkaOhealhAaYhHindnaYaeydbfRbbcl9hmbaHcl86bbkaeclfheaHcefhHaAcufgAmbkkamceGTmbaYhealhHindnaeRbbce9hmbaecl86bbkaecefheaHcufgHmbkkcbh8Mcualcx2alc;v:Q;v:Qe0Ecbyd1:H:cjbHjjjjbbh8Nasc:Cefasyd;8egecdtfa8NBdbasaecefBd;8eascbBd:qeas9cb83i1ea8Naialavazasc1efz:ejjjbhydndnaDmbcbh8PcbhCxekcbhCawhecbhHindnaeIdbJbbbb9ETmbasaCcdtfaHBdbaCcefhCkaeclfheaDaHcefgH9hmbkcuaCal2gecdtaecFFFFi0Ecbyd1:H:cjbHjjjjbbh8Pasc:Cefasyd;8egecdtfa8PBdbasaecefBd;8ealTmbdnaCmbcbhCxekarcd4hgdnazTmbaCcdthhcbh8Fa8Phainaoaza8Fcdtfydbag2cdtfhKasheaahHaChAinaHaKaeydbcdtgXfIdbawaXfIdbNUdbaeclfheaHclfhHaAcufgAmbkaaahfhaa8Fcefg8Fal9hmbxdkkaCcdthhcbh8Fa8Phainaoa8Fag2cdtfhKasheaahHaChAinaHaKaeydbcdtgXfIdbawaXfIdbNUdbaeclfheaHclfhHaAcufgAmbkaaahfhaa8Fcefg8Fal9hmbkkcualc8S2gHalc;D;O;f8U0EgXcbyd1:H:cjbHjjjjbbheasc:Cefasyd;8egAcdtfaeBdbasaAcefBd;8eaecbaHz:tjjjbhIcbh8RcbhgdnaCTmbcbh8MaXcbyd1:H:cjbHjjjjbbhgasc:Cefasyd;8egecdtfagBdbasaecefBd;8eagcbaHz:tjjjb8AcuaCal2gecltgHaecFFFFb0Ecbyd1:H:cjbHjjjjbbh8Rasc:Cefasyd;8egecdtfa8RBdbasaecefBd;8ea8RcbaHz:tjjjb8AamcjjjjdGTmbcualcltgealcFFFFb0Ecbyd1:H:cjbHjjjjbbh8Masc:Cefasyd;8egHcdtfa8MBdbasaHcefBd;8ea8Mcbaez:tjjjb8AkdnadTmbcbhKabhHina8NaHclfydbg8Fcx2fgeIdba8NaHydbgacx2fgAIdbg8S:tgRa8NaHcwfydbghcx2fgXIdlaAIdlg8U:tg8VNaeIdla8U:tg8WaXIdba8S:tg8XN:tg8Ya8YNa8WaXIdwaAIdwg8Z:tg80NaeIdwa8Z:tg8Wa8VN:tg81a81Na8Wa8XNaRa80N:tg80a80NMMg8V:rhBa8Yh8Xa80h8Wa81hRdna8VJbbbb9EgATmba8YaB:vh8Xa80aB:vh8Wa81aB:vhRkaIaOaacdtfydbgXc8S2fgeaRaB:rg8VaRNNg83aeIdbMUdbaea8Wa8Va8WNgUNg85aeIdlMUdlaea8Xa8Va8XNg86Ng87aeIdwMUdwaeaRaUNgUaeIdxMUdxaea86aRNg88aeIdzMUdzaea8Wa86Ng89aeIdCMUdCaeaRa8Va8Xa8ZNaRa8SNa8Ua8WNMM:mg8:Ng86NgRaeIdKMUdKaea8Wa86Ng8WaeId3MUd3aea8Xa86Ng8XaeIdaMUdaaea86a8:Ng86aeId8KMUd8Kaea8VaeIdyMUdyaIaOa8Fcdtfydbg8Fc8S2fgea83aeIdbMUdbaea85aeIdlMUdlaea87aeIdwMUdwaeaUaeIdxMUdxaea88aeIdzMUdzaea89aeIdCMUdCaeaRaeIdKMUdKaea8WaeId3MUd3aea8XaeIdaMUdaaea86aeId8KMUd8Kaea8VaeIdyMUdyaIaOahcdtfydbgac8S2fgea83aeIdbMUdbaea85aeIdlMUdlaea87aeIdwMUdwaeaUaeIdxMUdxaea88aeIdzMUdzaea89aeIdCMUdCaeaRaeIdKMUdKaea8WaeId3MUd3aea8XaeIdaMUdaaea86aeId8KMUd8Kaea8VaeIdyMUdydna8MTmbdnaATmba8YaB:vh8Ya80aB:vh80a81aB:vh81ka8MaXcltfgeaBJbbbZNgRa80Ng8VaeIdlMUdlaeaRa8YNg8WaeIdwMUdwaeaRa81Ng8XaeIdbMUdbaeaRa8S:ma81Na8Ua80N:ta8Za8YN:tNgRaeIdxMUdxa8Ma8Fcltfgea8VaeIdlMUdlaea8WaeIdwMUdwaea8XaeIdbMUdbaeaRaeIdxMUdxa8Maacltfgea8VaeIdlMUdlaea8WaeIdwMUdwaea8XaeIdbMUdbaeaRaeIdxMUdxkaHcxfhHaKcifgKad6mbkkdnalTmbJq;x8J88J;n;m;m89J:v:;;w8ZamczGEamc;abGEh80cbhHaOhXazhKaIhea8NhAindnaHaXydb9hmbaHh8FdnazTmbaKydbh8Fka80hRdnaqTmbJbbjZa80aqa8FfRbbclGEhRkaecxfg8Fa8FIdbJbbbbMUdbaeczfg8Fa8FIdbJbbbbMUdbaecCfg8Fa8FIdbJbbbbMUdbaeaRaecyfg8FIdbg8YNgRaeIdbMUdbaeclfgaaRaaIdbMUdbaecwfgaaRaaIdbMUdbaecKfgaaaIdbaAIdbg8WaRN:tUdbaAcwfIdbh8Vaec3fgaaaIdbaRaAclfIdbg8XN:tUdbaecafgaaaIdbaRa8VN:tUdbaec8KfgaIdbh81a8Fa8YaRMUdbaaa81aRa8Va8VNa8Wa8WNa8Xa8XNMMNMUdbkaXclfhXaKclfhKaec8SfheaAcxfhAalaHcefgH9hmbkkdnadTmbcbh8Aabhainaba8Acdtfh8FcbhHinaYa8FaHc:G:G:cjbfydbcdtfydbgAfRbbhedndnaYaaaHfydbgXfRbbgKc99fcFeGcpe0mbaec99fcFeGc;:e6mekdnaKcufcFeGce0mba5aXcdtfydbaA9hmekdnaecufcFeGce0mba8EaAcdtfydbaX9hmekJbbacJbbacJbbbZaecFeGceSEaKcFeGceSEhUdna8Na8FaHc:K:G:cjbfydbcdtfydbcx2fgeIdwa8NaXcx2fgKIdwg86:tg8Sa8NaAcx2fghIdwa86:tg8Xa8XNahIdbaKIdbg8U:tg80a80NahIdlaKIdlg8Z:tg8Va8VNMMg81Na8Xa8Sa8XNaeIdba8U:tg83a80Na8VaeIdla8Z:tg85NMMg8WN:tg8Ya8YNa83a81Na80a8WN:tgRaRNa85a81Na8Va8WN:tg8Wa8WNMMgBJbbbb9ETmba8YaB:rgB:vh8Ya8WaB:vh8WaRaB:vhRkaUa81:rNgBa8Ya86NaRa8UNa8Za8WNMM:mg81Ng87a81Nh88a80a85Na8Va83N:tg81a81Na8Va8SNa8Xa85N:tg8Va8VNa8Xa83Na80a8SN:tg8Xa8XNMMg83:rh80a8Ya87Nh85a8Wa87Nh89aRa87Nh87a8WaBa8YNg8SNh8:a8SaRNhZaRaBa8WNgnNhca8Ya8SNh8Ya8WanNh8WaRaBaRNNh8Sdna83Jbbbb9ETmba81a80:vh81a8Xa80:vh8Xa8Va80:vh8VkaIaOaXcdtfydbc8S2fgeaeIdba8Sa8VaUa80:rNgRa8VNNMg80MUdbaea8Wa8XaRa8XNg8SNMg83aeIdlMUdlaea8Ya81aRa81Ng8WNMg8YaeIdwMUdwaeaca8Va8SNMg8SaeIdxMUdxaeaZa8Wa8VNMgUaeIdzMUdzaea8:a8Xa8WNMg8WaeIdCMUdCaea87a8VaRa81a86Na8Va8UNa8Za8XNMMg86:mNgRNMg8VaeIdKMUdKaea89a8XaRNMg8XaeId3MUd3aea85a81aRNMg81aeIdaMUdaaea88a86aRN:tgRaeId8KMUd8KaeaBaeIdyMUdyaIaOaAcdtfydbc8S2fgea80aeIdbMUdbaea83aeIdlMUdlaea8YaeIdwMUdwaea8SaeIdxMUdxaeaUaeIdzMUdzaea8WaeIdCMUdCaea8VaeIdKMUdKaea8XaeId3MUd3aea81aeIdaMUdaaeaRaeId8KMUd8KaeaBaeIdyMUdykaHclfgHcx9hmbkaacxfhaa8Acifg8Aad6mbkaCTmbcbhainJbbbbh80a8Nabaacdtfgeclfydbg8Fcx2fgHIdwa8Naeydbghcx2fgAIdwg8Z:tg8Va8VNaHIdbaAIdbg83:tg8Wa8WNaHIdlaAIdlg85:tg8Xa8XNMMg8Sa8Naecwfydbg8Acx2fgeIdwa8Z:tg8YNa8Va8YNa8WaeIdba83:tg81Na8XaeIdla85:tgBNMMgRa8VN:tJbbbbJbbjZa8Sa8Ya8YNa81a81NaBaBNMMg8UNaRaRN:tg86:va86Jbbbb9BEg86Nh88a8Ua8VNaRa8YN:ta86Nh89a8SaBNaRa8XN:ta86Nh8:a8Ua8XNaRaBN:ta86NhZa8Sa81NaRa8WN:ta86Nhna8Ua8WNaRa81N:ta86Nhca8WaBNa8Xa81N:tgRaRNa8Xa8YNa8VaBN:tgRaRNa8Va81Na8Wa8YN:tgRaRNMM:rJbbbZNhRa8PahaC2g8JcdtfhHa8Pa8AaC2gDcdtfhAa8Pa8FaC2g8KcdtfhXa8Z:mh9ca85:mhJa83:mh9eascjdfheaChKJbbbbhBJbbbbh86Jbbbbh8SJbbbbh8UJbbbbh8ZJbbbbh83Jbbbbh85Jbbbbh87JbbbbhUinaecwfaRa89aXIdbaHIdbg8Y:tg8XNa88aAIdba8Y:tg81NMg8VNUdbaeclfaRaZa8XNa8:a81NMg8WNUdbaeaRaca8XNana81NMg8XNUdbaecxfaRa9ca8VNaJa8WNa8Ya9ea8XNMMMg8YNUdbaRa8Va8WNNa8ZMh8ZaRa8Va8XNNa8UMh8UaRa8Wa8XNNa8SMh8SaRa8Ya8YNNaUMhUaRa8Va8YNNa87Mh87aRa8Wa8YNNa85Mh85aRa8Xa8YNNa83Mh83aRa8Va8VNNa86Mh86aRa8Wa8WNNaBMhBaRa8Xa8XNNa80Mh80aHclfhHaXclfhXaAclfhAaeczfheaKcufgKmbkagahc8S2fgea80aeIdbMUdbaeaBaeIdlMUdlaea86aeIdwMUdwaea8SaeIdxMUdxaea8UaeIdzMUdzaea8ZaeIdCMUdCaea83aeIdKMUdKaea85aeId3MUd3aea87aeIdaMUdaaeaUaeId8KMUd8KaeaRaeIdyMUdyaga8Fc8S2fgea80aeIdbMUdbaeaBaeIdlMUdlaea86aeIdwMUdwaea8SaeIdxMUdxaea8UaeIdzMUdzaea8ZaeIdCMUdCaea83aeIdKMUdKaea85aeId3MUd3aea87aeIdaMUdaaeaUaeId8KMUd8KaeaRaeIdyMUdyaga8Ac8S2fgea80aeIdbMUdbaeaBaeIdlMUdlaea86aeIdwMUdwaea8SaeIdxMUdxaea8UaeIdzMUdzaea8ZaeIdCMUdCaea83aeIdKMUdKaea85aeId3MUd3aea87aeIdaMUdaaeaUaeId8KMUd8KaeaRaeIdyMUdya8Ra8Jcltfh8FcbhHaChXina8FaHfgeascjdfaHfgAIdbaeIdbMUdbaeclfgKaAclfIdbaKIdbMUdbaecwfgKaAcwfIdbaKIdbMUdbaecxfgeaAcxfIdbaeIdbMUdbaHczfhHaXcufgXmbka8Ra8Kcltfh8FcbhHaChXina8FaHfgeascjdfaHfgAIdbaeIdbMUdbaeclfgKaAclfIdbaKIdbMUdbaecwfgKaAcwfIdbaKIdbMUdbaecxfgeaAcxfIdbaeIdbMUdbaHczfhHaXcufgXmbka8RaDcltfh8FcbhHaChXina8FaHfgeascjdfaHfgAIdbaeIdbMUdbaeclfgKaAclfIdbaKIdbMUdbaecwfgKaAcwfIdbaKIdbMUdbaecxfgeaAcxfIdbaeIdbMUdbaHczfhHaXcufgXmbkaacifgaad6mbkkcbhAdndnamcwGgTmbJbbbbh8ScbhScbh9hcbh9ixekcbhSa3cbyd1:H:cjbHjjjjbbh9iasc:Cefasyd;8egecdtfa9iBdbasaecefBd;8ecua9ialabadaOz:fjjjbgXcltaXcjjjjiGEcbyd1:H:cjbHjjjjbbh9hasc:Cefasyd;8egecdtfa9hBdbasaecefBd;8ea9haXa9ia8Nalz:gjjjbJFFuuh8SaXTmba9hheaXhHinaeIdbgRa8Sa8SaR9EEh8SaeclfheaHcufgHmbkaXhSkdnalTmbaLclfheaLydbhXaYhHalhKcbhAincbaeydbg8FaX9RaHRbbcpeGEaAfhAaHcefhHaeclfhea8FhXaKcufgKmbkaAce4hAkcuadaA9Rcifg6cx2a6c;v:Q;v:Qe0Ecbyd1:H:cjbHjjjjbbh9kasc:Cefasyd;8egecdtfa9kBdbasaecefBd;8ecua6cdta6cFFFFi0Ecbyd1:H:cjbHjjjjbbh0asc:Cefasyd;8egecdtfa0BdbasaecefBd;8ea3cbyd1:H:cjbHjjjjbbh9masc:Cefasyd;8egecdtfa9mBdbasaecefBd;8ealcbyd1:H:cjbHjjjjbbh9nasc:Cefasyd;8egecdtfa9nBdbasaecefBd;8eaxaxNayJbbjZamclGEgZaZN:vh87JbbbbhUdnadak9nmbdna6ci6mbaCclth9oa9kcwfh9pJbbbbh85JbbbbhUinascNefabadalaOz:cjjjbabh8Acbh9qcbh9rinaba9rcdtfhDcbheindnaOa8AaefydbgAcdtghfydbgXaOaDaec:W:G:cjbfydbcdtfydbgHcdtg8JfydbgKSmbaYaHfRbbgacv2aYaAfRbbg8FfRb;a:G:cjbg8La8Fcv2aafg8KRb;a:G:cjbg3VcFeGTmbdnaKaX9nmba8KRb;G:G:cjbcFeGmekdna8FcufcFeGce0mbaaTmba5ahfydbaH9hmekdna8FTmbaacufcFeGce0mba8Ea8JfydbaA9hmeka9ka9qcx2fgXaHaAa3cFeGgKEBdlaXaAaHaKEBdbaXaKa8LGcb9hBdwa9qcefh9qkaeclfgecx9hmbkdna9rcifg9rad9pmba8Acxfh8Aa9qcifa69nmekka9qTmdcbh8KinaIaOa9ka8Kcx2fghydbgKcdtgXfydbg8Ac8S2fgeIdwa8Nahydlg8Fcx2fgHIdwg8WNaeIdzaHIdbg8XNaeIdaMgRaRMMa8WNaeIdlaHIdlg8YNaeIdCa8WNaeId3MgRaRMMa8YNaeIdba8XNaeIdxa8YNaeIdKMgRaRMMa8XNaeId8KMMM:lhRJbbbbJbbjZaeIdyg8V:va8VJbbbb9BEh8VdndnahydwgDmbJFFuuh86xekJbbbbJbbjZaIaOa8Fcdtfydbc8S2fgeIdyg81:va81Jbbbb9BEaeIdwa8NaKcx2fgHIdwg81NaeIdzaHIdbg80NaeIdaMgBaBMMa81NaeIdlaHIdlgBNaeIdCa81NaeId3Mg81a81MMaBNaeIdba80NaeIdxaBNaeIdKMg81a81MMa80NaeId8KMMM:lNh86ka8VaRNhBdnaCTmbagaKc8S2fgAIdwa8WNaAIdza8XNaAIdaMgRaRMMa8WNaAIdla8YNaAIdCa8WNaAId3MgRaRMMa8YNaAIdba8XNaAIdxa8YNaAIdKMgRaRMMa8XNaAId8KMMMhRa8Pa8FaC2gacdtfhHa8RaKaC2g8JcltfheaAIdyh81aChAinaHIdbg8Va8Va81NaecxfIdba8WaecwfIdbNa8XaeIdbNa8YaeclfIdbNMMMg8Va8VM:tNaRMhRaHclfhHaeczfheaAcufgAmbkdndnaDmbJbbbbh8Vxekaga8Fc8S2fgAIdwa8NaKcx2fgeIdwg8XNaAIdzaeIdbg8YNaAIdaMg8Va8VMMa8XNaAIdlaeIdlg81NaAIdCa8XNaAId3Mg8Va8VMMa81NaAIdba8YNaAIdxa81NaAIdKMg8Va8VMMa8YNaAId8KMMMh8Va8Pa8JcdtfhHa8RaacltfheaAIdyh80aChAinaHIdbg8Wa8Wa80NaecxfIdba8XaecwfIdbNa8YaeIdbNa81aeclfIdbNMMMg8Wa8WM:tNa8VMh8VaHclfhHaeczfheaAcufgAmbka8V:lh8VkaBaR:lMhBa86a8VMh86dndndnaYaKfRbbc9:fPddbekaQaXfydbgXaKSmbaOa8Fcdtfydbh8Jindndna5aXcdtgafydbgecuSmbaOaecdtfydba8JSmekdna8EaafydbgecuSmbaOaecdtfydba8JSmeka8FhekagaXc8S2fgAIdwa8Naecx2fgHIdwg8WNaAIdzaHIdbg8XNaAIdaMgRaRMMa8WNaAIdlaHIdlg8YNaAIdCa8WNaAId3MgRaRMMa8YNaAIdba8XNaAIdxa8YNaAIdKMgRaRMMa8XNaAId8KMMMhRa8PaeaC2cdtfhHa8RaXaC2cltfheaAIdyh81aChAinaHIdbg8Va8Va81NaecxfIdba8WaecwfIdbNa8XaeIdbNa8YaeclfIdbNMMMg8Va8VM:tNaRMhRaHclfhHaeczfheaAcufgAmbkaBaR:lMhBaQaafydbgXaK9hmbkkaYa8FfRbbci9hmeaDTmeaQa8FcdtfydbgXa8FSmeindndna5aXcdtgafydbgecuSmbaOaecdtfydba8ASmekdna8EaafydbgecuSmbaOaecdtfydba8ASmekaKhekagaXc8S2fgAIdwa8Naecx2fgHIdwg8WNaAIdzaHIdbg8XNaAIdaMgRaRMMa8WNaAIdlaHIdlg8YNaAIdCa8WNaAId3MgRaRMMa8YNaAIdba8XNaAIdxa8YNaAIdKMgRaRMMa8XNaAId8KMMMhRa8PaeaC2cdtfhHa8RaXaC2cltfheaAIdyh81aChAinaHIdbg8Va8Va81NaecxfIdba8WaecwfIdbNa8XaeIdbNa8YaeclfIdbNMMMg8Va8VM:tNaRMhRaHclfhHaeczfheaAcufgAmbka86aR:lMh86aQaafydbgXa8F9hmbxdkkdna8Ea5a5aXfydba8FSEaQaXfydbgacdtfydbgXcu9hmbaQa8FcdtfydbhXkagaac8S2fgAIdwa8NaXcx2fgeIdwg8WNaAIdzaeIdbg8XNaAIdaMgRaRMMa8WNaAIdlaeIdlg8YNaAIdCa8WNaAId3MgRaRMMa8YNaAIdba8XNaAIdxa8YNaAIdKMgRaRMMa8XNaAId8KMMMhRa8PaXaC2g8AcdtfhHa8RaaaC2g8JcltfheaAIdyh81aChAinaHIdbg8Va8Va81NaecxfIdba8WaecwfIdbNa8XaeIdbNa8YaeclfIdbNMMMg8Va8VM:tNaRMhRaHclfhHaeczfheaAcufgAmbkdndnaDmbJbbbbh8VxekagaXc8S2fgAIdwa8Naacx2fgeIdwg8XNaAIdzaeIdbg8YNaAIdaMg8Va8VMMa8XNaAIdlaeIdlg81NaAIdCa8XNaAId3Mg8Va8VMMa81NaAIdba8YNaAIdxa81NaAIdKMg8Va8VMMa8YNaAId8KMMMh8Va8Pa8JcdtfhHa8Ra8AcltfheaAIdyh80aChAinaHIdbg8Wa8Wa80NaecxfIdba8XaecwfIdbNa8YaeIdbNa81aeclfIdbNMMMg8Wa8WM:tNa8VMh8VaHclfhHaeczfheaAcufgAmbka8V:lh8VkaBaR:lMhBa86a8VMh86kaha86aBa86aB9DgeEUdwahaKa8FaeaDcb9hGgeEBdlaha8FaKaeEBdba8Kcefg8Ka9q9hmbkascjdfcbcj;qbz:tjjjb8Aa9phea9qhHinascjdfaeydbcA4cF8FGgAcFAaAcFA6EcdtfgAaAydbcefBdbaecxfheaHcufgHmbkcbhecbhHinascjdfaefgAydbhXaAaHBdbaXaHfhHaeclfgecj;qb9hmbkcbhea9phHinascjdfaHydbcA4cF8FGgAcFAaAcFA6EcdtfgAaAydbgAcefBdba0aAcdtfaeBdbaHcxfhHa9qaecefge9hmbkadak9RgAci9Uh9sdnalTmbcbhea9mhHinaHaeBdbaHclfhHalaecefge9hmbkkcbh9ta9ncbalz:tjjjbh3aAcO9Uh9ua9sce4h9rcbh8Lcbh8Kdnina9ka0a8Kcdtfydbcx2fg8JIdwgRa879Emea8La9s9pmeJFFuuh8Vdna9ra9q9pmba9ka0a9rcdtfydbcx2fIdwJbb;aZNh8VkdnaRa8V9ETmbaRaU9ETmba8La9u0mdkdna3aOa8JydlgDcdtg9vfg8AydbgAfg9wRbba3aOa8Jydbghcdtg9xfydbgefg9yRbbVmbaYahfRbbh9zdndnaLaecdtfgHclfydbgXaHydbgHSmbaXaH9RhXa8NaAcx2fh8Fa8Naecx2fhaaEaHcitfheindna9maeydbcdtfydbgHaASmba9maeclfydbcdtfydbgKaASmbaHaKSmba8NaKcx2fgKIdba8NaHcx2fgHIdbg8W:tgRaaIdlaHIdlg8X:tg80NaKIdla8X:tg8VaaIdba8W:tgBN:tg8YaRa8FIdla8X:tg86Na8Va8FIdba8W:tg8UN:tg8XNa8VaaIdwaHIdwg81:tg8ZNaKIdwa81:tg8Wa80N:tg80a8Va8FIdwa81:tg83Na8Wa86N:tg8VNa8WaBNaRa8ZN:tg81a8Wa8UNaRa83N:tgRNMMa8Ya8YNa80a80Na81a81NMMa8Xa8XNa8Va8VNaRaRNMMN:rJbbj8:N9FmikaecwfheaXcufgXmbkkdndndndna9zc9:fPdebdkahheina8AydbhAdndna5aecdtgHfydbgecuSmbaOaecdtfydbaASmekdna8EaHfydbgecuSmbaOaecdtfydbaASmekaDheka9maHfaeBdbaQaHfydbgeah9hmbxikkdna8Ea5a5a9xfydbaDSEaQa9xfydbghcdtfydbgecu9hmbaQa9vfydbheka9ma9xfaDBdbaehDka9mahcdtfaDBdbka9yce86bba9wce86bba8JIdwgRaUaUaR9DEhUa9tcefh9tcecda9zceSEa8Lfh8Lxeka9rcefh9rka8Kcefg8Ka9q9hmbkka9tTmddnalTmbcbh8Fcbhhindna9mahcdtgefydbgAahSmbaOaAcdtfydbh8AdnahaOaefydb9hg8JmbaIa8Ac8S2fgeaIahc8S2fgHIdbaeIdbMUdbaeaHIdlaeIdlMUdlaeaHIdwaeIdwMUdwaeaHIdxaeIdxMUdxaeaHIdzaeIdzMUdzaeaHIdCaeIdCMUdCaeaHIdKaeIdKMUdKaeaHId3aeId3MUd3aeaHIdaaeIdaMUdaaeaHId8KaeId8KMUd8KaeaHIdyaeIdyMUdya8MTmba8Ma8Acltfgea8MahcltfgHIdbaeIdbMUdbaeaHIdlaeIdlMUdlaeaHIdwaeIdwMUdwaeaHIdxaeIdxMUdxkaCTmbagaAc8S2fgeagahc8S2gDfgHIdbaeIdbMUdbaeaHIdlaeIdlMUdlaeaHIdwaeIdwMUdwaeaHIdxaeIdxMUdxaeaHIdzaeIdzMUdzaeaHIdCaeIdCMUdCaeaHIdKaeIdKMUdKaeaHId3aeId3MUd3aeaHIdaaeIdaMUdaaeaHId8KaeId8KMUd8KaeaHIdyaeIdyMUdya9oaA2haa8RhHaChXinaHaafgeaHa8FfgAIdbaeIdbMUdbaeclfgKaAclfIdbaKIdbMUdbaecwfgKaAcwfIdbaKIdbMUdbaecxfgeaAcxfIdbaeIdbMUdbaHczfhHaXcufgXmbka8JmbJbbbbJbbjZaIaDfgeIdygR:vaRJbbbb9BEaeIdwa8Na8Acx2fgHIdwgRNaeIdzaHIdbg8VNaeIdaMg8Wa8WMMaRNaeIdlaHIdlg8WNaeIdCaRNaeId3MgRaRMMa8WNaeIdba8VNaeIdxa8WNaeIdKMgRaRMMa8VNaeId8KMMM:lNgRa85a85aR9DEh85ka8Fa9ofh8Fahcefghal9hmbkcbhHa5heindnaeydbgAcuSmbdnaHa9maAcdtgXfydbgA9hmbcuhAa5aXfydbgXcuSmba9maXcdtfydbhAkaeaABdbkaeclfhealaHcefgH9hmbkcbhHa8EheindnaeydbgAcuSmbdnaHa9maAcdtgXfydbgA9hmbcuhAa8EaXfydbgXcuSmba9maXcdtfydbhAkaeaABdbkaeclfhealaHcefgH9hmbkka85aUaCEh85cbhHabhecbhAindnaOa9maeydbcdtfydbg8FcdtfydbgXaOa9maeclfydbcdtfydbgacdtfydbgKSmbaXaOa9maecwfydbcdtfydbg8AcdtfydbghSmbaKahSmbabaHcdtfgXa8FBdbaXcwfa8ABdbaXclfaaBdbaHcifhHkaecxfheaAcifgAad6mbkdndnaTmbaHhdxekdnaHak0mbaHhdxekdna8Sa859FmbaHhdxekJFFuuh8ScbhdabhecbhAindna9ha9iaeydbgXcdtfydbcdtfIdbgRa859ETmbaeclf8Pdbh9AabadcdtfgKaXBdbaKclfa9A83dbaRa8Sa8SaR9EEh8SadcifhdkaecxfheaAcifgAaH6mbkkadak0mbxdkkascNefabadalaOz:cjjjbkdndnadak0mbadhaxekdnaTmbadhaxekdna8Sa879FmbadhaxekcehKina8SJbb;aZNgRa87aRa879DEh8WJbbbbhRdnaSTmba9hheaShHinaeIdbg8VaRa8Va8W9FEaRa8VaR9EEhRaeclfheaHcufgHmbkkJFFuuh8ScbhaabhecbhHindna9ha9iaeydbgAcdtfydbcdtfIdbg8Va8W9ETmbaeclf8Pdbh9AabaacdtfgXaABdbaXclfa9A83dba8Va8Sa8Sa8V9EEh8SaacifhakaecxfheaHcifgHad6mbkdnaKaaad9hVceGmbadhaxdkaRaUaUaR9DEhUaaak9nmecbhKaahda8Sa879FmbkkdnamcjjjjdGTmba9ncbalz:tjjjbh8AdnaaTmbabheaahHina8AaeydbgAfce86bba8AaOaAcdtfydbfce86bbaeclfheaHcufgHmbkkascNefabaaalaOz:cjjjbdndnalTmbcbhXindna8AaXfRbbTmbdnaYaXfRbbgecl0mbceaetcQGmekdnaOaXcdtg8FfydbgeaXSmba8NaXcx2fgHa8Naecx2fgeydwBdwaHae8Pdb83dbxekaIaXc8S2fgKIdygcacJL:3;rUNgRMh87aKIdwg9BaRMh8SaKIdlg9CaRMh8UaKIdbg9DaRMh81aKIdag9EaRa8NaXcx2fg8JIdwg88N:th8ZaKId3g9FaRa8JIdlg89N:th83aKIdKg9Ga8JIdbg8:aRN:th80JbbbbhnaKIdCg9HJbbbbMh85aKIdzg9IJbbbbMhBaKIdxg9JJbbbbMh86dndnaCTmbaXhAinJbbbba87agaAc8S2fgHIdygR:vaRJbbbb9BEhRa8RaAaC2cltfheaHIdaa87Na8ZMh8ZaHId3a87Na83Mh83aHIdKa87Na80Mh80aHIdCa87Na85Mh85aHIdza87NaBMhBaHIdxa87Na86Mh86aHIdwa87Na8SMh8SaHIdla87Na8UMh8UaHIdba87Na81Mh81aChHina8ZaecwfIdbg8VaecxfIdbg8YNaRN:th8Za83aeclfIdbg8Wa8YNaRN:th83a85a8Wa8VNaRN:th85a81aeIdbg8Xa8XNaRN:th81a80a8Xa8YNaRN:th80aBa8Xa8VNaRN:thBa86a8Xa8WNaRN:th86a8Sa8Va8VNaRN:th8Sa8Ua8Wa8WNaRN:th8UaeczfheaHcufgHmbkaQaAcdtfydbgAaX9hmbka8MTmba8MaXcltfgeIdxhxaeIdwh9caeIdlhJaeIdbhRxekJbbbbhxJbbbbh9cJbbbbhJJbbbbhRkaBa81:vg8Wa80Na8Z:ta85aBa86a81:vg8VN:tg8Za8Ua86a8VN:tg8Y:vg8Xa8Va80Na83:tg8UN:th83a9caRa8WN:taJaRa8VN:tg86a8XN:tg85a8SaBa8WN:ta8Za8XN:tgB:vg8S:mh8Za86a8Y:vg9c:mhJdnJbbbbaRaRa81:vg9eN:ta86a9cN:ta85a8SN:tg86:la87J:983:g81NgR9ETmba8Za83NaJa8UNa9ea80Nax:tMMa86:vhnka81:laR9ETmba8Y:laR9ETmbaB:laR9ETmba9e:manNa8W:ma8ZanNa83aB:vMgBNa8V:maJanNa8X:maBNa8Ua8Y:vMMg85Na80:ma81:vMMMh87aLa8FfgeclfydbgHaeydbge9RhhaEaecitfh8FJbbbbhRdnaHaeSgDmbJbbbbhRa8FheahhAina8Naeclfydbcx2fgHIdwa88:tg8Va8VNaHIdba8::tg8Va8VNaHIdla89:tg8Va8VNMMg8Va8Naeydbcx2fgHIdwa88:tg8Wa8WNaHIdba8::tg8Wa8WNaHIdla89:tg8Wa8WNMMg8WaRaRa8W9DEgRaRa8V9DEhRaecwfheaAcufgAmbkaR:rgRaRNhRkaBa88:tg8Va8VNa87a8::tg8Va8VNa85a89:tg8Va8VNMMaR9EmbaKId8KhndnaDmbina8Na8Fclfydbcx2fgeIdba8Na8Fydbcx2fgHIdbg8W:tgRa89aHIdlg8X:tg80NaeIdla8X:tg8Va8:a8W:tg86N:tg8YaRa85a8X:tg8SNa8Va87a8W:tg8UN:tg8XNa8Va88aHIdwg81:tg8ZNaeIdwa81:tg8Wa80N:tg80a8VaBa81:tg83Na8Wa8SN:tg8VNa8Wa86NaRa8ZN:tg81a8Wa8UNaRa83N:tgRNMMa8Ya8YNa80a80Na81a81NMMa8Xa8XNa8Va8VNaRaRNMMN:rJbbj8:N9Fmda8Fcwfh8FahcufghmbkkJbbbbJbbjZac:vacJbbbb9BEgRa9BaBNa9Ia87Na9EMg8Va8VMMaBNa9Ca85Na9HaBNa9FMg8Va8VMMa85Na9Da87Na9Ja85Na9GMg8Va8VMMa87NanMMM:lNaRa9Ba88Na9Ia8:Na9EMg8Va8VMMa88Na9Ca89Na9Ha88Na9FMg8Va8VMMa89Na9Da8:Na9Ja89Na9GMg8Va8VMMa8:NanMMM:lNJbb;aZNJ:983:g81M9Emba8JaBUdwa8Ja85Udla8Ja87UdbkaXcefgXal9hmbkdnaCmbcbhCxdkcbhXindna8AaXfRbbTmbaOaXcdtgefydbaX9hmbaYaXfhhaQaefh8Ja8NaXcx2fhAa8PaXaC2cdtfhDcbhEincuhLdnahRbbci9hmbaXhLa8JydbgeaXSmba8PaEcdtgHfhKaDaHfIdbhRaXhLinaLhHcuhLdnaKaeaC2cdtfIdbaR9CmbaHcuSmbaHhLagaec8S2fIdyagaHc8S2fIdy9ETmbaehLkaQaecdtfydbgeaX9hmbkka8PaEcdtfhKa8RaEcltfh8FaXheinaKaeaC2cdtfJbbbbJbbjZagaeaLaLcuSEgHc8S2fIdygR:vaRJbbbb9BEa8FaHaC2cltfgHIdwaAIdwNaHIdbaAIdbNaHIdlaAIdlNMMaHIdxMNUdbaQaecdtfydbgeaX9hmbkaEcefgEaC9hmbkkaXcefgXal9hmbxdkkaCmbcbhCkaiavaoarawaCala8Na8Pazasayasc1efaYa8Aaqz:hjjjbkdnamcjjjjlGTmbazmbaaTmbabhecbhLinaYaeydbgAfRbbc3thQaecwfgXydbhHcjjjj94hCdna5aAcdtgEfydbaeclfgKydbgOSmbcjjjj94cba8EaOcdtfydbaASEhCkaeaQaCVaAVBdbaYaOfRbbc3th8Fcjjjj94hCcjjjj94hQdna5aOcdtfydbaHSmbcjjjj94cba8EaHcdtfydbaOSEhQkaKa8FaQVaOVBdbaYaHfRbbc3thOdna5aHcdtfydbaASmbcjjjj94cba8EaEfydbaHSEhCkaXaOaCVaHVBdbaecxfheaLcifgLaa6mbkkdnazTmbaaTmbaaheinabazabydbcdtfydbBdbabclfhbaecufgembkkdnaPTmbaPaZaU:rNUdbkdnasyd;8egHTmbaHcdtasc:Ceffc98fheinaeydbcbyd:m:H:cjbH:bjjjbbaec98fheaHcufgHmbkkascj;sbf8Kjjjjbaak;Yieouabydlhvabydbclfcbaicdtz:tjjjbhoadci9UhrdnadTmbdnalTmbaehwadhDinaoalawydbcdtfydbcdtfgqaqydbcefBdbawclfhwaDcufgDmbxdkkaehwadhDinaoawydbcdtfgqaqydbcefBdbawclfhwaDcufgDmbkkdnaiTmbcbhDaohwinawydbhqawaDBdbawclfhwaqaDfhDaicufgimbkkdnadci6mbinaecwfydbhwaeclfydbhDaeydbhidnalTmbalawcdtfydbhwalaDcdtfydbhDalaicdtfydbhikavaoaicdtfgqydbcitfaDBdbavaqydbcitfawBdlaqaqydbcefBdbavaoaDcdtfgqydbcitfawBdbavaqydbcitfaiBdlaqaqydbcefBdbavaoawcdtfgwydbcitfaiBdbavawydbcitfaDBdlawawydbcefBdbaecxfhearcufgrmbkkabydbcbBdbk:todDue99aicd4aifhrcehwinawgDcethwaDar6mbkcuaDcdtgraDcFFFFi0Ecbyd1:H:cjbHjjjjbbhwaoaoyd9GgqcefBd9GaoaqcdtfawBdbawcFearz:tjjjbhkdnaiTmbalcd4hlaDcufhxcbhminamhDdnavTmbavamcdtfydbhDkcbadaDal2cdtfgDydlgwawcjjjj94SEgwcH4aw7c:F:b:DD2cbaDydbgwawcjjjj94SEgwcH4aw7c;D;O:B8J27cbaDydwgDaDcjjjj94SEgDcH4aD7c:3F;N8N27axGhwamcdthPdndndnavTmbakawcdtfgrydbgDcuSmeadavaPfydbal2cdtfgsIdbhzcehqinaqhrdnadavaDcdtfydbal2cdtfgqIdbaz9CmbaqIdlasIdl9CmbaqIdwasIdw9BmlkarcefhqakawarfaxGgwcdtfgrydbgDcu9hmbxdkkakawcdtfgrydbgDcuSmbadamal2cdtfgsIdbhzcehqinaqhrdnadaDal2cdtfgqIdbaz9CmbaqIdlasIdl9CmbaqIdwasIdw9BmikarcefhqakawarfaxGgwcdtfgrydbgDcu9hmbkkaramBdbamhDkabaPfaDBdbamcefgmai9hmbkkakcbyd:m:H:cjbH:bjjjbbaoaoyd9GcufBd9GdnaeTmbaiTmbcbhDaehwinawaDBdbawclfhwaiaDcefgD9hmbkcbhDaehwindnaDabydbgrSmbawaearcdtfgrydbBdbaraDBdbkabclfhbawclfhwaiaDcefgD9hmbkkk;:odvuv998Jjjjjbca9Rgocbyd1:G:cjbBdKaocb8Pdj:G:cjb83izaocbydN:G:cjbBdwaocb8Pd:m:G:cjb83ibdnadTmbaicd4hrdnabmbdnalTmbcbhwinaealawcdtfydbar2cdtfhDcbhiinaoczfaifgqaDaifIdbgkaqIdbgxaxak9EEUdbaoaifgqakaqIdbgxaxak9DEUdbaiclfgicx9hmbkawcefgwad9hmbxikkarcdthwcbhDincbhiinaoczfaifgqaeaifIdbgkaqIdbgxaxak9EEUdbaoaifgqakaqIdbgxaxak9DEUdbaiclfgicx9hmbkaeawfheaDcefgDad9hmbxdkkdnalTmbcbhwinabawcx2fgiaealawcdtfydbar2cdtfgDIdbUdbaiaDIdlUdlaiaDIdwUdwcbhiinaoczfaifgqaDaifIdbgkaqIdbgxaxak9EEUdbaoaifgqakaqIdbgxaxak9DEUdbaiclfgicx9hmbkawcefgwad9hmbxdkkarcdthlcbhwaehDinabawcx2fgiaeawar2cdtfgqIdbUdbaiaqIdlUdlaiaqIdwUdwcbhiinaoczfaifgqaDaifIdbgkaqIdbgxaxak9EEUdbaoaifgqakaqIdbgxaxak9DEUdbaiclfgicx9hmbkaDalfhDawcefgwad9hmbkkJbbbbaoIdbaoIdzgx:tgkakJbbbb9DEgkaoIdlaoIdCgm:tgPaPak9DEgkaoIdwaoIdKgP:tgsasak9DEhsdnabTmbadTmbJbbbbJbbjZas:vasJbbbb9BEhkinabakabIdbax:tNUdbabclfgoakaoIdbam:tNUdbabcwfgoakaoIdbaP:tNUdbabcxfhbadcufgdmbkkdnavTmbavaPUdwavamUdlavaxUdbkask:WlewudnaeTmbcbhvabhoinaoavBdbaoclfhoaeavcefgv9hmbkkdnaiTmbcbhrinadarcdtfhwcbhDinalawaDcdtgvyd:G:G:cjbcdtfydbcdtfydbhodnalawavfydbcdtfydbgqabaqcdtfgkydbgvSmbinakabavgqcdtfgxydbgvBdbaxhkaqav9hmbkkdnaoabaocdtfgkydbgvSmbinakabavgocdtfgxydbgvBdbaxhkaoav9hmbkkdnaqaoSmbabaqaoaqao0Ecdtfaqaoaqao6EBdbkaDcefgDci9hmbkarcifgrai6mbkkdnaembcbskcbhxindnalaxcdtgvfydbax9hmbaxhodnaxabavfgDydbgvSmbaDhqinaqabavgocdtfgkydbgvBdbakhqaoav9hmbkkaDaoBdbkaxcefgxae9hmbkcbhkabhvcbhoindndnaoalydbgq9hmbdnaoavydbgq9hmbavakBdbakcefhkxdkavabaqcdtfydbBdbxekavabaqcdtfydbBdbkalclfhlavclfhvaeaocefgo9hmbkakk;jiilud99euabcbaecltz:tjjjbhvdnalTmbadhoaihralhwinarcwfIdbhDarclfIdbhqavaoydbcltfgkarIdbakIdbMUdbakaqakIdlMUdlakaDakIdwMUdwakakIdxJbbjZMUdxaoclfhoarcxfhrawcufgwmbkkdnaeTmbavhkaehrinakcxfgoIdbhDaocbBdbakakIdbJbbbbJbbjZaD:vaDJbbbb9BEgDNUdbakclfgoaDaoIdbNUdbakcwfgoaDaoIdbNUdbakczfhkarcufgrmbkkdnalTmbinavadydbcltfgkaicwfIdbakIdw:tgDaDNaiIdbakIdb:tgDaDNaiclfIdbakIdl:tgDaDNMMgDakIdxgqaqaD9DEUdxadclfhdaicxfhialcufglmbkkdnaeTmbavcxfhkinabakIdbUdbakczfhkabclfhbaecufgembkkk:moerudnaoTmbaecd4hzdnavTmbaicd4hHavcdthOcbhAindnaPaAfRbbTmbaAhednaDTmbaDaAcdtfydbhekdnasTmbasaefRbbceGmekdnamaAfRbbclSmbabaeaz2cdtfgiaraAcx2fgCIdbakNaxIdbMUdbaiaCIdlakNaxIdlMUdlaiaCIdwakNaxIdwMUdwkadaeaH2cdtfhXaqheawhiavhCinaXaeydbcdtgQfaiIdbalaQfIdb:vUdbaeclfheaiclfhiaCcufgCmbkkawaOfhwaAcefgAao9hmbxdkkdnasmbcbheaDhiindnaPaefRbbTmbaehCdnaDTmbaiydbhCkamaefRbbclSmbabaCaz2cdtfgCarIdbakNaxIdbMUdbaCarclfIdbakNaxIdlMUdlaCarcwfIdbakNaxIdwMUdwkaiclfhiarcxfhraoaecefge9hmbxdkkdnaDTmbindnaPRbbTmbasaDydbgefRbbceGmbamRbbclSmbabaeaz2cdtfgearIdbakNaxIdbMUdbaearclfIdbakNaxIdlMUdlaearcwfIdbakNaxIdwMUdwkaPcefhPaDclfhDamcefhmarcxfhraocufgombxdkkazcdthicbheindnaPaefRbbTmbasaefRbbceGmbamaefRbbclSmbabarIdbakNaxIdbMUdbabclfarclfIdbakNaxIdlMUdbabcwfarcwfIdbakNaxIdwMUdbkarcxfhrabaifhbaoaecefge9hmbkkk8MbabaeadaialavcbcbcbcbcbaoarawaDz:bjjjbk8MbabaeadaialavaoarawaDaqakaxamaPz:bjjjbkRbababaeadaialavaoarawaDaqakaxcjjjjdVamz:bjjjbk:g8Koque99due99duq998Jjjjjbc;Wb9Rgq8Kjjjjbcbhkaqcxfcbc;Kbz:tjjjb8Aaqcualcx2alc;v:Q;v:Qe0Ecbyd1:H:cjbHjjjjbbgxBdxaqceBd2axaialavcbcbz:ejjjb8AaqcualcdtalcFFFFi0Egmcbyd1:H:cjbHjjjjbbgiBdzaqcdBd2dndnJFF959eJbbjZawJbbjZawJbbjZ9DE:vawJ9VO:d869DEgw:lJbbb9p9DTmbaw:OhPxekcjjjj94hPkadci9Uhsarco9UhzdndnaombaPcd9imekdnalTmbaPcuf:YhwdnaoTmbcbhvaihHaxhOindndnaoavfRbbceGTmbavcjjjjlVhAxekdndnaOclfIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhAxekcjjjj94hAkaAcqthAdndnaOcwfIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhXxekcjjjj94hXkaAaXVhAdndnaOIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhXxekcjjjj94hXkaAaXcCtVhAkaHaABdbaHclfhHaOcxfhOalavcefgv9hmbxdkkaxhvaihOalhHindndnavIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhAxekcjjjj94hAkaAcCthAdndnavclfIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhXxekcjjjj94hXkaXcqtaAVhAdndnavcwfIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhXxekcjjjj94hXkaOaAaXVBdbavcxfhvaOclfhOaHcufgHmbkkadTmbcbhkaehvcbhOinakaiavclfydbcdtfydbgHaiavcwfydbcdtfydbgA9haiavydbcdtfydbgXaH9haXaA9hGGfhkavcxfhvaOcifgOad6mbkkarci9UhQdndnaz:Z:rJbbbZMgw:lJbbb9p9DTmbaw:Ohvxekcjjjj94hvkaQ:ZhLcbhKc:bwhzdninakaQ9pmeazaP9Rcd9imeavazcufgOavaO9iEaPcefavaP9kEhYdnalTmbaYcuf:YhwdnaoTmbcbhOaihHaxhvindndnaoaOfRbbceGTmbaOcjjjjlVhAxekdndnavclfIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhAxekcjjjj94hAkaAcqthAdndnavcwfIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhXxekcjjjj94hXkaAaXVhAdndnavIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhXxekcjjjj94hXkaAaXcCtVhAkaHaABdbaHclfhHavcxfhvalaOcefgO9hmbxdkkaxhvaihOalhHindndnavIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhAxekcjjjj94hAkaAcCthAdndnavclfIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhXxekcjjjj94hXkaXcqtaAVhAdndnavcwfIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhXxekcjjjj94hXkaOaAaXVBdbavcxfhvaOclfhOaHcufgHmbkkcbhOdnadTmbaehvcbhHinaOaiavclfydbcdtfydbgAaiavcwfydbcdtfydbgX9haiavydbcdtfydbgraA9haraX9hGGfhOavcxfhvaHcifgHad6mbkkdnas:ZgCaL:taY:Ygwaz:Y:tg8ANak:ZgEaO:Zg3:tNaEaL:tawaP:Y:tg5Na3aC:tNMg8EJbbbb9BmbaCaE:ta5a8Aa3aL:tNNNa8E:vawMhwkdndnaOaQ0mbaOhkaYhPxekaOhsaYhzkdndnaKcl0mbdnawJbbbZMgw:lJbbb9p9DTmbaw:Ohvxdkcjjjj94hvxekaPazfcd9ThvkaKcefgKcs9hmbkkdndndnakmbJbbjZhwcbhOcdhvaDmexdkalcd4alfhHcehOinaOgvcethOavaH6mbkcbhOaqcuavcdtgYavcFFFFi0Ecbyd1:H:cjbHjjjjbbgKBdCaqciBd2aqamcbyd1:H:cjbHjjjjbbgzBdKaqclBd2dndndndnalTmbaPcuf:YhwaoTmecbhOaihAaxhHindndnaoaOfRbbceGTmbaOcjjjjlVhXxekdndnaHclfIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhXxekcjjjj94hXkaXcqthXdndnaHcwfIdbawNJbbbZMgC:lJbbb9p9DTmbaC:Ohrxekcjjjj94hrkaXarVhXdndnaHIdbawNJbbbZMgC:lJbbb9p9DTmbaC:Ohrxekcjjjj94hrkaXarcCtVhXkaAaXBdbaAclfhAaHcxfhHalaOcefgO9hmbxikkaKcFeaYz:tjjjb8AcbhPcbhvxdkaxhOaihHalhAindndnaOIdbawNJbbbZMgC:lJbbb9p9DTmbaC:OhXxekcjjjj94hXkaXcCthXdndnaOclfIdbawNJbbbZMgC:lJbbb9p9DTmbaC:Ohrxekcjjjj94hrkarcqtaXVhXdndnaOcwfIdbawNJbbbZMgC:lJbbb9p9DTmbaC:Ohrxekcjjjj94hrkaHaXarVBdbaOcxfhOaHclfhHaAcufgAmbkkaKcFeaYz:tjjjbhravcufhocbhPcbhYindndndnaraiaYcdtgKfydbgAcm4aA7c:v;t;h;Ev2gvcs4av7aoGgHcdtfgXydbgOcuSmbcehvinaiaOcdtgOfydbaASmdaHavfhOavcefhvaraOaoGgHcdtfgXydbgOcu9hmbkkaXaYBdbaPhvaPcefhPxekazaOfydbhvkazaKfavBdbaYcefgYal9hmbkcuaPc8S2gOaPc;D;O;f8U0EhvkcbhXaqavcbyd1:H:cjbHjjjjbbgvBd3aqcvBd2avcbaOz:tjjjbhOdnadTmbaehiinaxaiclfydbgrcx2fgvIdbaxaiydbgocx2fgHIdbg3:tgCaxaicwfydbgYcx2fgAIdlaHIdlg8A:tgwNavIdla8A:tgEaAIdba3:tg8EN:tgLaLNaEaAIdwaHIdwg5:tg8FNavIdwa5:tgEawN:tgwawNaEa8ENaCa8FN:tgCaCNMMg8E:rhEJbbnnJbbjZazaocdtfydbgvazarcdtfydbgASavazaYcdtfydbgrSGgHEh8Fdna8EJbbbb9ETmbaLaE:vhLaCaE:vhCawaE:vhwkaOavc8S2fgvavIdbawa8FaE:rNgEawNNg8FMUdbavaCaEaCNgaNghavIdlMUdlavaLaEaLNg8ENggavIdwMUdwavawaaNgaavIdxMUdxava8EawNg8JavIdzMUdzavaCa8ENg8EavIdCMUdCavawaEaLa5Nawa3Na8AaCNMM:mg8ANg3NgwavIdKMUdKavaCa3NgCavId3MUd3avaLa3NgLavIdaMUdaava3a8ANg3avId8KMUd8KavaEavIdyMUdydnaHmbaOaAc8S2fgva8FavIdbMUdbavahavIdlMUdlavagavIdwMUdwavaaavIdxMUdxava8JavIdzMUdzava8EavIdCMUdCavawavIdKMUdKavaCavId3MUd3avaLavIdaMUdaava3avId8KMUd8KavaEavIdyMUdyaOarc8S2fgva8FavIdbMUdbavahavIdlMUdlavagavIdwMUdwavaaavIdxMUdxava8JavIdzMUdzava8EavIdCMUdCavawavIdKMUdKavaCavId3MUd3avaLavIdaMUdaava3avId8KMUd8KavaEavIdyMUdykaicxfhiaXcifgXad6mbkkcbhAaqcuaPcdtgvaPcFFFFi0Egicbyd1:H:cjbHjjjjbbgHBdaaqcoBd2aqaicbyd1:H:cjbHjjjjbbgiBd8KaqcrBd2aHcFeavz:tjjjbhYdnalTmbazhHinJbbbbJbbjZaOaHydbgXc8S2fgvIdygw:vawJbbbb9BEavIdwaxcwfIdbgwNavIdzaxIdbgCNavIdaMgLaLMMawNavIdlaxclfIdbgLNavIdCawNavId3MgwawMMaLNavIdbaCNavIdxaLNavIdKMgwawMMaCNavId8KMMM:lNhwdndnaYaXcdtgvfgXydbcuSmbaiavfIdbaw9ETmekaXaABdbaiavfawUdbkaHclfhHaxcxfhxalaAcefgA9hmbkkdndnaPmbJbbbbhwxekJbbbbhwinaiIdbgCawawaC9DEhwaiclfhiaPcufgPmbkaw:rhwkakcd4akfhOcehiinaigvcethiavaO6mbkcbhOaqcuavcdtgiavcFFFFi0Ecbyd1:H:cjbHjjjjbbgHBdyaHcFeaiz:tjjjbhXdnadTmbavcufhrcbhPcbhxindnazaeaxcdtfgvydbcdtfydbgiazavclfydbcdtfydbgOSmbaiazavcwfydbcdtfydbgvSmbaOavSmbaYavcdtfydbhAdndnaYaOcdtfydbgvaYaicdtfydbgi9pmbavaA9pmbaAhlaihoavhAxekdnaAai9pmbaAav9pmbaihlavhoxekavhlaAhoaihAkabaPcx2fgvaABdbavcwfaoBdbavclfalBdbdnaXaoc:3F;N8N2alc:F:b:DD27aAc;D;O:B8J27arGgOcdtfgvydbgicuSmbcehHinaHhvdnabaicx2fgiydbaA9hmbaiydlal9hmbaiydwaoSmikavcefhHaXaOavfarGgOcdtfgvydbgicu9hmbkkavaPBdbaPcefhPkaxcifgxad6mbkaPci2hOkcwhvaDTmekaDawUdbkavcdthvaqcxfc98fhiinaiavfydbcbyd:m:H:cjbH:bjjjbbavc98fgvmbkaqc;Wbf8KjjjjbaOk:3ldrue9:8Jjjjjbc;Wb9Rgr8Kjjjjbcbhwarcxfcbc;Kbz:tjjjb8AdnabaeSmbabaeadcdtzMjjjb8AkarcualcdtalcFFFFi0EgDcbyd1:H:cjbHjjjjbbgqBdxarceBd2aqcbaialavcbarcxfz:djjjbcualcx2alc;v:Q;v:Qe0Ecbyd1:H:cjbHjjjjbbhkarcxfaryd2gxcdtfakBdbaraxcefgmBd2akaialavcbcbz:ejjjb8AarcxfamcdtfaDcbyd1:H:cjbHjjjjbbgiBdbaraxcdfgvBd2arcxfavcdtfcuaialaeadaqz:fjjjbgecltaecjjjjiGEcbyd1:H:cjbHjjjjbbgqBdbaqaeaiakalz:gjjjbaxcifhkdnadTmbaoaoNhocbhwabhlcbheindnaqaialydbgvcdtfydbcdtfIdbao9ETmbalclf8PdbhPabawcdtfgDavBdbaDclfaP83dbawcifhwkalcxfhlaecifgead6mbkkdnakTmbaxcdtarcxffcwfhlinalydbcbyd:m:H:cjbH:bjjjbbalc98fhlakcufgkmbkkarc;Wbf8Kjjjjbawk:WCoDud99vue99vuv998Jjjjjbc;Wb9Rgw8KjjjjbdndnarmbcbhDxekawcxfcbc;Kbz:tjjjb8Aawcuadcx2adc;v:Q;v:Qe0Ecbyd1:H:cjbHjjjjbbgqBdxawceBd2aqaeadaicbcbz:ejjjb8AawcuadcdtadcFFFFi0Egkcbyd1:H:cjbHjjjjbbgxBdzawcdBd2adcd4adfhmceheinaegicetheaiam6mbkcbhPawcuaicdtgsaicFFFFi0Ecbyd1:H:cjbHjjjjbbgzBdCawciBd2dndnar:ZgH:rJbbbZMgO:lJbbb9p9DTmbaO:Ohexekcjjjj94hekaicufhAc:bwhCcbhXadhQcbhLinaeaCcufgiaeai9iEaPcefaeaP9kEhDdndnadTmbaDcuf:YhOaqhiaxheadhmindndnaiIdbaONJbbbZMgK:lJbbb9p9DTmbaK:OhYxekcjjjj94hYkaYcCthYdndnaiclfIdbaONJbbbZMgK:lJbbb9p9DTmbaK:Oh8Axekcjjjj94h8Aka8AcqtaYVhYdndnaicwfIdbaONJbbbZMgK:lJbbb9p9DTmbaK:Oh8Axekcjjjj94h8AkaeaYa8AVBdbaicxfhiaeclfheamcufgmmbkazcFeasz:tjjjbhEcbh3cbh5indnaEaxa5cdtfydbgYcm4aY7c:v;t;h;Ev2gics4ai7aAGgmcdtfg8AydbgecuSmbaeaYSmbcehiinaEamaifaAGgmcdtfg8AydbgecuSmeaicefhiaeaY9hmbkka8AaYBdba3aecuSfh3a5cefg5ad9hmbxdkkazcFeasz:tjjjb8Acbh3kdnaQ:ZgKaH:taD:YgOaC:Y:tg8ENaX:Zg8Fa3:Zga:tNa8FaH:taOaP:Y:tghNaaaK:tNMggJbbbb9BmbaKa8F:taha8EaaaH:tNNNag:vaOMhOkaPaDa3ar0giEhPaXa3aiEhXdna3arSmbaDaCaiEgCaP9Rcd9imbdndnaLcl0mbdnaOJbbbZMgO:lJbbb9p9DTmbaO:Ohexdkcjjjj94hexekaPaCfcd9Theka3aQaiEhQaLcefgLcs9hmekkdndnaXmbcihicbhDxekcbhiawakcbyd1:H:cjbHjjjjbbg5BdKawclBd2aPcuf:YhKdndnadTmbaqhiaxheadhmindndnaiIdbaKNJbbbZMgO:lJbbb9p9DTmbaO:OhYxekcjjjj94hYkaYcCthYdndnaiclfIdbaKNJbbbZMgO:lJbbb9p9DTmbaO:Oh8Axekcjjjj94h8Aka8AcqtaYVhYdndnaicwfIdbaKNJbbbZMgO:lJbbb9p9DTmbaO:Oh8Axekcjjjj94h8AkaeaYa8AVBdbaicxfhiaeclfheamcufgmmbkazcFeasz:tjjjbhEcbhDcbh3indndndnaEaxa3cdtgCfydbgYcm4aY7c:v;t;h;Ev2gics4ai7aAGgmcdtfg8AydbgecuSmbcehiinaxaecdtgefydbaYSmdamaifheaicefhiaEaeaAGgmcdtfg8Aydbgecu9hmbkka8Aa3BdbaDhiaDcefhDxeka5aefydbhika5aCfaiBdba3cefg3ad9hmbkcuaDc32giaDc;j:KM;jb0EhexekazcFeasz:tjjjb8AcbhDcbhekawaecbyd1:H:cjbHjjjjbbgeBd3awcvBd2aecbaiz:tjjjbh8Aavcd4hxdnadTmbdnalTmbaxcdthEa5hYaqhealhmadhAina8AaYydbc32fgiaeIdbaiIdbMUdbaiaeclfIdbaiIdlMUdlaiaecwfIdbaiIdwMUdwaiamIdbaiIdxMUdxaiamclfIdbaiIdzMUdzaiamcwfIdbaiIdCMUdCaiaiIdKJbbjZMUdKaYclfhYaecxfheamaEfhmaAcufgAmbxdkka5hmaqheadhYina8Aamydbc32fgiaeIdbaiIdbMUdbaiaeclfIdbaiIdlMUdlaiaecwfIdbaiIdwMUdwaiaiIdxJbbbbMUdxaiaiIdzJbbbbMUdzaiaiIdCJbbbbMUdCaiaiIdKJbbjZMUdKamclfhmaecxfheaYcufgYmbkkdnaDTmba8AhiaDheinaiaiIdbJbbbbJbbjZaicKfIdbgO:vaOJbbbb9BEgONUdbaiclfgmaOamIdbNUdbaicwfgmaOamIdbNUdbaicxfgmaOamIdbNUdbaiczfgmaOamIdbNUdbaicCfgmaOamIdbNUdbaic3fhiaecufgembkkcbhYawcuaDcdtgCaDcFFFFi0Egicbyd1:H:cjbHjjjjbbgeBdaawcoBd2awaicbyd1:H:cjbHjjjjbbgEBd8KaecFeaCz:tjjjbh3dnadTmbaoJbbjZJbbjZaK:vaPceSENgOaONhKaxcdthxalheinaKaec;8:G:cjbalEgmIdwa8Aa5ydbgAc32fgiIdC:tgOaONamIdbaiIdx:tgOaONamIdlaiIdz:tgOaONMMNaqcwfIdbaiIdw:tgOaONaqIdbaiIdb:tgOaONaqclfIdbaiIdl:tgOaONMMMhOdndna3aAcdtgifgmydbcuSmbaEaifIdbaO9ETmekamaYBdbaEaifaOUdbka5clfh5aqcxfhqaeaxfheadaYcefgY9hmbkkaba3aCzMjjjb8Acrhikaicdthiawcxfc98fheinaeaifydbcbyd:m:H:cjbH:bjjjbbaic98fgimbkkawc;Wbf8KjjjjbaDk:Pdidui99ducbhi8Jjjjjbca9Rglcbyd1:G:cjbBdKalcb8Pdj:G:cjb83izalcbydN:G:cjbBdwalcb8Pd:m:G:cjb83ibdndnaembJbbjFhvJbbjFhoJbbjFhrxekadcd4cdthwincbhdinalczfadfgDabadfIdbgvaDIdbgoaoav9EEUdbaladfgDavaDIdbgoaoav9DEUdbadclfgdcx9hmbkabawfhbaicefgiae9hmbkalIdwalIdK:thralIdlalIdC:thoalIdbalIdz:thvkJbbbbavavJbbbb9DEgvaoaoav9DEgvararav9DEk9DeeuabcFeaicdtz:tjjjbhlcbhbdnadTmbindnalaeydbcdtfgiydbcu9hmbaiabBdbabcefhbkaeclfheadcufgdmbkkabk;Bidqui998Jjjjjbc;Wb9Rgl8Kjjjjbalcxfcbc;Kbz:tjjjb8Aadcd4adfhvcehoinaogrcethoarav6mbkalcuarcdtgoarcFFFFi0Ecbyd1:H:cjbHjjjjbbgvBdxavcFeaoz:tjjjbhwdnadTmbaicd4hDarcufhqcbhkindndnawcbaeakaD2cdtfgrydlgiaicjjjj94SEgocH4ao7c:F:b:DD2cbarydbgxaxcjjjj94SEgocH4ao7c;D;O:B8J27cbarydwgmamcjjjj94SEgrcH4ar7c:3F;N8N27aqGgvcdtfgrydbgocuSmbam::hPai::hsax::hzcehiinaihrdnaeaoaD2cdtfgiIdbaz9CmbaiIdlas9CmbaiIdwaP9BmikarcefhiawavarfaqGgvcdtfgrydbgocu9hmbkkarakBdbakhokabakcdtfaoBdbakcefgkad9hmbkkalydxcbyd:m:H:cjbH:bjjjbbalc;Wbf8Kjjjjbk9teiucbcbyd:q:H:cjbgeabcifc98GfgbBd:q:H:cjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaik;LeeeudndnaeabVciGTmbabhixekdndnadcz9pmbabhixekabhiinaiaeydbBdbaiclfaeclfydbBdbaicwfaecwfydbBdbaicxfaecxfydbBdbaeczfheaiczfhiadc9Wfgdcs0mbkkadcl6mbinaiaeydbBdbaeclfheaiclfhiadc98fgdci0mbkkdnadTmbinaiaeRbb86bbaicefhiaecefheadcufgdmbkkabk;aeedudndnabciGTmbabhixekaecFeGc:b:c:ew2hldndnadcz9pmbabhixekabhiinaialBdbaicxfalBdbaicwfalBdbaiclfalBdbaiczfhiadc9Wfgdcs0mbkkadcl6mbinaialBdbaiclfhiadc98fgdci0mbkkdnadTmbinaiae86bbaicefhiadcufgdmbkkabk9teiucbcbyd:q:H:cjbgeabcrfc94GfgbBd:q:H:cjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaikTeeucbabcbyd:q:H:cjbge9Rcifc98GaefgbBd:q:H:cjbdnabZbcztge9nmbabae9RcFFifcz4nb8Akkk:Kedbcj:Gdk1eFFuuFFuuFFuuFFuFFFuFFFuFbbbbbbbbebbbdbbbbbbbebbbebbbdbbbbbbbbbbbeeeeebebbebbebebbbeebbbbbbbbbbbbeeeeeebebbeeebeebbbbebebbbbbbbbbbbbbbbbbbc1:Hdkxebbbdbbb:G:qbb";
618
+ var wasmpack = new Uint8Array([
619
+ 32,
620
+ 0,
621
+ 65,
622
+ 2,
623
+ 1,
624
+ 106,
625
+ 34,
626
+ 33,
627
+ 3,
628
+ 128,
629
+ 11,
630
+ 4,
631
+ 13,
632
+ 64,
633
+ 6,
634
+ 253,
635
+ 10,
636
+ 7,
637
+ 15,
638
+ 116,
639
+ 127,
640
+ 5,
641
+ 8,
642
+ 12,
643
+ 40,
644
+ 16,
645
+ 19,
646
+ 54,
647
+ 20,
648
+ 9,
649
+ 27,
650
+ 255,
651
+ 113,
652
+ 17,
653
+ 42,
654
+ 67,
655
+ 24,
656
+ 23,
657
+ 146,
658
+ 148,
659
+ 18,
660
+ 14,
661
+ 22,
662
+ 45,
663
+ 70,
664
+ 69,
665
+ 56,
666
+ 114,
667
+ 101,
668
+ 21,
669
+ 25,
670
+ 63,
671
+ 75,
672
+ 136,
673
+ 108,
674
+ 28,
675
+ 118,
676
+ 29,
677
+ 73,
678
+ 115
679
+ ]);
680
+ if (typeof WebAssembly !== "object") {
681
+ return {
682
+ supported: false
683
+ };
684
+ }
685
+ var instance;
686
+ var ready = WebAssembly.instantiate(unpack(wasm), {}).then(function(result) {
687
+ instance = result.instance;
688
+ instance.exports.__wasm_call_ctors();
689
+ });
690
+ function unpack(data) {
691
+ var result = new Uint8Array(data.length);
692
+ for (var i = 0; i < data.length; ++i) {
693
+ var ch = data.charCodeAt(i);
694
+ result[i] = ch > 96 ? ch - 97 : ch > 64 ? ch - 39 : ch + 4;
695
+ }
696
+ var write = 0;
697
+ for (var i = 0; i < data.length; ++i) {
698
+ result[write++] = result[i] < 60 ? wasmpack[result[i]] : (result[i] - 60) * 64 + result[++i];
699
+ }
700
+ return result.buffer.slice(0, write);
701
+ }
702
+ function assert(cond) {
703
+ if (!cond) {
704
+ throw new Error("Assertion failed");
705
+ }
706
+ }
707
+ function bytes(view) {
708
+ return new Uint8Array(view.buffer, view.byteOffset, view.byteLength);
709
+ }
710
+ function genremap(fun, positions, vertices, stride) {
711
+ var sbrk = instance.exports.sbrk;
712
+ var rp = sbrk(vertices * 4);
713
+ var sp = sbrk(vertices * stride * 4);
714
+ var heap = new Uint8Array(instance.exports.memory.buffer);
715
+ heap.set(bytes(positions), sp);
716
+ fun(rp, sp, vertices, stride * 4);
717
+ heap = new Uint8Array(instance.exports.memory.buffer);
718
+ var remap = new Uint32Array(vertices);
719
+ new Uint8Array(remap.buffer).set(heap.subarray(rp, rp + vertices * 4));
720
+ sbrk(rp - sbrk(0));
721
+ return remap;
722
+ }
723
+ function reorder(fun, indices, vertices) {
724
+ var sbrk = instance.exports.sbrk;
725
+ var ip = sbrk(indices.length * 4);
726
+ var rp = sbrk(vertices * 4);
727
+ var heap = new Uint8Array(instance.exports.memory.buffer);
728
+ var indices8 = bytes(indices);
729
+ heap.set(indices8, ip);
730
+ var unique = fun(rp, ip, indices.length, vertices);
731
+ heap = new Uint8Array(instance.exports.memory.buffer);
732
+ var remap = new Uint32Array(vertices);
733
+ new Uint8Array(remap.buffer).set(heap.subarray(rp, rp + vertices * 4));
734
+ sbrk(ip - sbrk(0));
735
+ for (var i = 0; i < indices.length; ++i) indices[i] = remap[indices[i]];
736
+ return [remap, unique];
737
+ }
738
+ function maxindex(source) {
739
+ var result = 0;
740
+ for (var i = 0; i < source.length; ++i) {
741
+ var index = source[i];
742
+ result = result < index ? index : result;
743
+ }
744
+ return result;
745
+ }
746
+ function simplify(fun, indices, index_count, vertex_positions, vertex_count, vertex_positions_stride, target_index_count, target_error, options) {
747
+ var sbrk = instance.exports.sbrk;
748
+ var te = sbrk(4);
749
+ var ti = sbrk(index_count * 4);
750
+ var sp = sbrk(vertex_count * vertex_positions_stride);
751
+ var si = sbrk(index_count * 4);
752
+ var heap = new Uint8Array(instance.exports.memory.buffer);
753
+ heap.set(bytes(vertex_positions), sp);
754
+ heap.set(bytes(indices), si);
755
+ var result = fun(ti, si, index_count, sp, vertex_count, vertex_positions_stride, target_index_count, target_error, options, te);
756
+ heap = new Uint8Array(instance.exports.memory.buffer);
757
+ var target = new Uint32Array(result);
758
+ bytes(target).set(heap.subarray(ti, ti + result * 4));
759
+ var error = new Float32Array(1);
760
+ bytes(error).set(heap.subarray(te, te + 4));
761
+ sbrk(te - sbrk(0));
762
+ return [target, error[0]];
763
+ }
764
+ function simplifyAttr(fun, indices, index_count, vertex_positions, vertex_count, vertex_positions_stride, vertex_attributes, vertex_attributes_stride, attribute_weights, vertex_lock, target_index_count, target_error, options) {
765
+ var sbrk = instance.exports.sbrk;
766
+ var te = sbrk(4);
767
+ var ti = sbrk(index_count * 4);
768
+ var sp = sbrk(vertex_count * vertex_positions_stride);
769
+ var sa = sbrk(vertex_count * vertex_attributes_stride);
770
+ var sw = sbrk(attribute_weights.length * 4);
771
+ var si = sbrk(index_count * 4);
772
+ var vl = vertex_lock ? sbrk(vertex_count) : 0;
773
+ var heap = new Uint8Array(instance.exports.memory.buffer);
774
+ heap.set(bytes(vertex_positions), sp);
775
+ heap.set(bytes(vertex_attributes), sa);
776
+ heap.set(bytes(attribute_weights), sw);
777
+ heap.set(bytes(indices), si);
778
+ if (vertex_lock) {
779
+ heap.set(bytes(vertex_lock), vl);
780
+ }
781
+ var result = fun(
782
+ ti,
783
+ si,
784
+ index_count,
785
+ sp,
786
+ vertex_count,
787
+ vertex_positions_stride,
788
+ sa,
789
+ vertex_attributes_stride,
790
+ sw,
791
+ attribute_weights.length,
792
+ vl,
793
+ target_index_count,
794
+ target_error,
795
+ options,
796
+ te
797
+ );
798
+ heap = new Uint8Array(instance.exports.memory.buffer);
799
+ var target = new Uint32Array(result);
800
+ bytes(target).set(heap.subarray(ti, ti + result * 4));
801
+ var error = new Float32Array(1);
802
+ bytes(error).set(heap.subarray(te, te + 4));
803
+ sbrk(te - sbrk(0));
804
+ return [target, error[0]];
805
+ }
806
+ function simplifyUpdate(fun, indices, index_count, vertex_positions, vertex_count, vertex_positions_stride, vertex_attributes, vertex_attributes_stride, attribute_weights, vertex_lock, target_index_count, target_error, options) {
807
+ var sbrk = instance.exports.sbrk;
808
+ var te = sbrk(4);
809
+ var sp = sbrk(vertex_count * vertex_positions_stride);
810
+ var sa = sbrk(vertex_count * vertex_attributes_stride);
811
+ var sw = sbrk(attribute_weights.length * 4);
812
+ var si = sbrk(index_count * 4);
813
+ var vl = vertex_lock ? sbrk(vertex_count) : 0;
814
+ var heap = new Uint8Array(instance.exports.memory.buffer);
815
+ heap.set(bytes(vertex_positions), sp);
816
+ heap.set(bytes(vertex_attributes), sa);
817
+ heap.set(bytes(attribute_weights), sw);
818
+ heap.set(bytes(indices), si);
819
+ if (vertex_lock) {
820
+ heap.set(bytes(vertex_lock), vl);
821
+ }
822
+ var result = fun(
823
+ si,
824
+ index_count,
825
+ sp,
826
+ vertex_count,
827
+ vertex_positions_stride,
828
+ sa,
829
+ vertex_attributes_stride,
830
+ sw,
831
+ attribute_weights.length,
832
+ vl,
833
+ target_index_count,
834
+ target_error,
835
+ options,
836
+ te
837
+ );
838
+ heap = new Uint8Array(instance.exports.memory.buffer);
839
+ bytes(indices).set(heap.subarray(si, si + result * 4));
840
+ bytes(vertex_positions).set(heap.subarray(sp, sp + vertex_count * vertex_positions_stride));
841
+ bytes(vertex_attributes).set(heap.subarray(sa, sa + vertex_count * vertex_attributes_stride));
842
+ var error = new Float32Array(1);
843
+ bytes(error).set(heap.subarray(te, te + 4));
844
+ sbrk(te - sbrk(0));
845
+ return [result, error[0]];
846
+ }
847
+ function simplifyScale(fun, vertex_positions, vertex_count, vertex_positions_stride) {
848
+ var sbrk = instance.exports.sbrk;
849
+ var sp = sbrk(vertex_count * vertex_positions_stride);
850
+ var heap = new Uint8Array(instance.exports.memory.buffer);
851
+ heap.set(bytes(vertex_positions), sp);
852
+ var result = fun(sp, vertex_count, vertex_positions_stride);
853
+ sbrk(sp - sbrk(0));
854
+ return result;
855
+ }
856
+ function simplifyPoints(fun, vertex_positions, vertex_count, vertex_positions_stride, vertex_colors, vertex_colors_stride, color_weight, target_vertex_count) {
857
+ var sbrk = instance.exports.sbrk;
858
+ var ti = sbrk(target_vertex_count * 4);
859
+ var sp = sbrk(vertex_count * vertex_positions_stride);
860
+ var sc = vertex_colors ? sbrk(vertex_count * vertex_colors_stride) : 0;
861
+ var heap = new Uint8Array(instance.exports.memory.buffer);
862
+ heap.set(bytes(vertex_positions), sp);
863
+ if (vertex_colors) {
864
+ heap.set(bytes(vertex_colors), sc);
865
+ }
866
+ var result = fun(ti, sp, vertex_count, vertex_positions_stride, sc, vertex_colors_stride, color_weight, target_vertex_count);
867
+ heap = new Uint8Array(instance.exports.memory.buffer);
868
+ var target = new Uint32Array(result);
869
+ bytes(target).set(heap.subarray(ti, ti + result * 4));
870
+ sbrk(ti - sbrk(0));
871
+ return target;
872
+ }
873
+ function simplifySloppy(fun, indices, index_count, vertex_positions, vertex_count, vertex_positions_stride, vertex_lock, target_index_count, target_error) {
874
+ var sbrk = instance.exports.sbrk;
875
+ var te = sbrk(4);
876
+ var ti = sbrk(index_count * 4);
877
+ var sp = sbrk(vertex_count * vertex_positions_stride);
878
+ var si = sbrk(index_count * 4);
879
+ var vl = vertex_lock ? sbrk(vertex_count) : 0;
880
+ var heap = new Uint8Array(instance.exports.memory.buffer);
881
+ heap.set(bytes(vertex_positions), sp);
882
+ heap.set(bytes(indices), si);
883
+ if (vertex_lock) {
884
+ heap.set(bytes(vertex_lock), vl);
885
+ }
886
+ var result = fun(ti, si, index_count, sp, vertex_count, vertex_positions_stride, vl, target_index_count, target_error, te);
887
+ heap = new Uint8Array(instance.exports.memory.buffer);
888
+ var target = new Uint32Array(result);
889
+ bytes(target).set(heap.subarray(ti, ti + result * 4));
890
+ var error = new Float32Array(1);
891
+ bytes(error).set(heap.subarray(te, te + 4));
892
+ sbrk(te - sbrk(0));
893
+ return [target, error[0]];
894
+ }
895
+ function simplifyPrune(fun, indices, index_count, vertex_positions, vertex_count, vertex_positions_stride, target_error) {
896
+ var sbrk = instance.exports.sbrk;
897
+ var ti = sbrk(index_count * 4);
898
+ var sp = sbrk(vertex_count * vertex_positions_stride);
899
+ var si = sbrk(index_count * 4);
900
+ var heap = new Uint8Array(instance.exports.memory.buffer);
901
+ heap.set(bytes(vertex_positions), sp);
902
+ heap.set(bytes(indices), si);
903
+ var result = fun(ti, si, index_count, sp, vertex_count, vertex_positions_stride, target_error);
904
+ heap = new Uint8Array(instance.exports.memory.buffer);
905
+ var target = new Uint32Array(result);
906
+ bytes(target).set(heap.subarray(ti, ti + result * 4));
907
+ sbrk(ti - sbrk(0));
908
+ return target;
909
+ }
910
+ var simplifyOptions = {
911
+ LockBorder: 1,
912
+ Sparse: 2,
913
+ ErrorAbsolute: 4,
914
+ Prune: 8,
915
+ Regularize: 16,
916
+ Permissive: 32,
917
+ RegularizeLight: 64,
918
+ _InternalDebug: 1 << 30
919
+ // internal, don't use!
920
+ };
921
+ return {
922
+ ready,
923
+ supported: true,
924
+ compactMesh: function(indices) {
925
+ assert(
926
+ indices instanceof Uint32Array || indices instanceof Int32Array || indices instanceof Uint16Array || indices instanceof Int16Array
927
+ );
928
+ assert(indices.length % 3 == 0);
929
+ var indices32 = indices.BYTES_PER_ELEMENT == 4 ? indices : new Uint32Array(indices);
930
+ var result = reorder(instance.exports.meshopt_optimizeVertexFetchRemap, indices32, maxindex(indices) + 1);
931
+ if (indices !== indices32) {
932
+ for (var i = 0; i < indices32.length; ++i) {
933
+ indices[i] = indices32[i];
934
+ }
935
+ }
936
+ return result;
937
+ },
938
+ generatePositionRemap: function(vertex_positions, vertex_positions_stride) {
939
+ assert(vertex_positions instanceof Float32Array);
940
+ assert(vertex_positions.length % vertex_positions_stride == 0);
941
+ assert(vertex_positions_stride >= 3);
942
+ return genremap(
943
+ instance.exports.meshopt_generatePositionRemap,
944
+ vertex_positions,
945
+ vertex_positions.length / vertex_positions_stride,
946
+ vertex_positions_stride
947
+ );
948
+ },
949
+ simplify: function(indices, vertex_positions, vertex_positions_stride, target_index_count, target_error, flags) {
950
+ assert(
951
+ indices instanceof Uint32Array || indices instanceof Int32Array || indices instanceof Uint16Array || indices instanceof Int16Array
952
+ );
953
+ assert(indices.length % 3 == 0);
954
+ assert(vertex_positions instanceof Float32Array);
955
+ assert(vertex_positions.length % vertex_positions_stride == 0);
956
+ assert(vertex_positions_stride >= 3);
957
+ assert(target_index_count >= 0 && target_index_count <= indices.length);
958
+ assert(target_index_count % 3 == 0);
959
+ assert(target_error >= 0);
960
+ var options = 0;
961
+ for (var i = 0; i < (flags ? flags.length : 0); ++i) {
962
+ assert(flags[i] in simplifyOptions);
963
+ options |= simplifyOptions[flags[i]];
964
+ }
965
+ var indices32 = indices.BYTES_PER_ELEMENT == 4 ? indices : new Uint32Array(indices);
966
+ var result = simplify(
967
+ instance.exports.meshopt_simplify,
968
+ indices32,
969
+ indices.length,
970
+ vertex_positions,
971
+ vertex_positions.length / vertex_positions_stride,
972
+ vertex_positions_stride * 4,
973
+ target_index_count,
974
+ target_error,
975
+ options
976
+ );
977
+ result[0] = indices instanceof Uint32Array ? result[0] : new indices.constructor(result[0]);
978
+ return result;
979
+ },
980
+ simplifyWithAttributes: function(indices, vertex_positions, vertex_positions_stride, vertex_attributes, vertex_attributes_stride, attribute_weights, vertex_lock, target_index_count, target_error, flags) {
981
+ assert(
982
+ indices instanceof Uint32Array || indices instanceof Int32Array || indices instanceof Uint16Array || indices instanceof Int16Array
983
+ );
984
+ assert(indices.length % 3 == 0);
985
+ assert(vertex_positions instanceof Float32Array);
986
+ assert(vertex_positions.length % vertex_positions_stride == 0);
987
+ assert(vertex_positions_stride >= 3);
988
+ assert(vertex_attributes instanceof Float32Array);
989
+ assert(vertex_attributes.length == vertex_attributes_stride * (vertex_positions.length / vertex_positions_stride));
990
+ assert(vertex_attributes_stride >= 0);
991
+ assert(vertex_lock == null || vertex_lock instanceof Uint8Array);
992
+ assert(vertex_lock == null || vertex_lock.length == vertex_positions.length / vertex_positions_stride);
993
+ assert(target_index_count >= 0 && target_index_count <= indices.length);
994
+ assert(target_index_count % 3 == 0);
995
+ assert(target_error >= 0);
996
+ assert(Array.isArray(attribute_weights));
997
+ assert(vertex_attributes_stride >= attribute_weights.length);
998
+ assert(attribute_weights.length <= 32);
999
+ for (var i = 0; i < attribute_weights.length; ++i) {
1000
+ assert(attribute_weights[i] >= 0);
1001
+ }
1002
+ var options = 0;
1003
+ for (var i = 0; i < (flags ? flags.length : 0); ++i) {
1004
+ assert(flags[i] in simplifyOptions);
1005
+ options |= simplifyOptions[flags[i]];
1006
+ }
1007
+ var indices32 = indices.BYTES_PER_ELEMENT == 4 ? indices : new Uint32Array(indices);
1008
+ var result = simplifyAttr(
1009
+ instance.exports.meshopt_simplifyWithAttributes,
1010
+ indices32,
1011
+ indices.length,
1012
+ vertex_positions,
1013
+ vertex_positions.length / vertex_positions_stride,
1014
+ vertex_positions_stride * 4,
1015
+ vertex_attributes,
1016
+ vertex_attributes_stride * 4,
1017
+ new Float32Array(attribute_weights),
1018
+ vertex_lock,
1019
+ target_index_count,
1020
+ target_error,
1021
+ options
1022
+ );
1023
+ result[0] = indices instanceof Uint32Array ? result[0] : new indices.constructor(result[0]);
1024
+ return result;
1025
+ },
1026
+ simplifyWithUpdate: function(indices, vertex_positions, vertex_positions_stride, vertex_attributes, vertex_attributes_stride, attribute_weights, vertex_lock, target_index_count, target_error, flags) {
1027
+ assert(
1028
+ indices instanceof Uint32Array || indices instanceof Int32Array || indices instanceof Uint16Array || indices instanceof Int16Array
1029
+ );
1030
+ assert(indices.length % 3 == 0);
1031
+ assert(vertex_positions instanceof Float32Array);
1032
+ assert(vertex_positions.length % vertex_positions_stride == 0);
1033
+ assert(vertex_positions_stride >= 3);
1034
+ assert(vertex_attributes instanceof Float32Array);
1035
+ assert(vertex_attributes.length == vertex_attributes_stride * (vertex_positions.length / vertex_positions_stride));
1036
+ assert(vertex_attributes_stride >= 0);
1037
+ assert(vertex_lock == null || vertex_lock instanceof Uint8Array);
1038
+ assert(vertex_lock == null || vertex_lock.length == vertex_positions.length / vertex_positions_stride);
1039
+ assert(target_index_count >= 0 && target_index_count <= indices.length);
1040
+ assert(target_index_count % 3 == 0);
1041
+ assert(target_error >= 0);
1042
+ assert(Array.isArray(attribute_weights));
1043
+ assert(vertex_attributes_stride >= attribute_weights.length);
1044
+ assert(attribute_weights.length <= 32);
1045
+ for (var i = 0; i < attribute_weights.length; ++i) {
1046
+ assert(attribute_weights[i] >= 0);
1047
+ }
1048
+ var options = 0;
1049
+ for (var i = 0; i < (flags ? flags.length : 0); ++i) {
1050
+ assert(flags[i] in simplifyOptions);
1051
+ options |= simplifyOptions[flags[i]];
1052
+ }
1053
+ var indices32 = indices.BYTES_PER_ELEMENT == 4 ? indices : new Uint32Array(indices);
1054
+ var result = simplifyUpdate(
1055
+ instance.exports.meshopt_simplifyWithUpdate,
1056
+ indices32,
1057
+ indices.length,
1058
+ vertex_positions,
1059
+ vertex_positions.length / vertex_positions_stride,
1060
+ vertex_positions_stride * 4,
1061
+ vertex_attributes,
1062
+ vertex_attributes_stride * 4,
1063
+ new Float32Array(attribute_weights),
1064
+ vertex_lock,
1065
+ target_index_count,
1066
+ target_error,
1067
+ options
1068
+ );
1069
+ if (indices !== indices32) {
1070
+ for (var i = 0; i < result[0]; ++i) {
1071
+ indices[i] = indices32[i];
1072
+ }
1073
+ }
1074
+ return result;
1075
+ },
1076
+ getScale: function(vertex_positions, vertex_positions_stride) {
1077
+ assert(vertex_positions instanceof Float32Array);
1078
+ assert(vertex_positions.length % vertex_positions_stride == 0);
1079
+ assert(vertex_positions_stride >= 3);
1080
+ return simplifyScale(
1081
+ instance.exports.meshopt_simplifyScale,
1082
+ vertex_positions,
1083
+ vertex_positions.length / vertex_positions_stride,
1084
+ vertex_positions_stride * 4
1085
+ );
1086
+ },
1087
+ simplifyPoints: function(vertex_positions, vertex_positions_stride, target_vertex_count, vertex_colors, vertex_colors_stride, color_weight) {
1088
+ assert(vertex_positions instanceof Float32Array);
1089
+ assert(vertex_positions.length % vertex_positions_stride == 0);
1090
+ assert(vertex_positions_stride >= 3);
1091
+ assert(target_vertex_count >= 0 && target_vertex_count <= vertex_positions.length / vertex_positions_stride);
1092
+ if (vertex_colors) {
1093
+ assert(vertex_colors instanceof Float32Array);
1094
+ assert(vertex_colors.length % vertex_colors_stride == 0);
1095
+ assert(vertex_colors_stride >= 3);
1096
+ assert(vertex_positions.length / vertex_positions_stride == vertex_colors.length / vertex_colors_stride);
1097
+ return simplifyPoints(
1098
+ instance.exports.meshopt_simplifyPoints,
1099
+ vertex_positions,
1100
+ vertex_positions.length / vertex_positions_stride,
1101
+ vertex_positions_stride * 4,
1102
+ vertex_colors,
1103
+ vertex_colors_stride * 4,
1104
+ color_weight || 0,
1105
+ target_vertex_count
1106
+ );
1107
+ } else {
1108
+ return simplifyPoints(
1109
+ instance.exports.meshopt_simplifyPoints,
1110
+ vertex_positions,
1111
+ vertex_positions.length / vertex_positions_stride,
1112
+ vertex_positions_stride * 4,
1113
+ void 0,
1114
+ 0,
1115
+ 0,
1116
+ target_vertex_count
1117
+ );
1118
+ }
1119
+ },
1120
+ simplifySloppy: function(indices, vertex_positions, vertex_positions_stride, vertex_lock, target_index_count, target_error) {
1121
+ assert(
1122
+ indices instanceof Uint32Array || indices instanceof Int32Array || indices instanceof Uint16Array || indices instanceof Int16Array
1123
+ );
1124
+ assert(indices.length % 3 == 0);
1125
+ assert(vertex_positions instanceof Float32Array);
1126
+ assert(vertex_positions.length % vertex_positions_stride == 0);
1127
+ assert(vertex_positions_stride >= 3);
1128
+ assert(vertex_lock == null || vertex_lock instanceof Uint8Array);
1129
+ assert(vertex_lock == null || vertex_lock.length == vertex_positions.length / vertex_positions_stride);
1130
+ assert(target_index_count >= 0 && target_index_count <= indices.length);
1131
+ assert(target_index_count % 3 == 0);
1132
+ assert(target_error >= 0);
1133
+ var indices32 = indices.BYTES_PER_ELEMENT == 4 ? indices : new Uint32Array(indices);
1134
+ var result = simplifySloppy(
1135
+ instance.exports.meshopt_simplifySloppy,
1136
+ indices32,
1137
+ indices.length,
1138
+ vertex_positions,
1139
+ vertex_positions.length / vertex_positions_stride,
1140
+ vertex_positions_stride * 4,
1141
+ vertex_lock,
1142
+ target_index_count,
1143
+ target_error
1144
+ );
1145
+ result[0] = indices instanceof Uint32Array ? result[0] : new indices.constructor(result[0]);
1146
+ return result;
1147
+ },
1148
+ simplifyPrune: function(indices, vertex_positions, vertex_positions_stride, target_error) {
1149
+ assert(
1150
+ indices instanceof Uint32Array || indices instanceof Int32Array || indices instanceof Uint16Array || indices instanceof Int16Array
1151
+ );
1152
+ assert(indices.length % 3 == 0);
1153
+ assert(vertex_positions instanceof Float32Array);
1154
+ assert(vertex_positions.length % vertex_positions_stride == 0);
1155
+ assert(vertex_positions_stride >= 3);
1156
+ assert(target_error >= 0);
1157
+ var indices32 = indices.BYTES_PER_ELEMENT == 4 ? indices : new Uint32Array(indices);
1158
+ var result = simplifyPrune(
1159
+ instance.exports.meshopt_simplifyPrune,
1160
+ indices32,
1161
+ indices.length,
1162
+ vertex_positions,
1163
+ vertex_positions.length / vertex_positions_stride,
1164
+ vertex_positions_stride * 4,
1165
+ target_error
1166
+ );
1167
+ result = indices instanceof Uint32Array ? result : new indices.constructor(result);
1168
+ return result;
1169
+ }
1170
+ };
1171
+ })();
1172
+
1173
+ // packages/engine/node_modules/meshoptimizer/meshopt_clusterizer.js
1174
+ var MeshoptClusterizer = (function() {
1175
+ var wasm = "b9H79Tebbbe:neP9Geueu9Geub9Gbb9Giuuueu9Gmuuuuuuuuuuu9999eu9Gouuuuuueu9Gruuuuuuub9Gxuuuuuuuuuuuueu9Gxuuuuuuuuuuu99eu9GPuuuuuuuuuuuuu99b9Gouuuuuub9Gwuuuuuuuub9Gvuuuuub9GluuuubiQXdilvorwDqokoqxmbiibeilve9Weiiviebeoweuecj:Gdkr;Zeqo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bb8A9TW79O9V9Wt9F9I919P29K9nW79O2Wt79c9V919U9KbeY9TW79O9V9Wt9F9I919P29K9nW79O2Wt7S2W94bd39TW79O9V9Wt9F9I919P29K9nW79O2Wt79t9W9Ht9P9H2bo39TW79O9V9Wt9F9J9V9T9W91tWJ2917tWV9c9V919U9K7bw39TW79O9V9Wt9F9J9V9T9W91tW9nW79O2Wt9c9V919U9K7bkE9TW79O9V9Wt9F9J9V9T9W91tW9t9W9OWVW9c9V919U9K7bxL9TW79O9V9Wt9F9V9Wt9P9T9P96W9nW79O2WtbPl79IV9RbsDwebcekdOAq;W:leXdbkIbabaec9:fgefcufae9Ugeabci9Uadfcufad9Ugbaeab0Ek:88JDPue99eux99due99euo99iu8Jjjjjbc:WD9Rgm8KjjjjbdndnalmbcbhPxekamc:Cwfcbc;Kbz:rjjjb8AcuaocdtgsaocFFFFi0Ehzcbyd;0:G:cjbhHdndnalcb9imbaoal9nmbamazaHHjjjjbbgHBd:CwamceBd;8wamazcbyd;0:G:cjbHjjjjbbgOBd:GwamcdBd;8wamcualcdtalcFFFFi0Ecbyd;0:G:cjbHjjjjbbgABd:KwamciBd;8waihzalhsinaHazydbcdtfcbBdbazclfhzascufgsmbkaihzalhsinaHazydbcdtfgCaCydbcefBdbazclfhzascufgsmbkaihzalhCcbhXindnaHazydbcdtgQfgsydbcb9imbaOaQfaXBdbasasydbgQcjjjj94VBdbaQaXfhXkazclfhzaCcufgCmbkalci9UhLdnalci6mbcbhzaihsinascwfydbhCasclfydbhXaOasydbcdtfgQaQydbgQcefBdbaAaQcdtfazBdbaOaXcdtfgXaXydbgXcefBdbaAaXcdtfazBdbaOaCcdtfgCaCydbgCcefBdbaAaCcdtfazBdbascxfhsaLazcefgz9hmbkkaihzalhsindnaHazydbcdtgCfgXydbgQcu9kmbaXaQcFFFFrGgQBdbaOaCfgCaCydbaQ9RBdbkazclfhzascufgsmbxdkkamazaHHjjjjbbgHBd:CwamceBd;8wamazcbyd;0:G:cjbHjjjjbbgOBd:GwamcdBd;8wamcualcdtalcFFFFi0Ecbyd;0:G:cjbHjjjjbbgABd:KwamciBd;8waHcbasz:rjjjbhXaihzalhsinaXazydbcdtfgCaCydbcefBdbazclfhzascufgsmbkalci9UhLdnaoTmbcbhzaOhsaXhCaohQinasazBdbasclfhsaCydbazfhzaCclfhCaQcufgQmbkkdnalci6mbcbhzaihsinascwfydbhCasclfydbhQaOasydbcdtfgKaKydbgKcefBdbaAaKcdtfazBdbaOaQcdtfgQaQydbgQcefBdbaAaQcdtfazBdbaOaCcdtfgCaCydbgCcefBdbaAaCcdtfazBdbascxfhsaLazcefgz9hmbkkaoTmbcbhzaohsinaOazfgCaCydbaXazfydb9RBdbazclfhzascufgsmbkkamaLcbyd;0:G:cjbHjjjjbbgzBd:OwamclBd;8wazcbaLz:rjjjbhYamcuaLcK2alcjjjjd0Ecbyd;0:G:cjbHjjjjbbg8ABd:SwamcvBd;8wJbbbbhEdnalci6g3mbarcd4hKaihsa8AhzaLhrJbbbbh5inavasclfydbaK2cdtfgCIdlh8EavasydbaK2cdtfgXIdlhEavascwfydbaK2cdtfgQIdlh8FaCIdwhaaXIdwhhaQIdwhgazaCIdbg8JaXIdbg8KMaQIdbg8LMJbbnn:vUdbazclfaXIdlaCIdlMaQIdlMJbbnn:vUdbaQIdwh8MaCIdwh8NaXIdwhyazcxfa8EaE:tg8Eagah:tggNaaah:tgaa8FaE:tghN:tgEJbbbbJbbjZa8Ja8K:tg8FahNa8Ea8La8K:tg8KN:tghahNaEaENaaa8KNa8FagN:tgEaENMMg8K:rg8E:va8KJbbbb9BEg8KNUdbazczfaEa8KNUdbazcCfaha8KNUdbazcwfa8Maya8NMMJbbnn:vUdba5a8EMh5ascxfhsazcKfhzarcufgrmbka5aL:Z:vJbbbZNhEkamcuaLcdtalcFFFF970Ecbyd;0:G:cjbHjjjjbbgCBd:WwamcoBd;8waq:Zhhdna3mbcbhzaChsinasazBdbasclfhsaLazcefgz9hmbkkaEahNhhamcuaLcltalcFFFFd0Ecbyd;0:G:cjbHjjjjbbg8PBd:0wamcrBd;8wcba8Pa8AaCaLcbz:djjjb8AJFFuuh8MJFFuuh8NJFFuuhydnalci6mbJFFuuhya8AhzaLhsJFFuuh8NJFFuuh8MinazcwfIdbgEa8Ma8MaE9EEh8MazclfIdbgEa8Na8NaE9EEh8NazIdbgEayayaE9EEhyazcKfhzascufgsmbkkah:rhEamaocetgzcuaocu9kEcbyd;0:G:cjbHjjjjbbgCBd:4wdndnaoal9nmbaihzalhsinaCazydbcetfcFFi87ebazclfhzascufgsmbxdkkaCcFeazz:rjjjb8AkaEJbbbZNh8JcuhIdnalci6mbcbhsJFFuuhEa8AhzcuhIinazcwfIdba8M:tghahNazIdbay:tghahNazclfIdba8N:tghahNMM:rghaEaIcuSahaE9DVgXEhEasaIaXEhIazcKfhzaLascefgs9hmbkkamczfcbcjwz:rjjjb8Aam9cb83iwam9cb83ibaxa8JNh8RJbbjZak:th8Lcbh8SJbbbbhRJbbbbh8UJbbbbh8VJbbbbh8WJbbbbh8XJbbbbh8Ycbh8ZcbhPinJbbbbhEdna8STmbJbbjZa8S:Z:vhEkJbbbbhhdna8Ya8YNa8Wa8WNa8Xa8XNMMg8KJbbbb9BmbJbbjZa8K:r:vhhka8VaENh8Ka8UaENh5aRaENh8EaIhLdndndndndna8SaPVTmbamydwg80Tmea8YahNh8Fa8XahNhaa8WahNhgaeamydbcdtfh81cbh3JFFuuhEcvhQcuhLindnaHa81a3cdtfydbcdtgzfydbgvTmbaAaOazfydbcdtfhsindndnaCaiasydbgKcx2fgzclfydbgrcetf8Vebcs4aCazydbgXcetf8Vebcs4faCazcwfydbglcetf8Vebcs4fgombcbhzxekcehzaHaXcdtfydbgXceSmbcehzaHarcdtfydbgrceSmbcehzaHalcdtfydbglceSmbdnarcdSaXcdSfalcdSfcd6mbaocefhzxekaocdfhzkdnazaQ9kmba8AaKcK2fgXIdwa8K:tghahNaXIdba8E:tghahNaXIdla5:tghahNMM:ra8J:va8LNJbbjZMJ9VO:d86JbbjZaXIdCa8FNaXIdxagNaaaXIdzNMMakN:tghahJ9VO:d869DENghaEazaQ6ahaE9DVgXEhEaKaLaXEhLazaQaXEhQkasclfhsavcufgvmbkka3cefg3a809hmbkkaLcu9hmekama8KUd:ODama5Ud:KDama8EUd:GDamcuBd:qDamcFFF;7rBdjDa8Pcba8AaYamc:GDfamc:qDfamcjDfz:ejjjbamyd:qDhLdndnaxJbbbb9ETmba8SaD6mbaLcuSmeceh3amIdjDa8R9EmixdkaLcu9hmekdna8STmbabaPcltfgHam8Piw83dwaHam8Pib83dbaPcefhPkc3hHinamc:CwfaHfydbcbyd;4:G:cjbH:bjjjbbaHc98fgHc989hmbxvkkcbh3a8Saq9pmbamydwaCaiaLcx2fgzydbcetf8Vebcs4aCazcwfydbcetf8Vebcs4faCazclfydbcetf8Vebcs4ffaw9nmekcbhzcbhsdna8ZTmbcbhsamczfhXinamczfascdtfaXydbgQBdbaXclfhXasaYaQfRbbTfhsa8Zcufg8ZmbkkamydwhlamydbhXam9cu83i:GDam9cu83i:ODam9cu83i:qDam9cu83i:yDinamcjDfazfcFFF;7rBdbazclfgzcz9hmbkasc;8easclfc:bd6Eg8Zcdth80dnalTmbaeaXcdtfhocbhrindnaHaoarcdtfydbcdtgzfydbgvTmbaAaOazfydbcdtfhscuhQcuhzinaHaiasydbgKcx2fgXclfydbcdtfydbaHaXydbcdtfydbfaHaXcwfydbcdtfydbfgXazaXaz6gXEhzaKaQaXEhQasclfhsavcufgvmbkaQcuSmba8AaQcK2fgsIdwa8M:tgEaENasIdbay:tgEaENasIdla8N:tgEaENMM:rhEcbhsindndnazamc:qDfasfgvydbgX6mbazaX9hmeaEamcjDfasfIdb9FTmekavazBdbamc:GDfasfaQBdbamcjDfasfaEUdbxdkasclfgscz9hmbkkarcefgral9hmbkkamczfa80fhQcbhzcbhsindnamc:GDfazfydbgXcuSmbaQascdtfaXBdbascefhskazclfgzcz9hmbkasa8Zfg8ZTmbJFFuuhhcuhKamczfhza8ZhvcuhQina8AazydbgXcK2fgsIdwa8M:tgEaENasIdbay:tgEaENasIdla8N:tgEaENMM:rhEdndnaHaiaXcx2fgsclfydbcdtfydbaHasydbcdtfydbfaHascwfydbcdtfydbfgsaQ6mbasaQ9hmeaEah9DTmekaEhhashQaXhKkazclfhzavcufgvmbkaKcuSmbaKhLkdnamaiaLcx2fgrydbarclfydbarcwfydbaCabaeadaPawaqa3z:fjjjbTmbaPcefhPJbbbbhRJbbbbh8UJbbbbh8VJbbbbh8WJbbbbh8XJbbbbh8YkcbhXinaAaOaraXcdtfydbcdtgsfydbcdtfgKhzaHasfgvydbgQhsdnaQTmbdninazydbaLSmeazclfhzascufgsTmdxbkkazaKaQcdtfc98fydbBdbavavydbcufBdbkaXcefgXci9hmbka8AaLcK2fgzIdbhEazIdlhhazIdwh8KazIdxh5azIdzh8EazIdCh8FaYaLfce86bba8Ya8FMh8Ya8Xa8EMh8Xa8Wa5Mh8Wa8Va8KMh8Va8UahMh8UaRaEMhRamydxh8Sxbkkamc:WDf8KjjjjbaPkjoivuv99lu8Jjjjjbca9Rgo8Kjjjjbdndnalcw0mbaiydbhraeabcitfgwalcdtciVBdlawarBdbdnalcd6mbaiclfhralcufhDawcxfhwinarydbhqawcuBdbawc98faqBdbawcwfhwarclfhraDcufgDmbkkalabfhwxekcbhqaocbBdKao9cb83izaocbBdwao9cb83ibJbbjZhkJbbjZhxinadaiaqcdtfydbcK2fhDcbhwinaoczfawfgraDawfIdbgmarIdbgP:tgsaxNaPMgPUdbaoawfgrasamaP:tNarIdbMUdbawclfgwcx9hmbkJbbjZakJbbjZMgk:vhxaqcefgqal9hmbkcbhradcbcecdaoIdlgmaoIdwgP9GEgwaoIdbgsaP9GEawasam9GEgzcdtgwfhHaoczfawfIdbhmaihwalhDinaiarcdtfgqydbhOaqawydbgABdbawaOBdbawclfhwaraHaAcK2fIdbam9DfhraDcufgDmbkdndnarcv6mbavc8X9kmbaralc98f6mekaiydbhraeabcitfgwalcdtciVBdlawarBdbaiclfhralcufhDawcxfhwinarydbhqawcuBdbawc98faqBdbawcwfhwarclfhraDcufgDmbkalabfhwxekaeabcitfgwamUdbawawydlc98GazVBdlabcefaeadaiaravcefgqz:djjjbhDawawydlciGaDabcu7fcdtVBdlaDaeadaiarcdtfalar9Raqz:djjjbhwkaocaf8Kjjjjbawk;Oddvue99dninabaecitfgrydlgwcd4gDTmednawciGgqci9hmbcihqdnawcl6mbabaecitfhbcbheawhqcehkindnaiabydbgDfRbbmbcbhkadaDcK2fgwIdwalIdw:tgxaxNawIdbalIdb:tgxaxNawIdlalIdl:tgxaxNMM:rgxaoIdb9DTmbaoaxUdbavaDBdbarydlhqkabcwfhbaecefgeaqcd46mbkakceGTmikaraqciGBdlskdnabcbaDalaqcdtfIdbarIdb:tgxJbbbb9FEgwaD7aecefgDfgecitfydlabawaDfgDcitfydlVci0mbaraqBdlkabaDadaialavaoz:ejjjbax:laoIdb9Fmbkkkjlevudndnabydwgxaladcetfgm8Vebcs4alaecetfgP8Vebgscs4falaicetfgz8Vebcs4ffaD0mbakmbcbhDabydxaq6mekavawcltfgxab8Pdw83dwaxab8Pdb83dbabydbhDdnabydwgwTmbaoaDcdtfhxawhsinalaxydbcetfcFFi87ebaxclfhxascufgsmbkkabaDawfBdbabydxhxab9cb83dwababydlaxci2fBdlaP8VebhscehDcbhxkdnascztcz91cu9kmbabaxcefBdwaPax87ebaoabydbcdtfaxcdtfaeBdbkdnam8Uebcu9kmbababydwgxcefBdwamax87ebaoabydbcdtfaxcdtfadBdbkdnaz8Uebcu9kmbababydwgxcefBdwazax87ebaoabydbcdtfaxcdtfaiBdbkarabydlfabydxci2faPRbb86bbarabydlfabydxci2fcefamRbb86bbarabydlfabydxci2fcdfazRbb86bbababydxcefBdxaDk:mPrHue99eue99eue99iu8Jjjjjbc;W;Gb9Rgx8KjjjjbdndnalmbcbhmxekcbhPaxc:m;Gbfcbc;Kbz:rjjjb8Aaxcualci9UgscltascjjjjiGEcbyd;0:G:cjbHjjjjbbgzBd:m9GaxceBd;S9GaxcuascK2gHcKfalcpFFFe0Ecbyd;0:G:cjbHjjjjbbgOBd:q9GaxcdBd;S9Gdnalci6gAmbarcd4hCascdthXaOhQazhLinavaiaPcx2fgrydwaC2cdtfhKavarydlaC2cdtfhYavarydbaC2cdtfh8AcbhraLhEinaQarfgma8Aarfg3Idbg5aYarfg8EIdbg8Fa5a8F9DEg5UdbamaKarfgaIdbg8Fa5a8Fa59DEg8FUdbamcxfgma3Idbg5a8EIdbgha5ah9EEg5UdbamaaIdbgha5aha59EEg5UdbaEa8Fa5MJbbbZNUdbaEaXfhEarclfgrcx9hmbkaQcKfhQaLclfhLaPcefgPas9hmbkkaOaHfgr9cb83dbar9cb83dzar9cb83dwaxcuascx2gralc:bjjjl0Ecbyd;0:G:cjbHjjjjbbgHBdN9GaxciBd;S9GascdthgazarfhvaxcwVhPaxclVhCaHh8Jazh8KcbhLinaxcbcj;Gbz:rjjjbhEaLas2cdthadnaAmba8Khrash3inaEarydbgmc8F91cjjjj94Vam7gmcQ4cx2fg8Ea8EydwcefBdwaEamcd4cFrGcx2fg8Ea8EydbcefBdbaEamcx4cFrGcx2fgmamydlcefBdlarclfhra3cufg3mbkkazaafh8AaHaafhXcbhmcbh3cbh8EcbhainaEamfgrydbhQara3BdbarcwfgKydbhYaKaaBdbarclfgrydbhKara8EBdbaQa3fh3aYaafhaaKa8Efh8Eamcxfgmcj;Gb9hmbkdnaAmbcbhravhminamarBdbamclfhmasarcefgr9hmbkavhrashminaEa8Aarydbg3cdtfydbg8Ec8F91a8E7cd4cFrGcx2fg8Ea8Eydbg8EcefBdbaXa8Ecdtfa3Bdbarclfhramcufgmmbka8JhrashminaCa8Aarydbg3cdtfydbg8Ec8F91a8E7cx4cFrGcx2fg8Ea8Eydbg8EcefBdbava8Ecdtfa3BdbarclfhramcufgmmbkavhrashminaPa8Aarydbg3cdtfydbg8Ec8F91cjjjj94Va8E7cQ4cx2fg8Ea8Eydbg8EcefBdbaXa8Ecdtfa3Bdbarclfhramcufgmmbkka8Jagfh8Ja8Kagfh8KaLcefgLci9hmbkaEaocetgrcuaocu9kEcbyd;0:G:cjbHjjjjbbgKBd:y9GaEclBd;S9Gdndnaoal9nmbaihralhminaKarydbcetfcFFi87ebarclfhramcufgmmbxdkkaKcFearz:rjjjb8Akcbh8EaEascbyd;0:G:cjbHjjjjbbg8ABd:C9GaOaHaHascdtfaHascitfa8AascbazaKaiawaDaqakz:hjjjbdndnalci6mba8Ahrashmina8EarRbbfh8EarcefhramcufgmmbkaE9cb83iwaE9cb83ibalawc9:fgrfcufar9UgrasaDfcufaD9Ugmaram0EhYcbhmcbhra8Ehaincbh3dnarTmba8AarfRbbceSh3kamaEaiaHydbcx2fgQydbaQclfydbaQcwfydbaKabaeadamawaqa3a3ce7a8EaY9nVaaamfaY6VGz:fjjjbfhmaHclfhHaaa8AarfRbb9Rhaasarcefgr9hmbkaEydxTmeabamcltfgraE8Piw83dwaraE8Pib83dbamcefhmxekaE9cb83iwaE9cb83ibcbhmkczhrinaEc:m;Gbfarfydbcbyd;4:G:cjbH:bjjjbbarc98fgrc989hmbkkaxc;W;Gbf8Kjjjjbamk:wKDQue99iue99iul9:euw99iu8Jjjjjbc;qb9RgP8Kjjjjbaxhsaxhzdndnavax0gHmbdnavTmbcbhOaehzavhAinawaDazydbcx2fgCcwfydbcetfgX8VebhQawaCclfydbcetfgL8VebhKawaCydbcetfgC8VebhYaXce87ebaLce87ebaCce87ebaOaKcs4aYcs4faQcs4ffhOazclfhzaAcufgAmbkaehzavhAinawaDazydbcx2fgCcwfydbcetfcFFi87ebawaCclfydbcetfcFFi87ebawaCydbcetfcFFi87ebazclfhzaAcufgAmbkcehzaqhsaOaq0mekalce86bbalcefcbavcufz:rjjjb8AxekaPaiBdxaPadBdwaPaeBdlavakaqci9Ug8Aaka8Aak6EaHEgK9RhEaxaK9Rh3aKcufh5aKceth8EaKcdtgCc98fh8FavcitgOaC9Rarfc98fhaascufhhavcufhgaraOfh8JJbbjZas:Y:vh8KcbazceakaxSEg8Lcdtg8M9Rh8NJFFuuhycuh8PcbhIcbh8RinaPclfa8RcdtfydbhQaPcb8Pd:y:G:cjbg8S83i9iaPcb8Pd:q:G:cjbgR83inaPcb8Pd1:G:cjbg8U83iUaPcb8Pdj:G:cjbg8V83i8WaPa8S83iyaPaR83iaaPa8U83iKaPa8V83izaQavcdtgYfh8WcbhXinabaQaXcdtgLfydbcK2fhAcbhzinaPc8WfazfgCaAazfgOIdbg8XaCIdbg8Ya8Xa8Y9DEUdbaCczfgCaOcxfIdbg8XaCIdbg8Ya8Xa8Y9EEUdbazclfgzcx9hmbkaba8WaXcu7cdtfydbcK2fhAcbhzaPIdUh8ZaPId9ih80aPId80h81aPId9ehBaPId8Wh83aPIdnhUinaPczfazfgCaAazfgOIdbg8XaCIdbg8Ya8Xa8Y9DEUdbaCczfgCaOcxfIdbg8XaCIdbg8Ya8Xa8Y9EEUdbazclfgzcx9hmbkaraLfgza80a8Z:tg8XaUa83:tg8YNa8YaBa81:tg8ZNa8Za8XNMMUdbazaYfaPIdyaPIdK:tg8XaPIdaaPIdz:tg8YNa8YaPId8KaPIdC:tg8ZNa8Za8XNMMUdbaXcefgXav9hmbkcbh85dnaHmbcbhAaQhza8JhCavhXinawaDazydbcx2fgOcwfydbcetfgL8Vebh8WawaOclfydbcetfg858Vebh86awaOydbcetfgO8Vebh87aLce87eba85ce87ebaOce87ebaCaAa86cs4a87cs4fa8Wcs4ffgABdbazclfhzaCclfhCaXcufgXmbkavhCinawaDaQydbcx2fgzcwfydbcetfcFFi87ebawazclfydbcetfcFFi87ebawazydbcetfcFFi87ebaQclfhQaCcufgCmbka8Jh85kdndndndndndndndndndndnava8E6mba8Eax9nmeavavaK9UgzaK29Raza320mda5aE9pmqa85Th87ceh8WaEhQxwka5ag9pmDa8Eax9nmixokavaK6mea5aE9pmwcehQaEhXa85Tmixlka5ag6mlxrka5ag9pmokcbhQaghXa85mekJFFuuh8XcbhLa5hzindnazcefgCaK6mbaQavaC9RgOaK6GmbarazcdtfIdbg8YaC:YNaravaz9RcdtfaYfc94fIdbg8ZaO:YNMg80a8X9Embdndna8KaOahf:YNg81:lJbbb9p9DTmba81:OhAxekcjjjj94hAka8ZasaA2aO9R:YNh8Zdndna8Kazasf:YNg81:lJbbb9p9DTmba81:OhOxekcjjjj94hOkamasaO2aC9R:Ya8YNa8ZMNa80Mg8Ya8Xa8Ya8X9DgOEh8XaCaLaOEhLkaza8LfgzaX6mbxlkkJFFuuh8XcbhLaEhCaahAa8FhOaKhzindnazaK6mbaQaCaK6GmbaraOfIdbg8Yaz:YNaAIdbg8ZaC:YNMg80a8X9Embdndna8Ka85aOfydbgYahf:YNg81:lJbbb9p9DTmba81:Oh8Wxekcjjjj94h8Wkamasa8W2aY9R:Yg81a8YNa8Za81NMNa80Mg8Ya8Xa8Ya8X9DgYEh8XazaLaYEhLkaCa8L9RhCaAa8NfhAaOa8MfhOaza8LfgzcufaX6mbxikka85Th87cbh8WaghQkJFFuuh8XcbhLaEhCaahAa8FhOaKhzindnazazaK9UgXaK29RaXa320mbdna8WTmbaCaCaK9UgXaK29RaXa320mekaraOfIdbg8Yaz:YNaAIdbg8ZaC:YNMg80a8X9EmbazhXaChYdna87mba85aOfydbgXhYkdndna8KaYahf:YNg81:lJbbb9p9DTmba81:Oh86xekcjjjj94h86ka8Zasa862aY9R:YNh8Zdndna8KaXahf:YNg81:lJbbb9p9DTmba81:OhYxekcjjjj94hYkamasaY2aX9R:Ya8YNa8ZMNa80Mg8Ya8Xa8Ya8X9DgXEh8XazaLaXEhLkaCa8L9RhCaAa8NfhAaOa8MfhOaza8LfgzcufaQ6mbkkaLTmba8Xay9DTmba8XhyaLhIa8Rh8Pka8Rcefg8Rci9hmbkdndnaoc8X9kmba8Pcb9omeka8Acufh85cbhYindndndnavaY9RaxaYaxfav0Eg8WTmbcbhAaeaYcdtfgzhCa8WhXinawaDaCydbcx2fgOcwfydbcetfgQ8VebhbawaOclfydbcetfgL8VebhrawaOydbcetfgO8VebhKaQce87ebaLce87ebaOce87ebaAarcs4aKcs4fabcs4ffhAaCclfhCaXcufgXmbka8WhOinawaDazydbcx2fgCcwfydbcetfcFFi87ebawaCclfydbcetfcFFi87ebawaCydbcetfcFFi87ebazclfhzaOcufgOmbkaAaq0mekalaYfgzce86bbazcefcba8Wcufz:rjjjb8AxekalaYfgzce86bbazcefcba85z:rjjjb8Aa8Ah8Wka8WaYfgYav9pmdxbkkaravcdtg8WfhLdnaITmbaPclfa8PcdtfydbhzaIhCinaLazydbfcb86bbazclfhzaCcufgCmbkkdnavaI9nmbaPclfa8PcdtfydbaIcdtfhzavaI9RhCinaLazydbfce86bbazclfhzaCcufgCmbkkcbhYindnaYa8PSmbcbhzaraPclfaYcdtfydbgKa8Wz:qjjjbhCavhXaIhOinaKaOazaLaCydbgQfRbbgAEcdtfaQBdbaCclfhCaOaAfhOazaA9RcefhzaXcufgXmbkkaYcefgYci9hmbkabaeadaialaIaocefgCarawaDaqakaxamz:hjjjbabaeaIcdtgzfadazfaiazfalaIfavaI9RaCarawaDaqakaxamz:hjjjbkaPc;qbf8Kjjjjbk:Seeru8Jjjjjbc:q;ab9Rgo8Kjjjjbaoc:q8WfcFecjzz:rjjjb8AcbhrdnadTmbaehwadhDinaoarcdtfawydbgqBdbaoc:q8WfaqcFiGcdtfgkydbhxakaqBdbawclfhwaraxaq9hfhraDcufgDmbkkabaeadaoaraiavz:jjjjbaoc:q;abf8Kjjjjbk;Sqloud99euD998Jjjjjbc:W;ab9Rgr8KjjjjbdndnadTmbaocd4hwcbhDcbhqindnavaeclfydbaw2cdtfgkIdbavaeydbaw2cdtfgxIdbgm:tgPavaecwfydbaw2cdtfgsIdlaxIdlgz:tgHNakIdlaz:tgOasIdbam:tgAN:tgCaCNaOasIdwaxIdwgX:tgQNakIdwaX:tgOaHN:tgHaHNaOaANaPaQN:tgPaPNMMgOJbbbb9Bmbarc8WfaDcltfgkaCaO:rgO:vgCUdwakaPaO:vgPUdlakaHaO:vgHUdbakaCaXNaHamNazaPNMM:mUdxaDcefhDkaecxfheaqcifgqad6mbkab9cb83dyab9cb83daab9cb83dKab9cb83dzab9cb83dwab9cb83dbaDTmearcbBd8Sar9cb83iKar9cb83izarczfavalaoarc8Sfcbcraiz:kjjjbarIdKhQarIdChLarIdzhKar9cb83iwar9cb83ibararc8WfaDczarc8Sfcbcicbz:kjjjbJbbbbhmdnarIdwgzazNarIdbgHaHNarIdlgXaXNMMgCJbbbb9BmbJbbjZaC:r:vhmkazamNhCaXamNhXaHamNhHJbbjZhmarc8WfheaDhvinaecwfIdbaCNaeIdbaHNaXaeclfIdbNMMgzamazam9DEhmaeczfheavcufgvmbkabaQUdwabaLUdlabaKUdbabarId3UdxdndnamJ;n;m;m899FmbJbbbbhzarc8WfheinaecxfIdbaQaecwfIdbgPNaKaeIdbgONaLaeclfIdbgANMMMaCaPNaHaONaXaANMM:vgPazaPaz9EEhzaeczfheaDcufgDmbkabaCUd8KabaXUdaabaHUd3abaQaCazN:tUdKabaLaXazN:tUdCabaKaHazN:tUdzabJbbjZamamN:t:rgmUdydndnaCJbbj:;aCJbbj:;9GEgzJbbjZazJbbjZ9FEJbb;:9cNJbbbZJbbb:;aCJbbbb9GEMgz:lJbbb9p9DTmbaz:Ohexekcjjjj94hekabae86b8UdndnaXJbbj:;aXJbbj:;9GEgzJbbjZazJbbjZ9FEJbb;:9cNJbbbZJbbb:;aXJbbbb9GEMgz:lJbbb9p9DTmbaz:Ohvxekcjjjj94hvkabav86bRdndnaHJbbj:;aHJbbj:;9GEgzJbbjZazJbbjZ9FEJbb;:9cNJbbbZJbbb:;aHJbbbb9GEMgz:lJbbb9p9DTmbaz:Ohwxekcjjjj94hwkabaw86b8SdndnaecKtcK91:YJbb;:9c:vaC:t:lavcKtcK91:YJbb;:9c:vaX:t:lawcKtcK91:YJbb;:9c:vaH:t:lamMMMJbb;:9cNJbbjZMgm:lJbbb9p9DTmbam:Ohexekcjjjj94hekaecFbaecFb9iEhexekabcjjj;8iBdycFbhekabae86b8Vxekab9cb83dyab9cb83daab9cb83dKab9cb83dzab9cb83dwab9cb83dbkarc:W;abf8Kjjjjbk;7woDuo99eue99euv998Jjjjjbcje9Rgw8Kjjjjbawc;abfcbaocdtgDz:rjjjb8Aawc;GbfcbaDz:rjjjb8AawcafhDawhqaohkinaqcFFF97BdbaDcFFF;7rBdbaqclfhqaDclfhDakcufgkmbkavcd4hxaicd4hmdnadTmbaocx2hPcbhsinashzdnarTmbarascdtfydbhzkaeazam2cdtfgDIdwhHaDIdlhOaDIdbhAalazax2cdtfIdbhCcbhDawcafhqawc;Gbfhvawhkawc;abfhiinaCaDc:O:G:cjbfIdbaHNaDc:G:G:cjbfIdbaANaDc:K:G:cjbfIdbaONMMgXMhQazhLdnaXaC:tgXaqIdbgK9DgYmbavydbhLkavaLBdbazhLdnaQakIdbg8A9EmbaiydbhLa8AhQkaiaLBdbakaQUdbaqaXaKaYEUdbaiclfhiakclfhkavclfhvaqclfhqaPaDcxfgD9hmbkascefgsad9hmbkkJbbbbhQcbhLawc;GbfhDawc;abfhqcbhkinalaqydbgvax2cdtfIdbalaDydbgiax2cdtfIdbaeavam2cdtfgvIdwaeaiam2cdtfgiIdw:tgCaCNavIdbaiIdb:tgCaCNavIdlaiIdl:tgCaCNMM:rMMgCaQaCaQ9EgvEhQakaLavEhLaqclfhqaDclfhDaoakcefgk9hmbkJbbbbhCdnaeawc;abfaLcdtgqfydbgkam2cdtfgDIdwaeawc;Gbfaqfydbgvam2cdtfgqIdwgH:tgXaXNaDIdbaqIdbgA:tg8Aa8ANaDIdlaqIdlgE:tgOaONMMgKJbbbb9ETmbaK:rgCalakax2cdtfIdbMalavax2cdtfIdb:taCaCM:vhCkaQJbbbZNhKaXaCNaHMhHaOaCNaEMhOa8AaCNaAMhAdnadTmbcbhqarhkinaqhDdnarTmbakydbhDkdnalaDax2cdtfIdbg3aeaDam2cdtfgDIdwaH:tgQaQNaDIdbaA:tgCaCNaDIdlaO:tgXaXNMMg5:rgEMg8EaK9ETmbJbbbbh8Adna5Jbbbb9ETmba8EaK:taEaEM:vh8Aka8AaQNaHMhHa8AaXNaOMhOa8AaCNaAMhAa3aKaEMMJbbbZNhKkakclfhkadaqcefgq9hmbkkabaKUdxabaHUdwabaOUdlabaAUdbawcjef8Kjjjjbk:reevu8Jjjjjbcj8W9Rgr8Kjjjjbaici2hwcbhDdnaiTmbarhiawhqinaiaeadRbbgkcdtfydbBdbaDakcefgkaDak0EhDaiclfhiadcefhdaqcufgqmbkkabarawaeaDalaoz:jjjjbarcj8Wf8Kjjjjbk:Eeeeu8Jjjjjbca9Rgo8Kjjjjbab9cb83dyab9cb83daab9cb83dKab9cb83dzab9cb83dwab9cb83dbdnadTmbaocbBd3ao9cb83iwao9cb83ibaoaeadaialaoc3falEavcbalEcrcbz:kjjjbabao8Pib83dbabao8Piw83dwkaocaf8Kjjjjbk::meQu8Jjjjjbcjz9Rgv8KjjjjbcbhoavcjPfcbaez:rjjjb8Aavcjxfcbaez:rjjjb8AdnaiTmbadhoaihrinavcjxfaoRbbfgwawRbbcef86bbavcjxfaocefRbbfgwawRbbcef86bbavcjxfaocdfRbbfgwawRbbcef86bbaocifhoarcufgrmbkcbhDcjehoadhqcehkindndnalTmbcbhxcuhmaqhrakhwcuhPinawcufamaoavcjPfarcefRbbgsfRbb9RcFeGgzci6aoavcjPfarRbbgHfRbb9RcFeGgOci6faoavcjPfarcdfRbbgAfRbb9RcFeGgCci6fgXcOtaOcFr7azaCf9RcwtVavcjxfaAfRbbgzavcjxfaHfRbbgHavcjxfasfRbbgsaHas6Egsazas6EcFe7VgsaP9kgzEhmaXcd6gHaxcefgOal9iVce9hmdasaPazEhPaxaOaHEhxarcifhrawai6hsawcefhwasmbxdkkcuhmaqhrakhwcuhxinawcufamaoavcjPfarcefRbbfRbb9RcFeGci6aoavcjPfarRbbfRbb9RcFeGci6faoavcjPfarcdfRbbfRbb9RcFeGci6fgPax9kgsEhmaPce0meaPaxasEhxarcifhrawai6hPawcefhwaPmbkkadamci2fgrcdfRbbhwarcefRbbhxarRbbhPadaDci2fgrcifaramaD9Rci2zNjjjb8AaPavcjPffaocefgo86bbaPavcjxffgmamRbbcuf86bbaxavcjPffao86bbaxavcjxffgmamRbbcuf86bbarcdfaw86bbarcefax86bbaraP86bbawavcjPffao86bbawavcjxffgrarRbbcuf86bbaqcifhqakcefhkaDcefgDai9hmbkcbhzdnalcb9mmbcbhsavcjPfcbaez:rjjjb8Aadcvfhlinadasci2fgxcefgDRbbhoaxcdfgqRbbhrdndnavcjPfaxRbbgmfRbbmbavcjPfarfRbbhwdndndnavcjPfaofRbbTmbawcFeGTmexikawcFeGmdascefgAai9pmdasc980mdascifhQcbhLarcFeGhCamcFeGhXalhwcbhKcbhYinawcufRbbhPawRbbhOcehkdndnawc9:fRbbgHao9hmbaPcFeGamSmekdnaPcFeGao9hmbaOcFeGamSmekaHamSaOcFeGaoSGhkkceh8AaYceGhYdndnaHar9hmbaPcFeGaoSmekdnaPcFeGar9hmbaOcFeGaoSmekaHaoSaOcFeGarSGh8AkakaYVhYaLaHcFeGgHaXSaPcFeGgPaCSGaPaXSaOcFeGgPaCSGVaHaCSaPaXSGVVhLa8AaKceGVhKdnaAcefgPai9pmbawcifhwaAaQ6hHaPhAaHmekkaYTmeaKmekarhwaohPaohHarhOamhrxdkdnaYTaLVceGTmbaYaKTVaLVceGmekamhwarhParhHamhOaohrxekaohwamhPamhHaohOkavcjPfarfce86bbavcjPfawfce86bbaxaH86bbaqar86bbaDaO86bbavcjPfaPfce86bbalcifhlascefgsai9hmbkkavcFeaecetz:rjjjbhwaici2hrindnawadRbbgmcetfgx8Uebgocu9kmbaxaz87ebawcjlfazcdtfabamcdtfydbBdbazhoazcefhzkadao86bbadcefhdarcufgrmbkazcdthokabavcjlfaoz:qjjjb8Aavcjzf8KjjjjbkObabaiaeadcbz:njjjbk9teiucbcbyd;8:G:cjbgeabcifc98GfgbBd;8:G:cjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaik;LeeeudndnaeabVciGTmbabhixekdndnadcz9pmbabhixekabhiinaiaeydbBdbaiclfaeclfydbBdbaicwfaecwfydbBdbaicxfaecxfydbBdbaeczfheaiczfhiadc9Wfgdcs0mbkkadcl6mbinaiaeydbBdbaeclfheaiclfhiadc98fgdci0mbkkdnadTmbinaiaeRbb86bbaicefhiaecefheadcufgdmbkkabk;aeedudndnabciGTmbabhixekaecFeGc:b:c:ew2hldndnadcz9pmbabhixekabhiinaialBdbaicxfalBdbaicwfalBdbaiclfalBdbaiczfhiadc9Wfgdcs0mbkkadcl6mbinaialBdbaiclfhiadc98fgdci0mbkkdnadTmbinaiae86bbaicefhiadcufgdmbkkabk9teiucbcbyd;8:G:cjbgeabcrfc94GfgbBd;8:G:cjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaikTeeucbabcbyd;8:G:cjbge9Rcifc98GaefgbBd;8:G:cjbdnabZbcztge9nmbabae9RcFFifcz4nb8Akk:3qeludndnadch6mbadTmeabaead;8qbbabskabaeSmbdnaeadabfgi9Rcbadcet9R0mbadTmeabaead;8qbbabskaeab7ciGhldndndnabae9pmbdnalTmbadhvabhixikdnabciGmbadhvabhixdkadTmiabaeRbb86bbadcufhvdnabcefgiciGmbaecefhexdkavTmiabaeRbe86beadc9:fhvdnabcdfgiciGmbaecdfhexdkavTmiabaeRbd86bdadc99fhvdnabcifgiciGmbaecifhexdkavTmiabaeRbi86biabclfhiaeclfheadc98fhvxekdnalmbdnaiciGTmbadTmlabadcufgifglaeaifRbb86bbdnalciGmbaihdxekaiTmlabadc9:fgifglaeaifRbb86bbdnalciGmbaihdxekaiTmlabadc99fgifglaeaifRbb86bbdnalciGmbaihdxekaiTmlabadc98fgdfaeadfRbb86bbkadcl6mbdnadc98fgocxGcxSmbaocd4cefciGhiaec98fhlabc98fhvinavadfaladfydbBdbadc98fhdaicufgimbkkaocx6mbaec9Wfhvabc9WfhoinaoadfgicxfavadfglcxfydbBdbaicwfalcwfydbBdbaiclfalclfydbBdbaialydbBdbadc9Wfgdci0mbkkadTmdadhidnadciGglTmbaecufhvabcufhoadhiinaoaifavaifRbb86bbaicufhialcufglmbkkadcl6mdaec98fhlabc98fhvinavaifgecifalaifgdcifRbb86bbaecdfadcdfRbb86bbaecefadcefRbb86bbaeadRbb86bbaic98fgimbxikkavcl6mbdnavc98fglc3Gc3Smbavalcd4cefcrGgdcdt9RhvinaiaeydbBdbaeclfheaiclfhiadcufgdmbkkalc36mbinaiaeydbBdbaiclfaeclfydbBdbaicwfaecwfydbBdbaicxfaecxfydbBdbaiczfaeczfydbBdbaicCfaecCfydbBdbaicKfaecKfydbBdbaic3faec3fydbBdbaecafheaicafhiavc9Gfgvci0mbkkavTmbdndnavcrGgdmbavhlxekavc94GhlinaiaeRbb86bbaicefhiaecefheadcufgdmbkkavcw6mbinaiaeRbb86bbaicefaecefRbb86bbaicdfaecdfRbb86bbaicifaecifRbb86bbaiclfaeclfRbb86bbaicvfaecvfRbb86bbaicofaecofRbb86bbaicrfaecrfRbb86bbaicwfhiaecwfhealc94fglmbkkabkk:pedbcj:GdktFFuuFFuuFFuubbbbFFuFFFuFFFuFbbbbbbjZbbbbbbbbbbbbbbjZbbbbbbbbbbbbbbjZ86;nAZ86;nAZ86;nAZ86;nA:;86;nAZ86;nAZ86;nAZ86;nA:;86;nAZ86;nAZ86;nAZ86;nA:;bc;0:Gdkxebbbdbbbj:qbb";
1176
+ var wasmpack = new Uint8Array([
1177
+ 32,
1178
+ 0,
1179
+ 65,
1180
+ 2,
1181
+ 1,
1182
+ 106,
1183
+ 34,
1184
+ 33,
1185
+ 3,
1186
+ 128,
1187
+ 11,
1188
+ 4,
1189
+ 13,
1190
+ 64,
1191
+ 6,
1192
+ 253,
1193
+ 10,
1194
+ 7,
1195
+ 15,
1196
+ 116,
1197
+ 127,
1198
+ 5,
1199
+ 8,
1200
+ 12,
1201
+ 40,
1202
+ 16,
1203
+ 19,
1204
+ 54,
1205
+ 20,
1206
+ 9,
1207
+ 27,
1208
+ 255,
1209
+ 113,
1210
+ 17,
1211
+ 42,
1212
+ 67,
1213
+ 24,
1214
+ 23,
1215
+ 146,
1216
+ 148,
1217
+ 18,
1218
+ 14,
1219
+ 22,
1220
+ 45,
1221
+ 70,
1222
+ 69,
1223
+ 56,
1224
+ 114,
1225
+ 101,
1226
+ 21,
1227
+ 25,
1228
+ 63,
1229
+ 75,
1230
+ 136,
1231
+ 108,
1232
+ 28,
1233
+ 118,
1234
+ 29,
1235
+ 73,
1236
+ 115
1237
+ ]);
1238
+ if (typeof WebAssembly !== "object") {
1239
+ return {
1240
+ supported: false
1241
+ };
1242
+ }
1243
+ var instance;
1244
+ var ready = WebAssembly.instantiate(unpack(wasm), {}).then(function(result) {
1245
+ instance = result.instance;
1246
+ instance.exports.__wasm_call_ctors();
1247
+ });
1248
+ function unpack(data) {
1249
+ var result = new Uint8Array(data.length);
1250
+ for (var i = 0; i < data.length; ++i) {
1251
+ var ch = data.charCodeAt(i);
1252
+ result[i] = ch > 96 ? ch - 97 : ch > 64 ? ch - 39 : ch + 4;
1253
+ }
1254
+ var write = 0;
1255
+ for (var i = 0; i < data.length; ++i) {
1256
+ result[write++] = result[i] < 60 ? wasmpack[result[i]] : (result[i] - 60) * 64 + result[++i];
1257
+ }
1258
+ return result.buffer.slice(0, write);
1259
+ }
1260
+ function assert(cond) {
1261
+ if (!cond) {
1262
+ throw new Error("Assertion failed");
1263
+ }
1264
+ }
1265
+ function bytes(view) {
1266
+ return new Uint8Array(view.buffer, view.byteOffset, view.byteLength);
1267
+ }
1268
+ var BOUNDS_SIZE = 48;
1269
+ var MESHLET_SIZE = 16;
1270
+ function extractMeshlet(buffers, index) {
1271
+ var vertex_offset = buffers.meshlets[index * 4 + 0];
1272
+ var triangle_offset = buffers.meshlets[index * 4 + 1];
1273
+ var vertex_count = buffers.meshlets[index * 4 + 2];
1274
+ var triangle_count = buffers.meshlets[index * 4 + 3];
1275
+ return {
1276
+ vertices: buffers.vertices.subarray(vertex_offset, vertex_offset + vertex_count),
1277
+ triangles: buffers.triangles.subarray(triangle_offset, triangle_offset + triangle_count * 3)
1278
+ };
1279
+ }
1280
+ function buildMeshlets(fun, indices, vertex_positions, vertex_count, vertex_positions_stride, max_vertices, min_triangles, max_triangles, parama, paramb) {
1281
+ var sbrk = instance.exports.sbrk;
1282
+ var max_meshlets = instance.exports.meshopt_buildMeshletsBound(indices.length, max_vertices, min_triangles);
1283
+ var meshletsp = sbrk(max_meshlets * MESHLET_SIZE);
1284
+ var meshlet_verticesp = sbrk(indices.length * 4);
1285
+ var meshlet_trianglesp = sbrk(indices.length);
1286
+ var indicesp = sbrk(indices.byteLength);
1287
+ var verticesp = sbrk(vertex_positions.byteLength);
1288
+ var heap = new Uint8Array(instance.exports.memory.buffer);
1289
+ heap.set(bytes(indices), indicesp);
1290
+ heap.set(bytes(vertex_positions), verticesp);
1291
+ var count = fun(
1292
+ meshletsp,
1293
+ meshlet_verticesp,
1294
+ meshlet_trianglesp,
1295
+ indicesp,
1296
+ indices.length,
1297
+ verticesp,
1298
+ vertex_count,
1299
+ vertex_positions_stride,
1300
+ max_vertices,
1301
+ min_triangles,
1302
+ max_triangles,
1303
+ parama,
1304
+ paramb
1305
+ );
1306
+ heap = new Uint8Array(instance.exports.memory.buffer);
1307
+ var meshletBytes = heap.subarray(meshletsp, meshletsp + count * MESHLET_SIZE);
1308
+ var meshlets = new Uint32Array(meshletBytes.buffer, meshletBytes.byteOffset, meshletBytes.byteLength / 4).slice();
1309
+ for (var i = 0; i < count; ++i) {
1310
+ var vertex_offset = meshlets[i * 4 + 0];
1311
+ var triangle_offset = meshlets[i * 4 + 1];
1312
+ var vertex_count = meshlets[i * 4 + 2];
1313
+ var triangle_count = meshlets[i * 4 + 3];
1314
+ instance.exports.meshopt_optimizeMeshlet(
1315
+ meshlet_verticesp + vertex_offset * 4,
1316
+ meshlet_trianglesp + triangle_offset,
1317
+ triangle_count,
1318
+ vertex_count
1319
+ );
1320
+ }
1321
+ var used_vertices = count ? meshlets[(count - 1) * 4 + 0] + meshlets[(count - 1) * 4 + 2] : 0;
1322
+ var used_triangles = count ? meshlets[(count - 1) * 4 + 1] + meshlets[(count - 1) * 4 + 3] * 3 : 0;
1323
+ var result = {
1324
+ meshlets,
1325
+ vertices: new Uint32Array(heap.buffer, meshlet_verticesp, used_vertices).slice(),
1326
+ triangles: new Uint8Array(heap.buffer, meshlet_trianglesp, used_triangles).slice(),
1327
+ meshletCount: count
1328
+ };
1329
+ sbrk(meshletsp - sbrk(0));
1330
+ return result;
1331
+ }
1332
+ function extractBounds(boundsp) {
1333
+ var bounds_floats = new Float32Array(instance.exports.memory.buffer, boundsp, BOUNDS_SIZE / 4);
1334
+ return {
1335
+ centerX: bounds_floats[0],
1336
+ centerY: bounds_floats[1],
1337
+ centerZ: bounds_floats[2],
1338
+ radius: bounds_floats[3],
1339
+ coneApexX: bounds_floats[4],
1340
+ coneApexY: bounds_floats[5],
1341
+ coneApexZ: bounds_floats[6],
1342
+ coneAxisX: bounds_floats[7],
1343
+ coneAxisY: bounds_floats[8],
1344
+ coneAxisZ: bounds_floats[9],
1345
+ coneCutoff: bounds_floats[10]
1346
+ };
1347
+ }
1348
+ function computeMeshletBounds(buffers, vertex_positions, vertex_count, vertex_positions_stride) {
1349
+ var sbrk = instance.exports.sbrk;
1350
+ var results = [];
1351
+ var verticesp = sbrk(vertex_positions.byteLength);
1352
+ var meshlet_verticesp = sbrk(buffers.vertices.byteLength);
1353
+ var meshlet_trianglesp = sbrk(buffers.triangles.byteLength);
1354
+ var resultp = sbrk(BOUNDS_SIZE);
1355
+ var heap = new Uint8Array(instance.exports.memory.buffer);
1356
+ heap.set(bytes(vertex_positions), verticesp);
1357
+ heap.set(bytes(buffers.vertices), meshlet_verticesp);
1358
+ heap.set(bytes(buffers.triangles), meshlet_trianglesp);
1359
+ for (var i = 0; i < buffers.meshletCount; ++i) {
1360
+ var vertex_offset = buffers.meshlets[i * 4 + 0];
1361
+ var triangle_offset = buffers.meshlets[i * 4 + 1];
1362
+ var triangle_count = buffers.meshlets[i * 4 + 3];
1363
+ instance.exports.meshopt_computeMeshletBounds(
1364
+ resultp,
1365
+ meshlet_verticesp + vertex_offset * 4,
1366
+ meshlet_trianglesp + triangle_offset,
1367
+ triangle_count,
1368
+ verticesp,
1369
+ vertex_count,
1370
+ vertex_positions_stride
1371
+ );
1372
+ results.push(extractBounds(resultp));
1373
+ }
1374
+ sbrk(verticesp - sbrk(0));
1375
+ return results;
1376
+ }
1377
+ function computeClusterBounds(indices, vertex_positions, vertex_count, vertex_positions_stride) {
1378
+ var sbrk = instance.exports.sbrk;
1379
+ var resultp = sbrk(BOUNDS_SIZE);
1380
+ var indicesp = sbrk(indices.byteLength);
1381
+ var verticesp = sbrk(vertex_positions.byteLength);
1382
+ var heap = new Uint8Array(instance.exports.memory.buffer);
1383
+ heap.set(bytes(indices), indicesp);
1384
+ heap.set(bytes(vertex_positions), verticesp);
1385
+ instance.exports.meshopt_computeClusterBounds(resultp, indicesp, indices.length, verticesp, vertex_count, vertex_positions_stride);
1386
+ var result = extractBounds(resultp);
1387
+ sbrk(resultp - sbrk(0));
1388
+ return result;
1389
+ }
1390
+ function computeSphereBounds(positions, count, positions_stride, radii, radii_stride) {
1391
+ var sbrk = instance.exports.sbrk;
1392
+ var resultp = sbrk(BOUNDS_SIZE);
1393
+ var positionsp = sbrk(positions.byteLength);
1394
+ var radiip = radii ? sbrk(radii.byteLength) : 0;
1395
+ var heap = new Uint8Array(instance.exports.memory.buffer);
1396
+ heap.set(bytes(positions), positionsp);
1397
+ if (radii) {
1398
+ heap.set(bytes(radii), radiip);
1399
+ }
1400
+ instance.exports.meshopt_computeSphereBounds(resultp, positionsp, count, positions_stride, radiip, radii ? radii_stride : 0);
1401
+ var result = extractBounds(resultp);
1402
+ sbrk(resultp - sbrk(0));
1403
+ return result;
1404
+ }
1405
+ return {
1406
+ ready,
1407
+ supported: true,
1408
+ buildMeshlets: function(indices, vertex_positions, vertex_positions_stride, max_vertices, max_triangles, cone_weight) {
1409
+ assert(indices.length % 3 == 0);
1410
+ assert(vertex_positions instanceof Float32Array);
1411
+ assert(vertex_positions.length % vertex_positions_stride == 0);
1412
+ assert(vertex_positions_stride >= 3);
1413
+ assert(max_vertices >= 3 && max_vertices <= 256);
1414
+ assert(max_triangles >= 1 && max_triangles <= 512);
1415
+ cone_weight = cone_weight || 0;
1416
+ var indices32 = indices.BYTES_PER_ELEMENT == 4 ? indices : new Uint32Array(indices);
1417
+ return buildMeshlets(
1418
+ instance.exports.meshopt_buildMeshletsFlex,
1419
+ indices32,
1420
+ vertex_positions,
1421
+ vertex_positions.length / vertex_positions_stride,
1422
+ vertex_positions_stride * 4,
1423
+ max_vertices,
1424
+ max_triangles,
1425
+ max_triangles,
1426
+ cone_weight,
1427
+ 0
1428
+ );
1429
+ },
1430
+ buildMeshletsFlex: function(indices, vertex_positions, vertex_positions_stride, max_vertices, min_triangles, max_triangles, cone_weight, split_factor) {
1431
+ assert(indices.length % 3 == 0);
1432
+ assert(vertex_positions instanceof Float32Array);
1433
+ assert(vertex_positions.length % vertex_positions_stride == 0);
1434
+ assert(vertex_positions_stride >= 3);
1435
+ assert(max_vertices >= 3 && max_vertices <= 256);
1436
+ assert(min_triangles >= 1 && max_triangles <= 512);
1437
+ assert(min_triangles <= max_triangles);
1438
+ cone_weight = cone_weight || 0;
1439
+ split_factor = split_factor || 0;
1440
+ var indices32 = indices.BYTES_PER_ELEMENT == 4 ? indices : new Uint32Array(indices);
1441
+ return buildMeshlets(
1442
+ instance.exports.meshopt_buildMeshletsFlex,
1443
+ indices32,
1444
+ vertex_positions,
1445
+ vertex_positions.length / vertex_positions_stride,
1446
+ vertex_positions_stride * 4,
1447
+ max_vertices,
1448
+ min_triangles,
1449
+ max_triangles,
1450
+ cone_weight,
1451
+ split_factor
1452
+ );
1453
+ },
1454
+ buildMeshletsSpatial: function(indices, vertex_positions, vertex_positions_stride, max_vertices, min_triangles, max_triangles, fill_weight) {
1455
+ assert(indices.length % 3 == 0);
1456
+ assert(vertex_positions instanceof Float32Array);
1457
+ assert(vertex_positions.length % vertex_positions_stride == 0);
1458
+ assert(vertex_positions_stride >= 3);
1459
+ assert(max_vertices >= 3 && max_vertices <= 256);
1460
+ assert(min_triangles >= 1 && max_triangles <= 512);
1461
+ assert(min_triangles <= max_triangles);
1462
+ fill_weight = fill_weight || 0;
1463
+ var indices32 = indices.BYTES_PER_ELEMENT == 4 ? indices : new Uint32Array(indices);
1464
+ return buildMeshlets(
1465
+ instance.exports.meshopt_buildMeshletsSpatial,
1466
+ indices32,
1467
+ vertex_positions,
1468
+ vertex_positions.length / vertex_positions_stride,
1469
+ vertex_positions_stride * 4,
1470
+ max_vertices,
1471
+ min_triangles,
1472
+ max_triangles,
1473
+ fill_weight
1474
+ );
1475
+ },
1476
+ extractMeshlet: function(buffers, index) {
1477
+ assert(index >= 0 && index < buffers.meshletCount);
1478
+ return extractMeshlet(buffers, index);
1479
+ },
1480
+ computeClusterBounds: function(indices, vertex_positions, vertex_positions_stride) {
1481
+ assert(indices.length % 3 == 0);
1482
+ assert(indices.length / 3 <= 512);
1483
+ assert(vertex_positions instanceof Float32Array);
1484
+ assert(vertex_positions.length % vertex_positions_stride == 0);
1485
+ assert(vertex_positions_stride >= 3);
1486
+ var indices32 = indices.BYTES_PER_ELEMENT == 4 ? indices : new Uint32Array(indices);
1487
+ return computeClusterBounds(indices32, vertex_positions, vertex_positions.length / vertex_positions_stride, vertex_positions_stride * 4);
1488
+ },
1489
+ computeMeshletBounds: function(buffers, vertex_positions, vertex_positions_stride) {
1490
+ assert(vertex_positions instanceof Float32Array);
1491
+ assert(vertex_positions.length % vertex_positions_stride == 0);
1492
+ assert(vertex_positions_stride >= 3);
1493
+ return computeMeshletBounds(buffers, vertex_positions, vertex_positions.length / vertex_positions_stride, vertex_positions_stride * 4);
1494
+ },
1495
+ computeSphereBounds: function(positions, positions_stride, radii, radii_stride) {
1496
+ assert(positions instanceof Float32Array);
1497
+ assert(positions.length % positions_stride == 0);
1498
+ assert(positions_stride >= 3);
1499
+ assert(!radii || radii instanceof Float32Array);
1500
+ assert(!radii || radii.length % radii_stride == 0);
1501
+ assert(!radii || radii_stride >= 1);
1502
+ assert(!radii || positions.length / positions_stride == radii.length / radii_stride);
1503
+ radii_stride = radii_stride || 0;
1504
+ return computeSphereBounds(positions, positions.length / positions_stride, positions_stride * 4, radii, radii_stride * 4);
1505
+ }
1506
+ };
1507
+ })();
1508
+
1509
+ // packages/engine/node_modules/meshoptimizer/meshopt_tangents.js
1510
+ var MeshoptTangents = (function() {
1511
+ var wasm = "b9H79Tebbbegv9Geueu9Geub9Gbb9Gkuuuuuuuuuuub9Giuuueuirodiblbelve9Weiiviebeoweuecj:Gdkrnlo9TW9T9VV95dbH9F9F939H79T9F9J9H229F9Jt9VV7bbK9TW79O9V9Wt9F9NW9UWV9HtW9u9H9U9NW9Ut7bel79IV9RbdDwebcekdlvq;m8Lodbk:wgvOuw99iuv99vu8Jjjjjbc;Wb9Rgk8Kjjjjbakcxfcbc;Kbz:djjjb8AakcualcdtgxalcFFFFi0Ecbyd:q:G:cjbHjjjjbbgmBdxakceBd2adci9UhPalcd4alfhscehzinazgHcethzaHas6mbkakcuaHcdtgzaHcFFFFi0Ecbyd:q:G:cjbHjjjjbbgsBdzakcdBd2ascFeazz:djjjbhOaDcd4hAarcd4hCavcd4hXdnalTmbaHcufhrcbhvindndnaOcbaiavaX2cdtfgHydlgDaDcjjjj94SEgscH4cbaoavaC2cdtfgzydlgQcs4aQcjjjj94SE7as7c:F:b:DD2cbaHydbgLaLcjjjj94SEgscH4cbazydbgKcs4aKcjjjj94SE7as7c;D;O:B8J27cbaHydwgYaYcjjjj94SEgHcH4cbazydwg8Acs4a8Acjjjj94SE7aH7c:3F;N8N27awavaA2cdtfgHydlgEaHydbg37cFFFFrGgHcm4aH7c:fjjK27arGgscdtfgHydbgzcuSmbaE::h5a3::h8Ea8A::h8FaQ::haaK::hhaY::hgaD::h8JaL::h8KcehDinaDhHdnaiazaX2cdtfgDIdba8K9CmbaDIdla8J9CmbaDIdwag9CmbaoazaC2cdtfgDIdbah9CmbaDIdlaa9CmbaDIdwa8F9CmbawazaA2cdtfgDIdba8E9CmbaDIdla59BmikaHcefhDaOasaHfarGgscdtfgHydbgzcu9hmbkkaHavBdbavhzkamavcdtfazBdbavcefgval9hmbkkaOcbydN:G:cjbH:bjjjbbakceBd2akcualcefgHcdtaHcFFFFi0Ecbyd:q:G:cjbHjjjjbbg8LBdzakcdBd2akcuadcdtadcFFFFi0EgYcbyd:q:G:cjbHjjjjbbg8MBdCakciBd2a8Lclfcbaxz:djjjbhzdnadTmbdnaeTmbaehHadhsinazamaHydbcdtfydbcdtfgDaDydbcefBdbaHclfhHascufgsmbxdkkamhHadhsinazaHydbcdtfgDaDydbcefBdbaHclfhHascufgsmbkkdnalTmbcbhsazhHalhDinaHydbhOaHasBdbaHclfhHaOasfhsaDcufgDmbkkdnadci6gQmbcbhscdhHaPhOindndnaeTmbamaeasfgvydbcdtfhDamavcwfydbcdtfhramavclfydbcdtfhvxekamasfgDcwfhraDclfhvkarydbhravydbhvazaDydbcdtfgDaDydbgDcefBdba8MaDcdtfaHc9:fBdbazavcdtfgDaDydbgDcefBdba8MaDcdtfaHcufBdbazarcdtfgDaDydbgDcefBdba8MaDcdtfaHBdbascxfhsaHclfhHaOcufgOmbkkcbhsa8LcbBdbakcuaPcltadcFFFFd0Ecbyd:q:G:cjbHjjjjbbg8NBdKakclBd2dnaQmbaehza8NhHaPhvindndnaeTmbazcwfydbhDazclfydbhOazydbhrxekascdfhDascefhOashrkJbbbbh8KJbbbbJbbbbJbbbbJbbbbJbbjZJbbj:;awaOaA2cdtfgQIdbawaraA2cdtfgLIdbgh:tawaDaA2cdtfgKIdlaLIdlgg:tg8JNaQIdlag:tggaKIdbah:tN:tghJbbbb9EEahJbbbb9BEg8EaiaraX2cdtfgrIdwghaiaOaX2cdtfgOIdwg59BEa8EarIdlgaaOIdlgy9BEa8EarIdbg8FaOIdbg8P9BEg8EahaiaDaX2cdtfgDIdwgI9BEa8EaaaDIdlg8R9BEa8Ea8FaDIdbg8S9BEg8Ea5aI9BEa8Eaya8R9BEa8Ea8Pa8S9BEh8Edna8Ja5ah:tNagaIah:tN:tghahNa8Ja8Pa8F:tNaga8Sa8F:tN:tg8Fa8FNa8Jayaa:tNaga8Raa:tN:tg8Ja8JNMMggJbbbb9Bmba8Eag:r:vh8KkaHcxfa8EUdbaHcwfaha8KNUdbaHclfa8Ja8KNUdbaHa8Fa8KNUdbazcxfhzaHczfhHascifhsavcufgvmbkkcbhHakaYcbyd:q:G:cjbHjjjjbbgDBd3akcvBd2dnadTmbaDhzinazaHBdbazclfhzadaHcefgH9hmbkkakcuaPcdtadcFFFF970Ecbyd:q:G:cjbHjjjjbbgvBdaakcoBd2akaPcbyd:q:G:cjbHjjjjbbg8ABd8KakcrBd2dnadci6mba8NcxfhzavhscbhHinasaHBdba8AaHfcdcbazIdbg8KJbbbb9DEa8KJbbbb9EV86bbasclfhsazczfhzaPaHcefgH9hmbkkdnalTmbcbhRinaRcdthHdna8LaRcefgRcdtfydbgza8LaHfydbgHSmbazaH9RhLa8MaHcdtfhKcbh8UinaKa8Ucdtfg8VydbgHcd4g8Wci2gxaHciGcdtgzyd:e:G:cjbfhHaxazydj:G:cjbfhzdnaeTmbaeaHcdtfydbhHaeazcdtfydbhzkdna8Ucefg8UaL9pmbamaHcdtfydbhYamazcdtfydbh3a8Aa8WfhEava8Wcdtfh8Xa8UhwinaKawcdtfgQydbgHcd4gzci2gAaHciGcdtgHyd:e:G:cjbfhsaAaHydj:G:cjbfhHdnaeTmbaeascdtfydbhsaeaHcdtfydbhHkdndnamaHcdtfydbaYSmbamascdtfydba39hmeka8AazfRbbgHaERbbgsVciSmbdnaHasGmba8Whsdna8Wa8XydbgHSmba8XhOinaOavaHgscdtfgrydbgHBdbarhOasaH9hmbkkdnazavazcdtfgOydbgHSmbinaOavaHgzcdtfgrydbgHBdbarhOazaH9hmbkkasazSmba8AazfgORbba8AasfgHRbbVciSmeavazcdtfasBdbaHaHRbbaORbbV86bbkdna8VydbciGaxfgzaDazcdtfgsydbgHSmbinasaDaHgzcdtfgOydbgHBdbaOhsazaH9hmbkkdnaQydbciGaAfgsaDascdtfgOydbgHSmbinaOaDaHgscdtfgrydbgHBdbarhOasaH9hmbkkazasSmbaDascdtfazBdbkawcefgwaL9hmbkka8UaL9hmbkkaRal9hmbkkdnadTmbcbhrinarhzdnaraDarcdtfgwydbgHSmbawhsinasaDaHgzcdtfgOydbgHBdbaOhsazaH9hmbkkawazBdbarcefgrad9hmbkcbh8Vabcbadcltz:djjjbhKdnadci6mbaqceGhEaDhYaeh3cbh8Windna8Na8WcltfgsIdxJbbbb9Bmbama8Wcx2gHfhxaeaHfhLcbhza8VhwinaKaYazfydbcltfhHdndnaeTmbamaLazc:e:G:cjbfydbcdtfydbcdtfhAamaLazcj:G:cjbfydbcdtfydbcdtfhra3azfydbhOxekaxazc:e:G:cjbfydbcdtfhAaxazcj:G:cjbfydbcdtfhrawhOkaHasIdbggaoamaOcdtfydbgQaC2cdtfgOIdbg8KasIdwg8FaOIdwg8JNaga8KNasIdlg8EaOIdlggNMMghN:tgaJbbbbJbbjZa8Fa8JahN:tg8Fa8FNaaaaNa8EagahN:tghahNMMga:r:vaaJbbbb9BEJ;As6nJbbjZaiarydbaX2cdtfgOIdwaiaQaX2cdtfgrIdwg5:tgaa8Jaaa8JNaOIdbarIdbgy:tg8Pa8KNagaOIdlarIdlgI:tg8RNMMgaN:tg8EaiaAydbaX2cdtfgOIdwa5:tg5a8Ja5a8JNaOIdbay:tg8Sa8KNagaOIdlaI:tgINMMg5N:tg8JNa8Pa8KaaN:tgya8Sa8Ka5N:tg8KNa8RagaaN:tgaaIaga5N:tggNMMJbbbbJbbjZa8Ea8ENayayNaaaaNMMa8Ja8JNa8Ka8KNagagNMMNg8K:rg8J:va8KJbbbb9BENgg:lg8Ka8KJbbjZ9EEg8Ka8KJ7;A9s89NJ:L9t9s::MNJ;ob;jZMJbbjZa8K:t:rNg8K:ta8KagJbbbb9DENg8Ka8Ja8KNaEEg8KNaHIdbMUdbaHaha8KNaHIdlMUdlaHa8Fa8KNaHIdwMUdwawcefhwazclfgzcx9hmbkkaYcxfhYa3cxfh3a8Vcifh8Va8Wcefg8WaP9hmbkcbhrinarhzdnaravarcdtfgsydbgHSmbinasavaHgzcdtfgOydbgHBdbaOhsazaH9hmbkkaKarc8W2fgHc3fJbbjZJbbj:;a8AazfRbbceGEg8KUdbaHc8Sfa8KUdbaHa8KUdxarcefgraP9hmbkkaqcdGhvcbhzaDhsaKhHindnazasydb9hmbJbbbbh8KdnaHcwfgOIdbg8Ja8JNaHIdbggagNaHclfgrIdbghahNMMgaJbbbb9BmbJbbjZaa:r:vh8KkaOa8Ja8KNUdbaraha8KNUdbaHaga8KNg8JUdbavmbaHJbbjZa8Ja8KJbbbb9BEUdbkasclfhsaHczfhHadazcefgz9hmbkcbhHaKhzindnaHaDydbgsSmbazaKascltfgsydwBdwazas8Pdb83dbkaDclfhDazczfhzadaHcefgH9hmbkkdnakyd2gzTmbazcdtakcxffc98fhHinaHydbcbydN:G:cjbH:bjjjbbaHc98fhHazcufgzmbkkakc;Wbf8Kjjjjbk9teiucbcbyd:y:G:cjbgeabcifc98GfgbBd:y:G:cjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaik;aeedudndnabciGTmbabhixekaecFeGc:b:c:ew2hldndnadcz9pmbabhixekabhiinaialBdbaicxfalBdbaicwfalBdbaiclfalBdbaiczfhiadc9Wfgdcs0mbkkadcl6mbinaialBdbaiclfhiadc98fgdci0mbkkdnadTmbinaiae86bbaicefhiadcufgdmbkkabk9teiucbcbyd:y:G:cjbgeabcrfc94GfgbBd:y:G:cjbdndnabZbcztgd9nmbcuhiabad9RcFFifcz4nbcuSmekaehikaikTeeucbabcbyd:y:G:cjbge9Rcifc98GaefgbBd:y:G:cjbdnabZbcztge9nmbabae9RcFFifcz4nb8Akkk8Rdbcj:Gdkzebbbdbbbbbbbebbbbc:q:Gdkxebbbdbbba:qbb";
1512
+ var wasmpack = new Uint8Array([
1513
+ 32,
1514
+ 0,
1515
+ 65,
1516
+ 2,
1517
+ 1,
1518
+ 106,
1519
+ 34,
1520
+ 33,
1521
+ 3,
1522
+ 128,
1523
+ 11,
1524
+ 4,
1525
+ 13,
1526
+ 64,
1527
+ 6,
1528
+ 253,
1529
+ 10,
1530
+ 7,
1531
+ 15,
1532
+ 116,
1533
+ 127,
1534
+ 5,
1535
+ 8,
1536
+ 12,
1537
+ 40,
1538
+ 16,
1539
+ 19,
1540
+ 54,
1541
+ 20,
1542
+ 9,
1543
+ 27,
1544
+ 255,
1545
+ 113,
1546
+ 17,
1547
+ 42,
1548
+ 67,
1549
+ 24,
1550
+ 23,
1551
+ 146,
1552
+ 148,
1553
+ 18,
1554
+ 14,
1555
+ 22,
1556
+ 45,
1557
+ 70,
1558
+ 69,
1559
+ 56,
1560
+ 114,
1561
+ 101,
1562
+ 21,
1563
+ 25,
1564
+ 63,
1565
+ 75,
1566
+ 136,
1567
+ 108,
1568
+ 28,
1569
+ 118,
1570
+ 29,
1571
+ 73,
1572
+ 115
1573
+ ]);
1574
+ if (typeof WebAssembly !== "object") {
1575
+ return {
1576
+ supported: false
1577
+ };
1578
+ }
1579
+ var instance;
1580
+ var ready = WebAssembly.instantiate(unpack(wasm), {}).then(function(result) {
1581
+ instance = result.instance;
1582
+ instance.exports.__wasm_call_ctors();
1583
+ });
1584
+ function unpack(data) {
1585
+ var result = new Uint8Array(data.length);
1586
+ for (var i = 0; i < data.length; ++i) {
1587
+ var ch = data.charCodeAt(i);
1588
+ result[i] = ch > 96 ? ch - 97 : ch > 64 ? ch - 39 : ch + 4;
1589
+ }
1590
+ var write = 0;
1591
+ for (var i = 0; i < data.length; ++i) {
1592
+ result[write++] = result[i] < 60 ? wasmpack[result[i]] : (result[i] - 60) * 64 + result[++i];
1593
+ }
1594
+ return result.buffer.slice(0, write);
1595
+ }
1596
+ function assert(cond) {
1597
+ if (!cond) {
1598
+ throw new Error("Assertion failed");
1599
+ }
1600
+ }
1601
+ function bytes(view) {
1602
+ return new Uint8Array(view.buffer, view.byteOffset, view.byteLength);
1603
+ }
1604
+ function generate(indices, index_count, vertex_positions, vertex_count, vertex_positions_stride, vertex_normals, vertex_normals_stride, vertex_uvs, vertex_uvs_stride, options) {
1605
+ var sbrk = instance.exports.sbrk;
1606
+ var resultp = sbrk(index_count * 16);
1607
+ var indicesp = indices ? sbrk(indices.byteLength) : 0;
1608
+ var positionsp = sbrk(vertex_positions.byteLength);
1609
+ var normalsp = sbrk(vertex_normals.byteLength);
1610
+ var uvsp = sbrk(vertex_uvs.byteLength);
1611
+ var heap = new Uint8Array(instance.exports.memory.buffer);
1612
+ if (indices) heap.set(bytes(indices), indicesp);
1613
+ heap.set(bytes(vertex_positions), positionsp);
1614
+ heap.set(bytes(vertex_normals), normalsp);
1615
+ heap.set(bytes(vertex_uvs), uvsp);
1616
+ instance.exports.meshopt_generateTangents(
1617
+ resultp,
1618
+ indicesp,
1619
+ index_count,
1620
+ positionsp,
1621
+ vertex_count,
1622
+ vertex_positions_stride * 4,
1623
+ normalsp,
1624
+ vertex_normals_stride * 4,
1625
+ uvsp,
1626
+ vertex_uvs_stride * 4,
1627
+ options
1628
+ );
1629
+ heap = new Uint8Array(instance.exports.memory.buffer);
1630
+ var result = new Float32Array(heap.buffer, resultp, index_count * 4).slice();
1631
+ sbrk(resultp - sbrk(0));
1632
+ return result;
1633
+ }
1634
+ var tangentOptions = {
1635
+ Compatible: 1,
1636
+ ZeroFallback: 2
1637
+ };
1638
+ return {
1639
+ ready,
1640
+ supported: true,
1641
+ generateTangents: function(indices, vertex_positions, vertex_positions_stride, vertex_normals, vertex_normals_stride, vertex_uvs, vertex_uvs_stride, flags) {
1642
+ assert(
1643
+ indices === null || indices instanceof Uint32Array || indices instanceof Int32Array || indices instanceof Uint16Array || indices instanceof Int16Array
1644
+ );
1645
+ assert(indices === null || indices.length % 3 == 0);
1646
+ assert(vertex_positions instanceof Float32Array);
1647
+ assert(vertex_positions.length % vertex_positions_stride == 0);
1648
+ assert(vertex_positions_stride >= 3);
1649
+ assert(vertex_normals instanceof Float32Array);
1650
+ assert(vertex_normals.length % vertex_normals_stride == 0);
1651
+ assert(vertex_normals_stride >= 3);
1652
+ assert(vertex_uvs instanceof Float32Array);
1653
+ assert(vertex_uvs.length % vertex_uvs_stride == 0);
1654
+ assert(vertex_uvs_stride >= 2);
1655
+ assert(vertex_positions.length / vertex_positions_stride == vertex_normals.length / vertex_normals_stride);
1656
+ assert(vertex_positions.length / vertex_positions_stride == vertex_uvs.length / vertex_uvs_stride);
1657
+ assert(indices !== null || vertex_positions.length / vertex_positions_stride % 3 == 0);
1658
+ var options = 0;
1659
+ for (var i = 0; i < (flags ? flags.length : 0); ++i) {
1660
+ assert(flags[i] in tangentOptions);
1661
+ options |= tangentOptions[flags[i]];
1662
+ }
1663
+ var vertex_count = vertex_positions.length / vertex_positions_stride;
1664
+ var index_count = indices ? indices.length : vertex_count;
1665
+ var indices32 = indices === null || indices.BYTES_PER_ELEMENT == 4 ? indices : new Uint32Array(indices);
1666
+ return generate(
1667
+ indices32,
1668
+ index_count,
1669
+ vertex_positions,
1670
+ vertex_count,
1671
+ vertex_positions_stride,
1672
+ vertex_normals,
1673
+ vertex_normals_stride,
1674
+ vertex_uvs,
1675
+ vertex_uvs_stride,
1676
+ options
1677
+ );
1678
+ }
1679
+ };
1680
+ })();
1681
+
1682
+ // packages/engine/Source/Scene/Axis.js
1683
+ var Axis = {
1684
+ /**
1685
+ * Denotes the x-axis.
1686
+ *
1687
+ * @type {number}
1688
+ * @constant
1689
+ */
1690
+ X: 0,
1691
+ /**
1692
+ * Denotes the y-axis.
1693
+ *
1694
+ * @type {number}
1695
+ * @constant
1696
+ */
1697
+ Y: 1,
1698
+ /**
1699
+ * Denotes the z-axis.
1700
+ *
1701
+ * @type {number}
1702
+ * @constant
1703
+ */
1704
+ Z: 2
1705
+ };
1706
+ Axis.Y_UP_TO_Z_UP = Matrix4_default.fromRotationTranslation(
1707
+ // Rotation about PI/2 around the X-axis
1708
+ Matrix3_default.fromArray([1, 0, 0, 0, 0, 1, 0, -1, 0])
1709
+ );
1710
+ Axis.Z_UP_TO_Y_UP = Matrix4_default.fromRotationTranslation(
1711
+ // Rotation about -PI/2 around the X-axis
1712
+ Matrix3_default.fromArray([1, 0, 0, 0, 0, -1, 0, 1, 0])
1713
+ );
1714
+ Axis.X_UP_TO_Z_UP = Matrix4_default.fromRotationTranslation(
1715
+ // Rotation about -PI/2 around the Y-axis
1716
+ Matrix3_default.fromArray([0, 0, 1, 0, 1, 0, -1, 0, 0])
1717
+ );
1718
+ Axis.Z_UP_TO_X_UP = Matrix4_default.fromRotationTranslation(
1719
+ // Rotation about PI/2 around the Y-axis
1720
+ Matrix3_default.fromArray([0, 0, -1, 0, 1, 0, 1, 0, 0])
1721
+ );
1722
+ Axis.X_UP_TO_Y_UP = Matrix4_default.fromRotationTranslation(
1723
+ // Rotation about PI/2 around the Z-axis
1724
+ Matrix3_default.fromArray([0, 1, 0, -1, 0, 0, 0, 0, 1])
1725
+ );
1726
+ Axis.Y_UP_TO_X_UP = Matrix4_default.fromRotationTranslation(
1727
+ // Rotation about -PI/2 around the Z-axis
1728
+ Matrix3_default.fromArray([0, -1, 0, 1, 0, 0, 0, 0, 1])
1729
+ );
1730
+ Axis.fromName = function(name) {
1731
+ Check_default.typeOf.string("name", name);
1732
+ return Axis[name];
1733
+ };
1734
+ Object.freeze(Axis);
1735
+ var Axis_default = Axis;
1736
+
1737
+ // packages/engine/Source/Scene/SceneMode.js
1738
+ var SceneMode = {
1739
+ /**
1740
+ * Morphing between mode, e.g., 3D to 2D.
1741
+ *
1742
+ * @type {number}
1743
+ * @constant
1744
+ */
1745
+ MORPHING: 0,
1746
+ /**
1747
+ * Columbus View mode. A 2.5D perspective view where the map is laid out
1748
+ * flat and objects with non-zero height are drawn above it.
1749
+ *
1750
+ * @type {number}
1751
+ * @constant
1752
+ */
1753
+ COLUMBUS_VIEW: 1,
1754
+ /**
1755
+ * 2D mode. The map is viewed top-down with an orthographic projection.
1756
+ *
1757
+ * @type {number}
1758
+ * @constant
1759
+ */
1760
+ SCENE2D: 2,
1761
+ /**
1762
+ * 3D mode. A traditional 3D perspective view of the globe.
1763
+ *
1764
+ * @type {number}
1765
+ * @constant
1766
+ */
1767
+ SCENE3D: 3
1768
+ };
1769
+ SceneMode.getMorphTime = function(value) {
1770
+ if (value === SceneMode.SCENE3D) {
1771
+ return 1;
1772
+ } else if (value === SceneMode.MORPHING) {
1773
+ return void 0;
1774
+ }
1775
+ return 0;
1776
+ };
1777
+ Object.freeze(SceneMode);
1778
+ var SceneMode_default = SceneMode;
1779
+
1780
+ // packages/engine/Source/Core/TaskProcessor.js
1781
+ var import_urijs = __toESM(require_URI(), 1);
1782
+
1783
+ // packages/engine/Source/Core/destroyObject.js
1784
+ function returnTrue() {
1785
+ return true;
1786
+ }
1787
+ function destroyObject(object, message) {
1788
+ message = message ?? "This object was destroyed, i.e., destroy() was called.";
1789
+ function throwOnDestroyed() {
1790
+ throw new DeveloperError_default(message);
1791
+ }
1792
+ for (const key in object) {
1793
+ if (typeof object[key] === "function") {
1794
+ object[key] = throwOnDestroyed;
1795
+ }
1796
+ }
1797
+ object.isDestroyed = returnTrue;
1798
+ return void 0;
1799
+ }
1800
+ var destroyObject_default = destroyObject;
1801
+
1802
+ // packages/engine/Source/Core/TaskProcessor.js
1803
+ function canTransferArrayBuffer() {
1804
+ if (!defined_default(TaskProcessor._canTransferArrayBuffer)) {
1805
+ const worker = createWorker("transferTypedArrayTest");
1806
+ worker.postMessage = worker.webkitPostMessage ?? worker.postMessage;
1807
+ const value = 99;
1808
+ const array = new Int8Array([value]);
1809
+ try {
1810
+ worker.postMessage(
1811
+ {
1812
+ array
1813
+ },
1814
+ [array.buffer]
1815
+ );
1816
+ } catch (e) {
1817
+ TaskProcessor._canTransferArrayBuffer = false;
1818
+ return TaskProcessor._canTransferArrayBuffer;
1819
+ }
1820
+ TaskProcessor._canTransferArrayBuffer = new Promise((resolve) => {
1821
+ worker.onmessage = function(event) {
1822
+ const array2 = event.data.array;
1823
+ const result = defined_default(array2) && array2[0] === value;
1824
+ resolve(result);
1825
+ worker.terminate();
1826
+ TaskProcessor._canTransferArrayBuffer = result;
1827
+ };
1828
+ });
1829
+ }
1830
+ return TaskProcessor._canTransferArrayBuffer;
1831
+ }
1832
+ var taskCompletedEvent = new Event_default();
1833
+ function urlFromScript(script) {
1834
+ let blob;
1835
+ try {
1836
+ blob = new Blob([script], {
1837
+ type: "application/javascript"
1838
+ });
1839
+ } catch (e) {
1840
+ const BlobBuilder = window.BlobBuilder || window.WebKitBlobBuilder || window.MozBlobBuilder || window.MSBlobBuilder;
1841
+ const blobBuilder = new BlobBuilder();
1842
+ blobBuilder.append(script);
1843
+ blob = blobBuilder.getBlob("application/javascript");
1844
+ }
1845
+ const URL2 = window.URL || window.webkitURL;
1846
+ return URL2.createObjectURL(blob);
1847
+ }
1848
+ function createWorker(url) {
1849
+ const uri = new import_urijs.default(url);
1850
+ const isUri = uri.scheme().length !== 0 && uri.fragment().length === 0;
1851
+ const moduleID = url.replace(/\.js$/, "");
1852
+ const options = {};
1853
+ let workerPath;
1854
+ let crossOriginUrl;
1855
+ if (isCrossOriginUrl_default(url)) {
1856
+ crossOriginUrl = url;
1857
+ } else if (!isUri) {
1858
+ const moduleAbsoluteUrl = buildModuleUrl_default(
1859
+ `${TaskProcessor._workerModulePrefix}/${moduleID}.js`
1860
+ );
1861
+ if (isCrossOriginUrl_default(moduleAbsoluteUrl)) {
1862
+ crossOriginUrl = moduleAbsoluteUrl;
1863
+ }
1864
+ }
1865
+ if (crossOriginUrl) {
1866
+ const script = `import "${crossOriginUrl}";`;
1867
+ workerPath = urlFromScript(script);
1868
+ options.type = "module";
1869
+ return new Worker(workerPath, options);
1870
+ }
1871
+ if (!isUri && typeof CESIUM_WORKERS !== "undefined") {
1872
+ const script = `
1873
+ importScripts("${urlFromScript(CESIUM_WORKERS)}");
1874
+ CesiumWorkers["${moduleID}"]();
1875
+ `;
1876
+ workerPath = urlFromScript(script);
1877
+ return new Worker(workerPath, options);
1878
+ }
1879
+ workerPath = url;
1880
+ if (!isUri) {
1881
+ workerPath = buildModuleUrl_default(
1882
+ `${TaskProcessor._workerModulePrefix + moduleID}.js`
1883
+ );
1884
+ }
1885
+ if (!FeatureDetection_default.supportsEsmWebWorkers()) {
1886
+ throw new RuntimeError_default(
1887
+ "This browser is not supported. Please update your browser to continue."
1888
+ );
1889
+ }
1890
+ options.type = "module";
1891
+ return new Worker(workerPath, options);
1892
+ }
1893
+ async function getWebAssemblyLoaderConfig(processor, wasmOptions) {
1894
+ const config = {
1895
+ modulePath: void 0,
1896
+ wasmBinaryFile: void 0,
1897
+ wasmBinary: void 0
1898
+ };
1899
+ if (!FeatureDetection_default.supportsWebAssembly()) {
1900
+ if (!defined_default(wasmOptions.fallbackModulePath)) {
1901
+ throw new RuntimeError_default(
1902
+ `This browser does not support Web Assembly, and no backup module was provided for ${processor._workerPath}`
1903
+ );
1904
+ }
1905
+ config.modulePath = buildModuleUrl_default(wasmOptions.fallbackModulePath);
1906
+ return config;
1907
+ }
1908
+ config.wasmBinaryFile = buildModuleUrl_default(wasmOptions.wasmBinaryFile);
1909
+ const arrayBuffer = await Resource_default.fetchArrayBuffer({
1910
+ url: config.wasmBinaryFile
1911
+ });
1912
+ config.wasmBinary = arrayBuffer;
1913
+ return config;
1914
+ }
1915
+ function TaskProcessor(workerPath, maximumActiveTasks) {
1916
+ this._workerPath = workerPath;
1917
+ this._maximumActiveTasks = maximumActiveTasks ?? Number.POSITIVE_INFINITY;
1918
+ this._activeTasks = 0;
1919
+ this._nextID = 0;
1920
+ this._webAssemblyPromise = void 0;
1921
+ }
1922
+ var createOnmessageHandler = (worker, id, resolve, reject) => {
1923
+ const listener = ({ data }) => {
1924
+ if (data.id !== id) {
1925
+ return;
1926
+ }
1927
+ if (defined_default(data.error)) {
1928
+ let error = data.error;
1929
+ if (error.name === "RuntimeError") {
1930
+ error = new RuntimeError_default(data.error.message);
1931
+ error.stack = data.error.stack;
1932
+ } else if (error.name === "DeveloperError") {
1933
+ error = new DeveloperError_default(data.error.message);
1934
+ error.stack = data.error.stack;
1935
+ } else if (error.name === "Error") {
1936
+ error = new Error(data.error.message);
1937
+ error.stack = data.error.stack;
1938
+ }
1939
+ taskCompletedEvent.raiseEvent(error);
1940
+ reject(error);
1941
+ } else {
1942
+ taskCompletedEvent.raiseEvent();
1943
+ resolve(data.result);
1944
+ }
1945
+ worker.removeEventListener("message", listener);
1946
+ };
1947
+ return listener;
1948
+ };
1949
+ var emptyTransferableObjectArray = [];
1950
+ async function runTask(processor, parameters, transferableObjects) {
1951
+ const canTransfer = await Promise.resolve(canTransferArrayBuffer());
1952
+ if (!defined_default(transferableObjects)) {
1953
+ transferableObjects = emptyTransferableObjectArray;
1954
+ } else if (!canTransfer) {
1955
+ transferableObjects.length = 0;
1956
+ }
1957
+ const id = processor._nextID++;
1958
+ const promise = new Promise((resolve, reject) => {
1959
+ processor._worker.addEventListener(
1960
+ "message",
1961
+ createOnmessageHandler(processor._worker, id, resolve, reject)
1962
+ );
1963
+ });
1964
+ processor._worker.postMessage(
1965
+ {
1966
+ id,
1967
+ baseUrl: buildModuleUrl_default.getCesiumBaseUrl().url,
1968
+ parameters,
1969
+ canTransferArrayBuffer: canTransfer
1970
+ },
1971
+ transferableObjects
1972
+ );
1973
+ return promise;
1974
+ }
1975
+ async function scheduleTask(processor, parameters, transferableObjects) {
1976
+ ++processor._activeTasks;
1977
+ try {
1978
+ const result = await runTask(processor, parameters, transferableObjects);
1979
+ --processor._activeTasks;
1980
+ return result;
1981
+ } catch (error) {
1982
+ --processor._activeTasks;
1983
+ throw error;
1984
+ }
1985
+ }
1986
+ TaskProcessor.prototype.scheduleTask = function(parameters, transferableObjects) {
1987
+ if (!defined_default(this._worker)) {
1988
+ this._worker = createWorker(this._workerPath);
1989
+ }
1990
+ if (this._activeTasks >= this._maximumActiveTasks) {
1991
+ return void 0;
1992
+ }
1993
+ return scheduleTask(this, parameters, transferableObjects);
1994
+ };
1995
+ TaskProcessor.prototype.initWebAssemblyModule = async function(webAssemblyOptions) {
1996
+ if (defined_default(this._webAssemblyPromise)) {
1997
+ return this._webAssemblyPromise;
1998
+ }
1999
+ const init = async () => {
2000
+ const worker = this._worker = createWorker(this._workerPath);
2001
+ const wasmConfig = await getWebAssemblyLoaderConfig(
2002
+ this,
2003
+ webAssemblyOptions
2004
+ );
2005
+ const canTransfer = await Promise.resolve(canTransferArrayBuffer());
2006
+ let transferableObjects;
2007
+ const binary = wasmConfig.wasmBinary;
2008
+ if (defined_default(binary) && canTransfer) {
2009
+ transferableObjects = [binary];
2010
+ }
2011
+ const promise = new Promise((resolve, reject) => {
2012
+ worker.onmessage = function({ data }) {
2013
+ if (defined_default(data)) {
2014
+ resolve(data.result);
2015
+ } else {
2016
+ reject(new RuntimeError_default("Could not configure wasm module"));
2017
+ }
2018
+ };
2019
+ });
2020
+ worker.postMessage(
2021
+ {
2022
+ canTransferArrayBuffer: canTransfer,
2023
+ parameters: { webAssemblyConfig: wasmConfig }
2024
+ },
2025
+ transferableObjects
2026
+ );
2027
+ return promise;
2028
+ };
2029
+ this._webAssemblyPromise = init();
2030
+ return this._webAssemblyPromise;
2031
+ };
2032
+ TaskProcessor.prototype.isDestroyed = function() {
2033
+ return false;
2034
+ };
2035
+ TaskProcessor.prototype.destroy = function() {
2036
+ if (defined_default(this._worker)) {
2037
+ this._worker.terminate();
2038
+ }
2039
+ return destroyObject_default(this);
2040
+ };
2041
+ TaskProcessor.taskCompletedEvent = taskCompletedEvent;
2042
+ TaskProcessor._defaultWorkerModulePrefix = "Workers/";
2043
+ TaskProcessor._workerModulePrefix = TaskProcessor._defaultWorkerModulePrefix;
2044
+ TaskProcessor._canTransferArrayBuffer = void 0;
2045
+ var TaskProcessor_default = TaskProcessor;
2046
+
2047
+ // packages/engine/Source/Core/TerrainPicker.js
2048
+ var MAXIMUM_TERRAIN_PICKER_LEVEL = 3;
2049
+ function TerrainPicker(vertices, indices, encoding) {
2050
+ Check_default.defined("vertices", vertices);
2051
+ Check_default.defined("indices", indices);
2052
+ Check_default.defined("encoding", encoding);
2053
+ this._vertices = vertices;
2054
+ this._indices = indices;
2055
+ this._encoding = encoding;
2056
+ this._inverseTransform = new Matrix4_default();
2057
+ this._needsRebuild = true;
2058
+ this._rootNode = new TerrainPickerNode();
2059
+ }
2060
+ var incrementallyBuildTerrainPickerTaskProcessor = new TaskProcessor_default(
2061
+ "incrementallyBuildTerrainPicker"
2062
+ );
2063
+ Object.defineProperties(TerrainPicker.prototype, {
2064
+ /**
2065
+ * Indicates whether the terrain picker needs to be rebuilt due to changes in the underlying terrain mesh's vertices or indices.
2066
+ * @memberof TerrainPicker.prototype
2067
+ * @type {boolean}
2068
+ */
2069
+ needsRebuild: {
2070
+ get: function() {
2071
+ return this._needsRebuild;
2072
+ },
2073
+ set: function(value) {
2074
+ this._needsRebuild = value;
2075
+ }
2076
+ }
2077
+ });
2078
+ function TerrainPickerNode() {
2079
+ this.x = 0;
2080
+ this.y = 0;
2081
+ this.level = 0;
2082
+ this.aabb = createAABBForNode(this.x, this.y, this.level);
2083
+ this.intersectingTriangles = new Uint32Array(0);
2084
+ this.children = [];
2085
+ this.buildingChildren = false;
2086
+ }
2087
+ TerrainPickerNode.prototype.addChild = function(childIdx) {
2088
+ if (childIdx < 0 || childIdx > 3) {
2089
+ throw new DeveloperError_default(
2090
+ "TerrainPickerNode child index must be between 0 and 3, inclusive."
2091
+ );
2092
+ }
2093
+ const childNode = new TerrainPickerNode();
2094
+ childNode.x = this.x * 2 + (childIdx & 1);
2095
+ childNode.y = this.y * 2 + (childIdx >> 1 & 1);
2096
+ childNode.level = this.level + 1;
2097
+ childNode.aabb = createAABBForNode(childNode.x, childNode.y, childNode.level);
2098
+ this.children[childIdx] = childNode;
2099
+ };
2100
+ var scratchTransformedRay = new Ray_default();
2101
+ var scratchTrianglePoints = [
2102
+ new Cartesian3_default(),
2103
+ new Cartesian3_default(),
2104
+ new Cartesian3_default()
2105
+ ];
2106
+ TerrainPicker.prototype.rayIntersect = function(ray, tileTransform, cullBackFaces, mode, projection) {
2107
+ if (this._needsRebuild) {
2108
+ reset(this, tileTransform);
2109
+ }
2110
+ const invTransform = this._inverseTransform;
2111
+ const transformedRay = scratchTransformedRay;
2112
+ transformedRay.origin = Matrix4_default.multiplyByPoint(
2113
+ invTransform,
2114
+ ray.origin,
2115
+ transformedRay.origin
2116
+ );
2117
+ transformedRay.direction = Matrix4_default.multiplyByPointAsVector(
2118
+ invTransform,
2119
+ ray.direction,
2120
+ transformedRay.direction
2121
+ );
2122
+ const intersections = [];
2123
+ getNodesIntersectingRay(this._rootNode, transformedRay, intersections);
2124
+ return findClosestPointInClosestNode(
2125
+ this,
2126
+ intersections,
2127
+ ray,
2128
+ cullBackFaces,
2129
+ mode,
2130
+ projection
2131
+ );
2132
+ };
2133
+ function reset(terrainPicker, tileTransform) {
2134
+ Matrix4_default.inverse(tileTransform, terrainPicker._inverseTransform);
2135
+ terrainPicker._needsRebuild = false;
2136
+ const triangleCount = terrainPicker._indices.length / 3;
2137
+ const intersectingTriangles = new Uint32Array(triangleCount);
2138
+ for (let i = 0; i < triangleCount; ++i) {
2139
+ intersectingTriangles[i] = i;
2140
+ }
2141
+ terrainPicker._rootNode.intersectingTriangles = intersectingTriangles;
2142
+ terrainPicker._rootNode.children.length = 0;
2143
+ }
2144
+ var scratchAABBMin = new Cartesian3_default();
2145
+ var scratchAABBMax = new Cartesian3_default();
2146
+ function createAABBForNode(x, y, level) {
2147
+ const sizeAtLevel = 1 / Math.pow(2, level);
2148
+ const aabbMin = Cartesian3_default.fromElements(
2149
+ x * sizeAtLevel - 0.5,
2150
+ y * sizeAtLevel - 0.5,
2151
+ -0.5,
2152
+ scratchAABBMin
2153
+ );
2154
+ const aabbMax = Cartesian3_default.fromElements(
2155
+ (x + 1) * sizeAtLevel - 0.5,
2156
+ (y + 1) * sizeAtLevel - 0.5,
2157
+ 0.5,
2158
+ scratchAABBMax
2159
+ );
2160
+ return AxisAlignedBoundingBox_default.fromCorners(aabbMin, aabbMax);
2161
+ }
2162
+ function packTriangleBuffers(trianglePositionsBuffer, triangleIndicesBuffer, trianglePositions, triangleIndex, bufferIndex) {
2163
+ Cartesian3_default.pack(
2164
+ trianglePositions[0],
2165
+ trianglePositionsBuffer,
2166
+ 9 * bufferIndex
2167
+ );
2168
+ Cartesian3_default.pack(
2169
+ trianglePositions[1],
2170
+ trianglePositionsBuffer,
2171
+ 9 * bufferIndex + 3
2172
+ );
2173
+ Cartesian3_default.pack(
2174
+ trianglePositions[2],
2175
+ trianglePositionsBuffer,
2176
+ 9 * bufferIndex + 6
2177
+ );
2178
+ triangleIndicesBuffer[bufferIndex] = triangleIndex;
2179
+ }
2180
+ var scratchInterval = new Interval_default();
2181
+ function getNodesIntersectingRay(currentNode, ray, intersectingNodes) {
2182
+ const interval = IntersectionTests_default.rayAxisAlignedBoundingBox(
2183
+ ray,
2184
+ currentNode.aabb,
2185
+ scratchInterval
2186
+ );
2187
+ if (!defined_default(interval)) {
2188
+ return;
2189
+ }
2190
+ const isLeaf = !currentNode.children.length || currentNode.buildingChildren;
2191
+ if (isLeaf) {
2192
+ intersectingNodes.push({
2193
+ node: currentNode,
2194
+ interval: new Interval_default(interval.start, interval.stop)
2195
+ });
2196
+ return;
2197
+ }
2198
+ for (let i = 0; i < currentNode.children.length; i++) {
2199
+ getNodesIntersectingRay(currentNode.children[i], ray, intersectingNodes);
2200
+ }
2201
+ }
2202
+ function findClosestPointInClosestNode(terrainPicker, intersections, ray, cullBackFaces, mode, projection) {
2203
+ const sortedIntersections = intersections.sort(function(a, b) {
2204
+ return a.interval.start - b.interval.start;
2205
+ });
2206
+ let minT = Number.MAX_VALUE;
2207
+ for (let i = 0; i < sortedIntersections.length; i++) {
2208
+ const intersection = sortedIntersections[i];
2209
+ const intersectionResult = getClosestTriangleInNode(
2210
+ terrainPicker,
2211
+ ray,
2212
+ intersection.node,
2213
+ cullBackFaces,
2214
+ mode,
2215
+ projection
2216
+ );
2217
+ minT = Math.min(intersectionResult, minT);
2218
+ if (minT !== Number.MAX_VALUE) {
2219
+ break;
2220
+ }
2221
+ }
2222
+ if (minT !== Number.MAX_VALUE) {
2223
+ return Ray_default.getPoint(ray, minT);
2224
+ }
2225
+ return void 0;
2226
+ }
2227
+ function getClosestTriangleInNode(terrainPicker, ray, node, cullBackFaces, mode, projection) {
2228
+ let result = Number.MAX_VALUE;
2229
+ const encoding = terrainPicker._encoding;
2230
+ const indices = terrainPicker._indices;
2231
+ const vertices = terrainPicker._vertices;
2232
+ const triangleCount = node.intersectingTriangles.length;
2233
+ const isMaxLevel = node.level >= MAXIMUM_TERRAIN_PICKER_LEVEL;
2234
+ const shouldBuildChildren = !isMaxLevel && !node.buildingChildren;
2235
+ let trianglePositions;
2236
+ let triangleIndices;
2237
+ if (shouldBuildChildren) {
2238
+ trianglePositions = new Float64Array(triangleCount * 9);
2239
+ triangleIndices = new Uint32Array(triangleCount);
2240
+ }
2241
+ for (let i = 0; i < triangleCount; i++) {
2242
+ const triIndex = node.intersectingTriangles[i];
2243
+ const v0 = getVertexPosition(
2244
+ encoding,
2245
+ mode,
2246
+ projection,
2247
+ ray,
2248
+ vertices,
2249
+ indices[3 * triIndex],
2250
+ scratchTrianglePoints[0]
2251
+ );
2252
+ const v1 = getVertexPosition(
2253
+ encoding,
2254
+ mode,
2255
+ projection,
2256
+ ray,
2257
+ vertices,
2258
+ indices[3 * triIndex + 1],
2259
+ scratchTrianglePoints[1]
2260
+ );
2261
+ const v2 = getVertexPosition(
2262
+ encoding,
2263
+ mode,
2264
+ projection,
2265
+ ray,
2266
+ vertices,
2267
+ indices[3 * triIndex + 2],
2268
+ scratchTrianglePoints[2]
2269
+ );
2270
+ const triT = IntersectionTests_default.rayTriangleParametric(
2271
+ ray,
2272
+ v0,
2273
+ v1,
2274
+ v2,
2275
+ cullBackFaces
2276
+ );
2277
+ if (defined_default(triT) && triT < result && triT >= 0) {
2278
+ result = triT;
2279
+ }
2280
+ if (shouldBuildChildren) {
2281
+ packTriangleBuffers(
2282
+ trianglePositions,
2283
+ triangleIndices,
2284
+ scratchTrianglePoints,
2285
+ triIndex,
2286
+ i
2287
+ );
2288
+ }
2289
+ }
2290
+ if (shouldBuildChildren) {
2291
+ for (let childIdx = 0; childIdx < 4; childIdx++) {
2292
+ node.addChild(childIdx);
2293
+ }
2294
+ addTrianglesToChildrenNodes(
2295
+ terrainPicker._inverseTransform,
2296
+ node,
2297
+ triangleIndices,
2298
+ trianglePositions
2299
+ );
2300
+ }
2301
+ return result;
2302
+ }
2303
+ var scratchCartographic = new Cartographic_default();
2304
+ function getVertexPosition(encoding, mode, projection, ray, vertices, index, result) {
2305
+ let position = encoding.getExaggeratedPosition(vertices, index, result);
2306
+ if (mode === SceneMode_default.SCENE3D) {
2307
+ return position;
2308
+ }
2309
+ const ellipsoid = projection.ellipsoid;
2310
+ const positionCartographic = ellipsoid.cartesianToCartographic(
2311
+ position,
2312
+ scratchCartographic
2313
+ );
2314
+ position = projection.project(positionCartographic, result);
2315
+ position = Cartesian3_default.fromElements(
2316
+ position.z,
2317
+ position.x,
2318
+ position.y,
2319
+ result
2320
+ );
2321
+ const worldWidth = Math_default.TWO_PI * projection.ellipsoid.maximumRadius;
2322
+ const k = Math.round((ray.origin.y - position.y) / worldWidth);
2323
+ position.y += k * worldWidth;
2324
+ return position;
2325
+ }
2326
+ async function addTrianglesToChildrenNodes(inverseTransform, node, triangleIndices, trianglePositions) {
2327
+ node.buildingChildren = true;
2328
+ const inverseTransformPacked = new Float64Array(16);
2329
+ Matrix4_default.pack(inverseTransform, inverseTransformPacked, 0);
2330
+ const aabbArray = new Float64Array(6 * 4);
2331
+ for (let i = 0; i < 4; i++) {
2332
+ Cartesian3_default.pack(node.children[i].aabb.minimum, aabbArray, i * 6);
2333
+ Cartesian3_default.pack(node.children[i].aabb.maximum, aabbArray, i * 6 + 3);
2334
+ }
2335
+ const parameters = {
2336
+ aabbs: aabbArray,
2337
+ inverseTransform: inverseTransformPacked,
2338
+ triangleIndices,
2339
+ trianglePositions
2340
+ };
2341
+ const transferableObjects = [
2342
+ aabbArray.buffer,
2343
+ inverseTransformPacked.buffer,
2344
+ triangleIndices.buffer,
2345
+ trianglePositions.buffer
2346
+ ];
2347
+ const incrementallyBuildTerrainPickerPromise = incrementallyBuildTerrainPickerTaskProcessor.scheduleTask(
2348
+ parameters,
2349
+ transferableObjects
2350
+ );
2351
+ if (!defined_default(incrementallyBuildTerrainPickerPromise)) {
2352
+ node.buildingChildren = false;
2353
+ return;
2354
+ }
2355
+ const result = await incrementallyBuildTerrainPickerPromise;
2356
+ result.intersectingTrianglesArrays.forEach((buffer, index) => {
2357
+ if (defined_default(node.children[index])) {
2358
+ node.children[index].intersectingTriangles = new Uint32Array(buffer);
2359
+ }
2360
+ });
2361
+ node.intersectingTriangles = new Uint32Array(0);
2362
+ node.buildingChildren = false;
2363
+ }
2364
+ var TerrainPicker_default = TerrainPicker;
2365
+
2366
+ // packages/engine/Source/Core/TerrainMesh.js
2367
+ function TerrainMesh(center, vertices, indices, indexCountWithoutSkirts, vertexCountWithoutSkirts, minimumHeight, maximumHeight, rectangle, boundingSphere3D, occludeePointInScaledSpace, vertexStride, orientedBoundingBox, encoding, westIndicesSouthToNorth, southIndicesEastToWest, eastIndicesNorthToSouth, northIndicesWestToEast) {
2368
+ this.center = center;
2369
+ this.vertices = vertices;
2370
+ this.stride = vertexStride ?? 6;
2371
+ this.indices = indices;
2372
+ this.indexCountWithoutSkirts = indexCountWithoutSkirts;
2373
+ this.vertexCountWithoutSkirts = vertexCountWithoutSkirts;
2374
+ this.minimumHeight = minimumHeight;
2375
+ this.maximumHeight = maximumHeight;
2376
+ this.rectangle = rectangle;
2377
+ this.boundingSphere3D = boundingSphere3D;
2378
+ this.occludeePointInScaledSpace = occludeePointInScaledSpace;
2379
+ this.orientedBoundingBox = orientedBoundingBox;
2380
+ this.encoding = encoding;
2381
+ this.westIndicesSouthToNorth = westIndicesSouthToNorth;
2382
+ this.southIndicesEastToWest = southIndicesEastToWest;
2383
+ this.eastIndicesNorthToSouth = eastIndicesNorthToSouth;
2384
+ this.northIndicesWestToEast = northIndicesWestToEast;
2385
+ this._transform = new Matrix4_default();
2386
+ this._lastPickSceneMode = void 0;
2387
+ this._terrainPicker = new TerrainPicker_default(vertices, indices, encoding);
2388
+ }
2389
+ TerrainMesh.prototype.getTransform = function(mode, projection) {
2390
+ if (this._lastPickSceneMode === mode) {
2391
+ return this._transform;
2392
+ }
2393
+ this._terrainPicker.needsRebuild = true;
2394
+ if (!defined_default(mode) || mode === SceneMode_default.SCENE3D) {
2395
+ return computeTransform(this, this._transform);
2396
+ }
2397
+ return computeTransform2D(this, projection, this._transform);
2398
+ };
2399
+ function computeTransform(mesh, result) {
2400
+ const exaggeration = mesh.encoding.exaggeration;
2401
+ const exaggerationRelativeHeight = mesh.encoding.exaggerationRelativeHeight;
2402
+ const exaggeratedMinHeight = VerticalExaggeration_default.getHeight(
2403
+ mesh.minimumHeight,
2404
+ exaggeration,
2405
+ exaggerationRelativeHeight
2406
+ );
2407
+ const exaggeratedMaxHeight = VerticalExaggeration_default.getHeight(
2408
+ mesh.maximumHeight,
2409
+ exaggeration,
2410
+ exaggerationRelativeHeight
2411
+ );
2412
+ const obb = OrientedBoundingBox_default.fromRectangle(
2413
+ mesh.rectangle,
2414
+ exaggeratedMinHeight,
2415
+ exaggeratedMaxHeight,
2416
+ Ellipsoid_default.default,
2417
+ mesh.orientedBoundingBox
2418
+ );
2419
+ OrientedBoundingBox_default.computeTransformation(obb, result);
2420
+ const zScale = Matrix4_default.getScale(result, scratchScale).z;
2421
+ if (zScale <= Math_default.EPSILON16) {
2422
+ scratchScale.z = 1;
2423
+ Matrix4_default.setScale(result, scratchScale, result);
2424
+ }
2425
+ return result;
2426
+ }
2427
+ var scratchSWCartesian = new Cartesian3_default();
2428
+ var scratchNECartesian = new Cartesian3_default();
2429
+ var scratchSWCartographic = new Cartographic_default();
2430
+ var scratchNECartographic = new Cartographic_default();
2431
+ var scratchScale2D = new Cartesian3_default();
2432
+ var scratchCenter2D = new Cartesian3_default();
2433
+ var scratchScale = new Cartesian3_default();
2434
+ function computeTransform2D(mesh, projection, result) {
2435
+ const exaggeration = mesh.encoding.exaggeration;
2436
+ const exaggerationRelativeHeight = mesh.encoding.exaggerationRelativeHeight;
2437
+ const exaggeratedMinHeight = VerticalExaggeration_default.getHeight(
2438
+ mesh.minimumHeight,
2439
+ exaggeration,
2440
+ exaggerationRelativeHeight
2441
+ );
2442
+ const exaggeratedMaxHeight = VerticalExaggeration_default.getHeight(
2443
+ mesh.maximumHeight,
2444
+ exaggeration,
2445
+ exaggerationRelativeHeight
2446
+ );
2447
+ const southwest = projection.project(
2448
+ Cartographic_default.fromRadians(
2449
+ mesh.rectangle.west,
2450
+ mesh.rectangle.south,
2451
+ 0,
2452
+ scratchSWCartographic
2453
+ ),
2454
+ scratchSWCartesian
2455
+ );
2456
+ const northeast = projection.project(
2457
+ Cartographic_default.fromRadians(
2458
+ mesh.rectangle.east,
2459
+ mesh.rectangle.north,
2460
+ 0,
2461
+ scratchNECartographic
2462
+ ),
2463
+ scratchNECartesian
2464
+ );
2465
+ const heightRange = exaggeratedMaxHeight - exaggeratedMinHeight;
2466
+ const scale = Cartesian3_default.fromElements(
2467
+ northeast.x - southwest.x,
2468
+ northeast.y - southwest.y,
2469
+ heightRange > 0 ? heightRange : 1,
2470
+ // Avoid zero scale
2471
+ scratchScale2D
2472
+ );
2473
+ const center = Cartesian3_default.fromElements(
2474
+ southwest.x + scale.x * 0.5,
2475
+ southwest.y + scale.y * 0.5,
2476
+ exaggeratedMinHeight + scale.z * 0.5,
2477
+ scratchCenter2D
2478
+ );
2479
+ Matrix4_default.fromTranslation(center, result);
2480
+ Matrix4_default.setScale(result, scale, result);
2481
+ Matrix4_default.multiply(Transforms_default.SWIZZLE_3D_TO_2D_MATRIX, result, result);
2482
+ return result;
2483
+ }
2484
+ TerrainMesh.prototype.pick = function(ray, cullBackFaces, mode, projection) {
2485
+ const intersection = this._terrainPicker.rayIntersect(
2486
+ ray,
2487
+ this.getTransform(mode, projection),
2488
+ cullBackFaces,
2489
+ mode,
2490
+ projection
2491
+ );
2492
+ this._lastPickSceneMode = mode;
2493
+ return intersection;
2494
+ };
2495
+ TerrainMesh.prototype.updateExaggeration = function(exaggeration, exaggerationRelativeHeight) {
2496
+ this._terrainPicker._vertices = this.vertices;
2497
+ this._terrainPicker.needsRebuild = true;
2498
+ this._lastPickSceneMode = void 0;
2499
+ };
2500
+ TerrainMesh.prototype.updateSceneMode = function(mode) {
2501
+ this._terrainPicker.needsRebuild = true;
2502
+ this._lastPickSceneMode = void 0;
2503
+ };
2504
+ var TerrainMesh_default = TerrainMesh;
2505
+
2506
+ // packages/engine/Source/Core/Cesium3DTilesTerrainGeometryProcessor.js
2507
+ var Cesium3DTilesTerrainGeometryProcessor = {};
2508
+ var scratchGltfInfo = {
2509
+ positions: void 0,
2510
+ normals: void 0,
2511
+ indices: void 0,
2512
+ edgeIndicesWest: void 0,
2513
+ edgeIndicesSouth: void 0,
2514
+ edgeIndicesEast: void 0,
2515
+ edgeIndicesNorth: void 0
2516
+ };
2517
+ var scratchCenterCartographic = new Cartographic_default();
2518
+ var scratchCenterCartesian = new Cartesian3_default();
2519
+ var scratchEnuToEcef = new Matrix4_default();
2520
+ var scratchEcefToEnu = new Matrix4_default();
2521
+ var scratchTilesetTransform = new Matrix4_default();
2522
+ var scratchMinimumPositionENU = new Cartesian3_default();
2523
+ var scratchMaximumPositionENU = new Cartesian3_default();
2524
+ var scratchPosLocal = new Cartesian3_default();
2525
+ var scratchPosEcef = new Cartesian3_default();
2526
+ var scratchCartographic2 = new Cartographic_default();
2527
+ var scratchUV = new Cartesian2_default();
2528
+ var scratchNormal = new Cartesian3_default();
2529
+ var scratchNormalOct = new Cartesian2_default();
2530
+ var scratchGeodeticSurfaceNormal = new Cartesian3_default();
2531
+ var scratchPosEnu = new Cartesian3_default();
2532
+ var sortedEdgeCompare = function(a, b) {
2533
+ return a - b;
2534
+ };
2535
+ Cesium3DTilesTerrainGeometryProcessor.createMesh = async function(options) {
2536
+ options = options ?? Frozen_default.EMPTY_OBJECT;
2537
+ const {
2538
+ exaggeration = 1,
2539
+ exaggerationRelativeHeight = 0,
2540
+ hasVertexNormals,
2541
+ hasWebMercatorT,
2542
+ gltf,
2543
+ minimumHeight,
2544
+ maximumHeight,
2545
+ skirtHeight
2546
+ } = options;
2547
+ Check_default.typeOf.object("options.ellipsoid", options.ellipsoid);
2548
+ Check_default.typeOf.object("options.rectangle", options.rectangle);
2549
+ Check_default.typeOf.bool("options.hasVertexNormals", hasVertexNormals);
2550
+ Check_default.typeOf.bool("options.hasWebMercatorT", hasWebMercatorT);
2551
+ Check_default.typeOf.object("options.gltf", gltf);
2552
+ Check_default.typeOf.number("options.minimumHeight", minimumHeight);
2553
+ Check_default.typeOf.number("options.maximumHeight", maximumHeight);
2554
+ Check_default.typeOf.object("options.boundingSphere", options.boundingSphere);
2555
+ Check_default.typeOf.object(
2556
+ "options.orientedBoundingBox",
2557
+ options.orientedBoundingBox
2558
+ );
2559
+ Check_default.typeOf.object(
2560
+ "options.horizonOcclusionPoint",
2561
+ options.horizonOcclusionPoint
2562
+ );
2563
+ Check_default.typeOf.number("options.skirtHeight", skirtHeight);
2564
+ const hasExaggeration = exaggeration !== 1;
2565
+ const hasGeodeticSurfaceNormals = hasExaggeration;
2566
+ const boundingSphere = BoundingSphere_default.clone(
2567
+ options.boundingSphere,
2568
+ new BoundingSphere_default()
2569
+ );
2570
+ const orientedBoundingBox = OrientedBoundingBox_default.clone(
2571
+ options.orientedBoundingBox,
2572
+ new OrientedBoundingBox_default()
2573
+ );
2574
+ const horizonOcclusionPoint = Cartesian3_default.clone(
2575
+ options.horizonOcclusionPoint,
2576
+ new Cartesian3_default()
2577
+ );
2578
+ const ellipsoid = Ellipsoid_default.clone(options.ellipsoid, new Ellipsoid_default());
2579
+ const rectangle = Rectangle_default.clone(options.rectangle, new Rectangle_default());
2580
+ const hasMeshOptCompression = gltf.extensionsRequired !== void 0 && gltf.extensionsRequired.indexOf("EXT_meshopt_compression") !== -1;
2581
+ const decoderPromise = hasMeshOptCompression ? MeshoptDecoder.ready : Promise.resolve(void 0);
2582
+ await decoderPromise;
2583
+ const tileMinLongitude = rectangle.west;
2584
+ const tileMinLatitude = rectangle.south;
2585
+ const tileMaxLatitude = rectangle.north;
2586
+ const tileLengthLongitude = rectangle.width;
2587
+ const tileLengthLatitude = rectangle.height;
2588
+ const approximateCenterCartographic = Rectangle_default.center(
2589
+ rectangle,
2590
+ scratchCenterCartographic
2591
+ );
2592
+ approximateCenterCartographic.height = 0.5 * (minimumHeight + maximumHeight);
2593
+ const approximateCenterPosition = Cartographic_default.toCartesian(
2594
+ approximateCenterCartographic,
2595
+ ellipsoid,
2596
+ scratchCenterCartesian
2597
+ );
2598
+ const enuToEcef = Transforms_default.eastNorthUpToFixedFrame(
2599
+ approximateCenterPosition,
2600
+ ellipsoid,
2601
+ scratchEnuToEcef
2602
+ );
2603
+ const ecefToEnu = Matrix4_default.inverseTransformation(enuToEcef, scratchEcefToEnu);
2604
+ let tilesetTransform = Matrix4_default.unpack(
2605
+ gltf.nodes[0].matrix,
2606
+ 0,
2607
+ scratchTilesetTransform
2608
+ );
2609
+ tilesetTransform = Matrix4_default.multiply(
2610
+ Axis_default.Y_UP_TO_Z_UP,
2611
+ tilesetTransform,
2612
+ tilesetTransform
2613
+ );
2614
+ const gltfInfo = decodeGltf(gltf, hasVertexNormals, scratchGltfInfo);
2615
+ const skirtVertexCount = TerrainProvider_default.getSkirtVertexCount(
2616
+ gltfInfo.edgeIndicesWest,
2617
+ gltfInfo.edgeIndicesSouth,
2618
+ gltfInfo.edgeIndicesEast,
2619
+ gltfInfo.edgeIndicesNorth
2620
+ );
2621
+ const positionsLocalWithoutSkirts = gltfInfo.positions;
2622
+ const normalsWithoutSkirts = gltfInfo.normals;
2623
+ const indicesWithoutSkirts = gltfInfo.indices;
2624
+ const vertexCountWithoutSkirts = positionsLocalWithoutSkirts.length / 3;
2625
+ const vertexCountWithSkirts = vertexCountWithoutSkirts + skirtVertexCount;
2626
+ const indexCountWithoutSkirts = indicesWithoutSkirts.length;
2627
+ const skirtIndexCount = TerrainProvider_default.getSkirtIndexCountWithFilledCorners(skirtVertexCount);
2628
+ const SizedIndexTypeWithSkirts = vertexCountWithSkirts <= 65535 ? Uint16Array : Uint32Array;
2629
+ const indexBufferWithSkirts = new SizedIndexTypeWithSkirts(
2630
+ indexCountWithoutSkirts + skirtIndexCount
2631
+ );
2632
+ indexBufferWithSkirts.set(indicesWithoutSkirts);
2633
+ const westIndices = new SizedIndexTypeWithSkirts(gltfInfo.edgeIndicesWest);
2634
+ const southIndices = new SizedIndexTypeWithSkirts(gltfInfo.edgeIndicesSouth);
2635
+ const eastIndices = new SizedIndexTypeWithSkirts(gltfInfo.edgeIndicesEast);
2636
+ const northIndices = new SizedIndexTypeWithSkirts(gltfInfo.edgeIndicesNorth);
2637
+ const sortedWestIndices = new SizedIndexTypeWithSkirts(westIndices).sort();
2638
+ const sortedSouthIndices = new SizedIndexTypeWithSkirts(southIndices).sort();
2639
+ const sortedEastIndices = new SizedIndexTypeWithSkirts(eastIndices).sort();
2640
+ const sortedNorthIndices = new SizedIndexTypeWithSkirts(northIndices).sort();
2641
+ const southMercatorAngle = WebMercatorProjection_default.geodeticLatitudeToMercatorAngle(tileMinLatitude);
2642
+ const northMercatorAngle = WebMercatorProjection_default.geodeticLatitudeToMercatorAngle(tileMaxLatitude);
2643
+ const oneOverMercatorHeight = 1 / (northMercatorAngle - southMercatorAngle);
2644
+ let minPosEnu = Cartesian3_default.fromElements(
2645
+ Number.POSITIVE_INFINITY,
2646
+ Number.POSITIVE_INFINITY,
2647
+ Number.POSITIVE_INFINITY,
2648
+ scratchMinimumPositionENU
2649
+ );
2650
+ let maxPosEnu = Cartesian3_default.fromElements(
2651
+ Number.NEGATIVE_INFINITY,
2652
+ Number.NEGATIVE_INFINITY,
2653
+ Number.NEGATIVE_INFINITY,
2654
+ scratchMaximumPositionENU
2655
+ );
2656
+ const tempTerrainEncoding = new TerrainEncoding_default(
2657
+ boundingSphere.center,
2658
+ void 0,
2659
+ void 0,
2660
+ void 0,
2661
+ void 0,
2662
+ hasVertexNormals,
2663
+ hasWebMercatorT,
2664
+ hasGeodeticSurfaceNormals,
2665
+ exaggeration,
2666
+ exaggerationRelativeHeight
2667
+ );
2668
+ const tempBufferStride = tempTerrainEncoding.stride;
2669
+ const tempBuffer = new Float32Array(vertexCountWithSkirts * tempBufferStride);
2670
+ let tempBufferOffset = 0;
2671
+ for (let i = 0; i < vertexCountWithoutSkirts; i++) {
2672
+ const posLocal = Cartesian3_default.unpack(
2673
+ positionsLocalWithoutSkirts,
2674
+ i * 3,
2675
+ scratchPosLocal
2676
+ );
2677
+ const posECEF = Matrix4_default.multiplyByPoint(
2678
+ tilesetTransform,
2679
+ posLocal,
2680
+ scratchPosEcef
2681
+ );
2682
+ const cartographic = Cartographic_default.fromCartesian(
2683
+ posECEF,
2684
+ ellipsoid,
2685
+ scratchCartographic2
2686
+ );
2687
+ const { longitude, latitude, height } = cartographic;
2688
+ let u = (longitude - tileMinLongitude) / tileLengthLongitude;
2689
+ let v = (latitude - tileMinLatitude) / tileLengthLatitude;
2690
+ u = Math_default.clamp(u, 0, 1);
2691
+ v = Math_default.clamp(v, 0, 1);
2692
+ if (binarySearch_default(sortedWestIndices, i, sortedEdgeCompare) >= 0) {
2693
+ u = 0;
2694
+ } else if (binarySearch_default(sortedEastIndices, i, sortedEdgeCompare) >= 0) {
2695
+ u = 1;
2696
+ }
2697
+ if (binarySearch_default(sortedSouthIndices, i, sortedEdgeCompare) >= 0) {
2698
+ v = 0;
2699
+ } else if (binarySearch_default(sortedNorthIndices, i, sortedEdgeCompare) >= 0) {
2700
+ v = 1;
2701
+ }
2702
+ const uv = Cartesian2_default.fromElements(u, v, scratchUV);
2703
+ let normalOct;
2704
+ if (hasVertexNormals) {
2705
+ let normal = Cartesian3_default.unpack(
2706
+ normalsWithoutSkirts,
2707
+ i * 3,
2708
+ scratchNormal
2709
+ );
2710
+ normal = Matrix4_default.multiplyByPointAsVector(
2711
+ tilesetTransform,
2712
+ normal,
2713
+ scratchNormal
2714
+ );
2715
+ normal = Cartesian3_default.normalize(normal, scratchNormal);
2716
+ normalOct = AttributeCompression_default.octEncode(normal, scratchNormalOct);
2717
+ }
2718
+ let webMercatorT;
2719
+ if (hasWebMercatorT) {
2720
+ const mercatorAngle = WebMercatorProjection_default.geodeticLatitudeToMercatorAngle(latitude);
2721
+ webMercatorT = (mercatorAngle - southMercatorAngle) * oneOverMercatorHeight;
2722
+ }
2723
+ let geodeticSurfaceNormal;
2724
+ if (hasGeodeticSurfaceNormals) {
2725
+ geodeticSurfaceNormal = ellipsoid.geodeticSurfaceNormal(
2726
+ posECEF,
2727
+ scratchGeodeticSurfaceNormal
2728
+ );
2729
+ }
2730
+ tempBufferOffset = tempTerrainEncoding.encode(
2731
+ tempBuffer,
2732
+ tempBufferOffset,
2733
+ posECEF,
2734
+ uv,
2735
+ height,
2736
+ normalOct,
2737
+ webMercatorT,
2738
+ geodeticSurfaceNormal
2739
+ );
2740
+ const posEnu = Matrix4_default.multiplyByPoint(ecefToEnu, posECEF, scratchPosEnu);
2741
+ minPosEnu = Cartesian3_default.minimumByComponent(posEnu, minPosEnu, minPosEnu);
2742
+ maxPosEnu = Cartesian3_default.maximumByComponent(posEnu, maxPosEnu, maxPosEnu);
2743
+ }
2744
+ const mesh = new TerrainMesh_default(
2745
+ Cartesian3_default.clone(tempTerrainEncoding.center, new Cartesian3_default()),
2746
+ tempBuffer,
2747
+ indexBufferWithSkirts,
2748
+ indexCountWithoutSkirts,
2749
+ vertexCountWithoutSkirts,
2750
+ minimumHeight,
2751
+ maximumHeight,
2752
+ rectangle,
2753
+ BoundingSphere_default.clone(boundingSphere, new BoundingSphere_default()),
2754
+ Cartesian3_default.clone(horizonOcclusionPoint, new Cartesian3_default()),
2755
+ tempBufferStride,
2756
+ OrientedBoundingBox_default.clone(orientedBoundingBox, new OrientedBoundingBox_default()),
2757
+ tempTerrainEncoding,
2758
+ westIndices,
2759
+ southIndices,
2760
+ eastIndices,
2761
+ northIndices
2762
+ );
2763
+ addSkirtsToMesh(
2764
+ mesh,
2765
+ rectangle,
2766
+ ellipsoid,
2767
+ minPosEnu,
2768
+ maxPosEnu,
2769
+ enuToEcef,
2770
+ ecefToEnu,
2771
+ skirtHeight
2772
+ );
2773
+ return Promise.resolve(mesh);
2774
+ };
2775
+ var scratchMinUV = new Cartesian2_default();
2776
+ var scratchMaxUV = new Cartesian2_default();
2777
+ var scratchPolygonIndices = new Array(6);
2778
+ var scratchUvA = new Cartesian2_default();
2779
+ var scratchUvB = new Cartesian2_default();
2780
+ var scratchUvC = new Cartesian2_default();
2781
+ var scratchNormalA = new Cartesian3_default();
2782
+ var scratchNormalB = new Cartesian3_default();
2783
+ var scratchNormalC = new Cartesian3_default();
2784
+ var scratchCenterCartographicUpsample = new Cartographic_default();
2785
+ var scratchCenterCartesianUpsample = new Cartesian3_default();
2786
+ var scratchCartographicSkirt = new Cartographic_default();
2787
+ var scratchCartographicUpsample = new Cartographic_default();
2788
+ var scratchPosEcefSkirt = new Cartesian3_default();
2789
+ var scratchPosEcefUpsample = new Cartesian3_default();
2790
+ var scratchPosEnuSkirt = new Cartesian3_default();
2791
+ var scratchPosEnuUpsample = new Cartesian3_default();
2792
+ var scratchMinimumPositionENUSkirt = new Cartesian3_default();
2793
+ var scratchMaximumPositionENUSkirt = new Cartesian3_default();
2794
+ var scratchMinimumPositionENUUpsample = new Cartesian3_default();
2795
+ var scratchMaximumPositionENUUpsample = new Cartesian3_default();
2796
+ var scratchEnuToEcefUpsample = new Matrix4_default();
2797
+ var scratchEcefToEnuUpsample = new Matrix4_default();
2798
+ var scratchUVSkirt = new Cartesian2_default();
2799
+ var scratchUVUpsample = new Cartesian2_default();
2800
+ var scratchHorizonOcclusionPoint = new Cartesian3_default();
2801
+ var scratchBoundingSphere = new BoundingSphere_default();
2802
+ var scratchOrientedBoundingBox = new OrientedBoundingBox_default();
2803
+ var scratchAABBEnuSkirt = new AxisAlignedBoundingBox_default();
2804
+ var scratchNormalUpsample = new Cartesian3_default();
2805
+ var scratchNormalOctSkirt = new Cartesian2_default();
2806
+ var scratchNormalOctUpsample = new Cartesian2_default();
2807
+ var scratchGeodeticSurfaceNormalSkirt = new Cartesian3_default();
2808
+ var scratchGeodeticSurfaceNormalUpsample = new Cartesian3_default();
2809
+ function decodePositions(gltf) {
2810
+ const primitive = gltf.meshes[0].primitives[0];
2811
+ const accessor = gltf.accessors[primitive.attributes["POSITION"]];
2812
+ const bufferView = gltf.bufferViews[accessor.bufferView];
2813
+ const positionCount = accessor.count;
2814
+ const bufferViewMeshOpt = bufferView.extensions ? bufferView.extensions["EXT_meshopt_compression"] : void 0;
2815
+ if (bufferViewMeshOpt === void 0) {
2816
+ const buffer2 = gltf.buffers[bufferView.buffer].extras._pipeline.source;
2817
+ return new Float32Array(
2818
+ buffer2.buffer,
2819
+ buffer2.byteOffset + // offset from the start of the glb
2820
+ (bufferView.byteOffset ?? 0) + (accessor.byteOffset ?? 0),
2821
+ positionCount * 3
2822
+ );
2823
+ }
2824
+ const buffer = gltf.buffers[bufferViewMeshOpt.buffer].extras._pipeline.source;
2825
+ const compressedBuffer = new Uint8Array(
2826
+ buffer.buffer,
2827
+ buffer.byteOffset + // offset from the start of the glb
2828
+ (bufferViewMeshOpt.byteOffset ?? 0) + (accessor.byteOffset ?? 0),
2829
+ bufferViewMeshOpt.byteLength
2830
+ );
2831
+ const positionByteLength = bufferViewMeshOpt.byteStride;
2832
+ const PositionType = positionByteLength === 4 ? Uint8Array : Uint16Array;
2833
+ const positionsResult = new PositionType(positionCount * 4);
2834
+ MeshoptDecoder.decodeVertexBuffer(
2835
+ new Uint8Array(positionsResult.buffer),
2836
+ positionCount,
2837
+ positionByteLength,
2838
+ compressedBuffer
2839
+ );
2840
+ const positionStorageValueMax = (1 << positionsResult.BYTES_PER_ELEMENT * 8) - 1;
2841
+ const positions = new Float32Array(positionCount * 3);
2842
+ for (let p = 0; p < positionCount; p++) {
2843
+ positions[p * 3 + 0] = positionsResult[p * 4 + 0] / positionStorageValueMax;
2844
+ positions[p * 3 + 1] = positionsResult[p * 4 + 1] / positionStorageValueMax;
2845
+ positions[p * 3 + 2] = positionsResult[p * 4 + 2] / positionStorageValueMax;
2846
+ }
2847
+ return positions;
2848
+ }
2849
+ function decodeNormals(gltf) {
2850
+ const primitive = gltf.meshes[0].primitives[0];
2851
+ const accessor = gltf.accessors[primitive.attributes["NORMAL"]];
2852
+ const bufferView = gltf.bufferViews[accessor.bufferView];
2853
+ const normalCount = accessor.count;
2854
+ const bufferViewMeshOpt = bufferView.extensions ? bufferView.extensions["EXT_meshopt_compression"] : void 0;
2855
+ if (bufferViewMeshOpt === void 0) {
2856
+ const buffer2 = gltf.buffers[bufferView.buffer].extras._pipeline.source;
2857
+ return new Float32Array(
2858
+ buffer2.buffer,
2859
+ buffer2.byteOffset + // offset from the start of the glb
2860
+ (bufferView.byteOffset ?? 0) + (accessor.byteOffset ?? 0),
2861
+ normalCount * 3
2862
+ );
2863
+ }
2864
+ const buffer = gltf.buffers[bufferViewMeshOpt.buffer].extras._pipeline.source;
2865
+ const compressedBuffer = new Uint8Array(
2866
+ buffer.buffer,
2867
+ buffer.byteOffset + // offset from the start of the glb
2868
+ (bufferViewMeshOpt.byteOffset ?? 0) + (accessor.byteOffset ?? 0),
2869
+ bufferViewMeshOpt.byteLength
2870
+ );
2871
+ const normalByteLength = bufferViewMeshOpt.byteStride;
2872
+ const normalsResult = new Int8Array(normalCount * normalByteLength);
2873
+ MeshoptDecoder.decodeVertexBuffer(
2874
+ new Uint8Array(normalsResult.buffer),
2875
+ normalCount,
2876
+ normalByteLength,
2877
+ compressedBuffer
2878
+ );
2879
+ const normals = new Float32Array(normalCount * 3);
2880
+ for (let i = 0; i < normalCount; i++) {
2881
+ let octX = Math.max(normalsResult[i * 4 + 0] / 127, -1);
2882
+ let octY = Math.max(normalsResult[i * 4 + 1] / 127, -1);
2883
+ const octZ = 1 - (Math.abs(octX) + Math.abs(octY));
2884
+ if (octZ < 0) {
2885
+ const oldX = octX;
2886
+ const oldY = octY;
2887
+ octX = (1 - Math.abs(oldY)) * Math_default.signNotZero(oldX);
2888
+ octY = (1 - Math.abs(oldX)) * Math_default.signNotZero(oldY);
2889
+ }
2890
+ let normal = scratchNormal;
2891
+ normal.x = octX;
2892
+ normal.y = octY;
2893
+ normal.z = octZ;
2894
+ normal = Cartesian3_default.normalize(normal, scratchNormal);
2895
+ normals[i * 3 + 0] = normal.x;
2896
+ normals[i * 3 + 1] = normal.y;
2897
+ normals[i * 3 + 2] = normal.z;
2898
+ }
2899
+ return normals;
2900
+ }
2901
+ function decodeIndices(gltf) {
2902
+ const primitive = gltf.meshes[0].primitives[0];
2903
+ const accessor = gltf.accessors[primitive.indices];
2904
+ const bufferView = gltf.bufferViews[accessor.bufferView];
2905
+ const indexCount = accessor.count;
2906
+ const SizedIndexType = accessor.componentType === ComponentDatatype_default.UNSIGNED_SHORT ? Uint16Array : Uint32Array;
2907
+ const bufferViewMeshOpt = bufferView.extensions ? bufferView.extensions["EXT_meshopt_compression"] : void 0;
2908
+ if (bufferViewMeshOpt === void 0) {
2909
+ const buffer2 = gltf.buffers[bufferView.buffer].extras._pipeline.source;
2910
+ return new SizedIndexType(
2911
+ buffer2.buffer,
2912
+ buffer2.byteOffset + // offset from the glb
2913
+ (bufferView.byteOffset ?? 0) + (accessor.byteOffset ?? 0),
2914
+ indexCount
2915
+ );
2916
+ }
2917
+ const buffer = gltf.buffers[bufferViewMeshOpt.buffer].extras._pipeline.source;
2918
+ const compressedBuffer = new Uint8Array(
2919
+ buffer.buffer,
2920
+ buffer.byteOffset + // offset from the start of the glb
2921
+ (bufferViewMeshOpt.byteOffset ?? 0) + (accessor.byteOffset ?? 0),
2922
+ bufferViewMeshOpt.byteLength
2923
+ );
2924
+ const indices = new SizedIndexType(indexCount);
2925
+ MeshoptDecoder.decodeIndexBuffer(
2926
+ new Uint8Array(indices.buffer),
2927
+ indexCount,
2928
+ bufferViewMeshOpt.byteStride,
2929
+ compressedBuffer
2930
+ );
2931
+ return indices;
2932
+ }
2933
+ function decodeEdgeIndices(gltf, name) {
2934
+ const primitive = gltf.meshes[0].primitives[0];
2935
+ const accessor = gltf.accessors[primitive.extensions.CESIUM_tile_edges[name]];
2936
+ const bufferView = gltf.bufferViews[accessor.bufferView];
2937
+ const indexCount = accessor.count;
2938
+ const SizedIndexType = accessor.componentType === ComponentDatatype_default.UNSIGNED_SHORT ? Uint16Array : Uint32Array;
2939
+ const bufferViewMeshOpt = bufferView.extensions ? bufferView.extensions["EXT_meshopt_compression"] : void 0;
2940
+ if (bufferViewMeshOpt === void 0) {
2941
+ const buffer2 = gltf.buffers[bufferView.buffer].extras._pipeline.source;
2942
+ return new SizedIndexType(
2943
+ buffer2.buffer,
2944
+ buffer2.byteOffset + // offset from the glb
2945
+ (bufferView.byteOffset ?? 0) + (accessor.byteOffset ?? 0),
2946
+ indexCount
2947
+ );
2948
+ }
2949
+ const buffer = gltf.buffers[bufferViewMeshOpt.buffer].extras._pipeline.source;
2950
+ const compressedBuffer = new Uint8Array(
2951
+ buffer.buffer,
2952
+ buffer.byteOffset + // offset from the start of the glb
2953
+ (bufferViewMeshOpt.byteOffset ?? 0) + (accessor.byteOffset ?? 0),
2954
+ bufferViewMeshOpt.byteLength
2955
+ );
2956
+ const indices = new SizedIndexType(indexCount);
2957
+ const indexByteLength = bufferViewMeshOpt.byteStride;
2958
+ MeshoptDecoder.decodeIndexSequence(
2959
+ new Uint8Array(indices.buffer),
2960
+ indexCount,
2961
+ indexByteLength,
2962
+ compressedBuffer
2963
+ );
2964
+ return indices;
2965
+ }
2966
+ function decodeGltf(gltf, hasNormals, result) {
2967
+ result.positions = decodePositions(gltf);
2968
+ result.normals = hasNormals ? decodeNormals(gltf) : void 0;
2969
+ result.indices = decodeIndices(gltf);
2970
+ result.edgeIndicesWest = decodeEdgeIndices(gltf, "left");
2971
+ result.edgeIndicesSouth = decodeEdgeIndices(gltf, "bottom");
2972
+ result.edgeIndicesEast = decodeEdgeIndices(gltf, "right");
2973
+ result.edgeIndicesNorth = decodeEdgeIndices(gltf, "top");
2974
+ return result;
2975
+ }
2976
+ Cesium3DTilesTerrainGeometryProcessor.upsampleMesh = function(options) {
2977
+ options = options ?? Frozen_default.EMPTY_OBJECT;
2978
+ const {
2979
+ isEastChild,
2980
+ isNorthChild,
2981
+ parentMinimumHeight,
2982
+ parentMaximumHeight,
2983
+ skirtHeight
2984
+ } = options;
2985
+ Check_default.typeOf.bool("options.isEastChild", isEastChild);
2986
+ Check_default.typeOf.bool("options.isNorthChild", isNorthChild);
2987
+ Check_default.typeOf.object("options.parentVertices", options.parentVertices);
2988
+ Check_default.typeOf.object("options.parentIndices", options.parentIndices);
2989
+ Check_default.typeOf.number(
2990
+ "options.parentVertexCountWithoutSkirts",
2991
+ options.parentVertexCountWithoutSkirts
2992
+ );
2993
+ Check_default.typeOf.number(
2994
+ "options.parentIndexCountWithoutSkirts",
2995
+ options.parentIndexCountWithoutSkirts
2996
+ );
2997
+ Check_default.typeOf.number("options.parentMinimumHeight", parentMinimumHeight);
2998
+ Check_default.typeOf.number("options.parentMaximumHeight", parentMaximumHeight);
2999
+ Check_default.typeOf.object("options.parentEncoding", options.parentEncoding);
3000
+ Check_default.typeOf.object("options.rectangle", options.rectangle);
3001
+ Check_default.typeOf.number("options.skirtHeight", skirtHeight);
3002
+ Check_default.typeOf.object("options.ellipsoid", options.ellipsoid);
3003
+ const indexCount = options.parentIndexCountWithoutSkirts;
3004
+ const indices = options.parentIndices;
3005
+ const vertexCount = options.parentVertexCountWithoutSkirts;
3006
+ const vertexBuffer = options.parentVertices;
3007
+ const encoding = TerrainEncoding_default.clone(
3008
+ options.parentEncoding,
3009
+ new TerrainEncoding_default()
3010
+ );
3011
+ const hasVertexNormals = encoding.hasVertexNormals;
3012
+ const hasWebMercatorT = encoding.hasWebMercatorT;
3013
+ const exaggeration = encoding.exaggeration;
3014
+ const exaggerationRelativeHeight = encoding.exaggerationRelativeHeight;
3015
+ const hasExaggeration = exaggeration !== 1;
3016
+ const hasGeodeticSurfaceNormals = hasExaggeration;
3017
+ const upsampleRectangle = Rectangle_default.clone(options.rectangle, new Rectangle_default());
3018
+ const ellipsoid = Ellipsoid_default.clone(options.ellipsoid);
3019
+ const upsampledTriIDs = [];
3020
+ const upsampledUVs = [];
3021
+ const upsampledBarys = [];
3022
+ const upsampledIndices = [];
3023
+ const upsampledWestIndices = [];
3024
+ const upsampledSouthIndices = [];
3025
+ const upsampledEastIndices = [];
3026
+ const upsampledNorthIndices = [];
3027
+ clipTileFromQuadrant(
3028
+ isEastChild,
3029
+ isNorthChild,
3030
+ indexCount,
3031
+ indices,
3032
+ vertexCount,
3033
+ vertexBuffer,
3034
+ encoding,
3035
+ upsampledIndices,
3036
+ upsampledWestIndices,
3037
+ upsampledSouthIndices,
3038
+ upsampledEastIndices,
3039
+ upsampledNorthIndices,
3040
+ upsampledTriIDs,
3041
+ upsampledBarys,
3042
+ upsampledUVs
3043
+ );
3044
+ const approximateCenterCartographic = Rectangle_default.center(
3045
+ upsampleRectangle,
3046
+ scratchCenterCartographicUpsample
3047
+ );
3048
+ approximateCenterCartographic.height = 0.5 * (parentMinimumHeight + parentMaximumHeight);
3049
+ const approximateCenterPosition = Cartographic_default.toCartesian(
3050
+ approximateCenterCartographic,
3051
+ ellipsoid,
3052
+ scratchCenterCartesianUpsample
3053
+ );
3054
+ const upsampledVertexCountWithoutSkirts = upsampledTriIDs.length;
3055
+ const upsampledTerrainEncoding = new TerrainEncoding_default(
3056
+ approximateCenterPosition,
3057
+ void 0,
3058
+ void 0,
3059
+ void 0,
3060
+ void 0,
3061
+ hasVertexNormals,
3062
+ hasWebMercatorT,
3063
+ hasGeodeticSurfaceNormals,
3064
+ exaggeration,
3065
+ exaggerationRelativeHeight
3066
+ );
3067
+ const upsampledVertexBufferStride = upsampledTerrainEncoding.stride;
3068
+ const upsampledSkirtVertexCount = TerrainProvider_default.getSkirtVertexCount(
3069
+ upsampledWestIndices,
3070
+ upsampledSouthIndices,
3071
+ upsampledEastIndices,
3072
+ upsampledNorthIndices
3073
+ );
3074
+ const upsampledVertexCountWithSkirts = upsampledVertexCountWithoutSkirts + upsampledSkirtVertexCount;
3075
+ const upsampledIndexCountWithoutSkirts = upsampledIndices.length;
3076
+ const upsampledSkirtIndexCount = TerrainProvider_default.getSkirtIndexCountWithFilledCorners(
3077
+ upsampledSkirtVertexCount
3078
+ );
3079
+ const upsampledIndexCountWithSkirts = upsampledIndexCountWithoutSkirts + upsampledSkirtIndexCount;
3080
+ const SizedIndexTypeWithSkirts = upsampledVertexCountWithSkirts <= 65535 ? Uint16Array : Uint32Array;
3081
+ const upsampledIndexBuffer = new SizedIndexTypeWithSkirts(
3082
+ upsampledIndexCountWithSkirts
3083
+ );
3084
+ upsampledIndexBuffer.set(upsampledIndices);
3085
+ const upsampledWestIndicesBuffer = new SizedIndexTypeWithSkirts(
3086
+ upsampledWestIndices
3087
+ );
3088
+ const upsampledSouthIndicesBuffer = new SizedIndexTypeWithSkirts(
3089
+ upsampledSouthIndices
3090
+ );
3091
+ const upsampledEastIndicesBuffer = new SizedIndexTypeWithSkirts(
3092
+ upsampledEastIndices
3093
+ );
3094
+ const upsampledNorthIndicesBuffer = new SizedIndexTypeWithSkirts(
3095
+ upsampledNorthIndices
3096
+ );
3097
+ const upsampledVertexBuffer = new Float32Array(
3098
+ upsampledVertexCountWithSkirts * upsampledVertexBufferStride
3099
+ );
3100
+ let upsampledVertexBufferOffset = 0;
3101
+ const enuToEcef = Transforms_default.eastNorthUpToFixedFrame(
3102
+ approximateCenterPosition,
3103
+ ellipsoid,
3104
+ scratchEnuToEcefUpsample
3105
+ );
3106
+ const ecefToEnu = Matrix4_default.inverseTransformation(
3107
+ enuToEcef,
3108
+ scratchEcefToEnuUpsample
3109
+ );
3110
+ const minimumLongitude = upsampleRectangle.west;
3111
+ const maximumLongitude = upsampleRectangle.east;
3112
+ const minimumLatitude = upsampleRectangle.south;
3113
+ const maximumLatitude = upsampleRectangle.north;
3114
+ const southMercatorAngle = WebMercatorProjection_default.geodeticLatitudeToMercatorAngle(minimumLatitude);
3115
+ const northMercatorAngle = WebMercatorProjection_default.geodeticLatitudeToMercatorAngle(maximumLatitude);
3116
+ const oneOverMercatorHeight = 1 / (northMercatorAngle - southMercatorAngle);
3117
+ let minimumHeight = Number.POSITIVE_INFINITY;
3118
+ let maximumHeight = Number.NEGATIVE_INFINITY;
3119
+ let minPosEnu = Cartesian3_default.fromElements(
3120
+ Number.POSITIVE_INFINITY,
3121
+ Number.POSITIVE_INFINITY,
3122
+ Number.POSITIVE_INFINITY,
3123
+ scratchMinimumPositionENUUpsample
3124
+ );
3125
+ let maxPosEnu = Cartesian3_default.fromElements(
3126
+ Number.NEGATIVE_INFINITY,
3127
+ Number.NEGATIVE_INFINITY,
3128
+ Number.NEGATIVE_INFINITY,
3129
+ scratchMaximumPositionENUUpsample
3130
+ );
3131
+ for (let i = 0; i < upsampledVertexCountWithoutSkirts; i++) {
3132
+ const triId = upsampledTriIDs[i];
3133
+ const indexA = indices[triId * 3 + 0];
3134
+ const indexB = indices[triId * 3 + 1];
3135
+ const indexC = indices[triId * 3 + 2];
3136
+ const uv = scratchUVUpsample;
3137
+ uv.x = upsampledUVs[i * 2 + 0];
3138
+ uv.y = upsampledUVs[i * 2 + 1];
3139
+ const u = uv.x;
3140
+ const v = uv.y;
3141
+ const baryA = upsampledBarys[i * 2 + 0];
3142
+ const baryB = upsampledBarys[i * 2 + 1];
3143
+ const baryC = 1 - baryA - baryB;
3144
+ const heightA = encoding.decodeHeight(vertexBuffer, indexA);
3145
+ const heightB = encoding.decodeHeight(vertexBuffer, indexB);
3146
+ const heightC = encoding.decodeHeight(vertexBuffer, indexC);
3147
+ const height = heightA * baryA + heightB * baryB + heightC * baryC;
3148
+ minimumHeight = Math.min(height, minimumHeight);
3149
+ maximumHeight = Math.max(height, maximumHeight);
3150
+ const lon = Math_default.lerp(minimumLongitude, maximumLongitude, u);
3151
+ const lat = Math_default.lerp(minimumLatitude, maximumLatitude, v);
3152
+ const carto = Cartographic_default.fromRadians(
3153
+ lon,
3154
+ lat,
3155
+ height,
3156
+ scratchCartographicUpsample
3157
+ );
3158
+ const position = Cartographic_default.toCartesian(
3159
+ carto,
3160
+ ellipsoid,
3161
+ scratchPosEcefUpsample
3162
+ );
3163
+ const posEnu = Matrix4_default.multiplyByPoint(
3164
+ ecefToEnu,
3165
+ position,
3166
+ scratchPosEnuUpsample
3167
+ );
3168
+ minPosEnu = Cartesian3_default.minimumByComponent(posEnu, minPosEnu, minPosEnu);
3169
+ maxPosEnu = Cartesian3_default.maximumByComponent(posEnu, maxPosEnu, maxPosEnu);
3170
+ let normalOct;
3171
+ if (hasVertexNormals) {
3172
+ const normalA = encoding.decodeNormal(
3173
+ vertexBuffer,
3174
+ indexA,
3175
+ scratchNormalA
3176
+ );
3177
+ const normalB = encoding.decodeNormal(
3178
+ vertexBuffer,
3179
+ indexB,
3180
+ scratchNormalB
3181
+ );
3182
+ const normalC = encoding.decodeNormal(
3183
+ vertexBuffer,
3184
+ indexC,
3185
+ scratchNormalC
3186
+ );
3187
+ let normal = Cartesian3_default.fromElements(
3188
+ normalA.x * baryA + normalB.x * baryB + normalC.x * baryC,
3189
+ normalA.y * baryA + normalB.y * baryB + normalC.y * baryC,
3190
+ normalA.z * baryA + normalB.z * baryB + normalC.z * baryC,
3191
+ scratchNormalUpsample
3192
+ );
3193
+ normal = Cartesian3_default.normalize(normal, scratchNormalUpsample);
3194
+ normalOct = AttributeCompression_default.octEncode(
3195
+ normal,
3196
+ scratchNormalOctUpsample
3197
+ );
3198
+ }
3199
+ let webMercatorT;
3200
+ if (hasWebMercatorT) {
3201
+ const mercatorAngle = WebMercatorProjection_default.geodeticLatitudeToMercatorAngle(lat);
3202
+ webMercatorT = (mercatorAngle - southMercatorAngle) * oneOverMercatorHeight;
3203
+ }
3204
+ let geodeticSurfaceNormal;
3205
+ if (hasGeodeticSurfaceNormals) {
3206
+ geodeticSurfaceNormal = ellipsoid.geodeticSurfaceNormal(
3207
+ position,
3208
+ scratchGeodeticSurfaceNormalUpsample
3209
+ );
3210
+ }
3211
+ upsampledVertexBufferOffset = upsampledTerrainEncoding.encode(
3212
+ upsampledVertexBuffer,
3213
+ upsampledVertexBufferOffset,
3214
+ position,
3215
+ uv,
3216
+ height,
3217
+ normalOct,
3218
+ webMercatorT,
3219
+ geodeticSurfaceNormal
3220
+ );
3221
+ }
3222
+ const orientedBoundingBox = OrientedBoundingBox_default.fromRectangle(
3223
+ upsampleRectangle,
3224
+ minimumHeight,
3225
+ maximumHeight,
3226
+ ellipsoid,
3227
+ scratchOrientedBoundingBox
3228
+ );
3229
+ const boundingSphere = BoundingSphere_default.fromVertices(
3230
+ upsampledVertexBuffer,
3231
+ upsampledTerrainEncoding.center,
3232
+ upsampledVertexBufferStride,
3233
+ scratchBoundingSphere
3234
+ );
3235
+ const occluder = new EllipsoidalOccluder_default(ellipsoid);
3236
+ const horizonOcclusionPoint = occluder.computeHorizonCullingPointFromVerticesPossiblyUnderEllipsoid(
3237
+ upsampledTerrainEncoding.center,
3238
+ // vector from ellipsoid center to horizon occlusion point
3239
+ upsampledVertexBuffer,
3240
+ upsampledVertexBufferStride,
3241
+ upsampledTerrainEncoding.center,
3242
+ minimumHeight,
3243
+ scratchHorizonOcclusionPoint
3244
+ );
3245
+ const upsampledMesh = new TerrainMesh_default(
3246
+ Cartesian3_default.clone(upsampledTerrainEncoding.center, new Cartesian3_default()),
3247
+ upsampledVertexBuffer,
3248
+ upsampledIndexBuffer,
3249
+ upsampledIndexCountWithoutSkirts,
3250
+ upsampledVertexCountWithoutSkirts,
3251
+ minimumHeight,
3252
+ maximumHeight,
3253
+ upsampleRectangle,
3254
+ BoundingSphere_default.clone(boundingSphere),
3255
+ Cartesian3_default.clone(horizonOcclusionPoint),
3256
+ upsampledVertexBufferStride,
3257
+ OrientedBoundingBox_default.clone(orientedBoundingBox),
3258
+ upsampledTerrainEncoding,
3259
+ upsampledWestIndicesBuffer,
3260
+ upsampledSouthIndicesBuffer,
3261
+ upsampledEastIndicesBuffer,
3262
+ upsampledNorthIndicesBuffer
3263
+ );
3264
+ addSkirtsToMesh(
3265
+ upsampledMesh,
3266
+ upsampleRectangle,
3267
+ ellipsoid,
3268
+ minPosEnu,
3269
+ maxPosEnu,
3270
+ enuToEcef,
3271
+ ecefToEnu,
3272
+ skirtHeight
3273
+ );
3274
+ return upsampledMesh;
3275
+ };
3276
+ function addSkirtsToMesh(mesh, rectangle, ellipsoid, enuMinimum, enuMaximum, enuToEcef, ecefToEnu, skirtHeight) {
3277
+ const { encoding } = mesh;
3278
+ const vertexStride = encoding.stride;
3279
+ const vertexBuffer = mesh.vertices;
3280
+ const {
3281
+ hasVertexNormals,
3282
+ hasWebMercatorT,
3283
+ exaggeration,
3284
+ exaggerationRelativeHeight
3285
+ } = encoding;
3286
+ const hasExaggeration = exaggeration !== 1;
3287
+ const hasGeodeticSurfaceNormals = hasExaggeration;
3288
+ const vertexCountWithoutSkirts = mesh.vertexCountWithoutSkirts;
3289
+ let vertexBufferOffset = vertexCountWithoutSkirts * vertexStride;
3290
+ const vertexCountWithSkirts = vertexBuffer.length / vertexStride;
3291
+ const skirtVertexCount = vertexCountWithSkirts - vertexCountWithoutSkirts;
3292
+ const indices = mesh.indices;
3293
+ const indexCountWithoutSkirts = mesh.indexCountWithoutSkirts;
3294
+ const westIndices = mesh.westIndicesSouthToNorth;
3295
+ const southIndices = mesh.southIndicesEastToWest;
3296
+ const eastIndices = mesh.eastIndicesNorthToSouth;
3297
+ const northIndices = mesh.northIndicesWestToEast;
3298
+ TerrainProvider_default.addSkirtIndicesWithFilledCorners(
3299
+ westIndices,
3300
+ southIndices,
3301
+ eastIndices,
3302
+ northIndices,
3303
+ vertexCountWithoutSkirts,
3304
+ indices,
3305
+ indexCountWithoutSkirts
3306
+ );
3307
+ const westOffset = 0;
3308
+ const southOffset = westOffset + westIndices.length;
3309
+ const eastOffset = southOffset + southIndices.length;
3310
+ const northOffset = eastOffset + eastIndices.length;
3311
+ const edges = [westIndices, southIndices, eastIndices, northIndices];
3312
+ const edgeIndexOffset = [westOffset, southOffset, eastOffset, northOffset];
3313
+ const edgeLongitudeSign = [-1, 0, 1, 0];
3314
+ const edgeLatitudeSign = [0, -1, 0, 1];
3315
+ const minimumPositionENUWithSkirts = Cartesian3_default.clone(
3316
+ enuMinimum,
3317
+ scratchMinimumPositionENUSkirt
3318
+ );
3319
+ const maximumPositionENUWithSkirts = Cartesian3_default.clone(
3320
+ enuMaximum,
3321
+ scratchMaximumPositionENUSkirt
3322
+ );
3323
+ const maximumHeight = mesh.maximumHeight;
3324
+ const minimumHeightWithSkirts = mesh.minimumHeight - skirtHeight;
3325
+ for (let skirtId = 0; skirtId < skirtVertexCount; skirtId++) {
3326
+ let side = 0;
3327
+ for (side = 0; side < 3; side++) {
3328
+ if (skirtId < edgeIndexOffset[side + 1]) {
3329
+ break;
3330
+ }
3331
+ }
3332
+ const vertexIndex = edges[side][skirtId - edgeIndexOffset[side]];
3333
+ const uv = encoding.decodeTextureCoordinates(
3334
+ vertexBuffer,
3335
+ vertexIndex,
3336
+ scratchUVSkirt
3337
+ );
3338
+ const skirtLonLatOffsetPercent = 1e-4;
3339
+ const longitudeT = uv.x + edgeLongitudeSign[side] * skirtLonLatOffsetPercent;
3340
+ const latitudeT = uv.y + edgeLatitudeSign[side] * skirtLonLatOffsetPercent;
3341
+ const longitude = Math_default.lerp(
3342
+ rectangle.west,
3343
+ rectangle.east,
3344
+ longitudeT
3345
+ );
3346
+ const latitude = Math_default.clamp(
3347
+ Math_default.lerp(rectangle.south, rectangle.north, latitudeT),
3348
+ -Math_default.PI_OVER_TWO,
3349
+ +Math_default.PI_OVER_TWO
3350
+ );
3351
+ const vertHeight = encoding.decodeHeight(vertexBuffer, vertexIndex);
3352
+ const height = vertHeight - skirtHeight;
3353
+ const cartographic = Cartographic_default.fromRadians(
3354
+ longitude,
3355
+ latitude,
3356
+ height,
3357
+ scratchCartographicSkirt
3358
+ );
3359
+ const positionEcef = Cartographic_default.toCartesian(
3360
+ cartographic,
3361
+ ellipsoid,
3362
+ scratchPosEcefSkirt
3363
+ );
3364
+ let normalOct;
3365
+ if (hasVertexNormals) {
3366
+ normalOct = encoding.getOctEncodedNormal(
3367
+ vertexBuffer,
3368
+ vertexIndex,
3369
+ scratchNormalOctSkirt
3370
+ );
3371
+ }
3372
+ let webMercatorT;
3373
+ if (hasWebMercatorT) {
3374
+ webMercatorT = encoding.decodeWebMercatorT(vertexBuffer, vertexIndex);
3375
+ }
3376
+ let geodeticSurfaceNormal;
3377
+ if (hasGeodeticSurfaceNormals) {
3378
+ geodeticSurfaceNormal = ellipsoid.geodeticSurfaceNormal(
3379
+ positionEcef,
3380
+ scratchGeodeticSurfaceNormalSkirt
3381
+ );
3382
+ }
3383
+ vertexBufferOffset = encoding.encode(
3384
+ vertexBuffer,
3385
+ vertexBufferOffset,
3386
+ positionEcef,
3387
+ uv,
3388
+ height,
3389
+ normalOct,
3390
+ webMercatorT,
3391
+ geodeticSurfaceNormal
3392
+ );
3393
+ const positionENU = Matrix4_default.multiplyByPoint(
3394
+ ecefToEnu,
3395
+ positionEcef,
3396
+ scratchPosEnuSkirt
3397
+ );
3398
+ Cartesian3_default.minimumByComponent(
3399
+ positionENU,
3400
+ minimumPositionENUWithSkirts,
3401
+ minimumPositionENUWithSkirts
3402
+ );
3403
+ Cartesian3_default.maximumByComponent(
3404
+ positionENU,
3405
+ maximumPositionENUWithSkirts,
3406
+ maximumPositionENUWithSkirts
3407
+ );
3408
+ }
3409
+ const aabbEnuWithSkirts = AxisAlignedBoundingBox_default.fromCorners(
3410
+ minimumPositionENUWithSkirts,
3411
+ maximumPositionENUWithSkirts,
3412
+ scratchAABBEnuSkirt
3413
+ );
3414
+ const encodingWithSkirts = new TerrainEncoding_default(
3415
+ encoding.center,
3416
+ aabbEnuWithSkirts,
3417
+ minimumHeightWithSkirts,
3418
+ maximumHeight,
3419
+ enuToEcef,
3420
+ encoding.hasVertexNormals,
3421
+ encoding.hasWebMercatorT,
3422
+ hasGeodeticSurfaceNormals,
3423
+ exaggeration,
3424
+ exaggerationRelativeHeight
3425
+ );
3426
+ if (encoding.quantization !== encodingWithSkirts.quantization) {
3427
+ const finalEncoding = encodingWithSkirts;
3428
+ const finalVertexStride = finalEncoding.stride;
3429
+ const finalVertexBuffer = new Float32Array(
3430
+ vertexCountWithSkirts * finalVertexStride
3431
+ );
3432
+ let finalVertexBufferOffset = 0;
3433
+ for (let i = 0; i < vertexCountWithSkirts; i++) {
3434
+ finalVertexBufferOffset = finalEncoding.encode(
3435
+ finalVertexBuffer,
3436
+ finalVertexBufferOffset,
3437
+ encoding.decodePosition(vertexBuffer, i, scratchPosEcefSkirt),
3438
+ encoding.decodeTextureCoordinates(vertexBuffer, i, scratchUVSkirt),
3439
+ encoding.decodeHeight(vertexBuffer, i),
3440
+ encoding.hasVertexNormals ? encoding.getOctEncodedNormal(vertexBuffer, i, scratchNormalOctSkirt) : void 0,
3441
+ encoding.hasWebMercatorT ? encoding.decodeWebMercatorT(vertexBuffer, i) : void 0,
3442
+ encoding.hasGeodeticSurfaceNormals ? encoding.decodeGeodeticSurfaceNormal(
3443
+ vertexBuffer,
3444
+ i,
3445
+ scratchGeodeticSurfaceNormalSkirt
3446
+ ) : void 0
3447
+ );
3448
+ }
3449
+ mesh.vertices = finalVertexBuffer;
3450
+ mesh.stride = finalVertexStride;
3451
+ mesh.encoding = finalEncoding;
3452
+ }
3453
+ return mesh;
3454
+ }
3455
+ var EDGE_ID_LEFT = 0;
3456
+ var EDGE_ID_TOP = 1;
3457
+ var EDGE_ID_RIGHT = 2;
3458
+ var EDGE_ID_BOTTOM = 3;
3459
+ var EDGE_COUNT = 4;
3460
+ var scratchIntersection = new Cartesian3_default();
3461
+ var scratchInBarys = [
3462
+ new Cartesian3_default(),
3463
+ new Cartesian3_default(),
3464
+ new Cartesian3_default(),
3465
+ new Cartesian3_default(),
3466
+ new Cartesian3_default(),
3467
+ new Cartesian3_default()
3468
+ ];
3469
+ var scratchInPoints = [
3470
+ new Cartesian2_default(),
3471
+ new Cartesian2_default(),
3472
+ new Cartesian2_default(),
3473
+ new Cartesian2_default(),
3474
+ new Cartesian2_default(),
3475
+ new Cartesian2_default()
3476
+ ];
3477
+ var scratchOutBarys = [
3478
+ new Cartesian3_default(),
3479
+ new Cartesian3_default(),
3480
+ new Cartesian3_default(),
3481
+ new Cartesian3_default(),
3482
+ new Cartesian3_default(),
3483
+ new Cartesian3_default()
3484
+ ];
3485
+ var scratchOutPoints = [
3486
+ new Cartesian2_default(),
3487
+ new Cartesian2_default(),
3488
+ new Cartesian2_default(),
3489
+ new Cartesian2_default(),
3490
+ new Cartesian2_default(),
3491
+ new Cartesian2_default()
3492
+ ];
3493
+ function inside(boxMinimum, boxMaximum, edgeId, p) {
3494
+ switch (edgeId) {
3495
+ case EDGE_ID_LEFT:
3496
+ return Math_default.sign(p.x - boxMinimum.x);
3497
+ case EDGE_ID_RIGHT:
3498
+ return Math_default.sign(boxMaximum.x - p.x);
3499
+ case EDGE_ID_BOTTOM:
3500
+ return Math_default.sign(p.y - boxMinimum.y);
3501
+ default:
3502
+ return Math_default.sign(boxMaximum.y - p.y);
3503
+ }
3504
+ }
3505
+ function intersect(boxMinimum, boxMaximum, edgeId, a, b, result) {
3506
+ let t, intersectX, intersectY;
3507
+ switch (edgeId) {
3508
+ case EDGE_ID_LEFT:
3509
+ t = (boxMinimum.x - a.x) / (b.x - a.x);
3510
+ intersectX = boxMinimum.x;
3511
+ intersectY = a.y + (b.y - a.y) * t;
3512
+ break;
3513
+ case EDGE_ID_RIGHT:
3514
+ t = (boxMaximum.x - a.x) / (b.x - a.x);
3515
+ intersectX = boxMaximum.x;
3516
+ intersectY = a.y + (b.y - a.y) * t;
3517
+ break;
3518
+ case EDGE_ID_BOTTOM:
3519
+ t = (boxMinimum.y - a.y) / (b.y - a.y);
3520
+ intersectX = a.x + (b.x - a.x) * t;
3521
+ intersectY = boxMinimum.y;
3522
+ break;
3523
+ default:
3524
+ t = (boxMaximum.y - a.y) / (b.y - a.y);
3525
+ intersectX = a.x + (b.x - a.x) * t;
3526
+ intersectY = boxMaximum.y;
3527
+ break;
3528
+ }
3529
+ return Cartesian3_default.fromElements(intersectX, intersectY, t, result);
3530
+ }
3531
+ var scratchPolygon = {
3532
+ length: 0,
3533
+ coordinates: [
3534
+ new Cartesian2_default(),
3535
+ new Cartesian2_default(),
3536
+ new Cartesian2_default(),
3537
+ new Cartesian2_default(),
3538
+ new Cartesian2_default(),
3539
+ new Cartesian2_default()
3540
+ ],
3541
+ barycentricCoordinates: [
3542
+ new Cartesian3_default(),
3543
+ new Cartesian3_default(),
3544
+ new Cartesian3_default(),
3545
+ new Cartesian3_default(),
3546
+ new Cartesian3_default(),
3547
+ new Cartesian3_default()
3548
+ ]
3549
+ };
3550
+ function clipTriangleAgainstBoxEdgeRange(edgeStart, edgeCount, boxMinimum, boxMaximum, p0, p1, p2, result) {
3551
+ let inputLength = 0;
3552
+ let inputPoints = scratchInPoints;
3553
+ let inputBarys = scratchInBarys;
3554
+ let outputLength = 3;
3555
+ let outputPoints = scratchOutPoints;
3556
+ Cartesian2_default.clone(p0, outputPoints[0]);
3557
+ Cartesian2_default.clone(p1, outputPoints[1]);
3558
+ Cartesian2_default.clone(p2, outputPoints[2]);
3559
+ let outputBarys = scratchOutBarys;
3560
+ Cartesian3_default.fromElements(1, 0, 0, outputBarys[0]);
3561
+ Cartesian3_default.fromElements(0, 1, 0, outputBarys[1]);
3562
+ Cartesian3_default.fromElements(0, 0, 1, outputBarys[2]);
3563
+ for (let e = 0; e < edgeCount; e++) {
3564
+ const edgeId = (edgeStart + e) % EDGE_COUNT;
3565
+ const tempPoints = inputPoints;
3566
+ const tempBarys = inputBarys;
3567
+ inputPoints = outputPoints;
3568
+ inputBarys = outputBarys;
3569
+ inputLength = outputLength;
3570
+ outputPoints = tempPoints;
3571
+ outputBarys = tempBarys;
3572
+ outputLength = 0;
3573
+ let prevIdx = inputLength - 1;
3574
+ let prevPoint = inputPoints[prevIdx];
3575
+ let prevBary = inputBarys[prevIdx];
3576
+ let prevInside = inside(boxMinimum, boxMaximum, edgeId, prevPoint);
3577
+ for (let currIdx = 0; currIdx < inputLength; currIdx++) {
3578
+ const currPoint = inputPoints[currIdx];
3579
+ const currBary = inputBarys[currIdx];
3580
+ const currInside = inside(boxMinimum, boxMaximum, edgeId, currPoint);
3581
+ if (prevInside * currInside === -1) {
3582
+ const intersection = intersect(
3583
+ boxMinimum,
3584
+ boxMaximum,
3585
+ edgeId,
3586
+ prevPoint,
3587
+ currPoint,
3588
+ scratchIntersection
3589
+ );
3590
+ const { x, y, z: t } = intersection;
3591
+ const tInv = 1 - t;
3592
+ const baryA = prevBary.x * tInv + currBary.x * t;
3593
+ const baryB = prevBary.y * tInv + currBary.y * t;
3594
+ const baryC = prevBary.z * tInv + currBary.z * t;
3595
+ Cartesian2_default.fromElements(x, y, outputPoints[outputLength]);
3596
+ Cartesian3_default.fromElements(baryA, baryB, baryC, outputBarys[outputLength]);
3597
+ outputLength++;
3598
+ }
3599
+ if (currInside >= 0) {
3600
+ Cartesian2_default.clone(currPoint, outputPoints[outputLength]);
3601
+ Cartesian3_default.clone(currBary, outputBarys[outputLength]);
3602
+ outputLength++;
3603
+ }
3604
+ prevIdx = currIdx;
3605
+ prevPoint = currPoint;
3606
+ prevBary = currBary;
3607
+ prevInside = currInside;
3608
+ }
3609
+ if (outputLength === 0) {
3610
+ break;
3611
+ }
3612
+ }
3613
+ result.length = outputLength;
3614
+ for (let i = 0; i < outputLength; i++) {
3615
+ Cartesian2_default.clone(outputPoints[i], result.coordinates[i]);
3616
+ Cartesian3_default.clone(outputBarys[i], result.barycentricCoordinates[i]);
3617
+ }
3618
+ return result;
3619
+ }
3620
+ function clipTriangleFromQuadrant(isEastChild, isNorthChild, boxMinimum, boxMaximum, p0, p1, p2, result) {
3621
+ const edgeStart = isEastChild ? isNorthChild ? EDGE_ID_BOTTOM : EDGE_ID_LEFT : isNorthChild ? EDGE_ID_RIGHT : EDGE_ID_TOP;
3622
+ return clipTriangleAgainstBoxEdgeRange(
3623
+ edgeStart,
3624
+ 2,
3625
+ boxMinimum,
3626
+ boxMaximum,
3627
+ p0,
3628
+ p1,
3629
+ p2,
3630
+ result
3631
+ );
3632
+ }
3633
+ var lookUpTableBaryToPrim = [
3634
+ [],
3635
+ // 000
3636
+ [0],
3637
+ // 001
3638
+ [1],
3639
+ // 010
3640
+ [0, 1],
3641
+ // 011
3642
+ [2],
3643
+ // 100
3644
+ [0, 2],
3645
+ // 101
3646
+ [1, 2],
3647
+ // 110
3648
+ [0, 1, 2]
3649
+ // 111
3650
+ ];
3651
+ function clipTileFromQuadrant(isEastChild, isNorthChild, indexCount, indices, vertexCount, vertices, vertexEncoding, resultIndices, resultWestIndices, resultSouthIndices, resultEastIndices, resultNorthIndices, resultTriIds, resultBary, resultUVs) {
3652
+ const upsampledVertexMap = {};
3653
+ const minU = isEastChild ? 0.5 : 0;
3654
+ const maxU = isEastChild ? 1 : 0.5;
3655
+ const minV = isNorthChild ? 0.5 : 0;
3656
+ const maxV = isNorthChild ? 1 : 0.5;
3657
+ const minUV = scratchMinUV;
3658
+ minUV.x = minU;
3659
+ minUV.y = minV;
3660
+ const maxUV = scratchMaxUV;
3661
+ maxUV.x = maxU;
3662
+ maxUV.y = maxV;
3663
+ let upsampledVertexCount = 0;
3664
+ for (let i = 0; i < indexCount; i += 3) {
3665
+ const indexA = indices[i + 0];
3666
+ const indexB = indices[i + 1];
3667
+ const indexC = indices[i + 2];
3668
+ const uvA = vertexEncoding.decodeTextureCoordinates(
3669
+ vertices,
3670
+ indexA,
3671
+ scratchUvA
3672
+ );
3673
+ const uvB = vertexEncoding.decodeTextureCoordinates(
3674
+ vertices,
3675
+ indexB,
3676
+ scratchUvB
3677
+ );
3678
+ const uvC = vertexEncoding.decodeTextureCoordinates(
3679
+ vertices,
3680
+ indexC,
3681
+ scratchUvC
3682
+ );
3683
+ const clippedPolygon = clipTriangleFromQuadrant(
3684
+ isEastChild,
3685
+ isNorthChild,
3686
+ minUV,
3687
+ maxUV,
3688
+ uvA,
3689
+ uvB,
3690
+ uvC,
3691
+ scratchPolygon
3692
+ );
3693
+ const clippedPolygonLength = clippedPolygon.length;
3694
+ if (clippedPolygonLength < 3) {
3695
+ continue;
3696
+ }
3697
+ const polygonUpsampledIndices = scratchPolygonIndices;
3698
+ for (let p = 0; p < clippedPolygonLength; p++) {
3699
+ const polygonBary = clippedPolygon.barycentricCoordinates[p];
3700
+ const bA = polygonBary.x;
3701
+ const bB = polygonBary.y;
3702
+ const bC = polygonBary.z;
3703
+ const baryId = Math.ceil(bA) | Math.ceil(bB) << 1 | Math.ceil(bC) << 2;
3704
+ const primitiveIds = lookUpTableBaryToPrim[baryId];
3705
+ let upsampledIndex;
3706
+ let isNewVertex = false;
3707
+ if (primitiveIds.length === 1) {
3708
+ const pointPrimitiveId = primitiveIds[0];
3709
+ const pointIndex = indices[i + pointPrimitiveId];
3710
+ const pointKey = pointIndex;
3711
+ upsampledIndex = upsampledVertexMap[pointKey];
3712
+ if (upsampledIndex === void 0) {
3713
+ isNewVertex = true;
3714
+ upsampledIndex = upsampledVertexCount++;
3715
+ upsampledVertexMap[pointKey] = upsampledIndex;
3716
+ }
3717
+ } else if (primitiveIds.length === 2) {
3718
+ const edgePrimitiveIdA = primitiveIds[0];
3719
+ const edgePrimitiveIdB = primitiveIds[1];
3720
+ const edgeIndexA = indices[i + edgePrimitiveIdA];
3721
+ const edgeIndexB = indices[i + edgePrimitiveIdB];
3722
+ const prevBary = clippedPolygon.barycentricCoordinates[(p + clippedPolygonLength - 1) % clippedPolygonLength];
3723
+ const prevBaryId = Math.ceil(prevBary.x) | Math.ceil(prevBary.y) << 1 | Math.ceil(prevBary.z) << 2;
3724
+ const sameEdge = baryId === prevBaryId;
3725
+ const minIndex = Math.min(edgeIndexA, edgeIndexB);
3726
+ const maxIndex = Math.max(edgeIndexA, edgeIndexB);
3727
+ const baseKey = vertexCount + 2 * (minIndex * vertexCount + maxIndex);
3728
+ const firstKey = baseKey + 0;
3729
+ const secondKey = baseKey + 1;
3730
+ const firstEntry = upsampledVertexMap[firstKey];
3731
+ const secondEntry = upsampledVertexMap[secondKey];
3732
+ const useFirst = !sameEdge === (firstEntry === void 0 || secondEntry === void 0);
3733
+ upsampledIndex = useFirst ? firstEntry : secondEntry;
3734
+ if (upsampledIndex === void 0) {
3735
+ isNewVertex = true;
3736
+ upsampledIndex = upsampledVertexCount++;
3737
+ const edgeKey = useFirst ? firstKey : secondKey;
3738
+ upsampledVertexMap[edgeKey] = upsampledIndex;
3739
+ }
3740
+ } else {
3741
+ isNewVertex = true;
3742
+ upsampledIndex = upsampledVertexCount++;
3743
+ }
3744
+ polygonUpsampledIndices[p] = upsampledIndex;
3745
+ if (isNewVertex) {
3746
+ const triId = i / 3;
3747
+ resultTriIds.push(triId);
3748
+ const polygonUV = clippedPolygon.coordinates[p];
3749
+ const u = (polygonUV.x - minU) / (maxU - minU);
3750
+ const v = (polygonUV.y - minV) / (maxV - minV);
3751
+ resultUVs.push(u, v);
3752
+ resultBary.push(bA, bB);
3753
+ if (u === 0) {
3754
+ resultWestIndices.push(upsampledIndex);
3755
+ } else if (u === 1) {
3756
+ resultEastIndices.push(upsampledIndex);
3757
+ }
3758
+ if (v === 0) {
3759
+ resultSouthIndices.push(upsampledIndex);
3760
+ } else if (v === 1) {
3761
+ resultNorthIndices.push(upsampledIndex);
3762
+ }
3763
+ }
3764
+ }
3765
+ const ui0 = polygonUpsampledIndices[0];
3766
+ let ui1 = polygonUpsampledIndices[1];
3767
+ let ui2 = polygonUpsampledIndices[2];
3768
+ resultIndices.push(ui0, ui1, ui2);
3769
+ for (let j = 3; j < clippedPolygonLength; j++) {
3770
+ ui1 = ui2;
3771
+ ui2 = polygonUpsampledIndices[j];
3772
+ resultIndices.push(ui0, ui1, ui2);
3773
+ }
3774
+ }
3775
+ resultWestIndices.sort(function(a, b) {
3776
+ return resultUVs[a * 2 + 1] - resultUVs[b * 2 + 1];
3777
+ });
3778
+ resultSouthIndices.sort(function(a, b) {
3779
+ return resultUVs[b * 2 + 0] - resultUVs[a * 2 + 0];
3780
+ });
3781
+ resultEastIndices.sort(function(a, b) {
3782
+ return resultUVs[b * 2 + 1] - resultUVs[a * 2 + 1];
3783
+ });
3784
+ resultNorthIndices.sort(function(a, b) {
3785
+ return resultUVs[a * 2 + 0] - resultUVs[b * 2 + 0];
3786
+ });
3787
+ }
3788
+ var Cesium3DTilesTerrainGeometryProcessor_default = Cesium3DTilesTerrainGeometryProcessor;
3789
+
3790
+ export {
3791
+ Cesium3DTilesTerrainGeometryProcessor_default
3792
+ };