synth-ai 0.2.8.dev2__py3-none-any.whl → 0.4.3__py3-none-any.whl

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.
Files changed (740) hide show
  1. synth_ai/__init__.py +44 -24
  2. synth_ai/__main__.py +30 -3
  3. synth_ai/cli/__init__.py +103 -48
  4. synth_ai/cli/__main__.py +42 -0
  5. synth_ai/cli/_internal/__init__.py +5 -0
  6. synth_ai/cli/_internal/modal_wrapper.py +31 -0
  7. synth_ai/cli/_internal/storage.py +20 -0
  8. synth_ai/cli/_internal/typer_patch.py +47 -0
  9. synth_ai/cli/_internal/validate_task_app.py +29 -0
  10. synth_ai/cli/agents/__init__.py +17 -0
  11. synth_ai/cli/agents/claude.py +77 -0
  12. synth_ai/cli/agents/codex.py +265 -0
  13. synth_ai/cli/agents/opencode.py +253 -0
  14. synth_ai/cli/commands/__init__.py +18 -0
  15. synth_ai/cli/commands/artifacts/__init__.py +13 -0
  16. synth_ai/cli/commands/artifacts/client.py +119 -0
  17. synth_ai/cli/commands/artifacts/config.py +57 -0
  18. synth_ai/cli/commands/artifacts/core.py +24 -0
  19. synth_ai/cli/commands/artifacts/download.py +188 -0
  20. synth_ai/cli/commands/artifacts/export.py +186 -0
  21. synth_ai/cli/commands/artifacts/list.py +156 -0
  22. synth_ai/cli/commands/artifacts/parsing.py +250 -0
  23. synth_ai/cli/commands/artifacts/show.py +336 -0
  24. synth_ai/cli/commands/demo/__init__.py +3 -0
  25. synth_ai/cli/commands/demo/core.py +153 -0
  26. synth_ai/cli/commands/eval/__init__.py +10 -0
  27. synth_ai/cli/commands/eval/config.py +338 -0
  28. synth_ai/cli/commands/eval/core.py +256 -0
  29. synth_ai/cli/commands/eval/runner.py +704 -0
  30. synth_ai/cli/commands/eval/validation.py +60 -0
  31. synth_ai/cli/commands/filter/__init__.py +12 -0
  32. synth_ai/cli/commands/filter/core.py +424 -0
  33. synth_ai/cli/commands/filter/errors.py +55 -0
  34. synth_ai/cli/commands/filter/validation.py +77 -0
  35. synth_ai/cli/commands/help/__init__.py +185 -0
  36. synth_ai/cli/commands/help/core.py +72 -0
  37. synth_ai/cli/commands/scan/__init__.py +19 -0
  38. synth_ai/cli/commands/scan/cloudflare_scanner.py +403 -0
  39. synth_ai/cli/commands/scan/core.py +344 -0
  40. synth_ai/cli/commands/scan/health_checker.py +242 -0
  41. synth_ai/cli/commands/scan/local_scanner.py +278 -0
  42. synth_ai/cli/commands/scan/models.py +83 -0
  43. synth_ai/cli/commands/smoke/__init__.py +7 -0
  44. synth_ai/cli/commands/smoke/core.py +1428 -0
  45. synth_ai/cli/commands/status/__init__.py +3 -0
  46. synth_ai/cli/commands/status/client.py +91 -0
  47. synth_ai/cli/commands/status/config.py +12 -0
  48. synth_ai/cli/commands/status/errors.py +11 -0
  49. synth_ai/cli/commands/status/subcommands/__init__.py +3 -0
  50. synth_ai/cli/commands/status/subcommands/config.py +13 -0
  51. synth_ai/cli/commands/status/subcommands/files.py +34 -0
  52. synth_ai/cli/commands/status/subcommands/jobs.py +51 -0
  53. synth_ai/cli/commands/status/subcommands/models.py +35 -0
  54. synth_ai/cli/commands/status/subcommands/runs.py +34 -0
  55. synth_ai/cli/commands/status/subcommands/session.py +77 -0
  56. synth_ai/cli/commands/status/subcommands/summary.py +39 -0
  57. synth_ai/cli/commands/status/subcommands/utils.py +41 -0
  58. synth_ai/cli/commands/status/utils.py +23 -0
  59. synth_ai/cli/commands/train/__init__.py +53 -0
  60. synth_ai/cli/commands/train/core.py +22 -0
  61. synth_ai/cli/commands/train/errors.py +117 -0
  62. synth_ai/cli/commands/train/judge_schemas.py +201 -0
  63. synth_ai/cli/commands/train/judge_validation.py +305 -0
  64. synth_ai/cli/commands/train/prompt_learning_validation.py +633 -0
  65. synth_ai/cli/commands/train/validation.py +392 -0
  66. synth_ai/cli/demo_apps/__init__.py +10 -0
  67. synth_ai/cli/demo_apps/core/__init__.py +28 -0
  68. synth_ai/{demos → cli/demo_apps}/core/cli.py +783 -441
  69. synth_ai/cli/demo_apps/crafter/__init__.py +1 -0
  70. synth_ai/cli/demo_apps/crafter/crafter_fft_4b.toml +55 -0
  71. synth_ai/cli/demo_apps/crafter/grpo_crafter_task_app.py +186 -0
  72. synth_ai/cli/demo_apps/crafter/rl_from_base_qwen4b.toml +74 -0
  73. synth_ai/cli/demo_apps/demo_registry.py +176 -0
  74. synth_ai/cli/demo_apps/demo_task_apps/__init__.py +7 -0
  75. synth_ai/{demos → cli/demo_apps}/demo_task_apps/core.py +75 -37
  76. synth_ai/cli/demo_apps/demo_task_apps/crafter/__init__.py +1 -0
  77. synth_ai/cli/demo_apps/demo_task_apps/crafter/configs/crafter_fft_4b.toml +53 -0
  78. synth_ai/cli/demo_apps/demo_task_apps/crafter/configs/rl_from_base_qwen4b.toml +73 -0
  79. synth_ai/cli/demo_apps/demo_task_apps/crafter/grpo_crafter_task_app.py +185 -0
  80. synth_ai/{demos → cli/demo_apps}/demo_task_apps/math/_common.py +1 -2
  81. synth_ai/{demos → cli/demo_apps}/demo_task_apps/math/app.py +2 -1
  82. synth_ai/cli/demo_apps/demo_task_apps/math/config.toml +73 -0
  83. synth_ai/{demos → cli/demo_apps}/demo_task_apps/math/deploy_modal.py +3 -6
  84. synth_ai/cli/demo_apps/demo_task_apps/math/modal_task_app.py +738 -0
  85. synth_ai/cli/demo_apps/demo_task_apps/math/task_app_entry.py +39 -0
  86. synth_ai/cli/demo_apps/math/__init__.py +1 -0
  87. synth_ai/cli/demo_apps/math/_common.py +16 -0
  88. synth_ai/cli/demo_apps/math/app.py +38 -0
  89. synth_ai/cli/demo_apps/math/config.toml +75 -0
  90. synth_ai/cli/demo_apps/math/deploy_modal.py +54 -0
  91. synth_ai/cli/demo_apps/math/modal_task_app.py +698 -0
  92. synth_ai/cli/demo_apps/math/task_app_entry.py +53 -0
  93. synth_ai/cli/demo_apps/mipro/main.py +271 -0
  94. synth_ai/cli/demo_apps/mipro/task_app.py +922 -0
  95. synth_ai/cli/demo_apps/mipro/train_cfg.toml +92 -0
  96. synth_ai/cli/demos/__init__.py +12 -0
  97. synth_ai/cli/demos/demo.py +32 -0
  98. synth_ai/cli/demos/rl_demo.py +254 -0
  99. synth_ai/cli/deploy.py +216 -0
  100. synth_ai/cli/infra/__init__.py +14 -0
  101. synth_ai/cli/{balance.py → infra/balance.py} +16 -4
  102. synth_ai/cli/infra/mcp.py +35 -0
  103. synth_ai/cli/infra/modal_app.py +36 -0
  104. synth_ai/cli/infra/setup.py +69 -0
  105. synth_ai/cli/infra/status.py +16 -0
  106. synth_ai/cli/infra/turso.py +77 -0
  107. synth_ai/cli/lib/__init__.py +10 -0
  108. synth_ai/cli/lib/agents.py +76 -0
  109. synth_ai/cli/lib/apps/modal_app.py +101 -0
  110. synth_ai/cli/lib/apps/task_app.py +642 -0
  111. synth_ai/cli/lib/bin.py +39 -0
  112. synth_ai/cli/lib/env.py +375 -0
  113. synth_ai/cli/lib/errors.py +85 -0
  114. synth_ai/cli/lib/modal.py +315 -0
  115. synth_ai/cli/lib/plotting.py +126 -0
  116. synth_ai/cli/lib/prompt_args.py +39 -0
  117. synth_ai/cli/lib/prompts.py +284 -0
  118. synth_ai/cli/lib/sqld.py +122 -0
  119. synth_ai/cli/lib/task_app_discovery.py +884 -0
  120. synth_ai/cli/lib/task_app_env.py +295 -0
  121. synth_ai/cli/lib/train_cfgs.py +300 -0
  122. synth_ai/cli/lib/tunnel_records.py +207 -0
  123. synth_ai/cli/local/__init__.py +14 -0
  124. synth_ai/cli/local/experiment_queue/__init__.py +72 -0
  125. synth_ai/cli/local/experiment_queue/api_schemas.py +221 -0
  126. synth_ai/cli/local/experiment_queue/celery_app.py +208 -0
  127. synth_ai/cli/local/experiment_queue/config.py +128 -0
  128. synth_ai/cli/local/experiment_queue/config_utils.py +272 -0
  129. synth_ai/cli/local/experiment_queue/database.py +175 -0
  130. synth_ai/cli/local/experiment_queue/dispatcher.py +119 -0
  131. synth_ai/cli/local/experiment_queue/models.py +231 -0
  132. synth_ai/cli/local/experiment_queue/progress_info.py +160 -0
  133. synth_ai/cli/local/experiment_queue/results.py +373 -0
  134. synth_ai/cli/local/experiment_queue/schemas.py +131 -0
  135. synth_ai/cli/local/experiment_queue/service.py +344 -0
  136. synth_ai/cli/local/experiment_queue/status.py +372 -0
  137. synth_ai/cli/local/experiment_queue/status_tracker.py +360 -0
  138. synth_ai/cli/local/experiment_queue/tasks.py +1984 -0
  139. synth_ai/cli/local/experiment_queue/trace_storage.py +65 -0
  140. synth_ai/cli/local/experiment_queue/validation.py +157 -0
  141. synth_ai/cli/local/session/__init__.py +92 -0
  142. synth_ai/cli/local/session/client.py +383 -0
  143. synth_ai/cli/local/session/constants.py +63 -0
  144. synth_ai/cli/local/session/exceptions.py +105 -0
  145. synth_ai/cli/local/session/manager.py +139 -0
  146. synth_ai/cli/local/session/models.py +89 -0
  147. synth_ai/cli/local/session/query.py +110 -0
  148. synth_ai/cli/root.py +150 -108
  149. synth_ai/cli/task_apps/__init__.py +37 -0
  150. synth_ai/cli/task_apps/commands.py +3145 -0
  151. synth_ai/cli/task_apps/deploy.py +7 -0
  152. synth_ai/cli/task_apps/list.py +26 -0
  153. synth_ai/cli/task_apps/main.py +36 -0
  154. synth_ai/cli/task_apps/modal_serve.py +11 -0
  155. synth_ai/cli/task_apps/serve.py +11 -0
  156. synth_ai/cli/training/__init__.py +8 -0
  157. synth_ai/cli/training/train.py +5 -0
  158. synth_ai/cli/training/train_cfg.py +34 -0
  159. synth_ai/cli/{watch.py → training/watch.py} +13 -18
  160. synth_ai/cli/turso.py +52 -0
  161. synth_ai/cli/utils/__init__.py +8 -0
  162. synth_ai/cli/utils/experiments.py +235 -0
  163. synth_ai/cli/utils/queue.py +504 -0
  164. synth_ai/cli/{recent.py → utils/recent.py} +13 -7
  165. synth_ai/cli/{traces.py → utils/traces.py} +9 -5
  166. synth_ai/contracts/__init__.py +67 -0
  167. synth_ai/core/__init__.py +100 -0
  168. synth_ai/core/_utils/__init__.py +54 -0
  169. synth_ai/core/_utils/base_url.py +10 -0
  170. synth_ai/core/_utils/http.py +10 -0
  171. synth_ai/core/_utils/prompts.py +14 -0
  172. synth_ai/core/_utils/task_app_state.py +12 -0
  173. synth_ai/core/_utils/user_config.py +10 -0
  174. synth_ai/core/apps/common.py +116 -0
  175. synth_ai/core/auth.py +95 -0
  176. synth_ai/core/cfgs.py +240 -0
  177. synth_ai/core/config/__init__.py +16 -0
  178. synth_ai/core/config/base.py +168 -0
  179. synth_ai/core/config/resolver.py +89 -0
  180. synth_ai/core/env.py +231 -0
  181. synth_ai/core/errors.py +126 -0
  182. synth_ai/core/http.py +230 -0
  183. synth_ai/core/integrations/__init__.py +11 -0
  184. synth_ai/core/integrations/cloudflare.py +1710 -0
  185. synth_ai/core/integrations/mcp/__init__.py +6 -0
  186. synth_ai/core/integrations/mcp/__main__.py +8 -0
  187. synth_ai/core/integrations/mcp/claude.py +36 -0
  188. synth_ai/core/integrations/mcp/main.py +254 -0
  189. synth_ai/core/integrations/mcp/setup.py +100 -0
  190. synth_ai/core/integrations/modal.py +277 -0
  191. synth_ai/core/json.py +72 -0
  192. synth_ai/core/log_filter.py +99 -0
  193. synth_ai/core/logging.py +82 -0
  194. synth_ai/core/paths.py +107 -0
  195. synth_ai/core/pricing.py +109 -0
  196. synth_ai/core/process.py +233 -0
  197. synth_ai/core/ssl.py +25 -0
  198. synth_ai/core/storage/__init__.py +71 -0
  199. synth_ai/core/task_app_state.py +318 -0
  200. synth_ai/core/telemetry.py +282 -0
  201. synth_ai/{tracing_v3 → core/tracing_v3}/__init__.py +5 -1
  202. synth_ai/{tracing_v3 → core/tracing_v3}/abstractions.py +21 -4
  203. synth_ai/core/tracing_v3/config.py +229 -0
  204. synth_ai/core/tracing_v3/constants.py +21 -0
  205. synth_ai/{tracing_v3 → core/tracing_v3}/db_config.py +42 -29
  206. synth_ai/{tracing_v3 → core/tracing_v3}/decorators.py +80 -45
  207. synth_ai/{tracing_v3 → core/tracing_v3}/examples/basic_usage.py +15 -9
  208. synth_ai/{tracing_v3 → core/tracing_v3}/hooks.py +6 -4
  209. synth_ai/{tracing_v3 → core/tracing_v3}/llm_call_record_helpers.py +161 -61
  210. synth_ai/{tracing_v3 → core/tracing_v3}/migration_helper.py +1 -2
  211. synth_ai/{tracing_v3 → core/tracing_v3}/replica_sync.py +12 -7
  212. synth_ai/core/tracing_v3/serialization.py +130 -0
  213. synth_ai/{tracing_v3 → core/tracing_v3}/session_tracer.py +88 -21
  214. synth_ai/{tracing_v3 → core/tracing_v3}/storage/base.py +99 -12
  215. synth_ai/core/tracing_v3/storage/config.py +109 -0
  216. synth_ai/{tracing_v3 → core/tracing_v3}/storage/factory.py +11 -9
  217. synth_ai/{tracing_v3 → core/tracing_v3}/storage/utils.py +15 -11
  218. synth_ai/core/tracing_v3/trace_utils.py +326 -0
  219. synth_ai/core/tracing_v3/turso/__init__.py +12 -0
  220. synth_ai/core/tracing_v3/turso/daemon.py +278 -0
  221. synth_ai/{tracing_v3 → core/tracing_v3}/turso/models.py +7 -3
  222. synth_ai/core/tracing_v3/turso/native_manager.py +1385 -0
  223. synth_ai/{tracing_v3 → core/tracing_v3}/utils.py +5 -4
  224. synth_ai/core/urls.py +18 -0
  225. synth_ai/core/user_config.py +137 -0
  226. synth_ai/core/uvicorn.py +222 -0
  227. synth_ai/data/__init__.py +83 -0
  228. synth_ai/data/enums.py +123 -0
  229. synth_ai/data/rewards.py +152 -0
  230. synth_ai/data/traces.py +35 -0
  231. synth_ai/products/__init__.py +6 -0
  232. synth_ai/products/graph_evolve/__init__.py +46 -0
  233. synth_ai/products/graph_evolve/client.py +226 -0
  234. synth_ai/products/graph_evolve/config.py +591 -0
  235. synth_ai/products/graph_evolve/converters/__init__.py +42 -0
  236. synth_ai/products/graph_evolve/converters/openai_sft.py +484 -0
  237. synth_ai/products/graph_evolve/examples/hotpotqa/config.toml +109 -0
  238. synth_ai/products/graph_evolve/run.py +222 -0
  239. synth_ai/products/graph_gepa/__init__.py +23 -0
  240. synth_ai/products/graph_gepa/converters/__init__.py +19 -0
  241. synth_ai/products/graph_gepa/converters/openai_sft.py +29 -0
  242. synth_ai/sdk/__init__.py +123 -0
  243. synth_ai/sdk/api/__init__.py +1 -0
  244. synth_ai/sdk/api/models/supported.py +514 -0
  245. synth_ai/sdk/api/research_agent/__init__.py +296 -0
  246. synth_ai/sdk/api/train/__init__.py +85 -0
  247. synth_ai/sdk/api/train/builders.py +895 -0
  248. synth_ai/sdk/api/train/cli.py +2199 -0
  249. synth_ai/sdk/api/train/config_finder.py +267 -0
  250. synth_ai/sdk/api/train/configs/__init__.py +65 -0
  251. synth_ai/sdk/api/train/configs/prompt_learning.py +1706 -0
  252. synth_ai/sdk/api/train/configs/rl.py +187 -0
  253. synth_ai/sdk/api/train/configs/sft.py +99 -0
  254. synth_ai/sdk/api/train/configs/shared.py +81 -0
  255. synth_ai/sdk/api/train/context_learning.py +312 -0
  256. synth_ai/sdk/api/train/env_resolver.py +418 -0
  257. synth_ai/sdk/api/train/graph_validators.py +216 -0
  258. synth_ai/sdk/api/train/graphgen.py +984 -0
  259. synth_ai/sdk/api/train/graphgen_models.py +823 -0
  260. synth_ai/sdk/api/train/graphgen_validators.py +109 -0
  261. synth_ai/sdk/api/train/local_api.py +10 -0
  262. synth_ai/sdk/api/train/pollers.py +124 -0
  263. synth_ai/sdk/api/train/progress/__init__.py +97 -0
  264. synth_ai/sdk/api/train/progress/dataclasses.py +569 -0
  265. synth_ai/sdk/api/train/progress/events.py +326 -0
  266. synth_ai/sdk/api/train/progress/results.py +428 -0
  267. synth_ai/sdk/api/train/progress/tracker.py +641 -0
  268. synth_ai/sdk/api/train/prompt_learning.py +469 -0
  269. synth_ai/sdk/api/train/rl.py +441 -0
  270. synth_ai/sdk/api/train/sft.py +396 -0
  271. synth_ai/sdk/api/train/summary.py +522 -0
  272. synth_ai/sdk/api/train/supported_algos.py +147 -0
  273. synth_ai/sdk/api/train/task_app.py +351 -0
  274. synth_ai/sdk/api/train/utils.py +279 -0
  275. synth_ai/sdk/api/train/validators.py +2424 -0
  276. synth_ai/sdk/graphs/__init__.py +15 -0
  277. synth_ai/sdk/graphs/completions.py +570 -0
  278. synth_ai/{inference → sdk/inference}/__init__.py +0 -1
  279. synth_ai/sdk/inference/client.py +128 -0
  280. synth_ai/sdk/jobs/__init__.py +16 -0
  281. synth_ai/sdk/jobs/client.py +371 -0
  282. synth_ai/sdk/judging/__init__.py +14 -0
  283. synth_ai/sdk/judging/base.py +24 -0
  284. synth_ai/sdk/judging/client.py +40 -0
  285. synth_ai/sdk/judging/schemas.py +222 -0
  286. synth_ai/sdk/judging/types.py +42 -0
  287. synth_ai/sdk/learning/__init__.py +99 -0
  288. synth_ai/sdk/learning/algorithms.py +14 -0
  289. synth_ai/{learning → sdk/learning}/client.py +121 -30
  290. synth_ai/sdk/learning/config.py +5 -0
  291. synth_ai/{learning → sdk/learning}/constants.py +0 -2
  292. synth_ai/sdk/learning/context_learning_client.py +531 -0
  293. synth_ai/sdk/learning/context_learning_types.py +292 -0
  294. synth_ai/sdk/learning/ft_client.py +7 -0
  295. synth_ai/{learning → sdk/learning}/health.py +15 -9
  296. synth_ai/{learning → sdk/learning}/jobs.py +44 -47
  297. synth_ai/sdk/learning/prompt_extraction.py +334 -0
  298. synth_ai/sdk/learning/prompt_learning_client.py +455 -0
  299. synth_ai/sdk/learning/prompt_learning_types.py +186 -0
  300. synth_ai/{rl → sdk/learning/rl}/__init__.py +13 -8
  301. synth_ai/{learning/rl_client.py → sdk/learning/rl/client.py} +89 -77
  302. synth_ai/sdk/learning/rl/config.py +31 -0
  303. synth_ai/{rl → sdk/learning/rl}/contracts.py +5 -14
  304. synth_ai/{rl → sdk/learning/rl}/env_keys.py +45 -16
  305. synth_ai/sdk/learning/rl/secrets.py +13 -0
  306. synth_ai/sdk/learning/rl_client.py +5 -0
  307. synth_ai/sdk/learning/sft/__init__.py +29 -0
  308. synth_ai/sdk/learning/sft/client.py +95 -0
  309. synth_ai/sdk/learning/sft/config.py +270 -0
  310. synth_ai/sdk/learning/sft/data.py +698 -0
  311. synth_ai/sdk/learning/sse.py +57 -0
  312. synth_ai/sdk/learning/validators.py +52 -0
  313. synth_ai/sdk/localapi/__init__.py +40 -0
  314. synth_ai/sdk/localapi/apps/__init__.py +28 -0
  315. synth_ai/sdk/localapi/client.py +10 -0
  316. synth_ai/sdk/localapi/contracts.py +10 -0
  317. synth_ai/sdk/localapi/helpers.py +519 -0
  318. synth_ai/sdk/localapi/rollouts.py +87 -0
  319. synth_ai/sdk/localapi/server.py +29 -0
  320. synth_ai/sdk/localapi/template.py +70 -0
  321. synth_ai/sdk/streaming/__init__.py +35 -0
  322. synth_ai/sdk/streaming/config.py +94 -0
  323. synth_ai/sdk/streaming/handlers.py +1997 -0
  324. synth_ai/sdk/streaming/streamer.py +713 -0
  325. synth_ai/sdk/streaming/types.py +112 -0
  326. synth_ai/sdk/task/__init__.py +164 -0
  327. synth_ai/sdk/task/apps/__init__.py +169 -0
  328. synth_ai/sdk/task/auth.py +165 -0
  329. synth_ai/sdk/task/client.py +175 -0
  330. synth_ai/sdk/task/config.py +257 -0
  331. synth_ai/sdk/task/contracts.py +219 -0
  332. synth_ai/sdk/task/datasets.py +108 -0
  333. synth_ai/sdk/task/errors.py +50 -0
  334. synth_ai/sdk/task/health.py +34 -0
  335. synth_ai/sdk/task/in_process.py +1190 -0
  336. synth_ai/sdk/task/in_process_runner.py +314 -0
  337. synth_ai/sdk/task/inference_api.py +299 -0
  338. synth_ai/sdk/task/json.py +111 -0
  339. synth_ai/sdk/task/proxy.py +287 -0
  340. synth_ai/sdk/task/rubrics/__init__.py +55 -0
  341. synth_ai/sdk/task/rubrics/loaders.py +156 -0
  342. synth_ai/sdk/task/rubrics/models.py +57 -0
  343. synth_ai/sdk/task/rubrics/scoring.py +116 -0
  344. synth_ai/sdk/task/rubrics/strict.py +149 -0
  345. synth_ai/sdk/task/rubrics.py +219 -0
  346. synth_ai/sdk/task/server.py +631 -0
  347. synth_ai/sdk/task/trace_correlation_helpers.py +539 -0
  348. synth_ai/sdk/task/tracing_utils.py +95 -0
  349. synth_ai/sdk/task/validators.py +441 -0
  350. synth_ai/sdk/task/vendors.py +59 -0
  351. synth_ai/sdk/training/__init__.py +102 -0
  352. synth_ai/sdk/tunnels/__init__.py +83 -0
  353. synth_ai/sdk/tunnels/cleanup.py +83 -0
  354. synth_ai/sdk/tunnels/ports.py +120 -0
  355. synth_ai/utils/__init__.py +213 -0
  356. synth_ai-0.4.3.dist-info/METADATA +262 -0
  357. synth_ai-0.4.3.dist-info/RECORD +370 -0
  358. {synth_ai-0.2.8.dev2.dist-info → synth_ai-0.4.3.dist-info}/entry_points.txt +0 -1
  359. synth_ai/cli/calc.py +0 -69
  360. synth_ai/cli/demo.py +0 -144
  361. synth_ai/cli/legacy_root_backup.py +0 -470
  362. synth_ai/cli/man.py +0 -106
  363. synth_ai/cli/rl_demo.py +0 -202
  364. synth_ai/cli/status.py +0 -133
  365. synth_ai/config/base_url.py +0 -107
  366. synth_ai/core/experiment.py +0 -15
  367. synth_ai/core/system.py +0 -15
  368. synth_ai/demos/core/__init__.py +0 -1
  369. synth_ai/demos/demo_task_apps/__init__.py +0 -1
  370. synth_ai/demos/demo_task_apps/math/config.toml +0 -129
  371. synth_ai/demos/demo_task_apps/math/deploy_task_app.sh +0 -22
  372. synth_ai/demos/demo_task_apps/math/modal_task_app.py +0 -415
  373. synth_ai/environments/__init__.py +0 -31
  374. synth_ai/environments/environment/__init__.py +0 -1
  375. synth_ai/environments/environment/artifacts/__init__.py +0 -1
  376. synth_ai/environments/environment/artifacts/base.py +0 -52
  377. synth_ai/environments/environment/core.py +0 -67
  378. synth_ai/environments/environment/db/__init__.py +0 -1
  379. synth_ai/environments/environment/db/sqlite.py +0 -45
  380. synth_ai/environments/environment/registry.py +0 -233
  381. synth_ai/environments/environment/resources/sqlite.py +0 -45
  382. synth_ai/environments/environment/results.py +0 -1
  383. synth_ai/environments/environment/rewards/__init__.py +0 -1
  384. synth_ai/environments/environment/rewards/core.py +0 -29
  385. synth_ai/environments/environment/shared_engine.py +0 -26
  386. synth_ai/environments/environment/tools/__init__.py +0 -200
  387. synth_ai/environments/examples/__init__.py +0 -1
  388. synth_ai/environments/examples/bandit/__init__.py +0 -33
  389. synth_ai/environments/examples/bandit/engine.py +0 -294
  390. synth_ai/environments/examples/bandit/environment.py +0 -194
  391. synth_ai/environments/examples/bandit/taskset.py +0 -200
  392. synth_ai/environments/examples/crafter_classic/__init__.py +0 -8
  393. synth_ai/environments/examples/crafter_classic/agent_demos/analyze_semantic_words_markdown.py +0 -250
  394. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_comprehensive_evaluation.py +0 -59
  395. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_evaluation_browser.py +0 -152
  396. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_evaluation_config.toml +0 -24
  397. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_evaluation_framework.py +0 -1194
  398. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/crafter_synth_config.toml +0 -56
  399. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/filter_config_modal.toml +0 -32
  400. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/filter_traces_sft_turso.py +0 -738
  401. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/kick_off_ft_modal.py +0 -384
  402. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/old/analyze_action_results.py +0 -53
  403. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/old/analyze_agent_actions.py +0 -178
  404. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/old/analyze_latest_run.py +0 -222
  405. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/old/analyze_lm_traces.py +0 -183
  406. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/old/analyze_no_rewards.py +0 -210
  407. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/old/analyze_trace_issue.py +0 -206
  408. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/old/check_db_schema.py +0 -49
  409. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/old/check_latest_results.py +0 -64
  410. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/old/debug_agent_responses.py +0 -88
  411. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_modal_ft/old/quick_trace_check.py +0 -77
  412. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/compare_experiments.py +0 -324
  413. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/filter_traces_sft_turso.py +0 -580
  414. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/kick_off_ft_oai.py +0 -362
  415. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/multi_model_config.toml +0 -49
  416. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/old/analyze_enhanced_hooks.py +0 -332
  417. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/old/analyze_hook_events.py +0 -97
  418. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/old/analyze_hook_results.py +0 -217
  419. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/old/check_hook_storage.py +0 -87
  420. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/old/check_seeds.py +0 -88
  421. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/old/compare_seed_performance.py +0 -195
  422. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/old/custom_eval_pipelines.py +0 -400
  423. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/old/plot_hook_frequency.py +0 -195
  424. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/old/seed_analysis_summary.py +0 -56
  425. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_openai_ft/run_rollouts_for_models_and_compare_v3.py +0 -858
  426. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_quick_evaluation.py +0 -52
  427. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_react_agent.py +0 -874
  428. synth_ai/environments/examples/crafter_classic/agent_demos/crafter_trace_evaluation.py +0 -1412
  429. synth_ai/environments/examples/crafter_classic/agent_demos/example_v3_usage.py +0 -216
  430. synth_ai/environments/examples/crafter_classic/agent_demos/old/compare_traces.py +0 -296
  431. synth_ai/environments/examples/crafter_classic/agent_demos/old/crafter_comprehensive_evaluation.py +0 -58
  432. synth_ai/environments/examples/crafter_classic/agent_demos/old/crafter_env_serialization.py +0 -464
  433. synth_ai/environments/examples/crafter_classic/agent_demos/old/crafter_evaluation_browser.py +0 -152
  434. synth_ai/environments/examples/crafter_classic/agent_demos/old/crafter_quick_evaluation.py +0 -51
  435. synth_ai/environments/examples/crafter_classic/agent_demos/old/crafter_trace_evaluation.py +0 -1412
  436. synth_ai/environments/examples/crafter_classic/agent_demos/old/debug_player_loss.py +0 -112
  437. synth_ai/environments/examples/crafter_classic/agent_demos/old/diagnose_service.py +0 -203
  438. synth_ai/environments/examples/crafter_classic/agent_demos/old/diagnose_slowness.py +0 -305
  439. synth_ai/environments/examples/crafter_classic/agent_demos/old/eval_by_difficulty.py +0 -126
  440. synth_ai/environments/examples/crafter_classic/agent_demos/old/eval_example.py +0 -94
  441. synth_ai/environments/examples/crafter_classic/agent_demos/old/explore_saved_states.py +0 -142
  442. synth_ai/environments/examples/crafter_classic/agent_demos/old/filter_traces_sft.py +0 -26
  443. synth_ai/environments/examples/crafter_classic/agent_demos/old/filter_traces_sft_OLD.py +0 -984
  444. synth_ai/environments/examples/crafter_classic/agent_demos/old/generate_ft_data_gemini.py +0 -724
  445. synth_ai/environments/examples/crafter_classic/agent_demos/old/generate_ft_data_modal.py +0 -386
  446. synth_ai/environments/examples/crafter_classic/agent_demos/old/generate_ft_metadata.py +0 -205
  447. synth_ai/environments/examples/crafter_classic/agent_demos/old/kick_off_ft_gemini.py +0 -150
  448. synth_ai/environments/examples/crafter_classic/agent_demos/old/kick_off_ft_modal.py +0 -283
  449. synth_ai/environments/examples/crafter_classic/agent_demos/old/prepare_vertex_ft.py +0 -280
  450. synth_ai/environments/examples/crafter_classic/agent_demos/old/profile_env_slowness.py +0 -456
  451. synth_ai/environments/examples/crafter_classic/agent_demos/old/replicate_issue.py +0 -166
  452. synth_ai/environments/examples/crafter_classic/agent_demos/old/run_and_eval.py +0 -102
  453. synth_ai/environments/examples/crafter_classic/agent_demos/old/run_comparison.py +0 -128
  454. synth_ai/environments/examples/crafter_classic/agent_demos/old/run_qwen_rollouts.py +0 -655
  455. synth_ai/environments/examples/crafter_classic/agent_demos/old/trace_eval_OLD.py +0 -202
  456. synth_ai/environments/examples/crafter_classic/agent_demos/old/validate_openai_format.py +0 -166
  457. synth_ai/environments/examples/crafter_classic/config_logging.py +0 -111
  458. synth_ai/environments/examples/crafter_classic/debug_translation.py +0 -0
  459. synth_ai/environments/examples/crafter_classic/engine.py +0 -579
  460. synth_ai/environments/examples/crafter_classic/engine_deterministic_patch.py +0 -64
  461. synth_ai/environments/examples/crafter_classic/engine_helpers/action_map.py +0 -6
  462. synth_ai/environments/examples/crafter_classic/engine_helpers/serialization.py +0 -75
  463. synth_ai/environments/examples/crafter_classic/engine_serialization_patch_v3.py +0 -267
  464. synth_ai/environments/examples/crafter_classic/environment.py +0 -404
  465. synth_ai/environments/examples/crafter_classic/taskset.py +0 -233
  466. synth_ai/environments/examples/crafter_classic/trace_hooks_v3.py +0 -228
  467. synth_ai/environments/examples/crafter_classic/world_config_patch_simple.py +0 -299
  468. synth_ai/environments/examples/crafter_custom/__init__.py +0 -4
  469. synth_ai/environments/examples/crafter_custom/agent_demos/__init__.py +0 -1
  470. synth_ai/environments/examples/crafter_custom/agent_demos/trace_eval.py +0 -202
  471. synth_ai/environments/examples/crafter_custom/crafter/__init__.py +0 -7
  472. synth_ai/environments/examples/crafter_custom/crafter/config.py +0 -182
  473. synth_ai/environments/examples/crafter_custom/crafter/constants.py +0 -8
  474. synth_ai/environments/examples/crafter_custom/crafter/engine.py +0 -269
  475. synth_ai/environments/examples/crafter_custom/crafter/env.py +0 -262
  476. synth_ai/environments/examples/crafter_custom/crafter/objects.py +0 -417
  477. synth_ai/environments/examples/crafter_custom/crafter/recorder.py +0 -187
  478. synth_ai/environments/examples/crafter_custom/crafter/worldgen.py +0 -118
  479. synth_ai/environments/examples/crafter_custom/dataset_builder.py +0 -373
  480. synth_ai/environments/examples/crafter_custom/environment.py +0 -312
  481. synth_ai/environments/examples/crafter_custom/old/analyze_diamond_issue.py +0 -159
  482. synth_ai/environments/examples/crafter_custom/old/analyze_diamond_spawning.py +0 -158
  483. synth_ai/environments/examples/crafter_custom/old/compare_worlds.py +0 -71
  484. synth_ai/environments/examples/crafter_custom/old/dataset_stats.py +0 -105
  485. synth_ai/environments/examples/crafter_custom/old/diamond_spawning_summary.py +0 -119
  486. synth_ai/environments/examples/crafter_custom/old/example_dataset_usage.py +0 -52
  487. synth_ai/environments/examples/crafter_custom/run_dataset.py +0 -305
  488. synth_ai/environments/examples/enron/art_helpers/email_search_tools.py +0 -156
  489. synth_ai/environments/examples/enron/art_helpers/local_email_db.py +0 -281
  490. synth_ai/environments/examples/enron/art_helpers/types_enron.py +0 -25
  491. synth_ai/environments/examples/enron/engine.py +0 -295
  492. synth_ai/environments/examples/enron/environment.py +0 -166
  493. synth_ai/environments/examples/enron/taskset.py +0 -112
  494. synth_ai/environments/examples/enron/units/keyword_stats.py +0 -112
  495. synth_ai/environments/examples/minigrid/__init__.py +0 -48
  496. synth_ai/environments/examples/minigrid/agent_demos/minigrid_evaluation_framework.py +0 -1188
  497. synth_ai/environments/examples/minigrid/agent_demos/minigrid_quick_evaluation.py +0 -48
  498. synth_ai/environments/examples/minigrid/agent_demos/minigrid_react_agent.py +0 -562
  499. synth_ai/environments/examples/minigrid/agent_demos/minigrid_trace_evaluation.py +0 -221
  500. synth_ai/environments/examples/minigrid/engine.py +0 -589
  501. synth_ai/environments/examples/minigrid/environment.py +0 -274
  502. synth_ai/environments/examples/minigrid/environment_mapping.py +0 -242
  503. synth_ai/environments/examples/minigrid/puzzle_loader.py +0 -417
  504. synth_ai/environments/examples/minigrid/taskset.py +0 -583
  505. synth_ai/environments/examples/nethack/__init__.py +0 -7
  506. synth_ai/environments/examples/nethack/achievements.py +0 -337
  507. synth_ai/environments/examples/nethack/agent_demos/nethack_evaluation_framework.py +0 -981
  508. synth_ai/environments/examples/nethack/agent_demos/nethack_quick_evaluation.py +0 -74
  509. synth_ai/environments/examples/nethack/agent_demos/nethack_react_agent.py +0 -831
  510. synth_ai/environments/examples/nethack/engine.py +0 -739
  511. synth_ai/environments/examples/nethack/environment.py +0 -256
  512. synth_ai/environments/examples/nethack/helpers/__init__.py +0 -41
  513. synth_ai/environments/examples/nethack/helpers/action_mapping.py +0 -301
  514. synth_ai/environments/examples/nethack/helpers/nle_wrapper.py +0 -402
  515. synth_ai/environments/examples/nethack/helpers/observation_utils.py +0 -433
  516. synth_ai/environments/examples/nethack/helpers/recording_wrapper.py +0 -200
  517. synth_ai/environments/examples/nethack/helpers/trajectory_recorder.py +0 -269
  518. synth_ai/environments/examples/nethack/helpers/visualization/replay_viewer.py +0 -308
  519. synth_ai/environments/examples/nethack/helpers/visualization/visualizer.py +0 -431
  520. synth_ai/environments/examples/nethack/taskset.py +0 -323
  521. synth_ai/environments/examples/red/__init__.py +0 -7
  522. synth_ai/environments/examples/red/agent_demos/__init__.py +0 -1
  523. synth_ai/environments/examples/red/config_logging.py +0 -110
  524. synth_ai/environments/examples/red/engine.py +0 -694
  525. synth_ai/environments/examples/red/engine_helpers/__init__.py +0 -1
  526. synth_ai/environments/examples/red/engine_helpers/memory_map.py +0 -28
  527. synth_ai/environments/examples/red/engine_helpers/reward_components.py +0 -276
  528. synth_ai/environments/examples/red/engine_helpers/reward_library/__init__.py +0 -142
  529. synth_ai/environments/examples/red/engine_helpers/reward_library/adaptive_rewards.py +0 -57
  530. synth_ai/environments/examples/red/engine_helpers/reward_library/battle_rewards.py +0 -284
  531. synth_ai/environments/examples/red/engine_helpers/reward_library/composite_rewards.py +0 -150
  532. synth_ai/environments/examples/red/engine_helpers/reward_library/economy_rewards.py +0 -138
  533. synth_ai/environments/examples/red/engine_helpers/reward_library/efficiency_rewards.py +0 -57
  534. synth_ai/environments/examples/red/engine_helpers/reward_library/exploration_rewards.py +0 -331
  535. synth_ai/environments/examples/red/engine_helpers/reward_library/novelty_rewards.py +0 -121
  536. synth_ai/environments/examples/red/engine_helpers/reward_library/pallet_town_rewards.py +0 -559
  537. synth_ai/environments/examples/red/engine_helpers/reward_library/pokemon_rewards.py +0 -313
  538. synth_ai/environments/examples/red/engine_helpers/reward_library/social_rewards.py +0 -148
  539. synth_ai/environments/examples/red/engine_helpers/reward_library/story_rewards.py +0 -247
  540. synth_ai/environments/examples/red/engine_helpers/screen_analysis.py +0 -368
  541. synth_ai/environments/examples/red/engine_helpers/state_extraction.py +0 -140
  542. synth_ai/environments/examples/red/environment.py +0 -238
  543. synth_ai/environments/examples/red/taskset.py +0 -79
  544. synth_ai/environments/examples/red/units/__init__.py +0 -1
  545. synth_ai/environments/examples/sokoban/__init__.py +0 -1
  546. synth_ai/environments/examples/sokoban/agent_demos/sokoban_full_eval.py +0 -899
  547. synth_ai/environments/examples/sokoban/engine.py +0 -678
  548. synth_ai/environments/examples/sokoban/engine_helpers/__init__.py +0 -1
  549. synth_ai/environments/examples/sokoban/engine_helpers/room_utils.py +0 -657
  550. synth_ai/environments/examples/sokoban/engine_helpers/vendored/__init__.py +0 -18
  551. synth_ai/environments/examples/sokoban/engine_helpers/vendored/envs/__init__.py +0 -3
  552. synth_ai/environments/examples/sokoban/engine_helpers/vendored/envs/boxoban_env.py +0 -131
  553. synth_ai/environments/examples/sokoban/engine_helpers/vendored/envs/render_utils.py +0 -370
  554. synth_ai/environments/examples/sokoban/engine_helpers/vendored/envs/room_utils.py +0 -332
  555. synth_ai/environments/examples/sokoban/engine_helpers/vendored/envs/sokoban_env.py +0 -306
  556. synth_ai/environments/examples/sokoban/engine_helpers/vendored/envs/sokoban_env_fixed_targets.py +0 -67
  557. synth_ai/environments/examples/sokoban/engine_helpers/vendored/envs/sokoban_env_pull.py +0 -115
  558. synth_ai/environments/examples/sokoban/engine_helpers/vendored/envs/sokoban_env_two_player.py +0 -123
  559. synth_ai/environments/examples/sokoban/engine_helpers/vendored/envs/sokoban_env_variations.py +0 -394
  560. synth_ai/environments/examples/sokoban/environment.py +0 -229
  561. synth_ai/environments/examples/sokoban/generate_verified_puzzles.py +0 -440
  562. synth_ai/environments/examples/sokoban/puzzle_loader.py +0 -312
  563. synth_ai/environments/examples/sokoban/taskset.py +0 -428
  564. synth_ai/environments/examples/sokoban/units/astar_common.py +0 -95
  565. synth_ai/environments/examples/tictactoe/__init__.py +0 -1
  566. synth_ai/environments/examples/tictactoe/engine.py +0 -368
  567. synth_ai/environments/examples/tictactoe/environment.py +0 -240
  568. synth_ai/environments/examples/tictactoe/taskset.py +0 -215
  569. synth_ai/environments/examples/verilog/__init__.py +0 -10
  570. synth_ai/environments/examples/verilog/engine.py +0 -329
  571. synth_ai/environments/examples/verilog/environment.py +0 -350
  572. synth_ai/environments/examples/verilog/taskset.py +0 -420
  573. synth_ai/environments/examples/wordle/__init__.py +0 -29
  574. synth_ai/environments/examples/wordle/engine.py +0 -398
  575. synth_ai/environments/examples/wordle/environment.py +0 -159
  576. synth_ai/environments/examples/wordle/helpers/generate_instances_wordfreq.py +0 -75
  577. synth_ai/environments/examples/wordle/taskset.py +0 -230
  578. synth_ai/environments/reproducibility/core.py +0 -42
  579. synth_ai/environments/reproducibility/helpers.py +0 -0
  580. synth_ai/environments/reproducibility/tree.py +0 -364
  581. synth_ai/environments/service/app.py +0 -98
  582. synth_ai/environments/service/core_routes.py +0 -1020
  583. synth_ai/environments/service/external_registry.py +0 -56
  584. synth_ai/environments/service/registry.py +0 -9
  585. synth_ai/environments/stateful/__init__.py +0 -1
  586. synth_ai/environments/stateful/core.py +0 -163
  587. synth_ai/environments/stateful/engine.py +0 -21
  588. synth_ai/environments/stateful/state.py +0 -7
  589. synth_ai/environments/tasks/api.py +0 -19
  590. synth_ai/environments/tasks/core.py +0 -80
  591. synth_ai/environments/tasks/filters.py +0 -41
  592. synth_ai/environments/tasks/utils.py +0 -91
  593. synth_ai/environments/v0_observability/history.py +0 -3
  594. synth_ai/environments/v0_observability/log.py +0 -2
  595. synth_ai/evals/base.py +0 -15
  596. synth_ai/experimental/synth_oss.py +0 -446
  597. synth_ai/handshake.py +0 -63
  598. synth_ai/http.py +0 -26
  599. synth_ai/http_client.py +0 -104
  600. synth_ai/inference/client.py +0 -20
  601. synth_ai/install_sqld.sh +0 -40
  602. synth_ai/jobs/client.py +0 -246
  603. synth_ai/learning/__init__.py +0 -24
  604. synth_ai/learning/config.py +0 -43
  605. synth_ai/learning/filtering.py +0 -0
  606. synth_ai/learning/ft_client.py +0 -59
  607. synth_ai/learning/offline/dpo.py +0 -0
  608. synth_ai/learning/offline/providers.py +0 -7
  609. synth_ai/learning/offline/sft.py +0 -0
  610. synth_ai/learning/offline/shared.py +0 -0
  611. synth_ai/learning/online/grpo.py +0 -0
  612. synth_ai/learning/online/irft.py +0 -0
  613. synth_ai/learning/prompts/banking77_injection_eval.py +0 -168
  614. synth_ai/learning/prompts/gepa.py +0 -0
  615. synth_ai/learning/prompts/hello_world_in_context_injection_ex.py +0 -213
  616. synth_ai/learning/prompts/mipro.py +0 -289
  617. synth_ai/learning/prompts/random_search.py +0 -246
  618. synth_ai/learning/prompts/run_mipro_banking77.py +0 -172
  619. synth_ai/learning/prompts/run_random_search_banking77.py +0 -324
  620. synth_ai/learning/sse.py +0 -58
  621. synth_ai/learning/validators.py +0 -48
  622. synth_ai/lm/__init__.py +0 -51
  623. synth_ai/lm/caching/constants.py +0 -6
  624. synth_ai/lm/caching/dbs.py +0 -0
  625. synth_ai/lm/caching/ephemeral.py +0 -102
  626. synth_ai/lm/caching/handler.py +0 -137
  627. synth_ai/lm/caching/initialize.py +0 -11
  628. synth_ai/lm/caching/persistent.py +0 -114
  629. synth_ai/lm/config.py +0 -110
  630. synth_ai/lm/constants.py +0 -32
  631. synth_ai/lm/core/__init__.py +0 -8
  632. synth_ai/lm/core/all.py +0 -73
  633. synth_ai/lm/core/exceptions.py +0 -7
  634. synth_ai/lm/core/main.py +0 -319
  635. synth_ai/lm/core/main_v3.py +0 -594
  636. synth_ai/lm/core/synth_models.py +0 -48
  637. synth_ai/lm/core/vendor_clients.py +0 -188
  638. synth_ai/lm/cost/__init__.py +0 -0
  639. synth_ai/lm/cost/monitor.py +0 -1
  640. synth_ai/lm/cost/statefulness.py +0 -1
  641. synth_ai/lm/injection.py +0 -80
  642. synth_ai/lm/overrides.py +0 -206
  643. synth_ai/lm/provider_support/__init__.py +0 -8
  644. synth_ai/lm/provider_support/anthropic.py +0 -972
  645. synth_ai/lm/provider_support/openai.py +0 -1139
  646. synth_ai/lm/provider_support/suppress_logging.py +0 -31
  647. synth_ai/lm/structured_outputs/__init__.py +0 -0
  648. synth_ai/lm/structured_outputs/handler.py +0 -440
  649. synth_ai/lm/structured_outputs/inject.py +0 -297
  650. synth_ai/lm/structured_outputs/rehabilitate.py +0 -185
  651. synth_ai/lm/tools/__init__.py +0 -3
  652. synth_ai/lm/tools/base.py +0 -172
  653. synth_ai/lm/unified_interface.py +0 -202
  654. synth_ai/lm/vendors/__init__.py +0 -0
  655. synth_ai/lm/vendors/base.py +0 -81
  656. synth_ai/lm/vendors/core/__init__.py +0 -0
  657. synth_ai/lm/vendors/core/anthropic_api.py +0 -387
  658. synth_ai/lm/vendors/core/gemini_api.py +0 -292
  659. synth_ai/lm/vendors/core/mistral_api.py +0 -322
  660. synth_ai/lm/vendors/core/openai_api.py +0 -225
  661. synth_ai/lm/vendors/core/synth_dev_api.py +0 -0
  662. synth_ai/lm/vendors/local/__init__.py +0 -0
  663. synth_ai/lm/vendors/local/ollama.py +0 -0
  664. synth_ai/lm/vendors/openai_standard.py +0 -780
  665. synth_ai/lm/vendors/openai_standard_responses.py +0 -256
  666. synth_ai/lm/vendors/retries.py +0 -22
  667. synth_ai/lm/vendors/supported/__init__.py +0 -0
  668. synth_ai/lm/vendors/supported/custom_endpoint.py +0 -417
  669. synth_ai/lm/vendors/supported/deepseek.py +0 -69
  670. synth_ai/lm/vendors/supported/grok.py +0 -75
  671. synth_ai/lm/vendors/supported/groq.py +0 -16
  672. synth_ai/lm/vendors/supported/ollama.py +0 -15
  673. synth_ai/lm/vendors/supported/openrouter.py +0 -74
  674. synth_ai/lm/vendors/supported/together.py +0 -11
  675. synth_ai/lm/vendors/synth_client.py +0 -808
  676. synth_ai/lm/warmup.py +0 -186
  677. synth_ai/rl/secrets.py +0 -19
  678. synth_ai/scripts/verify_rewards.py +0 -100
  679. synth_ai/task/__init__.py +0 -10
  680. synth_ai/task/contracts.py +0 -120
  681. synth_ai/task/health.py +0 -28
  682. synth_ai/task/validators.py +0 -12
  683. synth_ai/tracing/__init__.py +0 -30
  684. synth_ai/tracing_v1/__init__.py +0 -33
  685. synth_ai/tracing_v3/config.py +0 -84
  686. synth_ai/tracing_v3/storage/config.py +0 -62
  687. synth_ai/tracing_v3/turso/__init__.py +0 -25
  688. synth_ai/tracing_v3/turso/daemon.py +0 -144
  689. synth_ai/tracing_v3/turso/manager.py +0 -760
  690. synth_ai/v0/tracing/__init__.py +0 -0
  691. synth_ai/v0/tracing/abstractions.py +0 -224
  692. synth_ai/v0/tracing/base_client.py +0 -91
  693. synth_ai/v0/tracing/client_manager.py +0 -131
  694. synth_ai/v0/tracing/config.py +0 -142
  695. synth_ai/v0/tracing/context.py +0 -146
  696. synth_ai/v0/tracing/decorators.py +0 -682
  697. synth_ai/v0/tracing/events/__init__.py +0 -0
  698. synth_ai/v0/tracing/events/manage.py +0 -147
  699. synth_ai/v0/tracing/events/scope.py +0 -86
  700. synth_ai/v0/tracing/events/store.py +0 -228
  701. synth_ai/v0/tracing/immediate_client.py +0 -151
  702. synth_ai/v0/tracing/local.py +0 -18
  703. synth_ai/v0/tracing/log_client_base.py +0 -73
  704. synth_ai/v0/tracing/retry_queue.py +0 -186
  705. synth_ai/v0/tracing/trackers.py +0 -515
  706. synth_ai/v0/tracing/upload.py +0 -512
  707. synth_ai/v0/tracing/utils.py +0 -9
  708. synth_ai/v0/tracing_v1/__init__.py +0 -16
  709. synth_ai/v0/tracing_v1/abstractions.py +0 -224
  710. synth_ai/v0/tracing_v1/base_client.py +0 -91
  711. synth_ai/v0/tracing_v1/client_manager.py +0 -131
  712. synth_ai/v0/tracing_v1/config.py +0 -142
  713. synth_ai/v0/tracing_v1/context.py +0 -146
  714. synth_ai/v0/tracing_v1/decorators.py +0 -703
  715. synth_ai/v0/tracing_v1/events/__init__.py +0 -0
  716. synth_ai/v0/tracing_v1/events/manage.py +0 -147
  717. synth_ai/v0/tracing_v1/events/scope.py +0 -86
  718. synth_ai/v0/tracing_v1/events/store.py +0 -228
  719. synth_ai/v0/tracing_v1/immediate_client.py +0 -151
  720. synth_ai/v0/tracing_v1/local.py +0 -18
  721. synth_ai/v0/tracing_v1/log_client_base.py +0 -73
  722. synth_ai/v0/tracing_v1/retry_queue.py +0 -186
  723. synth_ai/v0/tracing_v1/trackers.py +0 -515
  724. synth_ai/v0/tracing_v1/upload.py +0 -527
  725. synth_ai/v0/tracing_v1/utils.py +0 -9
  726. synth_ai/zyk/__init__.py +0 -30
  727. synth_ai-0.2.8.dev2.dist-info/METADATA +0 -129
  728. synth_ai-0.2.8.dev2.dist-info/RECORD +0 -420
  729. /synth_ai/{demos → cli/demo_apps}/demo_task_apps/math/__init__.py +0 -0
  730. /synth_ai/{lm/caching → core/apps}/__init__.py +0 -0
  731. /synth_ai/{tracing_v3 → core/tracing_v3}/lm_call_record_abstractions.py +0 -0
  732. /synth_ai/{tracing_v3 → core/tracing_v3}/storage/__init__.py +0 -0
  733. /synth_ai/{tracing_v3 → core/tracing_v3}/storage/exceptions.py +0 -0
  734. /synth_ai/{tracing_v3 → core/tracing_v3}/storage/types.py +0 -0
  735. /synth_ai/{compound/cais.py → py.typed} +0 -0
  736. /synth_ai/{learning → sdk/learning}/core.py +0 -0
  737. /synth_ai/{learning → sdk/learning}/gateway.py +0 -0
  738. {synth_ai-0.2.8.dev2.dist-info → synth_ai-0.4.3.dist-info}/WHEEL +0 -0
  739. {synth_ai-0.2.8.dev2.dist-info → synth_ai-0.4.3.dist-info}/licenses/LICENSE +0 -0
  740. {synth_ai-0.2.8.dev2.dist-info → synth_ai-0.4.3.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,83 @@
1
+ """Process tracking with automatic atexit cleanup.
2
+
3
+ This module provides a simple way to track cloudflared processes and ensure
4
+ they are terminated when Python exits (via atexit) or when cleanup_all() is
5
+ called explicitly.
6
+
7
+ Example:
8
+ from synth_ai.sdk.tunnels import open_managed_tunnel, track_process
9
+
10
+ # Start a cloudflared process and track it
11
+ proc = track_process(open_managed_tunnel(tunnel_token))
12
+
13
+ # Process will be automatically terminated when Python exits
14
+ # Or you can clean up early:
15
+ # cleanup_all()
16
+ """
17
+
18
+ from __future__ import annotations
19
+
20
+ import atexit
21
+ import subprocess
22
+ from typing import List
23
+
24
+ # Global state - tracked processes for cleanup
25
+ _tracked: List[subprocess.Popen] = []
26
+ _cleanup_registered = False
27
+
28
+
29
+ def tracked_processes() -> List[subprocess.Popen]:
30
+ """Return list of currently tracked processes (read-only copy).
31
+
32
+ Returns:
33
+ List of subprocess.Popen objects being tracked
34
+ """
35
+ return list(_tracked)
36
+
37
+
38
+ def track_process(proc: subprocess.Popen) -> subprocess.Popen:
39
+ """Track a cloudflared process for automatic cleanup on exit.
40
+
41
+ Args:
42
+ proc: Process returned by open_managed_tunnel() or similar
43
+
44
+ Returns:
45
+ The same process (for chaining)
46
+
47
+ Example:
48
+ from synth_ai.sdk.tunnels import open_managed_tunnel, track_process
49
+
50
+ proc = track_process(open_managed_tunnel(token))
51
+ # proc will be terminated automatically when Python exits
52
+ """
53
+ global _cleanup_registered
54
+ _tracked.append(proc)
55
+
56
+ if not _cleanup_registered:
57
+ atexit.register(cleanup_all)
58
+ _cleanup_registered = True
59
+
60
+ return proc
61
+
62
+
63
+ def cleanup_all() -> None:
64
+ """Stop all tracked cloudflared processes.
65
+
66
+ This is called automatically on Python exit via atexit.
67
+ You can also call it manually to clean up early.
68
+
69
+ Processes are terminated gracefully (SIGTERM), with a fallback
70
+ to SIGKILL if they don't exit within 5 seconds.
71
+ """
72
+ for proc in _tracked:
73
+ try:
74
+ if proc.poll() is None: # Still running
75
+ proc.terminate()
76
+ try:
77
+ proc.wait(timeout=5)
78
+ except subprocess.TimeoutExpired:
79
+ proc.kill()
80
+ proc.wait()
81
+ except Exception:
82
+ pass # Best effort cleanup
83
+ _tracked.clear()
@@ -0,0 +1,120 @@
1
+ """Port management utilities.
2
+
3
+ This module provides utilities for checking port availability and
4
+ killing processes that are using specific ports.
5
+
6
+ Example:
7
+ from synth_ai.sdk.tunnels import kill_port, is_port_available, find_available_port
8
+
9
+ # Check if port is available
10
+ if not is_port_available(8001):
11
+ kill_port(8001) # Free the port
12
+
13
+ # Or find an available port automatically
14
+ port = find_available_port(8001)
15
+ """
16
+
17
+ from __future__ import annotations
18
+
19
+ import socket
20
+ import subprocess
21
+ import sys
22
+
23
+
24
+ def is_port_available(port: int, host: str = "127.0.0.1") -> bool:
25
+ """Check if a port is available for binding.
26
+
27
+ Args:
28
+ port: Port number to check
29
+ host: Host to check (default: 127.0.0.1)
30
+
31
+ Returns:
32
+ True if the port is available, False if in use
33
+ """
34
+ try:
35
+ with socket.socket(socket.AF_INET, socket.SOCK_STREAM) as sock:
36
+ sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
37
+ sock.bind((host, port))
38
+ return True
39
+ except OSError:
40
+ return False
41
+
42
+
43
+ def find_available_port(
44
+ start_port: int, host: str = "127.0.0.1", max_attempts: int = 100
45
+ ) -> int:
46
+ """Find an available port starting from start_port.
47
+
48
+ Args:
49
+ start_port: Port number to start searching from
50
+ host: Host to check (default: 127.0.0.1)
51
+ max_attempts: Maximum number of ports to try
52
+
53
+ Returns:
54
+ First available port number
55
+
56
+ Raises:
57
+ RuntimeError: If no available port found within max_attempts
58
+ """
59
+ for offset in range(max_attempts):
60
+ port = start_port + offset
61
+ if is_port_available(port, host):
62
+ return port
63
+ raise RuntimeError(f"No available port found starting from {start_port}")
64
+
65
+
66
+ def kill_port(port: int, host: str = "127.0.0.1") -> bool:
67
+ """Kill any process using the specified port.
68
+
69
+ This is a best-effort operation that attempts to free a port by
70
+ terminating whatever process is using it. Use with caution.
71
+
72
+ Args:
73
+ port: Port number to free
74
+ host: Host (unused, for API consistency)
75
+
76
+ Returns:
77
+ True if a process was killed, False if port was already free
78
+
79
+ Note:
80
+ This may not work on all systems or require elevated privileges.
81
+ Prefer using find_available_port() instead when possible.
82
+ """
83
+ if is_port_available(port, host):
84
+ return False # Already free
85
+
86
+ try:
87
+ if sys.platform == "win32":
88
+ # Windows: use netstat + taskkill
89
+ result = subprocess.run(
90
+ ["netstat", "-ano"], capture_output=True, text=True, check=False
91
+ )
92
+ for line in result.stdout.splitlines():
93
+ if f":{port}" in line and "LISTENING" in line:
94
+ parts = line.split()
95
+ if len(parts) > 4:
96
+ pid = parts[-1]
97
+ subprocess.run(
98
+ ["taskkill", "/F", "/PID", pid],
99
+ capture_output=True,
100
+ check=False,
101
+ )
102
+ return True
103
+ else:
104
+ # Unix-like (macOS, Linux): use lsof + kill
105
+ result = subprocess.run(
106
+ ["lsof", "-ti", f":{port}"],
107
+ capture_output=True,
108
+ text=True,
109
+ check=False,
110
+ )
111
+ if result.stdout.strip():
112
+ for pid in result.stdout.strip().split():
113
+ subprocess.run(
114
+ ["kill", "-9", pid], capture_output=True, check=False
115
+ )
116
+ return True
117
+ except Exception:
118
+ pass
119
+
120
+ return False
@@ -0,0 +1,213 @@
1
+ """
2
+ Backward compatibility re-exports for synth_ai.utils.
3
+
4
+ All utilities have been reorganized:
5
+ - Core utilities → synth_ai.core.*
6
+ - CLI utilities → synth_ai.cli.lib.*
7
+
8
+ This module provides lazy imports to avoid circular import issues.
9
+ """
10
+
11
+ from __future__ import annotations
12
+
13
+ from typing import Any
14
+
15
+ # Direct imports from core (no circular dependency risk)
16
+ from synth_ai.core import task_app_state
17
+ from synth_ai.core.env import PROD_BASE_URL_DEFAULT, get_backend_from_env
18
+ from synth_ai.core.http import AsyncHttpClient, HTTPError, http_request
19
+ from synth_ai.core.json import create_and_write_json, load_json_to_dict, strip_json_comments
20
+ from synth_ai.core.paths import (
21
+ REPO_ROOT,
22
+ cleanup_paths,
23
+ configure_import_paths,
24
+ find_config_path,
25
+ get_bin_path,
26
+ get_env_file_paths,
27
+ get_home_config_file_paths,
28
+ is_hidden_path,
29
+ )
30
+ from synth_ai.core.process import (
31
+ ensure_local_port_available,
32
+ popen_capture,
33
+ popen_stream,
34
+ popen_stream_capture,
35
+ )
36
+ from synth_ai.core.task_app_state import (
37
+ DEFAULT_TASK_APP_SECRET_NAME,
38
+ current_task_app_id,
39
+ load_demo_dir,
40
+ load_template_id,
41
+ now_iso,
42
+ persist_api_key,
43
+ persist_demo_dir,
44
+ persist_env_api_key,
45
+ persist_task_url,
46
+ persist_template_id,
47
+ read_task_app_config,
48
+ record_task_app,
49
+ resolve_task_app_entry,
50
+ task_app_config_path,
51
+ task_app_id_from_path,
52
+ update_task_app_entry,
53
+ write_task_app_config,
54
+ )
55
+ from synth_ai.core.telemetry import (
56
+ flush_logger,
57
+ log_batch,
58
+ log_error,
59
+ log_event,
60
+ log_info,
61
+ log_warning,
62
+ )
63
+ from synth_ai.core.user_config import (
64
+ USER_CONFIG_PATH,
65
+ load_user_config,
66
+ load_user_env,
67
+ save_user_config,
68
+ update_user_config,
69
+ )
70
+
71
+ # Lazy imports for CLI utilities to avoid circular imports
72
+ _CLI_IMPORTS = {
73
+ # From cli.lib.agents
74
+ "write_agents_md": ("synth_ai.cli.lib.agents", "write_agents_md"),
75
+ # From core.apps.common
76
+ "extract_routes_from_app": ("synth_ai.core.apps.common", "extract_routes_from_app"),
77
+ "get_asgi_app": ("synth_ai.core.apps.common", "get_asgi_app"),
78
+ "load_module": ("synth_ai.core.apps.common", "load_module"),
79
+ # From cli.lib.bin
80
+ "install_bin": ("synth_ai.cli.lib.bin", "install_bin"),
81
+ "verify_bin": ("synth_ai.cli.lib.bin", "verify_bin"),
82
+ # From cli.lib.env
83
+ "mask_str": ("synth_ai.cli.lib.env", "mask_str"),
84
+ "read_env_var_from_file": ("synth_ai.cli.lib.env", "read_env_var_from_file"),
85
+ "resolve_env_var": ("synth_ai.cli.lib.env", "resolve_env_var"),
86
+ "write_env_var_to_dotenv": ("synth_ai.cli.lib.env", "write_env_var_to_dotenv"),
87
+ "write_env_var_to_json": ("synth_ai.cli.lib.env", "write_env_var_to_json"),
88
+ # From cli.lib.modal
89
+ "ensure_modal_installed": ("synth_ai.cli.lib.modal", "ensure_modal_installed"),
90
+ "ensure_task_app_ready": ("synth_ai.cli.lib.modal", "ensure_task_app_ready"),
91
+ "find_asgi_apps": ("synth_ai.cli.lib.modal", "find_asgi_apps"),
92
+ "is_local_demo_url": ("synth_ai.cli.lib.modal", "is_local_demo_url"),
93
+ "is_modal_public_url": ("synth_ai.cli.lib.modal", "is_modal_public_url"),
94
+ "normalize_endpoint_url": ("synth_ai.cli.lib.modal", "normalize_endpoint_url"),
95
+ # From cli.lib.prompts
96
+ "PromptedChoiceOption": ("synth_ai.cli.lib.prompts", "PromptedChoiceOption"),
97
+ "PromptedChoiceType": ("synth_ai.cli.lib.prompts", "PromptedChoiceType"),
98
+ "PromptedPathOption": ("synth_ai.cli.lib.prompts", "PromptedPathOption"),
99
+ "ctx_print": ("synth_ai.cli.lib.prompts", "ctx_print"),
100
+ "prompt_choice": ("synth_ai.cli.lib.prompts", "prompt_choice"),
101
+ "prompt_for_path": ("synth_ai.cli.lib.prompts", "prompt_for_path"),
102
+ # From cli.lib.sqld
103
+ "SQLD_VERSION": ("synth_ai.cli.lib.sqld", "SQLD_VERSION"),
104
+ "find_sqld_binary": ("synth_ai.cli.lib.sqld", "find_sqld_binary"),
105
+ "install_sqld": ("synth_ai.cli.lib.sqld", "install_sqld"),
106
+ # From cli.lib.task_app_discovery
107
+ "AppChoice": ("synth_ai.cli.lib.task_app_discovery", "AppChoice"),
108
+ "discover_eval_config_paths": ("synth_ai.cli.lib.task_app_discovery", "discover_eval_config_paths"),
109
+ "select_app_choice": ("synth_ai.cli.lib.task_app_discovery", "select_app_choice"),
110
+ # From cli.lib.task_app_env
111
+ "ensure_env_credentials": ("synth_ai.cli.lib.task_app_env", "ensure_env_credentials"),
112
+ "ensure_port_free": ("synth_ai.cli.lib.task_app_env", "ensure_port_free"),
113
+ "preflight_env_key": ("synth_ai.cli.lib.task_app_env", "preflight_env_key"),
114
+ # From core.integrations.mcp.claude
115
+ "ClaudeConfig": ("synth_ai.core.integrations.mcp.claude", "ClaudeConfig"),
116
+ }
117
+
118
+
119
+ def __getattr__(name: str) -> Any:
120
+ if name in _CLI_IMPORTS:
121
+ module_name, attr_name = _CLI_IMPORTS[name]
122
+ import importlib
123
+ module = importlib.import_module(module_name)
124
+ return getattr(module, attr_name)
125
+ raise AttributeError(f"module 'synth_ai.utils' has no attribute '{name}'")
126
+
127
+
128
+ __all__ = [
129
+ # Core
130
+ "AsyncHttpClient",
131
+ "ClaudeConfig",
132
+ "DEFAULT_TASK_APP_SECRET_NAME",
133
+ "HTTPError",
134
+ "PROD_BASE_URL_DEFAULT",
135
+ "REPO_ROOT",
136
+ "USER_CONFIG_PATH",
137
+ "cleanup_paths",
138
+ "configure_import_paths",
139
+ "create_and_write_json",
140
+ "current_task_app_id",
141
+ "ensure_local_port_available",
142
+ "find_config_path",
143
+ "flush_logger",
144
+ "get_backend_from_env",
145
+ "get_bin_path",
146
+ "get_env_file_paths",
147
+ "get_home_config_file_paths",
148
+ "http_request",
149
+ "is_hidden_path",
150
+ "load_demo_dir",
151
+ "load_json_to_dict",
152
+ "load_template_id",
153
+ "load_user_config",
154
+ "load_user_env",
155
+ "log_batch",
156
+ "log_error",
157
+ "log_event",
158
+ "log_info",
159
+ "log_warning",
160
+ "now_iso",
161
+ "persist_api_key",
162
+ "persist_demo_dir",
163
+ "persist_env_api_key",
164
+ "persist_task_url",
165
+ "persist_template_id",
166
+ "popen_capture",
167
+ "popen_stream",
168
+ "popen_stream_capture",
169
+ "read_task_app_config",
170
+ "record_task_app",
171
+ "resolve_task_app_entry",
172
+ "save_user_config",
173
+ "strip_json_comments",
174
+ "task_app_config_path",
175
+ "task_app_id_from_path",
176
+ "task_app_state",
177
+ "update_task_app_entry",
178
+ "update_user_config",
179
+ "write_task_app_config",
180
+ # CLI (lazy)
181
+ "AppChoice",
182
+ "PromptedChoiceOption",
183
+ "PromptedChoiceType",
184
+ "PromptedPathOption",
185
+ "SQLD_VERSION",
186
+ "ctx_print",
187
+ "discover_eval_config_paths",
188
+ "ensure_env_credentials",
189
+ "ensure_modal_installed",
190
+ "ensure_port_free",
191
+ "ensure_task_app_ready",
192
+ "extract_routes_from_app",
193
+ "find_asgi_apps",
194
+ "find_sqld_binary",
195
+ "get_asgi_app",
196
+ "install_bin",
197
+ "install_sqld",
198
+ "is_local_demo_url",
199
+ "is_modal_public_url",
200
+ "load_module",
201
+ "mask_str",
202
+ "normalize_endpoint_url",
203
+ "preflight_env_key",
204
+ "prompt_choice",
205
+ "prompt_for_path",
206
+ "read_env_var_from_file",
207
+ "resolve_env_var",
208
+ "select_app_choice",
209
+ "verify_bin",
210
+ "write_agents_md",
211
+ "write_env_var_to_dotenv",
212
+ "write_env_var_to_json",
213
+ ]
@@ -0,0 +1,262 @@
1
+ Metadata-Version: 2.4
2
+ Name: synth-ai
3
+ Version: 0.4.3
4
+ Summary: Serverless Posttraining for Agents - Core AI functionality and tracing
5
+ Author-email: Synth AI <josh@usesynth.ai>
6
+ License: MIT
7
+ Project-URL: Homepage, https://github.com/synth-laboratories/synth-ai
8
+ Project-URL: Repository, https://github.com/synth-laboratories/synth-ai
9
+ Project-URL: Issues, https://github.com/synth-laboratories/synth-ai/issues
10
+ Requires-Python: >=3.11
11
+ Description-Content-Type: text/markdown
12
+ License-File: LICENSE
13
+ Requires-Dist: pydantic>=2.0.0
14
+ Requires-Dist: python-dotenv>=1.0.1
15
+ Requires-Dist: requests>=2.32.3
16
+ Requires-Dist: tqdm>=4.66.4
17
+ Requires-Dist: typing_extensions>=4.0.0
18
+ Requires-Dist: rich>=13.9.0
19
+ Requires-Dist: openai>=1.99.0
20
+ Requires-Dist: anthropic>=0.42.0
21
+ Requires-Dist: langfuse<3.0.0,>=2.53.9
22
+ Requires-Dist: opentelemetry-api>=1.26.0
23
+ Requires-Dist: opentelemetry-sdk>=1.26.0
24
+ Requires-Dist: groq>=0.30.0
25
+ Requires-Dist: google-genai>=1.26.0
26
+ Requires-Dist: together>=1.5.21
27
+ Requires-Dist: mistralai>=1.9.2
28
+ Requires-Dist: fastapi>=0.115.12
29
+ Requires-Dist: uvicorn>=0.34.2
30
+ Requires-Dist: numpy>=2.2.3
31
+ Requires-Dist: networkx>=3.4.2
32
+ Requires-Dist: sqlalchemy>=2.0.42
33
+ Requires-Dist: celery>=5.4.0
34
+ Requires-Dist: redis>=6.2.0
35
+ Requires-Dist: aiosqlite>=0.21.0
36
+ Requires-Dist: libsql>=0.1.8
37
+ Requires-Dist: pynacl>=1.5.0
38
+ Requires-Dist: click<8.2,>=8.1.7
39
+ Requires-Dist: aiohttp>=3.8.0
40
+ Requires-Dist: httpx>=0.28.1
41
+ Requires-Dist: modal<2.0.0,>=1.1.4
42
+ Requires-Dist: docker>=7.0.0
43
+ Requires-Dist: mcp>=1.21.0
44
+ Requires-Dist: ruff>=0.12.9
45
+ Requires-Dist: tomli_w>=1.0.0
46
+ Requires-Dist: dspy>=3.0.4
47
+ Requires-Dist: setuptools>=80.9.0
48
+ Requires-Dist: gymnasium>=0.26.2
49
+ Requires-Dist: gepa>=0.0.17
50
+ Requires-Dist: datasets>=4.0.0
51
+ Provides-Extra: dev
52
+ Requires-Dist: build>=1.2.2.post1; extra == "dev"
53
+ Requires-Dist: twine>=4.0.0; extra == "dev"
54
+ Requires-Dist: keyring>=24.0.0; extra == "dev"
55
+ Requires-Dist: pytest>=8.3.3; extra == "dev"
56
+ Requires-Dist: pytest-xdist>=3.6.1; extra == "dev"
57
+ Requires-Dist: pytest-timeout>=2.3.1; extra == "dev"
58
+ Requires-Dist: pytest-asyncio>=0.24.0; extra == "dev"
59
+ Requires-Dist: pytest-cov>=4.1.0; extra == "dev"
60
+ Requires-Dist: pyright>=1.1.350; extra == "dev"
61
+ Requires-Dist: coverage[toml]>=7.3.0; extra == "dev"
62
+ Requires-Dist: ruff>=0.1.0; extra == "dev"
63
+ Requires-Dist: papermill>=2.6.0; extra == "dev"
64
+ Requires-Dist: nest_asyncio>=1.6.0; extra == "dev"
65
+ Provides-Extra: research
66
+ Requires-Dist: crafter>=1.8.3; extra == "research"
67
+ Requires-Dist: datasets>=4.0.0; extra == "research"
68
+ Provides-Extra: swe
69
+ Requires-Dist: morphcloud>=0.1.3; extra == "swe"
70
+ Requires-Dist: swebench>=2.3.0; extra == "swe"
71
+ Provides-Extra: all
72
+ Requires-Dist: crafter>=1.8.3; extra == "all"
73
+ Requires-Dist: datasets>=4.0.0; extra == "all"
74
+ Requires-Dist: morphcloud>=0.1.3; extra == "all"
75
+ Requires-Dist: swebench>=2.3.0; extra == "all"
76
+ Requires-Dist: pyboy>=2.6.0; extra == "all"
77
+ Requires-Dist: transformers>=4.56.1; extra == "all"
78
+ Requires-Dist: redis>=6.2.0; extra == "all"
79
+ Provides-Extra: analytics
80
+ Requires-Dist: pandas>=2.2.3; extra == "analytics"
81
+ Dynamic: license-file
82
+
83
+ # Synth
84
+
85
+ [![Python](https://img.shields.io/badge/python-3.11+-blue)](https://www.python.org/)
86
+ [![PyPI](https://img.shields.io/pypi/v/synth-ai.svg)](https://pypi.org/project/synth-ai/)
87
+ [![PyPI Main](https://img.shields.io/badge/main-0.4.1-blue)](https://pypi.org/project/synth-ai/0.4.1/)
88
+ [![PyPI Nightly](https://img.shields.io/badge/nightly-0.4.0-orange)](https://pypi.org/project/synth-ai/)
89
+ [![License](https://img.shields.io/badge/license-MIT-green)](LICENSE)
90
+ ![Coverage](https://img.shields.io/badge/coverage-28.65%25-yellow)
91
+ ![Tests](https://img.shields.io/badge/tests-847%20passing-brightgreen)
92
+
93
+ Serverless Posttraining APIs for Developers
94
+
95
+ <p align="center">
96
+ <picture align="center">
97
+ <source media="(prefers-color-scheme: dark)" srcset="https://raw.githubusercontent.com/synth-laboratories/synth-ai/main/assets/langprobe_v2_dark.png">
98
+ <source media="(prefers-color-scheme: light)" srcset="https://raw.githubusercontent.com/synth-laboratories/synth-ai/main/assets/langprobe_v2_light.png">
99
+ <img alt="Shows a bar chart comparing prompt optimization performance across Synth GEPA, Synth MIPRO, GEPA (lib), DSPy MIPRO, and DSPy GEPA with baseline vs optimized." src="https://raw.githubusercontent.com/synth-laboratories/synth-ai/main/assets/langprobe_v2_light.png">
100
+ </picture>
101
+ </p>
102
+
103
+ <p align="center">
104
+ <i>Average accuracy on <a href="https://arxiv.org/abs/2502.20315">LangProBe</a> prompt optimization benchmarks.</i>
105
+ </p>
106
+
107
+ ## Highlights
108
+
109
+ - 🚀 Train across sft, RL, and prompt opt by standing up a single cloudflared Fastapi wrapper around your code. No production code churn.
110
+ - ⚡️ Parallelize training and achieve 80% GPU util. via PipelineRL
111
+ - 🗂️ Train prompts and models across multiple experiments
112
+ - 🛠️ Spin up experiment queues and datastores locally for dev work
113
+ - 🔩 Run serverless training via cli or programmatically
114
+ - 🏢 Scales gpu-based model training to 64 H100s seemlessly
115
+ - 💾 Use GEPA-calibrated verifiers for fast, accurate rubric scoring
116
+ - 🖥️ Supports HTTP-based training across all programming languages
117
+ - 🤖 CLI utilities tuned for use with Claude Code, Codex, Opencode
118
+
119
+ ## Getting Started
120
+
121
+ ```bash
122
+ # Use with OpenAI Codex
123
+ uvx synth-ai codex
124
+ ```
125
+
126
+ ```bash
127
+ # Use with Opencode
128
+ uvx synth-ai opencode
129
+ ```
130
+
131
+ Synth is maintained by devs behind the [MIPROv2](https://scholar.google.com/citations?view_op=view_citation&hl=en&user=jauNVA8AAAAJ&citation_for_view=jauNVA8AAAAJ:u5HHmVD_uO8C) prompt optimizer.
132
+
133
+ ## Documentation
134
+
135
+ **[docs.usesynth.ai](https://docs.usesynth.ai)**
136
+
137
+ ## In-Process Runner (SDK)
138
+
139
+ Run GEPA/MIPRO/RL jobs against a tunneled task app without the CLI:
140
+
141
+ ```python
142
+ import asyncio
143
+ import os
144
+ from synth_ai.sdk.task import run_in_process_job
145
+
146
+ result = asyncio.run(
147
+ run_in_process_job(
148
+ job_type="prompt_learning",
149
+ config_path="configs/style_matching_gepa.toml",
150
+ task_app_path="task_apps/style_matching_task_app.py",
151
+ overrides={"prompt_learning.gepa.rollout.budget": 4},
152
+ backend_url=os.getenv("TARGET_BACKEND_BASE_URL"), # resolves envs automatically
153
+ )
154
+ )
155
+ print(result.job_id, result.status.get("status"))
156
+ ```
157
+
158
+ ## Zero-Shot Verifiers (SDK)
159
+
160
+ Run a built-in verifier graph with rubric criteria passed at runtime:
161
+
162
+ ```python
163
+ import asyncio
164
+ import os
165
+ from synth_ai.sdk.graphs import VerifierClient
166
+
167
+ async def run_verifier():
168
+ client = VerifierClient(
169
+ base_url=os.environ["SYNTH_BACKEND_BASE"],
170
+ api_key=os.environ["SYNTH_API_KEY"],
171
+ )
172
+ result = await client.evaluate(
173
+ job_id="zero_shot_verifier_single",
174
+ session_trace={"session_id": "s", "event_history": []},
175
+ rubric={
176
+ "event": [{"id": "accuracy", "weight": 1.0, "description": "Correctness"}],
177
+ "outcome": [{"id": "task_completion", "weight": 1.0, "description": "Completed task"}],
178
+ },
179
+ options={"event": True, "outcome": True, "model": "gpt-5-nano"},
180
+ policy_name="my_policy",
181
+ task_app_id="my_task",
182
+ )
183
+ return result
184
+
185
+ asyncio.run(run_verifier())
186
+ ```
187
+
188
+ You can also call arbitrary graphs directly:
189
+
190
+ ```python
191
+ from synth_ai.sdk.graphs import GraphCompletionsClient
192
+
193
+ client = GraphCompletionsClient(base_url="https://api.usesynth.ai", api_key="...")
194
+ resp = await client.run(
195
+ graph={"kind": "zero_shot", "verifier_type": "zero_shot_verifier_mapreduce"},
196
+ input_data={"session_trace": {"session_id": "s", "event_history": []}, "rubric": {"event": [], "outcome": []}},
197
+ )
198
+ ```
199
+
200
+ ## GraphGen: Train Custom Verifier and RLM Graphs
201
+
202
+ Train custom verifier and RLM graphs using GraphGen:
203
+
204
+ ```python
205
+ from synth_ai.sdk.api.train.graphgen import GraphGenJob
206
+
207
+ # Train a verifier graph (judge/scorer)
208
+ verifier_job = GraphGenJob.from_dataset(
209
+ dataset="verifier_dataset.json",
210
+ graph_type="verifier",
211
+ policy_models=["gpt-4.1"],
212
+ proposer_effort="medium", # Use "medium" (gpt-4.1) or "high" (gpt-5.2)
213
+ rollout_budget=200,
214
+ )
215
+ verifier_job.submit()
216
+ result = verifier_job.stream_until_complete(timeout=3600.0)
217
+
218
+ # Run inference with trained verifier
219
+ judgment = verifier_job.run_verifier(
220
+ session_trace=my_trace,
221
+ context={"rubric": my_rubric},
222
+ )
223
+ print(f"Score: {judgment.score}, Reasoning: {judgment.reasoning}")
224
+ ```
225
+
226
+ ```python
227
+ # Train an RLM graph (massive context via tools)
228
+ rlm_job = GraphGenJob.from_dataset(
229
+ dataset="rlm_dataset.json",
230
+ graph_type="rlm",
231
+ configured_tools=[
232
+ {"name": "materialize_context", "kind": "rlm_materialize", "stateful": True},
233
+ {"name": "local_grep", "kind": "rlm_local_grep", "stateful": False},
234
+ {"name": "codex_exec", "kind": "daytona_exec", "stateful": True},
235
+ ],
236
+ policy_models=["gpt-4.1"],
237
+ proposer_effort="medium",
238
+ rollout_budget=100,
239
+ )
240
+ rlm_job.submit()
241
+ result = rlm_job.stream_until_complete(timeout=3600.0)
242
+
243
+ # Run inference with trained RLM graph
244
+ output = rlm_job.run_inference({"query": "Find relevant sections", "context": large_document})
245
+ ```
246
+
247
+ **Graph Types:**
248
+ - **`verifier`**: Trains a judge/scorer that evaluates traces and returns structured rewards
249
+ - **`rlm`**: Trains a graph optimized for massive contexts (1M+ tokens) using tool-based search
250
+ - **`policy`**: Trains a standard input→output graph (default)
251
+
252
+ **RLM Tools:**
253
+ - `materialize_context` - Store input fields for fast searching (~1ms local)
254
+ - `local_grep` - Regex search on materialized content (~1ms)
255
+ - `local_search` - Substring search (~1ms)
256
+ - `query_lm` - Sub-LM calls for processing chunks
257
+ - `codex_exec` - Shell execution for complex operations
258
+
259
+ **When to use RLM:**
260
+ - Context exceeds ~100K tokens (too large for prompt)
261
+ - You need to search/filter large datasets
262
+ - RAG-style workflows over massive corpora