adaptive-memory-multi-model-router 2.14.46 → 2.14.47

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 (598) hide show
  1. package/{docs/llms.txt → llms.txt.bak} +6 -6
  2. package/package.json +13 -84
  3. package/src/routing/advancedRouter.ts.bak +650 -0
  4. package/test.js.bak +376 -0
  5. package/.dockerignore +0 -82
  6. package/.env.example +0 -303
  7. package/.github/DISCUSSIONS_WELCOME.md +0 -27
  8. package/.github/DISCUSSION_TEMPLATE.yml +0 -5
  9. package/.github/FUNDING.yml +0 -2
  10. package/.github/ISSUE_TEMPLATE/bug_report.md +0 -94
  11. package/.github/ISSUE_TEMPLATE/config.yml +0 -17
  12. package/.github/ISSUE_TEMPLATE/feature_request.md +0 -71
  13. package/.github/PULL_REQUEST_TEMPLATE.md +0 -71
  14. package/.github/dependabot.yml +0 -9
  15. package/.github/workflows/auto-publish.yml +0 -51
  16. package/.github/workflows/ci.yml +0 -263
  17. package/.github/workflows/codeql.yml +0 -38
  18. package/.github/workflows/npm-publish.yml +0 -20
  19. package/.github/workflows/pages.yml +0 -37
  20. package/.github/workflows/stale.yml +0 -54
  21. package/.publish-tick +0 -1
  22. package/.well-known/ai-plugin.json +0 -16
  23. package/AGENT_COUNCIL_FINDINGS.md +0 -142
  24. package/ARCHITECTURE.md +0 -346
  25. package/AUDIT_REPORT.md +0 -28
  26. package/CODE_OF_CONDUCT.md +0 -128
  27. package/CONTRIBUTING.md +0 -50
  28. package/CONTRIBUTORS.md +0 -20
  29. package/Dockerfile +0 -53
  30. package/Dockerfile.proxy +0 -33
  31. package/HEALTH_REPORT.md +0 -118
  32. package/IMPROVEMENT_PLAN.md +0 -107
  33. package/LANDING.md +0 -43
  34. package/LAUNCH-PAIN-DRIVEN.md +0 -339
  35. package/LAUNCH.md +0 -337
  36. package/LAUNCH_CHECKLIST.md +0 -141
  37. package/LAUNCH_SNAPSHOT.md +0 -260
  38. package/MANIFESTO.md +0 -41
  39. package/POPULARITY_BOOSTERS.md +0 -285
  40. package/PR_STATUS_REPORT.md +0 -148
  41. package/REDESIGN.md +0 -95
  42. package/RUNKIT.md +0 -83
  43. package/SECURITY.md +0 -29
  44. package/SUBMISSIONS.md +0 -43
  45. package/_schema.html +0 -53
  46. package/ai-plugin.json +0 -16
  47. package/articles/AI_AGENT_LLM_ROUTING.md +0 -150
  48. package/articles/CHINESE_DIRECTORIES.md +0 -100
  49. package/articles/CHINESE_SUBMISSIONS_READY.md +0 -322
  50. package/articles/COMPETITOR_ALERTS.md +0 -31
  51. package/articles/COMPLETE_POSTING_DIRECTORY.md +0 -147
  52. package/articles/CONTENT_STRUCTURE.md +0 -292
  53. package/articles/DEVTO_COST_GUIDE.md +0 -473
  54. package/articles/DEVTO_FINAL.md +0 -416
  55. package/articles/DEVTO_MULTI_PROVIDER.md +0 -542
  56. package/articles/DEVTO_READY.md +0 -255
  57. package/articles/DEVTO_V2_ANNOUNCEMENT.md +0 -160
  58. package/articles/DEVTO_VIRAL_GROWTH.md +0 -280
  59. package/articles/FRESH_devto.md +0 -460
  60. package/articles/FRESH_devto_2026_05.md +0 -73
  61. package/articles/FRESH_hackernews.md +0 -14
  62. package/articles/FRESH_reddit_ml.md +0 -90
  63. package/articles/FRESH_reddit_node.md +0 -198
  64. package/articles/FRESH_reddit_sideproject.md +0 -72
  65. package/articles/FRESH_reddit_webdev.md +0 -130
  66. package/articles/FROM_ZERO_TO_10K.md +0 -107
  67. package/articles/HN_10X_BETTER.md +0 -430
  68. package/articles/HN_ACCOUNT_GUIDE.md +0 -21
  69. package/articles/HN_CHINESE_STYLE.md +0 -308
  70. package/articles/HN_FINAL.md +0 -148
  71. package/articles/HN_POSTED_VERSION.md +0 -56
  72. package/articles/HN_POST_READY.md +0 -137
  73. package/articles/HN_RESEARCH.md +0 -364
  74. package/articles/HN_SHOW_routerarena.md +0 -17
  75. package/articles/HN_TIMING_GUIDE.md +0 -52
  76. package/articles/INDIEHACKERS_POST.md +0 -52
  77. package/articles/INDIEHACKERS_READY.md +0 -120
  78. package/articles/LLM_BENCHMARK_DEEP_DIVE.md +0 -153
  79. package/articles/MASTER_POSTING_DIRECTORY.md +0 -189
  80. package/articles/NEWSLETTER_SEND_NOW.md +0 -259
  81. package/articles/NEWSLETTER_SUBMISSIONS.md +0 -112
  82. package/articles/PAIN-DRIVEN-devto-v2.md +0 -308
  83. package/articles/PAIN-DRIVEN-devto-v3.md +0 -268
  84. package/articles/PAIN-DRIVEN-devto.md +0 -242
  85. package/articles/PAIN-DRIVEN-hackernews-v2.md +0 -138
  86. package/articles/PAIN-DRIVEN-hackernews-v3.md +0 -151
  87. package/articles/PAIN-DRIVEN-hackernews.md +0 -131
  88. package/articles/PAIN-DRIVEN-reddit-v2.md +0 -301
  89. package/articles/PAIN-DRIVEN-reddit-v3.md +0 -236
  90. package/articles/PAIN-DRIVEN-reddit.md +0 -218
  91. package/articles/PAIN-DRIVEN-twitter-v2.md +0 -110
  92. package/articles/PAIN-DRIVEN-twitter-v3.md +0 -121
  93. package/articles/PAIN-DRIVEN-twitter.md +0 -120
  94. package/articles/PORTKEY_VS_A3M.md +0 -147
  95. package/articles/POSTING_KIT_2026_05.md +0 -67
  96. package/articles/PRESS_KIT_routerarena.md +0 -77
  97. package/articles/PRODUCTHUNT_LISTING.md +0 -48
  98. package/articles/PRODUCTHUNT_READY.md +0 -106
  99. package/articles/PR_PLAN_vault.md +0 -125
  100. package/articles/REDDIT_FINAL.md +0 -232
  101. package/articles/REDDIT_POST.md +0 -67
  102. package/articles/REDDIT_SUBMISSION_READY.md +0 -348
  103. package/articles/ROUTERARENA_LEADER.md +0 -45
  104. package/articles/SHOW_HN_FINAL.md +0 -29
  105. package/articles/TWEETS_10K_DOWNLOADS.md +0 -47
  106. package/articles/TWEETS_BENCHMARK_FIRST.md +0 -46
  107. package/articles/TWEETS_MCP_PLAY.md +0 -51
  108. package/articles/TWEETS_SEQUENTIAL_BROKEN.md +0 -49
  109. package/articles/TWEETS_WHY_BUILD.md +0 -54
  110. package/articles/TWEETS_routerarena_leader.md +0 -53
  111. package/articles/TWEET_STORM_READY.md +0 -165
  112. package/articles/TWITTER_FINAL.md +0 -167
  113. package/articles/WHY_10X_BETTER.md +0 -261
  114. package/articles/WHY_CHINESE_STYLE_BETTER.md +0 -323
  115. package/articles/ai-discoverability-llm-routing.md +0 -210
  116. package/articles/devto-llm-routing.md +0 -138
  117. package/articles/hackernews-show-hn.md +0 -54
  118. package/articles/hashnode-llm-cost-optimization.md +0 -125
  119. package/articles/hn_show_2026_05.md +0 -11
  120. package/articles/medium-building-llm-router.md +0 -205
  121. package/articles/reddit-ml.md +0 -76
  122. package/articles/twitter-thread-cost-savings.md +0 -50
  123. package/articles/youtube-tutorial-script.md +0 -262
  124. package/assets/a3m_3blue1brown.mp4 +0 -0
  125. package/assets/banner.svg +0 -109
  126. package/assets/chart-cost-v2.svg +0 -91
  127. package/assets/chart-cost-v3.svg +0 -143
  128. package/assets/chart-features-v2.svg +0 -132
  129. package/assets/chart-features-v3.svg +0 -211
  130. package/assets/chart-growth-v2.svg +0 -122
  131. package/assets/chart-growth-v3.svg +0 -189
  132. package/assets/cost-comparison.svg +0 -134
  133. package/assets/cost-simple.svg +0 -64
  134. package/assets/demo-hn.gif +0 -0
  135. package/assets/feature-matrix.svg +0 -136
  136. package/assets/growth-chart-animated.svg +0 -76
  137. package/assets/growth-chart.svg +0 -82
  138. package/assets/growth-simple.svg +0 -69
  139. package/assets/hero-diagram.svg +0 -81
  140. package/assets/logo-new.svg +0 -21
  141. package/assets/logo.svg +0 -68
  142. package/assets/provider-comparison.svg +0 -121
  143. package/assets/social-preview-new.svg +0 -100
  144. package/assets/social-preview.svg +0 -194
  145. package/assets/social-v2.svg +0 -130
  146. package/assets/social-v3.svg +0 -212
  147. package/benchmark-provider-results.json +0 -245
  148. package/benchmark-results.json +0 -54
  149. package/council-votes/architecture-vote.md +0 -121
  150. package/council-votes/coverage-vote.md +0 -93
  151. package/data/adaptive-benchmark.json +0 -92
  152. package/data/benchmark-results.json +0 -47
  153. package/data/labeled-benchmark.json +0 -88
  154. package/demo/3blue1brown_video.py +0 -285
  155. package/demo/3blue1brown_video_v2.py +0 -310
  156. package/demo/IMPROVED_PROMPTS.md +0 -229
  157. package/demo/VEO3_PROMPTS.md +0 -269
  158. package/demo/VIDEO_PRODUCTION_GUIDE.md +0 -333
  159. package/demo/a3m_3blue1brown.mp4 +0 -0
  160. package/demo/asciinema-demo.sh +0 -195
  161. package/demo/demo-hn.tape +0 -74
  162. package/demo/demo-script.md +0 -53
  163. package/demo/demo-script.sh +0 -62
  164. package/demo/demo.svg +0 -75
  165. package/demo/frame1_ai_data_center.png +0 -0
  166. package/demo/frame1_sunset_video.mp4 +0 -0
  167. package/demo/frame2_cost_comparison.png +0 -0
  168. package/demo/frame2_cost_comparison_fallback.png +0 -0
  169. package/demo/frame3_parallel_execution.png +0 -0
  170. package/demo/frame3_parallel_execution_fallback.png +0 -0
  171. package/demo/frame4_providers.png +0 -0
  172. package/demo/frame4_providers_fallback.png +0 -0
  173. package/demo/frame5_endcard.png +0 -0
  174. package/demo/frame5_endcard_fallback.png +0 -0
  175. package/demo/new_frame1_hook.png +0 -0
  176. package/demo/new_frame2_proof.png +0 -0
  177. package/demo/new_frame3_wow.png +0 -0
  178. package/demo/new_frame4_social.png +0 -0
  179. package/demo/new_frame5_cta.png +0 -0
  180. package/demo/package.json +0 -13
  181. package/demo/product-video-final.mp4 +0 -0
  182. package/demo/product-video-hype-v1.mp4 +0 -0
  183. package/demo/product-video-v1.mp4 +0 -0
  184. package/demo/public/index.html +0 -762
  185. package/demo/recording.cast +0 -55
  186. package/demo/server.js +0 -405
  187. package/demo-new.tape +0 -71
  188. package/demo-real.sh +0 -198
  189. package/demo-simple.tape +0 -205
  190. package/demo.html +0 -520
  191. package/demo.sh +0 -85
  192. package/demo.tape +0 -259
  193. package/dist/analytics/costAnalytics.d.ts.map +0 -1
  194. package/dist/analytics/costAnalytics.js.map +0 -1
  195. package/dist/benchmark/comprehensive.js.map +0 -1
  196. package/dist/benchmark/reproducible.d.ts.map +0 -1
  197. package/dist/benchmark/reproducible.js.map +0 -1
  198. package/dist/cache/prefixCache.d.ts.map +0 -1
  199. package/dist/cache/prefixCache.js.map +0 -1
  200. package/dist/cache/responseCache.d.ts.map +0 -1
  201. package/dist/cache/responseCache.js.map +0 -1
  202. package/dist/cache/semanticCache.d.ts.map +0 -1
  203. package/dist/cache/semanticCache.js.map +0 -1
  204. package/dist/cli/setupWizard.d.ts.map +0 -1
  205. package/dist/cli/setupWizard.js.map +0 -1
  206. package/dist/cost/budgetEnforcer.d.ts.map +0 -1
  207. package/dist/cost/budgetEnforcer.js.map +0 -1
  208. package/dist/cost/costTracker.d.ts.map +0 -1
  209. package/dist/cost/costTracker.js.map +0 -1
  210. package/dist/ensemble/multiRoundDialog.js.map +0 -1
  211. package/dist/ensemble/shapleyValue.js.map +0 -1
  212. package/dist/integrations/langchainAdapter.d.ts.map +0 -1
  213. package/dist/integrations/langchainAdapter.js.map +0 -1
  214. package/dist/integrations/oauth.d.ts.map +0 -1
  215. package/dist/integrations/oauth.js.map +0 -1
  216. package/dist/integrations/scienceAdapter.js.map +0 -1
  217. package/dist/memory/autoFetch.d.ts.map +0 -1
  218. package/dist/memory/autoFetch.js.map +0 -1
  219. package/dist/memory/episodicMemory.d.ts.map +0 -1
  220. package/dist/memory/episodicMemory.js.map +0 -1
  221. package/dist/memory/hybridMemory.js.map +0 -1
  222. package/dist/memory/memoryTree.d.ts.map +0 -1
  223. package/dist/memory/memoryTree.js.map +0 -1
  224. package/dist/memory/obsidianVault.d.ts.map +0 -1
  225. package/dist/memory/obsidianVault.js.map +0 -1
  226. package/dist/memory/reasoningBank.js.map +0 -1
  227. package/dist/observability/changeWatch.d.ts.map +0 -1
  228. package/dist/observability/changeWatch.js.map +0 -1
  229. package/dist/observability/fatigueDetector.d.ts.map +0 -1
  230. package/dist/observability/fatigueDetector.js.map +0 -1
  231. package/dist/observability/index.d.ts.map +0 -1
  232. package/dist/observability/index.js.map +0 -1
  233. package/dist/observability/metrics.d.ts.map +0 -1
  234. package/dist/observability/metrics.js.map +0 -1
  235. package/dist/observability/middleware.d.ts.map +0 -1
  236. package/dist/observability/middleware.js.map +0 -1
  237. package/dist/observability/tracer.d.ts.map +0 -1
  238. package/dist/observability/tracer.js.map +0 -1
  239. package/dist/observability/types.d.ts.map +0 -1
  240. package/dist/observability/types.js.map +0 -1
  241. package/dist/orchestration/haloOrchestrator.d.ts.map +0 -1
  242. package/dist/orchestration/haloOrchestrator.js.map +0 -1
  243. package/dist/orchestration/mctsWorkflow.d.ts.map +0 -1
  244. package/dist/orchestration/mctsWorkflow.js.map +0 -1
  245. package/dist/providers/localProvider.d.ts.map +0 -1
  246. package/dist/providers/localProvider.js.map +0 -1
  247. package/dist/providers/providerConfig.d.ts.map +0 -1
  248. package/dist/providers/providerConfig.js.map +0 -1
  249. package/dist/providers/registry.d.ts.map +0 -1
  250. package/dist/providers/registry.js.map +0 -1
  251. package/dist/routing/advancedRouter.d.ts.map +0 -1
  252. package/dist/routing/advancedRouter.js.map +0 -1
  253. package/dist/routing/crossModelValidation.d.ts.map +0 -1
  254. package/dist/routing/crossModelValidation.js.map +0 -1
  255. package/dist/routing/providerHealth.d.ts.map +0 -1
  256. package/dist/routing/providerHealth.js.map +0 -1
  257. package/dist/routing/providerRetry.d.ts.map +0 -1
  258. package/dist/routing/providerRetry.js.map +0 -1
  259. package/dist/scripts/banner.js +0 -29
  260. package/dist/security/guardrails.d.ts.map +0 -1
  261. package/dist/security/guardrails.js.map +0 -1
  262. package/dist/server/dashboard.d.ts.map +0 -1
  263. package/dist/server/dashboard.js.map +0 -1
  264. package/dist/server/modelMapper.d.ts.map +0 -1
  265. package/dist/server/modelMapper.js.map +0 -1
  266. package/dist/server/proxyServer.d.ts.map +0 -1
  267. package/dist/server/proxyServer.js.map +0 -1
  268. package/dist/skills/__tests__/skill_manager.test.d.ts +0 -2
  269. package/dist/skills/__tests__/skill_manager.test.d.ts.map +0 -1
  270. package/dist/skills/__tests__/skill_manager.test.js +0 -268
  271. package/dist/skills/__tests__/skill_manager.test.js.map +0 -1
  272. package/dist/tools/tmlpdTools.d.ts.map +0 -1
  273. package/dist/tools/tmlpdTools.js.map +0 -1
  274. package/dist/tui/dashboard.d.ts.map +0 -1
  275. package/dist/tui/dashboard.js.map +0 -1
  276. package/dist/tui/index.d.ts.map +0 -1
  277. package/dist/tui/index.js.map +0 -1
  278. package/dist/utils/batchProcessor.d.ts.map +0 -1
  279. package/dist/utils/batchProcessor.js.map +0 -1
  280. package/dist/utils/compression.d.ts.map +0 -1
  281. package/dist/utils/compression.js.map +0 -1
  282. package/dist/utils/costUtils.d.ts.map +0 -1
  283. package/dist/utils/costUtils.js.map +0 -1
  284. package/dist/utils/reliability.d.ts.map +0 -1
  285. package/dist/utils/reliability.js.map +0 -1
  286. package/dist/utils/sorting.d.ts.map +0 -1
  287. package/dist/utils/sorting.js.map +0 -1
  288. package/dist/utils/speculativeDecoding.d.ts.map +0 -1
  289. package/dist/utils/speculativeDecoding.js.map +0 -1
  290. package/dist/utils/tokenUtils.d.ts.map +0 -1
  291. package/dist/utils/tokenUtils.js.map +0 -1
  292. package/docs/.nojekyll +0 -0
  293. package/docs/ANALYSIS_PRINCIPLES.md +0 -162
  294. package/docs/API.md +0 -855
  295. package/docs/ARCHITECTURAL-IMPROVEMENTS-2025.md +0 -1391
  296. package/docs/ARCHITECTURAL-IMPROVEMENTS-REVISED-2025.md +0 -1051
  297. package/docs/BENCHMARK.md +0 -170
  298. package/docs/CHINESE_PROVIDER_RELIABILITY.md +0 -37
  299. package/docs/CITATIONS.md +0 -74
  300. package/docs/CLAIMS_AND_EVIDENCE.md +0 -58
  301. package/docs/CONFIGURATION.md +0 -476
  302. package/docs/COUNCIL_DECISION.json +0 -816
  303. package/docs/COUNCIL_SUMMARY.md +0 -319
  304. package/docs/COUNCIL_V2.2_DECISION.md +0 -416
  305. package/docs/ENGINEERING_SPEC.md +0 -55
  306. package/docs/FACTORY_RESET.md +0 -34
  307. package/docs/GEO.md +0 -66
  308. package/docs/GEO_OPTIMIZATION.md +0 -30
  309. package/docs/GEO_ROOT_CAUSE.md +0 -136
  310. package/docs/GEO_STATUS.md +0 -85
  311. package/docs/GEO_TEST_RESULTS.md +0 -176
  312. package/docs/HN_CHECKLIST.md +0 -38
  313. package/docs/HN_FOUNDER_COMMENT.md +0 -17
  314. package/docs/HN_SUBMISSION_FINAL.md +0 -180
  315. package/docs/HN_SUBMISSION_V3.md +0 -56
  316. package/docs/IMPROVEMENT_ROADMAP.md +0 -515
  317. package/docs/INTEGRATIONS.md +0 -420
  318. package/docs/LANGCHAIN_INTEGRATION.md +0 -147
  319. package/docs/LLM_COUNCIL_DECISION.md +0 -508
  320. package/docs/MIDDLEWARE_CHAIN.md +0 -35
  321. package/docs/PROMO_CHECKLIST.md +0 -200
  322. package/docs/QUICKSTART.md +0 -271
  323. package/docs/QUICK_START.md +0 -43
  324. package/docs/QUICK_START_VISIBILITY.md +0 -782
  325. package/docs/REDDIT_GAP_ANALYSIS.md +0 -299
  326. package/docs/RELEASE_CHECKLIST.md +0 -32
  327. package/docs/REPRODUCIBILITY.md +0 -63
  328. package/docs/RESEARCH_BACKED_IMPROVEMENTS.md +0 -1180
  329. package/docs/ROUTING_RUBRIC.md +0 -197
  330. package/docs/SEO_AUDIT.md +0 -186
  331. package/docs/SOCIAL_LISTENING.md +0 -219
  332. package/docs/TMLPD_QNA.md +0 -751
  333. package/docs/TMLPD_V2.1_COMPLETE.md +0 -763
  334. package/docs/TMLPD_V2.2_RESEARCH_ROADMAP.md +0 -754
  335. package/docs/UPDATE_TOPICS.md +0 -15
  336. package/docs/USE_CASES.md +0 -59
  337. package/docs/V2.2_IMPLEMENTATION_COMPLETE.md +0 -446
  338. package/docs/V2_IMPLEMENTATION_GUIDE.md +0 -388
  339. package/docs/VERCEL_AI_SDK.md +0 -209
  340. package/docs/VISIBILITY_ADOPTION_PLAN.md +0 -1005
  341. package/docs/_config.yml +0 -49
  342. package/docs/ai-plugin.json +0 -16
  343. package/docs/api.html +0 -513
  344. package/docs/architecture-diagram.md +0 -40
  345. package/docs/benchmark-chart.png +0 -0
  346. package/docs/benchmark.html +0 -387
  347. package/docs/blog/routerarena-number-one.html +0 -73
  348. package/docs/cli-cheatsheet.md +0 -339
  349. package/docs/compare.md +0 -109
  350. package/docs/comparison-litellm.md +0 -88
  351. package/docs/comparison.md +0 -108
  352. package/docs/cost-chart-ascii.md +0 -42
  353. package/docs/cost-comparison-chart.svg +0 -88
  354. package/docs/curl-examples.md +0 -247
  355. package/docs/demo-auto.html +0 -264
  356. package/docs/demo.html +0 -416
  357. package/docs/geo/GENERATIVE_ENGINE_OPTIMIZATION.md +0 -232
  358. package/docs/index.html +0 -507
  359. package/docs/launch-content/LAUNCH_EXECUTION_CHECKLIST.md +0 -421
  360. package/docs/launch-content/README.md +0 -457
  361. package/docs/launch-content/assets/cost_comparison_100_tasks.png +0 -0
  362. package/docs/launch-content/assets/cumulative_savings.png +0 -0
  363. package/docs/launch-content/assets/parallel_speedup.png +0 -0
  364. package/docs/launch-content/assets/provider_pricing_comparison.png +0 -0
  365. package/docs/launch-content/assets/task_breakdown_comparison.png +0 -0
  366. package/docs/launch-content/generate_charts.py +0 -313
  367. package/docs/launch-content/hn_show_post.md +0 -139
  368. package/docs/launch-content/partner_outreach_templates.md +0 -745
  369. package/docs/launch-content/reddit_posts.md +0 -467
  370. package/docs/launch-content/twitter_thread.txt +0 -460
  371. package/docs/npm-downloads-chart.svg +0 -43
  372. package/docs/openapi.json +0 -139
  373. package/docs/openapi.yaml +0 -1318
  374. package/docs/quick-start.html +0 -366
  375. package/docs/robots.txt +0 -52
  376. package/docs/sitemap.xml +0 -57
  377. package/docs/styles.css +0 -682
  378. package/docs/well-known/ai-plugin.json +0 -16
  379. package/docs/wellknown/ai-plugin.json +0 -16
  380. package/docs-site/assets/og-banner.svg +0 -194
  381. package/docs-site/index.html +0 -632
  382. package/eval/README.md +0 -46
  383. package/eval/baselines/main.json +0 -12
  384. package/eval/benchmark_dataset.jsonl +0 -16
  385. package/eval/check_golden_routes.js +0 -64
  386. package/eval/datasets/catalog.json +0 -33
  387. package/eval/datasets/slices/cn_provider_reliability_v1.jsonl +0 -3
  388. package/eval/datasets/slices/cost_pressure_v1.jsonl +0 -3
  389. package/eval/datasets/slices/safety_guardrails_v1.jsonl +0 -3
  390. package/eval/evals.json +0 -199
  391. package/eval/fault_injection_thresholds.json +0 -3
  392. package/eval/generate_report.js +0 -128
  393. package/eval/golden_routes.json +0 -114
  394. package/eval/lib/experiment_registry.js +0 -24
  395. package/eval/run_eval.js +0 -197
  396. package/eval/run_fault_injection.js +0 -201
  397. package/eval/run_shadow_eval.js +0 -85
  398. package/eval/thresholds.json +0 -9
  399. package/examples/QUICKSTART.md +0 -183
  400. package/examples/README.md +0 -61
  401. package/examples/a3m-sdk.js +0 -124
  402. package/examples/basic-route.js +0 -54
  403. package/examples/chat-loop.js +0 -202
  404. package/examples/classify-then-route.js +0 -102
  405. package/examples/cost-compare.js +0 -120
  406. package/examples/ensemble.js +0 -160
  407. package/examples/whatsapp-telegram-bridge-demo.js +0 -302
  408. package/examples/whatsapp-telegram-bridge.js +0 -269
  409. package/hf-space/README.md +0 -23
  410. package/hf-space/app.py +0 -240
  411. package/hf-space/requirements.txt +0 -1
  412. package/huggingface_space/README.md +0 -35
  413. package/huggingface_space/app.py +0 -126
  414. package/huggingface_space/create_space.py +0 -208
  415. package/huggingface_space/requirements.txt +0 -1
  416. package/mcp-server/README.md +0 -188
  417. package/mcp-server/package.json +0 -29
  418. package/mcp-server/src/index.ts +0 -744
  419. package/mcp-server/tsconfig.json +0 -19
  420. package/openclaw-alexa-bridge/ALL_REMAINING_FIXES_PLAN.md +0 -313
  421. package/openclaw-alexa-bridge/REMAINING_FIXES_SUMMARY.md +0 -277
  422. package/openclaw-alexa-bridge/src/alexa_handler_no_tmlpd.js +0 -1234
  423. package/openclaw-alexa-bridge/test_fixes.js +0 -77
  424. package/playground/README.md +0 -51
  425. package/playground/codesandbox.json +0 -12
  426. package/playground/index.js +0 -39
  427. package/proxy/README.md +0 -227
  428. package/proxy/package-lock.json +0 -831
  429. package/proxy/package.json +0 -17
  430. package/proxy/rate-limit.js +0 -145
  431. package/proxy/rate-limit.test.js +0 -311
  432. package/proxy/server.js +0 -970
  433. package/python/README.md +0 -102
  434. package/python/a3m/__init__.py +0 -6
  435. package/python/a3m/client.py +0 -190
  436. package/python/a3m/models.py +0 -40
  437. package/python/a3m/sync_client.py +0 -61
  438. package/python/examples.py +0 -53
  439. package/python/integrations.py +0 -330
  440. package/python/pyproject.toml +0 -23
  441. package/python/setup.py +0 -28
  442. package/python/tmlpd.py +0 -369
  443. package/qna/REDDIT_GAP_ANALYSIS.md +0 -299
  444. package/qna/TMLPD_QNA.md +0 -751
  445. package/research/FINDING_001_safety.md +0 -28
  446. package/research/FINDING_002_error_diversity.md +0 -32
  447. package/research/FINDING_003_confidence_weighted_voting.md +0 -32
  448. package/research/FINDING_004_cross_model_semantic_detection.md +0 -37
  449. package/research/FINDING_005_knowledge_gap_orthogonality.md +0 -34
  450. package/research/HALLUCINATION_RESEARCH.md +0 -27
  451. package/research/ensemble-voting.md +0 -324
  452. package/research/loss-functions.md +0 -545
  453. package/research-log.md +0 -49
  454. package/scripts/banner.js +0 -29
  455. package/scripts/benchmark-local-routerarena.ts +0 -176
  456. package/scripts/benchmark.js +0 -145
  457. package/scripts/benchmark.sh +0 -61
  458. package/scripts/compare-providers.sh +0 -230
  459. package/scripts/content-planner.js +0 -25
  460. package/scripts/create-labeled-benchmark.ts +0 -105
  461. package/scripts/cross_post.py +0 -443
  462. package/scripts/local-router-benchmark.ts +0 -154
  463. package/scripts/post-all.sh +0 -41
  464. package/scripts/publish_fcc.py +0 -106
  465. package/scripts/push-to-gitee.sh +0 -25
  466. package/scripts/routerarena_ensemble.js +0 -144
  467. package/scripts/routing-benchmark-v2.js +0 -373
  468. package/scripts/routing-benchmark-v3.js +0 -118
  469. package/scripts/routing-benchmark.js +0 -462
  470. package/scripts/run-labeled-benchmark.mjs +0 -104
  471. package/scripts/run-mmlu-benchmark.js +0 -176
  472. package/scripts/run-provider-benchmark.js +0 -244
  473. package/scripts/update-npm-badges.js +0 -158
  474. package/skill/SKILL.md +0 -238
  475. package/src/__tests__/integration/tmpld_integration.test.py +0 -540
  476. package/src/skills/__tests__/skill_manager.test.ts +0 -328
  477. package/submissions/benchmarks/ALL_PLATFORMS_SUBMISSION.md +0 -94
  478. package/submissions/benchmarks/LLMROUTERBENCH_SUBMISSION.md +0 -121
  479. package/submissions/benchmarks/MMRBENCH_SUBMISSION.md +0 -94
  480. package/submissions/benchmarks/ROUTERARENA_UPDATE.md +0 -83
  481. package/submissions/benchmarks/ROUTERBENCH_SUBMISSION.md +0 -225
  482. package/test-council/1-structure-tests.test.js +0 -353
  483. package/test-council/1-structure-tests.test.ts +0 -353
  484. package/test-council/2-edge-case-tests.test.ts +0 -361
  485. package/test-council/3-performance-tests.test.ts +0 -669
  486. package/test-council/4-integration-tests.test.ts +0 -391
  487. package/test-council/5-agent-council-eval.test.ts +0 -413
  488. package/test-council/AGENT_COUNCIL_ARCHITECTURE.md +0 -349
  489. package/test-council/TEST_COUNCIL_REPORT.md +0 -201
  490. package/test-council/agents/edge-case-agent.ts +0 -363
  491. package/test-council/agents/performance-agent.ts +0 -426
  492. package/test-council/agents/structure-agent.ts +0 -227
  493. package/test-council/council.md +0 -183
  494. package/tests/__mocks__/tokenUtils.ts +0 -8
  495. package/tests/memory/episodicMemory.test.ts +0 -227
  496. package/tests/package-lock.json +0 -1628
  497. package/tests/package.json +0 -18
  498. package/tests/routing/ensembleVoting.test.ts +0 -236
  499. package/tests/routing/providerRetry.test.ts +0 -360
  500. package/tests/routing/queryTypePresets.test.ts +0 -208
  501. package/tests/security/guardrailEngine.test.ts +0 -700
  502. package/tests/tsconfig.json +0 -21
  503. package/tests/vitest.config.ts +0 -18
  504. package/tmlpd-pi-extension/README.md +0 -66
  505. package/tmlpd-pi-extension/dist/cache/prefixCache.d.ts +0 -114
  506. package/tmlpd-pi-extension/dist/cache/prefixCache.d.ts.map +0 -1
  507. package/tmlpd-pi-extension/dist/cache/prefixCache.js +0 -285
  508. package/tmlpd-pi-extension/dist/cache/prefixCache.js.map +0 -1
  509. package/tmlpd-pi-extension/dist/cache/responseCache.d.ts +0 -58
  510. package/tmlpd-pi-extension/dist/cache/responseCache.d.ts.map +0 -1
  511. package/tmlpd-pi-extension/dist/cache/responseCache.js +0 -153
  512. package/tmlpd-pi-extension/dist/cache/responseCache.js.map +0 -1
  513. package/tmlpd-pi-extension/dist/cli.js +0 -59
  514. package/tmlpd-pi-extension/dist/cost/costTracker.d.ts +0 -95
  515. package/tmlpd-pi-extension/dist/cost/costTracker.d.ts.map +0 -1
  516. package/tmlpd-pi-extension/dist/cost/costTracker.js +0 -240
  517. package/tmlpd-pi-extension/dist/cost/costTracker.js.map +0 -1
  518. package/tmlpd-pi-extension/dist/index.d.ts +0 -723
  519. package/tmlpd-pi-extension/dist/index.d.ts.map +0 -1
  520. package/tmlpd-pi-extension/dist/index.js +0 -239
  521. package/tmlpd-pi-extension/dist/index.js.map +0 -1
  522. package/tmlpd-pi-extension/dist/memory/episodicMemory.d.ts +0 -82
  523. package/tmlpd-pi-extension/dist/memory/episodicMemory.d.ts.map +0 -1
  524. package/tmlpd-pi-extension/dist/memory/episodicMemory.js +0 -145
  525. package/tmlpd-pi-extension/dist/memory/episodicMemory.js.map +0 -1
  526. package/tmlpd-pi-extension/dist/orchestration/haloOrchestrator.d.ts +0 -102
  527. package/tmlpd-pi-extension/dist/orchestration/haloOrchestrator.d.ts.map +0 -1
  528. package/tmlpd-pi-extension/dist/orchestration/haloOrchestrator.js +0 -207
  529. package/tmlpd-pi-extension/dist/orchestration/haloOrchestrator.js.map +0 -1
  530. package/tmlpd-pi-extension/dist/orchestration/mctsWorkflow.d.ts +0 -85
  531. package/tmlpd-pi-extension/dist/orchestration/mctsWorkflow.d.ts.map +0 -1
  532. package/tmlpd-pi-extension/dist/orchestration/mctsWorkflow.js +0 -210
  533. package/tmlpd-pi-extension/dist/orchestration/mctsWorkflow.js.map +0 -1
  534. package/tmlpd-pi-extension/dist/providers/localProvider.d.ts +0 -102
  535. package/tmlpd-pi-extension/dist/providers/localProvider.d.ts.map +0 -1
  536. package/tmlpd-pi-extension/dist/providers/localProvider.js +0 -338
  537. package/tmlpd-pi-extension/dist/providers/localProvider.js.map +0 -1
  538. package/tmlpd-pi-extension/dist/providers/registry.d.ts +0 -55
  539. package/tmlpd-pi-extension/dist/providers/registry.d.ts.map +0 -1
  540. package/tmlpd-pi-extension/dist/providers/registry.js +0 -138
  541. package/tmlpd-pi-extension/dist/providers/registry.js.map +0 -1
  542. package/tmlpd-pi-extension/dist/routing/advancedRouter.d.ts +0 -68
  543. package/tmlpd-pi-extension/dist/routing/advancedRouter.d.ts.map +0 -1
  544. package/tmlpd-pi-extension/dist/routing/advancedRouter.js +0 -332
  545. package/tmlpd-pi-extension/dist/routing/advancedRouter.js.map +0 -1
  546. package/tmlpd-pi-extension/dist/tools/tmlpdTools.d.ts +0 -101
  547. package/tmlpd-pi-extension/dist/tools/tmlpdTools.d.ts.map +0 -1
  548. package/tmlpd-pi-extension/dist/tools/tmlpdTools.js +0 -368
  549. package/tmlpd-pi-extension/dist/tools/tmlpdTools.js.map +0 -1
  550. package/tmlpd-pi-extension/dist/utils/batchProcessor.d.ts +0 -96
  551. package/tmlpd-pi-extension/dist/utils/batchProcessor.d.ts.map +0 -1
  552. package/tmlpd-pi-extension/dist/utils/batchProcessor.js +0 -170
  553. package/tmlpd-pi-extension/dist/utils/batchProcessor.js.map +0 -1
  554. package/tmlpd-pi-extension/dist/utils/compression.d.ts +0 -61
  555. package/tmlpd-pi-extension/dist/utils/compression.d.ts.map +0 -1
  556. package/tmlpd-pi-extension/dist/utils/compression.js +0 -281
  557. package/tmlpd-pi-extension/dist/utils/compression.js.map +0 -1
  558. package/tmlpd-pi-extension/dist/utils/reliability.d.ts +0 -74
  559. package/tmlpd-pi-extension/dist/utils/reliability.d.ts.map +0 -1
  560. package/tmlpd-pi-extension/dist/utils/reliability.js +0 -177
  561. package/tmlpd-pi-extension/dist/utils/reliability.js.map +0 -1
  562. package/tmlpd-pi-extension/dist/utils/speculativeDecoding.d.ts +0 -117
  563. package/tmlpd-pi-extension/dist/utils/speculativeDecoding.d.ts.map +0 -1
  564. package/tmlpd-pi-extension/dist/utils/speculativeDecoding.js +0 -246
  565. package/tmlpd-pi-extension/dist/utils/speculativeDecoding.js.map +0 -1
  566. package/tmlpd-pi-extension/dist/utils/tokenUtils.d.ts +0 -50
  567. package/tmlpd-pi-extension/dist/utils/tokenUtils.d.ts.map +0 -1
  568. package/tmlpd-pi-extension/dist/utils/tokenUtils.js +0 -124
  569. package/tmlpd-pi-extension/dist/utils/tokenUtils.js.map +0 -1
  570. package/tmlpd-pi-extension/examples/QUICKSTART.md +0 -183
  571. package/tmlpd-pi-extension/package-lock.json +0 -79
  572. package/tmlpd-pi-extension/package.json +0 -172
  573. package/tmlpd-pi-extension/python/examples.py +0 -53
  574. package/tmlpd-pi-extension/python/integrations.py +0 -330
  575. package/tmlpd-pi-extension/python/setup.py +0 -28
  576. package/tmlpd-pi-extension/python/tmlpd.py +0 -369
  577. package/tmlpd-pi-extension/qna/REDDIT_GAP_ANALYSIS.md +0 -299
  578. package/tmlpd-pi-extension/qna/TMLPD_QNA.md +0 -751
  579. package/tmlpd-pi-extension/skill/SKILL.md +0 -238
  580. package/tmlpd-pi-extension/src/cache/responseCache.ts +0 -147
  581. package/tmlpd-pi-extension/src/cost/costTracker.ts +0 -302
  582. package/tmlpd-pi-extension/src/index.ts +0 -232
  583. package/tmlpd-pi-extension/src/memory/episodicMemory.ts +0 -257
  584. package/tmlpd-pi-extension/src/orchestration/haloOrchestrator.ts +0 -266
  585. package/tmlpd-pi-extension/src/orchestration/mctsWorkflow.ts +0 -262
  586. package/tmlpd-pi-extension/src/providers/localProvider.ts +0 -406
  587. package/tmlpd-pi-extension/src/providers/registry.ts +0 -164
  588. package/tmlpd-pi-extension/src/routing/ensembleVoting.ts +0 -159
  589. package/tmlpd-pi-extension/src/routing/queryTypePresets.ts +0 -136
  590. package/tmlpd-pi-extension/src/tools/tmlpdTools.ts +0 -433
  591. package/tmlpd-pi-extension/src/utils/batchProcessor.ts +0 -232
  592. package/tmlpd-pi-extension/src/utils/compression.ts +0 -325
  593. package/tmlpd-pi-extension/src/utils/reliability.ts +0 -221
  594. package/tmlpd-pi-extension/src/utils/tokenUtils.ts +0 -145
  595. package/tmlpd-pi-extension/tsconfig.json +0 -18
  596. package/tsconfig.build.json +0 -29
  597. package/tsconfig.json +0 -18
  598. /package/{docs/llms-full.txt → llms-full.txt.bak} +0 -0
@@ -1,47 +0,0 @@
1
- {
2
- "timestamp": "2026-06-07T22:37:49.653Z",
3
- "version": "2.14.44",
4
- "routing": {
5
- "total": 81,
6
- "correct": 29,
7
- "accuracy": 35.8,
8
- "offByOne": 66,
9
- "offByOneAccuracy": 81.5,
10
- "totalCost": 53.7775,
11
- "avgCost": 0.66392,
12
- "perTier": {
13
- "free": {
14
- "total": 20,
15
- "correct": 20
16
- },
17
- "cheap": {
18
- "total": 21,
19
- "correct": 0
20
- },
21
- "mid": {
22
- "total": 20,
23
- "correct": 9
24
- },
25
- "premium": {
26
- "total": 20,
27
- "correct": 0
28
- }
29
- }
30
- },
31
- "memory": {
32
- "total": 4,
33
- "passed": 4,
34
- "accuracy": 100
35
- },
36
- "robustness": {
37
- "total": 6,
38
- "passed": 6,
39
- "accuracy": 100
40
- },
41
- "cost": {
42
- "avgSavingsPct": -6587,
43
- "totalA3m": 4.34,
44
- "totalPremium": 0.107
45
- },
46
- "overallScore": -1925
47
- }
@@ -1,88 +0,0 @@
1
- {
2
- "queries": [
3
- {"query": "What is 2+2?", "actualTier": "free"},
4
- {"query": "What is the capital of France?", "actualTier": "free"},
5
- {"query": "How do you say hello in Spanish?", "actualTier": "free"},
6
- {"query": "Convert 100 Celsius to Fahrenheit", "actualTier": "free"},
7
- {"query": "What is the largest planet in the solar system?", "actualTier": "free"},
8
- {"query": "How many ounces in a pound?", "actualTier": "free"},
9
- {"query": "What is the speed of light?", "actualTier": "free"},
10
- {"query": "Who wrote Romeo and Juliet?", "actualTier": "free"},
11
- {"query": "What is photosynthesis?", "actualTier": "free"},
12
- {"query": "What is the square root of 144?", "actualTier": "free"},
13
- {"query": "Name three primary colors", "actualTier": "free"},
14
- {"query": "What is the chemical symbol for gold?", "actualTier": "free"},
15
- {"query": "How many continents are there?", "actualTier": "free"},
16
- {"query": "What is gravity?", "actualTier": "free"},
17
- {"query": "Define 'ubiquitous'", "actualTier": "free"},
18
- {"query": "What does 'benevolent' mean?", "actualTier": "free"},
19
- {"query": "How many bytes in a kilobyte?", "actualTier": "free"},
20
- {"query": "What is H2O commonly known as?", "actualTier": "free"},
21
- {"query": "Translate 'good morning' to French", "actualTier": "free"},
22
- {"query": "What is the time in Tokyo?", "actualTier": "free"},
23
-
24
- {"query": "Write a Python function to sort a list", "actualTier": "cheap"},
25
- {"query": "Explain the difference between TCP and UDP", "actualTier": "cheap"},
26
- {"query": "Write a SQL query to find duplicate records", "actualTier": "cheap"},
27
- {"query": "Create a REST API endpoint in Express.js", "actualTier": "cheap"},
28
- {"query": "Explain Docker containers vs virtual machines", "actualTier": "cheap"},
29
- {"query": "Write a regex to validate email addresses", "actualTier": "cheap"},
30
- {"query": "How do I reverse a string in JavaScript?", "actualTier": "cheap"},
31
- {"query": "Write a for loop in Python", "actualTier": "cheap"},
32
- {"query": "What is the difference between let and const in JavaScript?", "actualTier": "cheap"},
33
- {"query": "Explain what an API is to a non-technical person", "actualTier": "cheap"},
34
- {"query": "How do I center a div in CSS?", "actualTier": "cheap"},
35
- {"query": "Write a basic HTML form", "actualTier": "cheap"},
36
- {"query": "Explain git merge vs rebase", "actualTier": "cheap"},
37
- {"query": "What is a RESTful API?", "actualTier": "cheap"},
38
- {"query": "How do I read a file in Node.js?", "actualTier": "cheap"},
39
- {"query": "Write a simple unit test in Jest", "actualTier": "cheap"},
40
- {"query": "Explain what a database index does", "actualTier": "cheap"},
41
- {"query": "How do I parse JSON in Python?", "actualTier": "cheap"},
42
- {"query": "Write a Python script to send an email", "actualTier": "cheap"},
43
- {"query": "Create a simple login form in HTML/CSS", "actualTier": "cheap"},
44
- {"query": "How do I make an HTTP request in JavaScript?", "actualTier": "cheap"},
45
-
46
- {"query": "Design a REST API for a blog with users, posts, and comments", "actualTier": "mid"},
47
- {"query": "Explain how OAuth 2.0 authentication works", "actualTier": "mid"},
48
- {"query": "Design a rate limiting system for a web API", "actualTier": "mid"},
49
- {"query": "How would you implement a caching layer for a web application?", "actualTier": "mid"},
50
- {"query": "Compare and contrast SQL and NoSQL databases", "actualTier": "mid"},
51
- {"query": "Design a user authentication system with JWT tokens", "actualTier": "mid"},
52
- {"query": "Explain the CAP theorem and its implications", "actualTier": "mid"},
53
- {"query": "How do you design a URL shortening service like bit.ly?", "actualTier": "mid"},
54
- {"query": "Design a real-time notification system", "actualTier": "mid"},
55
- {"query": "Explain the pros and cons of microservices vs monolith", "actualTier": "mid"},
56
- {"query": "How would you implement search functionality in a web app?", "actualTier": "mid"},
57
- {"query": "Design a payment processing system", "actualTier": "mid"},
58
- {"query": "Explain how blockchain achieves consensus", "actualTier": "mid"},
59
- {"query": "Design a multi-tenant SaaS architecture", "actualTier": "mid"},
60
- {"query": "How do you handle database migrations in production?", "actualTier": "mid"},
61
- {"query": "Design a logging and monitoring system", "actualTier": "mid"},
62
- {"query": "Explain load balancing algorithms", "actualTier": "mid"},
63
- {"query": "How would you design a file upload system?", "actualTier": "mid"},
64
- {"query": "Design a chat application with WebSockets", "actualTier": "mid"},
65
- {"query": "Explain event-driven architecture patterns", "actualTier": "mid"},
66
-
67
- {"query": "Design a distributed system that handles 10 million requests per second", "actualTier": "premium"},
68
- {"query": "Architect a real-time collaboration system like Google Docs", "actualTier": "premium"},
69
- {"query": "Design a machine learning pipeline from data ingestion to model serving", "actualTier": "premium"},
70
- {"query": "Create a comprehensive technical design for a social media platform at scale", "actualTier": "premium"},
71
- {"query": "Design a zero-downtime deployment strategy for a distributed system", "actualTier": "premium"},
72
- {"query": "Architect a system that processes streaming data with sub-second latency", "actualTier": "premium"},
73
- {"query": "Design a fraud detection system using machine learning", "actualTier": "premium"},
74
- {"query": "Create an architecture for a global CDN with edge computing", "actualTier": "premium"},
75
- {"query": "Design a multi-region active-active database architecture", "actualTier": "premium"},
76
- {"query": "Architect a system for real-time video transcoding at scale", "actualTier": "premium"},
77
- {"query": "Design a privacy-preserving data analytics system", "actualTier": "premium"},
78
- {"query": "Create a comprehensive security architecture for a fintech application", "actualTier": "premium"},
79
- {"query": "Design a system that handles 1 billion events per day", "actualTier": "premium"},
80
- {"query": "Architect a serverless system with consistent performance", "actualTier": "premium"},
81
- {"query": "Design a data warehouse architecture for petabyte-scale analytics", "actualTier": "premium"},
82
- {"query": "Create a multi-cloud hybrid architecture strategy", "actualTier": "premium"},
83
- {"query": "Design a system for real-time anomaly detection in financial transactions", "actualTier": "premium"},
84
- {"query": "Architect a mesh network for IoT at scale", "actualTier": "premium"},
85
- {"query": "Design a comprehensive disaster recovery strategy", "actualTier": "premium"},
86
- {"query": "Create an architecture for autonomous vehicle sensor fusion", "actualTier": "premium"}
87
- ]
88
- }
@@ -1,285 +0,0 @@
1
- #!/usr/bin/env python3
2
- """
3
- A3M Router — 3Blue1Brown Style Explainer Video Generator
4
-
5
- Creates animated frames showing:
6
- 1. The problem: expensive AI routing
7
- 2. The solution: intelligent routing
8
- 3. How it works: 12 signals
9
- 4. Results: 76.43 score, 213x cheaper
10
-
11
- Usage:
12
- python3 demo/3blue1brown_video.py
13
- """
14
-
15
- import subprocess
16
- import json
17
- import sys
18
- import math
19
- import os
20
-
21
- # Check dependencies
22
- def check_deps():
23
- try:
24
- import matplotlib
25
- import numpy
26
- print("āœ… matplotlib, numpy available")
27
- return True
28
- except ImportError as e:
29
- print(f"āŒ Missing: {e}")
30
- print("Install: pip install matplotlib numpy pillow")
31
- return False
32
-
33
- def run_command(cmd, cwd=None):
34
- result = subprocess.run(cmd, shell=True, capture_output=True, text=True, cwd=cwd)
35
- return result.returncode == 0, result.stdout, result.stderr
36
-
37
- # Frame definitions - each scene
38
- SCENES = [
39
- {
40
- "id": 1,
41
- "title": "The AI Cost Problem",
42
- "content": "Every AI query goes to GPT-4\n$10.02 per 1,000 queries",
43
- "visual": "gpt4_cost_visual",
44
- "duration": 3.0
45
- },
46
- {
47
- "id": 2,
48
- "title": "The Solution",
49
- "content": "Route queries intelligently\nto the cheapest capable model",
50
- "visual": "routing_diagram",
51
- "duration": 3.0
52
- },
53
- {
54
- "id": 3,
55
- "title": "How A3M Routes",
56
- "content": "12 signals → instant decision\n<1ms, no GPU needed",
57
- "visual": "signals_animation",
58
- "duration": 4.0
59
- },
60
- {
61
- "id": 4,
62
- "title": "The Result",
63
- "content": "#1 on RouterArena\n76.43 accuracy at $0.047/1K",
64
- "visual": "benchmark_reveal",
65
- "duration": 3.0
66
- },
67
- {
68
- "id": 5,
69
- "title": "213x Cheaper",
70
- "content": "vs GPT-5: $10.02 → $0.047\nSame quality, 1/213th the cost",
71
- "visual": "cost_comparison",
72
- "duration": 3.0
73
- }
74
- ]
75
-
76
- def generate_frame_matplotlib(scene_num, frame_num, total_frames, output_path):
77
- """Generate a single frame using matplotlib"""
78
- import matplotlib.pyplot as plt
79
- import matplotlib.patches as patches
80
- import numpy as np
81
-
82
- # 3Blue1Brown color scheme
83
- bg_color = '#1a1a2e'
84
- text_color = '#ffffff'
85
- accent1 = '#00a8ff' # Blue
86
- accent2 = '#ff6b6b' # Red
87
- accent3 = '#4ecdc4' # Teal
88
- accent4 = '#ffe66d' # Yellow
89
-
90
- fig, ax = plt.subplots(figsize=(16, 9), facecolor=bg_color)
91
- ax.set_facecolor(bg_color)
92
- ax.set_xlim(0, 16)
93
- ax.set_ylim(0, 9)
94
- ax.axis('off')
95
-
96
- if scene_num == 1:
97
- # Scene 1: GPT-4 cost visualization
98
- # Big "$10.02" in center
99
- ax.text(8, 5.5, '$10.02', fontsize=120, color=accent2,
100
- ha='center', va='center', fontweight='bold', family='monospace')
101
- ax.text(8, 3.5, 'per 1,000 queries', fontsize=36, color=text_color,
102
- ha='center', va='center')
103
- ax.text(8, 1.5, 'GPT-4o', fontsize=28, color=accent1,
104
- ha='center', va='center', style='italic')
105
-
106
- # Animated circles representing money
107
- progress = frame_num / total_frames
108
- for i in range(int(progress * 20)):
109
- x = 2 + (i % 5) * 3
110
- y = 7.5 - (i // 5) * 0.8
111
- circle = patches.Circle((x, y), 0.3, color=accent2, alpha=0.6)
112
- ax.add_patch(circle)
113
-
114
- elif scene_num == 2:
115
- # Scene 2: Routing diagram
116
- ax.text(8, 7.5, 'A3M Router', fontsize=48, color=accent1,
117
- ha='center', va='center', fontweight='bold')
118
-
119
- # Query box
120
- rect = patches.FancyBboxPatch((1, 3.5), 3, 2, boxstyle="round,pad=0.1",
121
- facecolor=accent3, edgecolor='white', linewidth=2)
122
- ax.add_patch(rect)
123
- ax.text(2.5, 4.5, 'Query', fontsize=24, color=bg_color,
124
- ha='center', va='center', fontweight='bold')
125
-
126
- # Arrow
127
- ax.annotate('', xy=(5.5, 4.5), xytext=(4, 4.5),
128
- arrowprops=dict(arrowstyle='->', color=accent1, lw=3))
129
-
130
- # Router box
131
- rect = patches.FancyBboxPatch((5.5, 3), 4, 3, boxstyle="round,pad=0.1",
132
- facecolor=accent1, edgecolor='white', linewidth=3)
133
- ax.add_patch(rect)
134
- ax.text(7.5, 5, 'A3M', fontsize=28, color=text_color,
135
- ha='center', va='center', fontweight='bold')
136
- ax.text(7.5, 4, '12 signals', fontsize=18, color='white',
137
- ha='center', va='center')
138
- ax.text(7.5, 3.3, '<1ms routing', fontsize=14, color='white',
139
- ha='center', va='center')
140
-
141
- # Arrows to providers
142
- providers = [('Groq\nFree', 12, 6.5, accent3),
143
- ('GPT-4o\nPremium', 12, 4.5, accent2),
144
- ('Gemini\nMid', 12, 2.5, accent4)]
145
-
146
- progress = frame_num / total_frames
147
- for i, (name, x, y, color) in enumerate(providers):
148
- if progress > (i * 0.3):
149
- ax.annotate('', xy=(x, y), xytext=(9.5, 4.5),
150
- arrowprops=dict(arrowstyle='->', color=color, lw=2))
151
- rect = patches.FancyBboxPatch((x-0.8, y-0.5), 1.6, 1,
152
- boxstyle="round,pad=0.05",
153
- facecolor=color, edgecolor='white',
154
- linewidth=1, alpha=min(1, (progress - i*0.3)*3))
155
- ax.add_patch(rect)
156
- ax.text(x, y, name, fontsize=12, color=bg_color,
157
- ha='center', va='center', fontweight='bold', alpha=min(1, (progress - i*0.3)*3))
158
-
159
- elif scene_num == 3:
160
- # Scene 3: 12 signals animation
161
- ax.text(8, 8, '12 Keyword Signals', fontsize=44, color=accent1,
162
- ha='center', va='center', fontweight='bold')
163
- ax.text(8, 7, 'Multi-dimensional query analysis', fontsize=24, color=text_color,
164
- ha='center', va='center', alpha=0.7)
165
-
166
- # Grid of signals
167
- signals = ['coding', 'math', 'creative', 'factual',
168
- 'simple', 'complex', 'debug', 'explain',
169
- 'short', 'long', 'structured', 'open']
170
-
171
- progress = frame_num / total_frames
172
- cols = 4
173
- for idx, sig in enumerate(signals):
174
- row = idx // cols
175
- col = idx % cols
176
- x = 3 + col * 2.5
177
- y = 5.5 - row * 1.8
178
-
179
- alpha = min(1, max(0, (progress - idx * 0.08) * 3))
180
- if alpha > 0:
181
- color = [accent1, accent3, accent4, accent2][idx % 4]
182
- circle = patches.Circle((x, y), 0.5, color=color, alpha=alpha * 0.8)
183
- ax.add_patch(circle)
184
- ax.text(x, y, sig, fontsize=14, color=bg_color,
185
- ha='center', va='center', fontweight='bold', alpha=alpha)
186
-
187
- elif scene_num == 4:
188
- # Scene 4: Benchmark reveal
189
- ax.text(8, 7, 'RouterArena Benchmark', fontsize=44, color=text_color,
190
- ha='center', va='center', fontweight='bold')
191
-
192
- progress = frame_num / total_frames
193
-
194
- # Score reveal
195
- if progress > 0.3:
196
- score_alpha = min(1, (progress - 0.3) * 3)
197
- ax.text(8, 5, '76.43', fontsize=120, color=accent1,
198
- ha='center', va='center', fontweight='bold', alpha=score_alpha,
199
- family='monospace')
200
- ax.text(8, 3, '#1 OF 19 ROUTERS', fontsize=28, color=accent3,
201
- ha='center', va='center', alpha=score_alpha)
202
- ax.text(8, 2, 'arXiv:2510.00202', fontsize=18, color=text_color,
203
- ha='center', va='center', alpha=score_alpha * 0.7)
204
-
205
- elif scene_num == 5:
206
- # Scene 5: Cost comparison
207
- ax.text(8, 7.5, '213x Cheaper', fontsize=56, color=accent3,
208
- ha='center', va='center', fontweight='bold')
209
-
210
- progress = frame_num / total_frames
211
-
212
- # GPT-5 cost
213
- if progress > 0.2:
214
- alpha = min(1, (progress - 0.2) * 3)
215
- ax.text(4, 5, '$10.02', fontsize=64, color=accent2,
216
- ha='center', va='center', fontweight='bold', alpha=alpha)
217
- ax.text(4, 3.5, 'GPT-5', fontsize=24, color=text_color,
218
- ha='center', va='center', alpha=alpha)
219
-
220
- # A3M cost
221
- if progress > 0.5:
222
- alpha = min(1, (progress - 0.5) * 3)
223
- ax.text(12, 5, '$0.047', fontsize=64, color=accent3,
224
- ha='center', va='center', fontweight='bold', alpha=alpha)
225
- ax.text(12, 3.5, 'A3M', fontsize=24, color=text_color,
226
- ha='center', va='center', alpha=alpha)
227
-
228
- # VS text
229
- if progress > 0.7:
230
- alpha = min(1, (progress - 0.7) * 3)
231
- ax.text(8, 5, 'vs', fontsize=36, color=text_color,
232
- ha='center', va='center', alpha=alpha * 0.5)
233
- ax.text(8, 2, 'Same quality, 1/213th the cost',
234
- fontsize=22, color=text_color, ha='center', va='center', alpha=alpha)
235
-
236
- plt.tight_layout()
237
- plt.savefig(output_path, facecolor=bg_color, dpi=100)
238
- plt.close()
239
-
240
- def main():
241
- if not check_deps():
242
- sys.exit(1)
243
-
244
- print("šŸŽ¬ A3M Router — 3Blue1Brown Style Video Generator")
245
- print("=" * 50)
246
-
247
- # Create output directory
248
- output_dir = '/Users/Subho/adaptive-memory-multi-model-router/demo/frames_3b1b'
249
- os.makedirs(output_dir, exist_ok=True)
250
-
251
- total_scenes = len(SCENES)
252
- frames_per_scene = 30 # 30 frames per scene = ~1s at 30fps
253
-
254
- print(f"Generating {total_scenes} scenes, {frames_per_scene} frames each...")
255
- print(f"Output: {output_dir}")
256
-
257
- for scene in SCENES:
258
- scene_id = scene['id']
259
- scene_dir = os.path.join(output_dir, f'scene_{scene_id}')
260
- os.makedirs(scene_dir, exist_ok=True)
261
-
262
- print(f"\nšŸ“½ļø Scene {scene_id}: {scene['title']}")
263
-
264
- for frame_num in range(1, frames_per_scene + 1):
265
- output_path = os.path.join(scene_dir, f'frame_{frame_num:04d}.png')
266
- generate_frame_matplotlib(scene_id, frame_num, frames_per_scene, output_path)
267
-
268
- if frame_num % 10 == 0:
269
- print(f" Frame {frame_num}/{frames_per_scene}")
270
-
271
- print(f"\nāœ… Generated {total_scenes * frames_per_scene} frames")
272
- print(f"\nNext steps:")
273
- print(f"1. Install ffmpeg: brew install ffmpeg")
274
- print(f"2. Run: ./demo/render_3b1b_video.sh")
275
-
276
- # Save scene config
277
- with open(os.path.join(output_dir, 'scenes.json'), 'w') as f:
278
- json.dump(SCENES, f, indent=2)
279
-
280
- print(f"\n3. Or use Python to create video:")
281
- print(f" python3 -c \"from PIL import Image; import subprocess\"")
282
- print(f" # Then run ffmpeg to compile")
283
-
284
- if __name__ == '__main__':
285
- main()