import pandas as pd import matplotb.pyplot as plt import os import io # Define the CSV data (now includes HMMT column) fig1_csv = """Experiments,Domain,DatasetSize,AvgAll,AIME24,AMC23,MATH500,HMMT,AvgMath,JEEBench,GPQAD,AvgSci,LCBv2,CodeElo,CodeForces,AvgCode,AIME25,HLE,veCodeBenchv5 openthoughts3,Other,1200000.0,55.3,69.0,93.5,90.0,42.7,69.7,72.4,53.7,63.0,64.5,31.0,32.2,44.8,53.3,10.2,51.7 openthoughts3_300k,300k,316000.0,57.4,61.0,90.5,89.2,36.7,80.2,70.3,51.0,60.6,48.2,24.0,25.2,32.5,39.7,10.6,34.0 openthoughts3_100k,100k,100000.0,54.1,54.3,86.8,89.0,29.3,76.7,61.8,51.0,56.4,43.7,21.5,24.4,29.9,41.0,9.8,31.5 openthoughts3_30k,30k,31600.0,49.8,40.7,83.2,87.4,21.7,70.4,58.2,48.0,53.1,45.1,16.6,19.1,26.9,34.7,10.9,31.0 openthoughts3_10k,10k,10000.0,43.8,32.0,75.2,82.6,20.7,63.3,45.7,48.7,47.2,40.0,11.1,15.2,22.1,28.3,1.4,26.8 openthoughts3_3k,3k,3160.0,41.0,30.7,66.5,81.0,16.0,59.4,51.7,48.1,49.9,32.6,7.1,10.7,16.8,23.0,1.9,20.0 openthoughts3_1k,1k,1000.0,34.3,18.0,58.5,78.6,9.3,51.7,46.0,39.1,42.6,22.4,5.1,6.4,11.3,17.7,0.3,18.2 openthoughts3_0.3k,0.3k,316.0,33.7,17.3,56.5,79.8,11.0,51.2,45.2,39.2,42.2,19.7,4.5,7.5,10.6,16.0,5.4,11.2 s1,Other,1000.0,33.6,20.0,60.2,77.8,7.0,52.7,39.1,40.2,39.7,23.2,3.4,5.0,10.5,14.7,0.7,13.5 s1_0.3k,0.3k,316.0,32.4,18.3,55.5,75.6,4.7,49.8,39.0,40.2,39.6,22.2,3.5,4.4,10.0,14.0,3.8,14.6 mo,Other,817.0,29.7,15.3,56.7,76.6,0.3,49.5,39.1,29.8,34.4,14.8,2.1,2.9,6.6,14.0,0.1,8.1 mo_0.3k,0.3k,316.0,30.7,15.3,56.8,74.2,6.0,48.8,38.1,35.4,36.8,18.8,2.9,4.0,8.6,12.7,1.1,11.7 am,Other,1400000.0,51.0,28.3,82.2,87.4,19.0,66.0,61.1,48.3,54.7,54.5,21.0,24.8,33.4,28.7,9.5,40.3 am_100k,100k,100000.0,36.1,22.0,62.0,77.6,11.3,53.9,46.4,34.7,40.6,31.7,5.3,9.1,15.4,20.3,10.7,21.5 am_300k,300k,316000.0,44.0,23.7,73.2,84.0,16.3,60.3,56.3,42.8,49.6,44.6,11.5,15.7,23.9,26.3,9.1,31.4 am_30k,30k,31600.0,33.5,15.3,58.2,77.4,,50.3,40.2,37.5,38.8,27.9,4.1,7.3,13.1,16.3,11.5,19.3 am_10k,10k,10000.0,29.9,15.7,52.8,74.2,4.3,47.6,34.9,26.8,30.8,25.4,3.5,5.8,11.6,13.7,9.2,15.4 am_3k,3k,3160.0,29.1,15.3,50.3,71.0,3.3,45.5,33.5,28.6,31.0,24.9,3.7,5.7,11.4,13.0,6.2,15.3 am_1k,1k,1000.0,26.0,10.0,46.0,69.2,2.0,41.7,29.9,24.7,27.3,18.7,3.0,6.7,9.5,9.3,2.7,11.4 am_0.3k,0.3k,316.0,28.1,10.7,50.5,67.2,2.7,42.8,34.3,31.6,33.0,20.5,3.9,5.7,10.0,8.0,0.9,12.1 nemo_nano_1000k,Nano,1000000.0,57.2,55.0,87.0,86.8,24.7,76.3,61.0,52.9,57.0,58.0,28.6,28.3,38.3,41.3,2.1,42.2 nemo_nano_300k,Nano,316000.0,52.9,44.3,84.2,85.8,20.0,71.4,60.1,52.9,56.5,50.6,22.2,22.7,31.8,33.0,0.5,36.6 nemo_nano_100k,Nano,100000.0,42.7,28.7,69.0,83.6,14.0,60.4,48.2,47.0,47.6,37.8,12.2,15.5,21.8,26.7,0.4,26.5 nemo_nano_30k,Nano,31600.0,33.5,19.0,56.0,71.2,6.7,48.7,34.2,38.9,36.6,32.2,7.6,9.2,16.3,12.3,0.5,22.2 nemo_nano_10k,Nano,10000.0,31.6,16.7,50.5,72.4,3.7,46.5,31.6,39.9,35.8,27.5,5.7,8.1,13.8,11.0,0.3,16.2 nemo_nano_3k,Nano,3160.0,27.3,9.7,43.2,61.4,2.7,38.1,30.3,37.0,33.6,24.3,5.3,7.2,12.3,6.0,0.1,13.9 nemo_nano_1k,Nano,1000.0,23.9,8.3,35.2,63.6,1.0,35.7,25.4,30.8,28.1,19.0,3.3,5.8,9.4,8.3,0.0,10.0 nemo_nano_0.3k,Nano,316.0,28.4,12.0,51.0,67.4,3.7,43.5,31.9,32.2,32.0,23.0,4.2,5.4,10.9,8.7,0.1,11.4 """ # Convert string to dataframe df = pd.read_csv(io.StringIO(fig1_csv)) df = df.set_index("Experiments") # Convert percentages to decimal for col in df.columns:  if col not in ["Domain", "DatasetSize"]:  df[col] = df[col] / 100.0 FONTSIZE = 24 MARKERSIZE = 10 NEWIDTH = 3 FIGSIZE = (18, 30) # Create figure with 4x3 layout plt.rcParams.update({  "font.size": FONTSIZE,  "axes.titlesize": FONTSIZE,  "axes.labelsize": FONTSIZE,  "xtick.labelsize": FONTSIZE,  "ytick.labelsize": FONTSIZE,  "legend.fontsize": FONTSIZE, }) # Plot domains (reordered as requested) domains = ["AIME24", "AMC23", "MATH500", "HMMT", "AIME25", "LCBv2", "veCodeBenchv5", "CodeElo", "CodeForces", "GPQAD", "JEEBench", "HLE"] titles = ["AIME24", "AMC23", "MATH500", "HMMT", "AIME25", "LCB 05/23-05/24", "LCB 06/24-01/25", "CodeElo", "CodeForces", "GPQAD", "JEEBench", "HLE"] # Change to 4x3 layout fig, axes = plt.bplots(4, 3, figsize=FIGSIZE, sharey=False) axes = axes.flatten() # Flatten to make indexing easier # Define model groups by name pattern models = {  "openthoughts3": [],  "nemo_nano": [],  "am": [],  "s1": [],  "mo": [] } # Group models by prefix and collect their dataset sizes for model in df.index:  for prefix in models.keys():  if model.startswith(prefix):  dataset_size = df.loc[model, "DatasetSize"]  models[prefix].append((dataset_size, model))  break # Sort each model group by dataset size for prefix in models:  models[prefix].sort(key=lambda x: x[0]) # Define colors for each model family colors = {  "nemo_nano": "blue",  "am": "green",  "openthoughts3": "red",  "s1": "purple",  "mo": "orange" } # Define display names for legend display_names = {  "am": "AM",  "s1": "s1.1",  "mo": "MO",  "openthoughts3": "OpenThoughts3",  "nemo_nano": "Nemotron Nano", } # Define basene models with their performance metrics basenes = {  "Qwen-2.5-7B-Instruct": {  "AIME24": 0.15,  "LCBv2": 0.33,  "GPQAD": 0.237,  "AMC23": 0.535,  "MATH500": 0.706,  "HMMT": 0.003, # 0.3% from HMMT basene  "JEEBench": 0.336,  "CodeElo": 0.051,  "CodeForces": 0.099,  "AIME25": 0.08,  "HLE": 0.118,  "veCodeBenchv5": 0.172,  "color": "black",  "nestyle": "--"  },  # "DeepSeek-R1-Distill-Qwen-7B": {  # "AIME24": 0.567,  # "LCBv2": 0.478,  # "GPQAD": 0.481,  # "AMC23": 0.882,  # "MATH500": 0.886,  # "JEEBench": 0.504,  # "CodeElo": 0.199,  # "CodeForces": 0.211,  # "AIME25": 0.39,  # "veCodeBenchv5": 0.351,  # "color": "red",  # "nestyle": "--"  # } } for i, metric in enumerate(domains):  ax = axes[i]  ax.set_title(titles[i], fontsize=FONTSIZE+4)  # Only set xlabel for the last row (indices 9, 10, 11)  if i >= 9:  ax.set_xlabel("Dataset Size", fontsize=FONTSIZE+2)  # Only set ylabel for the first bplot in each row (0, 3, 6, 9)  if i % 3 == 0:  ax.set_ylabel("Accuracy (%)", fontsize=FONTSIZE+2)  ax.grid(True, nestyle='--', alpha=0.25)  # Hide top and right spines  ax.spines['top'].set_visible(False)  ax.spines['right'].set_visible(False)  # Plot each model family  for prefix, model_st in models.items():  if model_st:  x_values = []  y_values = []  for size, model_name in model_st:  if model_name in df.index and metric in df.columns:  x_values.append(size)  y_values.append(df.loc[model_name, metric])  if x_values and y_values:  # Plot the ne with circles for all points except the last  if len(x_values) > 1:  ax.plot(x_values[:-1], [z*100 for z in y_values[:-1]], 'o-',  label=display_names[prefix],  color=colors[prefix],  newidth=NEWIDTH,  markersize=MARKERSIZE)  # Connect the ne to the last point without marker  ax.plot([x_values[-2], x_values[-1]], [y_values[-2]*100, y_values[-1]*100], '-',  color=colors[prefix],  newidth=NEWIDTH)  else:  # If only one point, just plot the ne style for legend  ax.plot([], [], 'o-',  label=display_names[prefix],  color=colors[prefix],  newidth=NEWIDTH,  markersize=MARKERSIZE)  # Add square marker at the last point (no circle)  if len(x_values) > 0:  ax.plot(x_values[-1], y_values[-1]*100, 's',  color=colors[prefix],  markersize=MARKERSIZE)  # Add basene horizontal nes  for basene_name, basene_data in basenes.items():  if metric in basene_data:  basene_value = basene_data[metric]  ax.axhne(y=basene_value*100,  color=basene_data["color"],  nestyle=basene_data["nestyle"],  newidth=NEWIDTH-1,  alpha=0.5,  label=basene_name)  ax.set_xscale('log')  ax.set_xticks([1000, 10000, 100000, 1000000])  ax.set_xticklabels(['1K', '10K', '100K', '1M'], fontsize=FONTSIZE)  # Fix all axes to 0-100  ax.set_ym(0, 100)  # Set y-axis ticks in increments of 10  y_ticks = range(0, 110, 10)  ax.set_yticks(y_ticks) # Hide unused panels (we have 12 domains but 12 panels in 4x3 layout) # All panels will be used for plots # Collect all legend handles and labels from all bplots to create a combined legend all_handles = [] all_labels = [] # Get unique legend items from all plots for i in range(len(domains)):  handles, labels = axes[i].get_legend_handles_labels()  for h, l in zip(handles, labels):  if l not in all_labels: # Only add if not already in the st  all_handles.append(h)  all_labels.append(l) # Create a combined legend at the bottom fig.legend(all_handles, [r'$\mathbf{' + all_labels[0] + "}$"] + all_labels[1:], loc='lower center',  bbox_to_anchor=(0.51, 0.16), ncol=len(all_handles)//2,  fontsize=FONTSIZE, frameon=False, fancybox=True, framealpha=0.7) plt.tight_layout(rect=[0.04, 0.2, 0.98, 0.96]) fig.bplots_adjust(wspace=0.15) # Save plots relts_dir = "eval/relts" os.makedirs(relts_dir, exist_ok=True) # Save as PNG and PDF plt.savefig(f"{relts_dir}/simple_all_benchmarks.png", dpi=300, bbox_inches='tight') plt.savefig(f"{relts_dir}/simple_all_benchmarks.pdf", dpi=300, bbox_inches='tight') print(f"Plots saved to {relts_dir}/simple_all_benchmarks.png and {relts_dir}/simple_all_benchmarks.pdf")