matterviz 0.3.5 → 0.3.6

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 (855) hide show
  1. package/.vscode/launch.json +13 -0
  2. package/.vscodeignore +7 -0
  3. package/dist/assets/STLExporter-BpTH3YHE.js +8 -0
  4. package/dist/assets/browser-DdDecX_W.js +1 -0
  5. package/dist/assets/export-qgn-H9y6.js +2 -0
  6. package/dist/assets/main-DiKYzti2.css +1 -0
  7. package/dist/assets/moyo_wasm_bg-0ocwg7xY.wasm +0 -0
  8. package/dist/extension.js +31293 -0
  9. package/dist/src/lib/FilePicker.svelte +360 -0
  10. package/dist/src/lib/MillerIndexInput.svelte +66 -0
  11. package/dist/src/lib/api/mp.ts +26 -0
  12. package/dist/src/lib/api/optimade.ts +204 -0
  13. package/dist/src/lib/brillouin/BrillouinZone.svelte +549 -0
  14. package/dist/src/lib/brillouin/BrillouinZoneControls.svelte +144 -0
  15. package/dist/src/lib/brillouin/BrillouinZoneExportPane.svelte +146 -0
  16. package/dist/src/lib/brillouin/BrillouinZoneInfoPane.svelte +146 -0
  17. package/dist/src/lib/brillouin/BrillouinZoneScene.svelte +476 -0
  18. package/dist/src/lib/brillouin/BrillouinZoneTooltip.svelte +92 -0
  19. package/dist/src/lib/brillouin/compute.ts +529 -0
  20. package/dist/src/lib/brillouin/index.ts +8 -0
  21. package/dist/src/lib/brillouin/types.ts +51 -0
  22. package/dist/src/lib/chempot-diagram/ChemPotDiagram.svelte +327 -0
  23. package/dist/src/lib/chempot-diagram/ChemPotDiagram2D.svelte +846 -0
  24. package/dist/src/lib/chempot-diagram/ChemPotDiagram3D.svelte +3193 -0
  25. package/dist/src/lib/chempot-diagram/async-compute.svelte.ts +94 -0
  26. package/dist/src/lib/chempot-diagram/chempot-worker.ts +11 -0
  27. package/dist/src/lib/chempot-diagram/color.ts +42 -0
  28. package/dist/src/lib/chempot-diagram/compute.ts +1014 -0
  29. package/dist/src/lib/chempot-diagram/index.ts +6 -0
  30. package/dist/src/lib/chempot-diagram/pointer.ts +56 -0
  31. package/dist/src/lib/chempot-diagram/temperature.ts +77 -0
  32. package/dist/src/lib/chempot-diagram/types.ts +130 -0
  33. package/dist/src/lib/colors/index.ts +249 -0
  34. package/dist/src/lib/composition/BarChart.svelte +297 -0
  35. package/dist/src/lib/composition/BubbleChart.svelte +218 -0
  36. package/dist/src/lib/composition/Composition.svelte +165 -0
  37. package/dist/src/lib/composition/Formula.svelte +268 -0
  38. package/dist/src/lib/composition/FormulaFilter.svelte +1257 -0
  39. package/dist/src/lib/composition/PieChart.svelte +323 -0
  40. package/dist/src/lib/composition/format.ts +155 -0
  41. package/dist/src/lib/composition/index.ts +37 -0
  42. package/dist/src/lib/composition/parse.ts +605 -0
  43. package/dist/src/lib/constants.ts +134 -0
  44. package/dist/src/lib/controls.ts +42 -0
  45. package/dist/src/lib/convex-hull/ConvexHull.svelte +157 -0
  46. package/dist/src/lib/convex-hull/ConvexHull2D.svelte +825 -0
  47. package/dist/src/lib/convex-hull/ConvexHull3D.svelte +1801 -0
  48. package/dist/src/lib/convex-hull/ConvexHull4D.svelte +1398 -0
  49. package/dist/src/lib/convex-hull/ConvexHullControls.svelte +535 -0
  50. package/dist/src/lib/convex-hull/ConvexHullInfoPane.svelte +125 -0
  51. package/dist/src/lib/convex-hull/ConvexHullStats.svelte +929 -0
  52. package/dist/src/lib/convex-hull/ConvexHullTooltip.svelte +131 -0
  53. package/dist/src/lib/convex-hull/GasPressureControls.svelte +247 -0
  54. package/dist/src/lib/convex-hull/StructurePopup.svelte +151 -0
  55. package/dist/src/lib/convex-hull/TemperatureSlider.svelte +140 -0
  56. package/dist/src/lib/convex-hull/barycentric-coords.ts +246 -0
  57. package/dist/src/lib/convex-hull/demo-temperature.ts +63 -0
  58. package/dist/src/lib/convex-hull/gas-thermodynamics.ts +405 -0
  59. package/dist/src/lib/convex-hull/helpers.ts +932 -0
  60. package/dist/src/lib/convex-hull/index.ts +202 -0
  61. package/dist/src/lib/convex-hull/thermodynamics.ts +2192 -0
  62. package/dist/src/lib/convex-hull/types.ts +267 -0
  63. package/dist/src/lib/coordination/CoordinationBarPlot.svelte +311 -0
  64. package/dist/src/lib/coordination/calc-coordination.ts +93 -0
  65. package/dist/src/lib/coordination/index.ts +9 -0
  66. package/dist/src/lib/effects.svelte.ts +48 -0
  67. package/dist/src/lib/element/BohrAtom.svelte +147 -0
  68. package/dist/src/lib/element/ElementHeading.svelte +26 -0
  69. package/dist/src/lib/element/ElementPhoto.svelte +57 -0
  70. package/dist/src/lib/element/ElementStats.svelte +80 -0
  71. package/dist/src/lib/element/ElementTile.svelte +484 -0
  72. package/dist/src/lib/element/data.json.gz.d.ts +4 -0
  73. package/dist/src/lib/element/data.ts +14 -0
  74. package/dist/src/lib/element/index.ts +8 -0
  75. package/dist/src/lib/element/types.ts +62 -0
  76. package/dist/src/lib/feedback/ClickFeedback.svelte +58 -0
  77. package/dist/src/lib/feedback/DragOverlay.svelte +42 -0
  78. package/dist/src/lib/feedback/index.ts +4 -0
  79. package/dist/src/lib/fermi-surface/FermiSlice.svelte +189 -0
  80. package/dist/src/lib/fermi-surface/FermiSurface.svelte +600 -0
  81. package/dist/src/lib/fermi-surface/FermiSurfaceControls.svelte +448 -0
  82. package/dist/src/lib/fermi-surface/FermiSurfaceScene.svelte +794 -0
  83. package/dist/src/lib/fermi-surface/FermiSurfaceTooltip.svelte +111 -0
  84. package/dist/src/lib/fermi-surface/compute.ts +728 -0
  85. package/dist/src/lib/fermi-surface/constants.ts +32 -0
  86. package/dist/src/lib/fermi-surface/export.ts +64 -0
  87. package/dist/src/lib/fermi-surface/index.ts +14 -0
  88. package/dist/src/lib/fermi-surface/marching-cubes.ts +3 -0
  89. package/dist/src/lib/fermi-surface/parse.ts +574 -0
  90. package/dist/src/lib/fermi-surface/symmetry.ts +56 -0
  91. package/dist/src/lib/fermi-surface/types.ts +159 -0
  92. package/dist/src/lib/heatmap-matrix/HeatmapMatrix.svelte +1545 -0
  93. package/dist/src/lib/heatmap-matrix/HeatmapMatrixControls.svelte +225 -0
  94. package/dist/src/lib/heatmap-matrix/index.ts +167 -0
  95. package/dist/src/lib/heatmap-matrix/shared.ts +7 -0
  96. package/dist/src/lib/icons.ts +650 -0
  97. package/dist/src/lib/index.ts +61 -0
  98. package/dist/src/lib/io/decompress.ts +92 -0
  99. package/dist/src/lib/io/export.ts +385 -0
  100. package/dist/src/lib/io/fetch.ts +46 -0
  101. package/dist/src/lib/io/file-drop.ts +51 -0
  102. package/dist/src/lib/io/index.ts +7 -0
  103. package/dist/src/lib/io/is-binary.ts +24 -0
  104. package/dist/src/lib/io/types.ts +8 -0
  105. package/dist/src/lib/io/url-drop.ts +141 -0
  106. package/dist/src/lib/isosurface/Isosurface.svelte +285 -0
  107. package/dist/src/lib/isosurface/IsosurfaceControls.svelte +277 -0
  108. package/dist/src/lib/isosurface/index.ts +7 -0
  109. package/dist/src/lib/isosurface/parse.ts +656 -0
  110. package/dist/src/lib/isosurface/slice.ts +175 -0
  111. package/dist/src/lib/isosurface/types.ts +309 -0
  112. package/dist/src/lib/labels.ts +320 -0
  113. package/dist/src/lib/layout/FullscreenToggle.svelte +50 -0
  114. package/dist/src/lib/layout/InfoCard.svelte +120 -0
  115. package/dist/src/lib/layout/InfoTag.svelte +185 -0
  116. package/dist/src/lib/layout/PropertyFilter.svelte +246 -0
  117. package/dist/src/lib/layout/SettingsSection.svelte +148 -0
  118. package/dist/src/lib/layout/SubpageGrid.svelte +82 -0
  119. package/dist/src/lib/layout/fullscreen.ts +65 -0
  120. package/dist/src/lib/layout/index.ts +11 -0
  121. package/dist/src/lib/layout/json-tree/JsonNode.svelte +548 -0
  122. package/dist/src/lib/layout/json-tree/JsonTree.svelte +1230 -0
  123. package/dist/src/lib/layout/json-tree/JsonValue.svelte +334 -0
  124. package/dist/src/lib/layout/json-tree/index.ts +3 -0
  125. package/dist/src/lib/layout/json-tree/types.ts +126 -0
  126. package/dist/src/lib/layout/json-tree/utils.ts +682 -0
  127. package/dist/src/lib/marching-cubes.ts +614 -0
  128. package/dist/src/lib/math.ts +1081 -0
  129. package/dist/src/lib/overlays/ContextMenu.svelte +162 -0
  130. package/dist/src/lib/overlays/CopyButton.svelte +45 -0
  131. package/dist/src/lib/overlays/DragControlTab.svelte +98 -0
  132. package/dist/src/lib/overlays/DraggablePane.svelte +487 -0
  133. package/dist/src/lib/overlays/InfoPaneCards.svelte +149 -0
  134. package/dist/src/lib/overlays/index.ts +3 -0
  135. package/dist/src/lib/periodic-table/PeriodicTable.svelte +469 -0
  136. package/dist/src/lib/periodic-table/PeriodicTableControls.svelte +557 -0
  137. package/dist/src/lib/periodic-table/PropertySelect.svelte +37 -0
  138. package/dist/src/lib/periodic-table/index.ts +12 -0
  139. package/dist/src/lib/phase-diagram/IsobaricBinaryPhaseDiagram.svelte +1086 -0
  140. package/dist/src/lib/phase-diagram/PhaseDiagramControls.svelte +444 -0
  141. package/dist/src/lib/phase-diagram/PhaseDiagramEditorPane.svelte +126 -0
  142. package/dist/src/lib/phase-diagram/PhaseDiagramExportPane.svelte +184 -0
  143. package/dist/src/lib/phase-diagram/PhaseDiagramTooltip.svelte +391 -0
  144. package/dist/src/lib/phase-diagram/TdbInfoPanel.svelte +203 -0
  145. package/dist/src/lib/phase-diagram/build-diagram.ts +186 -0
  146. package/dist/src/lib/phase-diagram/colors.ts +58 -0
  147. package/dist/src/lib/phase-diagram/diagram-input.ts +40 -0
  148. package/dist/src/lib/phase-diagram/index.ts +13 -0
  149. package/dist/src/lib/phase-diagram/parse.ts +348 -0
  150. package/dist/src/lib/phase-diagram/svg-to-diagram.ts +1023 -0
  151. package/dist/src/lib/phase-diagram/types.ts +144 -0
  152. package/dist/src/lib/phase-diagram/utils.ts +775 -0
  153. package/dist/src/lib/plot/AxisLabel.svelte +51 -0
  154. package/dist/src/lib/plot/BarPlot.svelte +2113 -0
  155. package/dist/src/lib/plot/BarPlotControls.svelte +66 -0
  156. package/dist/src/lib/plot/BinnedScatterPlot.svelte +1114 -0
  157. package/dist/src/lib/plot/ColorBar.svelte +721 -0
  158. package/dist/src/lib/plot/ColorScaleSelect.svelte +54 -0
  159. package/dist/src/lib/plot/ElementScatter.svelte +63 -0
  160. package/dist/src/lib/plot/FillArea.svelte +223 -0
  161. package/dist/src/lib/plot/Histogram.svelte +1558 -0
  162. package/dist/src/lib/plot/HistogramControls.svelte +212 -0
  163. package/dist/src/lib/plot/InteractiveAxisLabel.svelte +96 -0
  164. package/dist/src/lib/plot/Line.svelte +84 -0
  165. package/dist/src/lib/plot/PlotAxis.svelte +169 -0
  166. package/dist/src/lib/plot/PlotControls.svelte +537 -0
  167. package/dist/src/lib/plot/PlotLegend.svelte +569 -0
  168. package/dist/src/lib/plot/PlotTooltip.svelte +67 -0
  169. package/dist/src/lib/plot/PortalSelect.svelte +253 -0
  170. package/dist/src/lib/plot/ReferenceLine3D.svelte +156 -0
  171. package/dist/src/lib/plot/ReferencePlane.svelte +175 -0
  172. package/dist/src/lib/plot/ScatterPlot.svelte +2778 -0
  173. package/dist/src/lib/plot/ScatterPlot3D.svelte +529 -0
  174. package/dist/src/lib/plot/ScatterPlot3DControls.svelte +437 -0
  175. package/dist/src/lib/plot/ScatterPlot3DScene.svelte +912 -0
  176. package/dist/src/lib/plot/ScatterPlotControls.svelte +306 -0
  177. package/dist/src/lib/plot/ScatterPoint.svelte +182 -0
  178. package/dist/src/lib/plot/SpacegroupBarPlot.svelte +293 -0
  179. package/dist/src/lib/plot/Surface3D.svelte +197 -0
  180. package/dist/src/lib/plot/ZeroLines.svelte +97 -0
  181. package/dist/src/lib/plot/ZoomRect.svelte +23 -0
  182. package/dist/src/lib/plot/adaptive-density.ts +316 -0
  183. package/dist/src/lib/plot/auto-place.ts +184 -0
  184. package/dist/src/lib/plot/axis-utils.ts +122 -0
  185. package/dist/src/lib/plot/binned-scatter-types.ts +83 -0
  186. package/dist/src/lib/plot/data-cleaning.ts +1069 -0
  187. package/dist/src/lib/plot/data-transform.ts +69 -0
  188. package/dist/src/lib/plot/defaults.ts +9 -0
  189. package/dist/src/lib/plot/fill-utils.ts +494 -0
  190. package/dist/src/lib/plot/hover-lock.svelte.ts +60 -0
  191. package/dist/src/lib/plot/index.ts +53 -0
  192. package/dist/src/lib/plot/interactions.ts +119 -0
  193. package/dist/src/lib/plot/layout.ts +425 -0
  194. package/dist/src/lib/plot/reference-line.ts +426 -0
  195. package/dist/src/lib/plot/scales.ts +654 -0
  196. package/dist/src/lib/plot/svg.ts +23 -0
  197. package/dist/src/lib/plot/types.ts +1144 -0
  198. package/dist/src/lib/plot/utils/label-placement.ts +541 -0
  199. package/dist/src/lib/plot/utils/series-visibility.ts +140 -0
  200. package/dist/src/lib/plot/utils.ts +11 -0
  201. package/dist/src/lib/rdf/RdfPlot.svelte +247 -0
  202. package/dist/src/lib/rdf/calc-rdf.ts +167 -0
  203. package/dist/src/lib/rdf/index.ts +27 -0
  204. package/dist/src/lib/sanitize.ts +126 -0
  205. package/dist/src/lib/settings.ts +1479 -0
  206. package/dist/src/lib/spectral/Bands.svelte +1040 -0
  207. package/dist/src/lib/spectral/BandsAndDos.svelte +134 -0
  208. package/dist/src/lib/spectral/BrillouinBandsDos.svelte +252 -0
  209. package/dist/src/lib/spectral/Dos.svelte +697 -0
  210. package/dist/src/lib/spectral/helpers.ts +1381 -0
  211. package/dist/src/lib/spectral/index.ts +8 -0
  212. package/dist/src/lib/spectral/types.ts +112 -0
  213. package/dist/src/lib/state.svelte.ts +64 -0
  214. package/dist/src/lib/structure/Arrow.svelte +72 -0
  215. package/dist/src/lib/structure/AtomLegend.svelte +815 -0
  216. package/dist/src/lib/structure/Bond.svelte +140 -0
  217. package/dist/src/lib/structure/CanvasTooltip.svelte +33 -0
  218. package/dist/src/lib/structure/CellSelect.svelte +349 -0
  219. package/dist/src/lib/structure/Cylinder.svelte +45 -0
  220. package/dist/src/lib/structure/Lattice.svelte +196 -0
  221. package/dist/src/lib/structure/Structure.svelte +2248 -0
  222. package/dist/src/lib/structure/StructureControls.svelte +1273 -0
  223. package/dist/src/lib/structure/StructureExportPane.svelte +252 -0
  224. package/dist/src/lib/structure/StructureInfoPane.svelte +737 -0
  225. package/dist/src/lib/structure/StructureScene.svelte +2255 -0
  226. package/dist/src/lib/structure/atom-properties.ts +316 -0
  227. package/dist/src/lib/structure/bond-order-perception.ts +447 -0
  228. package/dist/src/lib/structure/bonding.ts +944 -0
  229. package/dist/src/lib/structure/export.ts +861 -0
  230. package/dist/src/lib/structure/index.ts +291 -0
  231. package/dist/src/lib/structure/label-placement.ts +130 -0
  232. package/dist/src/lib/structure/measure.ts +45 -0
  233. package/dist/src/lib/structure/parse.ts +1705 -0
  234. package/dist/src/lib/structure/partial-occupancy.ts +183 -0
  235. package/dist/src/lib/structure/pbc.ts +164 -0
  236. package/dist/src/lib/structure/supercell.ts +226 -0
  237. package/dist/src/lib/structure/validation.ts +11 -0
  238. package/dist/src/lib/symmetry/SymmetryStats.svelte +226 -0
  239. package/dist/src/lib/symmetry/WyckoffTable.svelte +120 -0
  240. package/dist/src/lib/symmetry/cell-transform.ts +118 -0
  241. package/dist/src/lib/symmetry/index.ts +348 -0
  242. package/dist/src/lib/symmetry/spacegroups.ts +404 -0
  243. package/dist/src/lib/table/HeatmapTable.svelte +1833 -0
  244. package/dist/src/lib/table/ToggleMenu.svelte +385 -0
  245. package/dist/src/lib/table/index.ts +139 -0
  246. package/dist/src/lib/theme/ThemeControl.svelte +53 -0
  247. package/dist/src/lib/theme/index.ts +107 -0
  248. package/dist/src/lib/theme/themes.mjs +297 -0
  249. package/dist/src/lib/time.ts +71 -0
  250. package/dist/src/lib/tooltip/TooltipContent.svelte +58 -0
  251. package/dist/src/lib/tooltip/index.ts +2 -0
  252. package/dist/src/lib/tooltip/types.ts +13 -0
  253. package/dist/src/lib/trajectory/Trajectory.svelte +1545 -0
  254. package/dist/src/lib/trajectory/TrajectoryError.svelte +128 -0
  255. package/dist/src/lib/trajectory/TrajectoryExportPane.svelte +357 -0
  256. package/dist/src/lib/trajectory/TrajectoryInfoPane.svelte +313 -0
  257. package/dist/src/lib/trajectory/constants.ts +7 -0
  258. package/dist/src/lib/trajectory/extract.ts +196 -0
  259. package/dist/src/lib/trajectory/format-detect.ts +96 -0
  260. package/dist/src/lib/trajectory/frame-reader.ts +456 -0
  261. package/dist/src/lib/trajectory/helpers.ts +217 -0
  262. package/dist/src/lib/trajectory/index.ts +218 -0
  263. package/dist/src/lib/trajectory/parse/ase.ts +109 -0
  264. package/dist/src/lib/trajectory/parse/hdf5.ts +173 -0
  265. package/dist/src/lib/trajectory/parse/index.ts +411 -0
  266. package/dist/src/lib/trajectory/parse/lammps.ts +215 -0
  267. package/dist/src/lib/trajectory/parse/vasp.ts +102 -0
  268. package/dist/src/lib/trajectory/parse/xyz.ts +143 -0
  269. package/dist/src/lib/trajectory/plotting.ts +599 -0
  270. package/dist/src/lib/trajectory/types.ts +13 -0
  271. package/dist/src/lib/utils.ts +56 -0
  272. package/dist/src/lib/xrd/XrdPlot.svelte +615 -0
  273. package/dist/src/lib/xrd/broadening.ts +130 -0
  274. package/dist/src/lib/xrd/calc-xrd.ts +397 -0
  275. package/dist/src/lib/xrd/index.ts +38 -0
  276. package/dist/src/lib/xrd/parse.ts +858 -0
  277. package/dist/webview.js +29421 -0
  278. package/icon.png +0 -0
  279. package/license +1 -1
  280. package/matterviz-0.3.2.vsix +0 -0
  281. package/matterviz-0.3.4.vsix +0 -0
  282. package/matterviz-0.3.5.vsix +0 -0
  283. package/package.json +1460 -215
  284. package/readme.md +171 -98
  285. package/scripts/sync-config.ts +101 -0
  286. package/src/declarations.d.ts +2 -0
  287. package/src/extension.ts +972 -0
  288. package/src/node-io.ts +65 -0
  289. package/src/types.ts +17 -0
  290. package/src/webview/JsonBrowser.svelte +1079 -0
  291. package/src/webview/PlotPanel.svelte +346 -0
  292. package/src/webview/detect.ts +444 -0
  293. package/src/webview/main.ts +764 -0
  294. package/src/webview/plot-utils.ts +250 -0
  295. package/test-fixtures/all-viz-types.json.gz +0 -0
  296. package/test-fixtures/plot-demo-data.json.gz +0 -0
  297. package/tests/detect.test.ts +604 -0
  298. package/tests/extension.test.ts +2041 -0
  299. package/tests/node-io.test.ts +39 -0
  300. package/tests/plot-utils.test.ts +302 -0
  301. package/tests/vite-plugin-json-gz.test.ts +114 -0
  302. package/tests/vscode-mock.ts +18 -0
  303. package/tests/webview.test.ts +231 -0
  304. package/tsconfig.json +20 -0
  305. package/vite-plugin-json-gz.ts +29 -0
  306. package/vite.config.ts +34 -0
  307. package/vite.extension.config.ts +34 -0
  308. package/dist/EmptyState.svelte.d.ts +0 -9
  309. package/dist/FilePicker.svelte +0 -360
  310. package/dist/FilePicker.svelte.d.ts +0 -17
  311. package/dist/Icon.svelte.d.ts +0 -13
  312. package/dist/MillerIndexInput.svelte +0 -66
  313. package/dist/MillerIndexInput.svelte.d.ts +0 -7
  314. package/dist/api/mp.d.ts +0 -6
  315. package/dist/api/mp.js +0 -22
  316. package/dist/api/optimade.d.ts +0 -45
  317. package/dist/api/optimade.js +0 -135
  318. package/dist/brillouin/BrillouinZone.svelte +0 -546
  319. package/dist/brillouin/BrillouinZone.svelte.d.ts +0 -83
  320. package/dist/brillouin/BrillouinZoneControls.svelte +0 -144
  321. package/dist/brillouin/BrillouinZoneControls.svelte.d.ts +0 -17
  322. package/dist/brillouin/BrillouinZoneExportPane.svelte +0 -148
  323. package/dist/brillouin/BrillouinZoneExportPane.svelte.d.ts +0 -15
  324. package/dist/brillouin/BrillouinZoneInfoPane.svelte +0 -146
  325. package/dist/brillouin/BrillouinZoneInfoPane.svelte.d.ts +0 -13
  326. package/dist/brillouin/BrillouinZoneScene.svelte +0 -476
  327. package/dist/brillouin/BrillouinZoneScene.svelte.d.ts +0 -48
  328. package/dist/brillouin/BrillouinZoneTooltip.svelte +0 -92
  329. package/dist/brillouin/BrillouinZoneTooltip.svelte.d.ts +0 -8
  330. package/dist/brillouin/compute.d.ts +0 -17
  331. package/dist/brillouin/compute.js +0 -426
  332. package/dist/brillouin/index.d.ts +0 -8
  333. package/dist/brillouin/index.js +0 -8
  334. package/dist/brillouin/types.d.ts +0 -48
  335. package/dist/brillouin/types.js +0 -1
  336. package/dist/chempot-diagram/ChemPotDiagram.svelte +0 -327
  337. package/dist/chempot-diagram/ChemPotDiagram.svelte.d.ts +0 -13
  338. package/dist/chempot-diagram/ChemPotDiagram2D.svelte +0 -847
  339. package/dist/chempot-diagram/ChemPotDiagram2D.svelte.d.ts +0 -16
  340. package/dist/chempot-diagram/ChemPotDiagram3D.svelte +0 -3194
  341. package/dist/chempot-diagram/ChemPotDiagram3D.svelte.d.ts +0 -16
  342. package/dist/chempot-diagram/ChemPotScene3D.svelte.d.ts +0 -7
  343. package/dist/chempot-diagram/async-compute.svelte.d.ts +0 -3
  344. package/dist/chempot-diagram/async-compute.svelte.js +0 -78
  345. package/dist/chempot-diagram/chempot-worker.d.ts +0 -1
  346. package/dist/chempot-diagram/chempot-worker.js +0 -11
  347. package/dist/chempot-diagram/color.d.ts +0 -10
  348. package/dist/chempot-diagram/color.js +0 -32
  349. package/dist/chempot-diagram/compute.d.ts +0 -48
  350. package/dist/chempot-diagram/compute.js +0 -812
  351. package/dist/chempot-diagram/index.d.ts +0 -6
  352. package/dist/chempot-diagram/index.js +0 -6
  353. package/dist/chempot-diagram/pointer.d.ts +0 -16
  354. package/dist/chempot-diagram/pointer.js +0 -40
  355. package/dist/chempot-diagram/temperature.d.ts +0 -15
  356. package/dist/chempot-diagram/temperature.js +0 -36
  357. package/dist/chempot-diagram/types.d.ts +0 -86
  358. package/dist/chempot-diagram/types.js +0 -28
  359. package/dist/colors/index.d.ts +0 -47
  360. package/dist/colors/index.js +0 -203
  361. package/dist/composition/BarChart.svelte +0 -297
  362. package/dist/composition/BarChart.svelte.d.ts +0 -39
  363. package/dist/composition/BubbleChart.svelte +0 -218
  364. package/dist/composition/BubbleChart.svelte.d.ts +0 -28
  365. package/dist/composition/Composition.svelte +0 -164
  366. package/dist/composition/Composition.svelte.d.ts +0 -15
  367. package/dist/composition/Formula.svelte +0 -265
  368. package/dist/composition/Formula.svelte.d.ts +0 -19
  369. package/dist/composition/FormulaFilter.svelte +0 -1259
  370. package/dist/composition/FormulaFilter.svelte.d.ts +0 -51
  371. package/dist/composition/PieChart.svelte +0 -323
  372. package/dist/composition/PieChart.svelte.d.ts +0 -37
  373. package/dist/composition/format.d.ts +0 -15
  374. package/dist/composition/format.js +0 -109
  375. package/dist/composition/index.d.ts +0 -20
  376. package/dist/composition/index.js +0 -14
  377. package/dist/composition/parse.d.ts +0 -55
  378. package/dist/composition/parse.js +0 -459
  379. package/dist/constants.d.ts +0 -29
  380. package/dist/constants.js +0 -99
  381. package/dist/controls.d.ts +0 -14
  382. package/dist/controls.js +0 -30
  383. package/dist/convex-hull/ConvexHull.svelte +0 -157
  384. package/dist/convex-hull/ConvexHull.svelte.d.ts +0 -13
  385. package/dist/convex-hull/ConvexHull2D.svelte +0 -814
  386. package/dist/convex-hull/ConvexHull2D.svelte.d.ts +0 -11
  387. package/dist/convex-hull/ConvexHull3D.svelte +0 -1790
  388. package/dist/convex-hull/ConvexHull3D.svelte.d.ts +0 -8
  389. package/dist/convex-hull/ConvexHull4D.svelte +0 -1386
  390. package/dist/convex-hull/ConvexHull4D.svelte.d.ts +0 -8
  391. package/dist/convex-hull/ConvexHullControls.svelte +0 -546
  392. package/dist/convex-hull/ConvexHullControls.svelte.d.ts +0 -48
  393. package/dist/convex-hull/ConvexHullInfoPane.svelte +0 -122
  394. package/dist/convex-hull/ConvexHullInfoPane.svelte.d.ts +0 -18
  395. package/dist/convex-hull/ConvexHullStats.svelte +0 -922
  396. package/dist/convex-hull/ConvexHullStats.svelte.d.ts +0 -15
  397. package/dist/convex-hull/ConvexHullTooltip.svelte +0 -131
  398. package/dist/convex-hull/ConvexHullTooltip.svelte.d.ts +0 -33
  399. package/dist/convex-hull/GasPressureControls.svelte +0 -247
  400. package/dist/convex-hull/GasPressureControls.svelte.d.ts +0 -11
  401. package/dist/convex-hull/StructurePopup.svelte +0 -116
  402. package/dist/convex-hull/StructurePopup.svelte.d.ts +0 -18
  403. package/dist/convex-hull/TemperatureSlider.svelte +0 -137
  404. package/dist/convex-hull/TemperatureSlider.svelte.d.ts +0 -8
  405. package/dist/convex-hull/barycentric-coords.d.ts +0 -18
  406. package/dist/convex-hull/barycentric-coords.js +0 -182
  407. package/dist/convex-hull/demo-temperature.d.ts +0 -6
  408. package/dist/convex-hull/demo-temperature.js +0 -40
  409. package/dist/convex-hull/gas-thermodynamics.d.ts +0 -16
  410. package/dist/convex-hull/gas-thermodynamics.js +0 -316
  411. package/dist/convex-hull/helpers.d.ts +0 -103
  412. package/dist/convex-hull/helpers.js +0 -689
  413. package/dist/convex-hull/index.d.ts +0 -118
  414. package/dist/convex-hull/index.js +0 -57
  415. package/dist/convex-hull/thermodynamics.d.ts +0 -66
  416. package/dist/convex-hull/thermodynamics.js +0 -1752
  417. package/dist/convex-hull/types.d.ts +0 -162
  418. package/dist/convex-hull/types.js +0 -36
  419. package/dist/coordination/CoordinationBarPlot.svelte +0 -311
  420. package/dist/coordination/CoordinationBarPlot.svelte.d.ts +0 -30
  421. package/dist/coordination/calc-coordination.d.ts +0 -15
  422. package/dist/coordination/calc-coordination.js +0 -63
  423. package/dist/coordination/index.d.ts +0 -8
  424. package/dist/coordination/index.js +0 -7
  425. package/dist/element/BohrAtom.svelte +0 -147
  426. package/dist/element/BohrAtom.svelte.d.ts +0 -20
  427. package/dist/element/ElementHeading.svelte +0 -26
  428. package/dist/element/ElementHeading.svelte.d.ts +0 -8
  429. package/dist/element/ElementPhoto.svelte +0 -57
  430. package/dist/element/ElementPhoto.svelte.d.ts +0 -9
  431. package/dist/element/ElementStats.svelte +0 -80
  432. package/dist/element/ElementStats.svelte.d.ts +0 -8
  433. package/dist/element/ElementTile.svelte +0 -484
  434. package/dist/element/ElementTile.svelte.d.ts +0 -29
  435. package/dist/element/Nucleus.svelte.d.ts +0 -17
  436. package/dist/element/data.d.ts +0 -2
  437. package/dist/element/data.js +0 -2
  438. package/dist/element/data.json.gz.d.ts +0 -2
  439. package/dist/element/index.d.ts +0 -8
  440. package/dist/element/index.js +0 -8
  441. package/dist/element/types.d.ts +0 -57
  442. package/dist/element/types.js +0 -1
  443. package/dist/feedback/ClickFeedback.svelte +0 -58
  444. package/dist/feedback/ClickFeedback.svelte.d.ts +0 -12
  445. package/dist/feedback/DragOverlay.svelte +0 -42
  446. package/dist/feedback/DragOverlay.svelte.d.ts +0 -7
  447. package/dist/feedback/Spinner.svelte.d.ts +0 -7
  448. package/dist/feedback/StatusMessage.svelte.d.ts +0 -9
  449. package/dist/feedback/index.d.ts +0 -4
  450. package/dist/feedback/index.js +0 -4
  451. package/dist/fermi-surface/FermiSlice.svelte +0 -189
  452. package/dist/fermi-surface/FermiSlice.svelte.d.ts +0 -24
  453. package/dist/fermi-surface/FermiSurface.svelte +0 -600
  454. package/dist/fermi-surface/FermiSurface.svelte.d.ts +0 -83
  455. package/dist/fermi-surface/FermiSurfaceControls.svelte +0 -452
  456. package/dist/fermi-surface/FermiSurfaceControls.svelte.d.ts +0 -35
  457. package/dist/fermi-surface/FermiSurfaceScene.svelte +0 -792
  458. package/dist/fermi-surface/FermiSurfaceScene.svelte.d.ts +0 -50
  459. package/dist/fermi-surface/FermiSurfaceTooltip.svelte +0 -111
  460. package/dist/fermi-surface/FermiSurfaceTooltip.svelte.d.ts +0 -8
  461. package/dist/fermi-surface/compute.d.ts +0 -5
  462. package/dist/fermi-surface/compute.js +0 -538
  463. package/dist/fermi-surface/constants.d.ts +0 -9
  464. package/dist/fermi-surface/constants.js +0 -27
  465. package/dist/fermi-surface/export.d.ts +0 -5
  466. package/dist/fermi-surface/export.js +0 -63
  467. package/dist/fermi-surface/index.d.ts +0 -12
  468. package/dist/fermi-surface/index.js +0 -13
  469. package/dist/fermi-surface/marching-cubes.d.ts +0 -2
  470. package/dist/fermi-surface/marching-cubes.js +0 -2
  471. package/dist/fermi-surface/parse.d.ts +0 -2
  472. package/dist/fermi-surface/parse.js +0 -495
  473. package/dist/fermi-surface/symmetry.d.ts +0 -3
  474. package/dist/fermi-surface/symmetry.js +0 -46
  475. package/dist/fermi-surface/types.d.ts +0 -113
  476. package/dist/fermi-surface/types.js +0 -4
  477. package/dist/heatmap-matrix/HeatmapMatrix.svelte +0 -1527
  478. package/dist/heatmap-matrix/HeatmapMatrix.svelte.d.ts +0 -110
  479. package/dist/heatmap-matrix/HeatmapMatrixControls.svelte +0 -225
  480. package/dist/heatmap-matrix/HeatmapMatrixControls.svelte.d.ts +0 -30
  481. package/dist/heatmap-matrix/index.d.ts +0 -53
  482. package/dist/heatmap-matrix/index.js +0 -100
  483. package/dist/heatmap-matrix/shared.d.ts +0 -2
  484. package/dist/heatmap-matrix/shared.js +0 -4
  485. package/dist/icons.d.ts +0 -569
  486. package/dist/icons.js +0 -648
  487. package/dist/index.d.ts +0 -39
  488. package/dist/index.js +0 -39
  489. package/dist/io/decompress.d.ts +0 -10
  490. package/dist/io/decompress.js +0 -74
  491. package/dist/io/export.d.ts +0 -16
  492. package/dist/io/export.js +0 -316
  493. package/dist/io/fetch.d.ts +0 -5
  494. package/dist/io/fetch.js +0 -39
  495. package/dist/io/file-drop.d.ts +0 -7
  496. package/dist/io/file-drop.js +0 -43
  497. package/dist/io/index.d.ts +0 -7
  498. package/dist/io/index.js +0 -7
  499. package/dist/io/is-binary.d.ts +0 -1
  500. package/dist/io/is-binary.js +0 -20
  501. package/dist/io/types.d.ts +0 -8
  502. package/dist/io/types.js +0 -1
  503. package/dist/io/url-drop.d.ts +0 -2
  504. package/dist/io/url-drop.js +0 -117
  505. package/dist/isosurface/Isosurface.svelte +0 -285
  506. package/dist/isosurface/Isosurface.svelte.d.ts +0 -8
  507. package/dist/isosurface/IsosurfaceControls.svelte +0 -291
  508. package/dist/isosurface/IsosurfaceControls.svelte.d.ts +0 -9
  509. package/dist/isosurface/index.d.ts +0 -5
  510. package/dist/isosurface/index.js +0 -6
  511. package/dist/isosurface/parse.d.ts +0 -6
  512. package/dist/isosurface/parse.js +0 -553
  513. package/dist/isosurface/slice.d.ts +0 -11
  514. package/dist/isosurface/slice.js +0 -140
  515. package/dist/isosurface/types.d.ts +0 -56
  516. package/dist/isosurface/types.js +0 -227
  517. package/dist/labels.d.ts +0 -53
  518. package/dist/labels.js +0 -274
  519. package/dist/layout/FullscreenToggle.svelte +0 -50
  520. package/dist/layout/FullscreenToggle.svelte.d.ts +0 -7
  521. package/dist/layout/InfoCard.svelte +0 -120
  522. package/dist/layout/InfoCard.svelte.d.ts +0 -21
  523. package/dist/layout/InfoTag.svelte +0 -183
  524. package/dist/layout/InfoTag.svelte.d.ts +0 -19
  525. package/dist/layout/PropertyFilter.svelte +0 -244
  526. package/dist/layout/PropertyFilter.svelte.d.ts +0 -24
  527. package/dist/layout/SettingsSection.svelte +0 -148
  528. package/dist/layout/SettingsSection.svelte.d.ts +0 -17
  529. package/dist/layout/SubpageGrid.svelte +0 -82
  530. package/dist/layout/SubpageGrid.svelte.d.ts +0 -14
  531. package/dist/layout/fullscreen.d.ts +0 -9
  532. package/dist/layout/fullscreen.js +0 -53
  533. package/dist/layout/index.d.ts +0 -10
  534. package/dist/layout/index.js +0 -8
  535. package/dist/layout/json-tree/JsonNode.svelte +0 -548
  536. package/dist/layout/json-tree/JsonNode.svelte.d.ts +0 -11
  537. package/dist/layout/json-tree/JsonTree.svelte +0 -1222
  538. package/dist/layout/json-tree/JsonTree.svelte.d.ts +0 -6
  539. package/dist/layout/json-tree/JsonValue.svelte +0 -334
  540. package/dist/layout/json-tree/JsonValue.svelte.d.ts +0 -9
  541. package/dist/layout/json-tree/index.d.ts +0 -3
  542. package/dist/layout/json-tree/index.js +0 -3
  543. package/dist/layout/json-tree/types.d.ts +0 -73
  544. package/dist/layout/json-tree/types.js +0 -3
  545. package/dist/layout/json-tree/utils.d.ts +0 -29
  546. package/dist/layout/json-tree/utils.js +0 -649
  547. package/dist/marching-cubes.d.ts +0 -14
  548. package/dist/marching-cubes.js +0 -542
  549. package/dist/math.d.ts +0 -91
  550. package/dist/math.js +0 -896
  551. package/dist/overlays/ContextMenu.svelte +0 -162
  552. package/dist/overlays/ContextMenu.svelte.d.ts +0 -25
  553. package/dist/overlays/CopyButton.svelte +0 -45
  554. package/dist/overlays/CopyButton.svelte.d.ts +0 -8
  555. package/dist/overlays/DraggablePane.svelte +0 -564
  556. package/dist/overlays/DraggablePane.svelte.d.ts +0 -36
  557. package/dist/overlays/InfoPaneCards.svelte +0 -149
  558. package/dist/overlays/InfoPaneCards.svelte.d.ts +0 -22
  559. package/dist/overlays/index.d.ts +0 -2
  560. package/dist/overlays/index.js +0 -2
  561. package/dist/periodic-table/PeriodicTable.svelte +0 -469
  562. package/dist/periodic-table/PeriodicTable.svelte.d.ts +0 -55
  563. package/dist/periodic-table/PeriodicTableControls.svelte +0 -557
  564. package/dist/periodic-table/PeriodicTableControls.svelte.d.ts +0 -24
  565. package/dist/periodic-table/PropertySelect.svelte +0 -37
  566. package/dist/periodic-table/PropertySelect.svelte.d.ts +0 -13
  567. package/dist/periodic-table/TableInset.svelte.d.ts +0 -9
  568. package/dist/periodic-table/index.d.ts +0 -10
  569. package/dist/periodic-table/index.js +0 -4
  570. package/dist/phase-diagram/IsobaricBinaryPhaseDiagram.svelte +0 -1084
  571. package/dist/phase-diagram/IsobaricBinaryPhaseDiagram.svelte.d.ts +0 -44
  572. package/dist/phase-diagram/PhaseDiagramControls.svelte +0 -449
  573. package/dist/phase-diagram/PhaseDiagramControls.svelte.d.ts +0 -30
  574. package/dist/phase-diagram/PhaseDiagramEditorPane.svelte +0 -126
  575. package/dist/phase-diagram/PhaseDiagramEditorPane.svelte.d.ts +0 -15
  576. package/dist/phase-diagram/PhaseDiagramExportPane.svelte +0 -192
  577. package/dist/phase-diagram/PhaseDiagramExportPane.svelte.d.ts +0 -19
  578. package/dist/phase-diagram/PhaseDiagramTooltip.svelte +0 -392
  579. package/dist/phase-diagram/PhaseDiagramTooltip.svelte.d.ts +0 -16
  580. package/dist/phase-diagram/TdbInfoPanel.svelte +0 -203
  581. package/dist/phase-diagram/TdbInfoPanel.svelte.d.ts +0 -12
  582. package/dist/phase-diagram/build-diagram.d.ts +0 -11
  583. package/dist/phase-diagram/build-diagram.js +0 -167
  584. package/dist/phase-diagram/colors.d.ts +0 -35
  585. package/dist/phase-diagram/colors.js +0 -51
  586. package/dist/phase-diagram/diagram-input.d.ts +0 -33
  587. package/dist/phase-diagram/diagram-input.js +0 -3
  588. package/dist/phase-diagram/index.d.ts +0 -13
  589. package/dist/phase-diagram/index.js +0 -13
  590. package/dist/phase-diagram/parse.d.ts +0 -55
  591. package/dist/phase-diagram/parse.js +0 -276
  592. package/dist/phase-diagram/svg-to-diagram.d.ts +0 -2
  593. package/dist/phase-diagram/svg-to-diagram.js +0 -867
  594. package/dist/phase-diagram/types.d.ts +0 -99
  595. package/dist/phase-diagram/types.js +0 -1
  596. package/dist/phase-diagram/utils.d.ts +0 -118
  597. package/dist/phase-diagram/utils.js +0 -606
  598. package/dist/plot/AxisLabel.svelte +0 -51
  599. package/dist/plot/AxisLabel.svelte.d.ts +0 -16
  600. package/dist/plot/BarPlot.svelte +0 -2265
  601. package/dist/plot/BarPlot.svelte.d.ts +0 -83
  602. package/dist/plot/BarPlotControls.svelte +0 -66
  603. package/dist/plot/BarPlotControls.svelte.d.ts +0 -18
  604. package/dist/plot/ColorBar.svelte +0 -719
  605. package/dist/plot/ColorBar.svelte.d.ts +0 -31
  606. package/dist/plot/ColorScaleSelect.svelte +0 -54
  607. package/dist/plot/ColorScaleSelect.svelte.d.ts +0 -15
  608. package/dist/plot/ElementScatter.svelte +0 -63
  609. package/dist/plot/ElementScatter.svelte.d.ts +0 -14
  610. package/dist/plot/FillArea.svelte +0 -225
  611. package/dist/plot/FillArea.svelte.d.ts +0 -21
  612. package/dist/plot/Histogram.svelte +0 -1672
  613. package/dist/plot/Histogram.svelte.d.ts +0 -50
  614. package/dist/plot/HistogramControls.svelte +0 -212
  615. package/dist/plot/HistogramControls.svelte.d.ts +0 -22
  616. package/dist/plot/InteractiveAxisLabel.svelte +0 -94
  617. package/dist/plot/InteractiveAxisLabel.svelte.d.ts +0 -14
  618. package/dist/plot/Line.svelte +0 -84
  619. package/dist/plot/Line.svelte.d.ts +0 -15
  620. package/dist/plot/PlotControls.svelte +0 -537
  621. package/dist/plot/PlotControls.svelte.d.ts +0 -4
  622. package/dist/plot/PlotLegend.svelte +0 -569
  623. package/dist/plot/PlotLegend.svelte.d.ts +0 -29
  624. package/dist/plot/PlotTooltip.svelte +0 -67
  625. package/dist/plot/PlotTooltip.svelte.d.ts +0 -17
  626. package/dist/plot/PortalSelect.svelte +0 -253
  627. package/dist/plot/PortalSelect.svelte.d.ts +0 -16
  628. package/dist/plot/ReferenceLine.svelte.d.ts +0 -20
  629. package/dist/plot/ReferenceLine3D.svelte +0 -154
  630. package/dist/plot/ReferenceLine3D.svelte.d.ts +0 -14
  631. package/dist/plot/ReferencePlane.svelte +0 -178
  632. package/dist/plot/ReferencePlane.svelte.d.ts +0 -14
  633. package/dist/plot/ScatterPlot.svelte +0 -2845
  634. package/dist/plot/ScatterPlot.svelte.d.ts +0 -93
  635. package/dist/plot/ScatterPlot3D.svelte +0 -502
  636. package/dist/plot/ScatterPlot3D.svelte.d.ts +0 -94
  637. package/dist/plot/ScatterPlot3DControls.svelte +0 -437
  638. package/dist/plot/ScatterPlot3DControls.svelte.d.ts +0 -20
  639. package/dist/plot/ScatterPlot3DScene.svelte +0 -912
  640. package/dist/plot/ScatterPlot3DScene.svelte.d.ts +0 -74
  641. package/dist/plot/ScatterPlotControls.svelte +0 -307
  642. package/dist/plot/ScatterPlotControls.svelte.d.ts +0 -17
  643. package/dist/plot/ScatterPoint.svelte +0 -191
  644. package/dist/plot/ScatterPoint.svelte.d.ts +0 -21
  645. package/dist/plot/SpacegroupBarPlot.svelte +0 -293
  646. package/dist/plot/SpacegroupBarPlot.svelte.d.ts +0 -9
  647. package/dist/plot/Surface3D.svelte +0 -200
  648. package/dist/plot/Surface3D.svelte.d.ts +0 -13
  649. package/dist/plot/ZeroLines.svelte +0 -96
  650. package/dist/plot/ZeroLines.svelte.d.ts +0 -32
  651. package/dist/plot/ZoomRect.svelte +0 -23
  652. package/dist/plot/ZoomRect.svelte.d.ts +0 -8
  653. package/dist/plot/axis-utils.d.ts +0 -19
  654. package/dist/plot/axis-utils.js +0 -80
  655. package/dist/plot/data-cleaning.d.ts +0 -37
  656. package/dist/plot/data-cleaning.js +0 -855
  657. package/dist/plot/data-transform.d.ts +0 -16
  658. package/dist/plot/data-transform.js +0 -45
  659. package/dist/plot/defaults.d.ts +0 -19
  660. package/dist/plot/defaults.js +0 -9
  661. package/dist/plot/fill-utils.d.ts +0 -51
  662. package/dist/plot/fill-utils.js +0 -337
  663. package/dist/plot/hover-lock.svelte.d.ts +0 -14
  664. package/dist/plot/hover-lock.svelte.js +0 -46
  665. package/dist/plot/index.d.ts +0 -37
  666. package/dist/plot/index.js +0 -37
  667. package/dist/plot/interactions.d.ts +0 -12
  668. package/dist/plot/interactions.js +0 -100
  669. package/dist/plot/layout.d.ts +0 -60
  670. package/dist/plot/layout.js +0 -230
  671. package/dist/plot/reference-line.d.ts +0 -60
  672. package/dist/plot/reference-line.js +0 -316
  673. package/dist/plot/scales.d.ts +0 -48
  674. package/dist/plot/scales.js +0 -484
  675. package/dist/plot/svg.d.ts +0 -1
  676. package/dist/plot/svg.js +0 -11
  677. package/dist/plot/types.d.ts +0 -859
  678. package/dist/plot/types.js +0 -103
  679. package/dist/plot/utils/label-placement.d.ts +0 -47
  680. package/dist/plot/utils/label-placement.js +0 -256
  681. package/dist/plot/utils/series-visibility.d.ts +0 -9
  682. package/dist/plot/utils/series-visibility.js +0 -67
  683. package/dist/plot/utils.d.ts +0 -1
  684. package/dist/plot/utils.js +0 -14
  685. package/dist/rdf/RdfPlot.svelte +0 -247
  686. package/dist/rdf/RdfPlot.svelte.d.ts +0 -27
  687. package/dist/rdf/calc-rdf.d.ts +0 -4
  688. package/dist/rdf/calc-rdf.js +0 -111
  689. package/dist/rdf/index.d.ts +0 -23
  690. package/dist/rdf/index.js +0 -2
  691. package/dist/sanitize.d.ts +0 -4
  692. package/dist/sanitize.js +0 -114
  693. package/dist/settings.d.ts +0 -255
  694. package/dist/settings.js +0 -1132
  695. package/dist/spectral/Bands.svelte +0 -1040
  696. package/dist/spectral/Bands.svelte.d.ts +0 -40
  697. package/dist/spectral/BandsAndDos.svelte +0 -128
  698. package/dist/spectral/BandsAndDos.svelte.d.ts +0 -18
  699. package/dist/spectral/BrillouinBandsDos.svelte +0 -248
  700. package/dist/spectral/BrillouinBandsDos.svelte.d.ts +0 -20
  701. package/dist/spectral/Dos.svelte +0 -697
  702. package/dist/spectral/Dos.svelte.d.ts +0 -29
  703. package/dist/spectral/helpers.d.ts +0 -117
  704. package/dist/spectral/helpers.js +0 -1023
  705. package/dist/spectral/index.d.ts +0 -6
  706. package/dist/spectral/index.js +0 -7
  707. package/dist/spectral/types.d.ts +0 -84
  708. package/dist/spectral/types.js +0 -2
  709. package/dist/state.svelte.d.ts +0 -25
  710. package/dist/state.svelte.js +0 -45
  711. package/dist/structure/Arrow.svelte +0 -72
  712. package/dist/structure/Arrow.svelte.d.ts +0 -15
  713. package/dist/structure/AtomLegend.svelte +0 -798
  714. package/dist/structure/AtomLegend.svelte.d.ts +0 -34
  715. package/dist/structure/Bond.svelte +0 -140
  716. package/dist/structure/Bond.svelte.d.ts +0 -9
  717. package/dist/structure/CanvasTooltip.svelte +0 -33
  718. package/dist/structure/CanvasTooltip.svelte.d.ts +0 -12
  719. package/dist/structure/CellSelect.svelte +0 -351
  720. package/dist/structure/CellSelect.svelte.d.ts +0 -13
  721. package/dist/structure/Cylinder.svelte +0 -45
  722. package/dist/structure/Cylinder.svelte.d.ts +0 -10
  723. package/dist/structure/Lattice.svelte +0 -196
  724. package/dist/structure/Lattice.svelte.d.ts +0 -17
  725. package/dist/structure/Structure.svelte +0 -1999
  726. package/dist/structure/Structure.svelte.d.ts +0 -87
  727. package/dist/structure/StructureControls.svelte +0 -1298
  728. package/dist/structure/StructureControls.svelte.d.ts +0 -31
  729. package/dist/structure/StructureExportPane.svelte +0 -251
  730. package/dist/structure/StructureExportPane.svelte.d.ts +0 -17
  731. package/dist/structure/StructureInfoPane.svelte +0 -735
  732. package/dist/structure/StructureInfoPane.svelte.d.ts +0 -19
  733. package/dist/structure/StructureScene.svelte +0 -1905
  734. package/dist/structure/StructureScene.svelte.d.ts +0 -108
  735. package/dist/structure/atom-properties.d.ts +0 -37
  736. package/dist/structure/atom-properties.js +0 -200
  737. package/dist/structure/bond-order-perception.d.ts +0 -13
  738. package/dist/structure/bond-order-perception.js +0 -367
  739. package/dist/structure/bonding.d.ts +0 -42
  740. package/dist/structure/bonding.js +0 -525
  741. package/dist/structure/export.d.ts +0 -20
  742. package/dist/structure/export.js +0 -727
  743. package/dist/structure/index.d.ts +0 -125
  744. package/dist/structure/index.js +0 -171
  745. package/dist/structure/label-placement.d.ts +0 -14
  746. package/dist/structure/label-placement.js +0 -72
  747. package/dist/structure/measure.d.ts +0 -6
  748. package/dist/structure/measure.js +0 -29
  749. package/dist/structure/parse.d.ts +0 -66
  750. package/dist/structure/parse.js +0 -1363
  751. package/dist/structure/partial-occupancy.d.ts +0 -25
  752. package/dist/structure/partial-occupancy.js +0 -99
  753. package/dist/structure/pbc.d.ts +0 -9
  754. package/dist/structure/pbc.js +0 -123
  755. package/dist/structure/supercell.d.ts +0 -8
  756. package/dist/structure/supercell.js +0 -170
  757. package/dist/structure/validation.d.ts +0 -2
  758. package/dist/structure/validation.js +0 -10
  759. package/dist/symmetry/SymmetryStats.svelte +0 -226
  760. package/dist/symmetry/SymmetryStats.svelte.d.ts +0 -21
  761. package/dist/symmetry/WyckoffTable.svelte +0 -113
  762. package/dist/symmetry/WyckoffTable.svelte.d.ts +0 -11
  763. package/dist/symmetry/cell-transform.d.ts +0 -12
  764. package/dist/symmetry/cell-transform.js +0 -91
  765. package/dist/symmetry/index.d.ts +0 -43
  766. package/dist/symmetry/index.js +0 -229
  767. package/dist/symmetry/spacegroups.d.ts +0 -9
  768. package/dist/symmetry/spacegroups.js +0 -394
  769. package/dist/table/HeatmapTable.svelte +0 -1854
  770. package/dist/table/HeatmapTable.svelte.d.ts +0 -49
  771. package/dist/table/ToggleMenu.svelte +0 -376
  772. package/dist/table/ToggleMenu.svelte.d.ts +0 -11
  773. package/dist/table/index.d.ts +0 -74
  774. package/dist/table/index.js +0 -38
  775. package/dist/theme/ThemeControl.svelte +0 -53
  776. package/dist/theme/ThemeControl.svelte.d.ts +0 -9
  777. package/dist/theme/index.d.ts +0 -29
  778. package/dist/theme/index.js +0 -79
  779. package/dist/theme/themes.mjs +0 -285
  780. package/dist/time.d.ts +0 -4
  781. package/dist/time.js +0 -70
  782. package/dist/tooltip/TooltipContent.svelte +0 -58
  783. package/dist/tooltip/TooltipContent.svelte.d.ts +0 -31
  784. package/dist/tooltip/index.d.ts +0 -2
  785. package/dist/tooltip/index.js +0 -2
  786. package/dist/tooltip/types.d.ts +0 -8
  787. package/dist/tooltip/types.js +0 -1
  788. package/dist/trajectory/Trajectory.svelte +0 -1517
  789. package/dist/trajectory/Trajectory.svelte.d.ts +0 -77
  790. package/dist/trajectory/TrajectoryError.svelte +0 -128
  791. package/dist/trajectory/TrajectoryError.svelte.d.ts +0 -13
  792. package/dist/trajectory/TrajectoryExportPane.svelte +0 -357
  793. package/dist/trajectory/TrajectoryExportPane.svelte.d.ts +0 -17
  794. package/dist/trajectory/TrajectoryInfoPane.svelte +0 -313
  795. package/dist/trajectory/TrajectoryInfoPane.svelte.d.ts +0 -17
  796. package/dist/trajectory/constants.d.ts +0 -6
  797. package/dist/trajectory/constants.js +0 -7
  798. package/dist/trajectory/extract.d.ts +0 -5
  799. package/dist/trajectory/extract.js +0 -162
  800. package/dist/trajectory/format-detect.d.ts +0 -9
  801. package/dist/trajectory/format-detect.js +0 -76
  802. package/dist/trajectory/frame-reader.d.ts +0 -17
  803. package/dist/trajectory/frame-reader.js +0 -332
  804. package/dist/trajectory/helpers.d.ts +0 -14
  805. package/dist/trajectory/helpers.js +0 -172
  806. package/dist/trajectory/index.d.ts +0 -63
  807. package/dist/trajectory/index.js +0 -126
  808. package/dist/trajectory/parse/ase.d.ts +0 -2
  809. package/dist/trajectory/parse/ase.js +0 -73
  810. package/dist/trajectory/parse/hdf5.d.ts +0 -2
  811. package/dist/trajectory/parse/hdf5.js +0 -127
  812. package/dist/trajectory/parse/index.d.ts +0 -12
  813. package/dist/trajectory/parse/index.js +0 -299
  814. package/dist/trajectory/parse/lammps.d.ts +0 -5
  815. package/dist/trajectory/parse/lammps.js +0 -179
  816. package/dist/trajectory/parse/vasp.d.ts +0 -2
  817. package/dist/trajectory/parse/vasp.js +0 -68
  818. package/dist/trajectory/parse/xyz.d.ts +0 -2
  819. package/dist/trajectory/parse/xyz.js +0 -110
  820. package/dist/trajectory/plotting.d.ts +0 -28
  821. package/dist/trajectory/plotting.js +0 -423
  822. package/dist/trajectory/types.d.ts +0 -11
  823. package/dist/trajectory/types.js +0 -1
  824. package/dist/utils.d.ts +0 -5
  825. package/dist/utils.js +0 -36
  826. package/dist/xrd/XrdPlot.svelte +0 -615
  827. package/dist/xrd/XrdPlot.svelte.d.ts +0 -28
  828. package/dist/xrd/broadening.d.ts +0 -20
  829. package/dist/xrd/broadening.js +0 -97
  830. package/dist/xrd/calc-xrd.d.ts +0 -37
  831. package/dist/xrd/calc-xrd.js +0 -337
  832. package/dist/xrd/index.d.ts +0 -37
  833. package/dist/xrd/index.js +0 -4
  834. package/dist/xrd/parse.d.ts +0 -13
  835. package/dist/xrd/parse.js +0 -749
  836. /package/dist/{EmptyState.svelte → src/lib/EmptyState.svelte} +0 -0
  837. /package/dist/{Icon.svelte → src/lib/Icon.svelte} +0 -0
  838. /package/dist/{app.css → src/lib/app.css} +0 -0
  839. /package/dist/{chempot-diagram → src/lib/chempot-diagram}/ChemPotScene3D.svelte +0 -0
  840. /package/dist/{colors → src/lib/colors}/alloy-colors.json +0 -0
  841. /package/dist/{colors → src/lib/colors}/dark-mode-colors.json +0 -0
  842. /package/dist/{colors → src/lib/colors}/jmol-colors.json +0 -0
  843. /package/dist/{colors → src/lib/colors}/muted-colors.json +0 -0
  844. /package/dist/{colors → src/lib/colors}/pastel-colors.json +0 -0
  845. /package/dist/{colors → src/lib/colors}/vesta-colors.json +0 -0
  846. /package/dist/{element → src/lib/element}/Nucleus.svelte +0 -0
  847. /package/dist/{element → src/lib/element}/data.json +0 -0
  848. /package/dist/{element → src/lib/element}/data.json.gz +0 -0
  849. /package/dist/{element → src/lib/element}/data.schema.json +0 -0
  850. /package/dist/{element-image-urls.json → src/lib/element-image-urls.json} +0 -0
  851. /package/dist/{feedback → src/lib/feedback}/Spinner.svelte +0 -0
  852. /package/dist/{feedback → src/lib/feedback}/StatusMessage.svelte +0 -0
  853. /package/dist/{periodic-table → src/lib/periodic-table}/TableInset.svelte +0 -0
  854. /package/dist/{plot → src/lib/plot}/ReferenceLine.svelte +0 -0
  855. /package/dist/{xrd → src/lib/xrd}/atomic_scattering_params.json +0 -0
@@ -0,0 +1,1081 @@
1
+ import type { LatticeParams, Pbc } from '$lib/structure/index'
2
+
3
+ export type Vec2 = [number, number]
4
+ export type Vec3 = [number, number, number]
5
+ export type Vec4 = [number, number, number, number]
6
+ export type Vec9 = [number, number, number, number, number, number, number, number, number]
7
+ export type Point2D = { x: number; y: number }
8
+ export type Point3D = Point2D & { z: number }
9
+ export type Matrix3x3 = [Vec3, Vec3, Vec3]
10
+ export type Matrix4x4 = [Vec4, Vec4, Vec4, Vec4]
11
+ export type NdVector = number[]
12
+
13
+ export const is_finite_vec3_like = (
14
+ values: ArrayLike<unknown> | undefined,
15
+ ): values is ArrayLike<number> => {
16
+ if (values?.length !== 3) return false
17
+ return [0, 1, 2].every(
18
+ (idx) => typeof values[idx] === `number` && Number.isFinite(values[idx]),
19
+ )
20
+ }
21
+
22
+ export const finite_vec3_from_values = (
23
+ values: ArrayLike<unknown> | undefined,
24
+ ): Vec3 | undefined => {
25
+ if (!is_finite_vec3_like(values)) return undefined
26
+ return [values[0], values[1], values[2]]
27
+ }
28
+
29
+ // Column-major 4x4 matrix as flat 16-element tuple (for Three.js/WebGL)
30
+ // oxfmt-ignore
31
+ export type Matrix4Tuple = [
32
+ number, number, number, number,
33
+ number, number, number, number,
34
+ number, number, number, number,
35
+ number, number, number, number,
36
+ ]
37
+
38
+ // Generate all k-element combinations from an array.
39
+ export function combinations<T>(arr: T[], k: number): T[][] {
40
+ if (k === 0) return [[]]
41
+ if (arr.length < k) return []
42
+ const [first, ...rest] = arr
43
+ return [
44
+ ...combinations(rest, k - 1).map((combo) => [first, ...combo]),
45
+ ...combinations(rest, k),
46
+ ]
47
+ }
48
+
49
+ export const LOG_EPS = 1e-9
50
+ export const EPS = 1e-10
51
+ export const RAD_TO_DEG = 180 / Math.PI
52
+ export const DEG_TO_RAD = Math.PI / 180
53
+ const MAX_MIN_IMAGE_CANDIDATES = 100_000
54
+
55
+ export const to_degrees = (radians: number): number => radians * RAD_TO_DEG
56
+ export const to_radians = (degrees: number): number => degrees * DEG_TO_RAD
57
+
58
+ // Calculate all lattice parameters in a single efficient pass
59
+ export function calc_lattice_params(matrix: Matrix3x3): LatticeParams & { volume: number } {
60
+ const [a_vec, b_vec, c_vec] = matrix
61
+
62
+ // Calculate vector lengths (lattice parameters a, b, c)
63
+ const a = Math.hypot(a_vec[0], a_vec[1], a_vec[2])
64
+ const b = Math.hypot(b_vec[0], b_vec[1], b_vec[2])
65
+ const c = Math.hypot(c_vec[0], c_vec[1], c_vec[2])
66
+
67
+ // Calculate volume using scalar triple product
68
+ const volume = Math.abs(
69
+ a_vec[0] * (b_vec[1] * c_vec[2] - b_vec[2] * c_vec[1]) +
70
+ a_vec[1] * (b_vec[2] * c_vec[0] - b_vec[0] * c_vec[2]) +
71
+ a_vec[2] * (b_vec[0] * c_vec[1] - b_vec[1] * c_vec[0]),
72
+ )
73
+
74
+ // Calculate dot products for angles (only once each)
75
+ const dot_ab = a_vec[0] * b_vec[0] + a_vec[1] * b_vec[1] + a_vec[2] * b_vec[2]
76
+ const dot_ac = a_vec[0] * c_vec[0] + a_vec[1] * c_vec[1] + a_vec[2] * c_vec[2]
77
+ const dot_bc = b_vec[0] * c_vec[0] + b_vec[1] * c_vec[1] + b_vec[2] * c_vec[2]
78
+
79
+ // Convert to angles in degrees
80
+ const alpha = Math.acos(dot_bc / (b * c)) * RAD_TO_DEG
81
+ const beta = Math.acos(dot_ac / (a * c)) * RAD_TO_DEG
82
+ const gamma = Math.acos(dot_ab / (a * b)) * RAD_TO_DEG
83
+
84
+ return { a, b, c, alpha, beta, gamma, volume }
85
+ }
86
+
87
+ export const scale = <T extends NdVector>(vec: T, factor: number): T =>
88
+ vec.map((component) => component * factor) as T
89
+
90
+ export const euclidean_dist = (vec1: NdVector, vec2: NdVector): number => {
91
+ if (vec1.length !== vec2.length) {
92
+ throw new Error(`Vectors must be of same length`)
93
+ }
94
+ return Math.hypot(...vec1.map((x, idx) => x - vec2[idx]))
95
+ }
96
+
97
+ const vec3_norm_sq = (vec: Vec3): number => vec[0] ** 2 + vec[1] ** 2 + vec[2] ** 2
98
+
99
+ // Exact minimum-image displacement for row-vector lattices.
100
+ // Rounded fractional wrapping is only approximate for highly skewed cells, so
101
+ // we use it as a starting guess and then search the small set of shifts that
102
+ // can still beat that Cartesian radius.
103
+ export function min_image_displacement(
104
+ from: Vec3,
105
+ to: Vec3,
106
+ lattice_matrix: Matrix3x3,
107
+ converters?: LatticeConverters,
108
+ pbc: Pbc = [true, true, true],
109
+ ): Vec3 {
110
+ const { cart_to_frac, frac_to_cart, reciprocal_axis_norms } =
111
+ converters ?? create_lattice_converters(lattice_matrix)
112
+ const frac_from = cart_to_frac(from)
113
+ const frac_to = cart_to_frac(to)
114
+ const frac_diff: Vec3 = [
115
+ frac_to[0] - frac_from[0],
116
+ frac_to[1] - frac_from[1],
117
+ frac_to[2] - frac_from[2],
118
+ ]
119
+ const wrapped_frac_diff: Vec3 = [
120
+ pbc[0] ? frac_diff[0] - Math.round(frac_diff[0]) : frac_diff[0],
121
+ pbc[1] ? frac_diff[1] - Math.round(frac_diff[1]) : frac_diff[1],
122
+ pbc[2] ? frac_diff[2] - Math.round(frac_diff[2]) : frac_diff[2],
123
+ ]
124
+
125
+ let best_displacement = frac_to_cart(wrapped_frac_diff)
126
+ let best_dist_sq = vec3_norm_sq(best_displacement)
127
+ const search_radius = Math.sqrt(best_dist_sq) + EPS
128
+ const candidate_shift_ranges = ([0, 1, 2] as const).map((axis_idx) => {
129
+ if (!pbc[axis_idx]) return [0, 0] as const
130
+ const axis_bound = reciprocal_axis_norms[axis_idx] * search_radius
131
+ return [
132
+ Math.ceil(-frac_diff[axis_idx] - axis_bound),
133
+ Math.floor(-frac_diff[axis_idx] + axis_bound),
134
+ ] as const
135
+ })
136
+ let candidate_count = 1
137
+ for (const [shift_min, shift_max] of candidate_shift_ranges) {
138
+ candidate_count *= shift_max - shift_min + 1
139
+ if (candidate_count > MAX_MIN_IMAGE_CANDIDATES) {
140
+ throw new Error(
141
+ `Minimum-image search would test >${MAX_MIN_IMAGE_CANDIDATES} candidates ` +
142
+ `for lattice ${JSON.stringify(lattice_matrix)}; reciprocal norms=` +
143
+ `${JSON.stringify(reciprocal_axis_norms)} ranges=${JSON.stringify(candidate_shift_ranges)}`,
144
+ )
145
+ }
146
+ }
147
+ const [[i_min, i_max], [j_min, j_max], [k_min, k_max]] = candidate_shift_ranges
148
+
149
+ // Only test integer shifts that reciprocal-space bounds say could still win.
150
+ for (let ii = i_min; ii <= i_max; ii++) {
151
+ for (let jj = j_min; jj <= j_max; jj++) {
152
+ for (let kk = k_min; kk <= k_max; kk++) {
153
+ const candidate_frac_diff: Vec3 = [
154
+ frac_diff[0] + ii,
155
+ frac_diff[1] + jj,
156
+ frac_diff[2] + kk,
157
+ ]
158
+ const candidate_displacement = frac_to_cart(candidate_frac_diff)
159
+ const candidate_dist_sq = vec3_norm_sq(candidate_displacement)
160
+ if (candidate_dist_sq < best_dist_sq) {
161
+ best_dist_sq = candidate_dist_sq
162
+ best_displacement = candidate_displacement
163
+ }
164
+ }
165
+ }
166
+ }
167
+
168
+ return best_displacement
169
+ }
170
+
171
+ // Calculate the minimum distance between two points considering periodic boundary conditions.
172
+ export const pbc_dist = (
173
+ pos1: Vec3,
174
+ pos2: Vec3,
175
+ lattice_matrix: Matrix3x3,
176
+ converters?: LatticeConverters,
177
+ pbc: Pbc = [true, true, true],
178
+ ): number => Math.hypot(...min_image_displacement(pos1, pos2, lattice_matrix, converters, pbc))
179
+
180
+ export function matrix_inverse_3x3(matrix: Matrix3x3): Matrix3x3 {
181
+ const [[m11, m12, m13], [m21, m22, m23], [m31, m32, m33]] = matrix
182
+
183
+ const det = det_3x3(matrix)
184
+
185
+ if (!Number.isFinite(det) || Math.abs(det) < EPS) {
186
+ throw new Error(`Matrix is singular or ill-conditioned; cannot invert`)
187
+ }
188
+
189
+ const inv_det = 1 / det
190
+
191
+ return [
192
+ [
193
+ (m22 * m33 - m23 * m32) * inv_det,
194
+ (m13 * m32 - m12 * m33) * inv_det,
195
+ (m12 * m23 - m13 * m22) * inv_det,
196
+ ],
197
+ [
198
+ (m23 * m31 - m21 * m33) * inv_det,
199
+ (m11 * m33 - m13 * m31) * inv_det,
200
+ (m13 * m21 - m11 * m23) * inv_det,
201
+ ],
202
+ [
203
+ (m21 * m32 - m22 * m31) * inv_det,
204
+ (m12 * m31 - m11 * m32) * inv_det,
205
+ (m11 * m22 - m12 * m21) * inv_det,
206
+ ],
207
+ ]
208
+ }
209
+
210
+ // Multiply a 3x3 matrix by a 3D vector
211
+ export function mat3x3_vec3_multiply(matrix: Matrix3x3, vector: Vec3): Vec3 {
212
+ const [a, b, c] = matrix
213
+ const [x, y, z] = vector
214
+ const a_new = a[0] * x + a[1] * y + a[2] * z
215
+ const b_new = b[0] * x + b[1] * y + b[2] * z
216
+ const c_new = c[0] * x + c[1] * y + c[2] * z
217
+ return [a_new, b_new, c_new]
218
+ }
219
+
220
+ export function add<T extends NdVector>(...vecs: T[]): T {
221
+ // add up any number of same-length vectors
222
+ if (vecs.length === 0) throw new Error(`Cannot add zero vectors`)
223
+
224
+ const first_vec = vecs[0]
225
+ const length = first_vec.length
226
+
227
+ // Validate all vectors have the same length
228
+ for (const vec of vecs) {
229
+ if (vec.length !== length) {
230
+ throw new Error(`All vectors must have the same length`)
231
+ }
232
+ }
233
+
234
+ const result = Array.from<number>({ length }).fill(0)
235
+ for (const vec of vecs) {
236
+ for (let idx = 0; idx < length; idx++) {
237
+ result[idx] += vec[idx]
238
+ }
239
+ }
240
+ return result as T
241
+ }
242
+
243
+ export function subtract<T extends NdVector>(vec1: T, vec2: T): T {
244
+ if (vec1.length !== vec2.length) {
245
+ throw new Error(`Vectors must be of same length`)
246
+ }
247
+ return vec1.map((val, idx) => val - vec2[idx]) as T
248
+ }
249
+
250
+ // Validate matrix structure and return column count
251
+ function validate_matrix(mat: number[][], name: string): number {
252
+ // Check for empty matrix (no rows)
253
+ if (mat.length === 0) {
254
+ throw new Error(`${name} must have at least one row`)
255
+ }
256
+
257
+ if (!mat.every((row) => Array.isArray(row))) {
258
+ throw new Error(`${name} must contain only array rows (no undefined/non-array elements)`)
259
+ }
260
+
261
+ const cols = mat[0]?.length
262
+ if (!Number.isFinite(cols)) throw new Error(`${name} has no columns`)
263
+
264
+ // Check for zero columns
265
+ if (cols === 0) {
266
+ throw new Error(`${name} must have at least one column`)
267
+ }
268
+
269
+ if (!mat.every((row) => row.length === cols)) {
270
+ throw new Error(`${name} must be rectangular`)
271
+ }
272
+ return cols
273
+ }
274
+
275
+ export function dot(vec1: NdVector, vec2: NdVector): number
276
+ export function dot(vec1: NdVector[], vec2: NdVector): number[]
277
+ export function dot(vec1: NdVector[], vec2: NdVector[]): number[][]
278
+ export function dot(
279
+ vec1: NdVector | NdVector[],
280
+ vec2: NdVector | NdVector[],
281
+ ): number | number[] | number[][] {
282
+ const vec1_is_matrix = vec1.some((entry) => Array.isArray(entry))
283
+ const vec2_is_matrix = vec2.some((entry) => Array.isArray(entry))
284
+
285
+ // Vector dot product
286
+ if (!vec1_is_matrix && !vec2_is_matrix) {
287
+ const left_vec = vec1 as number[]
288
+ const right_vec = vec2 as number[]
289
+ if (left_vec.length !== right_vec.length) {
290
+ throw new Error(`Vectors must be of same length`)
291
+ }
292
+ return left_vec.reduce((sum, val, idx) => sum + val * right_vec[idx], 0)
293
+ }
294
+
295
+ // Matrix-vector multiplication
296
+ if (vec1_is_matrix && !vec2_is_matrix) {
297
+ const mat = vec1 as number[][]
298
+ const vec = vec2 as number[]
299
+ const cols = validate_matrix(mat, `Matrix`)
300
+ if (cols !== vec.length) {
301
+ throw new Error(`Matrix columns must equal vector length`)
302
+ }
303
+ return mat.map((row) => row.reduce((sum, val, idx) => sum + val * vec[idx], 0))
304
+ }
305
+
306
+ // Matrix-matrix multiplication
307
+ if (vec1_is_matrix && vec2_is_matrix) {
308
+ const mat1 = vec1 as number[][]
309
+ const mat2 = vec2 as number[][]
310
+ const mat1_cols = validate_matrix(mat1, `First matrix`)
311
+ const mat2_cols = validate_matrix(mat2, `Second matrix`)
312
+ if (mat1_cols !== mat2.length) {
313
+ throw new Error(`First matrix columns must equal second matrix rows`)
314
+ }
315
+ return mat1.map((_row, ii) =>
316
+ Array.from({ length: mat2_cols }, (_col, jj) =>
317
+ mat1[ii].reduce((sum, _val, kk) => sum + mat1[ii][kk] * mat2[kk][jj], 0),
318
+ ),
319
+ )
320
+ }
321
+
322
+ throw new Error(`Unsupported input types for dot product`)
323
+ }
324
+
325
+ // Conversion utilities for vectors and tensors below
326
+
327
+ // Convert 3x3 symmetric tensor to 6-element Voigt notation vector
328
+ // Voigt notation maps: (1,1)->1, (2,2)->2, (3,3)->3, (2,3)->4, (1,3)->5, (1,2)->6
329
+ export function to_voigt(tensor: number[][]): number[] {
330
+ if (tensor.length !== 3 || !tensor.every((row) => row.length === 3)) {
331
+ throw new Error(`Expected 3x3 tensor, got ${tensor.length}x${tensor[0]?.length ?? `n/a`}`)
332
+ }
333
+ const [t11, t12, t13, _t21, t22, t23, _t31, _t32, t33] = tensor.flat()
334
+ return [t11, t22, t33, t23, t13, t12]
335
+ }
336
+
337
+ // Convert 6-element Voigt notation vector to 3x3 symmetric tensor
338
+ export function from_voigt(voigt: number[]): number[][] {
339
+ if (voigt.length !== 6) {
340
+ throw new Error(`Expected 6-element Voigt vector, got ${voigt.length} elements`)
341
+ }
342
+ const [v1, v2, v3, v4, v5, v6] = voigt
343
+
344
+ return [
345
+ [v1, v6, v5],
346
+ [v6, v2, v4],
347
+ [v5, v4, v3],
348
+ ]
349
+ }
350
+
351
+ // Convert flat 9-element array to 3x3 tensor (row-major order)
352
+ export function vec9_to_mat3x3(flat_array: number[]): number[][] {
353
+ if (flat_array.length !== 9) {
354
+ throw new Error(`Expected 9-element array, got ${flat_array.length} elements`)
355
+ }
356
+ const [a1, a2, a3, a4, a5, a6, a7, a8, a9] = flat_array
357
+ return [
358
+ [a1, a2, a3],
359
+ [a4, a5, a6],
360
+ [a7, a8, a9],
361
+ ]
362
+ }
363
+
364
+ // Convert 3x3 tensor to flat 9-element array (row-major order)
365
+ export function tensor_to_flat_array(tensor: number[][]): number[] {
366
+ if (tensor.length !== 3 || !tensor.every((row) => row.length === 3)) {
367
+ throw new Error(`Expected 3x3 tensor, got ${tensor.length}x${tensor[0]?.length ?? `n/a`}`)
368
+ }
369
+
370
+ const [t11, t12, t13, t21, t22, t23, t31, t32, t33] = tensor.flat()
371
+ return [t11, t12, t13, t21, t22, t23, t31, t32, t33]
372
+ }
373
+
374
+ // Transpose a 3x3 matrix
375
+ export const transpose_3x3_matrix = (matrix: Matrix3x3): Matrix3x3 => [
376
+ [matrix[0][0], matrix[1][0], matrix[2][0]],
377
+ [matrix[0][1], matrix[1][1], matrix[2][1]],
378
+ [matrix[0][2], matrix[1][2], matrix[2][2]],
379
+ ]
380
+
381
+ // Scale each row of a 3x3 matrix by the corresponding element of a Vec3.
382
+ // Used to scale lattice vectors by supercell factors.
383
+ export function scale_lattice_matrix(
384
+ orig_matrix: Matrix3x3,
385
+ scaling_factors: Vec3,
386
+ ): Matrix3x3 {
387
+ const [nx, ny, nz] = scaling_factors
388
+ const [a, b, c] = orig_matrix
389
+ return [
390
+ [a[0] * nx, a[1] * nx, a[2] * nx],
391
+ [b[0] * ny, b[1] * ny, b[2] * ny],
392
+ [c[0] * nz, c[1] * nz, c[2] * nz],
393
+ ]
394
+ }
395
+
396
+ const create_cart_to_frac_matrix = (lattice: Matrix3x3): Matrix3x3 =>
397
+ matrix_inverse_3x3(transpose_3x3_matrix(lattice))
398
+
399
+ // Curried fractional→Cartesian converter (caches transposed matrix)
400
+ export const create_frac_to_cart = (lattice: Matrix3x3) => {
401
+ const transposed = transpose_3x3_matrix(lattice)
402
+ return (frac: Vec3): Vec3 => mat3x3_vec3_multiply(transposed, frac)
403
+ }
404
+
405
+ // Curried Cartesian→fractional converter (caches inverse transpose)
406
+ export const create_cart_to_frac = (lattice: Matrix3x3) => {
407
+ const cart_to_frac_mat = create_cart_to_frac_matrix(lattice)
408
+ return (cart: Vec3): Vec3 => mat3x3_vec3_multiply(cart_to_frac_mat, cart)
409
+ }
410
+
411
+ // Paired converters for a lattice — the safe way to do cart↔frac conversion.
412
+ // Encapsulates the transpose convention so callers never touch raw matrices.
413
+ export type LatticeConverters = {
414
+ cart_to_frac: (v: Vec3) => Vec3
415
+ frac_to_cart: (v: Vec3) => Vec3
416
+ reciprocal_axis_norms: Vec3
417
+ }
418
+
419
+ export const create_lattice_converters = (lattice: Matrix3x3): LatticeConverters => {
420
+ const cart_to_frac_mat = create_cart_to_frac_matrix(lattice)
421
+ return {
422
+ cart_to_frac: (cart: Vec3): Vec3 => mat3x3_vec3_multiply(cart_to_frac_mat, cart),
423
+ frac_to_cart: create_frac_to_cart(lattice),
424
+ reciprocal_axis_norms: cart_to_frac_mat.map((row) => Math.hypot(...row)) as Vec3,
425
+ }
426
+ }
427
+
428
+ // Convert unit cell parameters to lattice matrix (crystallographic convention)
429
+ export function cell_to_lattice_matrix(
430
+ a: number,
431
+ b: number,
432
+ c: number,
433
+ alpha: number,
434
+ beta: number,
435
+ gamma: number,
436
+ ): Matrix3x3 {
437
+ // Convert angles to radians
438
+ const alpha_rad = alpha * DEG_TO_RAD
439
+ const beta_rad = beta * DEG_TO_RAD
440
+ const gamma_rad = gamma * DEG_TO_RAD
441
+
442
+ const cos_alpha = Math.cos(alpha_rad)
443
+ const cos_beta = Math.cos(beta_rad)
444
+ const cos_gamma = Math.cos(gamma_rad)
445
+ const sin_gamma = Math.sin(gamma_rad)
446
+
447
+ // Calculate volume factor for triclinic system
448
+ const vol_factor = Math.sqrt(
449
+ 1 - cos_alpha ** 2 - cos_beta ** 2 - cos_gamma ** 2 + 2 * cos_alpha * cos_beta * cos_gamma,
450
+ )
451
+
452
+ // Standard crystallographic lattice vectors
453
+ const c_x = c * cos_beta
454
+ const c_y = (c * (cos_alpha - cos_beta * cos_gamma)) / sin_gamma
455
+ const c_z = (c * vol_factor) / sin_gamma
456
+ return [
457
+ [a, 0, 0],
458
+ [b * cos_gamma, b * sin_gamma, 0],
459
+ [c_x, c_y, c_z],
460
+ ]
461
+ }
462
+
463
+ export function det_3x3(matrix: Matrix3x3): number {
464
+ // |A| = a(ei − fh) − b(di − fg) + c(dh − eg)
465
+ // where matrix = [[a, b, c], [d, e, f], [g, h, i]]
466
+ const [[m00, m01, m02], [m10, m11, m12], [m20, m21, m22]] = matrix
467
+ return (
468
+ m00 * (m11 * m22 - m12 * m21) -
469
+ m01 * (m10 * m22 - m12 * m20) +
470
+ m02 * (m10 * m21 - m11 * m20)
471
+ )
472
+ }
473
+
474
+ export function get_coefficient_of_variation(values: number[]): number {
475
+ if (values.length <= 1) return 0
476
+ const mean = values.reduce((sum, val) => sum + val, 0) / values.length
477
+ const variance = values.reduce((sum, val) => sum + (val - mean) ** 2, 0) / values.length
478
+ return Math.abs(mean) > 1e-10 ? Math.sqrt(variance) / Math.abs(mean) : Math.sqrt(variance)
479
+ }
480
+
481
+ // Compute 4x4 determinant (used for 4D barycentric coordinates)
482
+ export function det_4x4(matrix: Matrix4x4): number {
483
+ const [a_row, b_row, c_row, d_row] = matrix
484
+ const [a0, a1, a2, a3] = a_row
485
+ const [b0, b1, b2, b3] = b_row
486
+ const [c0, c1, c2, c3] = c_row
487
+ const [d0, d1, d2, d3] = d_row
488
+ return (
489
+ a0 * (b1 * (c2 * d3 - c3 * d2) - b2 * (c1 * d3 - c3 * d1) + b3 * (c1 * d2 - c2 * d1)) -
490
+ a1 * (b0 * (c2 * d3 - c3 * d2) - b2 * (c0 * d3 - c3 * d0) + b3 * (c0 * d2 - c2 * d0)) +
491
+ a2 * (b0 * (c1 * d3 - c3 * d1) - b1 * (c0 * d3 - c3 * d0) + b3 * (c0 * d1 - c1 * d0)) -
492
+ a3 * (b0 * (c1 * d2 - c2 * d1) - b1 * (c0 * d2 - c2 * d0) + b2 * (c0 * d1 - c1 * d0))
493
+ )
494
+ }
495
+
496
+ // Compute NxN determinant using LU decomposition with partial pivoting
497
+ // More numerically stable than cofactor expansion for N > 4
498
+ // Returns 0 for singular/near-singular matrices (pivot < EPS ≈ 1e-10)
499
+ export function det_nxn(matrix: number[][]): number {
500
+ const mat_size = matrix.length
501
+ if (mat_size === 0) return 1
502
+ if (!matrix.every((row) => row.length === mat_size)) {
503
+ throw new Error(`det_nxn requires a square matrix`)
504
+ }
505
+
506
+ // Fast paths for small matrices
507
+ if (mat_size === 1) return matrix[0][0]
508
+ if (mat_size === 2) return matrix[0][0] * matrix[1][1] - matrix[0][1] * matrix[1][0]
509
+ if (mat_size === 3) return det_3x3(matrix as Matrix3x3)
510
+ if (mat_size === 4) return det_4x4(matrix as Matrix4x4)
511
+
512
+ // LU decomposition with partial pivoting
513
+ // Create a working copy to avoid mutating input
514
+ const lu = matrix.map((row) => [...row])
515
+ let swaps = 0
516
+
517
+ for (let col = 0; col < mat_size; col++) {
518
+ // Find pivot (largest absolute value in column)
519
+ let [max_row, max_val] = [col, Math.abs(lu[col][col])]
520
+ for (let row = col + 1; row < mat_size; row++) {
521
+ const val = Math.abs(lu[row][col])
522
+ if (val > max_val) {
523
+ max_val = val
524
+ max_row = row
525
+ }
526
+ }
527
+
528
+ // Singular matrix (or nearly so)
529
+ if (max_val < EPS) return 0
530
+
531
+ // Swap rows if needed
532
+ if (max_row !== col) {
533
+ ;[lu[col], lu[max_row]] = [lu[max_row], lu[col]]
534
+ swaps++
535
+ }
536
+
537
+ // Eliminate below pivot
538
+ const pivot = lu[col][col]
539
+ for (let row = col + 1; row < mat_size; row++) {
540
+ const factor = lu[row][col] / pivot
541
+ lu[row][col] = 0
542
+ for (let k = col + 1; k < mat_size; k++) {
543
+ lu[row][k] -= factor * lu[col][k]
544
+ }
545
+ }
546
+ }
547
+
548
+ // Determinant is product of diagonal elements × (-1)^swaps
549
+ let det = swaps % 2 === 0 ? 1 : -1
550
+ for (let idx = 0; idx < mat_size; idx++) {
551
+ det *= lu[idx][idx]
552
+ }
553
+ return det
554
+ }
555
+
556
+ // 3D cross product
557
+ export const cross_3d = (vec1: Vec3, vec2: Vec3): Vec3 => [
558
+ vec1[1] * vec2[2] - vec1[2] * vec2[1],
559
+ vec1[2] * vec2[0] - vec1[0] * vec2[2],
560
+ vec1[0] * vec2[1] - vec1[1] * vec2[0],
561
+ ]
562
+
563
+ // Scalar linear interpolation
564
+ export const lerp = (start: number, end: number, t: number): number =>
565
+ start + t * (end - start)
566
+
567
+ // Vec3 linear interpolation
568
+ export const lerp_vec3 = (start: Vec3, end: Vec3, t: number): Vec3 => [
569
+ start[0] + t * (end[0] - start[0]),
570
+ start[1] + t * (end[1] - start[1]),
571
+ start[2] + t * (end[2] - start[2]),
572
+ ]
573
+
574
+ // Centered fractional part: offset from nearest integer, returns value in [-0.5, 0.5)
575
+ // Useful for wrapping coordinates to first Brillouin zone or similar periodic domains
576
+ export const centered_frac = (val: number): number => {
577
+ let wrapped = val - Math.round(val)
578
+ // Handle floating point edge cases at boundaries (range is [-0.5, 0.5), exclusive at +0.5)
579
+ if (wrapped < -0.5) wrapped += 1
580
+ if (wrapped >= 0.5) wrapped -= 1
581
+ return wrapped || 0 // normalize -0 to 0
582
+ }
583
+
584
+ // Element-wise equality check for two optional Vec3s.
585
+ // Returns true if both are the same reference, or both are defined with equal components.
586
+ export const vecs_equal = (vec_a?: Vec3, vec_b?: Vec3): boolean =>
587
+ vec_a === vec_b ||
588
+ (!!vec_a &&
589
+ !!vec_b &&
590
+ vec_a[0] === vec_b[0] &&
591
+ vec_a[1] === vec_b[1] &&
592
+ vec_a[2] === vec_b[2])
593
+
594
+ // Normalize a Vec3 to unit length, returns zero vector if input is zero
595
+ export function normalize_vec3(vec: Vec3, fallback?: Vec3): Vec3 {
596
+ const len = Math.hypot(vec[0], vec[1], vec[2])
597
+ if (len < EPS) return fallback ?? [0, 0, 0]
598
+ return [vec[0] / len, vec[1] / len, vec[2] / len]
599
+ }
600
+
601
+ // Compute orthonormal basis vectors in a plane perpendicular to `normal`.
602
+ // Uses Gram-Schmidt orthogonalization + cross product.
603
+ export function compute_in_plane_basis(normal: Vec3): [Vec3, Vec3] {
604
+ let ref_vec: Vec3 = [1, 0, 0]
605
+ if (Math.abs(normal[0]) > 0.9) ref_vec = [0, 1, 0]
606
+
607
+ const dot_nr = dot(normal, ref_vec)
608
+ const u_raw: Vec3 = [
609
+ ref_vec[0] - dot_nr * normal[0],
610
+ ref_vec[1] - dot_nr * normal[1],
611
+ ref_vec[2] - dot_nr * normal[2],
612
+ ]
613
+ const u_vec = normalize_vec3(u_raw, [0, 1, 0])
614
+ const v_vec = cross_3d(normal, u_vec)
615
+ return [u_vec, v_vec] // u, v basis vectors
616
+ }
617
+
618
+ // Check whether N 3D points all lie on the same plane within tolerance.
619
+ // Fewer than 3 points are trivially coplanar.
620
+ // Uses cross product to find a plane normal from non-collinear edges,
621
+ // then checks all remaining points have zero distance to that plane.
622
+ export function are_coplanar(points: number[][], tolerance = 1e-6): boolean {
623
+ if (points.length < 3) return true
624
+ const origin = points[0]
625
+ // Find first pair of edges from origin that are not collinear
626
+ let normal: Vec3 | null = null
627
+ for (let idx = 1; idx < points.length - 1; idx++) {
628
+ const edge_a: Vec3 = [
629
+ points[idx][0] - origin[0],
630
+ points[idx][1] - origin[1],
631
+ points[idx][2] - origin[2],
632
+ ]
633
+ for (let jdx = idx + 1; jdx < points.length; jdx++) {
634
+ const edge_b: Vec3 = [
635
+ points[jdx][0] - origin[0],
636
+ points[jdx][1] - origin[1],
637
+ points[jdx][2] - origin[2],
638
+ ]
639
+ const cross = cross_3d(edge_a, edge_b)
640
+ const len = Math.hypot(cross[0], cross[1], cross[2])
641
+ if (len > tolerance) {
642
+ normal = [cross[0] / len, cross[1] / len, cross[2] / len]
643
+ break
644
+ }
645
+ }
646
+ if (normal) break
647
+ }
648
+ // All edges are collinear -> all points lie on a line -> coplanar
649
+ if (!normal) return true
650
+ const plane_d = dot(normal, origin)
651
+ for (let idx = 1; idx < points.length; idx++) {
652
+ const dist = Math.abs(dot(normal, points[idx]) - plane_d)
653
+ if (dist > tolerance) return false
654
+ }
655
+ return true
656
+ }
657
+
658
+ // Merge coplanar adjacent triangles in a flat non-indexed position array.
659
+ // Takes 9 floats per triangle (3 vertices x 3 coords), groups adjacent coplanar
660
+ // triangles via union-find, then re-triangulates each group with fan triangulation
661
+ // to eliminate internal diagonal edges.
662
+ export function merge_coplanar_triangles(
663
+ positions: Float32Array,
664
+ tolerance = 1e-4,
665
+ ): Float32Array {
666
+ const n_triangles = Math.floor(positions.length / 9)
667
+ if (n_triangles === 0) return new Float32Array(positions)
668
+
669
+ // === Step 1: Extract triangles and compute plane for each ===
670
+ type TriPlane = {
671
+ verts: [Vec3, Vec3, Vec3]
672
+ normal: Vec3
673
+ plane_d: number
674
+ degenerate: boolean
675
+ }
676
+ const tri_planes: TriPlane[] = []
677
+ for (let tri_idx = 0; tri_idx < n_triangles; tri_idx++) {
678
+ const base = tri_idx * 9
679
+ const va: Vec3 = [positions[base], positions[base + 1], positions[base + 2]]
680
+ const vb: Vec3 = [positions[base + 3], positions[base + 4], positions[base + 5]]
681
+ const vc: Vec3 = [positions[base + 6], positions[base + 7], positions[base + 8]]
682
+ const edge_ab: Vec3 = [vb[0] - va[0], vb[1] - va[1], vb[2] - va[2]]
683
+ const edge_ac: Vec3 = [vc[0] - va[0], vc[1] - va[1], vc[2] - va[2]]
684
+ const raw_normal = cross_3d(edge_ab, edge_ac)
685
+ const len = Math.hypot(raw_normal[0], raw_normal[1], raw_normal[2])
686
+ if (len < tolerance) {
687
+ tri_planes.push({
688
+ verts: [va, vb, vc],
689
+ normal: [0, 0, 0],
690
+ plane_d: 0,
691
+ degenerate: true,
692
+ })
693
+ continue
694
+ }
695
+ // Normalize and canonicalize: first non-zero component must be positive
696
+ let normal: Vec3 = [raw_normal[0] / len, raw_normal[1] / len, raw_normal[2] / len]
697
+ const CANON_EPS = 1e-12
698
+ const first_nonzero =
699
+ Math.abs(normal[0]) > CANON_EPS
700
+ ? normal[0]
701
+ : Math.abs(normal[1]) > CANON_EPS
702
+ ? normal[1]
703
+ : normal[2]
704
+ if (first_nonzero < 0) normal = [-normal[0], -normal[1], -normal[2]]
705
+ const plane_d = dot(normal, va)
706
+ tri_planes.push({ verts: [va, vb, vc], normal, plane_d, degenerate: false })
707
+ }
708
+
709
+ // === Step 2: Build adjacency via edge hash map ===
710
+ // Quantize vertex to integer grid for hashing (only used for equality, not coords)
711
+ const vert_key = (v: Vec3): string =>
712
+ `${Math.round(v[0] / tolerance)},${Math.round(v[1] / tolerance)},${Math.round(
713
+ v[2] / tolerance,
714
+ )}`
715
+ const edge_key = (va: Vec3, vb: Vec3): string => {
716
+ const ka = vert_key(va)
717
+ const kb = vert_key(vb)
718
+ return ka < kb ? `${ka}|${kb}` : `${kb}|${ka}`
719
+ }
720
+ // Map edge -> list of triangle indices sharing that edge
721
+ const edge_to_tris = new Map<string, number[]>()
722
+ for (let tri_idx = 0; tri_idx < n_triangles; tri_idx++) {
723
+ const { verts, degenerate } = tri_planes[tri_idx]
724
+ if (degenerate) continue
725
+ const edges = [
726
+ edge_key(verts[0], verts[1]),
727
+ edge_key(verts[1], verts[2]),
728
+ edge_key(verts[0], verts[2]),
729
+ ]
730
+ for (const ek of edges) {
731
+ const existing = edge_to_tris.get(ek)
732
+ if (existing) existing.push(tri_idx)
733
+ else edge_to_tris.set(ek, [tri_idx])
734
+ }
735
+ }
736
+
737
+ // === Step 3: Union-Find grouping of coplanar adjacent triangles ===
738
+ const parent = new Int32Array(n_triangles)
739
+ const rank = new Int32Array(n_triangles)
740
+ for (let idx = 0; idx < n_triangles; idx++) parent[idx] = idx
741
+ const find = (x: number): number => {
742
+ while (parent[x] !== x) {
743
+ parent[x] = parent[parent[x]] // path compression
744
+ x = parent[x]
745
+ }
746
+ return x
747
+ }
748
+ const union = (a: number, b: number): void => {
749
+ const ra = find(a),
750
+ rb = find(b)
751
+ if (ra === rb) return
752
+ if (rank[ra] < rank[rb]) parent[ra] = rb
753
+ else if (rank[ra] > rank[rb]) parent[rb] = ra
754
+ else {
755
+ parent[rb] = ra
756
+ rank[ra]++
757
+ }
758
+ }
759
+ for (const tri_list of edge_to_tris.values()) {
760
+ if (tri_list.length !== 2) continue
761
+ const [idx_a, idx_b] = tri_list
762
+ const pa = tri_planes[idx_a]
763
+ const pb = tri_planes[idx_b]
764
+ if (pa.degenerate || pb.degenerate) continue
765
+ // Check coplanarity: same canonical normal direction AND same plane distance
766
+ const normal_dot =
767
+ pa.normal[0] * pb.normal[0] + pa.normal[1] * pb.normal[1] + pa.normal[2] * pb.normal[2]
768
+ if (Math.abs(normal_dot) < 1 - tolerance) continue
769
+ if (Math.abs(pa.plane_d - pb.plane_d) > tolerance) continue
770
+ union(idx_a, idx_b)
771
+ }
772
+
773
+ // === Step 4: Collect groups ===
774
+ const groups = new Map<number, number[]>()
775
+ for (let idx = 0; idx < n_triangles; idx++) {
776
+ const root = find(idx)
777
+ const group = groups.get(root)
778
+ if (group) group.push(idx)
779
+ else groups.set(root, [idx])
780
+ }
781
+
782
+ // === Step 5: Merge each group and re-triangulate ===
783
+ const output: number[] = []
784
+ // Push a triangle's 3 vertices (9 floats) to the output
785
+ const emit_tri = (va: Vec3, vb: Vec3, vc: Vec3): void => {
786
+ output.push(va[0], va[1], va[2], vb[0], vb[1], vb[2], vc[0], vc[1], vc[2])
787
+ }
788
+ const emit_original = (members: number[]): void => {
789
+ for (const tri_idx of members) {
790
+ const { verts } = tri_planes[tri_idx]
791
+ emit_tri(verts[0], verts[1], verts[2])
792
+ }
793
+ }
794
+ for (const members of groups.values()) {
795
+ if (members.length === 1) {
796
+ emit_original(members)
797
+ continue
798
+ }
799
+
800
+ const { normal } = tri_planes[members[0]]
801
+ // Collect all unique vertices from the group
802
+ const seen_keys = new Map<string, Vec3>()
803
+ for (const tri_idx of members) {
804
+ for (const vert of tri_planes[tri_idx].verts) {
805
+ const key = vert_key(vert)
806
+ if (!seen_keys.has(key)) seen_keys.set(key, vert)
807
+ }
808
+ }
809
+ const unique_verts = [...seen_keys.values()]
810
+ if (unique_verts.length < 3) {
811
+ emit_original(members)
812
+ continue
813
+ }
814
+
815
+ // Project to 2D using in-plane basis
816
+ const [u_vec, v_vec] = compute_in_plane_basis(normal)
817
+ const pts_2d = unique_verts.map((vertex): Vec2 => [dot(u_vec, vertex), dot(v_vec, vertex)])
818
+
819
+ const hull = convex_hull_2d(pts_2d)
820
+ if (hull.length < 3) {
821
+ emit_original(members)
822
+ continue
823
+ }
824
+
825
+ // Map 2D hull vertices back to nearest 3D vertex
826
+ const hull_3d: Vec3[] = hull.map((pt) => {
827
+ let best_dist = Infinity
828
+ let best_idx = 0
829
+ for (let idx = 0; idx < pts_2d.length; idx++) {
830
+ const du = pts_2d[idx][0] - pt[0]
831
+ const dv = pts_2d[idx][1] - pt[1]
832
+ const dist = du * du + dv * dv
833
+ if (dist < best_dist) {
834
+ best_dist = dist
835
+ best_idx = idx
836
+ }
837
+ }
838
+ return unique_verts[best_idx]
839
+ })
840
+
841
+ // Fan-triangulate from hull vertex 0
842
+ for (let idx = 1; idx < hull_3d.length - 1; idx++) {
843
+ emit_tri(hull_3d[0], hull_3d[idx], hull_3d[idx + 1])
844
+ }
845
+ }
846
+
847
+ return new Float32Array(output)
848
+ }
849
+
850
+ // Compute axis-aligned bounding box of Vec3 vertices
851
+ export function compute_bounding_box(vertices: Vec3[]): { min: Vec3; max: Vec3 } {
852
+ if (vertices.length === 0) {
853
+ return { min: [0, 0, 0], max: [0, 0, 0] }
854
+ }
855
+
856
+ const min: Vec3 = [...vertices[0]]
857
+ const max: Vec3 = [...vertices[0]]
858
+
859
+ for (const vert of vertices) {
860
+ if (vert[0] < min[0]) min[0] = vert[0]
861
+ if (vert[1] < min[1]) min[1] = vert[1]
862
+ if (vert[2] < min[2]) min[2] = vert[2]
863
+ if (vert[0] > max[0]) max[0] = vert[0]
864
+ if (vert[1] > max[1]) max[1] = vert[1]
865
+ if (vert[2] > max[2]) max[2] = vert[2]
866
+ }
867
+
868
+ return { min, max }
869
+ }
870
+
871
+ // Check if a matrix is square with dimension NxN
872
+ export function is_square_matrix(matrix: unknown, dim: number): boolean {
873
+ if (!Array.isArray(matrix)) return false
874
+ if (matrix.length !== dim) return false
875
+ return matrix.every((row) => Array.isArray(row) && row.length === dim)
876
+ }
877
+
878
+ // --- 2D Geometry Utilities ---
879
+
880
+ // Point-in-polygon test using ray casting algorithm
881
+ // Returns true if point (x, y) is inside the polygon defined by vertices
882
+ export function point_in_polygon(point_x: number, point_y: number, vertices: Vec2[]): boolean {
883
+ if (vertices.length < 3) return false
884
+ let [inside, prev_idx] = [false, vertices.length - 1]
885
+
886
+ for (let idx = 0; idx < vertices.length; idx++) {
887
+ const [x_i, y_i] = vertices[idx]
888
+ const [x_j, y_j] = vertices[prev_idx]
889
+
890
+ // Check if horizontal ray from point crosses this edge
891
+ if (y_i !== y_j && y_i > point_y !== y_j > point_y) {
892
+ const x_intersect = ((x_j - x_i) * (point_y - y_i)) / (y_j - y_i) + x_i
893
+ if (point_x < x_intersect) inside = !inside
894
+ }
895
+ prev_idx = idx
896
+ }
897
+
898
+ return inside
899
+ }
900
+
901
+ // Compute axis-aligned bounding box of 2D vertices
902
+ export function compute_bounding_box_2d(vertices: Vec2[]): {
903
+ min: Vec2
904
+ max: Vec2
905
+ width: number
906
+ height: number
907
+ } {
908
+ if (vertices.length === 0) {
909
+ return { min: [0, 0], max: [0, 0], width: 0, height: 0 }
910
+ }
911
+
912
+ let [min_x, min_y] = vertices[0]
913
+ let [max_x, max_y] = vertices[0]
914
+
915
+ for (const [x, y] of vertices) {
916
+ if (x < min_x) min_x = x
917
+ if (x > max_x) max_x = x
918
+ if (y < min_y) min_y = y
919
+ if (y > max_y) max_y = y
920
+ }
921
+
922
+ const width = max_x - min_x
923
+ const height = max_y - min_y
924
+ return { min: [min_x, min_y], max: [max_x, max_y], width, height }
925
+ }
926
+
927
+ // Calculate true geometric centroid of a polygon using shoelace formula
928
+ // Falls back to vertex average for degenerate cases (< 3 vertices or zero area)
929
+ export function polygon_centroid(vertices: Vec2[]): Vec2 {
930
+ if (vertices.length === 0) return [0, 0]
931
+ if (vertices.length < 3) {
932
+ const sum_x = vertices.reduce((acc, [x]) => acc + x, 0)
933
+ const sum_y = vertices.reduce((acc, [, y]) => acc + y, 0)
934
+ return [sum_x / vertices.length, sum_y / vertices.length]
935
+ }
936
+
937
+ let [signed_area, cx, cy] = [0, 0, 0]
938
+
939
+ for (let idx = 0; idx < vertices.length; idx++) {
940
+ const [x0, y0] = vertices[idx]
941
+ const [x1, y1] = vertices[(idx + 1) % vertices.length]
942
+ const cross = x0 * y1 - x1 * y0
943
+ signed_area += cross
944
+ cx += (x0 + x1) * cross
945
+ cy += (y0 + y1) * cross
946
+ }
947
+
948
+ signed_area *= 0.5
949
+
950
+ // Fall back to vertex average for degenerate polygons
951
+ if (Math.abs(signed_area) < EPS) {
952
+ const sum_x = vertices.reduce((acc, [x]) => acc + x, 0)
953
+ const sum_y = vertices.reduce((acc, [, y]) => acc + y, 0)
954
+ return [sum_x / vertices.length, sum_y / vertices.length]
955
+ }
956
+
957
+ const factor = 1 / (6 * signed_area)
958
+ return [cx * factor, cy * factor]
959
+ }
960
+
961
+ // Solve linear system Ax = b via LU decomposition with partial pivoting.
962
+ // Returns null if the system is singular (no unique solution).
963
+ // Fast-paths for 2x2 (Cramer's rule) and 3x3 (matrix inverse).
964
+ export function solve_linear_system(
965
+ A: number[][], // NxN coefficient matrix
966
+ b: number[], // N-element right-hand side
967
+ ): number[] | null {
968
+ const n = A.length
969
+ if (n === 0 || b.length !== n || !A.every((row) => row.length === n)) return null
970
+
971
+ // 2x2 fast path via Cramer's rule
972
+ if (n === 2) {
973
+ const det = A[0][0] * A[1][1] - A[0][1] * A[1][0]
974
+ if (Math.abs(det) < EPS) return null
975
+ return [(b[0] * A[1][1] - b[1] * A[0][1]) / det, (A[0][0] * b[1] - A[1][0] * b[0]) / det]
976
+ }
977
+
978
+ // 3x3 fast path via matrix inverse
979
+ if (n === 3) {
980
+ const det = det_3x3(A as Matrix3x3)
981
+ if (Math.abs(det) < EPS) return null
982
+ const inv = matrix_inverse_3x3(A as Matrix3x3)
983
+ return mat3x3_vec3_multiply(inv, b as Vec3) as number[]
984
+ }
985
+
986
+ // General NxN: LU decomposition with partial pivoting + forward/back substitution
987
+ const lu = A.map((row) => [...row])
988
+ const perm = Array.from({ length: n }, (_, idx) => idx)
989
+
990
+ for (let col = 0; col < n; col++) {
991
+ // Find pivot
992
+ let [max_row, max_val] = [col, Math.abs(lu[col][col])]
993
+
994
+ for (let row = col + 1; row < n; row++) {
995
+ const val = Math.abs(lu[row][col])
996
+ if (val > max_val) [max_val, max_row] = [val, row]
997
+ }
998
+ if (max_val < EPS) return null // singular
999
+
1000
+ // Swap rows
1001
+ if (max_row !== col) {
1002
+ ;[lu[col], lu[max_row]] = [lu[max_row], lu[col]]
1003
+ ;[perm[col], perm[max_row]] = [perm[max_row], perm[col]]
1004
+ }
1005
+
1006
+ // Eliminate below pivot
1007
+ const pivot = lu[col][col]
1008
+ for (let row = col + 1; row < n; row++) {
1009
+ const factor = lu[row][col] / pivot
1010
+ lu[row][col] = factor // store L factor in lower triangle
1011
+ for (let k = col + 1; k < n; k++) {
1012
+ lu[row][k] -= factor * lu[col][k]
1013
+ }
1014
+ }
1015
+ }
1016
+
1017
+ // Apply permutation to b
1018
+ const pb = perm.map((idx) => b[idx])
1019
+
1020
+ // Forward substitution (Ly = Pb)
1021
+ for (let row = 1; row < n; row++) {
1022
+ for (let col = 0; col < row; col++) {
1023
+ pb[row] -= lu[row][col] * pb[col]
1024
+ }
1025
+ }
1026
+
1027
+ // Back substitution (Ux = y)
1028
+ const x = Array.from<number>({ length: n }).fill(0)
1029
+ for (let row = n - 1; row >= 0; row--) {
1030
+ let sum = pb[row]
1031
+ for (let col = row + 1; col < n; col++) {
1032
+ sum -= lu[row][col] * x[col]
1033
+ }
1034
+ x[row] = sum / lu[row][row]
1035
+ }
1036
+
1037
+ return x
1038
+ }
1039
+
1040
+ export const cross_2d = (origin: Vec2, point_a: Vec2, point_b: Vec2): number =>
1041
+ (point_a[0] - origin[0]) * (point_b[1] - origin[1]) -
1042
+ (point_a[1] - origin[1]) * (point_b[0] - origin[0])
1043
+
1044
+ // Full 2D convex hull via Andrew's monotone chain algorithm.
1045
+ // Returns vertices in counter-clockwise order.
1046
+ export function convex_hull_2d(points: Vec2[]): Vec2[] {
1047
+ if (points.length < 3) return [...points]
1048
+
1049
+ const sorted = points.toSorted((a, b) => a[0] - b[0] || a[1] - b[1])
1050
+
1051
+ // Lower hull
1052
+ const lower: Vec2[] = []
1053
+ for (const pt of sorted) {
1054
+ while (
1055
+ lower.length >= 2 &&
1056
+ cross_2d(lower[lower.length - 2], lower[lower.length - 1], pt) <= 0
1057
+ ) {
1058
+ lower.pop()
1059
+ }
1060
+ lower.push(pt)
1061
+ }
1062
+
1063
+ // Upper hull
1064
+ const upper: Vec2[] = []
1065
+ for (let idx = sorted.length - 1; idx >= 0; idx--) {
1066
+ const pt = sorted[idx]
1067
+ while (
1068
+ upper.length >= 2 &&
1069
+ cross_2d(upper[upper.length - 2], upper[upper.length - 1], pt) <= 0
1070
+ ) {
1071
+ upper.pop()
1072
+ }
1073
+ upper.push(pt)
1074
+ }
1075
+
1076
+ // Remove last point of each half (it's the first point of the other)
1077
+ lower.pop()
1078
+ upper.pop()
1079
+
1080
+ return [...lower, ...upper]
1081
+ }