
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Comparison between High and Low Confidence</title>
    <style>
        body {
            margin: 0;
            padding: 20px;
            background-color: #f5f5f5;
            font-family: Arial, sans-serif;
            line-height: 1.6;
        }
        .container { max-width: 1800px; margin: 0 auto; }
        h1 { text-align: center; color: #333; margin-bottom: 30px; }

        .sample-wrapper {
            margin-bottom: 40px;
            background: white;
            border-radius: 10px;
            box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
            padding: 20px;
        }

        .sample-header {
            margin-bottom: 20px;
        }

        .sample-title {
            font-size: 24px;
            font-weight: bold;
            color: #333;
            margin-bottom: 10px;
        }

        .prompt-section {
            margin: 10px 0;
        }

        .prompt-label {
            font-size: 14px;
            font-weight: bold;
            color: #495057;
            margin-bottom: 5px;
        }

        .prompt-text {
            font-size: 14px;
            color: #6c757d;
            font-style: italic;
            line-height: 1.4;
            background-color: #fff;
            padding: 10px 15px;
            border-radius: 6px;
            border-left: 3px solid #007bff;
            margin: 5px 0 15px 0;
        }

        .media-grid {
            display: flex;
            gap: 15px;
            align-items: stretch;
            margin-top: 15px;
        }

        .media-container {
            flex: 1;
            text-align: center;
            background: #fff;
            border-radius: 8px;
            padding: 15px;
            display: flex;
            flex-direction: column;
            min-width: 0;
        }

        .media-title {
            font-weight: bold;
            margin-bottom: 10px;
            color: #495057;
            font-size: 14px;
        }

        .media-content {
            height: 220px;
            display: flex;
            align-items: center;
            justify-content: center;
        }

        img, video {
            max-width: 100%;
            max-height: 100%;
            border-radius: 4px;
            object-fit: contain;
        }

        video { background-color: #000; }

        .loading-placeholder {
            width: 100%;
            height: 220px;
            background-color: #e9ecef;
            border-radius: 4px;
            display: flex;
            align-items: center;
            justify-content: center;
            color: #6c757d;
            font-style: italic;
        }

        .controls {
            display: flex;
            gap: 10px;
            margin-top: 10px;
            justify-content: center;
        }

        .controls button {
            background-color: #007bff;
            color: white;
            border: none;
            padding: 8px 16px;
            border-radius: 4px;
            cursor: pointer;
            font-size: 12px;
            transition: background-color 0.3s;
        }

        .controls button:hover {
            background-color: #0056b3;
        }

        .global-controls {
            text-align: center;
            margin-bottom: 30px;
            padding: 20px;
            background: white;
            border-radius: 10px;
            box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
        }

        .global-controls button {
            background-color: #28a745;
            color: white;
            border: none;
            padding: 12px 24px;
            margin: 5px 10px;
            border-radius: 6px;
            cursor: pointer;
            font-size: 14px;
            font-weight: bold;
        }

        .global-controls button:hover {
            background-color: #218838;
        }

        .status {
            text-align: center;
            margin-top: 20px;
            padding: 15px;
            background-color: #e9ecef;
            border-radius: 8px;
            color: #495057;
        }

        .vertical-divider {
            width: 2px;
            background-color: #dee2e6;
            margin: 0 5px;
            align-self: stretch;
        }
    </style>
</head>
<body>
    <div class="container">
        <h1>Comparison between High and Low Confidence</h1>
        <div class="global-controls">
            <button onclick="playAll()">Play All</button>
            <button onclick="pauseAll()">Pause All</button>
            <button onclick="restartAll()">Restart All</button>
        </div>
        <div id="main-container"></div>
        <div class="status" id="status">
            Click controls to load and manage videos.
        </div>
    </div>
    <script>
        const samplesData = [
    {
        "name": "00001",
        "user_input_prompt": "Make the men actively dance in unison, holding hands in a circle.",
        "refined_prompt": "The group of men in uniform actively engages in a circular dance. Their legs lift and step rhythmically to the left in unison, creating a counter-clockwise rotation of the circle. Their bodies sway dynamically, and their arms, linked together, move with the momentum of the dance. The soldiers shift their weight from foot to foot, driving the circular motion. The massive stone wall in the background and the paved ground remain completely static and stable, contrasting with the energetic movement of the dancers.",
        "proposed_motion": "00001/visual.jpg",
        "control": "00001/control.mp4",
        "video": "00001/video.mp4",
        "merged": "00001/merged.mp4",
        "video_conf7": "00001/video-conf7.mp4",
        "merged_conf7": "00001/merged-conf7.mp4"
    },
    {
        "name": "00002",
        "user_input_prompt": "Have the female dental professional turn away from the male patient and bend down to adjust the dental chair.",
        "refined_prompt": "The female dental professional rotates her body to the right, turning her back to the patient. She bends deeply at the waist, lowering her head and torso towards the dental chair in the foreground. Her left arm sweeps down and across her body, reaching out to adjust the chair's mechanism. The male patient stands perfectly still observing, and the surrounding dental office equipment and city view remain fixed.",
        "proposed_motion": "00002/visual.jpg",
        "control": "00002/control.mp4",
        "video": "00002/video.mp4",
        "merged": "00002/merged.mp4",
        "video_conf7": "00002/video-conf7.mp4",
        "merged_conf7": "00002/merged-conf7.mp4"
    },
    {
        "name": "00003",
        "user_input_prompt": "Adjust the man's head and gaze to look up and to the right, away from the phone, with a neutral expression.",
        "refined_prompt": "The man's head smoothly rotates upwards and to his left, lifting his chin away from the smartphone screen. His gaze shifts purposefully from the device in his hands to a point in the upper right distance. As his head turns, his facial expression transitions from a slight smile into a calm, neutral demeanor. His shoulders, chest, and hands gripping the phone remain perfectly stationary, anchoring the movement, while the dark background and bedding stay fixed in place.",
        "proposed_motion": "00003/visual.jpg",
        "control": "00003/control.mp4",
        "video": "00003/video.mp4",
        "merged": "00003/merged.mp4",
        "video_conf7": "00003/video-conf7.mp4",
        "merged_conf7": "00003/merged-conf7.mp4"
    },
    {
        "name": "00004",
        "user_input_prompt": "Change the girl's body orientation to face away from the camera, keeping her pink swimsuit and the blue and yellow beach ball.",
        "refined_prompt": "The girl begins to pivot her body, rotating smoothly to face away from the camera. Her face turns out of view, replaced by the back of her head and hair cascading down. Her shoulders and torso twist, shifting the perspective of the pink swimsuit to reveal its back. The blue and yellow beach ball in her hands rotates along with her movement, slightly changing position as she turns. The ocean waves and sandy beach in the background remain perfectly still and stable throughout the transformation.",
        "proposed_motion": "00004/visual.jpg",
        "control": "00004/control.mp4",
        "video": "00004/video.mp4",
        "merged": "00004/merged.mp4",
        "video_conf7": "00004/video-conf7.mp4",
        "merged_conf7": "00004/merged-conf7.mp4"
    },
    {
        "name": "00005",
        "user_input_prompt": "Make the boy actively drink milk from the glass, with his mouth on the rim and eyes looking down.",
        "refined_prompt": "The boy's right hand actively lifts the glass of milk from the table, raising it upwards in a smooth arc towards his face. The glass tilts slightly as it approaches his mouth. The boy's head tilts gently forward to meet the rim of the glass. The milk inside shifts its angle relative to the glass tilt. The kitchen background, cabinets, and window remain perfectly still throughout the motion.",
        "proposed_motion": "00005/visual.jpg",
        "control": "00005/control.mp4",
        "video": "00005/video.mp4",
        "merged": "00005/merged.mp4",
        "video_conf7": "00005/video-conf7.mp4",
        "merged_conf7": "00005/merged-conf7.mp4"
    },
    {
        "name": "00006",
        "user_input_prompt": "Change the pose of the two main women in the foreground: lower their hands from the disco ball, and have them dance closer, facing each other with hands joined in a more relaxed posture.",
        "refined_prompt": "The two women in the foreground gracefully lower their raised arms from the disco ball, bringing their hands down to clasp together at chest level. Simultaneously, they pivot and step inward, closing the gap between them to enter a close dancing embrace. The disco ball overhead and the surrounding partygoers, including the dancers in the background and the skeleton figure, remain perfectly static, keeping the focus entirely on the couple's intimate change in pose.",
        "proposed_motion": "00006/visual.jpg",
        "control": "00006/control.mp4",
        "video": "00006/video.mp4",
        "merged": "00006/merged.mp4",
        "video_conf7": "00006/video-conf7.mp4",
        "merged_conf7": "00006/merged-conf7.mp4"
    },
    {
        "name": "00007",
        "user_input_prompt": "Change the woman's facial expression from a gentle smile to an active, joyful laugh, while she continues holding the fork and salad.",
        "refined_prompt": "The woman's facial expression transitions from a closed smile to an open-mouthed, joyful laugh. Her jaw drops slightly to open her mouth wider, revealing more teeth, while the corners of her mouth stretch upwards and outwards. Her cheeks lift significantly, crinkling the area around her eyes to enhance the joyful emotion. While her face animates with laughter, her posture remains composed, holding the fork steady in her hand and the salad bowl firmly on the table. The kitchen background, including the cabinets and appliances, remains completely static.",
        "proposed_motion": "00007/visual.jpg",
        "control": "00007/control.mp4",
        "video": "00007/video.mp4",
        "merged": "00007/merged.mp4",
        "video_conf7": "00007/video-conf7.mp4",
        "merged_conf7": "00007/merged-conf7.mp4"
    },
    {
        "name": "00008",
        "user_input_prompt": "Change the woman's pose and action: have her actively scooping seeds from the girl's pumpkin with a spoon, looking down into the pumpkin with an engaged expression.",
        "refined_prompt": "The woman in the center shifts her posture, leaning forward with focused intent towards the pumpkin in front of the girl. Her right arm extends downward, hand grasping a large spoon that dips deep into the pumpkin's opening to scoop out seeds. Her head tilts down, eyes locking onto the task with an engaged, active expression. While she moves, the children on either side and the surrounding kitchen environment remain stable and observing.",
        "proposed_motion": "00008/visual.jpg",
        "control": "00008/control.mp4",
        "video": "00008/video.mp4",
        "merged": "00008/merged.mp4",
        "video_conf7": "00008/video-conf7.mp4",
        "merged_conf7": "00008/merged-conf7.mp4"
    },
    {
        "name": "00009",
        "user_input_prompt": "Change the man's pose from right arm raised and holding a microphone to both arms down, and change his expression from singing to a natural, relaxed smile. Keep his colorful t-shirt, sunglasses, and background unchanged.",
        "refined_prompt": "The man smoothly lowers his raised right arm from above his head until it rests naturally at his side. Simultaneously, his left hand moves down, lowering the microphone away from his mouth to his waist level. As the arms descend, his facial expression transforms from an open-mouthed singing pose to a calm, relaxed smile. His sunglasses, the colorful palm tree print t-shirt, and the background skyline with stage lights remain perfectly stable and unchanged throughout the movement.",
        "proposed_motion": "00009/visual.jpg",
        "control": "00009/control.mp4",
        "video": "00009/video.mp4",
        "merged": "00009/merged.mp4",
        "video_conf7": "00009/video-conf7.mp4",
        "merged_conf7": "00009/merged-conf7.mp4"
    },
    {
        "name": "00010",
        "user_input_prompt": "Change the man's pose from seated to standing, his expression from intense screaming to distressed, and his action from reacting to the laptop to disengaging from it, looking down.",
        "refined_prompt": "The man pushes upward from the sofa, his body extending vertically as he transitions from a seated, hunched position to a full standing posture. His head turns away from the laptop screen and tilts downward, his gaze fixing on the floor. The open-mouthed scream morphs into a closed-mouth expression of deep distress and resignation. His arms, previously raised in agitation, lower towards his sides, signaling a complete disengagement from the computer. The laptop, the stack of papers, and the cluttered shelves in the background remain perfectly still throughout the movement.",
        "proposed_motion": "00010/visual.jpg",
        "control": "00010/control.mp4",
        "video": "00010/video.mp4",
        "merged": "00010/merged.mp4",
        "video_conf7": "00010/video-conf7.mp4",
        "merged_conf7": "00010/merged-conf7.mp4"
    }
];
        const mainContainer = document.getElementById('main-container');
        const statusDiv = document.getElementById('status');

        function generateSamples() {
            samplesData.forEach((sample, sampleIdx) => {
                const sampleDiv = document.createElement('div');
                sampleDiv.className = 'sample-wrapper';
                sampleDiv.id = `sample-${sampleIdx}`;

                let sampleHTML = `
                    <div class="sample-header">
                        <div class="sample-title">${sample.name}</div>
                        <div class="controls">
                            <button onclick="playSample(${sampleIdx})">Play All</button>
                            <button onclick="pauseSample(${sampleIdx})">Pause All</button>
                            <button onclick="restartSample(${sampleIdx})">Restart All</button>
                        </div>
                    </div>
                `;

                // User Input Prompt
                if (sample.user_input_prompt) {
                    sampleHTML += `
                        <div class="prompt-section">
                            <div class="prompt-label">User Input Prompt</div>
                            <div class="prompt-text">${sample.user_input_prompt}</div>
                        </div>
                    `;
                }

                // Refined Prompt
                if (sample.refined_prompt) {
                    sampleHTML += `
                        <div class="prompt-section">
                            <div class="prompt-label">Refined Prompt</div>
                            <div class="prompt-text">${sample.refined_prompt}</div>
                        </div>
                    `;
                }

                // Media grid: all items in one row with vertical divider
                sampleHTML += `
                    <div class="media-grid">
                        <div class="media-container">
                            <div class="media-title">Proposed Motion</div>
                            <div class="media-content">
                                ${sample.proposed_motion ? 
                                    `<img src="${sample.proposed_motion}" alt="Proposed Motion"
                                         onerror="this.style.display='none'; this.parentNode.innerHTML='<div class=\'loading-placeholder\'>Image not found</div>'">` :
                                    `<div class="loading-placeholder">Not available</div>`}
                            </div>
                        </div>
                        <div class="media-container">
                            <div class="media-title">Control/Trajectories</div>
                            <div class="media-content" id="sample-${sampleIdx}-control">
                                ${sample.control ? 
                                    `<div class="loading-placeholder">Click play to load</div>` :
                                    `<div class="loading-placeholder">Not available</div>`}
                            </div>
                        </div>
                        <div class="vertical-divider"></div>
                        <div class="media-container">
                            <div class="media-title">Generated Video (High Confidence)</div>
                            <div class="media-content" id="sample-${sampleIdx}-video">
                                ${sample.video ? 
                                    `<div class="loading-placeholder">Click play to load</div>` :
                                    `<div class="loading-placeholder">Not available</div>`}
                            </div>
                        </div>
                        <div class="media-container">
                            <div class="media-title">Merged Video (High Confidence)</div>
                            <div class="media-content" id="sample-${sampleIdx}-merged">
                                ${sample.merged ? 
                                    `<div class="loading-placeholder">Click play to load</div>` :
                                    `<div class="loading-placeholder">Not available</div>`}
                            </div>
                        </div>
                        <div class="vertical-divider"></div>
                        <div class="media-container">
                            <div class="media-title">Generated Video (Low Confidence)</div>
                            <div class="media-content" id="sample-${sampleIdx}-video-conf7">
                                ${sample.video_conf7 ? 
                                    `<div class="loading-placeholder">Click play to load</div>` :
                                    `<div class="loading-placeholder">Not available</div>`}
                            </div>
                        </div>
                        <div class="media-container">
                            <div class="media-title">Merged Video (Low Confidence)</div>
                            <div class="media-content" id="sample-${sampleIdx}-merged-conf7">
                                ${sample.merged_conf7 ? 
                                    `<div class="loading-placeholder">Click play to load</div>` :
                                    `<div class="loading-placeholder">Not available</div>`}
                            </div>
                        </div>
                    </div>
                `;

                sampleDiv.innerHTML = sampleHTML;
                mainContainer.appendChild(sampleDiv);
            });
        }

        function loadVideosForSample(sampleIdx) {
            const sample = samplesData[sampleIdx];

            if (sample.control) {
                const controlContainer = document.getElementById(`sample-${sampleIdx}-control`);
                if (controlContainer && controlContainer.querySelector('.loading-placeholder')) {
                    controlContainer.innerHTML = `
                        <video controls muted loop>
                            <source src="${sample.control}" type="video/mp4">
                            Your browser does not support the video tag.
                        </video>`;
                }
            }

            if (sample.video) {
                const videoContainer = document.getElementById(`sample-${sampleIdx}-video`);
                if (videoContainer && videoContainer.querySelector('.loading-placeholder')) {
                    videoContainer.innerHTML = `
                        <video controls muted loop>
                            <source src="${sample.video}" type="video/mp4">
                            Your browser does not support the video tag.
                        </video>`;
                }
            }

            if (sample.merged) {
                const mergedContainer = document.getElementById(`sample-${sampleIdx}-merged`);
                if (mergedContainer && mergedContainer.querySelector('.loading-placeholder')) {
                    mergedContainer.innerHTML = `
                        <video controls muted loop>
                            <source src="${sample.merged}" type="video/mp4">
                            Your browser does not support the video tag.
                        </video>`;
                }
            }

            if (sample.video_conf7) {
                const videoConf7Container = document.getElementById(`sample-${sampleIdx}-video-conf7`);
                if (videoConf7Container && videoConf7Container.querySelector('.loading-placeholder')) {
                    videoConf7Container.innerHTML = `
                        <video controls muted loop>
                            <source src="${sample.video_conf7}" type="video/mp4">
                            Your browser does not support the video tag.
                        </video>`;
                }
            }

            if (sample.merged_conf7) {
                const mergedConf7Container = document.getElementById(`sample-${sampleIdx}-merged-conf7`);
                if (mergedConf7Container && mergedConf7Container.querySelector('.loading-placeholder')) {
                    mergedConf7Container.innerHTML = `
                        <video controls muted loop>
                            <source src="${sample.merged_conf7}" type="video/mp4">
                            Your browser does not support the video tag.
                        </video>`;
                }
            }
        }

        function playSample(sampleIdx) {
            loadVideosForSample(sampleIdx);

            setTimeout(() => {
                const sampleDiv = document.getElementById(`sample-${sampleIdx}`);
                sampleDiv.querySelectorAll('video').forEach(v => v.play().catch(e => console.log('Auto-play failed:', e)));
                updateStatus(`Playing: ${samplesData[sampleIdx].name}`);
            }, 100);
        }

        function pauseSample(sampleIdx) {
            const sampleDiv = document.getElementById(`sample-${sampleIdx}`);
            sampleDiv.querySelectorAll('video').forEach(v => v.pause());
            updateStatus(`Paused: ${samplesData[sampleIdx].name}`);
        }

        function restartSample(sampleIdx) {
            loadVideosForSample(sampleIdx);

            setTimeout(() => {
                const sampleDiv = document.getElementById(`sample-${sampleIdx}`);
                sampleDiv.querySelectorAll('video').forEach(video => {
                    video.currentTime = 0;
                    video.play().catch(e => console.log('Auto-play failed:', e));
                });
                updateStatus(`Restarted: ${samplesData[sampleIdx].name}`);
            }, 100);
        }

        function playAll() {
            samplesData.forEach((_, idx) => playSample(idx));
            updateStatus('Playing all samples');
        }

        function pauseAll() {
            samplesData.forEach((_, idx) => pauseSample(idx));
            updateStatus('Paused all samples');
        }

        function restartAll() {
            samplesData.forEach((_, idx) => restartSample(idx));
            updateStatus('Restarted all samples');
        }

        function updateStatus(message) {
            statusDiv.textContent = message;
        }

        document.addEventListener('DOMContentLoaded', generateSamples);
    </script>
</body>
</html>
