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