@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,512 @@
1
+ #!/usr/bin/env bash
2
+ # =============================================================================
3
+ # Qwen3.5 35B A3B LoRA Tool Call Adapter - Full Automation Script
4
+ # =============================================================================
5
+ #
6
+ # Automates the entire LoRA fine-tuning pipeline from training data generation
7
+ # to a ready-to-use GGUF adapter for llama.cpp. One command, one adapter.
8
+ #
9
+ # Usage:
10
+ # ./tools/agents/scripts/prepare_lora.sh
11
+ # ./tools/agents/scripts/prepare_lora.sh --samples 1000 --epochs 5
12
+ # ./tools/agents/scripts/prepare_lora.sh --trainer unsloth
13
+ # ./tools/agents/scripts/prepare_lora.sh --skip-train # data gen + convert only
14
+ #
15
+ # After completion, load in llama.cpp:
16
+ # llama-server --model base.gguf --lora output/qwen35-tool-call-lora/adapter.gguf
17
+ #
18
+ # Prerequisites:
19
+ # - Python 3.10+ with pip
20
+ # - CUDA GPU with 24GB+ VRAM (for training)
21
+ # - llama.cpp built (for GGUF conversion)
22
+ # - HuggingFace access to Qwen/Qwen3.5-35B-A3B (for base model weights)
23
+ #
24
+ # =============================================================================
25
+
26
+ set -euo pipefail
27
+
28
+ # ── Configuration ──────────────────────────────────────────────────────────────
29
+
30
+ SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
31
+ PROJECT_ROOT="$(cd "$SCRIPT_DIR/../../.." && pwd)"
32
+
33
+ # Defaults (overridable via CLI args or env vars)
34
+ SAMPLES="${SAMPLES:-500}"
35
+ EPOCHS="${EPOCHS:-3}"
36
+ LORA_RANK="${LORA_RANK:-16}"
37
+ LORA_ALPHA="${LORA_ALPHA:-32}"
38
+ TRAINER="${TRAINER:-unsloth}" # unsloth | axolotl
39
+ BASE_MODEL="${BASE_MODEL:-Qwen/Qwen3.5-35B-A3B}"
40
+ LLAMA_CPP_DIR="${LLAMA_CPP_DIR:-$HOME/llama.cpp}"
41
+ OUTPUT_DIR="${OUTPUT_DIR:-$PROJECT_ROOT/output/qwen35-tool-call-lora}"
42
+ TRAINING_DATA="${TRAINING_DATA:-$PROJECT_ROOT/tool_call_training_data.jsonl}"
43
+ LORA_CONFIG="${LORA_CONFIG:-$PROJECT_ROOT/config/lora-finetune.yaml}"
44
+ SKIP_TRAIN="${SKIP_TRAIN:-false}"
45
+ SKIP_CONVERT="${SKIP_CONVERT:-false}"
46
+ SEED="${SEED:-42}"
47
+ LEARNING_RATE="${LEARNING_RATE:-2e-4}"
48
+ BATCH_SIZE="${BATCH_SIZE:-1}"
49
+ GRAD_ACCUM="${GRAD_ACCUM:-8}"
50
+ SEQ_LEN="${SEQ_LEN:-4096}"
51
+
52
+ # ── CLI Argument Parsing ──────────────────────────────────────────────────────
53
+
54
+ usage() {
55
+ cat <<EOF
56
+ Usage: $(basename "$0") [OPTIONS]
57
+
58
+ Automates Qwen3.5 LoRA tool call adapter preparation.
59
+
60
+ Options:
61
+ --samples N Training examples to generate (default: $SAMPLES)
62
+ --epochs N Training epochs (default: $EPOCHS)
63
+ --rank N LoRA rank (default: $LORA_RANK)
64
+ --alpha N LoRA alpha (default: $LORA_ALPHA)
65
+ --trainer NAME Training framework: unsloth or axolotl (default: $TRAINER)
66
+ --base-model ID HuggingFace model ID (default: $BASE_MODEL)
67
+ --llama-cpp DIR Path to llama.cpp repo (default: $LLAMA_CPP_DIR)
68
+ --output DIR Output directory (default: $OUTPUT_DIR)
69
+ --lr RATE Learning rate (default: $LEARNING_RATE)
70
+ --batch-size N Micro batch size (default: $BATCH_SIZE)
71
+ --grad-accum N Gradient accumulation steps (default: $GRAD_ACCUM)
72
+ --seq-len N Max sequence length (default: $SEQ_LEN)
73
+ --seed N Random seed (default: $SEED)
74
+ --skip-train Skip training, only generate data + convert existing adapter
75
+ --skip-convert Skip GGUF conversion (output HuggingFace format only)
76
+ --help Show this help message
77
+
78
+ Examples:
79
+ # Default: 500 samples, 3 epochs, unsloth trainer
80
+ $(basename "$0")
81
+
82
+ # More data, more epochs
83
+ $(basename "$0") --samples 1000 --epochs 5
84
+
85
+ # Use axolotl instead of unsloth
86
+ $(basename "$0") --trainer axolotl
87
+
88
+ # Just regenerate training data and convert existing adapter
89
+ $(basename "$0") --skip-train
90
+
91
+ After completion, load in llama.cpp:
92
+ llama-server --model base.gguf \\
93
+ --lora $OUTPUT_DIR/adapter.gguf \\
94
+ --lora-scale 1.0
95
+ EOF
96
+ exit 0
97
+ }
98
+
99
+ while [[ $# -gt 0 ]]; do
100
+ case "$1" in
101
+ --samples) SAMPLES="$2"; shift 2 ;;
102
+ --epochs) EPOCHS="$2"; shift 2 ;;
103
+ --rank) LORA_RANK="$2"; shift 2 ;;
104
+ --alpha) LORA_ALPHA="$2"; shift 2 ;;
105
+ --trainer) TRAINER="$2"; shift 2 ;;
106
+ --base-model) BASE_MODEL="$2"; shift 2 ;;
107
+ --llama-cpp) LLAMA_CPP_DIR="$2"; shift 2 ;;
108
+ --output) OUTPUT_DIR="$2"; shift 2 ;;
109
+ --lr) LEARNING_RATE="$2"; shift 2 ;;
110
+ --batch-size) BATCH_SIZE="$2"; shift 2 ;;
111
+ --grad-accum) GRAD_ACCUM="$2"; shift 2 ;;
112
+ --seq-len) SEQ_LEN="$2"; shift 2 ;;
113
+ --seed) SEED="$2"; shift 2 ;;
114
+ --skip-train) SKIP_TRAIN=true; shift ;;
115
+ --skip-convert) SKIP_CONVERT=true; shift ;;
116
+ --help|-h) usage ;;
117
+ *) echo "Unknown option: $1"; usage ;;
118
+ esac
119
+ done
120
+
121
+ # ── Logging ───────────────────────────────────────────────────────────────────
122
+
123
+ log() { echo "[$(date '+%H:%M:%S')] $*"; }
124
+ info() { log "INFO $*"; }
125
+ warn() { log "WARN $*"; }
126
+ err() { log "ERROR $*" >&2; }
127
+ die() { err "$*"; exit 1; }
128
+
129
+ # ── Preflight Checks ─────────────────────────────────────────────────────────
130
+
131
+ preflight() {
132
+ info "=== Preflight Checks ==="
133
+
134
+ # Python
135
+ command -v python3 >/dev/null 2>&1 || die "python3 not found"
136
+ PYTHON_VERSION=$(python3 -c "import sys; print(f'{sys.version_info.major}.{sys.version_info.minor}')")
137
+ info "Python: $PYTHON_VERSION"
138
+
139
+ # Training data generator
140
+ [[ -f "$SCRIPT_DIR/generate_lora_training_data.py" ]] || \
141
+ die "generate_lora_training_data.py not found at $SCRIPT_DIR"
142
+
143
+ # Trainer
144
+ if [[ "$SKIP_TRAIN" != "true" ]]; then
145
+ case "$TRAINER" in
146
+ unsloth)
147
+ python3 -c "import unsloth" 2>/dev/null || {
148
+ warn "unsloth not installed. Installing..."
149
+ pip install unsloth 2>/dev/null || die "Failed to install unsloth"
150
+ }
151
+ info "Trainer: unsloth"
152
+ ;;
153
+ axolotl)
154
+ python3 -c "import axolotl" 2>/dev/null || {
155
+ warn "axolotl not installed. Installing..."
156
+ pip install axolotl 2>/dev/null || die "Failed to install axolotl"
157
+ }
158
+ info "Trainer: axolotl"
159
+ ;;
160
+ *)
161
+ die "Unknown trainer: $TRAINER (use 'unsloth' or 'axolotl')"
162
+ ;;
163
+ esac
164
+
165
+ # CUDA
166
+ python3 -c "import torch; assert torch.cuda.is_available()" 2>/dev/null || \
167
+ warn "CUDA not available - training will be very slow on CPU"
168
+ fi
169
+
170
+ # llama.cpp conversion script
171
+ if [[ "$SKIP_CONVERT" != "true" ]]; then
172
+ CONVERT_SCRIPT="$LLAMA_CPP_DIR/convert_lora_to_gguf.py"
173
+ [[ -f "$CONVERT_SCRIPT" ]] || \
174
+ die "convert_lora_to_gguf.py not found at $CONVERT_SCRIPT"
175
+ info "GGUF converter: $CONVERT_SCRIPT"
176
+ fi
177
+
178
+ info "Base model: $BASE_MODEL"
179
+ info "Output: $OUTPUT_DIR"
180
+ info "Preflight OK"
181
+ echo
182
+ }
183
+
184
+ # ── Step 1: Generate Training Data ───────────────────────────────────────────
185
+
186
+ generate_training_data() {
187
+ info "=== Step 1/4: Generating Training Data ==="
188
+ info "Samples: $SAMPLES | Seed: $SEED"
189
+
190
+ python3 "$SCRIPT_DIR/generate_lora_training_data.py" \
191
+ --output "$TRAINING_DATA" \
192
+ --count "$SAMPLES" \
193
+ --seed "$SEED"
194
+
195
+ LINES=$(wc -l < "$TRAINING_DATA")
196
+ info "Generated $LINES training examples -> $TRAINING_DATA"
197
+
198
+ # Validate a sample
199
+ FIRST=$(head -1 "$TRAINING_DATA")
200
+ python3 -c "
201
+ import json, sys
202
+ d = json.loads('''$FIRST''')
203
+ assert 'messages' in d, 'Missing messages key'
204
+ roles = [m['role'] for m in d['messages']]
205
+ assert 'user' in roles, 'Missing user role'
206
+ assert 'assistant' in roles, 'Missing assistant role'
207
+ print(' Validation: OK (roles: ' + ', '.join(set(roles)) + ')')
208
+ " || warn "Training data validation failed - check format"
209
+
210
+ echo
211
+ }
212
+
213
+ # ── Step 2: Generate Training Config ─────────────────────────────────────────
214
+
215
+ generate_config() {
216
+ info "=== Step 2/4: Generating Training Config ==="
217
+
218
+ mkdir -p "$OUTPUT_DIR"
219
+
220
+ # Generate a runtime config with CLI overrides applied
221
+ RUNTIME_CONFIG="$OUTPUT_DIR/train-config.yaml"
222
+
223
+ cat > "$RUNTIME_CONFIG" <<YAML
224
+ # Auto-generated by prepare_lora.sh at $(date -Iseconds)
225
+ # Base config: $LORA_CONFIG
226
+
227
+ # Base model
228
+ base_model: $BASE_MODEL
229
+ model_type: AutoModelForCausalLM
230
+ tokenizer_type: AutoTokenizer
231
+ trust_remote_code: true
232
+
233
+ # LoRA configuration
234
+ adapter: lora
235
+ lora_r: $LORA_RANK
236
+ lora_alpha: $LORA_ALPHA
237
+ lora_dropout: 0.05
238
+ lora_target_modules:
239
+ - q_proj
240
+ - k_proj
241
+ - v_proj
242
+ - o_proj
243
+ - gate_proj
244
+ - up_proj
245
+ - down_proj
246
+ lora_target_linear: true
247
+
248
+ # Dataset
249
+ datasets:
250
+ - path: $TRAINING_DATA
251
+ type: chat_template
252
+ chat_template: chatml
253
+ field_messages: messages
254
+
255
+ # Training parameters
256
+ num_epochs: $EPOCHS
257
+ micro_batch_size: $BATCH_SIZE
258
+ gradient_accumulation_steps: $GRAD_ACCUM
259
+ learning_rate: $LEARNING_RATE
260
+ lr_scheduler: cosine
261
+ warmup_ratio: 0.1
262
+ optimizer: adamw_torch
263
+ weight_decay: 0.01
264
+ max_grad_norm: 1.0
265
+
266
+ # Sequence length
267
+ sequence_len: $SEQ_LEN
268
+ sample_packing: true
269
+ pad_to_sequence_len: true
270
+
271
+ # Memory optimization
272
+ bf16: true
273
+ tf32: true
274
+ gradient_checkpointing: true
275
+ flash_attention: true
276
+
277
+ # Output
278
+ output_dir: $OUTPUT_DIR
279
+ save_strategy: epoch
280
+ save_total_limit: 2
281
+ logging_steps: 10
282
+
283
+ # Evaluation
284
+ val_set_size: 0.05
285
+ eval_steps: 50
286
+
287
+ # Special tokens
288
+ special_tokens:
289
+ pad_token: '<|endoftext|>'
290
+ YAML
291
+
292
+ info "Config written -> $RUNTIME_CONFIG"
293
+ info " LoRA rank=$LORA_RANK alpha=$LORA_ALPHA"
294
+ info " Epochs=$EPOCHS LR=$LEARNING_RATE Batch=$BATCH_SIZE GradAccum=$GRAD_ACCUM"
295
+ echo
296
+ }
297
+
298
+ # ── Step 3: Train LoRA Adapter ───────────────────────────────────────────────
299
+
300
+ train_adapter() {
301
+ if [[ "$SKIP_TRAIN" == "true" ]]; then
302
+ info "=== Step 3/4: Training SKIPPED (--skip-train) ==="
303
+ echo
304
+ return
305
+ fi
306
+
307
+ info "=== Step 3/4: Training LoRA Adapter ==="
308
+ info "Trainer: $TRAINER | Epochs: $EPOCHS | Rank: $LORA_RANK"
309
+
310
+ RUNTIME_CONFIG="$OUTPUT_DIR/train-config.yaml"
311
+ TRAIN_START=$(date +%s)
312
+
313
+ case "$TRAINER" in
314
+ unsloth)
315
+ info "Starting unsloth training..."
316
+ python3 -c "
317
+ import sys
318
+ sys.path.insert(0, '.')
319
+ from unsloth import FastLanguageModel
320
+ from datasets import load_dataset
321
+ import yaml, json
322
+
323
+ # Load config
324
+ with open('$RUNTIME_CONFIG') as f:
325
+ config = yaml.safe_load(f)
326
+
327
+ print(f'Loading base model: {config[\"base_model\"]}')
328
+ model, tokenizer = FastLanguageModel.from_pretrained(
329
+ model_name=config['base_model'],
330
+ max_seq_length=config['sequence_len'],
331
+ dtype=None,
332
+ load_in_4bit=True,
333
+ )
334
+
335
+ print(f'Applying LoRA: rank={config[\"lora_r\"]}, alpha={config[\"lora_alpha\"]}')
336
+ model = FastLanguageModel.get_peft_model(
337
+ model,
338
+ r=config['lora_r'],
339
+ lora_alpha=config['lora_alpha'],
340
+ lora_dropout=config.get('lora_dropout', 0.05),
341
+ target_modules=config['lora_target_modules'],
342
+ bias='none',
343
+ use_gradient_checkpointing='unsloth',
344
+ )
345
+
346
+ # Load dataset
347
+ print(f'Loading dataset: {config[\"datasets\"][0][\"path\"]}')
348
+ dataset = load_dataset('json', data_files=config['datasets'][0]['path'], split='train')
349
+
350
+ # Format for training
351
+ from trl import SFTTrainer
352
+ from transformers import TrainingArguments
353
+
354
+ trainer = SFTTrainer(
355
+ model=model,
356
+ tokenizer=tokenizer,
357
+ train_dataset=dataset,
358
+ args=TrainingArguments(
359
+ output_dir=config['output_dir'],
360
+ num_train_epochs=config['num_epochs'],
361
+ per_device_train_batch_size=config['micro_batch_size'],
362
+ gradient_accumulation_steps=config['gradient_accumulation_steps'],
363
+ learning_rate=float(config['learning_rate']),
364
+ lr_scheduler_type=config['lr_scheduler'],
365
+ warmup_ratio=config.get('warmup_ratio', 0.1),
366
+ weight_decay=config.get('weight_decay', 0.01),
367
+ max_grad_norm=config.get('max_grad_norm', 1.0),
368
+ bf16=config.get('bf16', True),
369
+ tf32=config.get('tf32', True),
370
+ logging_steps=config.get('logging_steps', 10),
371
+ save_strategy=config.get('save_strategy', 'epoch'),
372
+ save_total_limit=config.get('save_total_limit', 2),
373
+ seed=$SEED,
374
+ ),
375
+ max_seq_length=config['sequence_len'],
376
+ packing=config.get('sample_packing', True),
377
+ )
378
+
379
+ print('Starting training...')
380
+ trainer.train()
381
+
382
+ print(f'Saving adapter to {config[\"output_dir\"]}')
383
+ model.save_pretrained(config['output_dir'])
384
+ tokenizer.save_pretrained(config['output_dir'])
385
+ print('Training complete.')
386
+ "
387
+ ;;
388
+ axolotl)
389
+ info "Starting axolotl training..."
390
+ accelerate launch -m axolotl.cli.train "$RUNTIME_CONFIG"
391
+ ;;
392
+ esac
393
+
394
+ TRAIN_END=$(date +%s)
395
+ TRAIN_DURATION=$((TRAIN_END - TRAIN_START))
396
+ info "Training completed in ${TRAIN_DURATION}s"
397
+
398
+ # Verify adapter files exist
399
+ if [[ -f "$OUTPUT_DIR/adapter_model.safetensors" ]] || \
400
+ [[ -f "$OUTPUT_DIR/adapter_model.bin" ]]; then
401
+ info "Adapter saved -> $OUTPUT_DIR"
402
+ else
403
+ # Check for checkpoint subdirectories
404
+ LATEST_CHECKPOINT=$(ls -td "$OUTPUT_DIR"/checkpoint-* 2>/dev/null | head -1)
405
+ if [[ -n "$LATEST_CHECKPOINT" ]]; then
406
+ info "Adapter saved in checkpoint -> $LATEST_CHECKPOINT"
407
+ # Copy to output root for conversion
408
+ cp "$LATEST_CHECKPOINT"/adapter_* "$OUTPUT_DIR/" 2>/dev/null || true
409
+ cp "$LATEST_CHECKPOINT"/adapter_config.json "$OUTPUT_DIR/" 2>/dev/null || true
410
+ else
411
+ warn "No adapter files found in $OUTPUT_DIR"
412
+ fi
413
+ fi
414
+
415
+ echo
416
+ }
417
+
418
+ # ── Step 4: Convert to GGUF ──────────────────────────────────────────────────
419
+
420
+ convert_to_gguf() {
421
+ if [[ "$SKIP_CONVERT" == "true" ]]; then
422
+ info "=== Step 4/4: GGUF Conversion SKIPPED (--skip-convert) ==="
423
+ echo
424
+ return
425
+ fi
426
+
427
+ info "=== Step 4/4: Converting to GGUF ==="
428
+
429
+ CONVERT_SCRIPT="$LLAMA_CPP_DIR/convert_lora_to_gguf.py"
430
+ GGUF_OUTPUT="$OUTPUT_DIR/adapter.gguf"
431
+
432
+ # Check for adapter files
433
+ if [[ ! -f "$OUTPUT_DIR/adapter_config.json" ]]; then
434
+ die "No adapter_config.json found in $OUTPUT_DIR - training may have failed"
435
+ fi
436
+
437
+ info "Converting HuggingFace adapter -> GGUF"
438
+ info " Input: $OUTPUT_DIR"
439
+ info " Output: $GGUF_OUTPUT"
440
+
441
+ python3 "$CONVERT_SCRIPT" \
442
+ --base "$BASE_MODEL" \
443
+ --lora "$OUTPUT_DIR" \
444
+ --outfile "$GGUF_OUTPUT"
445
+
446
+ if [[ -f "$GGUF_OUTPUT" ]]; then
447
+ GGUF_SIZE=$(du -h "$GGUF_OUTPUT" | cut -f1)
448
+ info "GGUF adapter created: $GGUF_OUTPUT ($GGUF_SIZE)"
449
+ else
450
+ die "GGUF conversion failed - no output file"
451
+ fi
452
+
453
+ echo
454
+ }
455
+
456
+ # ── Summary ──────────────────────────────────────────────────────────────────
457
+
458
+ print_summary() {
459
+ GGUF_OUTPUT="$OUTPUT_DIR/adapter.gguf"
460
+
461
+ echo "=================================================================="
462
+ echo " LoRA Adapter Preparation Complete"
463
+ echo "=================================================================="
464
+ echo
465
+ echo " Training data: $TRAINING_DATA ($SAMPLES examples)"
466
+ echo " LoRA config: rank=$LORA_RANK alpha=$LORA_ALPHA"
467
+ echo " Training: $EPOCHS epochs, $TRAINER"
468
+ echo " Output dir: $OUTPUT_DIR"
469
+
470
+ if [[ -f "$GGUF_OUTPUT" ]]; then
471
+ GGUF_SIZE=$(du -h "$GGUF_OUTPUT" | cut -f1)
472
+ echo " GGUF adapter: $GGUF_OUTPUT ($GGUF_SIZE)"
473
+ echo
474
+ echo " Load in llama.cpp:"
475
+ echo " llama-server \\"
476
+ echo " --model /path/to/Qwen3.5-35B-A3B.gguf \\"
477
+ echo " --lora $GGUF_OUTPUT \\"
478
+ echo " --lora-scale 1.0 \\"
479
+ echo " --chat-template-file chat_template.jinja"
480
+ else
481
+ echo " GGUF adapter: (not generated)"
482
+ echo
483
+ echo " To convert manually:"
484
+ echo " python3 $LLAMA_CPP_DIR/convert_lora_to_gguf.py \\"
485
+ echo " --base $BASE_MODEL \\"
486
+ echo " --lora $OUTPUT_DIR \\"
487
+ echo " --outfile $OUTPUT_DIR/adapter.gguf"
488
+ fi
489
+
490
+ echo
491
+ echo " Test the adapter:"
492
+ echo " python3 tools/agents/scripts/qwen_tool_call_test.py --verbose"
493
+ echo
494
+ echo "=================================================================="
495
+ }
496
+
497
+ # ── Main ─────────────────────────────────────────────────────────────────────
498
+
499
+ main() {
500
+ info "Qwen3.5 35B A3B LoRA Tool Call Adapter Preparation"
501
+ info "Project root: $PROJECT_ROOT"
502
+ echo
503
+
504
+ preflight
505
+ generate_training_data
506
+ generate_config
507
+ train_adapter
508
+ convert_to_gguf
509
+ print_summary
510
+ }
511
+
512
+ main "$@"