<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Cross-Domain: GSM8K vs CoQA</title>
<style>
  html, body { margin: 0; padding: 0; overflow: hidden; width: 100%; height: 100%; font-family: 'Georgia', serif; background: #fafafa; }
  svg { display: block; width: 100%; height: 100%; }
  .tooltip { position: absolute; background: rgba(255,255,255,0.96); border: 1px solid #ccc; border-radius: 6px; padding: 10px 14px; font-size: 13px; line-height: 1.5; pointer-events: none; box-shadow: 0 2px 8px rgba(0,0,0,0.12); }
</style>
</head>
<body>
<div class="tooltip" id="tip" style="display:none;"></div>
<svg id="chart"></svg>
<script src="https://d3js.org/d3.v7.min.js"></script>
<script>
const models = [
  { name: "Qwen2.5-7B", color: "#4e79a7",
    gsm: { zs: 18.3, cot: 75.4, delta: 57.2 },
    coqa: { zs: 61.8, cot: 56.4, delta: -5.4 }
  },
  { name: "Llama-3.1-8B", color: "#e15759",
    gsm: { zs: 14.6, cot: 23.4, delta: 8.9 },
    coqa: { zs: 57.0, cot: 36.6, delta: -20.4 }
  },
  { name: "Llama-2-7B", color: "#f28e2b",
    gsm: { zs: 4.2, cot: 15.5, delta: 11.3 },
    coqa: { zs: 57.8, cot: 54.2, delta: -3.6 }
  },
  { name: "Mistral-7B", color: "#76b7b2",
    gsm: { zs: 4.5, cot: 7.2, delta: 2.7 },
    coqa: { zs: 56.0, cot: 29.2, delta: -26.8 }
  }
];

const svg = d3.select("#chart");
const tip = d3.select("#tip");

function draw() {
  const W = window.innerWidth, H = window.innerHeight;
  const m = { top: 35, right: 20, bottom: 50, left: 55 };
  const w = W - m.left - m.right, h = H - m.top - m.bottom;
  svg.selectAll("*").remove();

  const halfW = (w - 40) / 2;

  // Left panel: GSM8K
  drawPanel(svg.append("g").attr("transform",`translate(${m.left},${m.top})`), halfW, h, "GSM8K (Math)", "gsm", true);
  // Right panel: CoQA
  drawPanel(svg.append("g").attr("transform",`translate(${m.left + halfW + 40},${m.top})`), halfW, h, "CoQA (Text QA)", "coqa", false);

  function drawPanel(g, pw, ph, title, domain, showYLabel) {
    const x = d3.scaleBand().domain(models.map(d=>d.name)).range([0, pw]).padding(0.15);
    const y = d3.scaleLinear().domain([0, 82]).range([ph, 0]);
    const barW = x.bandwidth() / 2.2;

    g.append("text").attr("x",pw/2).attr("y",-12).attr("text-anchor","middle").attr("font-size","14px").attr("fill","#222").attr("font-weight",700).text(title);
    g.append("g").attr("transform",`translate(0,${ph})`).call(d3.axisBottom(x).tickFormat(d=>d.split("-")[0].replace("2.5",""))).selectAll("text").attr("font-size","11px");
    g.append("g").call(d3.axisLeft(y).ticks(5).tickFormat(d=>d+"%"));
    if (showYLabel) g.append("text").attr("transform","rotate(-90)").attr("x",-ph/2).attr("y",-40).attr("text-anchor","middle").attr("font-size","12px").attr("fill","#333").attr("font-weight",600).text("Accuracy (%)");

    models.forEach(d => {
      const dd = d[domain];
      // ZS bar
      g.append("rect")
        .attr("x", x(d.name)).attr("y", y(dd.zs)).attr("width", barW).attr("height", y(0)-y(dd.zs))
        .attr("fill", "#ccc").attr("rx",2).style("cursor","pointer")
        .on("mouseover", e => {
          tip.style("display","block").html(`<b>${d.name}</b> — ${title}<br>Zero-Shot: <b>${dd.zs}%</b>`);
        })
        .on("mousemove", e => { tip.style("left",(e.pageX+12)+"px").style("top",(e.pageY-10)+"px"); })
        .on("mouseout", () => tip.style("display","none"));

      // CoT bar
      g.append("rect")
        .attr("x", x(d.name) + barW + 2).attr("y", y(dd.cot)).attr("width", barW).attr("height", y(0)-y(dd.cot))
        .attr("fill", d.color).attr("rx",2).style("cursor","pointer")
        .on("mouseover", e => {
          const deltaStr = dd.delta > 0 ? `+${dd.delta}%` : `${dd.delta}%`;
          const deltaColor = dd.delta > 0 ? "#2a9d2a" : "#d32f2f";
          tip.style("display","block").html(`<b>${d.name}</b> — ${title}<br>CoT: <b>${dd.cot}%</b><br>Delta: <b style="color:${deltaColor}">${deltaStr}</b>`);
        })
        .on("mousemove", e => { tip.style("left",(e.pageX+12)+"px").style("top",(e.pageY-10)+"px"); })
        .on("mouseout", () => tip.style("display","none"));

      // Delta annotation
      const deltaStr = dd.delta > 0 ? `+${dd.delta}` : `${dd.delta}`;
      const deltaColor = dd.delta > 0 ? "#2a9d2a" : "#d32f2f";
      g.append("text")
        .attr("x", x(d.name) + x.bandwidth()/2)
        .attr("y", y(Math.max(dd.zs, dd.cot)) - 5)
        .attr("text-anchor","middle").attr("font-size","11px").attr("fill", deltaColor).attr("font-weight",700)
        .text(deltaStr);
    });

    // Mini legend
    g.append("rect").attr("x",pw-100).attr("y",5).attr("width",10).attr("height",10).attr("fill","#ccc").attr("rx",2);
    g.append("text").attr("x",pw-86).attr("y",14).attr("font-size","11px").attr("fill","#555").text("ZS");
    g.append("rect").attr("x",pw-55).attr("y",5).attr("width",10).attr("height",10).attr("fill","#4e79a7").attr("rx",2);
    g.append("text").attr("x",pw-41).attr("y",14).attr("font-size","11px").attr("fill","#555").text("CoT");
  }
}

draw();
window.addEventListener("resize", draw);
</script>
</body>
</html>
