"""검증: DX 포함 관계를 겹치는 원(벤 다이어그램)으로 시각화. 3개 기술이 서로 겹쳐서 융합을 표현하고, DX가 전체를 감싸는 구조. """ from __future__ import annotations import asyncio, json, sys, time, datetime, base64, re from pathlib import Path ROOT = Path(__file__).parent.parent sys.path.insert(0, str(ROOT)) async def main(): from src.slide_measurer import capture_slide_screenshot from src.config import settings import anthropic out_dir = ROOT / "data" / "runs" / f"verify_venn_{datetime.datetime.now().strftime('%Y%m%d_%H%M%S')}" out_dir.mkdir(parents=True, exist_ok=True) client = anthropic.AsyncAnthropic(api_key=settings.anthropic_api_key) t0 = time.time() prompt = """다음 포함 관계를 SVG 벤 다이어그램으로 시각화하는 HTML을 만들어라. ## 관계 구조 - DX(디지털 전환)는 상위개념이다 — 전체를 감싸는 가장 큰 원 또는 박스. - DX 안에 GIS, BIM, 디지털 트윈 3개 기술이 있다. - 이 3개 기술은 **서로 겹쳐서 융합**된다 — 벤 다이어그램처럼 원이 겹치는 부분이 있어야 한다. - 3개가 겹치는 중심 영역 = "기술 융합" 또는 "DX 실현" ## 시각화 요구사항 (SVG 사용) 1. 전체 크기: 707px × 250px 2. DX 큰 원 또는 둥근 박스가 전체를 감싼다: - fill: rgba(37,99,235,0.08), stroke: #2563eb, stroke-width: 2 - 상단 라벨: "DX (상위개념)" 3. 내부에 3개 원이 서로 겹쳐서 배치: - GIS 원: cx=250, cy=120, r=80, fill: rgba(59,130,246,0.2), stroke: #3b82f6 - BIM 원: cx=350, cy=120, r=80, fill: rgba(16,185,129,0.2), stroke: #10b981 - 디지털트윈 원: cx=450, cy=120, r=80, fill: rgba(245,158,11,0.2), stroke: #f59e0b - 각 원이 약 30-40px씩 겹쳐야 한다 (완전 분리 아님) 4. 각 원 안에 텍스트: - 이름 (14px bold) - 한 줄 설명 (10px) 5. 3개가 겹치는 중심 영역에 "융합" 또는 "DX 실현" 텍스트 (작게) 6. 아래에 핵심 메시지: "BIM ≠ DX — BIM은 DX를 실현하기 위한 핵심 기술 중 하나일 뿐이다" - background: #f0f9ff, border: 2px solid #bae6fd, border-radius: 8px - "BIM ≠ DX" 부분: color: #dc2626, font-weight: 900 ## 텍스트 (원본 그대로) - GIS: "지리적 데이터를 공간 분석하여 시각적으로 표현" - BIM: "시설물 생애주기 정보를 3차원 모델로 통합·관리" - 디지털 트윈: "현실 객체를 디지털로 동일하게 구현" HTML + inline