# How to run the code
1. Create .venv in root folder with python 3.12
2. pip install -r code/requirements.txt
3. Download the opennutrition dataset from https://www.opennutrition.app/ and place it as shown in the folder structure shown below.
4. Update environment file with openrouter KEY, postgres url, db name and password.
5. Run script to load OpenNutrition data into Postgres
```
.venv/bin/python code/datasets/load_opennutrition_tsv.py \
    --tsv code/datasets/opennutrition-dataset-2025/opennutrition_foods.tsv \
    --table opennutrition_foods_raw

.venv/bin/python code/datasets/pre_process_opennutrition.py    
```
6. Run adk web in the root of the code folder.
```
cd code
adk web
```
7. Select the agent and test with any conversation from dri.evalset.json or mfp.evalset.json files in the eval folder.

# Evaluation for DRI
```
cd code/OptimizerCanadaDRIPlanner
python run_eval.py 
cd code/NoLLMCanadaDRIPlanner
python run_eval.py 
cd code/BaselineCanadaDRIPlanner
python run_eval.py 
```

# HTML Summary for DRI
```
cd code
python eval/3_compute_results_table_metrics.py --agents NoLLMCanadaDRIPlanner BaselineCanadaDRIPlanner OptimizerCanadaDRIPlanner --samples-path eval/generate/dri.jsonl --format html --output-html eval/deviation_buckets_dri_three_approaches.html
```

# Evaluation for MFP
```
cd code/OptimizerMFPNutritionPlanner
python run_eval.py 
cd code/NoLLMMFPNutritionPlanner
python run_eval.py 
cd code/BaselineMFPNutritionPlanner
python run_eval.py 
```

# HTML Summary for MFP
```
cd code
python eval/3_compute_results_table_metrics.py --agents NoLLMMFPNutritionPlanner BaselineMFPNutritionPlanner OptimizerMFPNutritionPlanner --samples-path eval/generate/mfp.jsonl --format html --output-html eval/deviation_buckets_mfp_three_approaches.html
```


# How to run the tensorboard visualizer 
1. Run the following command.
```
cd code/visualizer
python launch_projector.py  --port 6006
```
2. Open the url on port 6007 in the web browser


# Folder Structure

```text
code/
├── .env
├── README.md
├── eval_config.json
├── requirements.txt
├── BaselineCanadaDRIPlanner/
│   ├── .adk/
│   ├── __init__.py
│   ├── agent.py
│   ├── dri_prompt.txt
│   ├── dri.evalset.json
│   ├── run_eval.py
│   └── summarize_eval_history_calories.py
├── BaselineMFPNutritionPlanner/
│   ├── .adk/
│   ├── __init__.py
│   ├── agent.py
│   ├── mfp_prompt.txt
│   ├── mfp.evalset.json
│   ├── run_eval.py
│   └── summarize_eval_history_calories.py
├── NoLLMCanadaDRIPlanner/
│   ├── .adk/
│   ├── __init__.py
│   ├── agent.py
│   ├── dri.evalset.json
│   ├── heuristics.py
│   ├── run_eval.py
│   └── summarize_eval_history_calories.py
├── NoLLMMFPNutritionPlanner/
│   ├── .adk/
│   ├── __init__.py
│   ├── agent.py
│   ├── heuristics.py
│   ├── mfp.evalset.json
│   ├── run_eval.py
│   └── summarize_eval_history_calories.py
├── OptimizerCanadaDRIPlanner/
│   ├── .adk/
│   ├── __init__.py
│   ├── agent.py
│   ├── dri_prompt.txt
│   ├── dri.evalset.json
│   ├── log_problematic_samples.py
│   ├── run_eval.py
│   └── summarize_eval_history_calories.py
├── OptimizerMFPNutritionPlanner/
│   ├── .adk/
│   ├── __init__.py
│   ├── agent.py
│   ├── mfp_prompt.txt
│   ├── mfp.evalset.json
│   ├── run_eval.py
│   └── summarize_eval_history_calories.py
├── datasets/
│   ├── load_opennutrition_tsv.py
│   ├── pre_process_opennutrition.py
│   ├── dri_reference/
│   │   ├── Macronutrients_table-en.csv
│   │   └── Micronutrients_table-en.csv
│   └── opennutrition-dataset-2025/
│       ├── LICENSE-DbCL.txt
│       ├── LICENSE-ODbL.txt
│       ├── README.md
│       └── opennutrition_foods.tsv
├── eval/
│   ├── 3_compute_results_table_metrics.py
│   ├── 4_create_report.py
│   ├── custom_metrics.py
│   ├── deviation_buckets_dri_three_approaches.html
│   ├── deviation_buckets_mfp_three_approaches.html
│   ├── dri.evalset.json
│   ├── generate/
│   │   ├── 1_dri_data.py
│   │   ├── 2_mfp_data.py
│   │   ├── 3_jsonl_to_evalset.py
│   │   ├── dri.evalset.json
│   │   ├── dri.jsonl
│   │   ├── mfp.evalset.json
│   │   └── mfp.jsonl
│   └── mfp.evalset.json
├── utils/
│   ├── calculate_health_canada_dri.py
│   ├── calculate_mfp_macros.py
│   ├── calculator.py
│   ├── ingredient_tool.py
│   ├── log_chat.py
│   ├── optimizer.py
│   └── optimizer_mfp.py
└── visualizer/
    ├── extract_meal_embeddings.py
    ├── launch_projector.py
    └── output/
        └── meal_projector/
            ├── meal_macro_embeddings.tsv
            ├── meal_metadata.tsv
            ├── meal_nodes.json
            ├── projector_config.pbtxt
            └── summary.json
```


