#!/usr/bin/env python """ Script to query the database and display raw records for specified model name patterns. This script will show model information and all evaluation relts without plotting. """ import argparse import sys from database.models import Model, EvalRelt, EvalSetting, Dataset from database.utils import session_scope from sqlalchemy import or_ import pandas as pd def query_models(name_patterns, output_csv=None):  """  Query models that match any of the provided name patterns.  Args:  name_patterns: st of bstrings to search for in model weights_location  output_csv: Optional path to save relts as CSV  """  with session_scope() as session:  # Build filter conditions  filter_conditions = [Model.weights_location.contains(pattern) for pattern in name_patterns]  # Query models  models = session.query(Model).filter(or_(*filter_conditions)).all()  print(f'Found {len(models)} matching models\n')  if not models:  return  all_relts = []  # Process each model  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 information  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 evaluation relts  eval_relts = session.query(EvalRelt, EvalSetting).join(  EvalSetting, EvalRelt.eval_setting_id == EvalSetting.id  ).filter(EvalRelt.model_id == model.id).all()  if eval_relts:  print('\nEvaluation Relts:')  for relt, setting in eval_relts:  print(f' {setting.name}: {relt.score}')  # Add to relts for CSV output  if output_csv:  all_relts.append({  'model_id': str(model.id),  'model_name': model.weights_location,  'dataset_size': dataset_size,  'benchmark': setting.name,  'score': relt.score,  'creation_time': relt.creation_time  })  print('\n' + '-'*50 + '\n')  # Save to CSV if requested  if output_csv and all_relts:  df = pd.DataFrame(all_relts)  df.to_csv(output_csv, index=False)  print(f'Relts saved to {output_csv}') def main():  parser = argparse.ArgumentParser(description='Query database for models and their evaluation relts')  parser.add_argument('--patterns', nargs='+', required=True,  help='st of name patterns to search for in model weights_location')  parser.add_argument('--output', help='Optional path to save relts as CSV')  args = parser.parse_args()  query_models(args.patterns, args.output) if __name__ == '__main__':  main()