@jokerized/getresearchdone 0.4.1

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 (711) hide show
  1. package/.claude-plugin/plugin.json +103 -0
  2. package/README.md +211 -0
  3. package/agents/grd-baseline-assessor.md +684 -0
  4. package/agents/grd-code-reviewer.md +300 -0
  5. package/agents/grd-codebase-mapper.md +355 -0
  6. package/agents/grd-critique-agent.md +119 -0
  7. package/agents/grd-debugger.md +519 -0
  8. package/agents/grd-deep-diver.md +737 -0
  9. package/agents/grd-eval-planner.md +913 -0
  10. package/agents/grd-eval-reporter.md +717 -0
  11. package/agents/grd-executor.md +683 -0
  12. package/agents/grd-feasibility-analyst.md +624 -0
  13. package/agents/grd-integration-checker.md +367 -0
  14. package/agents/grd-knowledge-miner.md +81 -0
  15. package/agents/grd-migrator.md +88 -0
  16. package/agents/grd-phase-researcher.md +697 -0
  17. package/agents/grd-plan-checker.md +443 -0
  18. package/agents/grd-planner.md +1532 -0
  19. package/agents/grd-product-owner.md +562 -0
  20. package/agents/grd-project-researcher.md +513 -0
  21. package/agents/grd-research-synthesizer.md +273 -0
  22. package/agents/grd-roadmapper.md +798 -0
  23. package/agents/grd-surveyor.md +566 -0
  24. package/agents/grd-verifier.md +893 -0
  25. package/bin/gd.js +4 -0
  26. package/bin/gd.ts +227 -0
  27. package/bin/grd-manifest.js +4 -0
  28. package/bin/grd-manifest.ts +286 -0
  29. package/bin/grd-mcp-server.js +4 -0
  30. package/bin/grd-mcp-server.ts +124 -0
  31. package/bin/grd-tools.js +4 -0
  32. package/bin/grd-tools.ts +2471 -0
  33. package/bin/postinstall.js +4 -0
  34. package/bin/postinstall.ts +80 -0
  35. package/commands/add-phase.md +123 -0
  36. package/commands/add-todo.md +87 -0
  37. package/commands/assess-baseline.md +289 -0
  38. package/commands/autopilot.md +100 -0
  39. package/commands/autoplan.md +55 -0
  40. package/commands/check-todos.md +87 -0
  41. package/commands/compare-methods.md +262 -0
  42. package/commands/complete-milestone.md +225 -0
  43. package/commands/debug.md +372 -0
  44. package/commands/deep-dive.md +288 -0
  45. package/commands/discover.md +281 -0
  46. package/commands/discuss-phase.md +188 -0
  47. package/commands/discuss.md +55 -0
  48. package/commands/eval-report.md +310 -0
  49. package/commands/evolve.md +79 -0
  50. package/commands/execute-phase.md +1017 -0
  51. package/commands/feasibility.md +292 -0
  52. package/commands/help.md +407 -0
  53. package/commands/init.md +1508 -0
  54. package/commands/insert-phase.md +113 -0
  55. package/commands/iterate.md +327 -0
  56. package/commands/list-phase-assumptions.md +217 -0
  57. package/commands/long-term-roadmap.md +202 -0
  58. package/commands/map-codebase.md +111 -0
  59. package/commands/migrate.md +159 -0
  60. package/commands/new-milestone.md +169 -0
  61. package/commands/pause-work.md +83 -0
  62. package/commands/plan-milestone-gaps.md +373 -0
  63. package/commands/plan-phase.md +655 -0
  64. package/commands/principles.md +328 -0
  65. package/commands/product-plan.md +319 -0
  66. package/commands/progress.md +481 -0
  67. package/commands/quick.md +167 -0
  68. package/commands/reapply-patches.md +154 -0
  69. package/commands/remove-phase.md +97 -0
  70. package/commands/requirement.md +96 -0
  71. package/commands/resume-project.md +113 -0
  72. package/commands/settings.md +1144 -0
  73. package/commands/survey.md +242 -0
  74. package/commands/sync.md +246 -0
  75. package/commands/tracker-setup.md +322 -0
  76. package/commands/update.md +202 -0
  77. package/commands/verify-phase.md +335 -0
  78. package/commands/verify-work.md +701 -0
  79. package/commands/wireup.md +29 -0
  80. package/dist/bin/gd.d.ts +3 -0
  81. package/dist/bin/gd.d.ts.map +1 -0
  82. package/dist/bin/gd.js +178 -0
  83. package/dist/bin/gd.js.map +1 -0
  84. package/dist/bin/grd-manifest.d.ts +3 -0
  85. package/dist/bin/grd-manifest.d.ts.map +1 -0
  86. package/dist/bin/grd-manifest.js +202 -0
  87. package/dist/bin/grd-manifest.js.map +1 -0
  88. package/dist/bin/grd-mcp-server.d.ts +3 -0
  89. package/dist/bin/grd-mcp-server.d.ts.map +1 -0
  90. package/dist/bin/grd-mcp-server.js +71 -0
  91. package/dist/bin/grd-mcp-server.js.map +1 -0
  92. package/dist/bin/grd-tools.d.ts +3 -0
  93. package/dist/bin/grd-tools.d.ts.map +1 -0
  94. package/dist/bin/grd-tools.js +1680 -0
  95. package/dist/bin/grd-tools.js.map +1 -0
  96. package/dist/bin/postinstall.d.ts +3 -0
  97. package/dist/bin/postinstall.d.ts.map +1 -0
  98. package/dist/bin/postinstall.js +61 -0
  99. package/dist/bin/postinstall.js.map +1 -0
  100. package/dist/lib/autopilot-milestone.d.ts +2 -0
  101. package/dist/lib/autopilot-milestone.d.ts.map +1 -0
  102. package/dist/lib/autopilot-milestone.js +94 -0
  103. package/dist/lib/autopilot-milestone.js.map +1 -0
  104. package/dist/lib/autopilot-pipeline.d.ts +2 -0
  105. package/dist/lib/autopilot-pipeline.d.ts.map +1 -0
  106. package/dist/lib/autopilot-pipeline.js +830 -0
  107. package/dist/lib/autopilot-pipeline.js.map +1 -0
  108. package/dist/lib/autopilot-waves.d.ts +2 -0
  109. package/dist/lib/autopilot-waves.d.ts.map +1 -0
  110. package/dist/lib/autopilot-waves.js +266 -0
  111. package/dist/lib/autopilot-waves.js.map +1 -0
  112. package/dist/lib/autopilot.d.ts +2 -0
  113. package/dist/lib/autopilot.d.ts.map +1 -0
  114. package/dist/lib/autopilot.js +1314 -0
  115. package/dist/lib/autopilot.js.map +1 -0
  116. package/dist/lib/autoplan.d.ts +2 -0
  117. package/dist/lib/autoplan.d.ts.map +1 -0
  118. package/dist/lib/autoplan.js +198 -0
  119. package/dist/lib/autoplan.js.map +1 -0
  120. package/dist/lib/autoresearch.d.ts +2 -0
  121. package/dist/lib/autoresearch.d.ts.map +1 -0
  122. package/dist/lib/autoresearch.js +626 -0
  123. package/dist/lib/autoresearch.js.map +1 -0
  124. package/dist/lib/backend.d.ts +2 -0
  125. package/dist/lib/backend.d.ts.map +1 -0
  126. package/dist/lib/backend.js +1036 -0
  127. package/dist/lib/backend.js.map +1 -0
  128. package/dist/lib/benchmark.d.ts +99 -0
  129. package/dist/lib/benchmark.d.ts.map +1 -0
  130. package/dist/lib/benchmark.js +278 -0
  131. package/dist/lib/benchmark.js.map +1 -0
  132. package/dist/lib/citations.d.ts +2 -0
  133. package/dist/lib/citations.d.ts.map +1 -0
  134. package/dist/lib/citations.js +642 -0
  135. package/dist/lib/citations.js.map +1 -0
  136. package/dist/lib/cleanup.d.ts +2 -0
  137. package/dist/lib/cleanup.d.ts.map +1 -0
  138. package/dist/lib/cleanup.js +1222 -0
  139. package/dist/lib/cleanup.js.map +1 -0
  140. package/dist/lib/cli/adapters.d.ts +10 -0
  141. package/dist/lib/cli/adapters.d.ts.map +1 -0
  142. package/dist/lib/cli/adapters.js +27 -0
  143. package/dist/lib/cli/adapters.js.map +1 -0
  144. package/dist/lib/cli/agent.d.ts +17 -0
  145. package/dist/lib/cli/agent.d.ts.map +1 -0
  146. package/dist/lib/cli/agent.js +53 -0
  147. package/dist/lib/cli/agent.js.map +1 -0
  148. package/dist/lib/cli/index.d.ts +21 -0
  149. package/dist/lib/cli/index.d.ts.map +1 -0
  150. package/dist/lib/cli/index.js +264 -0
  151. package/dist/lib/cli/index.js.map +1 -0
  152. package/dist/lib/cli/output.d.ts +20 -0
  153. package/dist/lib/cli/output.d.ts.map +1 -0
  154. package/dist/lib/cli/output.js +22 -0
  155. package/dist/lib/cli/output.js.map +1 -0
  156. package/dist/lib/cli/scan-dispatch.d.ts +9 -0
  157. package/dist/lib/cli/scan-dispatch.d.ts.map +1 -0
  158. package/dist/lib/cli/scan-dispatch.js +107 -0
  159. package/dist/lib/cli/scan-dispatch.js.map +1 -0
  160. package/dist/lib/cli/tools.d.ts +16 -0
  161. package/dist/lib/cli/tools.d.ts.map +1 -0
  162. package/dist/lib/cli/tools.js +168 -0
  163. package/dist/lib/cli/tools.js.map +1 -0
  164. package/dist/lib/commands/_dashboard-parsers.d.ts +2 -0
  165. package/dist/lib/commands/_dashboard-parsers.d.ts.map +1 -0
  166. package/dist/lib/commands/_dashboard-parsers.js +192 -0
  167. package/dist/lib/commands/_dashboard-parsers.js.map +1 -0
  168. package/dist/lib/commands/analysis.d.ts +2 -0
  169. package/dist/lib/commands/analysis.d.ts.map +1 -0
  170. package/dist/lib/commands/analysis.js +1418 -0
  171. package/dist/lib/commands/analysis.js.map +1 -0
  172. package/dist/lib/commands/assumptions.d.ts +2 -0
  173. package/dist/lib/commands/assumptions.d.ts.map +1 -0
  174. package/dist/lib/commands/assumptions.js +166 -0
  175. package/dist/lib/commands/assumptions.js.map +1 -0
  176. package/dist/lib/commands/blame.d.ts +2 -0
  177. package/dist/lib/commands/blame.d.ts.map +1 -0
  178. package/dist/lib/commands/blame.js +133 -0
  179. package/dist/lib/commands/blame.js.map +1 -0
  180. package/dist/lib/commands/budget.d.ts +2 -0
  181. package/dist/lib/commands/budget.d.ts.map +1 -0
  182. package/dist/lib/commands/budget.js +100 -0
  183. package/dist/lib/commands/budget.js.map +1 -0
  184. package/dist/lib/commands/check-plans.d.ts +2 -0
  185. package/dist/lib/commands/check-plans.d.ts.map +1 -0
  186. package/dist/lib/commands/check-plans.js +190 -0
  187. package/dist/lib/commands/check-plans.js.map +1 -0
  188. package/dist/lib/commands/config.d.ts +2 -0
  189. package/dist/lib/commands/config.d.ts.map +1 -0
  190. package/dist/lib/commands/config.js +188 -0
  191. package/dist/lib/commands/config.js.map +1 -0
  192. package/dist/lib/commands/dashboard.d.ts +2 -0
  193. package/dist/lib/commands/dashboard.d.ts.map +1 -0
  194. package/dist/lib/commands/dashboard.js +466 -0
  195. package/dist/lib/commands/dashboard.js.map +1 -0
  196. package/dist/lib/commands/estimate.d.ts +2 -0
  197. package/dist/lib/commands/estimate.d.ts.map +1 -0
  198. package/dist/lib/commands/estimate.js +148 -0
  199. package/dist/lib/commands/estimate.js.map +1 -0
  200. package/dist/lib/commands/eval-diff.d.ts +2 -0
  201. package/dist/lib/commands/eval-diff.d.ts.map +1 -0
  202. package/dist/lib/commands/eval-diff.js +213 -0
  203. package/dist/lib/commands/eval-diff.js.map +1 -0
  204. package/dist/lib/commands/freshness.d.ts +2 -0
  205. package/dist/lib/commands/freshness.d.ts.map +1 -0
  206. package/dist/lib/commands/freshness.js +163 -0
  207. package/dist/lib/commands/freshness.js.map +1 -0
  208. package/dist/lib/commands/health.d.ts +2 -0
  209. package/dist/lib/commands/health.d.ts.map +1 -0
  210. package/dist/lib/commands/health.js +435 -0
  211. package/dist/lib/commands/health.js.map +1 -0
  212. package/dist/lib/commands/index.d.ts +2 -0
  213. package/dist/lib/commands/index.d.ts.map +1 -0
  214. package/dist/lib/commands/index.js +128 -0
  215. package/dist/lib/commands/index.js.map +1 -0
  216. package/dist/lib/commands/install.d.ts +56 -0
  217. package/dist/lib/commands/install.d.ts.map +1 -0
  218. package/dist/lib/commands/install.js +214 -0
  219. package/dist/lib/commands/install.js.map +1 -0
  220. package/dist/lib/commands/knowhow-aggregator.d.ts +2 -0
  221. package/dist/lib/commands/knowhow-aggregator.d.ts.map +1 -0
  222. package/dist/lib/commands/knowhow-aggregator.js +279 -0
  223. package/dist/lib/commands/knowhow-aggregator.js.map +1 -0
  224. package/dist/lib/commands/knowledge-search.d.ts +2 -0
  225. package/dist/lib/commands/knowledge-search.d.ts.map +1 -0
  226. package/dist/lib/commands/knowledge-search.js +113 -0
  227. package/dist/lib/commands/knowledge-search.js.map +1 -0
  228. package/dist/lib/commands/long-term-roadmap.d.ts +2 -0
  229. package/dist/lib/commands/long-term-roadmap.d.ts.map +1 -0
  230. package/dist/lib/commands/long-term-roadmap.js +272 -0
  231. package/dist/lib/commands/long-term-roadmap.js.map +1 -0
  232. package/dist/lib/commands/patterns.d.ts +91 -0
  233. package/dist/lib/commands/patterns.d.ts.map +1 -0
  234. package/dist/lib/commands/patterns.js +391 -0
  235. package/dist/lib/commands/patterns.js.map +1 -0
  236. package/dist/lib/commands/phase-info.d.ts +2 -0
  237. package/dist/lib/commands/phase-info.d.ts.map +1 -0
  238. package/dist/lib/commands/phase-info.js +509 -0
  239. package/dist/lib/commands/phase-info.js.map +1 -0
  240. package/dist/lib/commands/plan-lint.d.ts +56 -0
  241. package/dist/lib/commands/plan-lint.d.ts.map +1 -0
  242. package/dist/lib/commands/plan-lint.js +481 -0
  243. package/dist/lib/commands/plan-lint.js.map +1 -0
  244. package/dist/lib/commands/plan-phase.d.ts +53 -0
  245. package/dist/lib/commands/plan-phase.d.ts.map +1 -0
  246. package/dist/lib/commands/plan-phase.js +288 -0
  247. package/dist/lib/commands/plan-phase.js.map +1 -0
  248. package/dist/lib/commands/progress.d.ts +2 -0
  249. package/dist/lib/commands/progress.d.ts.map +1 -0
  250. package/dist/lib/commands/progress.js +266 -0
  251. package/dist/lib/commands/progress.js.map +1 -0
  252. package/dist/lib/commands/quality.d.ts +2 -0
  253. package/dist/lib/commands/quality.d.ts.map +1 -0
  254. package/dist/lib/commands/quality.js +80 -0
  255. package/dist/lib/commands/quality.js.map +1 -0
  256. package/dist/lib/commands/rollback.d.ts +2 -0
  257. package/dist/lib/commands/rollback.d.ts.map +1 -0
  258. package/dist/lib/commands/rollback.js +145 -0
  259. package/dist/lib/commands/rollback.js.map +1 -0
  260. package/dist/lib/commands/scan.d.ts +25 -0
  261. package/dist/lib/commands/scan.d.ts.map +1 -0
  262. package/dist/lib/commands/scan.js +28 -0
  263. package/dist/lib/commands/scan.js.map +1 -0
  264. package/dist/lib/commands/search.d.ts +2 -0
  265. package/dist/lib/commands/search.d.ts.map +1 -0
  266. package/dist/lib/commands/search.js +212 -0
  267. package/dist/lib/commands/search.js.map +1 -0
  268. package/dist/lib/commands/select-candidate.d.ts +128 -0
  269. package/dist/lib/commands/select-candidate.d.ts.map +1 -0
  270. package/dist/lib/commands/select-candidate.js +518 -0
  271. package/dist/lib/commands/select-candidate.js.map +1 -0
  272. package/dist/lib/commands/singularity.d.ts +2 -0
  273. package/dist/lib/commands/singularity.d.ts.map +1 -0
  274. package/dist/lib/commands/singularity.js +185 -0
  275. package/dist/lib/commands/singularity.js.map +1 -0
  276. package/dist/lib/commands/slug-timestamp.d.ts +2 -0
  277. package/dist/lib/commands/slug-timestamp.d.ts.map +1 -0
  278. package/dist/lib/commands/slug-timestamp.js +54 -0
  279. package/dist/lib/commands/slug-timestamp.js.map +1 -0
  280. package/dist/lib/commands/tail.d.ts +2 -0
  281. package/dist/lib/commands/tail.d.ts.map +1 -0
  282. package/dist/lib/commands/tail.js +100 -0
  283. package/dist/lib/commands/tail.js.map +1 -0
  284. package/dist/lib/commands/todo.d.ts +2 -0
  285. package/dist/lib/commands/todo.d.ts.map +1 -0
  286. package/dist/lib/commands/todo.js +200 -0
  287. package/dist/lib/commands/todo.js.map +1 -0
  288. package/dist/lib/commands/watch.d.ts +2 -0
  289. package/dist/lib/commands/watch.d.ts.map +1 -0
  290. package/dist/lib/commands/watch.js +72 -0
  291. package/dist/lib/commands/watch.js.map +1 -0
  292. package/dist/lib/complexity.d.ts +55 -0
  293. package/dist/lib/complexity.d.ts.map +1 -0
  294. package/dist/lib/complexity.js +80 -0
  295. package/dist/lib/complexity.js.map +1 -0
  296. package/dist/lib/context/agents.d.ts +2 -0
  297. package/dist/lib/context/agents.d.ts.map +1 -0
  298. package/dist/lib/context/agents.js +344 -0
  299. package/dist/lib/context/agents.js.map +1 -0
  300. package/dist/lib/context/base.d.ts +2 -0
  301. package/dist/lib/context/base.d.ts.map +1 -0
  302. package/dist/lib/context/base.js +81 -0
  303. package/dist/lib/context/base.js.map +1 -0
  304. package/dist/lib/context/execute.d.ts +2 -0
  305. package/dist/lib/context/execute.d.ts.map +1 -0
  306. package/dist/lib/context/execute.js +753 -0
  307. package/dist/lib/context/execute.js.map +1 -0
  308. package/dist/lib/context/index.d.ts +2 -0
  309. package/dist/lib/context/index.d.ts.map +1 -0
  310. package/dist/lib/context/index.js +88 -0
  311. package/dist/lib/context/index.js.map +1 -0
  312. package/dist/lib/context/progress.d.ts +2 -0
  313. package/dist/lib/context/progress.d.ts.map +1 -0
  314. package/dist/lib/context/progress.js +178 -0
  315. package/dist/lib/context/progress.js.map +1 -0
  316. package/dist/lib/context/project.d.ts +2 -0
  317. package/dist/lib/context/project.d.ts.map +1 -0
  318. package/dist/lib/context/project.js +413 -0
  319. package/dist/lib/context/project.js.map +1 -0
  320. package/dist/lib/context/research.d.ts +2 -0
  321. package/dist/lib/context/research.d.ts.map +1 -0
  322. package/dist/lib/context/research.js +466 -0
  323. package/dist/lib/context/research.js.map +1 -0
  324. package/dist/lib/dead-ends.d.ts +28 -0
  325. package/dist/lib/dead-ends.d.ts.map +1 -0
  326. package/dist/lib/dead-ends.js +451 -0
  327. package/dist/lib/dead-ends.js.map +1 -0
  328. package/dist/lib/deps.d.ts +2 -0
  329. package/dist/lib/deps.d.ts.map +1 -0
  330. package/dist/lib/deps.js +630 -0
  331. package/dist/lib/deps.js.map +1 -0
  332. package/dist/lib/discussion.d.ts +2 -0
  333. package/dist/lib/discussion.d.ts.map +1 -0
  334. package/dist/lib/discussion.js +1041 -0
  335. package/dist/lib/discussion.js.map +1 -0
  336. package/dist/lib/drift.d.ts +36 -0
  337. package/dist/lib/drift.d.ts.map +1 -0
  338. package/dist/lib/drift.js +481 -0
  339. package/dist/lib/drift.js.map +1 -0
  340. package/dist/lib/evolve/_dimensions-features.d.ts +2 -0
  341. package/dist/lib/evolve/_dimensions-features.d.ts.map +1 -0
  342. package/dist/lib/evolve/_dimensions-features.js +369 -0
  343. package/dist/lib/evolve/_dimensions-features.js.map +1 -0
  344. package/dist/lib/evolve/_dimensions.d.ts +2 -0
  345. package/dist/lib/evolve/_dimensions.d.ts.map +1 -0
  346. package/dist/lib/evolve/_dimensions.js +358 -0
  347. package/dist/lib/evolve/_dimensions.js.map +1 -0
  348. package/dist/lib/evolve/_product-ideation.d.ts +2 -0
  349. package/dist/lib/evolve/_product-ideation.d.ts.map +1 -0
  350. package/dist/lib/evolve/_product-ideation.js +281 -0
  351. package/dist/lib/evolve/_product-ideation.js.map +1 -0
  352. package/dist/lib/evolve/_prompts.d.ts +2 -0
  353. package/dist/lib/evolve/_prompts.d.ts.map +1 -0
  354. package/dist/lib/evolve/_prompts.js +153 -0
  355. package/dist/lib/evolve/_prompts.js.map +1 -0
  356. package/dist/lib/evolve/cli.d.ts +2 -0
  357. package/dist/lib/evolve/cli.d.ts.map +1 -0
  358. package/dist/lib/evolve/cli.js +224 -0
  359. package/dist/lib/evolve/cli.js.map +1 -0
  360. package/dist/lib/evolve/discovery.d.ts +2 -0
  361. package/dist/lib/evolve/discovery.d.ts.map +1 -0
  362. package/dist/lib/evolve/discovery.js +391 -0
  363. package/dist/lib/evolve/discovery.js.map +1 -0
  364. package/dist/lib/evolve/index.d.ts +2 -0
  365. package/dist/lib/evolve/index.d.ts.map +1 -0
  366. package/dist/lib/evolve/index.js +88 -0
  367. package/dist/lib/evolve/index.js.map +1 -0
  368. package/dist/lib/evolve/orchestrator.d.ts +2 -0
  369. package/dist/lib/evolve/orchestrator.d.ts.map +1 -0
  370. package/dist/lib/evolve/orchestrator.js +851 -0
  371. package/dist/lib/evolve/orchestrator.js.map +1 -0
  372. package/dist/lib/evolve/scoring.d.ts +2 -0
  373. package/dist/lib/evolve/scoring.d.ts.map +1 -0
  374. package/dist/lib/evolve/scoring.js +118 -0
  375. package/dist/lib/evolve/scoring.js.map +1 -0
  376. package/dist/lib/evolve/state.d.ts +2 -0
  377. package/dist/lib/evolve/state.d.ts.map +1 -0
  378. package/dist/lib/evolve/state.js +264 -0
  379. package/dist/lib/evolve/state.js.map +1 -0
  380. package/dist/lib/evolve/types.d.ts +249 -0
  381. package/dist/lib/evolve/types.d.ts.map +1 -0
  382. package/dist/lib/evolve/types.js +3 -0
  383. package/dist/lib/evolve/types.js.map +1 -0
  384. package/dist/lib/frontmatter.d.ts +2 -0
  385. package/dist/lib/frontmatter.d.ts.map +1 -0
  386. package/dist/lib/frontmatter.js +513 -0
  387. package/dist/lib/frontmatter.js.map +1 -0
  388. package/dist/lib/gates.d.ts +2 -0
  389. package/dist/lib/gates.d.ts.map +1 -0
  390. package/dist/lib/gates.js +578 -0
  391. package/dist/lib/gates.js.map +1 -0
  392. package/dist/lib/genome.d.ts +10 -0
  393. package/dist/lib/genome.d.ts.map +1 -0
  394. package/dist/lib/genome.js +368 -0
  395. package/dist/lib/genome.js.map +1 -0
  396. package/dist/lib/got.d.ts +2 -0
  397. package/dist/lib/got.d.ts.map +1 -0
  398. package/dist/lib/got.js +280 -0
  399. package/dist/lib/got.js.map +1 -0
  400. package/dist/lib/invariants.d.ts +2 -0
  401. package/dist/lib/invariants.d.ts.map +1 -0
  402. package/dist/lib/invariants.js +298 -0
  403. package/dist/lib/invariants.js.map +1 -0
  404. package/dist/lib/knowledge.d.ts +2 -0
  405. package/dist/lib/knowledge.d.ts.map +1 -0
  406. package/dist/lib/knowledge.js +658 -0
  407. package/dist/lib/knowledge.js.map +1 -0
  408. package/dist/lib/long-term-roadmap.d.ts +2 -0
  409. package/dist/lib/long-term-roadmap.d.ts.map +1 -0
  410. package/dist/lib/long-term-roadmap.js +602 -0
  411. package/dist/lib/long-term-roadmap.js.map +1 -0
  412. package/dist/lib/markdown-split.d.ts +2 -0
  413. package/dist/lib/markdown-split.d.ts.map +1 -0
  414. package/dist/lib/markdown-split.js +199 -0
  415. package/dist/lib/markdown-split.js.map +1 -0
  416. package/dist/lib/mcp-server.d.ts +2 -0
  417. package/dist/lib/mcp-server.d.ts.map +1 -0
  418. package/dist/lib/mcp-server.js +2424 -0
  419. package/dist/lib/mcp-server.js.map +1 -0
  420. package/dist/lib/metrics.d.ts +16 -0
  421. package/dist/lib/metrics.d.ts.map +1 -0
  422. package/dist/lib/metrics.js +48 -0
  423. package/dist/lib/metrics.js.map +1 -0
  424. package/dist/lib/overstory.d.ts +2 -0
  425. package/dist/lib/overstory.d.ts.map +1 -0
  426. package/dist/lib/overstory.js +211 -0
  427. package/dist/lib/overstory.js.map +1 -0
  428. package/dist/lib/parallel.d.ts +2 -0
  429. package/dist/lib/parallel.d.ts.map +1 -0
  430. package/dist/lib/parallel.js +349 -0
  431. package/dist/lib/parallel.js.map +1 -0
  432. package/dist/lib/paths.d.ts +2 -0
  433. package/dist/lib/paths.d.ts.map +1 -0
  434. package/dist/lib/paths.js +254 -0
  435. package/dist/lib/paths.js.map +1 -0
  436. package/dist/lib/phase-complete-llm.d.ts +22 -0
  437. package/dist/lib/phase-complete-llm.d.ts.map +1 -0
  438. package/dist/lib/phase-complete-llm.js +331 -0
  439. package/dist/lib/phase-complete-llm.js.map +1 -0
  440. package/dist/lib/phase-complete.d.ts +46 -0
  441. package/dist/lib/phase-complete.d.ts.map +1 -0
  442. package/dist/lib/phase-complete.js +278 -0
  443. package/dist/lib/phase-complete.js.map +1 -0
  444. package/dist/lib/phase-io.d.ts +2 -0
  445. package/dist/lib/phase-io.d.ts.map +1 -0
  446. package/dist/lib/phase-io.js +126 -0
  447. package/dist/lib/phase-io.js.map +1 -0
  448. package/dist/lib/phase.d.ts +2 -0
  449. package/dist/lib/phase.d.ts.map +1 -0
  450. package/dist/lib/phase.js +1344 -0
  451. package/dist/lib/phase.js.map +1 -0
  452. package/dist/lib/plan-tournament.d.ts +63 -0
  453. package/dist/lib/plan-tournament.d.ts.map +1 -0
  454. package/dist/lib/plan-tournament.js +353 -0
  455. package/dist/lib/plan-tournament.js.map +1 -0
  456. package/dist/lib/refinement.d.ts +74 -0
  457. package/dist/lib/refinement.d.ts.map +1 -0
  458. package/dist/lib/refinement.js +283 -0
  459. package/dist/lib/refinement.js.map +1 -0
  460. package/dist/lib/requirements.d.ts +2 -0
  461. package/dist/lib/requirements.d.ts.map +1 -0
  462. package/dist/lib/requirements.js +355 -0
  463. package/dist/lib/requirements.js.map +1 -0
  464. package/dist/lib/research-bundle.d.ts +2 -0
  465. package/dist/lib/research-bundle.d.ts.map +1 -0
  466. package/dist/lib/research-bundle.js +246 -0
  467. package/dist/lib/research-bundle.js.map +1 -0
  468. package/dist/lib/roadmap.d.ts +2 -0
  469. package/dist/lib/roadmap.d.ts.map +1 -0
  470. package/dist/lib/roadmap.js +541 -0
  471. package/dist/lib/roadmap.js.map +1 -0
  472. package/dist/lib/sample.d.ts +16 -0
  473. package/dist/lib/sample.d.ts.map +1 -0
  474. package/dist/lib/sample.js +20 -0
  475. package/dist/lib/sample.js.map +1 -0
  476. package/dist/lib/scaffold.d.ts +2 -0
  477. package/dist/lib/scaffold.d.ts.map +1 -0
  478. package/dist/lib/scaffold.js +355 -0
  479. package/dist/lib/scaffold.js.map +1 -0
  480. package/dist/lib/scan/_utils.d.ts +11 -0
  481. package/dist/lib/scan/_utils.d.ts.map +1 -0
  482. package/dist/lib/scan/_utils.js +36 -0
  483. package/dist/lib/scan/_utils.js.map +1 -0
  484. package/dist/lib/scan/base64.d.ts +15 -0
  485. package/dist/lib/scan/base64.d.ts.map +1 -0
  486. package/dist/lib/scan/base64.js +66 -0
  487. package/dist/lib/scan/base64.js.map +1 -0
  488. package/dist/lib/scan/ignorefile.d.ts +30 -0
  489. package/dist/lib/scan/ignorefile.d.ts.map +1 -0
  490. package/dist/lib/scan/ignorefile.js +101 -0
  491. package/dist/lib/scan/ignorefile.js.map +1 -0
  492. package/dist/lib/scan/injection.d.ts +14 -0
  493. package/dist/lib/scan/injection.d.ts.map +1 -0
  494. package/dist/lib/scan/injection.js +39 -0
  495. package/dist/lib/scan/injection.js.map +1 -0
  496. package/dist/lib/scan/patterns.d.ts +17 -0
  497. package/dist/lib/scan/patterns.d.ts.map +1 -0
  498. package/dist/lib/scan/patterns.js +123 -0
  499. package/dist/lib/scan/patterns.js.map +1 -0
  500. package/dist/lib/scan/strip-markdown.d.ts +7 -0
  501. package/dist/lib/scan/strip-markdown.d.ts.map +1 -0
  502. package/dist/lib/scan/strip-markdown.js +38 -0
  503. package/dist/lib/scan/strip-markdown.js.map +1 -0
  504. package/dist/lib/scan/types.d.ts +23 -0
  505. package/dist/lib/scan/types.d.ts.map +1 -0
  506. package/dist/lib/scan/types.js +3 -0
  507. package/dist/lib/scan/types.js.map +1 -0
  508. package/dist/lib/scheduler-wait.d.ts +2 -0
  509. package/dist/lib/scheduler-wait.d.ts.map +1 -0
  510. package/dist/lib/scheduler-wait.js +59 -0
  511. package/dist/lib/scheduler-wait.js.map +1 -0
  512. package/dist/lib/scheduler.d.ts +254 -0
  513. package/dist/lib/scheduler.d.ts.map +1 -0
  514. package/dist/lib/scheduler.js +1147 -0
  515. package/dist/lib/scheduler.js.map +1 -0
  516. package/dist/lib/state.d.ts +2 -0
  517. package/dist/lib/state.d.ts.map +1 -0
  518. package/dist/lib/state.js +744 -0
  519. package/dist/lib/state.js.map +1 -0
  520. package/dist/lib/think.d.ts +18 -0
  521. package/dist/lib/think.d.ts.map +1 -0
  522. package/dist/lib/think.js +317 -0
  523. package/dist/lib/think.js.map +1 -0
  524. package/dist/lib/tracker.d.ts +2 -0
  525. package/dist/lib/tracker.d.ts.map +1 -0
  526. package/dist/lib/tracker.js +1121 -0
  527. package/dist/lib/tracker.js.map +1 -0
  528. package/dist/lib/types.d.ts +1514 -0
  529. package/dist/lib/types.d.ts.map +1 -0
  530. package/dist/lib/types.js +4 -0
  531. package/dist/lib/types.js.map +1 -0
  532. package/dist/lib/utils.d.ts +2 -0
  533. package/dist/lib/utils.d.ts.map +1 -0
  534. package/dist/lib/utils.js +1363 -0
  535. package/dist/lib/utils.js.map +1 -0
  536. package/dist/lib/verify.d.ts +2 -0
  537. package/dist/lib/verify.d.ts.map +1 -0
  538. package/dist/lib/verify.js +1153 -0
  539. package/dist/lib/verify.js.map +1 -0
  540. package/dist/lib/wireup/autofix.d.ts +2 -0
  541. package/dist/lib/wireup/autofix.d.ts.map +1 -0
  542. package/dist/lib/wireup/autofix.js +188 -0
  543. package/dist/lib/wireup/autofix.js.map +1 -0
  544. package/dist/lib/wireup/cli.d.ts +2 -0
  545. package/dist/lib/wireup/cli.d.ts.map +1 -0
  546. package/dist/lib/wireup/cli.js +194 -0
  547. package/dist/lib/wireup/cli.js.map +1 -0
  548. package/dist/lib/wireup/detection.d.ts +47 -0
  549. package/dist/lib/wireup/detection.d.ts.map +1 -0
  550. package/dist/lib/wireup/detection.js +410 -0
  551. package/dist/lib/wireup/detection.js.map +1 -0
  552. package/dist/lib/wireup/discovery.d.ts +2 -0
  553. package/dist/lib/wireup/discovery.d.ts.map +1 -0
  554. package/dist/lib/wireup/discovery.js +934 -0
  555. package/dist/lib/wireup/discovery.js.map +1 -0
  556. package/dist/lib/wireup/execution.d.ts +2 -0
  557. package/dist/lib/wireup/execution.d.ts.map +1 -0
  558. package/dist/lib/wireup/execution.js +573 -0
  559. package/dist/lib/wireup/execution.js.map +1 -0
  560. package/dist/lib/wireup/index.d.ts +2 -0
  561. package/dist/lib/wireup/index.d.ts.map +1 -0
  562. package/dist/lib/wireup/index.js +85 -0
  563. package/dist/lib/wireup/index.js.map +1 -0
  564. package/dist/lib/wireup/orchestrator.d.ts +2 -0
  565. package/dist/lib/wireup/orchestrator.d.ts.map +1 -0
  566. package/dist/lib/wireup/orchestrator.js +366 -0
  567. package/dist/lib/wireup/orchestrator.js.map +1 -0
  568. package/dist/lib/wireup/report.d.ts +47 -0
  569. package/dist/lib/wireup/report.d.ts.map +1 -0
  570. package/dist/lib/wireup/report.js +201 -0
  571. package/dist/lib/wireup/report.js.map +1 -0
  572. package/dist/lib/wireup/scenarios.d.ts +2 -0
  573. package/dist/lib/wireup/scenarios.d.ts.map +1 -0
  574. package/dist/lib/wireup/scenarios.js +516 -0
  575. package/dist/lib/wireup/scenarios.js.map +1 -0
  576. package/dist/lib/wireup/state.d.ts +2 -0
  577. package/dist/lib/wireup/state.d.ts.map +1 -0
  578. package/dist/lib/wireup/state.js +102 -0
  579. package/dist/lib/wireup/state.js.map +1 -0
  580. package/dist/lib/wireup/types.d.ts +376 -0
  581. package/dist/lib/wireup/types.d.ts.map +1 -0
  582. package/dist/lib/wireup/types.js +3 -0
  583. package/dist/lib/wireup/types.js.map +1 -0
  584. package/dist/lib/worktree.d.ts +2 -0
  585. package/dist/lib/worktree.d.ts.map +1 -0
  586. package/dist/lib/worktree.js +999 -0
  587. package/dist/lib/worktree.js.map +1 -0
  588. package/lib/autopilot-milestone.ts +136 -0
  589. package/lib/autopilot-pipeline.ts +1179 -0
  590. package/lib/autopilot-waves.ts +361 -0
  591. package/lib/autopilot.ts +1874 -0
  592. package/lib/autoplan.ts +280 -0
  593. package/lib/autoresearch.js +4 -0
  594. package/lib/autoresearch.ts +886 -0
  595. package/lib/backend.ts +1252 -0
  596. package/lib/benchmark.ts +341 -0
  597. package/lib/citations.ts +760 -0
  598. package/lib/cleanup.ts +1588 -0
  599. package/lib/cli/adapters.ts +41 -0
  600. package/lib/cli/agent.ts +83 -0
  601. package/lib/cli/index.ts +273 -0
  602. package/lib/cli/output.ts +33 -0
  603. package/lib/cli/scan-dispatch.ts +130 -0
  604. package/lib/cli/tools.ts +198 -0
  605. package/lib/commands/_dashboard-parsers.ts +275 -0
  606. package/lib/commands/analysis.ts +1851 -0
  607. package/lib/commands/assumptions.ts +232 -0
  608. package/lib/commands/blame.ts +174 -0
  609. package/lib/commands/budget.ts +148 -0
  610. package/lib/commands/check-plans.ts +233 -0
  611. package/lib/commands/config.ts +287 -0
  612. package/lib/commands/dashboard.ts +680 -0
  613. package/lib/commands/estimate.ts +204 -0
  614. package/lib/commands/eval-diff.ts +252 -0
  615. package/lib/commands/freshness.ts +213 -0
  616. package/lib/commands/health.ts +607 -0
  617. package/lib/commands/index.ts +266 -0
  618. package/lib/commands/install.ts +307 -0
  619. package/lib/commands/knowhow-aggregator.ts +345 -0
  620. package/lib/commands/knowledge-search.ts +153 -0
  621. package/lib/commands/long-term-roadmap.ts +390 -0
  622. package/lib/commands/patterns.ts +465 -0
  623. package/lib/commands/phase-info.ts +698 -0
  624. package/lib/commands/plan-lint.ts +546 -0
  625. package/lib/commands/plan-phase.ts +375 -0
  626. package/lib/commands/progress.ts +319 -0
  627. package/lib/commands/quality.ts +138 -0
  628. package/lib/commands/rollback.ts +195 -0
  629. package/lib/commands/scan.ts +72 -0
  630. package/lib/commands/search.ts +300 -0
  631. package/lib/commands/select-candidate.ts +687 -0
  632. package/lib/commands/singularity.ts +222 -0
  633. package/lib/commands/slug-timestamp.ts +74 -0
  634. package/lib/commands/tail.ts +129 -0
  635. package/lib/commands/todo.ts +273 -0
  636. package/lib/commands/watch.ts +80 -0
  637. package/lib/complexity.ts +117 -0
  638. package/lib/context/agents.ts +505 -0
  639. package/lib/context/base.ts +123 -0
  640. package/lib/context/execute.ts +977 -0
  641. package/lib/context/index.ts +110 -0
  642. package/lib/context/progress.ts +278 -0
  643. package/lib/context/project.ts +531 -0
  644. package/lib/context/research.ts +646 -0
  645. package/lib/dead-ends.ts +506 -0
  646. package/lib/deps.ts +773 -0
  647. package/lib/discussion.ts +1275 -0
  648. package/lib/drift.ts +519 -0
  649. package/lib/evolve/_dimensions-features.ts +525 -0
  650. package/lib/evolve/_dimensions.ts +511 -0
  651. package/lib/evolve/_product-ideation.ts +405 -0
  652. package/lib/evolve/_prompts.ts +178 -0
  653. package/lib/evolve/cli.ts +330 -0
  654. package/lib/evolve/discovery.ts +571 -0
  655. package/lib/evolve/index.ts +105 -0
  656. package/lib/evolve/orchestrator.ts +1139 -0
  657. package/lib/evolve/scoring.ts +167 -0
  658. package/lib/evolve/state.ts +330 -0
  659. package/lib/evolve/types.ts +290 -0
  660. package/lib/frontmatter.ts +615 -0
  661. package/lib/gates.ts +695 -0
  662. package/lib/genome.ts +402 -0
  663. package/lib/got.js +4 -0
  664. package/lib/got.ts +361 -0
  665. package/lib/invariants.ts +378 -0
  666. package/lib/knowledge.ts +768 -0
  667. package/lib/long-term-roadmap.ts +806 -0
  668. package/lib/markdown-split.ts +273 -0
  669. package/lib/mcp-server.ts +3292 -0
  670. package/lib/metrics.ts +49 -0
  671. package/lib/overstory.ts +270 -0
  672. package/lib/parallel.ts +570 -0
  673. package/lib/paths.ts +293 -0
  674. package/lib/phase-complete-llm.ts +376 -0
  675. package/lib/phase-complete.ts +366 -0
  676. package/lib/phase-io.ts +101 -0
  677. package/lib/phase.ts +1981 -0
  678. package/lib/plan-tournament.ts +426 -0
  679. package/lib/refinement.ts +349 -0
  680. package/lib/requirements.ts +469 -0
  681. package/lib/research-bundle.ts +300 -0
  682. package/lib/roadmap.ts +775 -0
  683. package/lib/scaffold.ts +480 -0
  684. package/lib/scan/_utils.ts +37 -0
  685. package/lib/scan/base64.ts +90 -0
  686. package/lib/scan/ignorefile.ts +109 -0
  687. package/lib/scan/injection.ts +67 -0
  688. package/lib/scan/patterns.ts +139 -0
  689. package/lib/scan/strip-markdown.ts +39 -0
  690. package/lib/scan/types.ts +28 -0
  691. package/lib/scheduler-wait.ts +58 -0
  692. package/lib/scheduler.ts +1370 -0
  693. package/lib/state.ts +1000 -0
  694. package/lib/think.ts +365 -0
  695. package/lib/tracker.ts +1591 -0
  696. package/lib/types.ts +1663 -0
  697. package/lib/utils.ts +1479 -0
  698. package/lib/verify.ts +1434 -0
  699. package/lib/wireup/autofix.ts +241 -0
  700. package/lib/wireup/cli.ts +278 -0
  701. package/lib/wireup/detection.ts +542 -0
  702. package/lib/wireup/discovery.ts +1063 -0
  703. package/lib/wireup/execution.ts +686 -0
  704. package/lib/wireup/index.ts +117 -0
  705. package/lib/wireup/orchestrator.ts +519 -0
  706. package/lib/wireup/report.ts +286 -0
  707. package/lib/wireup/scenarios.ts +616 -0
  708. package/lib/wireup/state.ts +139 -0
  709. package/lib/wireup/types.ts +436 -0
  710. package/lib/worktree.ts +1309 -0
  711. package/package.json +67 -0
@@ -0,0 +1,624 @@
1
+ ---
2
+ name: grd-feasibility-analyst
3
+ description: Analyzes paper-to-production gap. Assesses whether a research method can be integrated into the current system considering dependencies, scale, infrastructure, licensing, and codebase constraints.
4
+ tools: Read, Write, Bash, Grep, Glob, WebSearch, WebFetch
5
+ color: yellow
6
+ effort: medium
7
+ ---
8
+
9
+ <role>
10
+ You are a GRD feasibility analyst. You answer the critical question: "Can we actually use this in our system?"
11
+
12
+ Spawned by:
13
+ - `/grd:feasibility` workflow (standalone feasibility check)
14
+ - `/grd:plan-phase` workflow (when phase involves integrating research)
15
+ - `/grd:product-plan` workflow (when product owner needs integration assessment)
16
+
17
+ Your job: Bridge the gap between research papers and production systems. Analyze dependency conflicts, scale requirements, infrastructure needs, licensing implications, and integration difficulty. Produce actionable feasibility reports that prevent wasted integration effort.
18
+
19
+ **Core responsibilities:**
20
+ - Read the paper's deep-dive document (or create quick analysis if none exists)
21
+ - Read current codebase structure, dependencies, and constraints
22
+ - Analyze dependency conflicts and compatibility
23
+ - Assess scale requirements vs. available infrastructure
24
+ - Evaluate licensing implications
25
+ - Estimate integration difficulty (1-5 scale)
26
+ - Document findings in KNOWHOW.md
27
+ - Return structured feasibility verdict
28
+ </role>
29
+
30
+ <naming_convention>
31
+ ALL generated markdown files MUST use UPPERCASE filenames. This applies to every .md file written into .planning/ or any subdirectory:
32
+ - Standard files: STATE.md, ROADMAP.md, REQUIREMENTS.md, PLAN.md, SUMMARY.md, VERIFICATION.md, EVAL.md, REVIEW.md, CONTEXT.md, RESEARCH.md, BASELINE.md
33
+ - Slug-based files: use UPPERCASE slugs — e.g., VASWANI-ATTENTION-2017.md, not vaswani-attention-2017.md
34
+ - Feasibility files: {METHOD-SLUG}-FEASIBILITY.md
35
+ - Todo files: {DATE}-{SLUG}.md (date lowercase ok, slug UPPERCASE)
36
+ - Handoff files: .CONTINUE-HERE.md
37
+ - Quick task summaries: {N}-SUMMARY.md
38
+ Never create lowercase .md filenames in .planning/.
39
+ </naming_convention>
40
+
41
+ <philosophy>
42
+
43
+ ## The Paper-Production Gap Is Always Larger Than Expected
44
+
45
+ Papers optimize for benchmarks. Production optimizes for reliability, maintainability, and cost. Every paper-to-production integration encounters friction that wasn't visible in the paper:
46
+ - Training on 8x A100 -> deploying on 1x T4
47
+ - Evaluated on curated datasets -> receiving arbitrary user input
48
+ - Tested in isolation -> integrated with existing pipeline
49
+ - Python prototype -> production service with SLAs
50
+
51
+ Your job is to enumerate this friction BEFORE integration begins.
52
+
53
+ ## Blockers Are Not Problems
54
+
55
+ A blocker means "stop, this won't work as-is." A problem means "this is hard but solvable." Conflating the two wastes time:
56
+ - GPL license on code we need to ship commercially → BLOCKER
57
+ - Requires CUDA 12.0 but our cluster runs 11.8 → PROBLEM (upgrade path exists)
58
+ - Needs 80GB VRAM for training → PROBLEM if we have A100s, BLOCKER if we only have T4s
59
+
60
+ Be precise about which category each issue falls into.
61
+
62
+ ## Integration Difficulty Is Not Code Difficulty
63
+
64
+ Writing the code might be easy. Getting it to work in the existing system is the hard part:
65
+ - Code changes: 200 lines (easy)
66
+ - Dependency conflicts: 3 packages need downgrading (medium)
67
+ - Data pipeline changes: New preprocessing required (hard)
68
+ - Infrastructure changes: New GPU type needed (blocker)
69
+
70
+ Assess the FULL integration picture, not just the code diff.
71
+
72
+ ## Document Knowledge, Not Just Decisions
73
+
74
+ KNOWHOW.md captures institutional knowledge about what works, what doesn't, and why. This knowledge persists across phases and prevents the same mistakes from being made twice.
75
+
76
+ </philosophy>
77
+
78
+ <execution_flow>
79
+
80
+ <step name="identify_target" priority="first">
81
+ Identify the method/paper being assessed.
82
+
83
+ **From user prompt, extract:**
84
+ - Method name or paper title
85
+ - Specific aspects to assess (if provided)
86
+ - Integration target (where in our system this would go)
87
+
88
+ **Find the deep-dive document:**
89
+ ```bash
90
+ ls ${research_dir}/deep-dives/*.md 2>/dev/null
91
+ cat ${research_dir}/PAPERS.md 2>/dev/null
92
+ ```
93
+
94
+ If deep-dive exists, read it:
95
+ ```bash
96
+ cat ${research_dir}/deep-dives/{paper-slug}.md
97
+ ```
98
+
99
+ If no deep-dive exists:
100
+ - Perform quick analysis (abbreviated deep-dive focusing on method, dependencies, and license)
101
+ - Note that full deep-dive is recommended for completeness
102
+ - Proceed with available information
103
+ </step>
104
+
105
+ <step name="analyze_codebase">
106
+ Understand the current codebase structure and constraints.
107
+
108
+ **Read project context:**
109
+ ```bash
110
+ cat .planning/PROJECT.md 2>/dev/null
111
+ cat .planning/BASELINE.md 2>/dev/null
112
+ cat ${codebase_dir}/STACK.md 2>/dev/null
113
+ cat ${codebase_dir}/ARCHITECTURE.md 2>/dev/null
114
+ cat ${codebase_dir}/INTEGRATIONS.md 2>/dev/null
115
+ cat ${codebase_dir}/CONCERNS.md 2>/dev/null
116
+ ```
117
+
118
+ **Analyze current dependencies:**
119
+ ```bash
120
+ # Python projects
121
+ cat requirements.txt 2>/dev/null
122
+ cat setup.py 2>/dev/null
123
+ cat pyproject.toml 2>/dev/null
124
+ cat Pipfile 2>/dev/null
125
+ pip list 2>/dev/null | head -50
126
+
127
+ # Node projects
128
+ cat package.json 2>/dev/null
129
+
130
+ # System dependencies
131
+ python --version 2>/dev/null
132
+ nvcc --version 2>/dev/null
133
+ nvidia-smi 2>/dev/null | head -5
134
+ ```
135
+
136
+ **Understand current pipeline structure:**
137
+ ```bash
138
+ # Find entry points and pipeline files
139
+ ls src/ 2>/dev/null
140
+ ls scripts/ 2>/dev/null
141
+ ```
142
+
143
+ Use Grep to find relevant patterns:
144
+ ```
145
+ Grep: "import torch|import tensorflow|import jax" → understand ML framework in use
146
+ Grep: "cuda|gpu|device" → understand GPU usage patterns
147
+ Grep: "def train|def inference|def predict" → understand pipeline structure
148
+ ```
149
+
150
+ Record:
151
+ - ML framework and version (PyTorch, TF, JAX)
152
+ - CUDA version
153
+ - GPU type and count available
154
+ - Python version
155
+ - Key dependencies and their versions
156
+ - Pipeline architecture (how data flows through the system)
157
+ - Current model serving approach
158
+ </step>
159
+
160
+ <step name="analyze_dependencies">
161
+ Compare method dependencies against current system.
162
+
163
+ **Dependency conflict analysis:**
164
+
165
+ | Dependency | Method Requires | We Have | Status |
166
+ |-----------|----------------|---------|--------|
167
+ | Python | [version] | [version] | [Compatible/Conflict] |
168
+ | CUDA | [version] | [version] | [Compatible/Conflict] |
169
+ | PyTorch | [version] | [version] | [Compatible/Conflict] |
170
+ | [package] | [version] | [version or N/A] | [Compatible/New/Conflict] |
171
+
172
+ **For each conflict, assess:**
173
+ - Can we upgrade without breaking existing code?
174
+ - Is a virtual environment / container sufficient?
175
+ - Are there version-compatible alternatives?
176
+ - Is the conflict fundamental (e.g., PyTorch vs TensorFlow)?
177
+
178
+ **Custom operators:**
179
+ - Does the method require custom CUDA kernels?
180
+ - Can they be compiled on our system?
181
+ - Are there pure-Python fallbacks?
182
+
183
+ **New dependencies:**
184
+ - How many new packages would be added?
185
+ - Do any have restrictive licenses?
186
+ - Are they well-maintained?
187
+ </step>
188
+
189
+ <step name="analyze_scale">
190
+ Assess scale requirements vs. available infrastructure.
191
+
192
+ **Training requirements:**
193
+ | Resource | Method Needs | We Have | Feasible |
194
+ |----------|-------------|---------|----------|
195
+ | GPU VRAM | [size] | [size] | [Yes/No/With changes] |
196
+ | GPU count | [count] | [count] | [Yes/No] |
197
+ | GPU type | [A100/V100/etc.] | [type] | [Compatible/Need upgrade] |
198
+ | Training time | [hours/days] | [budget] | [Within budget/Over budget] |
199
+ | Training data | [size/type] | [available] | [Sufficient/Need more] |
200
+ | Storage | [TB] | [available] | [Sufficient/Need more] |
201
+
202
+ **Inference requirements:**
203
+ | Resource | Method Needs | We Have | Feasible |
204
+ |----------|-------------|---------|----------|
205
+ | GPU VRAM | [size] | [size] | [Yes/No] |
206
+ | Latency | [ms/sample] | [target] | [Meets target/Too slow] |
207
+ | Throughput | [samples/sec] | [target] | [Meets target/Too low] |
208
+ | Batch size | [optimal] | [supportable] | [OK/Constrained] |
209
+
210
+ **Scaling considerations:**
211
+ - How does memory scale with input size? (linear, quadratic, etc.)
212
+ - Can inference be parallelized across GPUs?
213
+ - Does the method support mixed precision (FP16/BF16)?
214
+ - Does model distillation / quantization work for this architecture?
215
+ </step>
216
+
217
+ <step name="analyze_infrastructure">
218
+ Assess infrastructure and operational requirements.
219
+
220
+ **Questions to answer:**
221
+ 1. Does this method require new infrastructure we don't have?
222
+ 2. Does it require changes to our deployment pipeline?
223
+ 3. Does it require a different serving framework?
224
+ 4. Does it have runtime external dependencies (API calls, data downloads)?
225
+ 5. Does it require specific OS or platform features?
226
+ 6. How does it affect our CI/CD pipeline?
227
+ 7. What monitoring/observability does it need?
228
+ 8. How does it affect our backup/recovery strategy?
229
+
230
+ **Operational considerations:**
231
+ - Model size (disk space for weights)
232
+ - Startup time (model loading)
233
+ - Warm-up requirements
234
+ - Failure modes and recovery
235
+ - Update/rollback strategy
236
+ </step>
237
+
238
+ <step name="analyze_licensing">
239
+ Assess licensing implications.
240
+
241
+ **Check all relevant licenses:**
242
+ - Code repository license
243
+ - Model weights license (may differ)
244
+ - Training data license implications
245
+ - Dependency licenses (transitive)
246
+
247
+ **License compatibility matrix:**
248
+
249
+ | Component | License | Commercial Use | Copyleft | Compatible |
250
+ |-----------|---------|----------------|----------|------------|
251
+ | [code] | [license] | [Yes/No] | [Yes/No] | [Yes/No/Check] |
252
+ | [weights] | [license] | [Yes/No] | [Yes/No] | [Yes/No/Check] |
253
+ | [key dep] | [license] | [Yes/No] | [Yes/No] | [Yes/No/Check] |
254
+
255
+ **Key questions:**
256
+ - Can we use this in our commercial product?
257
+ - Do we need to open-source our changes?
258
+ - Are there attribution requirements?
259
+ - Are model weights shareable?
260
+ - What about derived models (fine-tuned from their weights)?
261
+ </step>
262
+
263
+ <step name="assess_integration_difficulty">
264
+ Rate integration difficulty on 1-5 scale.
265
+
266
+ **Scoring rubric:**
267
+
268
+ | Score | Label | Criteria |
269
+ |-------|-------|----------|
270
+ | 1 | Drop-in | pip install and import. No conflicts, no infra changes, API-compatible |
271
+ | 2 | Easy | Minor changes: config updates, small wrapper code, compatible dependencies |
272
+ | 3 | Moderate | Meaningful work: new preprocessing, dependency resolution, pipeline changes |
273
+ | 4 | Hard | Significant effort: custom integration layer, infra changes, data pipeline rework |
274
+ | 5 | Overhaul | Major restructuring: framework migration, architecture changes, new infrastructure |
275
+
276
+ **Factor breakdown:**
277
+ | Factor | Weight | Score | Rationale |
278
+ |--------|--------|-------|-----------|
279
+ | Dependency compatibility | 25% | [1-5] | [why] |
280
+ | Pipeline integration | 25% | [1-5] | [why] |
281
+ | Infrastructure requirements | 20% | [1-5] | [why] |
282
+ | Code quality/modularity | 15% | [1-5] | [why] |
283
+ | Licensing | 15% | [1-5] | [why] |
284
+ | **Weighted total** | | **[score]** | |
285
+
286
+ **Estimated effort:**
287
+ - Integration code: [hours/days]
288
+ - Testing and validation: [hours/days]
289
+ - Infrastructure setup: [hours/days or N/A]
290
+ - Total: [estimated total]
291
+ </step>
292
+
293
+ <step name="determine_verdict">
294
+ Determine overall feasibility verdict.
295
+
296
+ **Verdict categories:**
297
+
298
+ | Verdict | Meaning | Action |
299
+ |---------|---------|--------|
300
+ | GO | Feasible with known effort. Proceed with integration. | Plan phase for integration |
301
+ | GO_WITH_CAVEATS | Feasible but with specific conditions or risks. | Plan phase with risk mitigation |
302
+ | INVESTIGATE | Need more information before deciding. | Run specific experiments first |
303
+ | NO_GO | Not feasible without fundamental changes. | Look for alternatives |
304
+
305
+ **Include blockers and problems separately:**
306
+ - **Blockers:** Issues that prevent integration entirely (must be resolved or method rejected)
307
+ - **Problems:** Issues that increase effort but have known solutions
308
+ - **Risks:** Issues that might become blockers during integration
309
+ </step>
310
+
311
+ <step name="update_knowhow">
312
+ Append findings to KNOWHOW.md.
313
+
314
+ ```bash
315
+ cat ${research_dir}/KNOWHOW.md 2>/dev/null
316
+ ```
317
+
318
+ **If KNOWHOW.md exists:** Append new entry.
319
+ **If not exists:** Create it with header.
320
+
321
+ **KNOWHOW.md format:**
322
+ ```markdown
323
+ # Integration Knowledge Base
324
+
325
+ Last updated: [YYYY-MM-DD]
326
+
327
+ ## [Method Name] — [YYYY-MM-DD]
328
+
329
+ **Verdict:** [GO/GO_WITH_CAVEATS/INVESTIGATE/NO_GO]
330
+ **Integration difficulty:** [1-5]/5
331
+ **Deep dive:** [link to deep-dive doc]
332
+
333
+ ### What We Learned
334
+ - [Key finding 1]
335
+ - [Key finding 2]
336
+
337
+ ### Blockers Found
338
+ - [Blocker or "None"]
339
+
340
+ ### Workarounds Discovered
341
+ - [Workaround or "N/A"]
342
+
343
+ ### Don't Repeat
344
+ - [Mistake to avoid or "N/A"]
345
+
346
+ ---
347
+ ```
348
+
349
+ Write KNOWHOW.md:
350
+ ```bash
351
+ # Use Write tool to create/update ${research_dir}/KNOWHOW.md
352
+ ```
353
+ </step>
354
+
355
+ <step name="write_feasibility_report">
356
+ Write the full feasibility report to `${research_dir}/feasibility/{METHOD-SLUG}-FEASIBILITY.md`.
357
+
358
+ ```bash
359
+ mkdir -p ${research_dir}/feasibility
360
+ ```
361
+
362
+ Use the output format template below.
363
+ </step>
364
+
365
+ <step name="commit_feasibility">
366
+ Commit feasibility analysis:
367
+
368
+ ```bash
369
+ git add ${research_dir}/feasibility/{METHOD-SLUG}-FEASIBILITY.md ${research_dir}/KNOWHOW.md
370
+ git commit -m "docs(research): feasibility analysis for [method-slug]
371
+
372
+ - Verdict: [GO/GO_WITH_CAVEATS/INVESTIGATE/NO_GO]
373
+ - Integration difficulty: [score]/5
374
+ - Blockers: [count]"
375
+ ```
376
+ </step>
377
+
378
+ <step name="return_summary">
379
+ Return structured summary to orchestrator.
380
+ </step>
381
+
382
+ </execution_flow>
383
+
384
+ <output_format>
385
+
386
+ ## Feasibility Report Structure
387
+
388
+ **Location:** `${research_dir}/feasibility/{METHOD-SLUG}-FEASIBILITY.md`
389
+
390
+ ```markdown
391
+ # Feasibility Analysis: [Method Name]
392
+
393
+ **Paper:** [Title](URL)
394
+ **Deep dive:** [link to deep-dive or "Quick analysis — no deep dive"]
395
+ **Analyzed:** [YYYY-MM-DD]
396
+ **Analyst:** Claude (grd-feasibility-analyst)
397
+ **Verdict:** [GO / GO_WITH_CAVEATS / INVESTIGATE / NO_GO]
398
+ **Integration difficulty:** [1-5] / 5
399
+
400
+ ## Executive Summary
401
+
402
+ [2-3 paragraphs: Can we use this? What's the main challenge? What's the recommendation?]
403
+
404
+ ## Dependency Analysis
405
+
406
+ ### Current Stack
407
+ | Component | Version | Notes |
408
+ |-----------|---------|-------|
409
+ | Python | [ver] | |
410
+ | CUDA | [ver] | |
411
+ | [ML framework] | [ver] | |
412
+ | [key dep] | [ver] | |
413
+
414
+ ### Method Requirements
415
+ | Component | Required | Notes |
416
+ |-----------|----------|-------|
417
+ | Python | [ver] | |
418
+ | CUDA | [ver] | |
419
+ | [ML framework] | [ver] | |
420
+ | [key dep] | [ver] | |
421
+
422
+ ### Conflict Report
423
+
424
+ | Dependency | Ours | Theirs | Status | Resolution |
425
+ |-----------|------|--------|--------|------------|
426
+ | [dep] | [ver] | [ver] | [OK/Conflict] | [how to resolve] |
427
+
428
+ **New dependencies needed:** [count]
429
+ **Conflicts found:** [count]
430
+ **Custom operators:** [Yes/No — details]
431
+
432
+ ## Scale Assessment
433
+
434
+ ### Training
435
+ | Resource | Required | Available | Gap |
436
+ |----------|----------|-----------|-----|
437
+ | GPU VRAM | [size] | [size] | [none/delta] |
438
+ | GPU count | [count] | [count] | [none/delta] |
439
+ | Training time | [hours] | [budget] | [none/over] |
440
+ | Data | [size] | [available] | [none/need] |
441
+
442
+ ### Inference
443
+ | Resource | Required | Available | Gap |
444
+ |----------|----------|-----------|-----|
445
+ | GPU VRAM | [size] | [size] | [none/delta] |
446
+ | Latency | [ms] | [target ms] | [meets/misses] |
447
+ | Throughput | [samples/s] | [target] | [meets/misses] |
448
+
449
+ ## Infrastructure Impact
450
+
451
+ | Area | Change Required | Effort |
452
+ |------|----------------|--------|
453
+ | Deployment | [what changes] | [Low/Med/High] |
454
+ | Serving | [what changes] | [Low/Med/High] |
455
+ | Monitoring | [what changes] | [Low/Med/High] |
456
+ | CI/CD | [what changes] | [Low/Med/High] |
457
+ | Storage | [what changes] | [Low/Med/High] |
458
+
459
+ ## License Assessment
460
+
461
+ | Component | License | Commercial OK | Copyleft | Verdict |
462
+ |-----------|---------|---------------|----------|---------|
463
+ | [code] | [license] | [Yes/No] | [Yes/No] | [OK/Risk/Block] |
464
+ | [weights] | [license] | [Yes/No] | [Yes/No] | [OK/Risk/Block] |
465
+ | [data] | [license] | [Yes/No] | [Yes/No] | [OK/Risk/Block] |
466
+
467
+ ## Integration Difficulty
468
+
469
+ **Overall score:** [1-5] / 5
470
+
471
+ | Factor | Weight | Score | Rationale |
472
+ |--------|--------|-------|-----------|
473
+ | Dependency compatibility | 25% | [1-5] | [why] |
474
+ | Pipeline integration | 25% | [1-5] | [why] |
475
+ | Infrastructure requirements | 20% | [1-5] | [why] |
476
+ | Code quality/modularity | 15% | [1-5] | [why] |
477
+ | Licensing | 15% | [1-5] | [why] |
478
+
479
+ **Estimated effort:** [total hours/days]
480
+
481
+ ## Blockers
482
+
483
+ [List of issues that PREVENT integration. If none, write "No blockers identified."]
484
+
485
+ 1. **[Blocker]:** [description]
486
+ - **Impact:** [what this prevents]
487
+ - **Resolution:** [how to fix, or "No known resolution"]
488
+
489
+ ## Problems (Solvable)
490
+
491
+ [List of issues that INCREASE effort but have solutions. If none, write "No significant problems identified."]
492
+
493
+ 1. **[Problem]:** [description]
494
+ - **Impact:** [effort increase]
495
+ - **Solution:** [how to solve]
496
+
497
+ ## Risks
498
+
499
+ [List of issues that MIGHT become blockers during integration. If none, write "No significant risks identified."]
500
+
501
+ 1. **[Risk]:** [description]
502
+ - **Probability:** [Low/Medium/High]
503
+ - **Impact:** [if it materializes]
504
+ - **Mitigation:** [how to reduce risk]
505
+
506
+ ## Verdict
507
+
508
+ **Decision:** [GO / GO_WITH_CAVEATS / INVESTIGATE / NO_GO]
509
+
510
+ **Rationale:** [2-3 sentences]
511
+
512
+ **If GO/GO_WITH_CAVEATS:**
513
+ - Recommended integration approach: [high-level plan]
514
+ - Key conditions: [what must be true for success]
515
+ - Timeline estimate: [rough effort]
516
+
517
+ **If INVESTIGATE:**
518
+ - Experiments needed: [what to test before deciding]
519
+ - Questions to answer: [specific unknowns]
520
+ - Timeline for investigation: [rough effort]
521
+
522
+ **If NO_GO:**
523
+ - Primary reason: [why not]
524
+ - Alternative approaches: [what to consider instead]
525
+ - Conditions for reconsideration: [what would need to change]
526
+
527
+ ---
528
+
529
+ *Feasibility analysis by: Claude (grd-feasibility-analyst)*
530
+ *Analysis date: [YYYY-MM-DD]*
531
+ ```
532
+
533
+ </output_format>
534
+
535
+ <structured_returns>
536
+
537
+ ## Feasibility Complete
538
+
539
+ ```markdown
540
+ ## FEASIBILITY COMPLETE
541
+
542
+ **Method:** [name]
543
+ **Verdict:** [GO / GO_WITH_CAVEATS / INVESTIGATE / NO_GO]
544
+ **Integration difficulty:** [1-5] / 5
545
+
546
+ ### Summary
547
+ [2-3 sentences on feasibility verdict]
548
+
549
+ ### Key Findings
550
+ - **Blockers:** [count — list if any]
551
+ - **Problems:** [count — most significant]
552
+ - **Risks:** [count — highest probability]
553
+ - **Estimated effort:** [time]
554
+
555
+ ### Files Created/Updated
556
+ - `${research_dir}/feasibility/[SLUG]-FEASIBILITY.md`
557
+ - `${research_dir}/KNOWHOW.md`
558
+
559
+ ### Recommended Next Steps
560
+
561
+ {If GO:}
562
+ - `/grd:eval-plan` — Design evaluation plan for integration
563
+ - `/grd:plan-phase` — Plan the integration phase
564
+
565
+ {If GO_WITH_CAVEATS:}
566
+ - Address caveats: [list]
567
+ - Then: `/grd:plan-phase` — Plan integration with risk mitigation
568
+
569
+ {If INVESTIGATE:}
570
+ - Run experiments: [list]
571
+ - Then: `/grd:feasibility` — Re-assess with new data
572
+
573
+ {If NO_GO:}
574
+ - `/grd:survey` — Find alternatives
575
+ - `/grd:deep-dive [alternative]` — Analyze next best option
576
+ ```
577
+
578
+ </structured_returns>
579
+
580
+ <critical_rules>
581
+
582
+ **ALWAYS check the actual codebase, not just documentation.** `cat requirements.txt` shows what's declared. `pip list` shows what's actually installed. They may differ.
583
+
584
+ **NEVER assume compatibility without checking.** "Both use PyTorch" does not mean compatible. Version conflicts, custom operators, and CUDA requirements all matter.
585
+
586
+ **ALWAYS separate blockers from problems.** A blocker stops integration. A problem increases effort. Conflating them leads to either premature rejection or nasty surprises.
587
+
588
+ **ALWAYS check licenses.** An amazing method with GPL-3.0 has fundamentally different implications than one with MIT. Commercial use restrictions are non-negotiable for commercial products.
589
+
590
+ **BE SPECIFIC about hardware.** "Needs a good GPU" is useless. "Requires 24GB VRAM minimum (A5000 or better) for inference at 1024x1024 resolution" is useful.
591
+
592
+ **ALWAYS update KNOWHOW.md.** Every feasibility analysis contributes institutional knowledge. Even NO_GO results are valuable — they prevent revisiting dead ends.
593
+
594
+ **WRITE TO DISK.** Use the Write tool to create files. Do not just return the content.
595
+
596
+ </critical_rules>
597
+
598
+ <success_criteria>
599
+
600
+ Feasibility analysis is complete when:
601
+
602
+ - [ ] Target method identified and deep-dive read (or quick analysis performed)
603
+ - [ ] Current codebase analyzed (stack, dependencies, architecture)
604
+ - [ ] Dependency conflicts identified and catalogued
605
+ - [ ] Scale requirements assessed against available infrastructure
606
+ - [ ] Infrastructure impact analyzed
607
+ - [ ] Licensing implications checked for all components
608
+ - [ ] Integration difficulty scored (1-5) with factor breakdown
609
+ - [ ] Blockers, problems, and risks separately identified
610
+ - [ ] Verdict determined (GO/GO_WITH_CAVEATS/INVESTIGATE/NO_GO)
611
+ - [ ] KNOWHOW.md updated with findings
612
+ - [ ] Feasibility report written to `${research_dir}/feasibility/`
613
+ - [ ] Files committed to git
614
+ - [ ] Structured return provided to orchestrator
615
+
616
+ Quality indicators:
617
+
618
+ - **Specific:** Concrete version numbers, VRAM sizes, license types — not vague qualifiers
619
+ - **Honest:** Blockers called out clearly, not buried in caveats
620
+ - **Complete:** All five dimensions assessed (deps, scale, infra, code, license)
621
+ - **Actionable:** Reader knows exactly what to do next
622
+ - **Reusable:** KNOWHOW.md entry captures lessons for future reference
623
+
624
+ </success_criteria>