adaptive-memory-multi-model-router 2.14.49 → 2.14.52
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.
- package/.dockerignore +82 -0
- package/.env.example +303 -0
- package/.github/DISCUSSIONS_WELCOME.md +27 -0
- package/.github/DISCUSSION_TEMPLATE.yml +5 -0
- package/.github/FUNDING.yml +2 -0
- package/.github/ISSUE_TEMPLATE/bug_report.md +94 -0
- package/.github/ISSUE_TEMPLATE/config.yml +17 -0
- package/.github/ISSUE_TEMPLATE/feature_request.md +71 -0
- package/.github/PULL_REQUEST_TEMPLATE.md +71 -0
- package/.github/dependabot.yml +9 -0
- package/.github/workflows/ci.yml +263 -0
- package/.github/workflows/codeql.yml +38 -0
- package/.github/workflows/npm-publish.yml +20 -0
- package/.github/workflows/pages.yml +37 -0
- package/.github/workflows/stale.yml +54 -0
- package/.publish-tick +1 -0
- package/.well-known/ai-plugin.json +16 -0
- package/AGENT_COUNCIL_FINDINGS.md +142 -0
- package/ARCHITECTURE.md +346 -0
- package/AUDIT_REPORT.md +28 -0
- package/CODE_OF_CONDUCT.md +128 -0
- package/CONTRIBUTING.md +50 -0
- package/CONTRIBUTORS.md +20 -0
- package/Dockerfile +53 -0
- package/Dockerfile.proxy +33 -0
- package/HEALTH_REPORT.md +118 -0
- package/IMPROVEMENT_PLAN.md +107 -0
- package/LANDING.md +43 -0
- package/LAUNCH-PAIN-DRIVEN.md +339 -0
- package/LAUNCH.md +337 -0
- package/LAUNCH_CHECKLIST.md +141 -0
- package/LAUNCH_SNAPSHOT.md +260 -0
- package/MANIFESTO.md +41 -0
- package/POPULARITY_BOOSTERS.md +285 -0
- package/PR_STATUS_REPORT.md +148 -0
- package/README.md +25 -14
- package/REDESIGN.md +95 -0
- package/RUNKIT.md +83 -0
- package/SECURITY.md +29 -0
- package/SUBMISSIONS.md +43 -0
- package/_schema.html +53 -0
- package/ai-plugin.json +16 -0
- package/articles/AI_AGENT_LLM_ROUTING.md +150 -0
- package/articles/CHINESE_DIRECTORIES.md +100 -0
- package/articles/CHINESE_SUBMISSIONS_READY.md +322 -0
- package/articles/COMPETITOR_ALERTS.md +31 -0
- package/articles/COMPLETE_POSTING_DIRECTORY.md +147 -0
- package/articles/CONTENT_STRUCTURE.md +292 -0
- package/articles/DEVTO_COST_GUIDE.md +473 -0
- package/articles/DEVTO_FINAL.md +416 -0
- package/articles/DEVTO_MULTI_PROVIDER.md +542 -0
- package/articles/DEVTO_READY.md +255 -0
- package/articles/DEVTO_V2_ANNOUNCEMENT.md +160 -0
- package/articles/DEVTO_VIRAL_GROWTH.md +280 -0
- package/articles/FRESH_devto.md +460 -0
- package/articles/FRESH_devto_2026_05.md +73 -0
- package/articles/FRESH_hackernews.md +14 -0
- package/articles/FRESH_reddit_ml.md +90 -0
- package/articles/FRESH_reddit_node.md +198 -0
- package/articles/FRESH_reddit_sideproject.md +72 -0
- package/articles/FRESH_reddit_webdev.md +130 -0
- package/articles/FROM_ZERO_TO_10K.md +107 -0
- package/articles/HN_10X_BETTER.md +430 -0
- package/articles/HN_ACCOUNT_GUIDE.md +21 -0
- package/articles/HN_CHINESE_STYLE.md +308 -0
- package/articles/HN_FINAL.md +148 -0
- package/articles/HN_POSTED_VERSION.md +56 -0
- package/articles/HN_POST_READY.md +137 -0
- package/articles/HN_RESEARCH.md +364 -0
- package/articles/HN_SHOW_routerarena.md +17 -0
- package/articles/HN_TIMING_GUIDE.md +52 -0
- package/articles/INDIEHACKERS_POST.md +52 -0
- package/articles/INDIEHACKERS_READY.md +120 -0
- package/articles/LLM_BENCHMARK_DEEP_DIVE.md +153 -0
- package/articles/MASTER_POSTING_DIRECTORY.md +189 -0
- package/articles/NEWSLETTER_SEND_NOW.md +259 -0
- package/articles/NEWSLETTER_SUBMISSIONS.md +112 -0
- package/articles/PAIN-DRIVEN-devto-v2.md +308 -0
- package/articles/PAIN-DRIVEN-devto-v3.md +268 -0
- package/articles/PAIN-DRIVEN-devto.md +242 -0
- package/articles/PAIN-DRIVEN-hackernews-v2.md +138 -0
- package/articles/PAIN-DRIVEN-hackernews-v3.md +151 -0
- package/articles/PAIN-DRIVEN-hackernews.md +131 -0
- package/articles/PAIN-DRIVEN-reddit-v2.md +301 -0
- package/articles/PAIN-DRIVEN-reddit-v3.md +236 -0
- package/articles/PAIN-DRIVEN-reddit.md +218 -0
- package/articles/PAIN-DRIVEN-twitter-v2.md +110 -0
- package/articles/PAIN-DRIVEN-twitter-v3.md +121 -0
- package/articles/PAIN-DRIVEN-twitter.md +120 -0
- package/articles/PORTKEY_VS_A3M.md +147 -0
- package/articles/POSTING_KIT_2026_05.md +67 -0
- package/articles/PRESS_KIT_routerarena.md +77 -0
- package/articles/PRODUCTHUNT_LISTING.md +48 -0
- package/articles/PRODUCTHUNT_READY.md +106 -0
- package/articles/PR_PLAN_vault.md +125 -0
- package/articles/REDDIT_FINAL.md +232 -0
- package/articles/REDDIT_POST.md +67 -0
- package/articles/REDDIT_SUBMISSION_READY.md +348 -0
- package/articles/ROUTERARENA_9677.md +78 -0
- package/articles/ROUTERARENA_LEADER.md +45 -0
- package/articles/SHOW_HN_FINAL.md +29 -0
- package/articles/TWEETS_10K_DOWNLOADS.md +47 -0
- package/articles/TWEETS_BENCHMARK_FIRST.md +46 -0
- package/articles/TWEETS_MCP_PLAY.md +51 -0
- package/articles/TWEETS_SEQUENTIAL_BROKEN.md +49 -0
- package/articles/TWEETS_WHY_BUILD.md +54 -0
- package/articles/TWEETS_routerarena_leader.md +53 -0
- package/articles/TWEET_STORM_READY.md +165 -0
- package/articles/TWITTER_FINAL.md +167 -0
- package/articles/WHY_10X_BETTER.md +261 -0
- package/articles/WHY_CHINESE_STYLE_BETTER.md +323 -0
- package/articles/ai-discoverability-llm-routing.md +210 -0
- package/articles/devto-llm-routing.md +138 -0
- package/articles/hackernews-show-hn.md +54 -0
- package/articles/hashnode-llm-cost-optimization.md +125 -0
- package/articles/hn_show_2026_05.md +11 -0
- package/articles/medium-building-llm-router.md +205 -0
- package/articles/reddit-ml.md +76 -0
- package/articles/twitter-thread-cost-savings.md +50 -0
- package/articles/youtube-tutorial-script.md +262 -0
- package/assets/a3m_3blue1brown.mp4 +0 -0
- package/assets/banner.svg +109 -0
- package/assets/chart-cost-v2.svg +91 -0
- package/assets/chart-cost-v3.svg +143 -0
- package/assets/chart-features-v2.svg +132 -0
- package/assets/chart-features-v3.svg +211 -0
- package/assets/chart-growth-v2.svg +122 -0
- package/assets/chart-growth-v3.svg +189 -0
- package/assets/cost-comparison.svg +134 -0
- package/assets/cost-simple.svg +64 -0
- package/assets/demo-hn.gif +0 -0
- package/assets/feature-matrix.svg +136 -0
- package/assets/growth-chart-animated.svg +76 -0
- package/assets/growth-chart.svg +82 -0
- package/assets/growth-simple.svg +69 -0
- package/assets/hero-diagram.svg +81 -0
- package/assets/logo-new.svg +21 -0
- package/assets/logo.svg +68 -0
- package/assets/provider-comparison.svg +121 -0
- package/assets/social-preview-new.svg +100 -0
- package/assets/social-preview.svg +194 -0
- package/assets/social-v2.svg +130 -0
- package/assets/social-v3.svg +212 -0
- package/benchmark-provider-results.json +245 -0
- package/benchmark-results.json +54 -0
- package/council-votes/architecture-vote.md +121 -0
- package/council-votes/coverage-vote.md +93 -0
- package/data/adaptive-benchmark.json +92 -0
- package/data/benchmark-results.json +47 -0
- package/data/labeled-benchmark.json +88 -0
- package/demo/3blue1brown_video.py +285 -0
- package/demo/3blue1brown_video_v2.py +310 -0
- package/demo/IMPROVED_PROMPTS.md +229 -0
- package/demo/VEO3_PROMPTS.md +269 -0
- package/demo/VIDEO_PRODUCTION_GUIDE.md +333 -0
- package/demo/a3m_3blue1brown.mp4 +0 -0
- package/demo/asciinema-demo.sh +195 -0
- package/demo/demo-hn.tape +74 -0
- package/demo/demo-script.md +53 -0
- package/demo/demo-script.sh +62 -0
- package/demo/demo.svg +75 -0
- package/demo/frame1_ai_data_center.png +0 -0
- package/demo/frame1_sunset_video.mp4 +0 -0
- package/demo/frame2_cost_comparison.png +0 -0
- package/demo/frame2_cost_comparison_fallback.png +0 -0
- package/demo/frame3_parallel_execution.png +0 -0
- package/demo/frame3_parallel_execution_fallback.png +0 -0
- package/demo/frame4_providers.png +0 -0
- package/demo/frame4_providers_fallback.png +0 -0
- package/demo/frame5_endcard.png +0 -0
- package/demo/frame5_endcard_fallback.png +0 -0
- package/demo/new_frame1_hook.png +0 -0
- package/demo/new_frame2_proof.png +0 -0
- package/demo/new_frame3_wow.png +0 -0
- package/demo/new_frame4_social.png +0 -0
- package/demo/new_frame5_cta.png +0 -0
- package/demo/package.json +13 -0
- package/demo/product-video-final.mp4 +0 -0
- package/demo/product-video-hype-v1.mp4 +0 -0
- package/demo/product-video-v1.mp4 +0 -0
- package/demo/public/index.html +762 -0
- package/demo/recording.cast +55 -0
- package/demo/server.js +405 -0
- package/demo-new.tape +71 -0
- package/demo-real.sh +198 -0
- package/demo-simple.tape +205 -0
- package/demo.html +520 -0
- package/demo.sh +85 -0
- package/demo.tape +259 -0
- package/dist/analytics/costAnalytics.d.ts.map +1 -0
- package/dist/analytics/costAnalytics.js.map +1 -0
- package/dist/benchmark/comprehensive.js.map +1 -0
- package/dist/benchmark/reproducible.d.ts.map +1 -0
- package/dist/benchmark/reproducible.js.map +1 -0
- package/dist/cache/prefixCache.d.ts.map +1 -0
- package/dist/cache/prefixCache.js.map +1 -0
- package/dist/cache/responseCache.d.ts.map +1 -0
- package/dist/cache/responseCache.js.map +1 -0
- package/dist/cache/semanticCache.d.ts.map +1 -0
- package/dist/cache/semanticCache.js.map +1 -0
- package/dist/cli/setupWizard.d.ts.map +1 -0
- package/dist/cli/setupWizard.js.map +1 -0
- package/dist/cost/budgetEnforcer.d.ts.map +1 -0
- package/dist/cost/budgetEnforcer.js.map +1 -0
- package/dist/cost/costTracker.d.ts.map +1 -0
- package/dist/cost/costTracker.js.map +1 -0
- package/dist/ensemble/multiRoundDialog.js.map +1 -0
- package/dist/ensemble/shapleyValue.js.map +1 -0
- package/dist/integrations/langchainAdapter.d.ts.map +1 -0
- package/dist/integrations/langchainAdapter.js.map +1 -0
- package/dist/integrations/oauth.d.ts.map +1 -0
- package/dist/integrations/oauth.js.map +1 -0
- package/dist/integrations/scienceAdapter.js.map +1 -0
- package/dist/memory/autoFetch.d.ts.map +1 -0
- package/dist/memory/autoFetch.js.map +1 -0
- package/dist/memory/episodicMemory.d.ts.map +1 -0
- package/dist/memory/episodicMemory.js.map +1 -0
- package/dist/memory/hybridMemory.js.map +1 -0
- package/dist/memory/memoryTree.d.ts.map +1 -0
- package/dist/memory/memoryTree.js.map +1 -0
- package/dist/memory/obsidianVault.d.ts.map +1 -0
- package/dist/memory/obsidianVault.js.map +1 -0
- package/dist/memory/reasoningBank.js.map +1 -0
- package/dist/observability/changeWatch.d.ts.map +1 -0
- package/dist/observability/changeWatch.js.map +1 -0
- package/dist/observability/fatigueDetector.d.ts.map +1 -0
- package/dist/observability/fatigueDetector.js.map +1 -0
- package/dist/observability/index.d.ts.map +1 -0
- package/dist/observability/index.js.map +1 -0
- package/dist/observability/metrics.d.ts.map +1 -0
- package/dist/observability/metrics.js.map +1 -0
- package/dist/observability/middleware.d.ts.map +1 -0
- package/dist/observability/middleware.js.map +1 -0
- package/dist/observability/tracer.d.ts.map +1 -0
- package/dist/observability/tracer.js.map +1 -0
- package/dist/observability/types.d.ts.map +1 -0
- package/dist/observability/types.js.map +1 -0
- package/dist/orchestration/haloOrchestrator.d.ts.map +1 -0
- package/dist/orchestration/haloOrchestrator.js.map +1 -0
- package/dist/orchestration/mctsWorkflow.d.ts.map +1 -0
- package/dist/orchestration/mctsWorkflow.js.map +1 -0
- package/dist/providers/localProvider.d.ts.map +1 -0
- package/dist/providers/localProvider.js.map +1 -0
- package/dist/providers/providerConfig.d.ts.map +1 -0
- package/dist/providers/providerConfig.js.map +1 -0
- package/dist/providers/registry.d.ts.map +1 -0
- package/dist/providers/registry.js.map +1 -0
- package/dist/routing/advancedRouter.d.ts.map +1 -0
- package/dist/routing/advancedRouter.js +1 -1
- package/dist/routing/advancedRouter.js.map +1 -0
- package/dist/routing/crossModelValidation.d.ts.map +1 -0
- package/dist/routing/crossModelValidation.js.map +1 -0
- package/dist/routing/providerHealth.d.ts.map +1 -0
- package/dist/routing/providerHealth.js.map +1 -0
- package/dist/routing/providerRetry.d.ts.map +1 -0
- package/dist/routing/providerRetry.js.map +1 -0
- package/dist/scripts/banner.js +29 -0
- package/dist/security/guardrails.d.ts.map +1 -0
- package/dist/security/guardrails.js.map +1 -0
- package/dist/server/dashboard.d.ts.map +1 -0
- package/dist/server/dashboard.js.map +1 -0
- package/dist/server/modelMapper.d.ts.map +1 -0
- package/dist/server/modelMapper.js.map +1 -0
- package/dist/server/proxyServer.d.ts.map +1 -0
- package/dist/server/proxyServer.js.map +1 -0
- package/dist/skills/__tests__/skill_manager.test.d.ts +2 -0
- package/dist/skills/__tests__/skill_manager.test.d.ts.map +1 -0
- package/dist/skills/__tests__/skill_manager.test.js +268 -0
- package/dist/skills/__tests__/skill_manager.test.js.map +1 -0
- package/dist/tools/tmlpdTools.d.ts.map +1 -0
- package/dist/tools/tmlpdTools.js.map +1 -0
- package/dist/tui/dashboard.d.ts.map +1 -0
- package/dist/tui/dashboard.js.map +1 -0
- package/dist/tui/index.d.ts.map +1 -0
- package/dist/tui/index.js.map +1 -0
- package/dist/utils/batchProcessor.d.ts.map +1 -0
- package/dist/utils/batchProcessor.js.map +1 -0
- package/dist/utils/compression.d.ts.map +1 -0
- package/dist/utils/compression.js.map +1 -0
- package/dist/utils/costUtils.d.ts.map +1 -0
- package/dist/utils/costUtils.js.map +1 -0
- package/dist/utils/reliability.d.ts.map +1 -0
- package/dist/utils/reliability.js.map +1 -0
- package/dist/utils/sorting.d.ts.map +1 -0
- package/dist/utils/sorting.js.map +1 -0
- package/dist/utils/speculativeDecoding.d.ts.map +1 -0
- package/dist/utils/speculativeDecoding.js.map +1 -0
- package/dist/utils/tokenUtils.d.ts.map +1 -0
- package/dist/utils/tokenUtils.js.map +1 -0
- package/docs/.nojekyll +0 -0
- package/docs/ANALYSIS_PRINCIPLES.md +162 -0
- package/docs/API.md +855 -0
- package/docs/ARCHITECTURAL-IMPROVEMENTS-2025.md +1391 -0
- package/docs/ARCHITECTURAL-IMPROVEMENTS-REVISED-2025.md +1051 -0
- package/docs/BENCHMARK.md +170 -0
- package/docs/CHINESE_PROVIDER_RELIABILITY.md +37 -0
- package/docs/CITATIONS.md +74 -0
- package/docs/CLAIMS_AND_EVIDENCE.md +58 -0
- package/docs/CONFIGURATION.md +476 -0
- package/docs/COUNCIL_DECISION.json +816 -0
- package/docs/COUNCIL_SUMMARY.md +319 -0
- package/docs/COUNCIL_V2.2_DECISION.md +416 -0
- package/docs/ENGINEERING_SPEC.md +55 -0
- package/docs/FACTORY_RESET.md +34 -0
- package/docs/GEO.md +66 -0
- package/docs/GEO_OPTIMIZATION.md +30 -0
- package/docs/GEO_ROOT_CAUSE.md +136 -0
- package/docs/GEO_STATUS.md +85 -0
- package/docs/GEO_TEST_RESULTS.md +176 -0
- package/docs/HN_CHECKLIST.md +38 -0
- package/docs/HN_FOUNDER_COMMENT.md +17 -0
- package/docs/HN_SUBMISSION_FINAL.md +180 -0
- package/docs/HN_SUBMISSION_V3.md +56 -0
- package/docs/IMPROVEMENT_ROADMAP.md +515 -0
- package/docs/INTEGRATIONS.md +420 -0
- package/docs/LANGCHAIN_INTEGRATION.md +147 -0
- package/docs/LLM_COUNCIL_DECISION.md +508 -0
- package/docs/MIDDLEWARE_CHAIN.md +35 -0
- package/docs/PROMO_CHECKLIST.md +200 -0
- package/docs/QUICKSTART.md +271 -0
- package/docs/QUICK_START.md +43 -0
- package/docs/QUICK_START_VISIBILITY.md +782 -0
- package/docs/REDDIT_GAP_ANALYSIS.md +299 -0
- package/docs/RELEASE_CHECKLIST.md +32 -0
- package/docs/REPRODUCIBILITY.md +63 -0
- package/docs/RESEARCH_BACKED_IMPROVEMENTS.md +1180 -0
- package/docs/ROUTING_RUBRIC.md +197 -0
- package/docs/SEO_AUDIT.md +186 -0
- package/docs/SOCIAL_LISTENING.md +219 -0
- package/docs/TMLPD_QNA.md +751 -0
- package/docs/TMLPD_V2.1_COMPLETE.md +763 -0
- package/docs/TMLPD_V2.2_RESEARCH_ROADMAP.md +754 -0
- package/docs/UPDATE_TOPICS.md +15 -0
- package/docs/USE_CASES.md +59 -0
- package/docs/V2.2_IMPLEMENTATION_COMPLETE.md +446 -0
- package/docs/V2_IMPLEMENTATION_GUIDE.md +388 -0
- package/docs/VERCEL_AI_SDK.md +209 -0
- package/docs/VISIBILITY_ADOPTION_PLAN.md +1005 -0
- package/docs/_config.yml +49 -0
- package/docs/ai-plugin.json +16 -0
- package/docs/api.html +513 -0
- package/docs/architecture-diagram.md +40 -0
- package/docs/benchmark-chart.png +0 -0
- package/docs/benchmark.html +387 -0
- package/docs/blog/routerarena-9677.html +92 -0
- package/docs/blog/routerarena-number-one.html +73 -0
- package/docs/cli-cheatsheet.md +339 -0
- package/docs/compare.md +109 -0
- package/docs/comparison-litellm.md +88 -0
- package/docs/comparison.md +108 -0
- package/docs/cost-chart-ascii.md +42 -0
- package/docs/cost-comparison-chart.svg +88 -0
- package/docs/curl-examples.md +247 -0
- package/docs/demo-auto.html +264 -0
- package/docs/demo.html +416 -0
- package/docs/geo/GENERATIVE_ENGINE_OPTIMIZATION.md +232 -0
- package/docs/index.html +507 -0
- package/docs/launch-content/LAUNCH_EXECUTION_CHECKLIST.md +421 -0
- package/docs/launch-content/README.md +457 -0
- package/docs/launch-content/assets/cost_comparison_100_tasks.png +0 -0
- package/docs/launch-content/assets/cumulative_savings.png +0 -0
- package/docs/launch-content/assets/parallel_speedup.png +0 -0
- package/docs/launch-content/assets/provider_pricing_comparison.png +0 -0
- package/docs/launch-content/assets/task_breakdown_comparison.png +0 -0
- package/docs/launch-content/generate_charts.py +313 -0
- package/docs/launch-content/hn_show_post.md +139 -0
- package/docs/launch-content/partner_outreach_templates.md +745 -0
- package/docs/launch-content/reddit_posts.md +467 -0
- package/docs/launch-content/twitter_thread.txt +460 -0
- package/{llms.txt.bak → docs/llms.txt} +6 -6
- package/docs/npm-downloads-chart.svg +43 -0
- package/docs/openapi.json +139 -0
- package/docs/openapi.yaml +1318 -0
- package/docs/quick-start.html +366 -0
- package/docs/robots.txt +52 -0
- package/docs/sitemap.xml +57 -0
- package/docs/styles.css +682 -0
- package/docs/well-known/ai-plugin.json +16 -0
- package/docs/wellknown/ai-plugin.json +16 -0
- package/docs-site/assets/og-banner.svg +194 -0
- package/docs-site/index.html +632 -0
- package/eval/README.md +46 -0
- package/eval/baselines/main.json +12 -0
- package/eval/benchmark_dataset.jsonl +16 -0
- package/eval/check_golden_routes.js +64 -0
- package/eval/datasets/catalog.json +33 -0
- package/eval/datasets/slices/cn_provider_reliability_v1.jsonl +3 -0
- package/eval/datasets/slices/cost_pressure_v1.jsonl +3 -0
- package/eval/datasets/slices/safety_guardrails_v1.jsonl +3 -0
- package/eval/evals.json +199 -0
- package/eval/fault_injection_thresholds.json +3 -0
- package/eval/generate_report.js +128 -0
- package/eval/golden_routes.json +114 -0
- package/eval/lib/experiment_registry.js +24 -0
- package/eval/run_eval.js +197 -0
- package/eval/run_fault_injection.js +201 -0
- package/eval/run_shadow_eval.js +85 -0
- package/eval/thresholds.json +9 -0
- package/examples/QUICKSTART.md +183 -0
- package/examples/README.md +61 -0
- package/examples/a3m-sdk.js +124 -0
- package/examples/basic-route.js +54 -0
- package/examples/chat-loop.js +202 -0
- package/examples/classify-then-route.js +102 -0
- package/examples/cost-compare.js +120 -0
- package/examples/ensemble.js +160 -0
- package/examples/whatsapp-telegram-bridge-demo.js +302 -0
- package/examples/whatsapp-telegram-bridge.js +269 -0
- package/hf-space/README.md +23 -0
- package/hf-space/app.py +240 -0
- package/hf-space/requirements.txt +1 -0
- package/huggingface_space/README.md +35 -0
- package/huggingface_space/app.py +126 -0
- package/huggingface_space/create_space.py +208 -0
- package/huggingface_space/requirements.txt +1 -0
- package/index.html +1 -1
- package/mcp-server/README.md +188 -0
- package/mcp-server/package.json +29 -0
- package/mcp-server/src/index.ts +744 -0
- package/mcp-server/tsconfig.json +19 -0
- package/openclaw-alexa-bridge/ALL_REMAINING_FIXES_PLAN.md +313 -0
- package/openclaw-alexa-bridge/REMAINING_FIXES_SUMMARY.md +277 -0
- package/openclaw-alexa-bridge/src/alexa_handler_no_tmlpd.js +1234 -0
- package/openclaw-alexa-bridge/test_fixes.js +77 -0
- package/package.json +76 -272
- package/playground/README.md +51 -0
- package/playground/codesandbox.json +12 -0
- package/playground/index.js +39 -0
- package/proxy/README.md +227 -0
- package/proxy/package-lock.json +831 -0
- package/proxy/package.json +17 -0
- package/proxy/rate-limit.js +145 -0
- package/proxy/rate-limit.test.js +311 -0
- package/proxy/server.js +970 -0
- package/python/README.md +102 -0
- package/python/a3m/__init__.py +6 -0
- package/python/a3m/client.py +190 -0
- package/python/a3m/models.py +40 -0
- package/python/a3m/sync_client.py +61 -0
- package/python/examples.py +53 -0
- package/python/integrations.py +330 -0
- package/python/pyproject.toml +23 -0
- package/python/setup.py +28 -0
- package/python/tmlpd.py +369 -0
- package/qna/REDDIT_GAP_ANALYSIS.md +299 -0
- package/qna/TMLPD_QNA.md +751 -0
- package/research/FINDING_001_safety.md +28 -0
- package/research/FINDING_002_error_diversity.md +32 -0
- package/research/FINDING_003_confidence_weighted_voting.md +32 -0
- package/research/FINDING_004_cross_model_semantic_detection.md +37 -0
- package/research/FINDING_005_knowledge_gap_orthogonality.md +34 -0
- package/research/HALLUCINATION_RESEARCH.md +27 -0
- package/research/ensemble-voting.md +324 -0
- package/research/loss-functions.md +545 -0
- package/research-log.md +49 -0
- package/scripts/banner.js +29 -0
- package/scripts/benchmark-local-routerarena.ts +176 -0
- package/scripts/benchmark.js +145 -0
- package/scripts/benchmark.sh +61 -0
- package/scripts/compare-providers.sh +230 -0
- package/scripts/content-planner.js +25 -0
- package/scripts/create-labeled-benchmark.ts +105 -0
- package/scripts/cross_post.py +443 -0
- package/scripts/local-router-benchmark.ts +154 -0
- package/scripts/post-all.sh +41 -0
- package/scripts/publish_fcc.py +106 -0
- package/scripts/push-to-gitee.sh +25 -0
- package/scripts/routerarena_ensemble.js +144 -0
- package/scripts/routing-benchmark-v2.js +373 -0
- package/scripts/routing-benchmark-v3.js +118 -0
- package/scripts/routing-benchmark.js +462 -0
- package/scripts/run-labeled-benchmark.mjs +104 -0
- package/scripts/run-mmlu-benchmark.js +176 -0
- package/scripts/run-provider-benchmark.js +244 -0
- package/scripts/update-npm-badges.js +158 -0
- package/skill/SKILL.md +238 -0
- package/src/__tests__/integration/tmpld_integration.test.py +540 -0
- package/src/ensemble.ts +2 -0
- package/src/routing/advancedRouter.ts +1 -1
- package/src/skills/__tests__/skill_manager.test.ts +328 -0
- package/submissions/benchmarks/ALL_PLATFORMS_SUBMISSION.md +94 -0
- package/submissions/benchmarks/LLMROUTERBENCH_SUBMISSION.md +121 -0
- package/submissions/benchmarks/MMRBENCH_SUBMISSION.md +94 -0
- package/submissions/benchmarks/ROUTERARENA_UPDATE.md +83 -0
- package/submissions/benchmarks/ROUTERBENCH_SUBMISSION.md +225 -0
- package/test-council/1-structure-tests.test.js +353 -0
- package/test-council/1-structure-tests.test.ts +353 -0
- package/test-council/2-edge-case-tests.test.ts +361 -0
- package/test-council/3-performance-tests.test.ts +652 -0
- package/test-council/4-integration-tests.test.ts +391 -0
- package/test-council/5-agent-council-eval.test.ts +413 -0
- package/test-council/AGENT_COUNCIL_ARCHITECTURE.md +349 -0
- package/test-council/TEST_COUNCIL_REPORT.md +201 -0
- package/test-council/agents/edge-case-agent.ts +363 -0
- package/test-council/agents/performance-agent.ts +426 -0
- package/test-council/agents/structure-agent.ts +227 -0
- package/test-council/council.md +183 -0
- package/tests/__mocks__/tokenUtils.ts +8 -0
- package/tests/memory/episodicMemory.test.ts +227 -0
- package/tests/package-lock.json +1785 -0
- package/tests/package.json +19 -0
- package/tests/routing/ensembleVoting.test.ts +236 -0
- package/tests/routing/providerRetry.test.ts +360 -0
- package/tests/routing/queryTypePresets.test.ts +208 -0
- package/tests/security/guardrailEngine.test.ts +700 -0
- package/tests/tsconfig.json +21 -0
- package/tests/vitest.config.ts +18 -0
- package/tmlpd-pi-extension/README.md +66 -0
- package/tmlpd-pi-extension/dist/cache/prefixCache.d.ts +114 -0
- package/tmlpd-pi-extension/dist/cache/prefixCache.d.ts.map +1 -0
- package/tmlpd-pi-extension/dist/cache/prefixCache.js +285 -0
- package/tmlpd-pi-extension/dist/cache/prefixCache.js.map +1 -0
- package/tmlpd-pi-extension/dist/cache/responseCache.d.ts +58 -0
- package/tmlpd-pi-extension/dist/cache/responseCache.d.ts.map +1 -0
- package/tmlpd-pi-extension/dist/cache/responseCache.js +153 -0
- package/tmlpd-pi-extension/dist/cache/responseCache.js.map +1 -0
- package/tmlpd-pi-extension/dist/cli.js +59 -0
- package/tmlpd-pi-extension/dist/cost/costTracker.d.ts +95 -0
- package/tmlpd-pi-extension/dist/cost/costTracker.d.ts.map +1 -0
- package/tmlpd-pi-extension/dist/cost/costTracker.js +240 -0
- package/tmlpd-pi-extension/dist/cost/costTracker.js.map +1 -0
- package/tmlpd-pi-extension/dist/index.d.ts +723 -0
- package/tmlpd-pi-extension/dist/index.d.ts.map +1 -0
- package/tmlpd-pi-extension/dist/index.js +239 -0
- package/tmlpd-pi-extension/dist/index.js.map +1 -0
- package/tmlpd-pi-extension/dist/memory/episodicMemory.d.ts +82 -0
- package/tmlpd-pi-extension/dist/memory/episodicMemory.d.ts.map +1 -0
- package/tmlpd-pi-extension/dist/memory/episodicMemory.js +145 -0
- package/tmlpd-pi-extension/dist/memory/episodicMemory.js.map +1 -0
- package/tmlpd-pi-extension/dist/orchestration/haloOrchestrator.d.ts +102 -0
- package/tmlpd-pi-extension/dist/orchestration/haloOrchestrator.d.ts.map +1 -0
- package/tmlpd-pi-extension/dist/orchestration/haloOrchestrator.js +207 -0
- package/tmlpd-pi-extension/dist/orchestration/haloOrchestrator.js.map +1 -0
- package/tmlpd-pi-extension/dist/orchestration/mctsWorkflow.d.ts +85 -0
- package/tmlpd-pi-extension/dist/orchestration/mctsWorkflow.d.ts.map +1 -0
- package/tmlpd-pi-extension/dist/orchestration/mctsWorkflow.js +210 -0
- package/tmlpd-pi-extension/dist/orchestration/mctsWorkflow.js.map +1 -0
- package/tmlpd-pi-extension/dist/providers/localProvider.d.ts +102 -0
- package/tmlpd-pi-extension/dist/providers/localProvider.d.ts.map +1 -0
- package/tmlpd-pi-extension/dist/providers/localProvider.js +338 -0
- package/tmlpd-pi-extension/dist/providers/localProvider.js.map +1 -0
- package/tmlpd-pi-extension/dist/providers/registry.d.ts +55 -0
- package/tmlpd-pi-extension/dist/providers/registry.d.ts.map +1 -0
- package/tmlpd-pi-extension/dist/providers/registry.js +138 -0
- package/tmlpd-pi-extension/dist/providers/registry.js.map +1 -0
- package/tmlpd-pi-extension/dist/routing/advancedRouter.d.ts +68 -0
- package/tmlpd-pi-extension/dist/routing/advancedRouter.d.ts.map +1 -0
- package/tmlpd-pi-extension/dist/routing/advancedRouter.js +332 -0
- package/tmlpd-pi-extension/dist/routing/advancedRouter.js.map +1 -0
- package/tmlpd-pi-extension/dist/tools/tmlpdTools.d.ts +101 -0
- package/tmlpd-pi-extension/dist/tools/tmlpdTools.d.ts.map +1 -0
- package/tmlpd-pi-extension/dist/tools/tmlpdTools.js +368 -0
- package/tmlpd-pi-extension/dist/tools/tmlpdTools.js.map +1 -0
- package/tmlpd-pi-extension/dist/utils/batchProcessor.d.ts +96 -0
- package/tmlpd-pi-extension/dist/utils/batchProcessor.d.ts.map +1 -0
- package/tmlpd-pi-extension/dist/utils/batchProcessor.js +170 -0
- package/tmlpd-pi-extension/dist/utils/batchProcessor.js.map +1 -0
- package/tmlpd-pi-extension/dist/utils/compression.d.ts +61 -0
- package/tmlpd-pi-extension/dist/utils/compression.d.ts.map +1 -0
- package/tmlpd-pi-extension/dist/utils/compression.js +281 -0
- package/tmlpd-pi-extension/dist/utils/compression.js.map +1 -0
- package/tmlpd-pi-extension/dist/utils/reliability.d.ts +74 -0
- package/tmlpd-pi-extension/dist/utils/reliability.d.ts.map +1 -0
- package/tmlpd-pi-extension/dist/utils/reliability.js +177 -0
- package/tmlpd-pi-extension/dist/utils/reliability.js.map +1 -0
- package/tmlpd-pi-extension/dist/utils/speculativeDecoding.d.ts +117 -0
- package/tmlpd-pi-extension/dist/utils/speculativeDecoding.d.ts.map +1 -0
- package/tmlpd-pi-extension/dist/utils/speculativeDecoding.js +246 -0
- package/tmlpd-pi-extension/dist/utils/speculativeDecoding.js.map +1 -0
- package/tmlpd-pi-extension/dist/utils/tokenUtils.d.ts +50 -0
- package/tmlpd-pi-extension/dist/utils/tokenUtils.d.ts.map +1 -0
- package/tmlpd-pi-extension/dist/utils/tokenUtils.js +124 -0
- package/tmlpd-pi-extension/dist/utils/tokenUtils.js.map +1 -0
- package/tmlpd-pi-extension/examples/QUICKSTART.md +183 -0
- package/tmlpd-pi-extension/package-lock.json +79 -0
- package/tmlpd-pi-extension/package.json +172 -0
- package/tmlpd-pi-extension/python/examples.py +53 -0
- package/tmlpd-pi-extension/python/integrations.py +330 -0
- package/tmlpd-pi-extension/python/setup.py +28 -0
- package/tmlpd-pi-extension/python/tmlpd.py +369 -0
- package/tmlpd-pi-extension/qna/REDDIT_GAP_ANALYSIS.md +299 -0
- package/tmlpd-pi-extension/qna/TMLPD_QNA.md +751 -0
- package/tmlpd-pi-extension/skill/SKILL.md +238 -0
- package/tmlpd-pi-extension/src/cache/responseCache.ts +147 -0
- package/tmlpd-pi-extension/src/cost/costTracker.ts +302 -0
- package/tmlpd-pi-extension/src/index.ts +232 -0
- package/tmlpd-pi-extension/src/memory/episodicMemory.ts +257 -0
- package/tmlpd-pi-extension/src/orchestration/haloOrchestrator.ts +266 -0
- package/tmlpd-pi-extension/src/orchestration/mctsWorkflow.ts +262 -0
- package/tmlpd-pi-extension/src/providers/localProvider.ts +406 -0
- package/tmlpd-pi-extension/src/providers/registry.ts +164 -0
- package/tmlpd-pi-extension/src/routing/ensembleVoting.ts +159 -0
- package/tmlpd-pi-extension/src/routing/queryTypePresets.ts +136 -0
- package/tmlpd-pi-extension/src/tools/tmlpdTools.ts +433 -0
- package/tmlpd-pi-extension/src/utils/batchProcessor.ts +232 -0
- package/tmlpd-pi-extension/src/utils/compression.ts +325 -0
- package/tmlpd-pi-extension/src/utils/reliability.ts +221 -0
- package/tmlpd-pi-extension/src/utils/tokenUtils.ts +145 -0
- package/tmlpd-pi-extension/tsconfig.json +18 -0
- package/tsconfig.build.json +29 -0
- package/tsconfig.json +18 -0
- package/README.md.bak +0 -1185
- package/src/routing/advancedRouter.ts.bak +0 -650
- package/test.js.bak +0 -376
- /package/{llms-full.txt.bak → docs/llms-full.txt} +0 -0
|
@@ -0,0 +1,262 @@
|
|
|
1
|
+
# YouTube Tutorial Script: A3M Router - Smart LLM Routing
|
|
2
|
+
|
|
3
|
+
## Video Title Options
|
|
4
|
+
1. "Cut Your OpenAI Bill by 70% with Intelligent LLM Routing"
|
|
5
|
+
2. "A3M Router: The Smart Way to Use Multiple LLM Providers"
|
|
6
|
+
3. "Stop Overpaying for LLMs - Automatic Cost Optimization"
|
|
7
|
+
4. "Build a Learned LLM Router in 10 Minutes"
|
|
8
|
+
|
|
9
|
+
## Video Info
|
|
10
|
+
- **Target Length**: 10-12 minutes
|
|
11
|
+
- **Target Audience**: Node.js developers using LLMs
|
|
12
|
+
- **Difficulty**: Beginner to Intermediate
|
|
13
|
+
|
|
14
|
+
---
|
|
15
|
+
|
|
16
|
+
## Intro (0:00 - 1:00)
|
|
17
|
+
|
|
18
|
+
**[Screen: Terminal with high OpenAI bill]**
|
|
19
|
+
|
|
20
|
+
"If you're using OpenAI for everything, you're probably overpaying. In this video, I'll show you how we cut our LLM API costs by 70% using intelligent routing."
|
|
21
|
+
|
|
22
|
+
**[Screen: A3M Router logo/banner]**
|
|
23
|
+
|
|
24
|
+
"This is A3M Router - an adaptive multi-model router that automatically sends your queries to the cheapest capable provider. Let's dive in."
|
|
25
|
+
|
|
26
|
+
---
|
|
27
|
+
|
|
28
|
+
## The Problem (1:00 - 2:30)
|
|
29
|
+
|
|
30
|
+
**[Screen: Code showing GPT-4 usage]**
|
|
31
|
+
|
|
32
|
+
"Here's what most developers do. They use GPT-4 for EVERYTHING."
|
|
33
|
+
|
|
34
|
+
```javascript
|
|
35
|
+
// Bad: Using GPT-4 for everything
|
|
36
|
+
const openai = new OpenAI({ apiKey: process.env.OPENAI_API_KEY });
|
|
37
|
+
|
|
38
|
+
// Simple question
|
|
39
|
+
await openai.chat.completions.create({
|
|
40
|
+
model: "gpt-4",
|
|
41
|
+
messages: [{ role: "user", content: "What is 2+2?" }]
|
|
42
|
+
});
|
|
43
|
+
// Cost: $0.03
|
|
44
|
+
|
|
45
|
+
// Code generation
|
|
46
|
+
await openai.chat.completions.create({
|
|
47
|
+
model: "gpt-4",
|
|
48
|
+
messages: [{ role: "user", content: "Write Python to sort an array" }]
|
|
49
|
+
});
|
|
50
|
+
// Cost: $0.05
|
|
51
|
+
```
|
|
52
|
+
|
|
53
|
+
**[Screen: Calculator showing monthly cost]**
|
|
54
|
+
|
|
55
|
+
"If you process 1,000 queries per day, that's $30-50 per day. $900-1,500 per month. Just for simple queries that any model could handle."
|
|
56
|
+
|
|
57
|
+
---
|
|
58
|
+
|
|
59
|
+
## The Solution (2:30 - 4:00)
|
|
60
|
+
|
|
61
|
+
**[Screen: A3M Router architecture diagram]**
|
|
62
|
+
|
|
63
|
+
"A3M Router solves this with learned routing. It analyzes your query and picks the optimal provider."
|
|
64
|
+
|
|
65
|
+
"Here's the magic:"
|
|
66
|
+
|
|
67
|
+
```javascript
|
|
68
|
+
// Good: Using A3M Router
|
|
69
|
+
const { createA3MRouter } = require('adaptive-memory-multi-model-router');
|
|
70
|
+
|
|
71
|
+
const router = createA3MRouter();
|
|
72
|
+
|
|
73
|
+
// Simple question → cheapest provider (FREE)
|
|
74
|
+
const result1 = await router.route("What is 2+2?");
|
|
75
|
+
console.log(result1.primary_model); // "commandcode/taste-1"
|
|
76
|
+
console.log(result1.estimated_cost); // $0.00
|
|
77
|
+
|
|
78
|
+
// Code generation → fast provider
|
|
79
|
+
const result2 = await router.route("Write Python to sort an array");
|
|
80
|
+
console.log(result2.primary_model); // "groq/llama-3.3-70b"
|
|
81
|
+
console.log(result2.estimated_cost); // $0.0004
|
|
82
|
+
```
|
|
83
|
+
|
|
84
|
+
**[Screen: Side-by-side cost comparison]**
|
|
85
|
+
|
|
86
|
+
"See the difference? Simple queries go to free providers. Code queries go to fast, code-capable models. You only pay for what you need."
|
|
87
|
+
|
|
88
|
+
---
|
|
89
|
+
|
|
90
|
+
## Installation & Setup (4:00 - 5:30)
|
|
91
|
+
|
|
92
|
+
**[Screen: Terminal recording]**
|
|
93
|
+
|
|
94
|
+
"Let's install it and see it in action."
|
|
95
|
+
|
|
96
|
+
```bash
|
|
97
|
+
# Install
|
|
98
|
+
npm install adaptive-memory-multi-model-router
|
|
99
|
+
|
|
100
|
+
# Check providers
|
|
101
|
+
npx a3m-router providers
|
|
102
|
+
```
|
|
103
|
+
|
|
104
|
+
**[Screen: Provider table output]**
|
|
105
|
+
|
|
106
|
+
"Look at that - 9 providers configured out of the box. Groq, Cerebras, Mistral, and free CLI providers like CommandCode and OpenCode."
|
|
107
|
+
|
|
108
|
+
"Now let's route a query:"
|
|
109
|
+
|
|
110
|
+
```bash
|
|
111
|
+
npx a3m-router route "Write Python to reverse a string"
|
|
112
|
+
```
|
|
113
|
+
|
|
114
|
+
**[Screen: Routing result]**
|
|
115
|
+
|
|
116
|
+
"Boom! It automatically selected Groq's Llama model because it's fast and good at code. Estimated cost: $0.0004. That's 75x cheaper than GPT-4."
|
|
117
|
+
|
|
118
|
+
---
|
|
119
|
+
|
|
120
|
+
## How Routing Works (5:30 - 7:00)
|
|
121
|
+
|
|
122
|
+
**[Screen: Routing algorithm visualization]**
|
|
123
|
+
|
|
124
|
+
"Here's how the routing actually works:"
|
|
125
|
+
|
|
126
|
+
"Step 1: Feature Extraction"
|
|
127
|
+
- Detects code patterns (function, class, import)
|
|
128
|
+
- Detects math notation
|
|
129
|
+
- Detects language/translation needs
|
|
130
|
+
- Estimates complexity
|
|
131
|
+
|
|
132
|
+
"Step 2: Model Profiles"
|
|
133
|
+
- Each provider has cost, latency, quality scores
|
|
134
|
+
- Groq: fast, cheap, good at code
|
|
135
|
+
- Mistral: high quality, moderate cost
|
|
136
|
+
- CommandCode: free, good for simple queries
|
|
137
|
+
|
|
138
|
+
"Step 3: Smart Selection"
|
|
139
|
+
- Simple queries → prioritize cost
|
|
140
|
+
- Complex queries → prioritize quality
|
|
141
|
+
- Automatic fallback if provider fails
|
|
142
|
+
|
|
143
|
+
**[Screen: Code showing routing result]**
|
|
144
|
+
|
|
145
|
+
```javascript
|
|
146
|
+
const result = await router.route("Your query");
|
|
147
|
+
|
|
148
|
+
console.log(result);
|
|
149
|
+
// {
|
|
150
|
+
// primary_model: "groq/llama-3.3-70b",
|
|
151
|
+
// fallback_models: ["mistral/medium", "cerebras/llama"],
|
|
152
|
+
// estimated_cost: 0.0004,
|
|
153
|
+
// confidence: 0.85,
|
|
154
|
+
// reasoning: "Selected Groq for code detected"
|
|
155
|
+
// }
|
|
156
|
+
```
|
|
157
|
+
|
|
158
|
+
---
|
|
159
|
+
|
|
160
|
+
## Real Results (7:00 - 8:30)
|
|
161
|
+
|
|
162
|
+
**[Screen: Benchmark table]**
|
|
163
|
+
|
|
164
|
+
"Let's run the benchmark to see real performance:"
|
|
165
|
+
|
|
166
|
+
```bash
|
|
167
|
+
npx a3m-router benchmark
|
|
168
|
+
```
|
|
169
|
+
|
|
170
|
+
**[Screen: Benchmark output]**
|
|
171
|
+
|
|
172
|
+
"Look at these results:"
|
|
173
|
+
|
|
174
|
+
| Provider | Latency | Cost/1K | Quality |
|
|
175
|
+
|----------|---------|---------|---------|
|
|
176
|
+
| Groq | 400ms | $0.59 | 82% |
|
|
177
|
+
| Cerebras | 350ms | $0.60 | 82% |
|
|
178
|
+
| Mistral | 800ms | $0.20 | 90% |
|
|
179
|
+
| CommandCode | 5s | FREE | 75% |
|
|
180
|
+
|
|
181
|
+
"For simple queries, CommandCode is FREE. For code, Groq is 5x faster than OpenAI. For quality, Mistral beats GPT-3.5 at half the price."
|
|
182
|
+
|
|
183
|
+
---
|
|
184
|
+
|
|
185
|
+
## Advanced Features (8:30 - 9:30)
|
|
186
|
+
|
|
187
|
+
**[Screen: Code examples]**
|
|
188
|
+
|
|
189
|
+
"A3M Router has more tricks up its sleeve:"
|
|
190
|
+
|
|
191
|
+
"Batch Processing:"
|
|
192
|
+
```javascript
|
|
193
|
+
const queries = ["Q1", "Q2", "Q3"];
|
|
194
|
+
const results = routeBatch(queries, { same_model: true });
|
|
195
|
+
```
|
|
196
|
+
|
|
197
|
+
"Cost Tracking:"
|
|
198
|
+
```javascript
|
|
199
|
+
const router = createA3MRouter();
|
|
200
|
+
const summary = router.costTracker.getSummary();
|
|
201
|
+
console.log(`Total spent: $${summary.totalSpent}`);
|
|
202
|
+
```
|
|
203
|
+
|
|
204
|
+
"Custom Providers:"
|
|
205
|
+
```javascript
|
|
206
|
+
registerProvider('my-provider', {
|
|
207
|
+
baseUrl: 'https://api.myprovider.com',
|
|
208
|
+
models: ['my-model'],
|
|
209
|
+
type: 'api'
|
|
210
|
+
});
|
|
211
|
+
```
|
|
212
|
+
|
|
213
|
+
---
|
|
214
|
+
|
|
215
|
+
## Conclusion (9:30 - 10:30)
|
|
216
|
+
|
|
217
|
+
**[Screen: Summary slide]**
|
|
218
|
+
|
|
219
|
+
"To summarize:"
|
|
220
|
+
|
|
221
|
+
"✅ Install: npm install adaptive-memory-multi-model-router"
|
|
222
|
+
"✅ Route: npx a3m-router route 'Your query'"
|
|
223
|
+
"✅ Save: 50-80% on API costs"
|
|
224
|
+
"✅ Get: Automatic fallback, cost tracking, batch processing"
|
|
225
|
+
|
|
226
|
+
**[Screen: GitHub and NPM links]**
|
|
227
|
+
|
|
228
|
+
"Links in the description:
|
|
229
|
+
- GitHub: github.com/Das-rebel/a3m-router
|
|
230
|
+
- NPM: npmjs.com/package/adaptive-memory-multi-model-router
|
|
231
|
+
- Docs: Full documentation on GitHub"
|
|
232
|
+
|
|
233
|
+
**[Screen: Subscribe button]**
|
|
234
|
+
|
|
235
|
+
"If this helped you save money on LLM APIs, hit like and subscribe. Questions? Drop them in the comments. Thanks for watching!"
|
|
236
|
+
|
|
237
|
+
---
|
|
238
|
+
|
|
239
|
+
## Video Assets Needed
|
|
240
|
+
|
|
241
|
+
1. **Thumbnail**: Split screen - "$2,400" vs "$720" with A3M Router logo
|
|
242
|
+
2. **Intro Animation**: 5-second logo animation
|
|
243
|
+
3. **Terminal Recording**: Actual CLI usage
|
|
244
|
+
4. **Diagram**: Routing architecture (can use ASCII art)
|
|
245
|
+
5. **Benchmark Table**: Animated comparison
|
|
246
|
+
6. **Outro Screen**: Links and subscribe button
|
|
247
|
+
|
|
248
|
+
## B-Roll Footage
|
|
249
|
+
|
|
250
|
+
- Terminal typing (can use asciinema)
|
|
251
|
+
- Code scrolling
|
|
252
|
+
- Provider logos (Groq, Mistral, etc.)
|
|
253
|
+
- Money/cost graphics
|
|
254
|
+
- Speedometer for latency
|
|
255
|
+
|
|
256
|
+
## Call to Action
|
|
257
|
+
|
|
258
|
+
- Like the video
|
|
259
|
+
- Subscribe for more
|
|
260
|
+
- Comment with questions
|
|
261
|
+
- Star on GitHub
|
|
262
|
+
- Try the package
|
|
Binary file
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 400" width="1200" height="400">
|
|
2
|
+
<defs>
|
|
3
|
+
<linearGradient id="bgGradient" x1="0%" y1="0%" x2="100%" y2="100%">
|
|
4
|
+
<stop offset="0%" style="stop-color:#0f172a;stop-opacity:1" />
|
|
5
|
+
<stop offset="50%" style="stop-color:#1e1b4b;stop-opacity:1" />
|
|
6
|
+
<stop offset="100%" style="stop-color:#312e81;stop-opacity:1" />
|
|
7
|
+
</linearGradient>
|
|
8
|
+
<linearGradient id="accentGradient" x1="0%" y1="0%" x2="100%" y2="0%">
|
|
9
|
+
<stop offset="0%" style="stop-color:#6366f1;stop-opacity:1" />
|
|
10
|
+
<stop offset="50%" style="stop-color:#8b5cf6;stop-opacity:1" />
|
|
11
|
+
<stop offset="100%" style="stop-color:#06b6d4;stop-opacity:1" />
|
|
12
|
+
</linearGradient>
|
|
13
|
+
<filter id="glowBanner">
|
|
14
|
+
<feGaussianBlur stdDeviation="4" result="coloredBlur"/>
|
|
15
|
+
<feMerge>
|
|
16
|
+
<feMergeNode in="coloredBlur"/>
|
|
17
|
+
<feMergeNode in="SourceGraphic"/>
|
|
18
|
+
</feMerge>
|
|
19
|
+
</filter>
|
|
20
|
+
<pattern id="grid" width="40" height="40" patternUnits="userSpaceOnUse">
|
|
21
|
+
<path d="M 40 0 L 0 0 0 40" fill="none" stroke="rgba(255,255,255,0.03)" stroke-width="1"/>
|
|
22
|
+
</pattern>
|
|
23
|
+
</defs>
|
|
24
|
+
|
|
25
|
+
<!-- Background -->
|
|
26
|
+
<rect width="1200" height="400" fill="url(#bgGradient)"/>
|
|
27
|
+
<rect width="1200" height="400" fill="url(#grid)"/>
|
|
28
|
+
|
|
29
|
+
<!-- Animated Particles -->
|
|
30
|
+
<g opacity="0.3">
|
|
31
|
+
<circle cx="100" cy="100" r="2" fill="#6366f1">
|
|
32
|
+
<animate attributeName="cy" values="100;120;100" dur="4s" repeatCount="indefinite"/>
|
|
33
|
+
<animate attributeName="opacity" values="0.3;0.6;0.3" dur="4s" repeatCount="indefinite"/>
|
|
34
|
+
</circle>
|
|
35
|
+
<circle cx="300" cy="300" r="3" fill="#8b5cf6">
|
|
36
|
+
<animate attributeName="cy" values="300;280;300" dur="5s" repeatCount="indefinite"/>
|
|
37
|
+
<animate attributeName="opacity" values="0.3;0.7;0.3" dur="5s" repeatCount="indefinite"/>
|
|
38
|
+
</circle>
|
|
39
|
+
<circle cx="900" cy="150" r="2" fill="#06b6d4">
|
|
40
|
+
<animate attributeName="cy" values="150;170;150" dur="3s" repeatCount="indefinite"/>
|
|
41
|
+
<animate attributeName="opacity" values="0.3;0.5;0.3" dur="3s" repeatCount="indefinite"/>
|
|
42
|
+
</circle>
|
|
43
|
+
<circle cx="1100" cy="350" r="3" fill="#10b981">
|
|
44
|
+
<animate attributeName="cy" values="350;330;350" dur="6s" repeatCount="indefinite"/>
|
|
45
|
+
<animate attributeName="opacity" values="0.3;0.6;0.3" dur="6s" repeatCount="indefinite"/>
|
|
46
|
+
</circle>
|
|
47
|
+
</g>
|
|
48
|
+
|
|
49
|
+
<!-- Main Logo Icon -->
|
|
50
|
+
<g transform="translate(150, 200)">
|
|
51
|
+
<circle cx="0" cy="0" r="60" fill="none" stroke="url(#accentGradient)" stroke-width="2" opacity="0.3"/>
|
|
52
|
+
<circle cx="0" cy="0" r="50" fill="none" stroke="url(#accentGradient)" stroke-width="1" opacity="0.2" stroke-dasharray="5 5">
|
|
53
|
+
<animateTransform attributeName="transform" type="rotate" from="0 0 0" to="360 0 0" dur="20s" repeatCount="indefinite"/>
|
|
54
|
+
</circle>
|
|
55
|
+
<circle cx="0" cy="0" r="20" fill="url(#accentGradient)" filter="url(#glowBanner)"/>
|
|
56
|
+
<circle cx="0" cy="-35" r="8" fill="#6366f1" opacity="0.9">
|
|
57
|
+
<animateTransform attributeName="transform" type="rotate" from="0 0 0" to="360 0 0" dur="8s" repeatCount="indefinite"/>
|
|
58
|
+
</circle>
|
|
59
|
+
<circle cx="30" cy="18" r="6" fill="#10b981" opacity="0.9">
|
|
60
|
+
<animateTransform attributeName="transform" type="rotate" from="120 0 0" to="480 0 0" dur="10s" repeatCount="indefinite"/>
|
|
61
|
+
</circle>
|
|
62
|
+
<circle cx="-30" cy="18" r="6" fill="#f59e0b" opacity="0.9">
|
|
63
|
+
<animateTransform attributeName="transform" type="rotate" from="240 0 0" to="600 0 0" dur="12s" repeatCount="indefinite"/>
|
|
64
|
+
</circle>
|
|
65
|
+
<text x="0" y="8" font-family="system-ui, -apple-system, sans-serif" font-size="24" font-weight="bold" fill="white" text-anchor="middle">A3M</text>
|
|
66
|
+
</g>
|
|
67
|
+
|
|
68
|
+
<!-- Title -->
|
|
69
|
+
<text x="600" y="160" font-family="system-ui, -apple-system, sans-serif" font-size="72" font-weight="bold" fill="white" text-anchor="middle" filter="url(#glowBanner)">A3M Router</text>
|
|
70
|
+
|
|
71
|
+
<!-- Subtitle -->
|
|
72
|
+
<text x="600" y="210" font-family="system-ui, -apple-system, sans-serif" font-size="28" fill="url(#accentGradient)" text-anchor="middle">Adaptive Memory Multi-Model Router</text>
|
|
73
|
+
|
|
74
|
+
<!-- Tagline -->
|
|
75
|
+
<text x="600" y="250" font-family="system-ui, -apple-system, sans-serif" font-size="18" fill="#94a3b8" text-anchor="middle">Route LLM queries to optimal providers • Save 50-80% on API costs</text>
|
|
76
|
+
|
|
77
|
+
<!-- Stats Bar -->
|
|
78
|
+
<g transform="translate(600, 320)">
|
|
79
|
+
<rect x="-350" y="0" width="700" height="50" rx="25" fill="rgba(255,255,255,0.05)" stroke="rgba(255,255,255,0.1)" stroke-width="1"/>
|
|
80
|
+
|
|
81
|
+
<!-- Stat 1 -->
|
|
82
|
+
<text x="-280" y="32" font-family="system-ui, -apple-system, sans-serif" font-size="14" font-weight="bold" fill="#6366f1" text-anchor="middle">872+</text>
|
|
83
|
+
<text x="-280" y="48" font-family="system-ui, -apple-system, sans-serif" font-size="10" fill="#64748b" text-anchor="middle">Weekly Downloads</text>
|
|
84
|
+
|
|
85
|
+
<!-- Divider -->
|
|
86
|
+
<line x1="-200" y1="10" x2="-200" y2="40" stroke="rgba(255,255,255,0.1)" stroke-width="1"/>
|
|
87
|
+
|
|
88
|
+
<!-- Stat 2 -->
|
|
89
|
+
<text x="-100" y="32" font-family="system-ui, -apple-system, sans-serif" font-size="14" font-weight="bold" fill="#10b981" text-anchor="middle">12</text>
|
|
90
|
+
<text x="-100" y="48" font-family="system-ui, -apple-system, sans-serif" font-size="10" fill="#64748b" text-anchor="middle">LLM Providers</text>
|
|
91
|
+
|
|
92
|
+
<!-- Divider -->
|
|
93
|
+
<line x1="0" y1="10" x2="0" y2="40" stroke="rgba(255,255,255,0.1)" stroke-width="1"/>
|
|
94
|
+
|
|
95
|
+
<!-- Stat 3 -->
|
|
96
|
+
<text x="100" y="32" font-family="system-ui, -apple-system, sans-serif" font-size="14" font-weight="bold" fill="#f59e0b" text-anchor="middle">116</text>
|
|
97
|
+
<text x="100" y="48" font-family="system-ui, -apple-system, sans-serif" font-size="10" fill="#64748b" text-anchor="middle">Integrations</text>
|
|
98
|
+
|
|
99
|
+
<!-- Divider -->
|
|
100
|
+
<line x1="200" y1="10" x2="200" y2="40" stroke="rgba(255,255,255,0.1)" stroke-width="1"/>
|
|
101
|
+
|
|
102
|
+
<!-- Stat 4 -->
|
|
103
|
+
<text x="280" y="32" font-family="system-ui, -apple-system, sans-serif" font-size="14" font-weight="bold" fill="#8b5cf6" text-anchor="middle">33</text>
|
|
104
|
+
<text x="280" y="48" font-family="system-ui, -apple-system, sans-serif" font-size="10" fill="#64748b" text-anchor="middle">Tests Passing</text>
|
|
105
|
+
</g>
|
|
106
|
+
|
|
107
|
+
<!-- Bottom Gradient Line -->
|
|
108
|
+
<rect x="0" y="395" width="1200" height="5" fill="url(#accentGradient)"/>
|
|
109
|
+
</svg>
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 700 400" width="700" height="400">
|
|
2
|
+
<defs>
|
|
3
|
+
<linearGradient id="bgGrad" x1="0%" y1="0%" x2="100%" y2="100%">
|
|
4
|
+
<stop offset="0%" stop-color="#0a0f1c"/>
|
|
5
|
+
<stop offset="100%" stop-color="#111827"/>
|
|
6
|
+
</linearGradient>
|
|
7
|
+
<linearGradient id="openaiGrad" x1="0%" y1="0%" x2="0%" y2="100%">
|
|
8
|
+
<stop offset="0%" stop-color="#2472e8"/>
|
|
9
|
+
<stop offset="100%" stop-color="#1a5bc4"/>
|
|
10
|
+
</linearGradient>
|
|
11
|
+
<linearGradient id="a3mGrad" x1="0%" y1="0%" x2="0%" y2="100%">
|
|
12
|
+
<stop offset="0%" stop-color="#10b981"/>
|
|
13
|
+
<stop offset="100%" stop-color="#059669"/>
|
|
14
|
+
</linearGradient>
|
|
15
|
+
<linearGradient id="savingsGrad" x1="0%" y1="0%" x2="100%" y2="0%">
|
|
16
|
+
<stop offset="0%" stop-color="#10b981"/>
|
|
17
|
+
<stop offset="100%" stop-color="#06b6d4"/>
|
|
18
|
+
</linearGradient>
|
|
19
|
+
|
|
20
|
+
<!-- Glow filter -->
|
|
21
|
+
<filter id="barGlow" x="-20%" y="-20%" width="140%" height="140%">
|
|
22
|
+
<feGaussianBlur stdDeviation="3" result="blur"/>
|
|
23
|
+
<feMerge><feMergeNode in="blur"/><feMergeNode in="SourceGraphic"/></feMerge>
|
|
24
|
+
</filter>
|
|
25
|
+
|
|
26
|
+
<!-- Grid pattern -->
|
|
27
|
+
<pattern id="gridPattern" width="50" height="50" patternUnits="userSpaceOnUse">
|
|
28
|
+
<path d="M 50 0 L 0 0 0 50" fill="none" stroke="#1f2937" stroke-width="0.5" opacity="0.4"/>
|
|
29
|
+
</pattern>
|
|
30
|
+
</defs>
|
|
31
|
+
|
|
32
|
+
<!-- Background -->
|
|
33
|
+
<rect width="700" height="400" fill="url(#bgGrad)"/>
|
|
34
|
+
<rect width="700" height="400" fill="url(#gridPattern)"/>
|
|
35
|
+
|
|
36
|
+
<!-- Header -->
|
|
37
|
+
<text x="350" y="38" text-anchor="middle" fill="#f9fafb" font-family="system-ui,-apple-system,sans-serif" font-size="22" font-weight="700">Cost Comparison — 100 Mixed Queries</text>
|
|
38
|
+
<text x="350" y="60" text-anchor="middle" fill="#6b7280" font-family="system-ui,sans-serif" font-size="13">Code, math, creative, translation tasks</text>
|
|
39
|
+
|
|
40
|
+
<!-- Chart area: x=100..650, y=100..350 -->
|
|
41
|
+
|
|
42
|
+
<!-- Y-axis labels -->
|
|
43
|
+
<g fill="#6b7280" font-family="system-ui,sans-serif" font-size="12" text-anchor="end">
|
|
44
|
+
<text x="85" y="350">$0</text>
|
|
45
|
+
<text x="85" y="280">$5</text>
|
|
46
|
+
<text x="85" y="210">$10</text>
|
|
47
|
+
<text x="85" y="140">$15</text>
|
|
48
|
+
<text x="85" y="100">$20</text>
|
|
49
|
+
</g>
|
|
50
|
+
|
|
51
|
+
<!-- Y-axis grid lines -->
|
|
52
|
+
<g stroke="#1f2937" stroke-width="1" stroke-dasharray="3,3">
|
|
53
|
+
<line x1="100" y1="280" x2="650" y2="280"/>
|
|
54
|
+
<line x1="100" y1="210" x2="650" y2="210"/>
|
|
55
|
+
<line x1="100" y1="140" x2="650" y2="140"/>
|
|
56
|
+
</g>
|
|
57
|
+
|
|
58
|
+
<!-- Axes -->
|
|
59
|
+
<line x1="100" y1="350" x2="650" y2="350" stroke="#374151" stroke-width="2"/>
|
|
60
|
+
<line x1="100" y1="100" x2="100" y2="350" stroke="#374151" stroke-width="2"/>
|
|
61
|
+
|
|
62
|
+
<!-- OpenAI Bar (GPT-4) -->
|
|
63
|
+
<g filter="url(#barGlow)">
|
|
64
|
+
<rect x="150" y="105" width="130" height="245" rx="8" fill="url(#openaiGrad)"/>
|
|
65
|
+
</g>
|
|
66
|
+
<text x="215" y="90" text-anchor="middle" fill="#60a5fa" font-family="system-ui,sans-serif" font-size="16" font-weight="600">$15.00</text>
|
|
67
|
+
<text x="215" y="375" text-anchor="middle" fill="#f9fafb" font-family="system-ui,sans-serif" font-size="15" font-weight="600">GPT-4</text>
|
|
68
|
+
<text x="215" y="392" text-anchor="middle" fill="#6b7280" font-family="system-ui,sans-serif" font-size="11">$0.15/1K tokens</text>
|
|
69
|
+
|
|
70
|
+
<!-- A3M Bar (routed) -->
|
|
71
|
+
<g filter="url(#barGlow)">
|
|
72
|
+
<rect x="420" y="280" width="130" height="70" rx="8" fill="url(#a3mGrad)"/>
|
|
73
|
+
</g>
|
|
74
|
+
<text x="485" y="265" text-anchor="middle" fill="#10b981" font-family="system-ui,sans-serif" font-size="16" font-weight="600">$5.75</text>
|
|
75
|
+
<text x="485" y="375" text-anchor="middle" fill="#f9fafb" font-family="system-ui,sans-serif" font-size="15" font-weight="600">A3M Router</text>
|
|
76
|
+
<text x="485" y="392" text-anchor="middle" fill="#6b7280" font-family="system-ui,sans-serif" font-size="11">auto-routed</text>
|
|
77
|
+
|
|
78
|
+
<!-- Savings badge -->
|
|
79
|
+
<g transform="translate(280, 175)">
|
|
80
|
+
<rect x="0" y="0" width="140" height="60" rx="30" fill="url(#savingsGrad)" fill-opacity="0.15" stroke="url(#savingsGrad)" stroke-width="1.5"/>
|
|
81
|
+
<text x="70" y="28" text-anchor="middle" fill="#10b981" font-family="system-ui,sans-serif" font-size="20" font-weight="800">-62%</text>
|
|
82
|
+
<text x="70" y="48" text-anchor="middle" fill="#6b7280" font-family="system-ui,sans-serif" font-size="11">savings</text>
|
|
83
|
+
</g>
|
|
84
|
+
|
|
85
|
+
<!-- Arrow connecting bars to savings -->
|
|
86
|
+
<path d="M215,200 L310,205" stroke="#10b981" stroke-width="1.5" stroke-dasharray="4,4" fill="none"/>
|
|
87
|
+
<path d="M485,200 L420,205" stroke="#10b981" stroke-width="1.5" stroke-dasharray="4,4" fill="none"/>
|
|
88
|
+
|
|
89
|
+
<!-- Bottom note -->
|
|
90
|
+
<text x="350" y="388" text-anchor="middle" fill="#4b5563" font-family="system-ui,sans-serif" font-size="11">Actual benchmark results • May 2026</text>
|
|
91
|
+
</svg>
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 700 450" width="700" height="450">
|
|
2
|
+
<defs>
|
|
3
|
+
<linearGradient id="bg" x1="0%" y1="0%" x2="100%" y2="100%">
|
|
4
|
+
<stop offset="0%" stop-color="#0a0a0f"/>
|
|
5
|
+
<stop offset="50%" stop-color="#12121a"/>
|
|
6
|
+
<stop offset="100%" stop-color="#1a1a2e"/>
|
|
7
|
+
</linearGradient>
|
|
8
|
+
|
|
9
|
+
<!-- GPT-4 gradient -->
|
|
10
|
+
<linearGradient id="gpt4Grad" x1="0%" y1="0%" x2="0%" y2="100%">
|
|
11
|
+
<stop offset="0%" stop-color="#3b82f6"/>
|
|
12
|
+
<stop offset="100%" stop-color="#1d4ed8"/>
|
|
13
|
+
</linearGradient>
|
|
14
|
+
|
|
15
|
+
<!-- A3M gradient with shimmer -->
|
|
16
|
+
<linearGradient id="a3mGrad" x1="0%" y1="0%" x2="0%" y2="100%">
|
|
17
|
+
<stop offset="0%" stop-color="#10b981">
|
|
18
|
+
<animate attributeName="stop-color" values="#10b981;#34d399;#10b981" dur="3s" repeatCount="indefinite"/>
|
|
19
|
+
</stop>
|
|
20
|
+
<stop offset="100%" stop-color="#059669"/>
|
|
21
|
+
</linearGradient>
|
|
22
|
+
|
|
23
|
+
<!-- Savings badge gradient -->
|
|
24
|
+
<linearGradient id="savingsGrad" x1="0%" y1="0%" x2="100%" y2="0%">
|
|
25
|
+
<stop offset="0%" stop-color="#10b981"/>
|
|
26
|
+
<stop offset="100%" stop-color="#06b6d4"/>
|
|
27
|
+
</linearGradient>
|
|
28
|
+
|
|
29
|
+
<!-- Glow filter -->
|
|
30
|
+
<filter id="glow" x="-50%" y="-50%" width="200%" height="200%">
|
|
31
|
+
<feGaussianBlur stdDeviation="5" result="blur"/>
|
|
32
|
+
<feMerge><feMergeNode in="blur"/><feMergeNode in="SourceGraphic"/></feMerge>
|
|
33
|
+
</filter>
|
|
34
|
+
|
|
35
|
+
<!-- Bar glow -->
|
|
36
|
+
<filter id="barGlow" x="-20%" y="-20%" width="140%" height="140%">
|
|
37
|
+
<feGaussianBlur stdDeviation="3" result="blur"/>
|
|
38
|
+
<feMerge><feMergeNode in="blur"/><feMergeNode in="SourceGraphic"/></feMerge>
|
|
39
|
+
</filter>
|
|
40
|
+
|
|
41
|
+
<!-- Grid pattern -->
|
|
42
|
+
<pattern id="grid" width="40" height="40" patternUnits="userSpaceOnUse">
|
|
43
|
+
<path d="M 40 0 L 0 0 0 40" fill="none" stroke="#ffffff" stroke-width="0.5" opacity="0.04"/>
|
|
44
|
+
</pattern>
|
|
45
|
+
</defs>
|
|
46
|
+
|
|
47
|
+
<style>
|
|
48
|
+
@keyframes fadeIn { from { opacity: 0; transform: translateY(15px); } to { opacity: 1; transform: translateY(0); } }
|
|
49
|
+
@keyframes slideUp { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); } }
|
|
50
|
+
@keyframes pulse { 0%, 100% { box-shadow: 0 0 0 0 rgba(16, 185, 129, 0.4); } 50% { box-shadow: 0 0 20px 5px rgba(16, 185, 129, 0.2); } }
|
|
51
|
+
@keyframes countUp { from { opacity: 0; } to { opacity: 1; } }
|
|
52
|
+
.title { animation: fadeIn 0.6s ease-out; }
|
|
53
|
+
.bar-group { animation: slideUp 0.8s ease-out; animation-fill-mode: both; }
|
|
54
|
+
.gpt4-bar { animation: slideUp 0.8s ease-out 0.1s both; }
|
|
55
|
+
.a3m-bar { animation: slideUp 0.8s ease-out 0.3s both; }
|
|
56
|
+
.savings { animation: slideUp 0.8s ease-out 0.5s both; }
|
|
57
|
+
</style>
|
|
58
|
+
|
|
59
|
+
<!-- Background -->
|
|
60
|
+
<rect width="700" height="450" fill="url(#bg)"/>
|
|
61
|
+
<rect width="700" height="450" fill="url(#grid)"/>
|
|
62
|
+
|
|
63
|
+
<!-- Ambient glow -->
|
|
64
|
+
<ellipse cx="350" cy="225" rx="300" ry="200" fill="#3b82f6" opacity="0.03" filter="url(#glow)"/>
|
|
65
|
+
<ellipse cx="350" cy="300" rx="200" ry="100" fill="#10b981" opacity="0.05" filter="url(#glow)"/>
|
|
66
|
+
|
|
67
|
+
<!-- Header -->
|
|
68
|
+
<g class="title">
|
|
69
|
+
<text x="350" y="42" text-anchor="middle" fill="#ffffff" font-family="system-ui,-apple-system,sans-serif" font-size="26" font-weight="700">
|
|
70
|
+
Cost Comparison
|
|
71
|
+
</text>
|
|
72
|
+
<text x="350" y="65" text-anchor="middle" fill="#8888aa" font-family="system-ui,sans-serif" font-size="13">
|
|
73
|
+
100 mixed queries • Code, math, creative, translation
|
|
74
|
+
</text>
|
|
75
|
+
</g>
|
|
76
|
+
|
|
77
|
+
<!-- Chart area -->
|
|
78
|
+
<g transform="translate(80, 100)">
|
|
79
|
+
<!-- Y-axis labels -->
|
|
80
|
+
<g fill="#666688" font-family="system-ui,sans-serif" font-size="12" text-anchor="end">
|
|
81
|
+
<text x="55" y="255">$0</text>
|
|
82
|
+
<text x="55" y="195">$5</text>
|
|
83
|
+
<text x="55" y="135">$10</text>
|
|
84
|
+
<text x="55" y="75">$15</text>
|
|
85
|
+
<text x="55" y="40">$20</text>
|
|
86
|
+
</g>
|
|
87
|
+
|
|
88
|
+
<!-- Y-axis grid -->
|
|
89
|
+
<g stroke="#ffffff" stroke-opacity="0.06" stroke-dasharray="4,4">
|
|
90
|
+
<line x1="70" y1="190" x2="540" y2="190"/>
|
|
91
|
+
<line x1="70" y1="130" x2="540" y2="130"/>
|
|
92
|
+
<line x1="70" y1="70" x2="540" y2="70"/>
|
|
93
|
+
</g>
|
|
94
|
+
|
|
95
|
+
<!-- Axes -->
|
|
96
|
+
<line x1="70" y1="250" x2="540" y2="250" stroke="#444466" stroke-width="2"/>
|
|
97
|
+
<line x1="70" y1="30" x2="70" y2="250" stroke="#444466" stroke-width="2"/>
|
|
98
|
+
|
|
99
|
+
<!-- GPT-4 Bar with glow -->
|
|
100
|
+
<g class="gpt4-bar" filter="url(#barGlow)">
|
|
101
|
+
<rect x="130" y="65" width="110" height="185" rx="8" fill="url(#gpt4Grad)" class="bar">
|
|
102
|
+
<animate attributeName="height" values="0;185;185" dur="1s" ease-out" fill="freeze"/>
|
|
103
|
+
<animate attributeName="y" values="250;65;65" dur="1s" ease-out" fill="freeze"/>
|
|
104
|
+
</rect>
|
|
105
|
+
<!-- Shine effect -->
|
|
106
|
+
<rect x="130" y="65" width="55" height="185" rx="8" fill="#ffffff" fill-opacity="0.1"/>
|
|
107
|
+
</g>
|
|
108
|
+
<text x="185" y="50" text-anchor="middle" fill="#60a5fa" font-family="system-ui,sans-serif" font-size="18" font-weight="700">$15.00</text>
|
|
109
|
+
<text x="185" y="275" text-anchor="middle" fill="#ffffff" font-family="system-ui,sans-serif" font-size="15" font-weight="600">GPT-4</text>
|
|
110
|
+
<text x="185" y="292" text-anchor="middle" fill="#666688" font-family="system-ui,sans-serif" font-size="11">$0.15/1K tokens</text>
|
|
111
|
+
|
|
112
|
+
<!-- A3M Bar with glow -->
|
|
113
|
+
<g class="a3m-bar" filter="url(#barGlow)">
|
|
114
|
+
<rect x="380" y="200" width="110" height="50" rx="8" fill="url(#a3mGrad)" class="bar">
|
|
115
|
+
<animate attributeName="height" values="0;50;50" dur="1s" ease-out" fill="freeze"/>
|
|
116
|
+
<animate attributeName="y" values="250;200;200" dur="1s" ease-out" fill="freeze"/>
|
|
117
|
+
</rect>
|
|
118
|
+
<!-- Shine effect -->
|
|
119
|
+
<rect x="380" y="200" width="55" height="50" rx="8" fill="#ffffff" fill-opacity="0.15"/>
|
|
120
|
+
</g>
|
|
121
|
+
<text x="435" y="185" text-anchor="middle" fill="#10b981" font-family="system-ui,sans-serif" font-size="18" font-weight="700">$5.75</text>
|
|
122
|
+
<text x="435" y="275" text-anchor="middle" fill="#ffffff" font-family="system-ui,sans-serif" font-size="15" font-weight="600">A3M Router</text>
|
|
123
|
+
<text x="435" y="292" text-anchor="middle" fill="#666688" font-family="system-ui,sans-serif" font-size="11">auto-routed</text>
|
|
124
|
+
|
|
125
|
+
<!-- Savings badge -->
|
|
126
|
+
<g class="savings">
|
|
127
|
+
<rect x="230" y="115" width="160" height="65" rx="32" fill="url(#savingsGrad)" fill-opacity="0.15" stroke="url(#savingsGrad)" stroke-width="1.5" filter="url(#glow)"/>
|
|
128
|
+
<text x="310" y="145" text-anchor="middle" fill="#10b981" font-family="system-ui,sans-serif" font-size="26" font-weight="800">-62%</text>
|
|
129
|
+
<text x="310" y="168" text-anchor="middle" fill="#8888aa" font-family="system-ui,sans-serif" font-size="12">savings per query</text>
|
|
130
|
+
</g>
|
|
131
|
+
|
|
132
|
+
<!-- Connection lines -->
|
|
133
|
+
<path d="M185,130 L260,148" stroke="#10b981" stroke-width="1.5" stroke-dasharray="4,4" fill="none" opacity="0.6"/>
|
|
134
|
+
<path d="M435,175 L390,148" stroke="#10b981" stroke-width="1.5" stroke-dasharray="4,4" fill="none" opacity="0.6"/>
|
|
135
|
+
</g>
|
|
136
|
+
|
|
137
|
+
<!-- Bottom info -->
|
|
138
|
+
<g transform="translate(0, 400)">
|
|
139
|
+
<text x="350" y="20" text-anchor="middle" fill="#555577" font-family="system-ui,sans-serif" font-size="11">
|
|
140
|
+
Based on actual benchmark • May 2026 • Real provider pricing
|
|
141
|
+
</text>
|
|
142
|
+
</g>
|
|
143
|
+
</svg>
|