
import json
import argparse
from wrapper import MultimodalModelWrapper

if __name__ == '__main__':
    parser = argparse.ArgumentParser(description="Run multimodal model predictions")
    parser.add_argument('--instrcutocr_path', type=str, required=True, help="Path to the input JSON file containing samples")
    parser.add_argument('--img_dir', type=str, required=True, help="Directory containing images")
    parser.add_argument('--output_json', type=str, required=True, help="Path to the output JSON file to save predictions")
    parser.add_argument('--model', type=str, required=True, help="Model name")
    parser.add_argument('--temperature', type=float, required=True, help="Model name")
    parser.add_argument('--lambda_factor', type=float, required=True, help="Model name")

    args = parser.parse_args()

    with open(args.instrcutocr_path, 'r') as f:
        samples = json.load(f)

    wrapper = MultimodalModelWrapper(args.model, args.img_dir, temperature=args.temperature, lambda_factor=args.lambda_factor)

    predictions = wrapper.batch_predict(samples)

    wrapper.save_predictions(predictions, args.output_json)
