<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Self-Consistency Rescue Analysis</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 data = [
  { model: "Qwen2.5-7B", cotAcc: 75.4, scAcc: 77.6, cotFlips: 39, scFlips: 25, rescues: 26, rescueRate: 66.7, color: "#4e79a7" },
  { model: "Llama-3.1-8B", cotAcc: 23.4, scAcc: 32.4, cotFlips: 131, scFlips: 101, rescues: 56, rescueRate: 42.8, color: "#e15759" },
  { model: "Mistral-7B", cotAcc: 7.2, scAcc: 10.6, cotFlips: 52, scFlips: 45, rescues: 9, rescueRate: 17.3, color: "#76b7b2" },
  { model: "Llama-2-7B", cotAcc: 15.5, scAcc: 15.8, cotFlips: 46, scFlips: 45, rescues: 4, rescueRate: 8.7, color: "#f28e2b" }
];

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

function draw() {
  const W = window.innerWidth, H = window.innerHeight;
  const m = { top: 35, right: 130, bottom: 50, left: 55 };
  const w = W - m.left - m.right, h = H - m.top - m.bottom;
  svg.selectAll("*").remove();
  const g = svg.append("g").attr("transform", `translate(${m.left},${m.top})`);

  // Left: rescue rate bars, Right: flip count comparison
  const x = d3.scaleBand().domain(data.map(d=>d.model)).range([0, w]).padding(0.2);
  const y = d3.scaleLinear().domain([0, 75]).range([h, 0]);

  g.append("g").attr("transform",`translate(0,${h})`).call(d3.axisBottom(x).tickFormat(d=>d.split("-")[0].replace("2.5",""))).selectAll("text").attr("font-size","12px");
  g.append("g").call(d3.axisLeft(y).ticks(5).tickFormat(d=>d+"%"));
  g.append("text").attr("transform","rotate(-90)").attr("x",-h/2).attr("y",-40).attr("text-anchor","middle").attr("font-size","13px").attr("fill","#333").attr("font-weight",600).text("SC@5 Rescue Rate (%)");

  // Bars
  data.forEach(d => {
    // Main rescue rate bar
    g.append("rect")
      .attr("x", x(d.model)).attr("y", y(d.rescueRate)).attr("width", x.bandwidth()).attr("height", y(0)-y(d.rescueRate))
      .attr("fill", d.color).attr("rx", 3).attr("opacity", 0.85)
      .style("cursor","pointer")
      .on("mouseover", e => {
        tip.style("display","block").html(
          `<b>${d.model}</b><br>
           SC@5 Rescue Rate: <b>${d.rescueRate}%</b><br>
           CoT Flips: ${d.cotFlips} → SC Flips: ${d.scFlips}<br>
           Rescued: <b>${d.rescues}</b> flips<br>
           CoT Acc: ${d.cotAcc}% → SC@5 Acc: <b>${d.scAcc}%</b> (+${(d.scAcc-d.cotAcc).toFixed(1)}%)`
        );
      })
      .on("mousemove", e => { tip.style("left",(e.pageX+12)+"px").style("top",(e.pageY-10)+"px"); })
      .on("mouseout", () => tip.style("display","none"));

    // Label on bar
    g.append("text")
      .attr("x", x(d.model) + x.bandwidth()/2)
      .attr("y", y(d.rescueRate) - 6)
      .attr("text-anchor","middle").attr("font-size","13px").attr("fill",d.color).attr("font-weight",700)
      .text(d.rescueRate + "%");

    // Flip count annotation inside bar
    if (d.rescueRate > 12) {
      g.append("text")
        .attr("x", x(d.model) + x.bandwidth()/2)
        .attr("y", y(d.rescueRate/2) + 4)
        .attr("text-anchor","middle").attr("font-size","11px").attr("fill","#fff").attr("font-weight",600)
        .attr("pointer-events","none")
        .text(`${d.rescues}/${d.cotFlips} saved`);
    }
  });

  // Annotation: correlation
  g.append("text").attr("x",w+10).attr("y",20).attr("font-size","12px").attr("fill","#555").attr("font-weight",600).text("Capability ↔ Rescue");
  g.append("text").attr("x",w+10).attr("y",38).attr("font-size","12px").attr("fill","#999").text("r ≈ 0.95");
  g.append("text").attr("x",w+10).attr("y",62).attr("font-size","11px").attr("fill","#555").text("Stronger models");
  g.append("text").attr("x",w+10).attr("y",78).attr("font-size","11px").attr("fill","#555").text("have more robust");
  g.append("text").attr("x",w+10).attr("y",94).attr("font-size","11px").attr("fill","#555").text("correct intuitions");
}

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