@miller-tech/uap 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (660) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +888 -0
  3. package/dist/analyzers/index.d.ts +3 -0
  4. package/dist/analyzers/index.d.ts.map +1 -0
  5. package/dist/analyzers/index.js +684 -0
  6. package/dist/analyzers/index.js.map +1 -0
  7. package/dist/benchmarks/agents/naive-agent.d.ts +60 -0
  8. package/dist/benchmarks/agents/naive-agent.d.ts.map +1 -0
  9. package/dist/benchmarks/agents/naive-agent.js +144 -0
  10. package/dist/benchmarks/agents/naive-agent.js.map +1 -0
  11. package/dist/benchmarks/agents/uap-agent.d.ts +167 -0
  12. package/dist/benchmarks/agents/uap-agent.d.ts.map +1 -0
  13. package/dist/benchmarks/agents/uap-agent.js +437 -0
  14. package/dist/benchmarks/agents/uap-agent.js.map +1 -0
  15. package/dist/benchmarks/benchmark.d.ts +328 -0
  16. package/dist/benchmarks/benchmark.d.ts.map +1 -0
  17. package/dist/benchmarks/benchmark.js +112 -0
  18. package/dist/benchmarks/benchmark.js.map +1 -0
  19. package/dist/benchmarks/execution-verifier.d.ts +41 -0
  20. package/dist/benchmarks/execution-verifier.d.ts.map +1 -0
  21. package/dist/benchmarks/execution-verifier.js +340 -0
  22. package/dist/benchmarks/execution-verifier.js.map +1 -0
  23. package/dist/benchmarks/hierarchical-prompting.d.ts +37 -0
  24. package/dist/benchmarks/hierarchical-prompting.d.ts.map +1 -0
  25. package/dist/benchmarks/hierarchical-prompting.js +246 -0
  26. package/dist/benchmarks/hierarchical-prompting.js.map +1 -0
  27. package/dist/benchmarks/improved-benchmark.d.ts +89 -0
  28. package/dist/benchmarks/improved-benchmark.d.ts.map +1 -0
  29. package/dist/benchmarks/improved-benchmark.js +585 -0
  30. package/dist/benchmarks/improved-benchmark.js.map +1 -0
  31. package/dist/benchmarks/index.d.ts +11 -0
  32. package/dist/benchmarks/index.d.ts.map +1 -0
  33. package/dist/benchmarks/index.js +11 -0
  34. package/dist/benchmarks/index.js.map +1 -0
  35. package/dist/benchmarks/model-integration.d.ts +111 -0
  36. package/dist/benchmarks/model-integration.d.ts.map +1 -0
  37. package/dist/benchmarks/model-integration.js +904 -0
  38. package/dist/benchmarks/model-integration.js.map +1 -0
  39. package/dist/benchmarks/multi-turn-agent.d.ts +44 -0
  40. package/dist/benchmarks/multi-turn-agent.d.ts.map +1 -0
  41. package/dist/benchmarks/multi-turn-agent.js +254 -0
  42. package/dist/benchmarks/multi-turn-agent.js.map +1 -0
  43. package/dist/benchmarks/multi-turn-loop.d.ts +57 -0
  44. package/dist/benchmarks/multi-turn-loop.d.ts.map +1 -0
  45. package/dist/benchmarks/multi-turn-loop.js +167 -0
  46. package/dist/benchmarks/multi-turn-loop.js.map +1 -0
  47. package/dist/benchmarks/tasks.d.ts +19 -0
  48. package/dist/benchmarks/tasks.d.ts.map +1 -0
  49. package/dist/benchmarks/tasks.js +435 -0
  50. package/dist/benchmarks/tasks.js.map +1 -0
  51. package/dist/bin/cli.d.ts +3 -0
  52. package/dist/bin/cli.d.ts.map +1 -0
  53. package/dist/bin/cli.js +546 -0
  54. package/dist/bin/cli.js.map +1 -0
  55. package/dist/bin/llama-server-optimize.d.ts +18 -0
  56. package/dist/bin/llama-server-optimize.d.ts.map +1 -0
  57. package/dist/bin/llama-server-optimize.js +708 -0
  58. package/dist/bin/llama-server-optimize.js.map +1 -0
  59. package/dist/bin/policy.d.ts +3 -0
  60. package/dist/bin/policy.d.ts.map +1 -0
  61. package/dist/bin/policy.js +143 -0
  62. package/dist/bin/policy.js.map +1 -0
  63. package/dist/bin/tool-calls.d.ts +3 -0
  64. package/dist/bin/tool-calls.d.ts.map +1 -0
  65. package/dist/bin/tool-calls.js +4 -0
  66. package/dist/bin/tool-calls.js.map +1 -0
  67. package/dist/browser/index.d.ts +2 -0
  68. package/dist/browser/index.d.ts.map +1 -0
  69. package/dist/browser/index.js +2 -0
  70. package/dist/browser/index.js.map +1 -0
  71. package/dist/browser/web-browser.d.ts +30 -0
  72. package/dist/browser/web-browser.d.ts.map +1 -0
  73. package/dist/browser/web-browser.js +93 -0
  74. package/dist/browser/web-browser.js.map +1 -0
  75. package/dist/cli/agent.d.ts +20 -0
  76. package/dist/cli/agent.d.ts.map +1 -0
  77. package/dist/cli/agent.js +474 -0
  78. package/dist/cli/agent.js.map +1 -0
  79. package/dist/cli/analyze.d.ts +7 -0
  80. package/dist/cli/analyze.d.ts.map +1 -0
  81. package/dist/cli/analyze.js +103 -0
  82. package/dist/cli/analyze.js.map +1 -0
  83. package/dist/cli/completion-gates.d.ts +51 -0
  84. package/dist/cli/completion-gates.d.ts.map +1 -0
  85. package/dist/cli/completion-gates.js +201 -0
  86. package/dist/cli/completion-gates.js.map +1 -0
  87. package/dist/cli/compliance.d.ts +8 -0
  88. package/dist/cli/compliance.d.ts.map +1 -0
  89. package/dist/cli/compliance.js +509 -0
  90. package/dist/cli/compliance.js.map +1 -0
  91. package/dist/cli/coord.d.ts +7 -0
  92. package/dist/cli/coord.d.ts.map +1 -0
  93. package/dist/cli/coord.js +138 -0
  94. package/dist/cli/coord.js.map +1 -0
  95. package/dist/cli/dashboard.d.ts +21 -0
  96. package/dist/cli/dashboard.d.ts.map +1 -0
  97. package/dist/cli/dashboard.js +1508 -0
  98. package/dist/cli/dashboard.js.map +1 -0
  99. package/dist/cli/deploy.d.ts +19 -0
  100. package/dist/cli/deploy.d.ts.map +1 -0
  101. package/dist/cli/deploy.js +387 -0
  102. package/dist/cli/deploy.js.map +1 -0
  103. package/dist/cli/droids.d.ts +9 -0
  104. package/dist/cli/droids.d.ts.map +1 -0
  105. package/dist/cli/droids.js +227 -0
  106. package/dist/cli/droids.js.map +1 -0
  107. package/dist/cli/generate.d.ts +17 -0
  108. package/dist/cli/generate.d.ts.map +1 -0
  109. package/dist/cli/generate.js +432 -0
  110. package/dist/cli/generate.js.map +1 -0
  111. package/dist/cli/hooks.d.ts +9 -0
  112. package/dist/cli/hooks.d.ts.map +1 -0
  113. package/dist/cli/hooks.js +464 -0
  114. package/dist/cli/hooks.js.map +1 -0
  115. package/dist/cli/init.d.ts +12 -0
  116. package/dist/cli/init.d.ts.map +1 -0
  117. package/dist/cli/init.js +364 -0
  118. package/dist/cli/init.js.map +1 -0
  119. package/dist/cli/mcp-router.d.ts +16 -0
  120. package/dist/cli/mcp-router.d.ts.map +1 -0
  121. package/dist/cli/mcp-router.js +143 -0
  122. package/dist/cli/mcp-router.js.map +1 -0
  123. package/dist/cli/memory.d.ts +24 -0
  124. package/dist/cli/memory.d.ts.map +1 -0
  125. package/dist/cli/memory.js +885 -0
  126. package/dist/cli/memory.js.map +1 -0
  127. package/dist/cli/model.d.ts +15 -0
  128. package/dist/cli/model.d.ts.map +1 -0
  129. package/dist/cli/model.js +290 -0
  130. package/dist/cli/model.js.map +1 -0
  131. package/dist/cli/patterns.d.ts +26 -0
  132. package/dist/cli/patterns.d.ts.map +1 -0
  133. package/dist/cli/patterns.js +862 -0
  134. package/dist/cli/patterns.js.map +1 -0
  135. package/dist/cli/rtk-validation.d.ts +9 -0
  136. package/dist/cli/rtk-validation.d.ts.map +1 -0
  137. package/dist/cli/rtk-validation.js +9 -0
  138. package/dist/cli/rtk-validation.js.map +1 -0
  139. package/dist/cli/rtk.d.ts +34 -0
  140. package/dist/cli/rtk.d.ts.map +1 -0
  141. package/dist/cli/rtk.js +401 -0
  142. package/dist/cli/rtk.js.map +1 -0
  143. package/dist/cli/schema-diff.d.ts +7 -0
  144. package/dist/cli/schema-diff.d.ts.map +1 -0
  145. package/dist/cli/schema-diff.js +11 -0
  146. package/dist/cli/schema-diff.js.map +1 -0
  147. package/dist/cli/setup-mcp-router.d.ts +8 -0
  148. package/dist/cli/setup-mcp-router.d.ts.map +1 -0
  149. package/dist/cli/setup-mcp-router.js +163 -0
  150. package/dist/cli/setup-mcp-router.js.map +1 -0
  151. package/dist/cli/setup-wizard.d.ts +2 -0
  152. package/dist/cli/setup-wizard.d.ts.map +1 -0
  153. package/dist/cli/setup-wizard.js +806 -0
  154. package/dist/cli/setup-wizard.js.map +1 -0
  155. package/dist/cli/setup.d.ts +15 -0
  156. package/dist/cli/setup.d.ts.map +1 -0
  157. package/dist/cli/setup.js +154 -0
  158. package/dist/cli/setup.js.map +1 -0
  159. package/dist/cli/sync.d.ts +8 -0
  160. package/dist/cli/sync.d.ts.map +1 -0
  161. package/dist/cli/sync.js +395 -0
  162. package/dist/cli/sync.js.map +1 -0
  163. package/dist/cli/task.d.ts +33 -0
  164. package/dist/cli/task.d.ts.map +1 -0
  165. package/dist/cli/task.js +672 -0
  166. package/dist/cli/task.js.map +1 -0
  167. package/dist/cli/tool-calls.d.ts +20 -0
  168. package/dist/cli/tool-calls.d.ts.map +1 -0
  169. package/dist/cli/tool-calls.js +605 -0
  170. package/dist/cli/tool-calls.js.map +1 -0
  171. package/dist/cli/uap.d.ts +10 -0
  172. package/dist/cli/uap.d.ts.map +1 -0
  173. package/dist/cli/uap.js +398 -0
  174. package/dist/cli/uap.js.map +1 -0
  175. package/dist/cli/update.d.ts +10 -0
  176. package/dist/cli/update.d.ts.map +1 -0
  177. package/dist/cli/update.js +300 -0
  178. package/dist/cli/update.js.map +1 -0
  179. package/dist/cli/visualize.d.ts +77 -0
  180. package/dist/cli/visualize.d.ts.map +1 -0
  181. package/dist/cli/visualize.js +287 -0
  182. package/dist/cli/visualize.js.map +1 -0
  183. package/dist/cli/worktree.d.ts +9 -0
  184. package/dist/cli/worktree.d.ts.map +1 -0
  185. package/dist/cli/worktree.js +213 -0
  186. package/dist/cli/worktree.js.map +1 -0
  187. package/dist/coordination/adaptive-patterns.d.ts +65 -0
  188. package/dist/coordination/adaptive-patterns.d.ts.map +1 -0
  189. package/dist/coordination/adaptive-patterns.js +108 -0
  190. package/dist/coordination/adaptive-patterns.js.map +1 -0
  191. package/dist/coordination/auto-agent.d.ts +82 -0
  192. package/dist/coordination/auto-agent.d.ts.map +1 -0
  193. package/dist/coordination/auto-agent.js +145 -0
  194. package/dist/coordination/auto-agent.js.map +1 -0
  195. package/dist/coordination/capability-router.d.ts +79 -0
  196. package/dist/coordination/capability-router.d.ts.map +1 -0
  197. package/dist/coordination/capability-router.js +334 -0
  198. package/dist/coordination/capability-router.js.map +1 -0
  199. package/dist/coordination/database.d.ts +13 -0
  200. package/dist/coordination/database.d.ts.map +1 -0
  201. package/dist/coordination/database.js +136 -0
  202. package/dist/coordination/database.js.map +1 -0
  203. package/dist/coordination/deploy-batcher.d.ts +122 -0
  204. package/dist/coordination/deploy-batcher.d.ts.map +1 -0
  205. package/dist/coordination/deploy-batcher.js +718 -0
  206. package/dist/coordination/deploy-batcher.js.map +1 -0
  207. package/dist/coordination/droid-validator.d.ts +59 -0
  208. package/dist/coordination/droid-validator.d.ts.map +1 -0
  209. package/dist/coordination/droid-validator.js +142 -0
  210. package/dist/coordination/droid-validator.js.map +1 -0
  211. package/dist/coordination/index.d.ts +10 -0
  212. package/dist/coordination/index.d.ts.map +1 -0
  213. package/dist/coordination/index.js +10 -0
  214. package/dist/coordination/index.js.map +1 -0
  215. package/dist/coordination/pattern-router.d.ts +50 -0
  216. package/dist/coordination/pattern-router.d.ts.map +1 -0
  217. package/dist/coordination/pattern-router.js +118 -0
  218. package/dist/coordination/pattern-router.js.map +1 -0
  219. package/dist/coordination/service.d.ts +81 -0
  220. package/dist/coordination/service.d.ts.map +1 -0
  221. package/dist/coordination/service.js +619 -0
  222. package/dist/coordination/service.js.map +1 -0
  223. package/dist/coordination/worktree-enforcer.d.ts +22 -0
  224. package/dist/coordination/worktree-enforcer.d.ts.map +1 -0
  225. package/dist/coordination/worktree-enforcer.js +71 -0
  226. package/dist/coordination/worktree-enforcer.js.map +1 -0
  227. package/dist/generators/claude-md.d.ts +3 -0
  228. package/dist/generators/claude-md.d.ts.map +1 -0
  229. package/dist/generators/claude-md.js +1020 -0
  230. package/dist/generators/claude-md.js.map +1 -0
  231. package/dist/generators/template-loader.d.ts +105 -0
  232. package/dist/generators/template-loader.d.ts.map +1 -0
  233. package/dist/generators/template-loader.js +291 -0
  234. package/dist/generators/template-loader.js.map +1 -0
  235. package/dist/index.d.ts +49 -0
  236. package/dist/index.d.ts.map +1 -0
  237. package/dist/index.js +63 -0
  238. package/dist/index.js.map +1 -0
  239. package/dist/mcp-router/config/parser.d.ts +9 -0
  240. package/dist/mcp-router/config/parser.d.ts.map +1 -0
  241. package/dist/mcp-router/config/parser.js +174 -0
  242. package/dist/mcp-router/config/parser.js.map +1 -0
  243. package/dist/mcp-router/executor/client.d.ts +31 -0
  244. package/dist/mcp-router/executor/client.d.ts.map +1 -0
  245. package/dist/mcp-router/executor/client.js +189 -0
  246. package/dist/mcp-router/executor/client.js.map +1 -0
  247. package/dist/mcp-router/index.d.ts +22 -0
  248. package/dist/mcp-router/index.d.ts.map +1 -0
  249. package/dist/mcp-router/index.js +18 -0
  250. package/dist/mcp-router/index.js.map +1 -0
  251. package/dist/mcp-router/output-compressor.d.ts +26 -0
  252. package/dist/mcp-router/output-compressor.d.ts.map +1 -0
  253. package/dist/mcp-router/output-compressor.js +236 -0
  254. package/dist/mcp-router/output-compressor.js.map +1 -0
  255. package/dist/mcp-router/search/fuzzy.d.ts +26 -0
  256. package/dist/mcp-router/search/fuzzy.d.ts.map +1 -0
  257. package/dist/mcp-router/search/fuzzy.js +94 -0
  258. package/dist/mcp-router/search/fuzzy.js.map +1 -0
  259. package/dist/mcp-router/server.d.ts +50 -0
  260. package/dist/mcp-router/server.d.ts.map +1 -0
  261. package/dist/mcp-router/server.js +229 -0
  262. package/dist/mcp-router/server.js.map +1 -0
  263. package/dist/mcp-router/session-stats.d.ts +37 -0
  264. package/dist/mcp-router/session-stats.d.ts.map +1 -0
  265. package/dist/mcp-router/session-stats.js +56 -0
  266. package/dist/mcp-router/session-stats.js.map +1 -0
  267. package/dist/mcp-router/tools/discover.d.ts +37 -0
  268. package/dist/mcp-router/tools/discover.d.ts.map +1 -0
  269. package/dist/mcp-router/tools/discover.js +65 -0
  270. package/dist/mcp-router/tools/discover.js.map +1 -0
  271. package/dist/mcp-router/tools/execute.d.ts +43 -0
  272. package/dist/mcp-router/tools/execute.d.ts.map +1 -0
  273. package/dist/mcp-router/tools/execute.js +144 -0
  274. package/dist/mcp-router/tools/execute.js.map +1 -0
  275. package/dist/mcp-router/types.d.ts +62 -0
  276. package/dist/mcp-router/types.d.ts.map +1 -0
  277. package/dist/mcp-router/types.js +6 -0
  278. package/dist/mcp-router/types.js.map +1 -0
  279. package/dist/memory/adaptive-context.d.ts +149 -0
  280. package/dist/memory/adaptive-context.d.ts.map +1 -0
  281. package/dist/memory/adaptive-context.js +1095 -0
  282. package/dist/memory/adaptive-context.js.map +1 -0
  283. package/dist/memory/agent-scoped-memory.d.ts +67 -0
  284. package/dist/memory/agent-scoped-memory.d.ts.map +1 -0
  285. package/dist/memory/agent-scoped-memory.js +126 -0
  286. package/dist/memory/agent-scoped-memory.js.map +1 -0
  287. package/dist/memory/ambiguity-detector.d.ts +54 -0
  288. package/dist/memory/ambiguity-detector.d.ts.map +1 -0
  289. package/dist/memory/ambiguity-detector.js +401 -0
  290. package/dist/memory/ambiguity-detector.js.map +1 -0
  291. package/dist/memory/backends/base.d.ts +18 -0
  292. package/dist/memory/backends/base.d.ts.map +1 -0
  293. package/dist/memory/backends/base.js +2 -0
  294. package/dist/memory/backends/base.js.map +1 -0
  295. package/dist/memory/backends/factory.d.ts +4 -0
  296. package/dist/memory/backends/factory.d.ts.map +1 -0
  297. package/dist/memory/backends/factory.js +53 -0
  298. package/dist/memory/backends/factory.js.map +1 -0
  299. package/dist/memory/backends/github.d.ts +27 -0
  300. package/dist/memory/backends/github.d.ts.map +1 -0
  301. package/dist/memory/backends/github.js +134 -0
  302. package/dist/memory/backends/github.js.map +1 -0
  303. package/dist/memory/backends/qdrant-cloud.d.ts +32 -0
  304. package/dist/memory/backends/qdrant-cloud.d.ts.map +1 -0
  305. package/dist/memory/backends/qdrant-cloud.js +167 -0
  306. package/dist/memory/backends/qdrant-cloud.js.map +1 -0
  307. package/dist/memory/context-compressor.d.ts +116 -0
  308. package/dist/memory/context-compressor.d.ts.map +1 -0
  309. package/dist/memory/context-compressor.js +430 -0
  310. package/dist/memory/context-compressor.js.map +1 -0
  311. package/dist/memory/context-pruner.d.ts +55 -0
  312. package/dist/memory/context-pruner.d.ts.map +1 -0
  313. package/dist/memory/context-pruner.js +85 -0
  314. package/dist/memory/context-pruner.js.map +1 -0
  315. package/dist/memory/correction-propagator.d.ts +44 -0
  316. package/dist/memory/correction-propagator.d.ts.map +1 -0
  317. package/dist/memory/correction-propagator.js +156 -0
  318. package/dist/memory/correction-propagator.js.map +1 -0
  319. package/dist/memory/daily-log.d.ts +67 -0
  320. package/dist/memory/daily-log.d.ts.map +1 -0
  321. package/dist/memory/daily-log.js +143 -0
  322. package/dist/memory/daily-log.js.map +1 -0
  323. package/dist/memory/dynamic-retrieval.d.ts +112 -0
  324. package/dist/memory/dynamic-retrieval.d.ts.map +1 -0
  325. package/dist/memory/dynamic-retrieval.js +908 -0
  326. package/dist/memory/dynamic-retrieval.js.map +1 -0
  327. package/dist/memory/embeddings.d.ts +172 -0
  328. package/dist/memory/embeddings.d.ts.map +1 -0
  329. package/dist/memory/embeddings.js +780 -0
  330. package/dist/memory/embeddings.js.map +1 -0
  331. package/dist/memory/generic-uap-patterns.d.ts +7 -0
  332. package/dist/memory/generic-uap-patterns.d.ts.map +1 -0
  333. package/dist/memory/generic-uap-patterns.js +43 -0
  334. package/dist/memory/generic-uap-patterns.js.map +1 -0
  335. package/dist/memory/hierarchical-memory.d.ts +141 -0
  336. package/dist/memory/hierarchical-memory.d.ts.map +1 -0
  337. package/dist/memory/hierarchical-memory.js +485 -0
  338. package/dist/memory/hierarchical-memory.js.map +1 -0
  339. package/dist/memory/knowledge-graph.d.ts +98 -0
  340. package/dist/memory/knowledge-graph.d.ts.map +1 -0
  341. package/dist/memory/knowledge-graph.js +275 -0
  342. package/dist/memory/knowledge-graph.js.map +1 -0
  343. package/dist/memory/memory-consolidator.d.ts +124 -0
  344. package/dist/memory/memory-consolidator.d.ts.map +1 -0
  345. package/dist/memory/memory-consolidator.js +514 -0
  346. package/dist/memory/memory-consolidator.js.map +1 -0
  347. package/dist/memory/memory-maintenance.d.ts +39 -0
  348. package/dist/memory/memory-maintenance.d.ts.map +1 -0
  349. package/dist/memory/memory-maintenance.js +336 -0
  350. package/dist/memory/memory-maintenance.js.map +1 -0
  351. package/dist/memory/model-router.d.ts +105 -0
  352. package/dist/memory/model-router.d.ts.map +1 -0
  353. package/dist/memory/model-router.js +474 -0
  354. package/dist/memory/model-router.js.map +1 -0
  355. package/dist/memory/multi-view-memory.d.ts +134 -0
  356. package/dist/memory/multi-view-memory.d.ts.map +1 -0
  357. package/dist/memory/multi-view-memory.js +430 -0
  358. package/dist/memory/multi-view-memory.js.map +1 -0
  359. package/dist/memory/predictive-memory.d.ts +79 -0
  360. package/dist/memory/predictive-memory.d.ts.map +1 -0
  361. package/dist/memory/predictive-memory.js +294 -0
  362. package/dist/memory/predictive-memory.js.map +1 -0
  363. package/dist/memory/prepopulate.d.ts +76 -0
  364. package/dist/memory/prepopulate.d.ts.map +1 -0
  365. package/dist/memory/prepopulate.js +832 -0
  366. package/dist/memory/prepopulate.js.map +1 -0
  367. package/dist/memory/semantic-compression.d.ts +77 -0
  368. package/dist/memory/semantic-compression.d.ts.map +1 -0
  369. package/dist/memory/semantic-compression.js +359 -0
  370. package/dist/memory/semantic-compression.js.map +1 -0
  371. package/dist/memory/serverless-qdrant.d.ts +102 -0
  372. package/dist/memory/serverless-qdrant.d.ts.map +1 -0
  373. package/dist/memory/serverless-qdrant.js +369 -0
  374. package/dist/memory/serverless-qdrant.js.map +1 -0
  375. package/dist/memory/short-term/factory.d.ts +26 -0
  376. package/dist/memory/short-term/factory.d.ts.map +1 -0
  377. package/dist/memory/short-term/factory.js +28 -0
  378. package/dist/memory/short-term/factory.js.map +1 -0
  379. package/dist/memory/short-term/indexeddb.d.ts +25 -0
  380. package/dist/memory/short-term/indexeddb.d.ts.map +1 -0
  381. package/dist/memory/short-term/indexeddb.js +64 -0
  382. package/dist/memory/short-term/indexeddb.js.map +1 -0
  383. package/dist/memory/short-term/schema.d.ts +6 -0
  384. package/dist/memory/short-term/schema.d.ts.map +1 -0
  385. package/dist/memory/short-term/schema.js +141 -0
  386. package/dist/memory/short-term/schema.js.map +1 -0
  387. package/dist/memory/short-term/sqlite.d.ts +64 -0
  388. package/dist/memory/short-term/sqlite.d.ts.map +1 -0
  389. package/dist/memory/short-term/sqlite.js +274 -0
  390. package/dist/memory/short-term/sqlite.js.map +1 -0
  391. package/dist/memory/speculative-cache.d.ts +111 -0
  392. package/dist/memory/speculative-cache.d.ts.map +1 -0
  393. package/dist/memory/speculative-cache.js +457 -0
  394. package/dist/memory/speculative-cache.js.map +1 -0
  395. package/dist/memory/task-classifier.d.ts +40 -0
  396. package/dist/memory/task-classifier.d.ts.map +1 -0
  397. package/dist/memory/task-classifier.js +342 -0
  398. package/dist/memory/task-classifier.js.map +1 -0
  399. package/dist/memory/terminal-bench-knowledge.d.ts +48 -0
  400. package/dist/memory/terminal-bench-knowledge.d.ts.map +1 -0
  401. package/dist/memory/terminal-bench-knowledge.js +622 -0
  402. package/dist/memory/terminal-bench-knowledge.js.map +1 -0
  403. package/dist/memory/write-gate.d.ts +39 -0
  404. package/dist/memory/write-gate.d.ts.map +1 -0
  405. package/dist/memory/write-gate.js +190 -0
  406. package/dist/memory/write-gate.js.map +1 -0
  407. package/dist/models/api-client.d.ts +46 -0
  408. package/dist/models/api-client.d.ts.map +1 -0
  409. package/dist/models/api-client.js +182 -0
  410. package/dist/models/api-client.js.map +1 -0
  411. package/dist/models/execution-profiles.d.ts +64 -0
  412. package/dist/models/execution-profiles.d.ts.map +1 -0
  413. package/dist/models/execution-profiles.js +403 -0
  414. package/dist/models/execution-profiles.js.map +1 -0
  415. package/dist/models/executor.d.ts +130 -0
  416. package/dist/models/executor.d.ts.map +1 -0
  417. package/dist/models/executor.js +382 -0
  418. package/dist/models/executor.js.map +1 -0
  419. package/dist/models/index.d.ts +19 -0
  420. package/dist/models/index.d.ts.map +1 -0
  421. package/dist/models/index.js +23 -0
  422. package/dist/models/index.js.map +1 -0
  423. package/dist/models/plan-validator.d.ts +37 -0
  424. package/dist/models/plan-validator.d.ts.map +1 -0
  425. package/dist/models/plan-validator.js +179 -0
  426. package/dist/models/plan-validator.js.map +1 -0
  427. package/dist/models/planner.d.ts +73 -0
  428. package/dist/models/planner.d.ts.map +1 -0
  429. package/dist/models/planner.js +375 -0
  430. package/dist/models/planner.js.map +1 -0
  431. package/dist/models/router.d.ts +96 -0
  432. package/dist/models/router.d.ts.map +1 -0
  433. package/dist/models/router.js +523 -0
  434. package/dist/models/router.js.map +1 -0
  435. package/dist/models/types.d.ts +370 -0
  436. package/dist/models/types.d.ts.map +1 -0
  437. package/dist/models/types.js +232 -0
  438. package/dist/models/types.js.map +1 -0
  439. package/dist/models/unified-router.d.ts +152 -0
  440. package/dist/models/unified-router.d.ts.map +1 -0
  441. package/dist/models/unified-router.js +313 -0
  442. package/dist/models/unified-router.js.map +1 -0
  443. package/dist/policies/convert-policy-to-claude.d.ts +3 -0
  444. package/dist/policies/convert-policy-to-claude.d.ts.map +1 -0
  445. package/dist/policies/convert-policy-to-claude.js +87 -0
  446. package/dist/policies/convert-policy-to-claude.js.map +1 -0
  447. package/dist/policies/database-manager.d.ts +27 -0
  448. package/dist/policies/database-manager.d.ts.map +1 -0
  449. package/dist/policies/database-manager.js +198 -0
  450. package/dist/policies/database-manager.js.map +1 -0
  451. package/dist/policies/enforced-tool-router.d.ts +53 -0
  452. package/dist/policies/enforced-tool-router.d.ts.map +1 -0
  453. package/dist/policies/enforced-tool-router.js +80 -0
  454. package/dist/policies/enforced-tool-router.js.map +1 -0
  455. package/dist/policies/index.d.ts +10 -0
  456. package/dist/policies/index.d.ts.map +1 -0
  457. package/dist/policies/index.js +8 -0
  458. package/dist/policies/index.js.map +1 -0
  459. package/dist/policies/policy-gate.d.ts +59 -0
  460. package/dist/policies/policy-gate.d.ts.map +1 -0
  461. package/dist/policies/policy-gate.js +171 -0
  462. package/dist/policies/policy-gate.js.map +1 -0
  463. package/dist/policies/policy-memory.d.ts +18 -0
  464. package/dist/policies/policy-memory.d.ts.map +1 -0
  465. package/dist/policies/policy-memory.js +126 -0
  466. package/dist/policies/policy-memory.js.map +1 -0
  467. package/dist/policies/policy-tools.d.ts +11 -0
  468. package/dist/policies/policy-tools.d.ts.map +1 -0
  469. package/dist/policies/policy-tools.js +66 -0
  470. package/dist/policies/policy-tools.js.map +1 -0
  471. package/dist/policies/schemas/policy.d.ts +69 -0
  472. package/dist/policies/schemas/policy.d.ts.map +1 -0
  473. package/dist/policies/schemas/policy.js +31 -0
  474. package/dist/policies/schemas/policy.js.map +1 -0
  475. package/dist/tasks/coordination.d.ts +83 -0
  476. package/dist/tasks/coordination.d.ts.map +1 -0
  477. package/dist/tasks/coordination.js +291 -0
  478. package/dist/tasks/coordination.js.map +1 -0
  479. package/dist/tasks/database.d.ts +19 -0
  480. package/dist/tasks/database.d.ts.map +1 -0
  481. package/dist/tasks/database.js +149 -0
  482. package/dist/tasks/database.js.map +1 -0
  483. package/dist/tasks/decoder-gate.d.ts +64 -0
  484. package/dist/tasks/decoder-gate.d.ts.map +1 -0
  485. package/dist/tasks/decoder-gate.js +268 -0
  486. package/dist/tasks/decoder-gate.js.map +1 -0
  487. package/dist/tasks/index.d.ts +6 -0
  488. package/dist/tasks/index.d.ts.map +1 -0
  489. package/dist/tasks/index.js +6 -0
  490. package/dist/tasks/index.js.map +1 -0
  491. package/dist/tasks/service.d.ts +40 -0
  492. package/dist/tasks/service.d.ts.map +1 -0
  493. package/dist/tasks/service.js +671 -0
  494. package/dist/tasks/service.js.map +1 -0
  495. package/dist/tasks/types.d.ts +238 -0
  496. package/dist/tasks/types.d.ts.map +1 -0
  497. package/dist/tasks/types.js +74 -0
  498. package/dist/tasks/types.js.map +1 -0
  499. package/dist/telemetry/index.d.ts +2 -0
  500. package/dist/telemetry/index.d.ts.map +1 -0
  501. package/dist/telemetry/index.js +2 -0
  502. package/dist/telemetry/index.js.map +1 -0
  503. package/dist/telemetry/session-telemetry.d.ts +56 -0
  504. package/dist/telemetry/session-telemetry.d.ts.map +1 -0
  505. package/dist/telemetry/session-telemetry.js +807 -0
  506. package/dist/telemetry/session-telemetry.js.map +1 -0
  507. package/dist/types/analysis.d.ts +82 -0
  508. package/dist/types/analysis.d.ts.map +1 -0
  509. package/dist/types/analysis.js +2 -0
  510. package/dist/types/analysis.js.map +1 -0
  511. package/dist/types/config.d.ts +3324 -0
  512. package/dist/types/config.d.ts.map +1 -0
  513. package/dist/types/config.js +418 -0
  514. package/dist/types/config.js.map +1 -0
  515. package/dist/types/coordination.d.ts +240 -0
  516. package/dist/types/coordination.d.ts.map +1 -0
  517. package/dist/types/coordination.js +43 -0
  518. package/dist/types/coordination.js.map +1 -0
  519. package/dist/types/index.d.ts +4 -0
  520. package/dist/types/index.d.ts.map +1 -0
  521. package/dist/types/index.js +4 -0
  522. package/dist/types/index.js.map +1 -0
  523. package/dist/uap-droids-strict.d.ts +59 -0
  524. package/dist/uap-droids-strict.d.ts.map +1 -0
  525. package/dist/uap-droids-strict.js +200 -0
  526. package/dist/uap-droids-strict.js.map +1 -0
  527. package/dist/utils/config-manager.d.ts +30 -0
  528. package/dist/utils/config-manager.d.ts.map +1 -0
  529. package/dist/utils/config-manager.js +41 -0
  530. package/dist/utils/config-manager.js.map +1 -0
  531. package/dist/utils/fetch-with-retry.d.ts +5 -0
  532. package/dist/utils/fetch-with-retry.d.ts.map +1 -0
  533. package/dist/utils/fetch-with-retry.js +61 -0
  534. package/dist/utils/fetch-with-retry.js.map +1 -0
  535. package/dist/utils/merge-claude-md.d.ts +28 -0
  536. package/dist/utils/merge-claude-md.d.ts.map +1 -0
  537. package/dist/utils/merge-claude-md.js +342 -0
  538. package/dist/utils/merge-claude-md.js.map +1 -0
  539. package/dist/utils/rate-limiter.d.ts +58 -0
  540. package/dist/utils/rate-limiter.d.ts.map +1 -0
  541. package/dist/utils/rate-limiter.js +100 -0
  542. package/dist/utils/rate-limiter.js.map +1 -0
  543. package/dist/utils/string-similarity.d.ts +37 -0
  544. package/dist/utils/string-similarity.d.ts.map +1 -0
  545. package/dist/utils/string-similarity.js +114 -0
  546. package/dist/utils/string-similarity.js.map +1 -0
  547. package/dist/utils/validate-json.d.ts +51 -0
  548. package/dist/utils/validate-json.d.ts.map +1 -0
  549. package/dist/utils/validate-json.js +94 -0
  550. package/dist/utils/validate-json.js.map +1 -0
  551. package/docs/INDEX.md +66 -0
  552. package/docs/architecture/MULTI_MODEL.md +224 -0
  553. package/docs/architecture/SYSTEM_ANALYSIS.md +1117 -0
  554. package/docs/architecture/UAP_COMPLIANCE.md +217 -0
  555. package/docs/architecture/UAP_PROTOCOL.md +339 -0
  556. package/docs/architecture/UAP_STRICT_DROIDS.md +172 -0
  557. package/docs/archive/BALLS_MODE_SELF_ANALYSIS.md +260 -0
  558. package/docs/archive/FAILING_TASKS_SOLUTION_PLAN.md +668 -0
  559. package/docs/archive/JINJA2-SYSTEM-MESSAGE-FIX.md +209 -0
  560. package/docs/archive/NPM-PUBLISH-V0.9.1.md +240 -0
  561. package/docs/archive/OPTIMIZATION_OPTIONS.md +334 -0
  562. package/docs/archive/SETUP_IMPROVEMENTS.md +213 -0
  563. package/docs/archive/UAP_GENERIC_OPTIMIZATION_PLAN.md +270 -0
  564. package/docs/archive/UAP_V103_PATTERN_DESIGN.md +315 -0
  565. package/docs/archive/UAP_V104_COMPLIANCE_DESIGN.md +223 -0
  566. package/docs/archive/changelog/2026-03-10_uap-100-compliance.md +77 -0
  567. package/docs/archive/changelog/2026-03-10_uap-full-system-verification.md +109 -0
  568. package/docs/benchmarks/ACCURACY_ANALYSIS.md +471 -0
  569. package/docs/benchmarks/TOKEN_OPTIMIZATION.md +572 -0
  570. package/docs/benchmarks/VALIDATION_PLAN.md +568 -0
  571. package/docs/benchmarks/VALIDATION_RESULTS.md +161 -0
  572. package/docs/deployment/DEPLOYMENT.md +895 -0
  573. package/docs/deployment/DEPLOYMENT_STRATEGIES.md +518 -0
  574. package/docs/deployment/DEPLOY_BATCHER_ANALYSIS.md +856 -0
  575. package/docs/deployment/DEPLOY_BATCHING.md +273 -0
  576. package/docs/deployment/DEPLOY_BUCKETING_ANALYSIS.md +420 -0
  577. package/docs/deployment/QWEN35_LLAMA_CPP.md +265 -0
  578. package/docs/getting-started/INTEGRATION.md +449 -0
  579. package/docs/getting-started/OVERVIEW.md +344 -0
  580. package/docs/getting-started/SETUP.md +203 -0
  581. package/docs/integrations/MCP_ROUTER_SETUP.md +445 -0
  582. package/docs/integrations/RTK_INTEGRATION.md +468 -0
  583. package/docs/operations/TROUBLESHOOTING.md +660 -0
  584. package/docs/reference/API_REFERENCE.md +903 -0
  585. package/docs/reference/FEATURES.md +472 -0
  586. package/docs/reference/HARNESS-MATRIX.md +318 -0
  587. package/docs/reference/UAP_CLI_REFERENCE.md +600 -0
  588. package/docs/research/BEHAVIORAL_PATTERNS.md +228 -0
  589. package/docs/research/DOMAIN_STRATEGIES.md +316 -0
  590. package/docs/research/MEMORY_SYSTEMS_COMPARISON.md +812 -0
  591. package/docs/research/PATTERN_ANALYSIS_2026-01-18.md +436 -0
  592. package/docs/research/PERFORMANCE_ANALYSIS_2026-01-18.md +209 -0
  593. package/docs/research/PERFORMANCE_TEST_PLAN.md +383 -0
  594. package/docs/research/TERMINAL_BENCH_LEARNINGS.md +217 -0
  595. package/package.json +113 -0
  596. package/scripts/README.md +161 -0
  597. package/templates/CLAUDE.template.md +10 -0
  598. package/templates/CLAUDE_ARCHITECTURE.template.md +103 -0
  599. package/templates/CLAUDE_CODING.template.md +127 -0
  600. package/templates/CLAUDE_DROIDS.template.md +109 -0
  601. package/templates/CLAUDE_MEMORY.template.md +131 -0
  602. package/templates/CLAUDE_WORKFLOWS.template.md +139 -0
  603. package/templates/PROJECT.template.md +209 -0
  604. package/templates/SCHEMA.md +57 -0
  605. package/templates/archive/CLAUDE.template.root-v6.md +534 -0
  606. package/templates/archive/CLAUDE.template.v6.md +534 -0
  607. package/templates/hooks/forgecode/pre-compact.sh +68 -0
  608. package/templates/hooks/forgecode/session-start.sh +169 -0
  609. package/templates/hooks/forgecode.plugin.sh +128 -0
  610. package/templates/hooks/pre-compact.sh +74 -0
  611. package/templates/hooks/session-start.sh +366 -0
  612. package/tools/agents/README.md +224 -0
  613. package/tools/agents/UAP/README.md +386 -0
  614. package/tools/agents/UAP/__init__.py +9 -0
  615. package/tools/agents/UAP/cli.py +901 -0
  616. package/tools/agents/UAP/compliance_verify.sh +108 -0
  617. package/tools/agents/UAP/full_verification.sh +126 -0
  618. package/tools/agents/UAP/version.py +32 -0
  619. package/tools/agents/benchmarks/benchmark_memory_systems.py +730 -0
  620. package/tools/agents/benchmarks/results/benchmark_20260106_064817.json +170 -0
  621. package/tools/agents/benchmarks/results/benchmark_20260106_064817.md +51 -0
  622. package/tools/agents/config/chat_template.jinja +77 -0
  623. package/tools/agents/config/tool-call-schema.json +19 -0
  624. package/tools/agents/config/tool-call.gbnf +58 -0
  625. package/tools/agents/docker/Dockerfile.python +52 -0
  626. package/tools/agents/docker/Dockerfile.ubuntu +55 -0
  627. package/tools/agents/docker-compose.qdrant.yml +24 -0
  628. package/tools/agents/install-opencode-local.sh.j2 +135 -0
  629. package/tools/agents/migrations/apply.py +256 -0
  630. package/tools/agents/opencode_uap_agent.py +1505 -0
  631. package/tools/agents/plugin/README.md +91 -0
  632. package/tools/agents/plugin/index.ts +46 -0
  633. package/tools/agents/plugin/pre-compact.sh +68 -0
  634. package/tools/agents/plugin/session-start.sh +175 -0
  635. package/tools/agents/plugin/uap-commands.ts +45 -0
  636. package/tools/agents/plugin/uap-droids.ts +54 -0
  637. package/tools/agents/plugin/uap-patterns.ts +54 -0
  638. package/tools/agents/plugin/uap-skills.ts +52 -0
  639. package/tools/agents/plugins/uap-enforce.ts +314 -0
  640. package/tools/agents/scripts/__pycache__/tool_call_wrapper.cpython-313.pyc +0 -0
  641. package/tools/agents/scripts/chat_template_verifier.py +343 -0
  642. package/tools/agents/scripts/fix-qwen-template.js +38 -0
  643. package/tools/agents/scripts/fix_qwen_chat_template.py +316 -0
  644. package/tools/agents/scripts/generate_lora_training_data.py +412 -0
  645. package/tools/agents/scripts/init_qdrant.py +151 -0
  646. package/tools/agents/scripts/memory_migration.py +560 -0
  647. package/tools/agents/scripts/migrate_memory_to_qdrant.py +110 -0
  648. package/tools/agents/scripts/prepare_lora.sh +512 -0
  649. package/tools/agents/scripts/query_memory.py +200 -0
  650. package/tools/agents/scripts/qwen-tool-call-test.js +38 -0
  651. package/tools/agents/scripts/qwen-tool-call-wrapper.js +38 -0
  652. package/tools/agents/scripts/qwen_tool_call_test.py +464 -0
  653. package/tools/agents/scripts/qwen_tool_call_wrapper.py +686 -0
  654. package/tools/agents/scripts/start-services.sh +96 -0
  655. package/tools/agents/scripts/tool-choice-proxy.cjs +296 -0
  656. package/tools/agents/scripts/tool_call_test.py +656 -0
  657. package/tools/agents/scripts/tool_call_wrapper.py +799 -0
  658. package/tools/agents/tests/test_uap_compliance.py +257 -0
  659. package/tools/agents/uap_agent.py +122 -0
  660. package/tools/agents/uap_agent_install.sh +12 -0
@@ -0,0 +1,708 @@
1
+ #!/usr/bin/env node
2
+ /**
3
+ * llama-server-optimize.ts v2.0.0
4
+ *
5
+ * CLI tool for generating optimal llama.cpp startup parameters
6
+ * for Qwen3.5 35B A3B on 16GB or 24GB VRAM systems.
7
+ *
8
+ * v2.0.0 improvements:
9
+ * - GBNF grammar support for structured tool call output
10
+ * - Speculative decoding with draft model support
11
+ * - KV cache quantization (q8_0/q4_0 split K/V)
12
+ * - Flash attention integration
13
+ * - Prompt caching via slot-save
14
+ * - LoRA adapter loading
15
+ * - Quant upgrade profiles with accuracy/speed tradeoffs
16
+ */
17
+ import { program } from 'commander';
18
+ import * as fs from 'fs';
19
+ import * as readline from 'readline';
20
+ import * as os from 'os';
21
+ import { join, dirname } from 'path';
22
+ import { fileURLToPath } from 'url';
23
+ const __filename = fileURLToPath(import.meta.url);
24
+ const __dirname = dirname(__filename);
25
+ const PROJECT_ROOT = join(__dirname, '..', '..');
26
+ // Quantization profiles based on Qwen3.5 35B A3B architecture
27
+ const QUANTIZATION_PROFILES = {
28
+ q8_0: {
29
+ name: 'Q8_0',
30
+ description: '8-bit quantization - maximum accuracy',
31
+ modelSizeGB: 38,
32
+ kvCacheOverheadGB: 0.5,
33
+ accuracy: 100,
34
+ contextMultiplier: 0.5,
35
+ recommendedFor: '48GB+ VRAM only',
36
+ toolCallReliability: '99%',
37
+ },
38
+ q6_k: {
39
+ name: 'Q6_K',
40
+ description: '6-bit quantization - near-lossless',
41
+ modelSizeGB: 28,
42
+ kvCacheOverheadGB: 0.5,
43
+ accuracy: 98,
44
+ contextMultiplier: 0.7,
45
+ recommendedFor: '24GB VRAM - high accuracy',
46
+ toolCallReliability: '98%',
47
+ },
48
+ q5_k_m: {
49
+ name: 'Q5_K_M',
50
+ description: '5-bit quantization - best balance for 24GB',
51
+ modelSizeGB: 24,
52
+ kvCacheOverheadGB: 0.5,
53
+ accuracy: 97,
54
+ contextMultiplier: 0.8,
55
+ recommendedFor: '24GB VRAM - RECOMMENDED',
56
+ toolCallReliability: '97%',
57
+ },
58
+ q4_k_m: {
59
+ name: 'Q4_K_M',
60
+ description: '4-bit quantization - best balance for 16GB',
61
+ modelSizeGB: 20,
62
+ kvCacheOverheadGB: 0.5,
63
+ accuracy: 95,
64
+ contextMultiplier: 1.0,
65
+ recommendedFor: '16-24GB VRAM',
66
+ toolCallReliability: '95%',
67
+ },
68
+ iq4_xs: {
69
+ name: 'IQ4_XS',
70
+ description: '4-bit importance quantization - max context on 16GB',
71
+ modelSizeGB: 17,
72
+ kvCacheOverheadGB: 0.5,
73
+ accuracy: 96,
74
+ contextMultiplier: 2.0,
75
+ recommendedFor: '16GB VRAM - CURRENT DEFAULT',
76
+ toolCallReliability: '94%',
77
+ },
78
+ q3_k_m: {
79
+ name: 'Q3_K_M',
80
+ description: '3-bit quantization - maximum context',
81
+ modelSizeGB: 16,
82
+ kvCacheOverheadGB: 0.5,
83
+ accuracy: 92,
84
+ contextMultiplier: 1.5,
85
+ recommendedFor: '16GB VRAM - max context trade-off',
86
+ toolCallReliability: '88%',
87
+ },
88
+ q2_k: {
89
+ name: 'Q2_K',
90
+ description: '2-bit quantization - NOT RECOMMENDED',
91
+ modelSizeGB: 14,
92
+ kvCacheOverheadGB: 0.5,
93
+ accuracy: 85,
94
+ contextMultiplier: 2.0,
95
+ recommendedFor: 'AVOID - quality cliff below 3-bit',
96
+ toolCallReliability: '60%',
97
+ },
98
+ };
99
+ // Context length options
100
+ const CONTEXT_LENGTHS = [
101
+ { value: 4096, label: '4K', description: 'Fastest, minimal context' },
102
+ { value: 8192, label: '8K', description: 'Short documents' },
103
+ { value: 16384, label: '16K', description: 'Standard context' },
104
+ { value: 32768, label: '32K', description: 'Long documents' },
105
+ { value: 65536, label: '64K', description: 'Very long documents' },
106
+ { value: 131072, label: '128K', description: 'Maximum practical for IQ4_XS on 24GB' },
107
+ { value: 262144, label: '256K', description: 'Full context (requires 48GB+ or KV quant)' },
108
+ ];
109
+ // KV cache quantization options (split K/V for optimal quality/VRAM)
110
+ const KV_CACHE_OPTIONS = [
111
+ {
112
+ value: { k: 'f16', v: 'f16' },
113
+ label: 'f16/f16',
114
+ description: 'Default - highest accuracy, most VRAM',
115
+ },
116
+ {
117
+ value: { k: 'q8_0', v: 'q8_0' },
118
+ label: 'q8_0/q8_0',
119
+ description: 'Good balance - ~50% KV VRAM savings',
120
+ },
121
+ {
122
+ value: { k: 'q8_0', v: 'q4_0' },
123
+ label: 'q8_0/q4_0',
124
+ description: 'RECOMMENDED - keys need more precision than values',
125
+ },
126
+ {
127
+ value: { k: 'q4_0', v: 'q4_0' },
128
+ label: 'q4_0/q4_0',
129
+ description: 'Maximum savings - ~75% KV VRAM reduction',
130
+ },
131
+ ];
132
+ // GPU layers (Qwen3.5 35B has 64 layers in MoE architecture)
133
+ // Used in interactive mode for GPU layer selection
134
+ const _GPU_LAYERS = [
135
+ { value: 0, label: '0 (CPU only)' },
136
+ { value: 32, label: '32 (half on GPU)' },
137
+ { value: 63, label: '63 (all but 1 on GPU)' },
138
+ { value: 64, label: '64 (all on GPU)' },
139
+ { value: 99, label: '99 (auto - offload everything possible)' },
140
+ ];
141
+ void _GPU_LAYERS;
142
+ // Preset configurations
143
+ const PRESETS = {
144
+ balanced: {
145
+ name: 'balanced',
146
+ description: 'IQ4_XS, 32K context, KV q8/q4 (16-24GB)',
147
+ vram: 16,
148
+ quantization: 'iq4_xs',
149
+ context: 32768,
150
+ kvCacheK: 'q8_0',
151
+ kvCacheV: 'q4_0',
152
+ gpuLayers: 99,
153
+ flashAttn: true,
154
+ speculative: false,
155
+ promptCache: true,
156
+ grammar: true,
157
+ },
158
+ accuracy: {
159
+ name: 'accuracy',
160
+ description: 'Q5_K_M, 16K context, f16 KV, flash attn (24GB)',
161
+ vram: 24,
162
+ quantization: 'q5_k_m',
163
+ context: 16384,
164
+ kvCacheK: 'f16',
165
+ kvCacheV: 'f16',
166
+ gpuLayers: 99,
167
+ flashAttn: true,
168
+ speculative: false,
169
+ promptCache: true,
170
+ grammar: true,
171
+ },
172
+ context: {
173
+ name: 'context',
174
+ description: 'IQ4_XS, 128K context, KV q4/q4, flash attn (24GB)',
175
+ vram: 24,
176
+ quantization: 'iq4_xs',
177
+ context: 131072,
178
+ kvCacheK: 'q4_0',
179
+ kvCacheV: 'q4_0',
180
+ gpuLayers: 99,
181
+ flashAttn: true,
182
+ speculative: false,
183
+ promptCache: true,
184
+ grammar: true,
185
+ },
186
+ speed: {
187
+ name: 'speed',
188
+ description: 'IQ4_XS, 8K context, speculative decoding, flash attn',
189
+ vram: 16,
190
+ quantization: 'iq4_xs',
191
+ context: 8192,
192
+ kvCacheK: 'q8_0',
193
+ kvCacheV: 'q4_0',
194
+ gpuLayers: 99,
195
+ flashAttn: true,
196
+ speculative: true,
197
+ promptCache: true,
198
+ grammar: true,
199
+ },
200
+ 'tool-call': {
201
+ name: 'tool-call',
202
+ description: 'Optimized for tool calling: grammar + prompt cache + flash attn',
203
+ vram: 16,
204
+ quantization: 'iq4_xs',
205
+ context: 32768,
206
+ kvCacheK: 'q8_0',
207
+ kvCacheV: 'q4_0',
208
+ gpuLayers: 99,
209
+ flashAttn: true,
210
+ speculative: false,
211
+ promptCache: true,
212
+ grammar: true,
213
+ },
214
+ 'max-context': {
215
+ name: 'max-context',
216
+ description: 'Q3_K_M, 256K context, KV q4/q4 (24GB+)',
217
+ vram: 24,
218
+ quantization: 'q3_k_m',
219
+ context: 262144,
220
+ kvCacheK: 'q4_0',
221
+ kvCacheV: 'q4_0',
222
+ gpuLayers: 99,
223
+ flashAttn: true,
224
+ speculative: false,
225
+ promptCache: false,
226
+ grammar: false,
227
+ },
228
+ };
229
+ const rl = readline.createInterface({
230
+ input: process.stdin,
231
+ output: process.stdout,
232
+ });
233
+ const question = (query) => {
234
+ return new Promise((resolve) => rl.question(query, resolve));
235
+ };
236
+ async function detectVRAM() {
237
+ try {
238
+ const { execSync } = await import('child_process');
239
+ // Try nvidia-smi for NVIDIA GPUs
240
+ try {
241
+ const output = execSync('nvidia-smi --query-gpu=memory.total --format=csv,noheader,nounits', {
242
+ encoding: 'utf-8',
243
+ timeout: 5000,
244
+ });
245
+ const totalMB = parseInt(output.trim().split('\n')[0]);
246
+ return Math.round(totalMB / 1024);
247
+ }
248
+ catch {
249
+ // nvidia-smi not available
250
+ }
251
+ // Try sysctl for macOS (unified memory)
252
+ try {
253
+ const output = execSync('sysctl -n hw.memsize', { encoding: 'utf-8' });
254
+ const totalBytes = parseInt(output.trim());
255
+ const totalGB = Math.round(totalBytes / (1024 * 1024 * 1024));
256
+ return Math.min(totalGB, 48);
257
+ }
258
+ catch {
259
+ // sysctl not available
260
+ }
261
+ return 16;
262
+ }
263
+ catch {
264
+ return 16;
265
+ }
266
+ }
267
+ async function selectOption(message, options, defaultIndex = 0) {
268
+ console.log(`\n${message}`);
269
+ console.log('--'.repeat(30));
270
+ options.forEach((opt, index) => {
271
+ const marker = index === defaultIndex ? '>' : ' ';
272
+ console.log(`${marker} ${index + 1}. ${opt.label}`);
273
+ if (opt.description) {
274
+ console.log(` ${opt.description}`);
275
+ }
276
+ });
277
+ const answer = await question('\nSelect option (1-99): ');
278
+ const index = parseInt(answer) - 1;
279
+ if (index >= 0 && index < options.length) {
280
+ return options[index];
281
+ }
282
+ return options[defaultIndex];
283
+ }
284
+ function calculateVRAMUsage(config) {
285
+ const profile = QUANTIZATION_PROFILES[config.quantization];
286
+ if (!profile) {
287
+ return { model: 20, kvCache: 10, draftModel: 0, total: 30, sufficient: false };
288
+ }
289
+ const modelGB = profile.modelSizeGB;
290
+ // KV cache VRAM depends on context length and quantization
291
+ const contextMultiplier = config.context / 32768;
292
+ let kvMultiplier = 1.0;
293
+ if (config.kvCacheK === 'q8_0')
294
+ kvMultiplier *= 0.5;
295
+ if (config.kvCacheK === 'q4_0')
296
+ kvMultiplier *= 0.25;
297
+ if (config.kvCacheV === 'q4_0')
298
+ kvMultiplier *= 0.5;
299
+ if (config.kvCacheV === 'q8_0')
300
+ kvMultiplier *= 0.75;
301
+ const kvCacheGB = 2.0 * contextMultiplier * kvMultiplier;
302
+ // Draft model for speculative decoding (~0.5GB for 0.6B model)
303
+ const draftModelGB = config.speculative ? 0.5 : 0;
304
+ const totalGB = modelGB + kvCacheGB + draftModelGB + 1.5; // +1.5GB buffer
305
+ return {
306
+ model: modelGB,
307
+ kvCache: kvCacheGB,
308
+ draftModel: draftModelGB,
309
+ total: totalGB,
310
+ sufficient: totalGB <= config.vram,
311
+ };
312
+ }
313
+ function generateStartupCommand(config) {
314
+ const lines = ['llama-server \\'];
315
+ // Model
316
+ lines.push(` --model ${config.modelPath} \\`);
317
+ // Context
318
+ lines.push(` --ctx-size ${config.context} \\`);
319
+ // KV cache quantization (split K/V)
320
+ lines.push(` --cache-type-k ${config.kvCacheK} \\`);
321
+ lines.push(` --cache-type-v ${config.kvCacheV} \\`);
322
+ // GPU layers
323
+ lines.push(` --n-gpu-layers ${config.gpuLayers} \\`);
324
+ // Threads
325
+ lines.push(` --threads ${config.threads} \\`);
326
+ // Flash attention
327
+ if (config.flashAttn) {
328
+ lines.push(' --flash-attn \\');
329
+ }
330
+ // Speculative decoding
331
+ if (config.speculative && config.draftModelPath) {
332
+ lines.push(` --model-draft ${config.draftModelPath} \\`);
333
+ lines.push(` --draft-max 16 \\`);
334
+ lines.push(` --draft-min 3 \\`);
335
+ lines.push(` --draft-p-min 0.8 \\`);
336
+ if (config.draftModelLayers > 0) {
337
+ lines.push(` --n-gpu-layers-draft ${config.draftModelLayers} \\`);
338
+ }
339
+ }
340
+ // Prompt caching
341
+ if (config.promptCache && config.slotSavePath) {
342
+ lines.push(` --slot-save-path ${config.slotSavePath} \\`);
343
+ }
344
+ // Chat template
345
+ if (config.chatTemplatePath) {
346
+ lines.push(` --chat-template-file ${config.chatTemplatePath} \\`);
347
+ }
348
+ // LoRA adapter
349
+ if (config.loraPath) {
350
+ lines.push(` --lora ${config.loraPath} \\`);
351
+ if (config.loraScale !== 1.0) {
352
+ lines.push(` --lora-scaled ${config.loraScale} \\`);
353
+ }
354
+ }
355
+ // Server config
356
+ lines.push(` --host ${config.host} \\`);
357
+ lines.push(` --port ${config.port} \\`);
358
+ // Memory management
359
+ lines.push(' --mlock \\');
360
+ // Logging
361
+ if (config.logFile) {
362
+ lines.push(` --log-file ${config.logFile} \\`);
363
+ }
364
+ // Parallel slots for concurrent requests
365
+ lines.push(' --parallel 2 \\');
366
+ // Metrics endpoint
367
+ lines.push(' --metrics');
368
+ return lines.join('\n');
369
+ }
370
+ function generateConfigFile(config) {
371
+ const vramUsage = calculateVRAMUsage(config);
372
+ const profile = QUANTIZATION_PROFILES[config.quantization];
373
+ return `# llama.cpp server configuration
374
+ # Generated by llama-server-optimize v2.0.0
375
+ # Optimized for Qwen3.5 35B A3B tool calling
376
+ #
377
+ # VRAM estimate: ${vramUsage.total.toFixed(1)}GB (model: ${vramUsage.model}GB, KV: ${vramUsage.kvCache.toFixed(1)}GB${config.speculative ? `, draft: ${vramUsage.draftModel}GB` : ''})
378
+ # Quantization: ${profile?.name || config.quantization} (${profile?.accuracy || '?'}% accuracy)
379
+ # Tool call reliability: ${profile?.toolCallReliability || '?'}
380
+
381
+ [model]
382
+ path=${config.modelPath}
383
+ type=gguf
384
+ quantization=${config.quantization}
385
+
386
+ [server]
387
+ host=${config.host}
388
+ port=${config.port}
389
+ threads=${config.threads}
390
+ parallel=2
391
+ log-file=${config.logFile || 'llama-server.log'}
392
+ metrics=true
393
+
394
+ [inference]
395
+ ctx-size=${config.context}
396
+ cache-type-k=${config.kvCacheK}
397
+ cache-type-v=${config.kvCacheV}
398
+ n-gpu-layers=${config.gpuLayers}
399
+ flash-attn=${config.flashAttn}
400
+
401
+ [chat]
402
+ chat-template-file=${config.chatTemplatePath || 'tools/agents/config/chat_template.jinja'}
403
+
404
+ [optimization]
405
+ mlock=true
406
+ ${config.speculative ? `\n[speculative]\nmodel-draft=${config.draftModelPath}\ndraft-max=16\ndraft-min=3\ndraft-p-min=0.8` : '# speculative decoding disabled'}
407
+ ${config.promptCache ? `\n[cache]\nslot-save-path=${config.slotSavePath}` : '# prompt caching disabled'}
408
+ ${config.loraPath ? `\n[lora]\npath=${config.loraPath}\nscale=${config.loraScale}` : '# no LoRA adapter'}
409
+ ${config.grammar ? `\n[grammar]\n# Use with --grammar-file flag for structured tool call output\ngrammar-file=${config.grammarPath || 'tools/agents/config/tool-call.gbnf'}` : '# grammar constrained output disabled'}
410
+ `;
411
+ }
412
+ async function interactiveMode() {
413
+ console.log('\n=== Qwen3.5 35B A3B Server Optimizer v2.0 ===\n');
414
+ const detectedVRAM = await detectVRAM();
415
+ console.log(`Detected VRAM: ${detectedVRAM}GB`);
416
+ const vramOption = await selectOption('Select VRAM:', [
417
+ { value: 16, label: '16GB', description: 'Standard GPU (RTX 4060 Ti 16GB, etc.)' },
418
+ { value: 24, label: '24GB', description: 'High-end GPU (RTX 3090/4090)' },
419
+ { value: 48, label: '48GB', description: 'Professional GPU (A6000, dual GPU)' },
420
+ ], detectedVRAM <= 16 ? 0 : detectedVRAM <= 24 ? 1 : 2);
421
+ // Use case
422
+ const useCase = await selectOption('Primary use case:', [
423
+ {
424
+ value: 'tool-call',
425
+ label: 'Tool Calling (RECOMMENDED)',
426
+ description: 'Optimized for reliable tool calls with grammar + prompt cache',
427
+ },
428
+ { value: 'balanced', label: 'Balanced', description: 'Good for most tasks' },
429
+ { value: 'accuracy', label: 'Maximum Accuracy', description: 'Best quality, less context' },
430
+ { value: 'context', label: 'Maximum Context', description: 'Long documents, codebases' },
431
+ {
432
+ value: 'speed',
433
+ label: 'Fastest Speed',
434
+ description: 'Speculative decoding + small context',
435
+ },
436
+ ], 0);
437
+ const preset = PRESETS[useCase.value] || PRESETS['tool-call'];
438
+ // Context length
439
+ const contextOption = await selectOption('Context length:', CONTEXT_LENGTHS, CONTEXT_LENGTHS.findIndex((c) => c.value === preset.context));
440
+ // Quantization
441
+ const quantOption = await selectOption('Quantization:', Object.entries(QUANTIZATION_PROFILES).map(([key, profile]) => ({
442
+ value: key,
443
+ label: `${profile.name} - ${profile.description}`,
444
+ description: `${profile.accuracy}% accuracy | Tool calls: ${profile.toolCallReliability} | ${profile.recommendedFor}`,
445
+ })), Object.keys(QUANTIZATION_PROFILES).indexOf(preset.quantization));
446
+ // KV cache
447
+ const kvOption = await selectOption('KV cache quantization:', KV_CACHE_OPTIONS, 2 // q8_0/q4_0 recommended
448
+ );
449
+ // Flash attention
450
+ const flashAnswer = await question('\nEnable flash attention? (Y/n): ');
451
+ const flashAttn = flashAnswer.toLowerCase() !== 'n';
452
+ // Speculative decoding
453
+ const specAnswer = await question('Enable speculative decoding with draft model? (y/N): ');
454
+ const speculative = specAnswer.toLowerCase() === 'y';
455
+ let draftModelPath = '';
456
+ if (speculative) {
457
+ draftModelPath =
458
+ (await question('Draft model path (default: ./models/Qwen3.5-0.6B.gguf): ')).trim() ||
459
+ './models/Qwen3.5-0.6B.gguf';
460
+ }
461
+ // Prompt caching
462
+ const cacheAnswer = await question('Enable prompt caching (slot-save)? (Y/n): ');
463
+ const promptCache = cacheAnswer.toLowerCase() !== 'n';
464
+ // LoRA
465
+ const loraAnswer = await question('Load LoRA adapter? (y/N): ');
466
+ let loraPath = '';
467
+ let loraScale = 1.0;
468
+ if (loraAnswer.toLowerCase() === 'y') {
469
+ loraPath = (await question('LoRA adapter path: ')).trim();
470
+ const scaleStr = await question('LoRA scale (default: 1.0): ');
471
+ loraScale = parseFloat(scaleStr) || 1.0;
472
+ }
473
+ const config = {
474
+ vram: vramOption.value,
475
+ quantization: quantOption.value,
476
+ context: contextOption.value,
477
+ kvCacheK: kvOption.value.k,
478
+ kvCacheV: kvOption.value.v,
479
+ gpuLayers: 99,
480
+ threads: Math.max(1, os.cpus().length - 2),
481
+ modelPath: './models/Qwen3.5-35B-A3B.gguf',
482
+ host: '0.0.0.0',
483
+ port: 8080,
484
+ logFile: 'llama-server.log',
485
+ hfModel: '',
486
+ flashAttn,
487
+ speculative,
488
+ draftModelPath,
489
+ draftModelLayers: 99,
490
+ promptCache,
491
+ slotSavePath: promptCache ? './cache/slots' : '',
492
+ grammar: true,
493
+ grammarPath: join(PROJECT_ROOT, 'tools/agents/config/tool-call.gbnf'),
494
+ loraPath,
495
+ loraScale,
496
+ chatTemplatePath: join(PROJECT_ROOT, 'tools/agents/config/chat_template.jinja'),
497
+ };
498
+ const vramUsage = calculateVRAMUsage(config);
499
+ // Summary
500
+ console.log('\n' + '='.repeat(60));
501
+ console.log('=== Configuration Summary ===');
502
+ console.log('='.repeat(60));
503
+ console.log(`VRAM: ${config.vram}GB`);
504
+ console.log(`Quantization: ${QUANTIZATION_PROFILES[config.quantization]?.name || config.quantization}`);
505
+ console.log(`Context: ${CONTEXT_LENGTHS.find((c) => c.value === config.context)?.label || config.context}`);
506
+ console.log(`KV Cache: K=${config.kvCacheK} V=${config.kvCacheV}`);
507
+ console.log(`Flash Attn: ${config.flashAttn ? 'YES' : 'no'}`);
508
+ console.log(`Speculative: ${config.speculative ? 'YES (' + config.draftModelPath + ')' : 'no'}`);
509
+ console.log(`Prompt Cache: ${config.promptCache ? 'YES' : 'no'}`);
510
+ console.log(`Grammar: ${config.grammar ? 'YES (GBNF)' : 'no'}`);
511
+ console.log(`LoRA: ${config.loraPath || 'none'}`);
512
+ console.log(`Threads: ${config.threads}`);
513
+ console.log('='.repeat(60));
514
+ console.log('\nVRAM Usage:');
515
+ console.log(` Model weights: ${vramUsage.model.toFixed(1)} GB`);
516
+ console.log(` KV cache: ${vramUsage.kvCache.toFixed(1)} GB`);
517
+ if (config.speculative) {
518
+ console.log(` Draft model: ${vramUsage.draftModel.toFixed(1)} GB`);
519
+ }
520
+ console.log(` Total: ${vramUsage.total.toFixed(1)} GB`);
521
+ console.log(` Available: ${config.vram} GB`);
522
+ console.log(` Status: ${vramUsage.sufficient ? 'OK - fits in VRAM' : 'WARNING - may not fit!'}`);
523
+ if (!vramUsage.sufficient) {
524
+ console.log(`\n Suggestions to reduce VRAM:`);
525
+ console.log(` - Lower quantization (current: ${config.quantization})`);
526
+ console.log(` - Reduce context length (current: ${config.context})`);
527
+ console.log(` - Use KV cache q4_0/q4_0`);
528
+ console.log(` - Disable speculative decoding`);
529
+ }
530
+ console.log('\n' + '='.repeat(60));
531
+ console.log('=== Startup Command ===');
532
+ console.log('='.repeat(60));
533
+ console.log(generateStartupCommand(config));
534
+ const saveConfig = await question('\nSave configuration to llama-server.conf? (y/N): ');
535
+ if (saveConfig.toLowerCase() === 'y') {
536
+ const configContent = generateConfigFile(config);
537
+ fs.writeFileSync('llama-server.conf', configContent);
538
+ console.log('Configuration saved to llama-server.conf');
539
+ }
540
+ console.log('\nOptimization complete!');
541
+ return config;
542
+ }
543
+ async function presetMode(presetName) {
544
+ const preset = PRESETS[presetName];
545
+ if (!preset) {
546
+ console.error(`Unknown preset: ${presetName}`);
547
+ console.log('Available presets:', Object.keys(PRESETS).join(', '));
548
+ process.exit(1);
549
+ }
550
+ const config = {
551
+ vram: preset.vram,
552
+ quantization: preset.quantization,
553
+ context: preset.context,
554
+ kvCacheK: preset.kvCacheK,
555
+ kvCacheV: preset.kvCacheV,
556
+ gpuLayers: preset.gpuLayers,
557
+ threads: Math.max(1, os.cpus().length - 2),
558
+ modelPath: './models/Qwen3.5-35B-A3B.gguf',
559
+ host: '0.0.0.0',
560
+ port: 8080,
561
+ logFile: 'llama-server.log',
562
+ hfModel: '',
563
+ flashAttn: preset.flashAttn,
564
+ speculative: preset.speculative,
565
+ draftModelPath: preset.speculative ? './models/Qwen3.5-0.6B.gguf' : '',
566
+ draftModelLayers: 99,
567
+ promptCache: preset.promptCache,
568
+ slotSavePath: preset.promptCache ? './cache/slots' : '',
569
+ grammar: preset.grammar,
570
+ grammarPath: join(PROJECT_ROOT, 'tools/agents/config/tool-call.gbnf'),
571
+ loraPath: '',
572
+ loraScale: 1.0,
573
+ chatTemplatePath: join(PROJECT_ROOT, 'tools/agents/config/chat_template.jinja'),
574
+ };
575
+ const vramUsage = calculateVRAMUsage(config);
576
+ const profile = QUANTIZATION_PROFILES[config.quantization];
577
+ console.log(`\n=== Qwen3.5 35B A3B - ${preset.name.toUpperCase()} Preset ===`);
578
+ console.log(`${preset.description}`);
579
+ console.log('='.repeat(60));
580
+ console.log(`Quantization: ${profile?.name || config.quantization} (${profile?.accuracy}% accuracy)`);
581
+ console.log(`Context: ${CONTEXT_LENGTHS.find((c) => c.value === config.context)?.label || config.context}`);
582
+ console.log(`KV Cache: K=${config.kvCacheK} V=${config.kvCacheV}`);
583
+ console.log(`Flash Attn: ${config.flashAttn ? 'YES' : 'no'}`);
584
+ console.log(`Speculative: ${config.speculative ? 'YES' : 'no'}`);
585
+ console.log(`Prompt Cache: ${config.promptCache ? 'YES' : 'no'}`);
586
+ console.log(`Grammar: ${config.grammar ? 'YES (GBNF)' : 'no'}`);
587
+ console.log(`Tool Calls: ${profile?.toolCallReliability || '?'} reliability`);
588
+ console.log('='.repeat(60));
589
+ console.log('\nVRAM Usage:');
590
+ console.log(` Model: ${vramUsage.model.toFixed(1)} GB`);
591
+ console.log(` KV cache: ${vramUsage.kvCache.toFixed(1)} GB`);
592
+ if (config.speculative)
593
+ console.log(` Draft: ${vramUsage.draftModel.toFixed(1)} GB`);
594
+ console.log(` Total: ${vramUsage.total.toFixed(1)} GB / ${config.vram} GB`);
595
+ console.log(` Status: ${vramUsage.sufficient ? 'OK' : 'WARNING - may not fit!'}`);
596
+ console.log('\n' + '='.repeat(60));
597
+ console.log('=== Startup Command ===');
598
+ console.log('='.repeat(60));
599
+ console.log(generateStartupCommand(config));
600
+ return config;
601
+ }
602
+ // CLI commands
603
+ program
604
+ .name('llama-optimize')
605
+ .description('Optimize llama.cpp startup parameters for Qwen3.5 35B A3B')
606
+ .version('2.0.0');
607
+ program
608
+ .command('interactive')
609
+ .description('Run interactive setup wizard')
610
+ .action(async () => {
611
+ try {
612
+ await interactiveMode();
613
+ }
614
+ catch (error) {
615
+ console.error('Error:', error);
616
+ process.exit(1);
617
+ }
618
+ finally {
619
+ rl.close();
620
+ }
621
+ });
622
+ program
623
+ .command('preset <name>')
624
+ .description(`Use a preset: ${Object.keys(PRESETS).join(', ')}`)
625
+ .action(async (presetName) => {
626
+ try {
627
+ await presetMode(presetName);
628
+ }
629
+ catch (error) {
630
+ console.error('Error:', error);
631
+ process.exit(1);
632
+ }
633
+ });
634
+ program
635
+ .command('quick')
636
+ .description('Quick mode with tool-call preset (recommended)')
637
+ .action(async () => {
638
+ try {
639
+ await presetMode('tool-call');
640
+ }
641
+ catch (error) {
642
+ console.error('Error:', error);
643
+ process.exit(1);
644
+ }
645
+ });
646
+ program
647
+ .command('json')
648
+ .description('Output configuration as JSON')
649
+ .option('--preset <name>', 'Use preset')
650
+ .action(async (options) => {
651
+ try {
652
+ let config;
653
+ if (options.preset) {
654
+ config = await presetMode(options.preset);
655
+ }
656
+ else {
657
+ config = await interactiveMode();
658
+ }
659
+ const output = {
660
+ ...config,
661
+ vramUsage: calculateVRAMUsage(config),
662
+ quantProfile: QUANTIZATION_PROFILES[config.quantization],
663
+ };
664
+ console.log(JSON.stringify(output, null, 2));
665
+ }
666
+ catch (error) {
667
+ console.error('Error:', error);
668
+ process.exit(1);
669
+ }
670
+ finally {
671
+ rl.close();
672
+ }
673
+ });
674
+ program
675
+ .command('hf <repo>')
676
+ .description('Download model from HuggingFace')
677
+ .option('--quant <name>', 'Quantization to download', 'iq4_xs')
678
+ .option('--output <dir>', 'Output directory', './models')
679
+ .option('--draft', 'Also download draft model for speculative decoding')
680
+ .action(async (repo, options) => {
681
+ console.log(`\nDownload ${options.quant} model from ${repo}:`);
682
+ console.log(` huggingface-cli download ${repo} --include "*${options.quant}*" --local-dir ${options.output}`);
683
+ if (options.draft) {
684
+ console.log(`\nDownload draft model for speculative decoding:`);
685
+ console.log(` huggingface-cli download Qwen/Qwen3.5-0.6B-GGUF --include "*q8_0*" --local-dir ${options.output}`);
686
+ }
687
+ console.log(`\nAfter download, run:`);
688
+ console.log(` llama-optimize preset tool-call`);
689
+ });
690
+ program
691
+ .command('profiles')
692
+ .description('Show all quantization profiles with tool call reliability')
693
+ .action(() => {
694
+ console.log('\n=== Quantization Profiles for Qwen3.5 35B A3B ===\n');
695
+ console.log('Profile | Size | Accuracy | Tool Calls | Recommended For');
696
+ console.log('-----------|-------|----------|------------|----------------');
697
+ for (const [, p] of Object.entries(QUANTIZATION_PROFILES)) {
698
+ console.log(`${p.name.padEnd(10)} | ${(p.modelSizeGB + 'GB').padEnd(5)} | ${(p.accuracy + '%').padEnd(8)} | ${p.toolCallReliability.padEnd(10)} | ${p.recommendedFor}`);
699
+ }
700
+ console.log('\nUpgrade path for better tool call reliability:');
701
+ console.log(' IQ4_XS (94%) -> Q4_K_M (95%) -> Q5_K_M (97%) -> Q6_K (98%)');
702
+ console.log(' Each step up requires ~4-7GB more VRAM');
703
+ });
704
+ program.parse(process.argv);
705
+ if (!process.argv.slice(2).length) {
706
+ program.outputHelp();
707
+ }
708
+ //# sourceMappingURL=llama-server-optimize.js.map