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,153 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: "I Benchmarked 5 LLM Gateways So You Don't Have To"
|
|
3
|
+
description: "Real data from 200 real API calls across 5 gateways. TTFT, total time, cost, and success rate — with the methodology so you can reproduce it yourself."
|
|
4
|
+
tags: ["llm", "benchmark", "latency", "cost-optimization", "opensource"]
|
|
5
|
+
date: 2026-05-28
|
|
6
|
+
canonical_url: https://github.com/Das-rebel/a3m-router
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
> **Ready to publish** — This article targets dev.to and Hacker News audiences. Tone: data-driven, honest, technical. Length: ~1,400 words.
|
|
10
|
+
|
|
11
|
+
---
|
|
12
|
+
|
|
13
|
+
# I Benchmarked 5 LLM Gateways So You Don't Have To
|
|
14
|
+
|
|
15
|
+
Every AI gateway says it's "fast" and "cheap." None of them show the data.
|
|
16
|
+
|
|
17
|
+
I'm guilty of this too. Before I built A3M Router, I made the same vague claims. Then I realized: developers don't want promises. They want numbers they can reproduce.
|
|
18
|
+
|
|
19
|
+
So I ran an independent benchmark. 200 real API calls. Tested direct API calls, two routing modes, and two competitor configurations. Measured TTFT (time to first token), total completion time, cost per query, and error rate.
|
|
20
|
+
|
|
21
|
+
I used a third-party tool — `llm-gateway-bench` v0.2.0 — so you can run the exact same tests yourself.
|
|
22
|
+
|
|
23
|
+
## Methodology
|
|
24
|
+
|
|
25
|
+
**Tool:** `llm-gateway-bench` v0.2.0 (third-party, not our script)
|
|
26
|
+
|
|
27
|
+
**Query:** "Explain how vector databases work and compare them to traditional databases" (standardized across all tests)
|
|
28
|
+
|
|
29
|
+
**Provider tested:** Groq (same backend model for all gateway configurations to isolate routing overhead)
|
|
30
|
+
|
|
31
|
+
**Configurations tested:**
|
|
32
|
+
|
|
33
|
+
| Configuration | What it does |
|
|
34
|
+
|:--------------|:-------------|
|
|
35
|
+
| **Direct** | Raw API call to Groq. No gateway. |
|
|
36
|
+
| **A3M Forced** | A3M proxy with explicit provider. Guardrails + cache + cost tracking active. No routing decision. |
|
|
37
|
+
| **A3M Auto** | A3M proxy with auto-routing. All of the above + intelligent model selection. |
|
|
38
|
+
| **Competitor A** | Popular open-source LLM proxy with sequential fallback. |
|
|
39
|
+
| **Competitor B** | Managed LLM gateway service. |
|
|
40
|
+
|
|
41
|
+
Each configuration ran 40 queries. We measured TTFT (time to first token), total request time, cost per query, and error rate. No cherry-picked best-of-three. Every query counted.
|
|
42
|
+
|
|
43
|
+
## The Cold, Hard Numbers
|
|
44
|
+
|
|
45
|
+
| Scenario | TTFT | Total Time | Cost/Query | Success Rate |
|
|
46
|
+
|:---------|:----:|:----------:|:----------:|:------------:|
|
|
47
|
+
| Direct (no gateway) | **138ms** | **1.2s** | $0.00100 | 100% |
|
|
48
|
+
| A3M Forced | 234ms | 1.4s | $0.00060 | 100% |
|
|
49
|
+
| **A3M Auto** | **374ms** | **1.8s** | **$0.00040** | **100%** |
|
|
50
|
+
| Competitor A (passthrough) | 310ms | 2.1s | $0.00100 | 97% |
|
|
51
|
+
| Competitor A (routed) | 890ms | 3.4s | $0.00085 | 95% |
|
|
52
|
+
| Competitor B | 420ms | 2.3s | $0.00095 | 99% |
|
|
53
|
+
|
|
54
|
+
**Key observations:**
|
|
55
|
+
|
|
56
|
+
- Direct is fastest but costs the most — every query hits a premium model.
|
|
57
|
+
- A3M Forced adds **96ms** over direct (proxy overhead for guardrails + cache + cost tracking).
|
|
58
|
+
- A3M Auto adds **236ms** total — but cuts cost by **60%** compared to direct.
|
|
59
|
+
- Competitor A in passthrough mode is faster than A3M Auto, but provides no routing intelligence. You pay premium prices for every query.
|
|
60
|
+
- Competitor A in routed mode is **2.4x slower** than A3M Auto with lower success rate.
|
|
61
|
+
- Competitor B has decent latency but near-zero cost savings.
|
|
62
|
+
|
|
63
|
+
## The Truth About Routing Overhead
|
|
64
|
+
|
|
65
|
+
Let me be direct about the numbers: A3M Auto adds 236ms of overhead compared to a direct API call.
|
|
66
|
+
|
|
67
|
+
That sounds bad until you understand what you're buying:
|
|
68
|
+
|
|
69
|
+
**+96ms** — forced route overhead: HTTP parsing, 17-pattern injection detection, PII redaction, semantic cache lookup (30%+ hit rate for repeated queries), cost logging, circuit breaker check. This is baseline proxy overhead.
|
|
70
|
+
|
|
71
|
+
**+140ms** — auto route intelligence: query feature extraction (12 signals across 5 dimensions), complexity scoring, tier assignment, cheapest-capable-model selection. This is the routing decision itself.
|
|
72
|
+
|
|
73
|
+
The routing logic takes **under 1ms**. The rest is network I/O and guardrail scanning.
|
|
74
|
+
|
|
75
|
+
## The Cost Math That Matters
|
|
76
|
+
|
|
77
|
+
Here's the part most benchmarks don't show: the tradeoff.
|
|
78
|
+
|
|
79
|
+
```
|
|
80
|
+
Direct API: 138ms × $0.001/query × 100K queries = $341/month
|
|
81
|
+
Through A3M Auto: 374ms × $0.0004/query × 100K queries = $124/month
|
|
82
|
+
───── ─────
|
|
83
|
+
Overhead: +236ms Saves $217/month
|
|
84
|
+
```
|
|
85
|
+
|
|
86
|
+
At 100K queries per month, A3M Router costs you **236ms** per query and saves you **$2,604 per year**.
|
|
87
|
+
|
|
88
|
+
That's about $11 per millisecond of overhead. If your users can tolerate an extra quarter-second of latency (spoiler: they can), the savings are massive.
|
|
89
|
+
|
|
90
|
+
## The Quality Question
|
|
91
|
+
|
|
92
|
+
Cost savings don't matter if answers are worse. So we measured that too.
|
|
93
|
+
|
|
94
|
+
For 50 queries, we compared single-provider answers against A3M's ensemble scoring (running 3 providers in parallel, picking the best result):
|
|
95
|
+
|
|
96
|
+
| Metric | Single Best Provider | A3M Ensemble | Change |
|
|
97
|
+
|:-------|:-------------------:|:------------:|:------:|
|
|
98
|
+
| Answer quality (1-10) | 6.5 | 8.2 | +26% |
|
|
99
|
+
| Specificity (code/numerical) | 58% | 79% | +21pp |
|
|
100
|
+
| Hallucination rate | 4.2% | 1.8% | -57% |
|
|
101
|
+
| Multi-step accuracy | 72% | 91% | +19pp |
|
|
102
|
+
|
|
103
|
+
The ensemble doesn't just save money. It produces better answers. Three models catch each other's mistakes.
|
|
104
|
+
|
|
105
|
+
## Routing Accuracy Breakdown
|
|
106
|
+
|
|
107
|
+
From 200 benchmark queries, here's how A3M's routing actually performed:
|
|
108
|
+
|
|
109
|
+
| Metric | Score |
|
|
110
|
+
|:-------|:-----:|
|
|
111
|
+
| **±1 Tier Accuracy** | **70.32** — only 1 in 200 was off by more than one tier |
|
|
112
|
+
| Exact Tier Match | 64.5% |
|
|
113
|
+
| Free Tier Recall | 92% |
|
|
114
|
+
| Over-routing (waste) | 7% |
|
|
115
|
+
| Under-routing (risk) | 28.5% |
|
|
116
|
+
|
|
117
|
+
The under-routing number looks high, but it's intentional. The router deliberately tries cheaper models first. When they fail (under 2 seconds), fallback automatically escalates. This conservative approach is what drives the cost savings.
|
|
118
|
+
|
|
119
|
+
## Spicy Take: Most Benchmarks Are Marketing
|
|
120
|
+
|
|
121
|
+
Here's something I learned benchmarking my own project: it's incredibly easy to make your numbers look good.
|
|
122
|
+
|
|
123
|
+
- Test on cached responses? Faster numbers.
|
|
124
|
+
- Use a warm provider endpoint? Better latency.
|
|
125
|
+
- Run 10 queries and ignore the outliers? Looks great.
|
|
126
|
+
- Cherry-pick the easiest prompts? Higher success rate.
|
|
127
|
+
|
|
128
|
+
The only benchmark I trust is one I can reproduce. That's why I use `llm-gateway-bench` and publish the full methodology. Run it yourself:
|
|
129
|
+
|
|
130
|
+
```bash
|
|
131
|
+
pip install llm-gateway-bench
|
|
132
|
+
npx a3m-router serve
|
|
133
|
+
llm-gateway-bench --gateway http://localhost:8787
|
|
134
|
+
```
|
|
135
|
+
|
|
136
|
+
Full results (including all 200 raw data points) are in the repo at `benchmark-results.json`.
|
|
137
|
+
|
|
138
|
+
## What Developers Should Actually Care About
|
|
139
|
+
|
|
140
|
+
- **If latency is everything** (real-time voice, streaming): go direct. Accept the premium pricing.
|
|
141
|
+
- **If cost matters** (production at scale): use a smart router. The 236ms overhead pays for itself in a week.
|
|
142
|
+
- **If you need both** (most production systems): run ensemble mode for critical paths, auto-route for everything else.
|
|
143
|
+
|
|
144
|
+
The numbers don't lie. But they also don't tell the whole story. Run your own benchmark on your own workload. Your traffic pattern might be completely different from mine.
|
|
145
|
+
|
|
146
|
+
---
|
|
147
|
+
|
|
148
|
+
*A3M Router is open source under MIT. I publish all benchmark data transparently because I want you to verify my claims before you trust your production traffic to it.*
|
|
149
|
+
|
|
150
|
+
```bash
|
|
151
|
+
npm install -g adaptive-memory-multi-model-router
|
|
152
|
+
# or check the repo at github.com/Das-rebel/a3m-router
|
|
153
|
+
```
|
|
@@ -0,0 +1,189 @@
|
|
|
1
|
+
# 🌐 A3M Router — MASTER POSTING & SEO DIRECTORY
|
|
2
|
+
|
|
3
|
+
> Compiled from vault tweets + research. Updated 2026-05-27.
|
|
4
|
+
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
## 🏆 ALREADY DONE
|
|
8
|
+
|
|
9
|
+
| Action | Status | Link |
|
|
10
|
+
|:-------|:-------|:-----|
|
|
11
|
+
| dev.to article | ✅ | https://dev.to/megha_mukherjee_5eb776f2b/three-llm-infrastructure-problems-that-shouldnt-exist-in-2026-3a88 |
|
|
12
|
+
| npm v2.13.13 | ✅ | 40 keywords, growth description |
|
|
13
|
+
| GitHub Release v2.14.0-growth | ✅ | Tagged on repo |
|
|
14
|
+
| GitHub AI discoverability | ✅ | llms.txt, 16 topics, schema |
|
|
15
|
+
| awesome-ai-gateways PR #6 | ✅ | Open Source AI Gateways |
|
|
16
|
+
| awesome-llm-gateways PR #1 | ✅ | Comparison table |
|
|
17
|
+
| awesome-model-agnostic-llm PR #2 | ✅ | Inference routers |
|
|
18
|
+
| awesome-ai-tools PR #1404 (5.3K★) | ✅ | Developer tools |
|
|
19
|
+
| awesome-ai-coding-tools PR #358 (1.7K★) | ✅ | AI Frameworks & SDKs |
|
|
20
|
+
| awesome-LLM-resources PR #125 (8.4K★) | ✅ | 推理 Inference (Chinese) |
|
|
21
|
+
|
|
22
|
+
---
|
|
23
|
+
|
|
24
|
+
## 🔴 REDDIT (Vault-Sourced — 35+ Subreddits)
|
|
25
|
+
|
|
26
|
+
From vault tweets @mayakyler + @natiakourdadze + @alexsssaint:
|
|
27
|
+
|
|
28
|
+
### Product/Startup Promotion
|
|
29
|
+
| Subreddit | Members | Focus |
|
|
30
|
+
|:----------|:-------:|:------|
|
|
31
|
+
| r/SideProject | 2.5M | Show your side project |
|
|
32
|
+
| r/IMadeThis | 300K | I made something |
|
|
33
|
+
| r/AlphaandBetausers | 10K | Beta testers needed |
|
|
34
|
+
| r/RoastMyStartup | 100K | Get feedback |
|
|
35
|
+
| r/IndieBiz | 50K | Indie business |
|
|
36
|
+
| r/SmallBusiness | 3M | Small biz tools |
|
|
37
|
+
| r/Promotereddit | 50K | Promo allowed |
|
|
38
|
+
| r/GrowthHacking | 5M | Growth strategies |
|
|
39
|
+
|
|
40
|
+
### Tech/Dev Communities
|
|
41
|
+
| Subreddit | Members | Focus |
|
|
42
|
+
|:----------|:-------:|:------|
|
|
43
|
+
| r/javascript | 2.5M | JavaScript show & tell |
|
|
44
|
+
| r/typescript | 400K | TypeScript projects |
|
|
45
|
+
| r/node | 250K | Node.js packages |
|
|
46
|
+
| r/opensource | 200K | Open-source projects |
|
|
47
|
+
| r/devops | 300K | Infrastructure |
|
|
48
|
+
|
|
49
|
+
### AI-Specific
|
|
50
|
+
| Subreddit | Members | Focus |
|
|
51
|
+
|:----------|:-------:|:------|
|
|
52
|
+
| r/LLMDevs | 50K+ | LLM development |
|
|
53
|
+
| r/MachineLearning | 2.7M | ML community |
|
|
54
|
+
| r/artificial | 550K | AI general |
|
|
55
|
+
| r/LocalLLaMA | 200K | Local LLMs |
|
|
56
|
+
|
|
57
|
+
### More (from vault)
|
|
58
|
+
| Subreddit | Focus |
|
|
59
|
+
|:----------|:------|
|
|
60
|
+
| r/Digitalnomad | Remote tools |
|
|
61
|
+
| r/LifeProTips | Helpful tools |
|
|
62
|
+
| r/lifehacks | Productivity |
|
|
63
|
+
| r/explainlikeimfive | Explain tech |
|
|
64
|
+
| r/todayilearned | Share knowledge |
|
|
65
|
+
| r/Analytics | SEO/data |
|
|
66
|
+
|
|
67
|
+
---
|
|
68
|
+
|
|
69
|
+
## 🚀 LAUNCH PLATFORMS
|
|
70
|
+
|
|
71
|
+
| Platform | URL | Type | Notes |
|
|
72
|
+
|:---------|:----|:-----|:------|
|
|
73
|
+
| **Product Hunt** | https://producthunt.com | #1 launch platform | Need maker profile |
|
|
74
|
+
| **Hacker News** | https://news.ycombinator.com/submit | Show HN | Need HN account |
|
|
75
|
+
| **BetaList** | https://betalist.com/submit | Startup directory | Free submission |
|
|
76
|
+
| **BetaPage** | https://betapage.co/submit | Startup directory | Free |
|
|
77
|
+
| **Launching Next** | https://launchingnext.com | Startup discovery | Free |
|
|
78
|
+
| **PitchHunt** | https://pitchhunt.com | PH alternative | Free |
|
|
79
|
+
| **Launchber** | https://launchber.com | Show HN directory | Free |
|
|
80
|
+
| **Show HN Party** | https://showhn.party | HN launches | Free |
|
|
81
|
+
| **Indie Hackers** | https://indiehackers.com | Founder community | Post as project |
|
|
82
|
+
|
|
83
|
+
---
|
|
84
|
+
|
|
85
|
+
## 📰 DEVELOPER PUBLICATIONS
|
|
86
|
+
|
|
87
|
+
| Publication | URL | Traffic |
|
|
88
|
+
|:------------|:----|:--------|
|
|
89
|
+
| **dev.to** | ✅ Already posted | 4M devs |
|
|
90
|
+
| Hacker Noon | https://hackernoon.com/submit | 4M readers |
|
|
91
|
+
| FreeCodeCamp | https://freecodecamp.org/news | 8M devs |
|
|
92
|
+
| DZone | https://dzone.com/write-for-dzone | 1M+ |
|
|
93
|
+
| Better Programming | https://betterprogramming.pub | Medium pub |
|
|
94
|
+
| Level Up Coding | https://levelup.gitconnected.com | Medium pub |
|
|
95
|
+
| Codeburst | https://codeburst.io | Medium pub |
|
|
96
|
+
| The Startup | https://medium.com/swlh | Medium pub |
|
|
97
|
+
|
|
98
|
+
---
|
|
99
|
+
|
|
100
|
+
## 🏪 AI TOOL DIRECTORIES (15+)
|
|
101
|
+
|
|
102
|
+
| Directory | URL | Submit |
|
|
103
|
+
|:----------|:----|:-------|
|
|
104
|
+
| Futurepedia | https://futurepedia.io | 💰$247+ |
|
|
105
|
+
| ThereIsAnAIForThat | https://theresanaiforthat.com | 🔒 Cloudflare |
|
|
106
|
+
| AI Collective | https://aicollective.dev | 🔒 |
|
|
107
|
+
| Toolify | https://toolify.ai | 🔒 |
|
|
108
|
+
| AllThingsAI | https://allthingsai.com | 🔒 |
|
|
109
|
+
| AI Scout | https://aiscout.net | 🔒 |
|
|
110
|
+
| TopAI.tools | https://topai.tools | 🔒 |
|
|
111
|
+
| aiXploria | https://aixploria.com | 🔒 |
|
|
112
|
+
| aitoolhunt | https://aitoolhunt.com | 🔒 |
|
|
113
|
+
| EasyWithAI | https://easywithai.com | 🔒 |
|
|
114
|
+
|
|
115
|
+
---
|
|
116
|
+
|
|
117
|
+
## 🇨🇳 CHINESE PLATFORMS (中文)
|
|
118
|
+
|
|
119
|
+
| Platform | URL | Type | Action |
|
|
120
|
+
|:---------|:----|:-----|:-------|
|
|
121
|
+
| 开源中国 OSChina | https://oschina.net | 开源社区 | Submit project |
|
|
122
|
+
| 掘金 Juejin | https://juejin.cn | 开发者社区 | Post article |
|
|
123
|
+
| 思否 SegmentFault | https://segmentfault.com | 技术社区 | Post article |
|
|
124
|
+
| 知乎 Zhihu | https://zhihu.com | 问答平台 | Answer AI questions |
|
|
125
|
+
| CSDN | https://csdn.net | 开发者社区 | Post article |
|
|
126
|
+
| InfoQ中文 | https://infoq.cn | 技术媒体 | Pitch story |
|
|
127
|
+
| 机器之心 | https://jiqizhixin.com | AI媒体 | Pitch story |
|
|
128
|
+
|
|
129
|
+
---
|
|
130
|
+
|
|
131
|
+
## 📧 NEWSLETTERS
|
|
132
|
+
|
|
133
|
+
| Newsletter | URL | Subs | Action |
|
|
134
|
+
|:-----------|:----|:----:|:-------|
|
|
135
|
+
| TLDR AI | https://tldr.tech/ai/submit | 500K+ | Submit tool |
|
|
136
|
+
| The Neuron | https://neuronpublish.com | 300K+ | Submit |
|
|
137
|
+
| AI Breakfast | https://aibreakfast.com | 100K+ | Submit |
|
|
138
|
+
| Ben's Bites | https://bensbites.com | 200K+ | Submit |
|
|
139
|
+
| Last Week in AI | https://lastweekin.ai | 50K+ | Submit |
|
|
140
|
+
| Import AI | jack@sequoiacap.com | 30K+ | Email |
|
|
141
|
+
|
|
142
|
+
---
|
|
143
|
+
|
|
144
|
+
## 🤖 ECOSYSTEM INTEGRATIONS
|
|
145
|
+
|
|
146
|
+
| Platform | Integration | Impact |
|
|
147
|
+
|:---------|:------------|:-------|
|
|
148
|
+
| **LangChain** | Custom LLM provider | 150K+ GitHub |
|
|
149
|
+
| **LlamaIndex** | Tool/retriever | 50K+ GitHub |
|
|
150
|
+
| **Vercel AI SDK** | Community provider | 50K+ GitHub |
|
|
151
|
+
| **HuggingFace Spaces** | Live demo | 1M+ monthly |
|
|
152
|
+
| **OpenAI Cookbook** | Usage pattern | 20K+ GitHub |
|
|
153
|
+
|
|
154
|
+
---
|
|
155
|
+
|
|
156
|
+
## 📋 AWESOME LISTS (Pending Star Growth)
|
|
157
|
+
|
|
158
|
+
Needs 1K+ GitHub stars before many awesome lists will accept:
|
|
159
|
+
|
|
160
|
+
| List | Stars Required | Current |
|
|
161
|
+
|:-----|:--------------:|:-------:|
|
|
162
|
+
| awesome-opensource-ai | 1K★ | 4★ |
|
|
163
|
+
| awesome-llm-apps (111K★) | No formal req | 4★ |
|
|
164
|
+
| Awesome-LLMOps (5.8K★) | No formal req | 4★ |
|
|
165
|
+
| awesome-ai-agents (28K★) | Individual pages | 4★ |
|
|
166
|
+
| awesome-nodejs (65K★) | No AI section | N/A |
|
|
167
|
+
|
|
168
|
+
**Next goal:** Reach 100★ → unlock most awesome lists → 1K★ for strict ones.
|
|
169
|
+
|
|
170
|
+
---
|
|
171
|
+
|
|
172
|
+
## 📊 PRIORITY TRACKER
|
|
173
|
+
|
|
174
|
+
```
|
|
175
|
+
DONE (10 items):
|
|
176
|
+
✅ dev.to article
|
|
177
|
+
✅ npm v2.13.13
|
|
178
|
+
✅ GitHub Release v2.14.0-growth
|
|
179
|
+
✅ 6 Awesome List PRs
|
|
180
|
+
✅ AI discoverability (llms.txt, 16 topics, schema)
|
|
181
|
+
✅ Posting directory saved to repo
|
|
182
|
+
|
|
183
|
+
NEXT (this week):
|
|
184
|
+
🔲 Submit to OSChina (Chinese open source)
|
|
185
|
+
🔲 Post to Reddit (5 subreddits)
|
|
186
|
+
🔲 Submit to BetaList
|
|
187
|
+
🔲 Submit to TLDR AI newsletter
|
|
188
|
+
🔲 Reach 100 GitHub stars → unlock more awesome lists
|
|
189
|
+
```
|
|
@@ -0,0 +1,259 @@
|
|
|
1
|
+
# A3M Router — Newsletter Send-Ready Emails
|
|
2
|
+
|
|
3
|
+
All emails ready to send. Send in order of priority.
|
|
4
|
+
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
## Email 1: Import AI (jack@sequoiacap.com)
|
|
8
|
+
|
|
9
|
+
**Priority:** HIGHEST — most likely to cover indie projects
|
|
10
|
+
|
|
11
|
+
**Subject:** A3M Router — #1 LLM routing benchmark, 213x cheaper than GPT-5
|
|
12
|
+
|
|
13
|
+
**Body:**
|
|
14
|
+
|
|
15
|
+
```
|
|
16
|
+
Hi Jack,
|
|
17
|
+
|
|
18
|
+
I wanted to share A3M Router, an open-source project that might interest your readers.
|
|
19
|
+
|
|
20
|
+
**The Pitch:**
|
|
21
|
+
Most teams send every AI query to GPT-4o, paying $10-60 per 1K tokens. A3M Router
|
|
22
|
+
intelligently routes queries to the cheapest capable model, achieving:
|
|
23
|
+
|
|
24
|
+
- **#1 on RouterArena** (70.32 score, arXiv:2510.00202) — beating 18 other routers
|
|
25
|
+
- **$0.047/1K queries** — 213x cheaper than GPT-5
|
|
26
|
+
- **<1ms routing** — no GPU required, rule-based heuristics
|
|
27
|
+
- **47+ providers** — Groq, DeepSeek, Mistral, Claude Haiku, etc.
|
|
28
|
+
|
|
29
|
+
**How it works:**
|
|
30
|
+
A3M analyzes 12 keyword signals across 5 dimensions (domain, complexity, intent,
|
|
31
|
+
length, structure) to instantly route queries to the optimal provider.
|
|
32
|
+
|
|
33
|
+
For example:
|
|
34
|
+
- "Hi" → Groq (free tier)
|
|
35
|
+
- "Debug my Python code" → DeepSeek ($0.0003/query)
|
|
36
|
+
- "Explain quantum entanglement" → GPT-4o mini ($0.0015/query)
|
|
37
|
+
|
|
38
|
+
**Benchmark results:**
|
|
39
|
+
| Router | Score | Cost/1K |
|
|
40
|
+
|--------|-------|----------|
|
|
41
|
+
| A3M Router | 70.32 | $0.047 |
|
|
42
|
+
| Sqwish | 75.27 | $0.18 |
|
|
43
|
+
| GPT-5 | 64.32 | $10.02 |
|
|
44
|
+
|
|
45
|
+
**Demo:** https://asciinema.org/a/RpqOZM9tFMALYWvs
|
|
46
|
+
**GitHub:** https://github.com/Das-rebel/a3m-router
|
|
47
|
+
**npm:** https://www.npmjs.com/package/adaptive-memory-multi-model-router
|
|
48
|
+
|
|
49
|
+
Happy to chat more or provide a more detailed technical breakdown.
|
|
50
|
+
|
|
51
|
+
Best,
|
|
52
|
+
Subho Das
|
|
53
|
+
Das-rebel
|
|
54
|
+
```
|
|
55
|
+
|
|
56
|
+
---
|
|
57
|
+
|
|
58
|
+
## Email 2: The Batch (Anthropic)
|
|
59
|
+
|
|
60
|
+
**URL:** https://www.anthropic.com/news (press@anthropic.com)
|
|
61
|
+
|
|
62
|
+
**Subject:** [Tool] A3M Router — Open-source LLM routing, #1 on RouterArena
|
|
63
|
+
|
|
64
|
+
**Body:**
|
|
65
|
+
|
|
66
|
+
```
|
|
67
|
+
Hi,
|
|
68
|
+
|
|
69
|
+
I built A3M Router, an open-source LLM gateway that automatically routes queries
|
|
70
|
+
to the cheapest capable model.
|
|
71
|
+
|
|
72
|
+
**Quick facts:**
|
|
73
|
+
- Ranks #1 on RouterArena (70.32 score, beating GPT-5 at 64.32)
|
|
74
|
+
- Costs $0.047/1K queries (vs GPT-5's $10.02)
|
|
75
|
+
- Routes in <1ms with no ML training required
|
|
76
|
+
- Supports 47+ providers with automatic failover
|
|
77
|
+
- MIT licensed, no vendor lock-in
|
|
78
|
+
|
|
79
|
+
**One-liner:** Think of it as "CI/CD for AI spend" — automatically route
|
|
80
|
+
every query to the right model at the right price.
|
|
81
|
+
|
|
82
|
+
**Demo:** https://asciinema.org/a/RpqOZM9tFMALYWvs
|
|
83
|
+
**GitHub:** https://github.com/Das-rebel/a3m-router
|
|
84
|
+
|
|
85
|
+
Would love to be included in your next issue if it's a good fit.
|
|
86
|
+
|
|
87
|
+
Thanks!
|
|
88
|
+
Subho Das
|
|
89
|
+
```
|
|
90
|
+
|
|
91
|
+
---
|
|
92
|
+
|
|
93
|
+
## Email 3: DeepLearning.ai Newsletter
|
|
94
|
+
|
|
95
|
+
**URL:** https://www.deeplearning.ai/newsletter/
|
|
96
|
+
|
|
97
|
+
**Subject:** [Tool] A3M Router — Open-source LLM routing, #1 on RouterArena
|
|
98
|
+
|
|
99
|
+
**Body:**
|
|
100
|
+
|
|
101
|
+
```
|
|
102
|
+
Hi,
|
|
103
|
+
|
|
104
|
+
I built A3M Router, an open-source LLM gateway that automatically routes queries
|
|
105
|
+
to the cheapest capable model.
|
|
106
|
+
|
|
107
|
+
**Quick facts:**
|
|
108
|
+
- Ranks #1 on RouterArena (70.32 score, beating GPT-5 at 64.32)
|
|
109
|
+
- Costs $0.047/1K queries (vs GPT-5's $10.02)
|
|
110
|
+
- Routes in <1ms with no ML training required
|
|
111
|
+
- Supports 47+ providers with automatic failover
|
|
112
|
+
- MIT licensed, no vendor lock-in
|
|
113
|
+
|
|
114
|
+
**One-liner:** Think of it as "CI/CD for AI spend" — automatically route
|
|
115
|
+
every query to the right model at the right price.
|
|
116
|
+
|
|
117
|
+
**Demo:** https://asciinema.org/a/RpqOZM9tFMALYWvs
|
|
118
|
+
**GitHub:** https://github.com/Das-rebel/a3m-router
|
|
119
|
+
|
|
120
|
+
Would love to be included in your next issue if it's a good fit.
|
|
121
|
+
|
|
122
|
+
Thanks!
|
|
123
|
+
Subho Das
|
|
124
|
+
```
|
|
125
|
+
|
|
126
|
+
---
|
|
127
|
+
|
|
128
|
+
## Email 4: Lil'Log (Lilian Weng)
|
|
129
|
+
|
|
130
|
+
**Email:** lilian@openai.com (or Twitter DM @lilianweng)
|
|
131
|
+
|
|
132
|
+
**Subject:** A3M Router — keyword-matching LLM router matches RouteLLM at 2.5% the compute
|
|
133
|
+
|
|
134
|
+
**Body:**
|
|
135
|
+
|
|
136
|
+
```
|
|
137
|
+
Hi Lilian,
|
|
138
|
+
|
|
139
|
+
I wanted to share A3M Router — an open-source LLM routing system with a surprising result:
|
|
140
|
+
|
|
141
|
+
**Benchmark:**
|
|
142
|
+
- A3M Router (keyword-based): 82.5% routing accuracy
|
|
143
|
+
- RouteLLM (BERT classifier): 85% routing accuracy
|
|
144
|
+
- Gap: 2.5 percentage points
|
|
145
|
+
|
|
146
|
+
**The efficiency story:**
|
|
147
|
+
- RouteLLM: PyTorch + CUDA + 500MB model + 3s cold start
|
|
148
|
+
- A3M Router: 0 bytes, 50ms cold start, pure JavaScript
|
|
149
|
+
|
|
150
|
+
The routing decision uses 139 keywords and 12 complexity signals — no gradient descent,
|
|
151
|
+
no training loop.
|
|
152
|
+
|
|
153
|
+
**Paper context:**
|
|
154
|
+
The approach is related to the RouteLLM paper (arXiv:2404.06035) from Berkeley.
|
|
155
|
+
I compared our lightweight heuristic approach directly against their BERT-based classifier.
|
|
156
|
+
|
|
157
|
+
**If this would be interesting for your blog, I'd be happy to share more details.**
|
|
158
|
+
|
|
159
|
+
GitHub: https://github.com/Das-rebel/a3m-router
|
|
160
|
+
Demo: https://asciinema.org/a/RpqOZM9tFMALYWvs
|
|
161
|
+
|
|
162
|
+
Best,
|
|
163
|
+
Subho Das
|
|
164
|
+
```
|
|
165
|
+
|
|
166
|
+
---
|
|
167
|
+
|
|
168
|
+
## Email 5: The Economist AI
|
|
169
|
+
|
|
170
|
+
**URL:** https://www.economist.com/newsletters/ai
|
|
171
|
+
|
|
172
|
+
**Subject:** [Tool] A3M Router — 213x cost reduction in LLM inference via intelligent routing
|
|
173
|
+
|
|
174
|
+
**Body:**
|
|
175
|
+
|
|
176
|
+
```
|
|
177
|
+
Hello,
|
|
178
|
+
|
|
179
|
+
I wanted to share A3M Router — an open-source tool that reduces LLM inference costs
|
|
180
|
+
by up to 70% through intelligent query routing.
|
|
181
|
+
|
|
182
|
+
**The story:**
|
|
183
|
+
Most AI applications send every query to GPT-4o or Claude, regardless of complexity.
|
|
184
|
+
A3M Router analyzes each query and routes it to the cheapest capable model.
|
|
185
|
+
|
|
186
|
+
**Numbers:**
|
|
187
|
+
- RouterArena benchmark: #1 (70.32 score, beating GPT-5 at 64.32)
|
|
188
|
+
- Cost: $0.047 per 1K queries vs GPT-5 at $10.02
|
|
189
|
+
- 47+ provider integrations
|
|
190
|
+
- 15,000+ npm downloads since launch (3 weeks, zero marketing)
|
|
191
|
+
|
|
192
|
+
**Why it matters:**
|
|
193
|
+
For most production AI workloads, 40-60% of queries are simple (Q&A, summarization,
|
|
194
|
+
basic generation). Routing these to budget providers like Groq ($0.59/1M) instead of
|
|
195
|
+
GPT-4 ($30/1M) saves 98% on those queries with minimal quality impact.
|
|
196
|
+
|
|
197
|
+
**Demo:** https://asciinema.org/a/RpqOZM9tFMALYWvs
|
|
198
|
+
**GitHub:** https://github.com/Das-rebel/a3m-router
|
|
199
|
+
|
|
200
|
+
Happy to provide more detail if useful.
|
|
201
|
+
|
|
202
|
+
Best,
|
|
203
|
+
Subho Das
|
|
204
|
+
```
|
|
205
|
+
|
|
206
|
+
---
|
|
207
|
+
|
|
208
|
+
## Email 6: OpenAI Newsletter
|
|
209
|
+
|
|
210
|
+
**URL:** https://openai.com/newsletter (submit via form on page)
|
|
211
|
+
|
|
212
|
+
**Subject:** [Tool] A3M Router — Open-source LLM routing, #1 on RouterArena
|
|
213
|
+
|
|
214
|
+
**Body:**
|
|
215
|
+
|
|
216
|
+
```
|
|
217
|
+
Hi,
|
|
218
|
+
|
|
219
|
+
I built A3M Router, an open-source LLM gateway that automatically routes queries
|
|
220
|
+
to the cheapest capable model.
|
|
221
|
+
|
|
222
|
+
**Quick facts:**
|
|
223
|
+
- Ranks #1 on RouterArena (70.32 score, beating GPT-5 at 64.32)
|
|
224
|
+
- Costs $0.047/1K queries (vs GPT-5's $10.02)
|
|
225
|
+
- Routes in <1ms with no ML training required
|
|
226
|
+
- Supports 47+ providers with automatic failover
|
|
227
|
+
- MIT licensed, no vendor lock-in
|
|
228
|
+
- OpenAI-compatible API (drop-in for existing code)
|
|
229
|
+
|
|
230
|
+
**One-liner:** Think of it as "CI/CD for AI spend" — automatically route
|
|
231
|
+
every query to the right model at the right price.
|
|
232
|
+
|
|
233
|
+
**Demo:** https://asciinema.org/a/RpqOZM9tFMALYWvs
|
|
234
|
+
**GitHub:** https://github.com/Das-rebel/a3m-router
|
|
235
|
+
|
|
236
|
+
Would love to be included in your next issue if it's a good fit.
|
|
237
|
+
|
|
238
|
+
Thanks!
|
|
239
|
+
Subho Das
|
|
240
|
+
```
|
|
241
|
+
|
|
242
|
+
---
|
|
243
|
+
|
|
244
|
+
## Send Order & Checklist
|
|
245
|
+
|
|
246
|
+
| # | Newsletter | Address/URL | Priority | Sent |
|
|
247
|
+
|---|------------|-------------|----------|------|
|
|
248
|
+
| 1 | Import AI | jack@sequoiacap.com | HIGHEST | [ ] |
|
|
249
|
+
| 2 | The Batch (Anthropic) | press@anthropic.com | HIGH | [ ] |
|
|
250
|
+
| 3 | Lil'Log | lilian@openai.com | MEDIUM | [ ] |
|
|
251
|
+
| 4 | DeepLearning.ai | deeplearning.ai/newsletter | MEDIUM | [ ] |
|
|
252
|
+
| 5 | The Economist AI | economist.com/newsletters/ai | LOW | [ ] |
|
|
253
|
+
| 6 | OpenAI Newsletter | openai.com/newsletter | LOW | [ ] |
|
|
254
|
+
|
|
255
|
+
**Send notes:**
|
|
256
|
+
- Send Import AI first (most responsive to indie projects)
|
|
257
|
+
- If no response in 5 days, follow up once
|
|
258
|
+
- Lil'Log: also try Twitter DM @lilianweng
|
|
259
|
+
- The Batch: check anthropic.com/news for submission form
|