<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>ICLR2026 Submission</title>
    <style>
        body {
            font-family: Arial, sans-serif;
            margin: 20px;
            background-color: #f5f5f5;
        }
        
        .container {
            max-width: 1400px;
            margin: 0 auto;
        }
        
        .header {
            text-align: center;
            margin-bottom: 30px;
            padding: 20px;
            background-color: white;
            border-radius: 10px;
            box-shadow: 0 2px 5px rgba(0,0,0,0.1);
        }
        
        .result-item {
            margin-bottom: 40px;
            padding: 20px;
            background-color: white;
            border-radius: 10px;
            box-shadow: 0 2px 5px rgba(0,0,0,0.1);
        }
        
        .prompt {
            font-size: 18px;
            font-weight: bold;
            color: #333;
            margin-bottom: 20px;
            padding: 15px;
            background-color: #e8f4f8;
            border-radius: 8px;
            border-left: 4px solid #2196F3;
        }
        
        .methods-container {
            display: flex;
            gap: 20px;
            flex-wrap: wrap;
        }
        
        .method-section {
            flex: 1;
            min-width: 300px;
        }
        
        .method-title {
            font-size: 16px;
            font-weight: bold;
            color: #555;
            margin-bottom: 10px;
            padding: 10px;
            text-align: center;
            border-radius: 5px;
        }
        
        .test-images { background-color: #e8f5e8; }
        .dg4d { background-color: #fff3e8; }
        .animate3d { background-color: #ffe8e8; }
        .ours { background-color: #f0e8ff; }
        
        .grid-2x2 {
            display: grid;
            grid-template-columns: 1fr 1fr;
            grid-template-rows: 1fr 1fr;
            gap: 10px;
            aspect-ratio: 1;
        }
        
        .grid-item {
            border: 2px solid #ddd;
            border-radius: 8px;
            overflow: hidden;
            display: flex;
            align-items: center;
            justify-content: center;
            background-color: #f9f9f9;
        }
        
        .grid-item img {
            width: 100%;
            height: 100%;
            object-fit: contain;
            transition: transform 0.3s ease;
        }
        
        .grid-item:hover img {
            transform: scale(1.05);
        }
        
        .error-placeholder {
            color: #888;
            font-style: italic;
            text-align: center;
            padding: 20px;
        }
        
        @media (max-width: 768px) {
            .methods-container {
                flex-direction: column;
            }
            
            .method-section {
                min-width: unset;
            }
        }
    </style>
</head>
<body>
    <div class="container">
        <div class="header">
            <h1>Generated 4D Assets Visual Comparison</h1>
        </div>
        
        <script>
            // JSON data
            const prompts = {
                "superman": "A cool superman is dancing.",
                "butterfly": "A glowing butterfly is flying.",
                "robotic_arm": "A robotic arm is in operation.",
                "plant": "A fantastic plant is swaying.",
                "fox": "A red fox with a bird standing on its head looks around.",
                "deer": "A cute deer is walking.",
                "Spiderman": "A Spiderman is walking.",
                "bird": "A bird is flapping its wings.",
                "dog_beast": "A monstrous dog beast attempts to attack.",
                "giraffe": "A cartoon giraffe with a charmingly long neck and spots ambles along gracefully, spots shifting.",
                "monkey": "Monkey in 3D cartoon, wearing a tiny fez, is jumping up and down.",
                "dolphin": "A cartoon dolphin with a playful smile and sparkling eyes leaps joyfully from waves.",
                "frog": "A cartoon frog with a friendly, wide mouthed smile jumps up.",
                "space_shuttle": "Space shuttle in cartoon style, boosters ready, is flying.",
                "chicken": "Chicken in 3D cartoon, with superhero cape takes off briefly, cape billowing.",
                "fox_cartoon": "Fox wearing a 3D cartoon detective hat slinks suspiciously, hat tilted.",
                "panda": "Magical panda in 3D cartoon style, with a wizard hat and cloak waves its hands to cast a spell.",
                "buffalo": "A cartoon buffalo with a shaggy head of fur and horns paws at the ground menacingly.",
                "d66fdd6b2dfd45eaa74ed26fbfa4f442": "Person jogs forward wearing black shirt and shorts.",
                "8bb433dfbef3479cbaa3bcdf63b5b6a2": "Pink slug wiggles and crawls forward.",
                "c8cc083d68cd4b86a0f141b20c4b1ac4": "Pokémon draws bow and fires glowing green arrow.",
                "b7a53e8540ae486cba1cd29478ec63f6": "Pixelated man jumps forward.",
                "bb6aa5b57a084dd18e73e22f158fc6a2": "Zombie staggers forward, arms reaching for prey.",
                "a197b450a4ec4c3b933f557b87aeeba6": "Tall man lifts stick, cross glowing above head.",
                "953437b434c34899a0c02813518551fd": "White fish swims.",
                "59858d6442e1482a8205e6b94704aeb0": "Minecraft wolf trots forward with blocky steps.",
                "35b69cafad8a4dae8e5afc0a80925795": "Businessman is walking steadily.",
                "63b30bdfa1d64b019fa2750902e5a5db": "Bee character stomps, horns shaking wildly.",
                "cb3a73fe138d4da6bc2cd0d27629a1c6": "Pokémon is wobbling.",
                "596abfe314494b86b52bdc37d47a6864": "A dragon flaps wings and stomps forward aggressively.",
                "8d77fbbc6e66474995a24dcc4db4bbe0": "Creature is attacking with his claws.",
                "2003a0ae7bea40c4adac708677253d17": "Character with VR headset nods.",
                "6812bf2c9a47488a8ef249ea08eda67c": "Tiger prowls, muscles rippling under fur.",
                "3b02dda8abfe471d8417a551c95ead6c": "The armored figure reaches forward.",
                "43827ce48f5c47f598fb7587d9d236e0": "Blue-bloused person steps forward, lifting a dancing foot."
            };

            // Function to create a 2x2 grid
            function create2x2Grid(basePath, fileName, extension, isGif = false) {
                const grid = document.createElement('div');
                grid.className = 'grid-2x2';
                
                for (let i = 0; i < 4; i++) {
                    const gridItem = document.createElement('div');
                    gridItem.className = 'grid-item';
                    
                    const img = document.createElement('img');
                    img.src = `${basePath}/${fileName}_${i}.${extension}`;
                    img.alt = `${fileName}_${i}`;
                    img.onerror = function() {
                        this.style.display = 'none';
                        gridItem.innerHTML = '<div class="error-placeholder">Image not found</div>';
                    };
                    
                    // Add loading attribute for better performance
                    if (!isGif) {
                        img.loading = 'lazy';
                    }
                    
                    gridItem.appendChild(img);
                    grid.appendChild(gridItem);
                }
                
                return grid;
            }

            // Generate content for each prompt
            function generateContent() {
                const container = document.querySelector('.container');
                
                for (const [fileName, prompt] of Object.entries(prompts)) {
                    const resultItem = document.createElement('div');
                    resultItem.className = 'result-item';
                    
                    // Add prompt
                    const promptDiv = document.createElement('div');
                    promptDiv.className = 'prompt';
                    promptDiv.textContent = `Text Prompt: "${prompt}"`;
                    resultItem.appendChild(promptDiv);
                    
                    // Create methods container
                    const methodsContainer = document.createElement('div');
                    methodsContainer.className = 'methods-container';
                    
                    // Test Images (Static)
                    const testImagesSection = document.createElement('div');
                    testImagesSection.className = 'method-section';
                    
                    const testImagesTitle = document.createElement('div');
                    testImagesTitle.className = 'method-title test-images';
                    testImagesTitle.textContent = 'Input Images (Static)';
                    testImagesSection.appendChild(testImagesTitle);
                    
                    const testImagesGrid = create2x2Grid('test_images', fileName, 'png');
                    testImagesSection.appendChild(testImagesGrid);
                    methodsContainer.appendChild(testImagesSection);
                    
                    // DG4D GIFs
                    const dg4dSection = document.createElement('div');
                    dg4dSection.className = 'method-section';
                    
                    const dg4dTitle = document.createElement('div');
                    dg4dTitle.className = 'method-title dg4d';
                    dg4dTitle.textContent = 'DG4D';
                    dg4dSection.appendChild(dg4dTitle);
                    
                    const dg4dGrid = create2x2Grid('dg4d_gifs', fileName, 'gif', true);
                    dg4dSection.appendChild(dg4dGrid);
                    methodsContainer.appendChild(dg4dSection);
                    
                    // Animate3D GIFs
                    const animate3dSection = document.createElement('div');
                    animate3dSection.className = 'method-section';
                    
                    const animate3dTitle = document.createElement('div');
                    animate3dTitle.className = 'method-title animate3d';
                    animate3dTitle.textContent = 'Animate3D';
                    animate3dSection.appendChild(animate3dTitle);
                    
                    const animate3dGrid = create2x2Grid('Animate3d_gifs', fileName, 'gif', true);
                    animate3dSection.appendChild(animate3dGrid);
                    methodsContainer.appendChild(animate3dSection);
                    
                    // Ours GIFs
                    const oursSection = document.createElement('div');
                    oursSection.className = 'method-section';
                    
                    const oursTitle = document.createElement('div');
                    oursTitle.className = 'method-title ours';
                    oursTitle.textContent = 'Ours';
                    oursSection.appendChild(oursTitle);
                    
                    const oursGrid = create2x2Grid('ours_gif', fileName, 'gif', true);
                    oursSection.appendChild(oursGrid);
                    methodsContainer.appendChild(oursSection);
                    
                    resultItem.appendChild(methodsContainer);
                    container.appendChild(resultItem);
                }
            }

            // Generate content when page loads
            document.addEventListener('DOMContentLoaded', generateContent);
        </script>
    </div>
</body>
</html>