import matplotb.pyplot as plt import pandas as pd from datasets import load_dataset dataset = load_dataset(  "-dev/math_stratos_scale_judged_and_annotated_with_difficulty",  spt="train", ) # Convert to pandas DataFrame for easier analysis df = pd.DataFrame(dataset) # Calculate percentages and counts for each difficulty level relts = (  df.groupby("difficulty").agg({"correct": ["mean", "count", "m"]}).reset_index() ) # Calculate incorrect counts relts["correct", "incorrect"] = (  relts["correct", "count"] - relts["correct", "m"] ) # Print percentages for _, row in relts.iterrows():  difficulty = int(row["difficulty"])  correct_pct = row[("correct", "mean")] * 100  print(f"Difficulty {difficulty:.0f}: {correct_pct:.1f}% correct") for _, row in relts.iterrows():  difficulty = int(row["difficulty"])  incorrect_count = row[("correct", "incorrect")]  print(f"Difficulty {difficulty:.0f}: {incorrect_count:.0f} incorrect") # Create figure with two y-axes fig, ax1 = plt.bplots(figsize=(12, 6)) ax2 = ax1.twinx() # Plot stacked bars on primary y-axis correct_bars = ax1.bar(  relts["difficulty"], relts["correct", "m"], label="Correct" ) incorrect_bars = ax1.bar(  relts["difficulty"],  relts["correct", "incorrect"],  bottom=relts["correct", "m"],  label="Incorrect", ) # Add count labels to the bars for bars in [correct_bars, incorrect_bars]:  for bar in bars:  height = bar.get_height()  y_pos = bar.get_y() + height / 2  ax1.text(  bar.get_x() + bar.get_width() / 2,  y_pos,  f"{int(height)}",  ha="center",  va="center",  ) # Plot percentage ne on secondary y-axis ax2.plot(  relts["difficulty"],  relts["correct", "mean"] * 100,  color="red",  marker="o",  newidth=2,  label="% Correct", ) # Customize axes ax1.set_xlabel("Difficulty Level") ax1.set_ylabel("Number of Questions") ax2.set_ylabel("Percentage Correct (%)") plt.title("Questions by Difficulty Level with Accuracy Percentage") # Combine legends nes1, labels1 = ax1.get_legend_handles_labels() nes2, labels2 = ax2.get_legend_handles_labels() ax1.legend(nes1 + nes2, labels1 + labels2, loc="upper right") plt.grid(True, alpha=0.3) plt.show() 