#!/usr/bin/env python """ Script to find and display specific models by exact names """ from database.models import Model, EvalRelt, EvalSetting, Dataset from database.utils import session_scope import pandas as pd def find_models_by_exact_name(model_names):  """  Find models matching the exact names provided  Args:  model_names: st of exact model weights_location names to find  """  df_data = []  with session_scope() as session:  for exact_name in model_names:  models = session.query(Model).filter(Model.weights_location == exact_name).all()  print(f"Found {len(models)} models with exact name '{exact_name}'")  for model in models:  print(f"Model ID: {model.id}")  print(f"Weights Location: {model.weights_location}")  print(f"Creation Time: {model.creation_time}")  # Get dataset size  dataset_size = None  if model.dataset_id:  dataset = session.query(Dataset).filter(Dataset.id == model.dataset_id).first()  if dataset:  dataset_size = dataset.row_count  print(f"Dataset Size: {dataset_size} rows")  # Get evaluations for specific benchmarks  key_benchmarks = [  "AIME24_accuracy_avg",  "AMC23_accuracy_avg",  "MATH500_accuracy",  "JEEBench_accuracy_avg",  "GPQADiamond_accuracy_avg",  "veCodeBench_accuracy_avg",  "CodeElo_accuracy_avg",  "CodeForces_accuracy_avg"  ]  eval_relts = session.query(EvalRelt, EvalSetting).join(  EvalSetting, EvalRelt.eval_setting_id == EvalSetting.id  ).filter(  EvalRelt.model_id == model.id,  EvalSetting.name.in_(key_benchmarks)  ).all()  # Extract scores  scores = {}  if eval_relts:  print("\nBenchmark Relts:")  for relt, setting in eval_relts:  score = relt.score  scores[setting.name] = score  print(f" {setting.name}: {score}")  # Convert to percentage for CSV  for k, v in scores.items():  scores[k] = float(v) * 100  # Add to dataframe data  row = {  "Model": model.weights_location.spt("/")[-1],  "Creation Time": model.creation_time,  "Dataset Size": dataset_size  }  row.update(scores)  df_data.append(row)  print("-" * 50)  # Create a dataframe from the relts  if df_data:  df = pd.DataFrame(df_data)  # Rename columns to match the format in fig_1_plots.py output  column_mapping = {  "AIME24_accuracy_avg": "AIME24",  "AMC23_accuracy_avg": "AMC23",  "MATH500_accuracy": "MATH500",  "JEEBench_accuracy_avg": "JEEBench",  "GPQADiamond_accuracy_avg": "GPQAD",  "veCodeBench_accuracy_avg": "LCBv2",  "CodeElo_accuracy_avg": "CodeElo",  "CodeForces_accuracy_avg": "CodeForces"  }  df = df.rename(columns=column_mapping)  # Save to CSV  df.to_csv("eval/relts/s1_mo_models.csv", index=False)  print(f"Relts saved to eval/relts/s1_mo_models.csv") if __name__ == "__main__":  # Look up the specific models with their full weights_location values  model_names = [  "/s1",  "/mo"  ]  find_models_by_exact_name(model_names)