{
    "id": "InterwovenSphericalTriangles",
    "theorem or principle": "Spherical Geometry and Tessellation Patterns",
    "discipline": "Mathematics",
    "interactive elements count": 8,
    "difficulty": "hard",
    "snapshot_checklists": [
        {
            "screenshot_id": "1",
            "checklist": [
                "The lattice of shapes is generated based on the 'units in x direction' = 2 and 'units in y direction' = 2 inputs, resulting in the visible grid size (9 primary shapes).",
                "The primary shapes have a color gradient from light pink at the center to darker magenta at the edges, as specified in the plan.",
                "Each shape has a black outline with a 'linewidth' of 2, as specified in the procedural geometry plan.",
                "The label next to the trim slider displays '0.8', matching the slider's value.",
                "With the 'trim' slider at 0.8 (a high value), the concave edges of the shapes are rounded and 'less concave', as described in the plan.",
                "Since the 'double' checkbox is unchecked, no secondary cyan/teal shapes are rendered, as per the plan.",
                "Since the 'sphere' checkbox is unchecked, the reference sphere is not visible.",
                "Since the 'triangles' checkbox is unchecked, the underlying flat triangles and vertex points are not visible."
            ]
        },
        {
            "screenshot_id": "2",
            "checklist": [
                "The lattice size is based on 'units in x direction' = 1 and 'units in y direction' = 1, resulting in the visible grid size (4 primary shapes).",
                "The secondary 'doubled' shapes have a color gradient from light cyan to darker teal, as specified in the plan.",
                "The label next to the trim slider displays '0.71', matching the slider's value.",
                "With the 'trim' slider at 0.71 (a low value), the concave edges of all shapes have a 'spikier appearance', as described in the plan.",
                "Since the 'double' checkbox is checked, a second lattice of cyan/teal shapes is rendered, interwoven into the gaps of the primary pink lattice.",
                "Since the 'sphere' checkbox is unchecked, the reference sphere is not visible.",
                "Since the 'triangles' checkbox is unchecked, the underlying flat triangles and vertex points are not visible."
            ]
        },
        {
            "screenshot_id": "3",
            "checklist": [
                "The lattice size is based on 'units in x direction' = 2 and 'units in y direction' = 2, resulting in the visible grid size.",
                "The label next to the trim slider displays '0.71', matching the slider's value.",
                "With the 'trim' slider at 0.71 (a low value), the concave edges of the shapes have a 'spikier appearance'.",
                "Since the 'double' checkbox is checked, the secondary cyan/teal lattice is rendered in the gaps of the primary pink lattice.",
                "Since the 'sphere' checkbox is checked, a reference sphere with a shiny material is visible, positioned under the shape at the lattice origin.",
                "Since the 'triangles' checkbox is checked, a grid of flat, semi-transparent purple triangles is rendered underneath the curved shapes.",
                "Since the 'triangles' checkbox is checked, small black points are visible at the vertices of the underlying triangles, as specified in the plan."
            ]
        },
        {
            "screenshot_id": "4",
            "checklist": [
                "The lattice of shapes is generated based on 'units in x direction' = 3 and 'units in y direction' = 2, resulting in the visible grid size (12 primary shapes).",
                "The primary shapes show a pink-to-magenta gradient and the secondary shapes show a cyan-to-teal gradient, as per the plan.",
                "The label next to the trim slider displays '0.812', matching the slider's value and formatted to 3 decimal places.",
                "With the 'trim' slider at 0.812 (a high value), the concave edges of all shapes are rounded and 'less concave', as described in the plan.",
                "Since the 'double' checkbox is checked, a second lattice of cyan/teal shapes is rendered, interwoven into the gaps of the primary pink lattice.",
                "Since the 'sphere' checkbox is unchecked, the reference sphere is not visible.",
                "Since the 'triangles' checkbox is unchecked, the underlying flat triangles and vertex points are not visible."
            ]
        }
    ],
    "question": "---\n\n### 1. Page Content Structure\n-   **Main Container**: A full-page container using CSS Grid or Flexbox to organize the layout.\n-   **Control Panel**: Located at the top of the page. It contains all user interface controls for manipulating the visualization.\n    -   **Grid Controls**: Two rows of radio buttons to control the number of pattern repetitions in the X and Y directions.\n    -   **Trim Control**: A slider to adjust the \"trim\" or shape of the individual elements.\n    -   **Display Options**: A group of checkboxes to toggle the visibility of different geometric elements: the doubled pattern, a reference sphere, and the underlying planar triangles.\n-   **Visualization Canvas**: A large area below the control panel where the 3D rendering occurs. This canvas will be managed by the three.js library.\n-   **Reset Button**: A small button in the top-right corner of the canvas area to reset the camera view.\n\n### 2. HTML Components\nThe document will be a single HTML file including the three.js and OrbitControls libraries from a CDN.\n\n```html\n<!-- Main container -->\n<div id=\"main-container\">\n\n    <!-- Control Panel -->\n    <div id=\"control-panel\">\n        <div>\n            <label>units in x direction</label>\n            <input type=\"radio\" name=\"unitsX\" id=\"radio-x-0\" value=\"0\"> 0\n            <input type=\"radio\" name=\"unitsX\" id=\"radio-x-1\" value=\"1\"> 1\n            <input type=\"radio\" name=\"unitsX\" id=\"radio-x-2\" value=\"2\" checked> 2\n            <input type=\"radio\" name=\"unitsX\" id=\"radio-x-3\" value=\"3\"> 3\n            <input type=\"radio\" name=\"unitsX\" id=\"radio-x-4\" value=\"4\"> 4\n        </div>\n        <div>\n            <label>units in y direction</label>\n            <input type=\"radio\" name=\"unitsY\" id=\"radio-y-0\" value=\"0\"> 0\n            <input type=\"radio\" name=\"unitsY\" id=\"radio-y-1\" value=\"1\"> 1\n            <input type=\"radio\" name=\"unitsY\" id=\"radio-y-2\" value=\"2\" checked> 2\n            <input type=\"radio\" name=\"unitsY\" id=\"radio-y-3\" value=\"3\"> 3\n            <input type=\"radio\" name=\"unitsY\" id=\"radio-y-4\" value=\"4\"> 4\n        </div>\n        <div>\n            <label>trim</label>\n            <input type=\"range\" id=\"slider-trim\">\n            <span id=\"label-trim-value\"></span>\n        </div>\n        <div>\n            <input type=\"checkbox\" id=\"checkbox-double\"> <label for=\"checkbox-double\">double</label>\n            <input type=\"checkbox\" id=\"checkbox-sphere\"> <label for=\"checkbox-sphere\">sphere</label>\n            <input type=\"checkbox\" id=\"checkbox-triangles\"> <label for=\"checkbox-triangles\">triangles</label>\n        </div>\n    </div>\n\n    <!-- Visualization Area -->\n    <div id=\"canvas-container\">\n        <canvas id=\"main-canvas\"></canvas>\n        <button id=\"btn-reset-view\">+</button>\n    </div>\n</div>\n\n<!-- Scripts -->\n<script src=\"https://cdnjs.cloudflare.com/ajax/libs/three.js/r128/three.min.js\"></script>\n<script src=\"https://cdn.jsdelivr.net/npm/three@0.128.0/examples/js/controls/OrbitControls.js\"></script>\n```\n\n### 3. Component IDs and State\n\n-   **Radio Buttons (X direction)**:\n    -   `id=\"radio-x-0\"` to `id=\"radio-x-4\"`. Name: `unitsX`.\n    -   `id=\"radio-x-2\"` is checked by default.\n\n-   **Radio Buttons (Y direction)**:\n    -   `id=\"radio-y-0\"` to `id=\"radio-y-4\"`. Name: `unitsY`.\n    -   `id=\"radio-y-2\"` is checked by default.\n\n-   **Trim Slider**:\n    -   `id=\"slider-trim\"`\n    -   default: 0.8\n    -   min: 0.65\n    -   max: 0.9\n    -   step: 0.001\n    -   label: \"trim\"\n\n-   **Trim Value Display**:\n    -   `id=\"label-trim-value\"`\n    -   Initial text content: \"0.8\"\n\n-   **Checkboxes**:\n    -   `id=\"checkbox-double\"` - default: unchecked\n    -   `id=\"checkbox-sphere\"` - default: unchecked\n    -   `id=\"checkbox-triangles\"` - default: unchecked\n\n-   **Reset Button**:\n    -   `id=\"btn-reset-view\"`\n    -   label: \"+\"\n\n### 4. Interaction Logic\n\n-   **General**: All control changes (radio buttons, slider, checkboxes) will trigger a single function, `updateScene()`. This function will clear all existing geometric objects (but not the camera or lights) and regenerate the entire scene from scratch based on the current state of all controls.\n\n-   **Radio Buttons (`radio-x-*`, `radio-y-*`)**: On change, `updateScene()` is called. The selected values determine the number of loops for generating the lattice of shapes in the X and Y dimensions.\n\n-   **Trim Slider (`slider-trim`)**: On input, the `label-trim-value` is updated to show the slider's current value formatted to 3 decimal places. `updateScene()` is called. The slider value directly controls the curvature of the main shapes' edges. A lower value results in more concave edges (spikier appearance), while a higher value results in less concave edges (rounder appearance).\n\n-   **Double Checkbox (`checkbox-double`)**: On change, `updateScene()` is called. If checked, a second, interwoven lattice of shapes is generated. This second lattice is colored differently (cyan/blue) and is offset and rotated 180 degrees from the primary lattice to fit into its gaps.\n\n-   **Sphere Checkbox (`checkbox-sphere`)**: On change, `updateScene()` is called. If checked, a reference sphere is added to the scene. It is positioned under the primary shape at the origin of the lattice to show how the curved shapes are derived from a sphere.\n\n-   **Triangles Checkbox (`checkbox-triangles`)**: On change, `updateScene()` is called. If checked, a grid of flat, semi-transparent triangles is rendered, showing the underlying planar geometry corresponding to the curved shapes. Small black points are also rendered at the vertices of these triangles.\n\n-   **Reset Button (`btn-reset-view`)**: On click, it calls the `reset()` method of the `OrbitControls` instance, returning the camera to its initial position and orientation.\n\n-   **Mouse Interaction**: The scene is interactive via `OrbitControls`. The user can rotate the view by dragging with the left mouse button, pan by dragging with the right mouse button, and zoom using the mouse wheel.\n\n### 5. Visualization Techniques\n\n-   **Core Technology**: The visualization will be built using **three.js**.\n-   **Scene Setup**:\n    -   A `THREE.Scene` with a light gray background color (`0xf0f0f0`).\n    -   A `THREE.PerspectiveCamera` positioned to view the generated lattice.\n    -   A `THREE.WebGLRenderer` attached to the `<canvas id=\"main-canvas\">`.\n    -   `THREE.OrbitControls` will be used for camera manipulation.\n    -   Lighting: A `THREE.HemisphereLight` (sky color `0xffffff`, ground color `0x444444`) and a `THREE.DirectionalLight` (color `0xffffff`, intensity `0.8`) will be used to create soft, full illumination.\n\n-   **Procedural Geometry (Curved Triangles)**:\n    -   The main shape is a triangle with concave, curved edges on a spherical surface. It will be generated as a `THREE.BufferGeometry`.\n    -   **Method**: Define three vertices of an equilateral triangle on a sphere's surface. The curved edges between them are circular arcs. The amount of curvature is controlled by the `slider-trim` value. The geometry is created by generating vertices along these curved edges and creating faces by connecting them to a central point, forming a triangle fan.\n    -   **Color**: A gradient effect will be achieved using `THREE.VertexColors`. Vertices near the center of the shape will be colored light pink (`0xffc0cb`), and vertices near the edges will be a darker magenta (`0x904090`). The material will be a `THREE.MeshStandardMaterial` with `vertexColors: true`.\n    -   **Outline**: An outline is created by making a `THREE.LineSegments` object using the edge vertices of the main shape. The material will be a `THREE.LineBasicMaterial` with `color: 0x000000` and `linewidth: 2`.\n\n-   **Lattice Generation**:\n    -   A main `THREE.Group` will hold all generated meshes. This group is cleared and rebuilt in the `updateScene` function.\n    -   The lattice is based on two basis vectors for a triangular grid. A nested loop (using limits from the radio buttons) calculates the position of each shape.\n    -   Shapes in alternating rows/columns are rotated by 180 degrees to form the tessellating pattern.\n\n-   **\"Double\" Feature**:\n    -   If enabled, a second set of curved triangles is generated.\n    -   They use the same procedural geometry but are shifted to fill the gaps in the first lattice. This shift vector is calculated from the lattice basis vectors. They are also rotated 180 degrees relative to the primary shapes in their positions.\n    -   **Color**: The vertex colors for this set will be a gradient from light cyan (`0x80ffff`) to a darker teal (`0x008080`).\n\n-   **\"Sphere\" Feature**:\n    -   A `THREE.SphereGeometry` is used.\n    -   The material is a `THREE.MeshPhongMaterial` with a neutral color like `0xdddddd` and `shininess: 80` to interact with the scene lighting, producing the effect seen in the screenshot.\n    -   It is positioned at the base of the central triangle instance.\n\n-   **\"Triangles\" Feature**:\n    -   The flat triangles are generated using `THREE.BufferGeometry` with vertices corresponding to the vertices of the main curved shapes.\n    -   The material is a `THREE.MeshBasicMaterial` with a purple color (`0x800080`), `transparent: true`, and `opacity: 0.4`.\n    -   The vertices are visualized using a `THREE.Points` object with a `THREE.PointsMaterial` (color `0x000000`, size `3`).\n\n---",
    "lm_system_prompt": "You are an expert in frontend web development (HTML, JavaScript, CSS) and scientific visualization. Your task is to generate a complete HTML document containing necessary interactions or animations based on the following HTML implementation plan.\n\nRequirements:\n1. You must strictly follow the component list, component types, and ID definitions as specified in the plan.\n2. The layout, structure, and interactivity must reflect the interaction logic in the plan.\n3. You may use HTML, CSS (inline or embedded), and JavaScript, and must include correct JavaScript libraries (such as Plotly, Chart.js, or MathJax) via CDN if any component requires them.\n4. The HTML document must be self-contained and functional, ready to be opened in a web browser.\n\nYour output must be only the HTML code wrapped in ```html and ```.\n\nHere is the HTML implementation plan:\n",
    "vlm_system_prompt": "You are an expert in frontend web development (HTML, JavaScript, CSS) and scientific visualization. Your task is to generate a complete HTML document containing necessary interactions or animations based on the following HTML implementation plan and corresponding one or more snapshots.\n\nRequirements:\n1. You must strictly follow the component list, component types, and ID definitions as specified in the plan.\n2. The layout, structure, and interactivity must reflect the interaction logic in the plan.\n3. You may use HTML, CSS (inline or embedded), and JavaScript, and must include correct JavaScript libraries (such as Plotly, Chart.js, or MathJax) via CDN if any component requires them.\n4. The HTML document must be self-contained and functional, ready to be opened in a web browser.\n\nYour output must be only the HTML code wrapped in ```html and ```\n\nHere is the HTML implementation plan and snapshots:\n",
    "image_path": [
        "data/snapshots/InterwovenSphericalTriangles_Snapshot-1.png",
        "data/snapshots/InterwovenSphericalTriangles_Snapshot-2.png",
        "data/snapshots/InterwovenSphericalTriangles_Snapshot-3.png",
        "data/snapshots/InterwovenSphericalTriangles_Snapshot-4.png"
    ]
}