synth-ai 0.2.9.dev3__tar.gz → 0.2.9.dev4__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of synth-ai might be problematic. Click here for more details.

Files changed (549) hide show
  1. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/MANIFEST.in +5 -0
  2. {synth_ai-0.2.9.dev3/synth_ai.egg-info → synth_ai-0.2.9.dev4}/PKG-INFO +1 -1
  3. synth_ai-0.2.9.dev4/examples/analyze_semantic_words.sh +17 -0
  4. synth_ai-0.2.9.dev4/examples/common_old/backend.py +21 -0
  5. synth_ai-0.2.9.dev4/examples/crafter_debug_render.py +180 -0
  6. synth_ai-0.2.9.dev4/examples/evals_old/README.md +98 -0
  7. synth_ai-0.2.9.dev4/examples/evals_old/__init__.py +6 -0
  8. synth_ai-0.2.9.dev4/examples/evals_old/compare_models.py +1037 -0
  9. synth_ai-0.2.9.dev4/examples/evals_old/example_log.md +145 -0
  10. synth_ai-0.2.9.dev4/examples/evals_old/run_demo.sh +126 -0
  11. synth_ai-0.2.9.dev4/examples/evals_old/trace_analysis.py +270 -0
  12. synth_ai-0.2.9.dev4/examples/finetuning_old/_backup_synth_qwen/config.toml +29 -0
  13. synth_ai-0.2.9.dev4/examples/finetuning_old/_backup_synth_qwen/example_log.md +324 -0
  14. synth_ai-0.2.9.dev4/examples/finetuning_old/_backup_synth_qwen/filter_traces.py +60 -0
  15. synth_ai-0.2.9.dev4/examples/finetuning_old/_backup_synth_qwen/filter_traces_achievements.py +239 -0
  16. synth_ai-0.2.9.dev4/examples/finetuning_old/_backup_synth_qwen/purge_v3_traces.py +109 -0
  17. synth_ai-0.2.9.dev4/examples/finetuning_old/_backup_synth_qwen/react_agent_lm.py +1924 -0
  18. synth_ai-0.2.9.dev4/examples/finetuning_old/_backup_synth_qwen/readme.md +49 -0
  19. synth_ai-0.2.9.dev4/examples/finetuning_old/_backup_synth_qwen/run_crafter_qwen4b.py +114 -0
  20. synth_ai-0.2.9.dev4/examples/finetuning_old/_backup_synth_qwen/run_demo.sh +195 -0
  21. synth_ai-0.2.9.dev4/examples/finetuning_old/_backup_synth_qwen/sft_kickoff.py +118 -0
  22. synth_ai-0.2.9.dev4/examples/finetuning_old/synth_qwen_v1/README.md +68 -0
  23. synth_ai-0.2.9.dev4/examples/finetuning_old/synth_qwen_v1/filter_traces.py +60 -0
  24. synth_ai-0.2.9.dev4/examples/finetuning_old/synth_qwen_v1/filter_traces_achievements.py +239 -0
  25. synth_ai-0.2.9.dev4/examples/finetuning_old/synth_qwen_v1/finetune.py +46 -0
  26. synth_ai-0.2.9.dev4/examples/finetuning_old/synth_qwen_v1/hello_ft_model.py +71 -0
  27. synth_ai-0.2.9.dev4/examples/finetuning_old/synth_qwen_v1/infer.py +37 -0
  28. synth_ai-0.2.9.dev4/examples/finetuning_old/synth_qwen_v1/poll.py +44 -0
  29. synth_ai-0.2.9.dev4/examples/finetuning_old/synth_qwen_v1/prepare_data.py +35 -0
  30. synth_ai-0.2.9.dev4/examples/finetuning_old/synth_qwen_v1/purge_v3_traces.py +109 -0
  31. synth_ai-0.2.9.dev4/examples/finetuning_old/synth_qwen_v1/react_agent_lm.py +1932 -0
  32. synth_ai-0.2.9.dev4/examples/finetuning_old/synth_qwen_v1/run_crafter_sft_job.py +207 -0
  33. synth_ai-0.2.9.dev4/examples/finetuning_old/synth_qwen_v1/run_ft_job.py +232 -0
  34. synth_ai-0.2.9.dev4/examples/finetuning_old/synth_qwen_v1/upload_data.py +34 -0
  35. synth_ai-0.2.9.dev4/examples/finetuning_old/synth_qwen_v1/util.py +147 -0
  36. synth_ai-0.2.9.dev4/examples/rl/README.md +169 -0
  37. synth_ai-0.2.9.dev4/examples/rl/configs/eval_base_qwen.toml +15 -0
  38. synth_ai-0.2.9.dev4/examples/rl/configs/eval_rl_qwen.toml +11 -0
  39. synth_ai-0.2.9.dev4/examples/rl/configs/rl_from_base_qwen.toml +35 -0
  40. synth_ai-0.2.9.dev4/examples/rl/configs/rl_from_ft_qwen.toml +35 -0
  41. synth_ai-0.2.9.dev4/examples/rl/download_dataset.py +64 -0
  42. synth_ai-0.2.9.dev4/examples/rl/run_eval.py +435 -0
  43. synth_ai-0.2.9.dev4/examples/rl/run_rl_and_save.py +94 -0
  44. synth_ai-0.2.9.dev4/examples/rl/task_app/README.md +22 -0
  45. {synth_ai-0.2.9.dev3/synth_ai/task/apps → synth_ai-0.2.9.dev4/examples/rl/task_app}/math_single_step.py +8 -8
  46. synth_ai-0.2.9.dev4/examples/rl/task_app/math_task_app.py +107 -0
  47. synth_ai-0.2.9.dev4/examples/rl_old/task_app.py +962 -0
  48. synth_ai-0.2.9.dev4/examples/run_crafter_demo.sh +10 -0
  49. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/analyze_trace_db.py +420 -0
  50. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/configs/crafter_fft.toml +48 -0
  51. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/configs/eval_fft_qwen4b.toml +20 -0
  52. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/configs/eval_groq_qwen32b.toml +13 -0
  53. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/configs/eval_modal_qwen4b.toml +23 -0
  54. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/configs/rl_from_ft.toml +56 -0
  55. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/export_trace_sft.py +541 -0
  56. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/groq_test.py +88 -0
  57. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/manage_secrets.py +127 -0
  58. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/old/event_rewards.md +234 -0
  59. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/old/notes.md +73 -0
  60. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/readme.md +172 -0
  61. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/run_eval.py +434 -0
  62. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/run_fft_and_save.py +309 -0
  63. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/run_local_rollout.py +188 -0
  64. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/run_local_rollout_modal.py +160 -0
  65. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/run_local_rollout_parallel.py +342 -0
  66. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/run_local_rollout_traced.py +372 -0
  67. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/run_rl_and_save.py +101 -0
  68. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/run_rollout_remote.py +129 -0
  69. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/README.md +38 -0
  70. {synth_ai-0.2.9.dev3/synth_ai/task/apps → synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app}/grpo_crafter.py +7 -7
  71. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/grpo_crafter_task_app.py +165 -0
  72. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/synth_envs_hosted/README.md +173 -0
  73. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/synth_envs_hosted/__init__.py +5 -0
  74. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/synth_envs_hosted/branching.py +145 -0
  75. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/synth_envs_hosted/environment_routes.py +1271 -0
  76. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/synth_envs_hosted/envs/__init__.py +1 -0
  77. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/synth_envs_hosted/envs/crafter/__init__.py +6 -0
  78. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/synth_envs_hosted/envs/crafter/app.py +1 -0
  79. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/synth_envs_hosted/envs/crafter/environment.py +429 -0
  80. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/synth_envs_hosted/envs/crafter/policy.py +442 -0
  81. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/synth_envs_hosted/envs/crafter/react_agent.py +96 -0
  82. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/synth_envs_hosted/envs/crafter/shared.py +302 -0
  83. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/synth_envs_hosted/envs/crafter/tools.py +47 -0
  84. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/synth_envs_hosted/hosted_app.py +202 -0
  85. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/synth_envs_hosted/inference/__init__.py +5 -0
  86. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/synth_envs_hosted/inference/openai_client.py +512 -0
  87. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/synth_envs_hosted/main.py +102 -0
  88. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/synth_envs_hosted/policy_routes.py +985 -0
  89. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/synth_envs_hosted/registry.py +197 -0
  90. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/synth_envs_hosted/rollout.py +1749 -0
  91. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/synth_envs_hosted/storage/__init__.py +5 -0
  92. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/synth_envs_hosted/storage/volume.py +217 -0
  93. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/synth_envs_hosted/test_agents.py +160 -0
  94. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/synth_envs_hosted/test_service.py +146 -0
  95. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/synth_envs_hosted/test_stepwise_rewards.py +58 -0
  96. synth_ai-0.2.9.dev4/examples/warming_up_to_rl/task_app/synth_envs_hosted/utils.py +61 -0
  97. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/pyproject.toml +2 -2
  98. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/api/train/config_finder.py +18 -18
  99. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/api/train/env_resolver.py +28 -1
  100. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/cli/task_apps.py +264 -55
  101. synth_ai-0.2.9.dev4/synth_ai/demos/demo_task_apps/crafter/configs/crafter_fft_4b.toml +54 -0
  102. synth_ai-0.2.9.dev4/synth_ai/demos/demo_task_apps/crafter/configs/rl_from_base_qwen4b.toml +73 -0
  103. synth_ai-0.2.9.dev4/synth_ai/demos/demo_task_apps/math/config.toml +74 -0
  104. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/task/apps/__init__.py +54 -13
  105. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4/synth_ai.egg-info}/PKG-INFO +1 -1
  106. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai.egg-info/SOURCES.txt +97 -2
  107. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai.egg-info/top_level.txt +1 -0
  108. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/LICENSE +0 -0
  109. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/README.md +0 -0
  110. /synth_ai-0.2.9.dev3/synth_ai/demos/demo_task_apps/math/config.toml → /synth_ai-0.2.9.dev4/examples/rl/configs/rl_from_base_qwen17.toml +0 -0
  111. {synth_ai-0.2.9.dev3/synth_ai/demos/demo_task_apps/crafter → synth_ai-0.2.9.dev4/examples/warming_up_to_rl}/configs/crafter_fft_4b.toml +0 -0
  112. {synth_ai-0.2.9.dev3/synth_ai/demos/demo_task_apps/crafter → synth_ai-0.2.9.dev4/examples/warming_up_to_rl}/configs/rl_from_base_qwen4b.toml +0 -0
  113. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/setup.cfg +0 -0
  114. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/__init__.py +0 -0
  115. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/__main__.py +0 -0
  116. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/api/train/__init__.py +0 -0
  117. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/api/train/builders.py +0 -0
  118. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/api/train/cli.py +0 -0
  119. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/api/train/pollers.py +0 -0
  120. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/api/train/task_app.py +0 -0
  121. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/api/train/utils.py +0 -0
  122. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/cli/__init__.py +0 -0
  123. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/cli/balance.py +0 -0
  124. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/cli/calc.py +0 -0
  125. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/cli/demo.py +0 -0
  126. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/cli/legacy_root_backup.py +0 -0
  127. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/cli/man.py +0 -0
  128. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/cli/recent.py +0 -0
  129. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/cli/rl_demo.py +0 -0
  130. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/cli/root.py +0 -0
  131. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/cli/status.py +0 -0
  132. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/cli/traces.py +0 -0
  133. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/cli/watch.py +0 -0
  134. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/compound/cais.py +0 -0
  135. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/config/base_url.py +0 -0
  136. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/core/experiment.py +0 -0
  137. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/core/system.py +0 -0
  138. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/demo_registry.py +0 -0
  139. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/demos/core/__init__.py +0 -0
  140. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/demos/core/cli.py +0 -0
  141. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/demos/demo_task_apps/__init__.py +0 -0
  142. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/demos/demo_task_apps/core.py +0 -0
  143. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/demos/demo_task_apps/crafter/__init__.py +0 -0
  144. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/demos/demo_task_apps/crafter/grpo_crafter_task_app.py +0 -0
  145. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/demos/demo_task_apps/math/__init__.py +0 -0
  146. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/demos/demo_task_apps/math/_common.py +0 -0
  147. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/demos/demo_task_apps/math/app.py +0 -0
  148. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/demos/demo_task_apps/math/deploy_modal.py +0 -0
  149. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/demos/demo_task_apps/math/deploy_task_app.sh +0 -0
  150. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/demos/demo_task_apps/math/modal_task_app.py +0 -0
  151. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/demos/demo_task_apps/math/task_app_entry.py +0 -0
  152. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/__init__.py +0 -0
  153. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/environment/__init__.py +0 -0
  154. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/environment/artifacts/__init__.py +0 -0
  155. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/environment/artifacts/base.py +0 -0
  156. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/environment/core.py +0 -0
  157. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/environment/db/__init__.py +0 -0
  158. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/environment/db/sqlite.py +0 -0
  159. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/environment/registry.py +0 -0
  160. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/environment/resources/sqlite.py +0 -0
  161. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/environment/results.py +0 -0
  162. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/environment/rewards/__init__.py +0 -0
  163. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/environment/rewards/core.py +0 -0
  164. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/environment/shared_engine.py +0 -0
  165. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/environment/tools/__init__.py +0 -0
  166. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/__init__.py +0 -0
  167. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/bandit/__init__.py +0 -0
  168. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/bandit/engine.py +0 -0
  169. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/bandit/environment.py +0 -0
  170. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/bandit/taskset.py +0 -0
  171. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/__init__.py +0 -0
  172. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/analyze_semantic_words_markdown.py +0 -0
  173. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_comprehensive_evaluation.py +0 -0
  174. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_evaluation_browser.py +0 -0
  175. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_evaluation_config.toml +0 -0
  176. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_evaluation_framework.py +0 -0
  177. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/crafter_synth_config.toml +0 -0
  178. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/filter_config_modal.toml +0 -0
  179. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/filter_traces_sft_turso.py +0 -0
  180. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/kick_off_ft_modal.py +0 -0
  181. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/old/analyze_action_results.py +0 -0
  182. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/old/analyze_agent_actions.py +0 -0
  183. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/old/analyze_latest_run.py +0 -0
  184. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/old/analyze_lm_traces.py +0 -0
  185. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/old/analyze_no_rewards.py +0 -0
  186. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/old/analyze_trace_issue.py +0 -0
  187. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/old/check_db_schema.py +0 -0
  188. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/old/check_latest_results.py +0 -0
  189. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/old/debug_agent_responses.py +0 -0
  190. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/old/quick_trace_check.py +0 -0
  191. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/compare_experiments.py +0 -0
  192. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/filter_traces_sft_turso.py +0 -0
  193. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/kick_off_ft_oai.py +0 -0
  194. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/multi_model_config.toml +0 -0
  195. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/old/analyze_enhanced_hooks.py +0 -0
  196. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/old/analyze_hook_events.py +0 -0
  197. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/old/analyze_hook_results.py +0 -0
  198. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/old/check_hook_storage.py +0 -0
  199. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/old/check_seeds.py +0 -0
  200. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/old/compare_seed_performance.py +0 -0
  201. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/old/custom_eval_pipelines.py +0 -0
  202. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/old/plot_hook_frequency.py +0 -0
  203. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/old/seed_analysis_summary.py +0 -0
  204. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/run_rollouts_for_models_and_compare_v3.py +0 -0
  205. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_quick_evaluation.py +0 -0
  206. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_react_agent.py +0 -0
  207. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/crafter_trace_evaluation.py +0 -0
  208. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/example_v3_usage.py +0 -0
  209. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/compare_traces.py +0 -0
  210. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/crafter_comprehensive_evaluation.py +0 -0
  211. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/crafter_env_serialization.py +0 -0
  212. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/crafter_evaluation_browser.py +0 -0
  213. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/crafter_quick_evaluation.py +0 -0
  214. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/crafter_trace_evaluation.py +0 -0
  215. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/debug_player_loss.py +0 -0
  216. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/diagnose_service.py +0 -0
  217. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/diagnose_slowness.py +0 -0
  218. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/eval_by_difficulty.py +0 -0
  219. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/eval_example.py +0 -0
  220. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/explore_saved_states.py +0 -0
  221. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/filter_traces_sft.py +0 -0
  222. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/filter_traces_sft_OLD.py +0 -0
  223. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/generate_ft_data_gemini.py +0 -0
  224. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/generate_ft_data_modal.py +0 -0
  225. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/generate_ft_metadata.py +0 -0
  226. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/kick_off_ft_gemini.py +0 -0
  227. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/kick_off_ft_modal.py +0 -0
  228. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/prepare_vertex_ft.py +0 -0
  229. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/profile_env_slowness.py +0 -0
  230. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/replicate_issue.py +0 -0
  231. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/run_and_eval.py +0 -0
  232. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/run_comparison.py +0 -0
  233. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/run_qwen_rollouts.py +0 -0
  234. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/trace_eval_OLD.py +0 -0
  235. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/agent_demos/old/validate_openai_format.py +0 -0
  236. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/config_logging.py +0 -0
  237. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/debug_translation.py +0 -0
  238. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/engine.py +0 -0
  239. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/engine_deterministic_patch.py +0 -0
  240. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/engine_helpers/action_map.py +0 -0
  241. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/engine_helpers/serialization.py +0 -0
  242. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/engine_serialization_patch_v3.py +0 -0
  243. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/environment.py +0 -0
  244. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/taskset.py +0 -0
  245. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/trace_hooks_v3.py +0 -0
  246. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_classic/world_config_patch_simple.py +0 -0
  247. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_custom/__init__.py +0 -0
  248. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_custom/agent_demos/__init__.py +0 -0
  249. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_custom/agent_demos/trace_eval.py +0 -0
  250. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_custom/crafter/__init__.py +0 -0
  251. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_custom/crafter/config.py +0 -0
  252. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_custom/crafter/constants.py +0 -0
  253. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_custom/crafter/engine.py +0 -0
  254. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_custom/crafter/env.py +0 -0
  255. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_custom/crafter/objects.py +0 -0
  256. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_custom/crafter/recorder.py +0 -0
  257. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_custom/crafter/worldgen.py +0 -0
  258. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_custom/dataset_builder.py +0 -0
  259. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_custom/environment.py +0 -0
  260. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_custom/old/analyze_diamond_issue.py +0 -0
  261. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_custom/old/analyze_diamond_spawning.py +0 -0
  262. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_custom/old/compare_worlds.py +0 -0
  263. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_custom/old/dataset_stats.py +0 -0
  264. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_custom/old/diamond_spawning_summary.py +0 -0
  265. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_custom/old/example_dataset_usage.py +0 -0
  266. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/crafter_custom/run_dataset.py +0 -0
  267. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/enron/art_helpers/email_search_tools.py +0 -0
  268. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/enron/art_helpers/local_email_db.py +0 -0
  269. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/enron/art_helpers/types_enron.py +0 -0
  270. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/enron/engine.py +0 -0
  271. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/enron/environment.py +0 -0
  272. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/enron/taskset.py +0 -0
  273. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/enron/units/keyword_stats.py +0 -0
  274. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/minigrid/__init__.py +0 -0
  275. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/minigrid/agent_demos/minigrid_evaluation_framework.py +0 -0
  276. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/minigrid/agent_demos/minigrid_quick_evaluation.py +0 -0
  277. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/minigrid/agent_demos/minigrid_react_agent.py +0 -0
  278. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/minigrid/agent_demos/minigrid_trace_evaluation.py +0 -0
  279. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/minigrid/engine.py +0 -0
  280. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/minigrid/environment.py +0 -0
  281. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/minigrid/environment_mapping.py +0 -0
  282. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/minigrid/puzzle_loader.py +0 -0
  283. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/minigrid/taskset.py +0 -0
  284. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/nethack/__init__.py +0 -0
  285. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/nethack/achievements.py +0 -0
  286. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/nethack/agent_demos/nethack_evaluation_framework.py +0 -0
  287. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/nethack/agent_demos/nethack_quick_evaluation.py +0 -0
  288. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/nethack/agent_demos/nethack_react_agent.py +0 -0
  289. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/nethack/engine.py +0 -0
  290. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/nethack/environment.py +0 -0
  291. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/nethack/helpers/__init__.py +0 -0
  292. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/nethack/helpers/action_mapping.py +0 -0
  293. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/nethack/helpers/nle_wrapper.py +0 -0
  294. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/nethack/helpers/observation_utils.py +0 -0
  295. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/nethack/helpers/recording_wrapper.py +0 -0
  296. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/nethack/helpers/trajectory_recorder.py +0 -0
  297. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/nethack/helpers/visualization/replay_viewer.py +0 -0
  298. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/nethack/helpers/visualization/visualizer.py +0 -0
  299. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/nethack/taskset.py +0 -0
  300. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/red/__init__.py +0 -0
  301. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/red/agent_demos/__init__.py +0 -0
  302. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/red/config_logging.py +0 -0
  303. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/red/engine.py +0 -0
  304. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/red/engine_helpers/__init__.py +0 -0
  305. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/red/engine_helpers/memory_map.py +0 -0
  306. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/red/engine_helpers/reward_components.py +0 -0
  307. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/red/engine_helpers/reward_library/__init__.py +0 -0
  308. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/red/engine_helpers/reward_library/adaptive_rewards.py +0 -0
  309. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/red/engine_helpers/reward_library/battle_rewards.py +0 -0
  310. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/red/engine_helpers/reward_library/composite_rewards.py +0 -0
  311. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/red/engine_helpers/reward_library/economy_rewards.py +0 -0
  312. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/red/engine_helpers/reward_library/efficiency_rewards.py +0 -0
  313. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/red/engine_helpers/reward_library/exploration_rewards.py +0 -0
  314. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/red/engine_helpers/reward_library/novelty_rewards.py +0 -0
  315. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/red/engine_helpers/reward_library/pallet_town_rewards.py +0 -0
  316. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/red/engine_helpers/reward_library/pokemon_rewards.py +0 -0
  317. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/red/engine_helpers/reward_library/social_rewards.py +0 -0
  318. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/red/engine_helpers/reward_library/story_rewards.py +0 -0
  319. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/red/engine_helpers/screen_analysis.py +0 -0
  320. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/red/engine_helpers/state_extraction.py +0 -0
  321. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/red/environment.py +0 -0
  322. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/red/taskset.py +0 -0
  323. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/red/units/__init__.py +0 -0
  324. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/sokoban/__init__.py +0 -0
  325. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/sokoban/agent_demos/sokoban_full_eval.py +0 -0
  326. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/sokoban/engine.py +0 -0
  327. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/sokoban/engine_helpers/__init__.py +0 -0
  328. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/sokoban/engine_helpers/room_utils.py +0 -0
  329. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/sokoban/engine_helpers/vendored/__init__.py +0 -0
  330. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/sokoban/engine_helpers/vendored/envs/__init__.py +0 -0
  331. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/sokoban/engine_helpers/vendored/envs/boxoban_env.py +0 -0
  332. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/sokoban/engine_helpers/vendored/envs/render_utils.py +0 -0
  333. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/sokoban/engine_helpers/vendored/envs/room_utils.py +0 -0
  334. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/sokoban/engine_helpers/vendored/envs/sokoban_env.py +0 -0
  335. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/sokoban/engine_helpers/vendored/envs/sokoban_env_fixed_targets.py +0 -0
  336. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/sokoban/engine_helpers/vendored/envs/sokoban_env_pull.py +0 -0
  337. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/sokoban/engine_helpers/vendored/envs/sokoban_env_two_player.py +0 -0
  338. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/sokoban/engine_helpers/vendored/envs/sokoban_env_variations.py +0 -0
  339. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/sokoban/environment.py +0 -0
  340. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/sokoban/generate_verified_puzzles.py +0 -0
  341. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/sokoban/puzzle_loader.py +0 -0
  342. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/sokoban/taskset.py +0 -0
  343. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/sokoban/units/astar_common.py +0 -0
  344. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/tictactoe/__init__.py +0 -0
  345. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/tictactoe/engine.py +0 -0
  346. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/tictactoe/environment.py +0 -0
  347. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/tictactoe/taskset.py +0 -0
  348. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/verilog/__init__.py +0 -0
  349. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/verilog/engine.py +0 -0
  350. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/verilog/environment.py +0 -0
  351. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/verilog/taskset.py +0 -0
  352. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/wordle/__init__.py +0 -0
  353. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/wordle/engine.py +0 -0
  354. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/wordle/environment.py +0 -0
  355. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/wordle/helpers/generate_instances_wordfreq.py +0 -0
  356. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/examples/wordle/taskset.py +0 -0
  357. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/reproducibility/core.py +0 -0
  358. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/reproducibility/helpers.py +0 -0
  359. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/reproducibility/tree.py +0 -0
  360. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/service/app.py +0 -0
  361. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/service/core_routes.py +0 -0
  362. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/service/external_registry.py +0 -0
  363. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/service/registry.py +0 -0
  364. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/stateful/__init__.py +0 -0
  365. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/stateful/core.py +0 -0
  366. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/stateful/engine.py +0 -0
  367. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/stateful/state.py +0 -0
  368. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/tasks/api.py +0 -0
  369. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/tasks/core.py +0 -0
  370. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/tasks/filters.py +0 -0
  371. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/tasks/utils.py +0 -0
  372. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/v0_observability/history.py +0 -0
  373. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/environments/v0_observability/log.py +0 -0
  374. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/evals/base.py +0 -0
  375. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/experimental/synth_oss.py +0 -0
  376. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/handshake.py +0 -0
  377. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/http.py +0 -0
  378. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/http_client.py +0 -0
  379. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/inference/__init__.py +0 -0
  380. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/inference/client.py +0 -0
  381. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/install_sqld.sh +0 -0
  382. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/jobs/client.py +0 -0
  383. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/__init__.py +0 -0
  384. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/client.py +0 -0
  385. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/config.py +0 -0
  386. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/constants.py +0 -0
  387. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/core.py +0 -0
  388. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/filtering.py +0 -0
  389. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/ft_client.py +0 -0
  390. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/gateway.py +0 -0
  391. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/health.py +0 -0
  392. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/jobs.py +0 -0
  393. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/offline/dpo.py +0 -0
  394. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/offline/providers.py +0 -0
  395. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/offline/sft.py +0 -0
  396. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/offline/shared.py +0 -0
  397. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/online/grpo.py +0 -0
  398. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/online/irft.py +0 -0
  399. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/prompts/banking77_injection_eval.py +0 -0
  400. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/prompts/gepa.py +0 -0
  401. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/prompts/hello_world_in_context_injection_ex.py +0 -0
  402. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/prompts/mipro.py +0 -0
  403. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/prompts/random_search.py +0 -0
  404. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/prompts/run_mipro_banking77.py +0 -0
  405. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/prompts/run_random_search_banking77.py +0 -0
  406. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/rl_client.py +0 -0
  407. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/sse.py +0 -0
  408. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/learning/validators.py +0 -0
  409. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/__init__.py +0 -0
  410. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/caching/__init__.py +0 -0
  411. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/caching/constants.py +0 -0
  412. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/caching/dbs.py +0 -0
  413. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/caching/ephemeral.py +0 -0
  414. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/caching/handler.py +0 -0
  415. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/caching/initialize.py +0 -0
  416. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/caching/persistent.py +0 -0
  417. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/config.py +0 -0
  418. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/constants.py +0 -0
  419. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/core/__init__.py +0 -0
  420. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/core/all.py +0 -0
  421. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/core/exceptions.py +0 -0
  422. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/core/main.py +0 -0
  423. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/core/main_v3.py +0 -0
  424. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/core/synth_models.py +0 -0
  425. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/core/vendor_clients.py +0 -0
  426. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/cost/__init__.py +0 -0
  427. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/cost/monitor.py +0 -0
  428. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/cost/statefulness.py +0 -0
  429. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/injection.py +0 -0
  430. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/overrides.py +0 -0
  431. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/provider_support/__init__.py +0 -0
  432. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/provider_support/anthropic.py +0 -0
  433. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/provider_support/openai.py +0 -0
  434. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/provider_support/suppress_logging.py +0 -0
  435. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/structured_outputs/__init__.py +0 -0
  436. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/structured_outputs/handler.py +0 -0
  437. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/structured_outputs/inject.py +0 -0
  438. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/structured_outputs/rehabilitate.py +0 -0
  439. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/tools/__init__.py +0 -0
  440. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/tools/base.py +0 -0
  441. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/unified_interface.py +0 -0
  442. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/vendors/__init__.py +0 -0
  443. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/vendors/base.py +0 -0
  444. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/vendors/core/__init__.py +0 -0
  445. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/vendors/core/anthropic_api.py +0 -0
  446. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/vendors/core/gemini_api.py +0 -0
  447. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/vendors/core/mistral_api.py +0 -0
  448. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/vendors/core/openai_api.py +0 -0
  449. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/vendors/core/synth_dev_api.py +0 -0
  450. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/vendors/local/__init__.py +0 -0
  451. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/vendors/local/ollama.py +0 -0
  452. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/vendors/openai_standard.py +0 -0
  453. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/vendors/openai_standard_responses.py +0 -0
  454. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/vendors/retries.py +0 -0
  455. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/vendors/supported/__init__.py +0 -0
  456. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/vendors/supported/custom_endpoint.py +0 -0
  457. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/vendors/supported/deepseek.py +0 -0
  458. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/vendors/supported/grok.py +0 -0
  459. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/vendors/supported/groq.py +0 -0
  460. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/vendors/supported/ollama.py +0 -0
  461. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/vendors/supported/openrouter.py +0 -0
  462. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/vendors/supported/together.py +0 -0
  463. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/vendors/synth_client.py +0 -0
  464. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/lm/warmup.py +0 -0
  465. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/rl/__init__.py +0 -0
  466. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/rl/contracts.py +0 -0
  467. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/rl/env_keys.py +0 -0
  468. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/rl/secrets.py +0 -0
  469. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/scripts/verify_rewards.py +0 -0
  470. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/task/__init__.py +0 -0
  471. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/task/auth.py +0 -0
  472. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/task/client.py +0 -0
  473. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/task/contracts.py +0 -0
  474. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/task/datasets.py +0 -0
  475. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/task/errors.py +0 -0
  476. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/task/health.py +0 -0
  477. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/task/json.py +0 -0
  478. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/task/proxy.py +0 -0
  479. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/task/rubrics.py +0 -0
  480. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/task/server.py +0 -0
  481. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/task/tracing_utils.py +0 -0
  482. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/task/validators.py +0 -0
  483. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/task/vendors.py +0 -0
  484. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing/__init__.py +0 -0
  485. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing_v1/__init__.py +0 -0
  486. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing_v3/__init__.py +0 -0
  487. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing_v3/abstractions.py +0 -0
  488. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing_v3/config.py +0 -0
  489. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing_v3/db_config.py +0 -0
  490. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing_v3/decorators.py +0 -0
  491. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing_v3/examples/basic_usage.py +0 -0
  492. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing_v3/hooks.py +0 -0
  493. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing_v3/llm_call_record_helpers.py +0 -0
  494. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing_v3/lm_call_record_abstractions.py +0 -0
  495. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing_v3/migration_helper.py +0 -0
  496. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing_v3/replica_sync.py +0 -0
  497. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing_v3/session_tracer.py +0 -0
  498. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing_v3/storage/__init__.py +0 -0
  499. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing_v3/storage/base.py +0 -0
  500. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing_v3/storage/config.py +0 -0
  501. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing_v3/storage/exceptions.py +0 -0
  502. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing_v3/storage/factory.py +0 -0
  503. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing_v3/storage/types.py +0 -0
  504. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing_v3/storage/utils.py +0 -0
  505. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing_v3/turso/__init__.py +0 -0
  506. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing_v3/turso/daemon.py +0 -0
  507. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing_v3/turso/manager.py +0 -0
  508. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing_v3/turso/models.py +0 -0
  509. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/tracing_v3/utils.py +0 -0
  510. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing/__init__.py +0 -0
  511. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing/abstractions.py +0 -0
  512. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing/base_client.py +0 -0
  513. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing/client_manager.py +0 -0
  514. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing/config.py +0 -0
  515. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing/context.py +0 -0
  516. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing/decorators.py +0 -0
  517. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing/events/__init__.py +0 -0
  518. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing/events/manage.py +0 -0
  519. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing/events/scope.py +0 -0
  520. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing/events/store.py +0 -0
  521. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing/immediate_client.py +0 -0
  522. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing/local.py +0 -0
  523. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing/log_client_base.py +0 -0
  524. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing/retry_queue.py +0 -0
  525. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing/trackers.py +0 -0
  526. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing/upload.py +0 -0
  527. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing/utils.py +0 -0
  528. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing_v1/__init__.py +0 -0
  529. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing_v1/abstractions.py +0 -0
  530. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing_v1/base_client.py +0 -0
  531. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing_v1/client_manager.py +0 -0
  532. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing_v1/config.py +0 -0
  533. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing_v1/context.py +0 -0
  534. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing_v1/decorators.py +0 -0
  535. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing_v1/events/__init__.py +0 -0
  536. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing_v1/events/manage.py +0 -0
  537. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing_v1/events/scope.py +0 -0
  538. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing_v1/events/store.py +0 -0
  539. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing_v1/immediate_client.py +0 -0
  540. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing_v1/local.py +0 -0
  541. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing_v1/log_client_base.py +0 -0
  542. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing_v1/retry_queue.py +0 -0
  543. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing_v1/trackers.py +0 -0
  544. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing_v1/upload.py +0 -0
  545. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/v0/tracing_v1/utils.py +0 -0
  546. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai/zyk/__init__.py +0 -0
  547. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai.egg-info/dependency_links.txt +0 -0
  548. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai.egg-info/entry_points.txt +0 -0
  549. {synth_ai-0.2.9.dev3 → synth_ai-0.2.9.dev4}/synth_ai.egg-info/requires.txt +0 -0
@@ -4,6 +4,11 @@ include synth_ai/install_sqld.sh
4
4
  recursive-include synth_ai *.py
5
5
  # Only include lightweight config/data files from core packages
6
6
  recursive-include synth_ai *.toml
7
+ # Include examples for task app discovery
8
+ recursive-include examples *.py
9
+ recursive-include examples *.toml
10
+ recursive-include examples *.md
11
+ recursive-include examples *.sh
7
12
 
8
13
  # Prune heavy example/demo/test/data trees from the sdist (keep code)
9
14
  prune tests
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: synth-ai
3
- Version: 0.2.9.dev3
3
+ Version: 0.2.9.dev4
4
4
  Summary: RL as a service SDK - Core AI functionality and tracing
5
5
  Author-email: Synth AI <josh@usesynth.ai>
6
6
  License-Expression: MIT
@@ -0,0 +1,17 @@
1
+ #!/bin/bash
2
+
3
+ # Run Crafter agent and analyze semantic map word distribution
4
+ # This script demonstrates semantic analysis of agent observations
5
+ # Output: Markdown tables and JSON data (no plotting dependencies)
6
+
7
+ echo "🔍 Analyzing semantic map words from Crafter agent..."
8
+ echo "Make sure the synth-ai service is running: uvx synth-ai serve"
9
+ echo ""
10
+
11
+ cd synth_ai/environments/examples/crafter_classic/agent_demos/
12
+
13
+ # Run the semantic analysis (markdown output only)
14
+ python analyze_semantic_words_markdown.py --model gemini-1.5-flash --episodes 3 --max-turns 30
15
+
16
+ echo ""
17
+ echo "✅ Analysis complete! Check the generated markdown report and JSON files."
@@ -0,0 +1,21 @@
1
+ from __future__ import annotations
2
+
3
+ from synth_ai.config.base_url import get_backend_from_env, PROD_BASE_URL_DEFAULT
4
+
5
+
6
+ DEFAULT_PROD_BACKEND = f"{PROD_BASE_URL_DEFAULT.rstrip('/')}/api"
7
+
8
+
9
+ def resolve_backend_url() -> str:
10
+ """Resolve backend base URL honoring BACKEND_OVERRIDE and env overrides.
11
+
12
+ Always returns a URL ending with /api.
13
+ """
14
+ base, _ = get_backend_from_env()
15
+ base = base.rstrip("/")
16
+ return base if base.endswith("/api") else f"{base}/api"
17
+
18
+
19
+ if __name__ == "__main__":
20
+ print(resolve_backend_url())
21
+
@@ -0,0 +1,180 @@
1
+ #!/usr/bin/env python3
2
+ """
3
+ Quick local Crafter observation inspector.
4
+
5
+ - Initializes a CrafterClassic env via local service (default http://localhost:8901)
6
+ - Fetches one observation
7
+ - Renders a 7x7 semantic view around the player with best-effort item names
8
+ - Prints status (health/food/energy), inventory, and achievements
9
+
10
+ Run:
11
+ uv run python examples/crafter_debug_render.py --base-url http://localhost:8901 --seed 1
12
+ """
13
+ import argparse
14
+ import math
15
+ import os
16
+ from typing import Any, Dict, List
17
+
18
+ import httpx
19
+
20
+
21
+ def try_import_crafter_mapping():
22
+ try:
23
+ import crafter # type: ignore
24
+
25
+ env = crafter.Env()
26
+ try:
27
+ max_id = (
28
+ max(max(env._world._mat_ids.values()), max(env._sem_view._obj_ids.values())) + 1
29
+ )
30
+ id_to_item = ["void"] * max_id
31
+ for name, ind in env._world._mat_ids.items():
32
+ label = name.__name__ if hasattr(name, "__name__") else str(name)
33
+ id_to_item[ind] = label.lower()
34
+ for name, ind in env._sem_view._obj_ids.items():
35
+ label = name.__name__ if hasattr(name, "__name__") else str(name)
36
+ id_to_item[ind] = label.lower()
37
+ return id_to_item
38
+ finally:
39
+ try:
40
+ env.close()
41
+ except Exception:
42
+ pass
43
+ except Exception:
44
+ return None
45
+
46
+
47
+ def format_semantic_map_view(obs: Dict[str, Any], view_size: int = 7) -> str:
48
+ sem = obs.get("semantic_map") or obs.get("sem_map") or obs.get("map")
49
+ if sem is None:
50
+ return "No semantic map available"
51
+
52
+ # Normalize to 2D grid
53
+ grid: List[List[int]]
54
+ if isinstance(sem, list) and sem and isinstance(sem[0], list):
55
+ grid = sem
56
+ elif isinstance(sem, list):
57
+ try:
58
+ n = int(math.sqrt(len(sem)))
59
+ if n * n != len(sem) or n == 0:
60
+ return "Semantic map format not recognized"
61
+ grid = [sem[i * n : (i + 1) * n] for i in range(n)]
62
+ except Exception:
63
+ return "Semantic map format not recognized"
64
+ else:
65
+ return "Semantic map format not recognized"
66
+
67
+ rows = len(grid)
68
+ cols = len(grid[0]) if rows > 0 else 0
69
+ if rows == 0 or cols == 0:
70
+ return "Empty semantic map"
71
+
72
+ # Resolve item mapping if available
73
+ id_to_item = try_import_crafter_mapping()
74
+
75
+ # Player position if provided; otherwise center
76
+ ppos = obs.get("player_position") or [rows // 2, cols // 2]
77
+ try:
78
+ px = int(ppos[0])
79
+ py = int(ppos[1])
80
+ except Exception:
81
+ px, py = rows // 2, cols // 2
82
+
83
+ half = max(1, view_size // 2)
84
+ lines: List[str] = []
85
+ visible: set[str] = set()
86
+ for dy in range(-half, half + 1):
87
+ row_cells: List[str] = []
88
+ for dx in range(-half, half + 1):
89
+ x = px + dx
90
+ y = py + dy
91
+ if dx == 0 and dy == 0:
92
+ row_cells.append("you")
93
+ elif 0 <= x < rows and 0 <= y < cols:
94
+ try:
95
+ val = int(grid[x][y])
96
+ except Exception:
97
+ val = -1
98
+ if id_to_item and 0 <= val < len(id_to_item):
99
+ name = id_to_item[val]
100
+ else:
101
+ # Fallback: simple mapping for common ids (best-effort)
102
+ name = {
103
+ 0: "grass",
104
+ 1: "stone",
105
+ 2: "stone",
106
+ 3: "tree",
107
+ 4: "coal",
108
+ 5: "iron",
109
+ 6: "water",
110
+ 7: "zombie",
111
+ 14: "wood",
112
+ }.get(val, str(val))
113
+ row_cells.append(name)
114
+ if name not in {"grass", "you", "0"}:
115
+ visible.add(name)
116
+ else:
117
+ row_cells.append("void")
118
+ lines.append(" ".join(row_cells))
119
+
120
+ legend = f"Visible items: {', '.join(sorted(visible))}" if visible else "No notable items visible"
121
+ return "\n".join(lines) + "\n" + legend
122
+
123
+
124
+ async def main():
125
+ parser = argparse.ArgumentParser()
126
+ parser.add_argument("--base-url", default=os.getenv("CRAFTER_BASE_URL", "http://localhost:8901"))
127
+ parser.add_argument("--seed", type=int, default=1)
128
+ args = parser.parse_args()
129
+
130
+ async with httpx.AsyncClient(timeout=30.0) as client:
131
+ init = await client.post(
132
+ f"{args.base_url}/env/CrafterClassic/initialize",
133
+ json={"config": {"difficulty": "easy", "seed": args.seed}},
134
+ )
135
+ init.raise_for_status()
136
+ data = init.json()
137
+ env_id = data["env_id"]
138
+ obs = data["observation"]
139
+
140
+ print("=== INITIAL OBSERVATION ===")
141
+ print(format_semantic_map_view(obs, view_size=7))
142
+ inv = obs.get("inventory", {})
143
+ ach = obs.get("achievements_status", {})
144
+ print("\n=== STATUS ===")
145
+ print(f"Health: {obs.get('health', 10)}/10")
146
+ print(f"Hunger: {obs.get('food', 10)}/10")
147
+ print(f"Energy: {obs.get('energy', 10)}/10")
148
+ inv_items = ", ".join([f"{k}: {v}" for k, v in inv.items() if v]) if isinstance(inv, dict) else str(inv)
149
+ print(f"Inventory: {inv_items if inv_items else 'empty'}")
150
+ if isinstance(ach, dict):
151
+ unlocked = sum(1 for v in ach.values() if v)
152
+ print(f"Achievements: {unlocked}/{len(ach)} unlocked")
153
+
154
+ # Take one step right to get a new obs
155
+ step = await client.post(
156
+ f"{args.base_url}/env/CrafterClassic/step",
157
+ json={
158
+ "env_id": env_id,
159
+ "action": {"tool_calls": [{"tool": "interact", "args": {"action": 2}}]},
160
+ },
161
+ )
162
+ step.raise_for_status()
163
+ sdata = step.json()
164
+ sobs = sdata["observation"]
165
+ print("\n=== NEXT OBSERVATION (after move_right) ===")
166
+ print(format_semantic_map_view(sobs, view_size=7))
167
+
168
+ # Cleanup
169
+ try:
170
+ await client.post(f"{args.base_url}/env/CrafterClassic/terminate", json={"env_id": env_id})
171
+ except Exception:
172
+ pass
173
+
174
+
175
+ if __name__ == "__main__":
176
+ import asyncio
177
+
178
+ asyncio.run(main())
179
+
180
+
@@ -0,0 +1,98 @@
1
+ # Crafter Model Comparison Cookbook
2
+
3
+ This cookbook demonstrates how to run parallel experiments comparing different language models on the Crafter environment, with robust timeout handling and performance analysis.
4
+
5
+ ## Overview
6
+
7
+ This cookbook runs episodes of the Crafter game environment with different language models (e.g., gpt-5-nano and Qwen/Qwen3-32B-Instruct) in parallel, collecting performance metrics and analyzing the results.
8
+
9
+ ## Features
10
+
11
+ - **Parallel episode execution**: Runs multiple episodes simultaneously for faster experimentation
12
+ - **Timeout handling**:
13
+ - Turn-level timeout (20s per LLM call)
14
+ - Episode-level timeout (180s total)
15
+ - Action execution timeout (5s)
16
+ - **Progress tracking**: Real-time progress bars showing steps across all episodes
17
+ - **Performance comparison**: Analyzes achievements, invalid action rates, and model usage statistics
18
+ - **Deterministic seeding**: Uses consecutive seeds for reproducible experiments
19
+
20
+ ## Prerequisites
21
+
22
+ 1. Ensure the Crafter environment service is running:
23
+ ```bash
24
+ cd synth-ai/
25
+ bash serve.sh
26
+ ```
27
+
28
+ 2. Set up your API keys (Synth/OpenAI or provider as needed):
29
+ ```bash
30
+ export OPENAI_API_KEY="your-api-key"
31
+ ```
32
+
33
+ ## Usage
34
+
35
+ Run the comparison script (gpt-5-nano vs Qwen/Qwen3-32B-Instruct):
36
+ ```bash
37
+ uvpm examples.evals.compare_models --episodes 5 --max-turns 100 --difficulty easy \
38
+ --models "gpt-5-nano" "Qwen/Qwen3-32B-Instruct"
39
+ ```
40
+
41
+ Or with custom parameters:
42
+ ```bash
43
+ python compare_models.py \
44
+ --episodes 10 \
45
+ --max-turns 100 \
46
+ --difficulty easy \
47
+ --models "gpt-5-nano" "Qwen/Qwen3-32B-Instruct" \
48
+ --base-seed 1000 \
49
+ --turn-timeout 30.0 \
50
+ --episode-timeout 300.0
51
+ ```
52
+
53
+ ## Parameters
54
+
55
+ - `--episodes`: Number of episodes per model (default: 5)
56
+ - `--max-turns`: Maximum turns per episode (default: 50)
57
+ - `--difficulty`: Game difficulty - easy, medium, hard (default: easy)
58
+ - `--models`: Models to test (default: gpt-4o-mini gpt-4.1-mini)
59
+ - `--base-seed`: Starting seed for episodes (default: 1000)
60
+ - `--turn-timeout`: Timeout per turn in seconds (default: 20.0)
61
+ - `--episode-timeout`: Total timeout per episode in seconds (default: 180.0)
62
+
63
+ ## Output
64
+
65
+ The script produces:
66
+ 1. Real-time progress bars showing episode execution
67
+ 2. Performance summary table comparing models
68
+ 3. Achievement frequency analysis
69
+ 4. Model usage statistics (filtered to current experiment only)
70
+ 5. JSON file with detailed results
71
+
72
+ ## Example Output (abridged)
73
+
74
+ ```
75
+ 📊 Analysis Results:
76
+ ================================================================================
77
+
78
+ 📈 Model Performance Summary:
79
+ Model Avg Achievements Max Achievements Invalid Rate Success Rate
80
+ --------------------------------------------------------------------------------------
81
+ gpt-5-nano 1.60 ± 1.10 4 1.20% 100.00%
82
+ Qwen/Qwen3-32B-Inst 1.40 ± 1.05 3 1.80% 100.00%
83
+
84
+ 🏆 Achievement Frequencies:
85
+ Achievement gpt-5-na qwen3-32
86
+ -----------------------------------------------
87
+ collect_drink 1/5 ( 20%) 3/5 ( 60%)
88
+ collect_sapling 2/5 ( 40%) 2/5 ( 40%)
89
+ collect_wood 4/5 ( 80%) 2/5 ( 40%)
90
+ ```
91
+
92
+ ## Implementation Details
93
+
94
+ The comparison uses:
95
+ - Async/await for parallel episode execution
96
+ - Session-based tracing with v3 architecture
97
+ - Structured output tools for consistent LLM interactions
98
+ - SQLite database for tracking model usage and costs
@@ -0,0 +1,6 @@
1
+ """
2
+ Crafter Model Comparison Cookbook
3
+
4
+ A self-contained example for comparing language model performance on the Crafter environment
5
+ with parallel execution and robust timeout handling.
6
+ """