@researai/deepscientist 1.5.16 → 1.6.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 (896) hide show
  1. package/AGENTS.md +309 -130
  2. package/AISB/catalog/aisb.b1.agentic_coding.yaml +244 -0
  3. package/AISB/catalog/aisb.b10.climate_earth.yaml +235 -0
  4. package/AISB/catalog/aisb.b11.model_efficiency.yaml +231 -0
  5. package/AISB/catalog/aisb.b12.embodied_ai.yaml +238 -0
  6. package/AISB/catalog/aisb.b2.agent_systems.yaml +229 -0
  7. package/AISB/catalog/aisb.b3.self_evolving_rl.yaml +237 -0
  8. package/AISB/catalog/aisb.b4.lm_reasoning.yaml +240 -0
  9. package/AISB/catalog/aisb.b5.math_proof.yaml +235 -0
  10. package/AISB/catalog/aisb.b6.research_process.yaml +243 -0
  11. package/AISB/catalog/aisb.b7.multimodal_fusion.yaml +232 -0
  12. package/AISB/catalog/aisb.b8.lifesci_drug.yaml +275 -0
  13. package/AISB/catalog/aisb.b9.material_science.yaml +237 -0
  14. package/AISB/catalog/aisb.t3.001_savvy.yaml +159 -0
  15. package/AISB/catalog/aisb.t3.001_savvy.zh.yaml +121 -0
  16. package/AISB/catalog/aisb.t3.002_pinet.yaml +189 -0
  17. package/AISB/catalog/aisb.t3.002_pinet.zh.yaml +130 -0
  18. package/AISB/catalog/aisb.t3.004_decentralattn.yaml +184 -0
  19. package/AISB/catalog/aisb.t3.004_decentralattn.zh.yaml +153 -0
  20. package/AISB/catalog/aisb.t3.005_tsae.yaml +193 -0
  21. package/AISB/catalog/aisb.t3.005_tsae.zh.yaml +139 -0
  22. package/AISB/catalog/aisb.t3.006_physense.yaml +194 -0
  23. package/AISB/catalog/aisb.t3.006_physense.zh.yaml +118 -0
  24. package/AISB/catalog/aisb.t3.007_reasoningiqa.yaml +169 -0
  25. package/AISB/catalog/aisb.t3.007_reasoningiqa.zh.yaml +133 -0
  26. package/AISB/catalog/aisb.t3.008_meanflows.yaml +188 -0
  27. package/AISB/catalog/aisb.t3.008_meanflows.zh.yaml +140 -0
  28. package/AISB/catalog/aisb.t3.009_scoremissing.yaml +179 -0
  29. package/AISB/catalog/aisb.t3.009_scoremissing.zh.yaml +119 -0
  30. package/AISB/catalog/aisb.t3.010_suitabilityfilter.yaml +221 -0
  31. package/AISB/catalog/aisb.t3.010_suitabilityfilter.zh.yaml +141 -0
  32. package/AISB/catalog/aisb.t3.011_osd.yaml +206 -0
  33. package/AISB/catalog/aisb.t3.011_osd.zh.yaml +163 -0
  34. package/AISB/catalog/aisb.t3.012_efficientqat.yaml +206 -0
  35. package/AISB/catalog/aisb.t3.012_efficientqat.zh.yaml +159 -0
  36. package/AISB/catalog/aisb.t3.013_appl.yaml +152 -0
  37. package/AISB/catalog/aisb.t3.013_appl.zh.yaml +126 -0
  38. package/AISB/catalog/aisb.t3.014_piguard.yaml +207 -0
  39. package/AISB/catalog/aisb.t3.014_piguard.zh.yaml +164 -0
  40. package/AISB/catalog/aisb.t3.015_frspec.yaml +209 -0
  41. package/AISB/catalog/aisb.t3.015_frspec.zh.yaml +163 -0
  42. package/AISB/catalog/aisb.t3.016_mathfusion.yaml +166 -0
  43. package/AISB/catalog/aisb.t3.016_mathfusion.zh.yaml +145 -0
  44. package/AISB/catalog/aisb.t3.017_multimodalglp.yaml +171 -0
  45. package/AISB/catalog/aisb.t3.017_multimodalglp.zh.yaml +122 -0
  46. package/AISB/catalog/aisb.t3.018_cotsynth.yaml +206 -0
  47. package/AISB/catalog/aisb.t3.018_cotsynth.zh.yaml +162 -0
  48. package/AISB/catalog/aisb.t3.019_dyscaleut.yaml +211 -0
  49. package/AISB/catalog/aisb.t3.019_dyscaleut.zh.yaml +148 -0
  50. package/AISB/catalog/aisb.t3.020_aristotle.yaml +173 -0
  51. package/AISB/catalog/aisb.t3.020_aristotle.zh.yaml +119 -0
  52. package/AISB/catalog/aisb.t3.021_tokenrecycling.yaml +160 -0
  53. package/AISB/catalog/aisb.t3.021_tokenrecycling.zh.yaml +129 -0
  54. package/AISB/catalog/aisb.t3.022_chainofreasoning.yaml +204 -0
  55. package/AISB/catalog/aisb.t3.022_chainofreasoning.zh.yaml +161 -0
  56. package/AISB/catalog/aisb.t3.023_guidedembed.yaml +211 -0
  57. package/AISB/catalog/aisb.t3.023_guidedembed.zh.yaml +189 -0
  58. package/AISB/catalog/aisb.t3.024_outputcentric.yaml +148 -0
  59. package/AISB/catalog/aisb.t3.024_outputcentric.zh.yaml +131 -0
  60. package/AISB/catalog/aisb.t3.025_deeper.yaml +143 -0
  61. package/AISB/catalog/aisb.t3.025_deeper.zh.yaml +116 -0
  62. package/AISB/catalog/aisb.t3.026_gartkg.yaml +195 -0
  63. package/AISB/catalog/aisb.t3.026_gartkg.zh.yaml +127 -0
  64. package/AISB/catalog/aisb.t3.027_citeeval.yaml +182 -0
  65. package/AISB/catalog/aisb.t3.027_citeeval.zh.yaml +135 -0
  66. package/AISB/catalog/aisb.t3.028_sbam.yaml +206 -0
  67. package/AISB/catalog/aisb.t3.028_sbam.zh.yaml +166 -0
  68. package/AISB/catalog/aisb.t3.029_cdqgeoembed.yaml +224 -0
  69. package/AISB/catalog/aisb.t3.029_cdqgeoembed.zh.yaml +142 -0
  70. package/AISB/catalog/aisb.t3.030_processrm.yaml +211 -0
  71. package/AISB/catalog/aisb.t3.030_processrm.zh.yaml +166 -0
  72. package/AISB/catalog/aisb.t3.031_circuitstability.yaml +172 -0
  73. package/AISB/catalog/aisb.t3.031_circuitstability.zh.yaml +134 -0
  74. package/AISB/catalog/aisb.t3.032_ptsolver.yaml +169 -0
  75. package/AISB/catalog/aisb.t3.032_ptsolver.zh.yaml +135 -0
  76. package/AISB/catalog/aisb.t3.033_gcse.yaml +144 -0
  77. package/AISB/catalog/aisb.t3.033_gcse.zh.yaml +126 -0
  78. package/AISB/catalog/aisb.t3.034_ensemblewm.yaml +183 -0
  79. package/AISB/catalog/aisb.t3.034_ensemblewm.zh.yaml +146 -0
  80. package/AISB/catalog/aisb.t3.035_moralvalueswa.yaml +207 -0
  81. package/AISB/catalog/aisb.t3.035_moralvalueswa.zh.yaml +165 -0
  82. package/AISB/catalog/aisb.t3.036_weakstrongpref.yaml +210 -0
  83. package/AISB/catalog/aisb.t3.036_weakstrongpref.zh.yaml +194 -0
  84. package/AISB/catalog/aisb.t3.037_dementiamask.yaml +172 -0
  85. package/AISB/catalog/aisb.t3.037_dementiamask.zh.yaml +132 -0
  86. package/AISB/catalog/aisb.t3.038_tinysam.yaml +284 -0
  87. package/AISB/catalog/aisb.t3.038_tinysam.zh.yaml +240 -0
  88. package/AISB/catalog/aisb.t3.039_calf.yaml +224 -0
  89. package/AISB/catalog/aisb.t3.039_calf.zh.yaml +194 -0
  90. package/AISB/catalog/aisb.t3.040_graniteguardian.yaml +199 -0
  91. package/AISB/catalog/aisb.t3.040_graniteguardian.zh.yaml +174 -0
  92. package/AISB/catalog/aisb.t3.041_amdm.yaml +149 -0
  93. package/AISB/catalog/aisb.t3.041_amdm.zh.yaml +137 -0
  94. package/AISB/catalog/aisb.t3.042_xpatch.yaml +216 -0
  95. package/AISB/catalog/aisb.t3.042_xpatch.zh.yaml +182 -0
  96. package/AISB/catalog/aisb.t3.043_vhm.yaml +268 -0
  97. package/AISB/catalog/aisb.t3.043_vhm.zh.yaml +193 -0
  98. package/AISB/catalog/aisb.t3.044_rgvi.yaml +224 -0
  99. package/AISB/catalog/aisb.t3.044_rgvi.zh.yaml +176 -0
  100. package/AISB/catalog/aisb.t3.045_pslstm.yaml +203 -0
  101. package/AISB/catalog/aisb.t3.045_pslstm.zh.yaml +179 -0
  102. package/AISB/catalog/aisb.t3.046_nonstatts.yaml +208 -0
  103. package/AISB/catalog/aisb.t3.046_nonstatts.zh.yaml +194 -0
  104. package/AISB/catalog/aisb.t3.047_timepfn.yaml +156 -0
  105. package/AISB/catalog/aisb.t3.047_timepfn.zh.yaml +124 -0
  106. package/AISB/catalog/aisb.t3.048_proxyspex.yaml +148 -0
  107. package/AISB/catalog/aisb.t3.048_proxyspex.zh.yaml +125 -0
  108. package/AISB/catalog/aisb.t3.049_hogwildinference.yaml +183 -0
  109. package/AISB/catalog/aisb.t3.049_hogwildinference.zh.yaml +138 -0
  110. package/AISB/catalog/aisb.t3.050_causalpfn.yaml +214 -0
  111. package/AISB/catalog/aisb.t3.050_causalpfn.zh.yaml +190 -0
  112. package/AISB/catalog/aisb.t3.051_flashtp.yaml +169 -0
  113. package/AISB/catalog/aisb.t3.051_flashtp.zh.yaml +124 -0
  114. package/AISB/catalog/aisb.t3.052_nsdiff.yaml +155 -0
  115. package/AISB/catalog/aisb.t3.052_nsdiff.zh.yaml +138 -0
  116. package/AISB/catalog/aisb.t3.053_k2vae.yaml +158 -0
  117. package/AISB/catalog/aisb.t3.053_k2vae.zh.yaml +132 -0
  118. package/AISB/catalog/aisb.t3.054_timebase.yaml +178 -0
  119. package/AISB/catalog/aisb.t3.054_timebase.zh.yaml +158 -0
  120. package/AISB/catalog/aisb.t3.055_csbrain.yaml +238 -0
  121. package/AISB/catalog/aisb.t3.055_csbrain.zh.yaml +184 -0
  122. package/AISB/catalog/aisb.t3.056_infosam.yaml +224 -0
  123. package/AISB/catalog/aisb.t3.056_infosam.zh.yaml +189 -0
  124. package/AISB/catalog/aisb.t3.057_mdreid.yaml +129 -0
  125. package/AISB/catalog/aisb.t3.057_mdreid.zh.yaml +117 -0
  126. package/AISB/catalog/aisb.t3.058_mindglitch.yaml +171 -0
  127. package/AISB/catalog/aisb.t3.058_mindglitch.zh.yaml +145 -0
  128. package/AISB/catalog/aisb.t3.059_selfsupervised.yaml +154 -0
  129. package/AISB/catalog/aisb.t3.059_selfsupervised.zh.yaml +125 -0
  130. package/AISB/catalog/aisb.t3.060_iaggad.yaml +121 -0
  131. package/AISB/catalog/aisb.t3.060_iaggad.zh.yaml +100 -0
  132. package/AISB/catalog/aisb.t3.061_hsgkn.yaml +136 -0
  133. package/AISB/catalog/aisb.t3.061_hsgkn.zh.yaml +113 -0
  134. package/AISB/catalog/aisb.t3.062_visionts.yaml +237 -0
  135. package/AISB/catalog/aisb.t3.062_visionts.zh.yaml +216 -0
  136. package/AISB/catalog/aisb.t3.063_tsrag.yaml +162 -0
  137. package/AISB/catalog/aisb.t3.063_tsrag.zh.yaml +138 -0
  138. package/AISB/catalog/aisb.t3.064_pir.yaml +221 -0
  139. package/AISB/catalog/aisb.t3.064_pir.zh.yaml +197 -0
  140. package/AISB/catalog/aisb.t3.065_proteinbinding.yaml +234 -0
  141. package/AISB/catalog/aisb.t3.065_proteinbinding.zh.yaml +167 -0
  142. package/AISB/catalog/aisb.t3.066_tropicalattention.yaml +267 -0
  143. package/AISB/catalog/aisb.t3.066_tropicalattention.zh.yaml +229 -0
  144. package/AISB/catalog/aisb.t3.067_kanad.yaml +193 -0
  145. package/AISB/catalog/aisb.t3.067_kanad.zh.yaml +167 -0
  146. package/AISB/catalog/aisb.t3.068_sempo.yaml +187 -0
  147. package/AISB/catalog/aisb.t3.068_sempo.zh.yaml +148 -0
  148. package/AISB/catalog/aisb.t3.069_treehfd.yaml +129 -0
  149. package/AISB/catalog/aisb.t3.069_treehfd.zh.yaml +111 -0
  150. package/AISB/catalog/aisb.t3.070_certifiedunlearning.yaml +224 -0
  151. package/AISB/catalog/aisb.t3.070_certifiedunlearning.zh.yaml +171 -0
  152. package/AISB/catalog/aisb.t3.071_neuralmjd.yaml +142 -0
  153. package/AISB/catalog/aisb.t3.071_neuralmjd.zh.yaml +120 -0
  154. package/AISB/catalog/aisb.t3.072_fedgmt.yaml +181 -0
  155. package/AISB/catalog/aisb.t3.072_fedgmt.zh.yaml +158 -0
  156. package/AISB/catalog/aisb.t3.073_rld.yaml +161 -0
  157. package/AISB/catalog/aisb.t3.073_rld.zh.yaml +129 -0
  158. package/AISB/catalog/aisb.t3.074_lsvi.yaml +163 -0
  159. package/AISB/catalog/aisb.t3.074_lsvi.zh.yaml +129 -0
  160. package/AISB/catalog/aisb.t3.075_treeslicedentropy.yaml +201 -0
  161. package/AISB/catalog/aisb.t3.075_treeslicedentropy.zh.yaml +148 -0
  162. package/AISB/catalog/aisb.t3.076_aanet.yaml +169 -0
  163. package/AISB/catalog/aisb.t3.076_aanet.zh.yaml +129 -0
  164. package/AISB/catalog/aisb.t3.077_cmnn.yaml +199 -0
  165. package/AISB/catalog/aisb.t3.077_cmnn.zh.yaml +165 -0
  166. package/AISB/catalog/aisb.t3.078_conformalanomaly.yaml +146 -0
  167. package/AISB/catalog/aisb.t3.078_conformalanomaly.zh.yaml +117 -0
  168. package/AISB/catalog/aisb.t3.079_dpfkmeans.yaml +131 -0
  169. package/AISB/catalog/aisb.t3.079_dpfkmeans.zh.yaml +104 -0
  170. package/AISB/catalog/aisb.t3.080_latentscorereweight.yaml +169 -0
  171. package/AISB/catalog/aisb.t3.080_latentscorereweight.zh.yaml +123 -0
  172. package/AISB/catalog/aisb.t3.081_qmamba.yaml +150 -0
  173. package/AISB/catalog/aisb.t3.081_qmamba.zh.yaml +117 -0
  174. package/AISB/catalog/aisb.t3.082_onlinellmrouting.yaml +160 -0
  175. package/AISB/catalog/aisb.t3.082_onlinellmrouting.zh.yaml +133 -0
  176. package/AISB/catalog/aisb.t3.083_starformer.yaml +178 -0
  177. package/AISB/catalog/aisb.t3.083_starformer.zh.yaml +140 -0
  178. package/AISB/catalog/aisb.t3.084_ift.yaml +139 -0
  179. package/AISB/catalog/aisb.t3.084_ift.zh.yaml +111 -0
  180. package/AISB/catalog/aisb.t3.085_neuralsurv.yaml +183 -0
  181. package/AISB/catalog/aisb.t3.085_neuralsurv.zh.yaml +143 -0
  182. package/AISB/catalog/aisb.t3.086_stella.yaml +197 -0
  183. package/AISB/catalog/aisb.t3.086_stella.zh.yaml +142 -0
  184. package/AISB/catalog/aisb.t3.087_moses.yaml +167 -0
  185. package/AISB/catalog/aisb.t3.087_moses.zh.yaml +132 -0
  186. package/AISB/catalog/aisb.t3.088_channelnorm.yaml +140 -0
  187. package/AISB/catalog/aisb.t3.088_channelnorm.zh.yaml +109 -0
  188. package/AISB/catalog/aisb.t3.089_causalvelocity.yaml +730 -0
  189. package/AISB/catalog/aisb.t3.089_causalvelocity.zh.yaml +668 -0
  190. package/AISB/catalog/aisb.t3.090_rstib.yaml +144 -0
  191. package/AISB/catalog/aisb.t3.090_rstib.zh.yaml +109 -0
  192. package/AISB/catalog/aisb.t3.091_timeawarecausal.yaml +132 -0
  193. package/AISB/catalog/aisb.t3.091_timeawarecausal.zh.yaml +107 -0
  194. package/AISB/catalog/aisb.t3.092_kmeanslocalopt.yaml +138 -0
  195. package/AISB/catalog/aisb.t3.092_kmeanslocalopt.zh.yaml +110 -0
  196. package/AISB/catalog/aisb.t3.093_fedwmsam.yaml +134 -0
  197. package/AISB/catalog/aisb.t3.093_fedwmsam.zh.yaml +106 -0
  198. package/AISB/catalog/aisb.t3.094_boundre.yaml +147 -0
  199. package/AISB/catalog/aisb.t3.094_boundre.zh.yaml +114 -0
  200. package/AISB/catalog/aisb.t3.095_fastfeaturecp.yaml +153 -0
  201. package/AISB/catalog/aisb.t3.095_fastfeaturecp.zh.yaml +118 -0
  202. package/AISB/catalog/aisb.t3.096_m3svm.yaml +189 -0
  203. package/AISB/catalog/aisb.t3.096_m3svm.zh.yaml +149 -0
  204. package/AISB/catalog/aisb.t3.097_wassersteintl.yaml +212 -0
  205. package/AISB/catalog/aisb.t3.097_wassersteintl.zh.yaml +169 -0
  206. package/AISB/catalog/aisb.t3.098_xmahalanobis.yaml +171 -0
  207. package/AISB/catalog/aisb.t3.098_xmahalanobis.zh.yaml +127 -0
  208. package/AISB/catalog/aisb.t3.099_ollalanding.yaml +248 -0
  209. package/AISB/catalog/aisb.t3.099_ollalanding.zh.yaml +182 -0
  210. package/AISB/catalog/aisb.t3.100_invmissingdata.yaml +179 -0
  211. package/AISB/catalog/aisb.t3.100_invmissingdata.zh.yaml +150 -0
  212. package/AISB/catalog/aisb.t3.101_acia.yaml +164 -0
  213. package/AISB/catalog/aisb.t3.101_acia.zh.yaml +109 -0
  214. package/AISB/catalog/aisb.t3.102_stochasticff.yaml +178 -0
  215. package/AISB/catalog/aisb.t3.102_stochasticff.zh.yaml +130 -0
  216. package/AISB/catalog/aisb.t3.103_qdcp.yaml +150 -0
  217. package/AISB/catalog/aisb.t3.103_qdcp.zh.yaml +116 -0
  218. package/AISB/catalog/aisb.t3.104_balancedactiveinf.yaml +137 -0
  219. package/AISB/catalog/aisb.t3.104_balancedactiveinf.zh.yaml +104 -0
  220. package/AISB/catalog/aisb.t3.105_binaryclasseval.yaml +161 -0
  221. package/AISB/catalog/aisb.t3.105_binaryclasseval.zh.yaml +130 -0
  222. package/AISB/image/001_aisb.t3.001_savvy.jpg +0 -0
  223. package/AISB/image/002_aisb.t3.002_pinet.jpg +0 -0
  224. package/AISB/image/003_aisb.t3.003_dmsqd.jpg +0 -0
  225. package/AISB/image/004_aisb.t3.004_decentralattn.jpg +0 -0
  226. package/AISB/image/005_aisb.t3.005_tsae.jpg +0 -0
  227. package/AISB/image/006_aisb.t3.006_physense.jpg +0 -0
  228. package/AISB/image/007_aisb.t3.007_reasoningiqa.jpg +0 -0
  229. package/AISB/image/008_aisb.t3.008_meanflows.jpg +0 -0
  230. package/AISB/image/009_aisb.t3.009_scoremissing.jpg +0 -0
  231. package/AISB/image/010_aisb.t3.010_suitabilityfilter.jpg +0 -0
  232. package/AISB/image/011_aisb.t3.011_osd.jpg +0 -0
  233. package/AISB/image/012_aisb.t3.012_efficientqat.jpg +0 -0
  234. package/AISB/image/013_aisb.t3.013_appl.jpg +0 -0
  235. package/AISB/image/014_aisb.t3.014_piguard.jpg +0 -0
  236. package/AISB/image/015_aisb.t3.015_frspec.jpg +0 -0
  237. package/AISB/image/016_aisb.t3.016_mathfusion.jpg +0 -0
  238. package/AISB/image/017_aisb.t3.017_multimodalglp.jpg +0 -0
  239. package/AISB/image/018_aisb.t3.018_cotsynth.jpg +0 -0
  240. package/AISB/image/019_aisb.t3.019_dyscaleut.jpg +0 -0
  241. package/AISB/image/020_aisb.t3.020_aristotle.jpg +0 -0
  242. package/AISB/image/021_aisb.t3.021_tokenrecycling.jpg +0 -0
  243. package/AISB/image/022_aisb.t3.022_chainofreasoning.jpg +0 -0
  244. package/AISB/image/023_aisb.t3.023_guidedembed.jpg +0 -0
  245. package/AISB/image/024_aisb.t3.024_outputcentric.jpg +0 -0
  246. package/AISB/image/025_aisb.t3.025_deeper.jpg +0 -0
  247. package/AISB/image/026_aisb.t3.026_gartkg.jpg +0 -0
  248. package/AISB/image/027_aisb.t3.027_citeeval.jpg +0 -0
  249. package/AISB/image/028_aisb.t3.028_sbam.jpg +0 -0
  250. package/AISB/image/029_aisb.t3.029_cdqgeoembed.jpg +0 -0
  251. package/AISB/image/030_aisb.t3.030_processrm.jpg +0 -0
  252. package/AISB/image/031_aisb.t3.031_circuitstability.jpg +0 -0
  253. package/AISB/image/032_aisb.t3.032_ptsolver.jpg +0 -0
  254. package/AISB/image/033_aisb.t3.033_gcse.jpg +0 -0
  255. package/AISB/image/034_aisb.t3.034_ensemblewm.jpg +0 -0
  256. package/AISB/image/035_aisb.t3.035_moralvalueswa.jpg +0 -0
  257. package/AISB/image/036_aisb.t3.036_weakstrongpref.jpg +0 -0
  258. package/AISB/image/037_aisb.t3.037_dementiamask.jpg +0 -0
  259. package/AISB/image/038_aisb.t3.038_tinysam.jpg +0 -0
  260. package/AISB/image/039_aisb.t3.039_calf.jpg +0 -0
  261. package/AISB/image/040_aisb.t3.040_graniteguardian.jpg +0 -0
  262. package/AISB/image/041_aisb.t3.041_amdm.jpg +0 -0
  263. package/AISB/image/042_aisb.t3.042_xpatch.jpg +0 -0
  264. package/AISB/image/043_aisb.t3.043_vhm.jpg +0 -0
  265. package/AISB/image/044_aisb.t3.044_rgvi.jpg +0 -0
  266. package/AISB/image/045_aisb.t3.045_pslstm.jpg +0 -0
  267. package/AISB/image/046_aisb.t3.046_nonstatts.jpg +0 -0
  268. package/AISB/image/047_aisb.t3.047_timepfn.jpg +0 -0
  269. package/AISB/image/048_aisb.t3.048_proxyspex.jpg +0 -0
  270. package/AISB/image/049_aisb.t3.049_hogwildinference.jpg +0 -0
  271. package/AISB/image/050_aisb.t3.050_causalpfn.jpg +0 -0
  272. package/AISB/image/051_aisb.t3.051_flashtp.jpg +0 -0
  273. package/AISB/image/052_aisb.t3.052_nsdiff.jpg +0 -0
  274. package/AISB/image/053_aisb.t3.053_k2vae.jpg +0 -0
  275. package/AISB/image/054_aisb.t3.054_timebase.jpg +0 -0
  276. package/AISB/image/055_aisb.t3.055_csbrain.jpg +0 -0
  277. package/AISB/image/056_aisb.t3.056_infosam.jpg +0 -0
  278. package/AISB/image/057_aisb.t3.057_mdreid.jpg +0 -0
  279. package/AISB/image/058_aisb.t3.058_mindglitch.jpg +0 -0
  280. package/AISB/image/059_aisb.t3.059_selfsupervised.jpg +0 -0
  281. package/AISB/image/060_aisb.t3.060_iaggad.jpg +0 -0
  282. package/AISB/image/061_aisb.t3.061_hsgkn.jpg +0 -0
  283. package/AISB/image/062_aisb.t3.062_visionts.jpg +0 -0
  284. package/AISB/image/063_aisb.t3.063_tsrag.jpg +0 -0
  285. package/AISB/image/064_aisb.t3.064_pir.jpg +0 -0
  286. package/AISB/image/065_aisb.t3.065_proteinbinding.jpg +0 -0
  287. package/AISB/image/066_aisb.t3.066_tropicalattention.jpg +0 -0
  288. package/AISB/image/067_aisb.t3.067_kanad.jpg +0 -0
  289. package/AISB/image/068_aisb.t3.068_sempo.jpg +0 -0
  290. package/AISB/image/069_aisb.t3.069_treehfd.jpg +0 -0
  291. package/AISB/image/070_aisb.t3.070_certifiedunlearning.jpg +0 -0
  292. package/AISB/image/071_aisb.t3.071_neuralmjd.jpg +0 -0
  293. package/AISB/image/072_aisb.t3.072_fedgmt.jpg +0 -0
  294. package/AISB/image/073_aisb.t3.073_rld.jpg +0 -0
  295. package/AISB/image/074_aisb.t3.074_lsvi.jpg +0 -0
  296. package/AISB/image/075_aisb.t3.075_treeslicedentropy.jpg +0 -0
  297. package/AISB/image/076_aisb.t3.076_aanet.jpg +0 -0
  298. package/AISB/image/077_aisb.t3.077_cmnn.jpg +0 -0
  299. package/AISB/image/078_aisb.t3.078_conformalanomaly.jpg +0 -0
  300. package/AISB/image/079_aisb.t3.079_dpfkmeans.jpg +0 -0
  301. package/AISB/image/080_aisb.t3.080_latentscorereweight.jpg +0 -0
  302. package/AISB/image/081_aisb.t3.081_qmamba.jpg +0 -0
  303. package/AISB/image/082_aisb.t3.082_onlinellmrouting.jpg +0 -0
  304. package/AISB/image/083_aisb.t3.083_starformer.jpg +0 -0
  305. package/AISB/image/084_aisb.t3.084_ift.jpg +0 -0
  306. package/AISB/image/085_aisb.t3.085_neuralsurv.jpg +0 -0
  307. package/AISB/image/086_aisb.t3.086_stella.jpg +0 -0
  308. package/AISB/image/087_aisb.t3.087_moses.jpg +0 -0
  309. package/AISB/image/088_aisb.t3.088_channelnorm.jpg +0 -0
  310. package/AISB/image/089_aisb.t3.089_causalvelocity.jpg +0 -0
  311. package/AISB/image/090_aisb.t3.090_rstib.jpg +0 -0
  312. package/AISB/image/091_aisb.t3.091_timeawarecausal.jpg +0 -0
  313. package/AISB/image/092_aisb.t3.092_kmeanslocalopt.jpg +0 -0
  314. package/AISB/image/093_aisb.t3.093_fedwmsam.jpg +0 -0
  315. package/AISB/image/094_aisb.t3.094_boundre.jpg +0 -0
  316. package/AISB/image/095_aisb.t3.095_fastfeaturecp.jpg +0 -0
  317. package/AISB/image/096_aisb.t3.096_m3svm.jpg +0 -0
  318. package/AISB/image/097_aisb.t3.097_wassersteintl.jpg +0 -0
  319. package/AISB/image/098_aisb.t3.098_xmahalanobis.jpg +0 -0
  320. package/AISB/image/099_aisb.t3.099_ollalanding.jpg +0 -0
  321. package/AISB/image/100_aisb.t3.100_invmissingdata.jpg +0 -0
  322. package/AISB/image/101_aisb.t3.101_acia.jpg +0 -0
  323. package/AISB/image/102_aisb.t3.102_stochasticff.jpg +0 -0
  324. package/AISB/image/103_aisb.t3.103_qdcp.jpg +0 -0
  325. package/AISB/image/104_aisb.t3.104_balancedactiveinf.jpg +0 -0
  326. package/AISB/image/105_aisb.t3.105_binaryclasseval.jpg +0 -0
  327. package/AISB/image/106_aisb.t1.reasoning_lite.jpg +0 -0
  328. package/AISB/image/107_aisb.t2.paper_audit.jpg +0 -0
  329. package/AISB/image/108_aisb.t3.multi_gpu_search.jpg +0 -0
  330. package/AISB/image/109_aisb.t3.tdc_admet.jpg +0 -0
  331. package/AISB/image/aisb.b1.agentic_coding.svg +16 -0
  332. package/AISB/image/aisb.b10.climate_earth.svg +16 -0
  333. package/AISB/image/aisb.b11.model_efficiency.svg +16 -0
  334. package/AISB/image/aisb.b12.embodied_ai.svg +16 -0
  335. package/AISB/image/aisb.b2.agent_systems.svg +16 -0
  336. package/AISB/image/aisb.b3.self_evolving_rl.svg +16 -0
  337. package/AISB/image/aisb.b4.lm_reasoning.svg +16 -0
  338. package/AISB/image/aisb.b5.math_proof.svg +16 -0
  339. package/AISB/image/aisb.b6.research_process.svg +16 -0
  340. package/AISB/image/aisb.b7.multimodal_fusion.svg +16 -0
  341. package/AISB/image/aisb.b8.lifesci_drug.svg +16 -0
  342. package/AISB/image/aisb.b9.material_science.svg +16 -0
  343. package/README.md +196 -32
  344. package/bin/ds.js +924 -66
  345. package/docs/en/00_QUICK_START.md +195 -18
  346. package/docs/en/01_SETTINGS_REFERENCE.md +468 -96
  347. package/docs/en/02_START_RESEARCH_GUIDE.md +26 -5
  348. package/docs/en/03_QQ_CONNECTOR_GUIDE.md +14 -3
  349. package/docs/en/04_LINGZHU_CONNECTOR_GUIDE.md +2 -0
  350. package/docs/en/05_TUI_GUIDE.md +171 -2
  351. package/docs/en/07_MEMORY_AND_MCP.md +38 -2
  352. package/docs/en/09_DOCTOR.md +78 -7
  353. package/docs/en/10_WEIXIN_CONNECTOR_GUIDE.md +38 -1
  354. package/docs/en/11_LICENSE_AND_RISK.md +4 -0
  355. package/docs/en/12_GUIDED_WORKFLOW_TOUR.md +15 -0
  356. package/docs/en/14_PROMPT_SKILLS_AND_MCP_GUIDE.md +9 -0
  357. package/docs/en/15_CODEX_PROVIDER_SETUP.md +624 -180
  358. package/docs/en/16_TELEGRAM_CONNECTOR_GUIDE.md +14 -0
  359. package/docs/en/17_WHATSAPP_CONNECTOR_GUIDE.md +14 -0
  360. package/docs/en/18_FEISHU_CONNECTOR_GUIDE.md +14 -0
  361. package/docs/en/21_LOCAL_MODEL_BACKENDS_GUIDE.md +386 -0
  362. package/docs/en/22_BENCHSTORE_YAML_REFERENCE.md +469 -0
  363. package/docs/en/23_BENCHSTORE_GITHUB_RELEASES_SPEC.md +316 -0
  364. package/docs/en/24_CLAUDE_CODE_PROVIDER_SETUP.md +469 -0
  365. package/docs/en/25_OPENCODE_PROVIDER_SETUP.md +653 -0
  366. package/docs/en/26_CITATION_AND_ATTRIBUTION.md +119 -0
  367. package/docs/en/27_KIMI_CODE_PROVIDER_SETUP.md +180 -0
  368. package/docs/en/28_DISCORD_CONNECTOR_GUIDE.md +61 -0
  369. package/docs/en/29_SLACK_CONNECTOR_GUIDE.md +60 -0
  370. package/docs/en/30_SETTINGS_CONTROL_CENTER_GUIDE.md +371 -0
  371. package/docs/en/{19_LOCAL_BROWSER_AUTH.md → 31_LOCAL_BROWSER_AUTH.md} +1 -1
  372. package/docs/en/32_WINDOWS_WSL2_DEPLOYMENT_GUIDE.md +273 -0
  373. package/docs/en/33_WORKSPACE_EXPLORER_QA.md +121 -0
  374. package/docs/en/91_DEVELOPMENT.md +266 -0
  375. package/docs/en/99_ACKNOWLEDGEMENTS.md +24 -19
  376. package/docs/en/README.md +48 -7
  377. package/docs/images/admin/admin-connectors-health-en.png +0 -0
  378. package/docs/images/admin/admin-controllers-en.png +0 -0
  379. package/docs/images/admin/admin-diagnostics-en.png +0 -0
  380. package/docs/images/admin/admin-errors-en.png +0 -0
  381. package/docs/images/admin/admin-issues-en.png +0 -0
  382. package/docs/images/admin/admin-logs-en.png +0 -0
  383. package/docs/images/admin/admin-quest-detail-en.png +0 -0
  384. package/docs/images/admin/admin-quests-en.png +0 -0
  385. package/docs/images/admin/admin-repairs-en.png +0 -0
  386. package/docs/images/admin/admin-runtime-en.png +0 -0
  387. package/docs/images/admin/admin-search-en.png +0 -0
  388. package/docs/images/admin/admin-stats-en.png +0 -0
  389. package/docs/images/admin/admin-summary-en.png +0 -0
  390. package/docs/images/connectors/connector-discord-en.png +0 -0
  391. package/docs/images/connectors/connector-feishu-en.png +0 -0
  392. package/docs/images/connectors/connector-lingzhu-en.png +0 -0
  393. package/docs/images/connectors/connector-qq-en.png +0 -0
  394. package/docs/images/connectors/connector-slack-en.png +0 -0
  395. package/docs/images/connectors/connector-telegram-en.png +0 -0
  396. package/docs/images/connectors/connector-weixin-en.png +0 -0
  397. package/docs/images/connectors/connector-whatsapp-en.png +0 -0
  398. package/docs/images/settings/settings-baselines-en.png +0 -0
  399. package/docs/images/settings/settings-config-en.png +0 -0
  400. package/docs/images/settings/settings-connectors-overview-en.png +0 -0
  401. package/docs/images/settings/settings-deepxiv-en.png +0 -0
  402. package/docs/images/settings/settings-mcp-servers-en.png +0 -0
  403. package/docs/images/settings/settings-plugins-en.png +0 -0
  404. package/docs/images/settings/settings-runners-en.png +0 -0
  405. package/docs/zh/00_QUICK_START.md +142 -18
  406. package/docs/zh/01_SETTINGS_REFERENCE.md +219 -98
  407. package/docs/zh/02_START_RESEARCH_GUIDE.md +26 -5
  408. package/docs/zh/05_TUI_GUIDE.md +171 -2
  409. package/docs/zh/07_MEMORY_AND_MCP.md +29 -2
  410. package/docs/zh/09_DOCTOR.md +54 -8
  411. package/docs/zh/10_WEIXIN_CONNECTOR_GUIDE.md +24 -1
  412. package/docs/zh/11_LICENSE_AND_RISK.md +4 -0
  413. package/docs/zh/12_GUIDED_WORKFLOW_TOUR.md +15 -0
  414. package/docs/zh/14_PROMPT_SKILLS_AND_MCP_GUIDE.md +9 -0
  415. package/docs/zh/15_CODEX_PROVIDER_SETUP.md +552 -181
  416. package/docs/zh/21_LOCAL_MODEL_BACKENDS_GUIDE.md +384 -0
  417. package/docs/zh/22_BENCHSTORE_YAML_REFERENCE.md +459 -0
  418. package/docs/zh/23_BENCHSTORE_GITHUB_RELEASES_SPEC.md +287 -0
  419. package/docs/zh/23_CLAUDE_RUNNER_GUIDE.md +103 -0
  420. package/docs/zh/24_CLAUDE_CODE_PROVIDER_SETUP.md +460 -0
  421. package/docs/zh/25_OPENCODE_PROVIDER_SETUP.md +660 -0
  422. package/docs/zh/26_CITATION_AND_ATTRIBUTION.md +102 -0
  423. package/docs/zh/27_KIMI_CODE_PROVIDER_SETUP.md +51 -0
  424. package/docs/zh/{19_LOCAL_BROWSER_AUTH.md → 31_LOCAL_BROWSER_AUTH.md} +1 -1
  425. package/docs/zh/32_WINDOWS_WSL2_DEPLOYMENT_GUIDE.md +264 -0
  426. package/docs/zh/33_WORKSPACE_EXPLORER_QA.md +127 -0
  427. package/docs/zh/99_ACKNOWLEDGEMENTS.md +23 -19
  428. package/docs/zh/README.md +33 -7
  429. package/install.sh +168 -20
  430. package/package.json +5 -1
  431. package/pyproject.toml +2 -1
  432. package/src/deepscientist/__init__.py +1 -1
  433. package/src/deepscientist/acp/envelope.py +13 -0
  434. package/src/deepscientist/admin/__init__.py +3 -0
  435. package/src/deepscientist/admin/charts.py +681 -0
  436. package/src/deepscientist/admin/logs.py +119 -0
  437. package/src/deepscientist/admin/repairs.py +217 -0
  438. package/src/deepscientist/admin/service.py +1310 -0
  439. package/src/deepscientist/admin/system_info.py +700 -0
  440. package/src/deepscientist/admin/tasks.py +465 -0
  441. package/src/deepscientist/admin/tool_metrics.py +600 -0
  442. package/src/deepscientist/artifact/guidance.py +8 -4
  443. package/src/deepscientist/artifact/schemas.py +115 -0
  444. package/src/deepscientist/artifact/service.py +4268 -260
  445. package/src/deepscientist/bash_exec/monitor.py +30 -3
  446. package/src/deepscientist/bash_exec/service.py +134 -1
  447. package/src/deepscientist/benchstore/__init__.py +4 -0
  448. package/src/deepscientist/benchstore/prompt_builder.py +224 -0
  449. package/src/deepscientist/benchstore/service.py +1716 -0
  450. package/src/deepscientist/bridges/connectors.py +8 -2
  451. package/src/deepscientist/channels/weixin_ilink.py +8 -1
  452. package/src/deepscientist/cli.py +92 -17
  453. package/src/deepscientist/codex_cli_compat.py +187 -74
  454. package/src/deepscientist/config/models.py +82 -11
  455. package/src/deepscientist/config/service.py +1077 -93
  456. package/src/deepscientist/connector/weixin_support.py +48 -17
  457. package/src/deepscientist/daemon/api/handlers.py +827 -235
  458. package/src/deepscientist/daemon/api/router.py +81 -1
  459. package/src/deepscientist/daemon/app.py +1512 -85
  460. package/src/deepscientist/diagnostics/__init__.py +6 -0
  461. package/src/deepscientist/diagnostics/runner_failures.py +277 -0
  462. package/src/deepscientist/doctor.py +407 -56
  463. package/src/deepscientist/evidence_packets.py +590 -0
  464. package/src/deepscientist/home.py +52 -4
  465. package/src/deepscientist/kimi_cli_compat.py +50 -0
  466. package/src/deepscientist/latex_runtime.py +2 -2
  467. package/src/deepscientist/mcp/context.py +2 -0
  468. package/src/deepscientist/mcp/schemas.py +114 -0
  469. package/src/deepscientist/mcp/server.py +1566 -126
  470. package/src/deepscientist/memory/service.py +203 -16
  471. package/src/deepscientist/process_control.py +8 -1
  472. package/src/deepscientist/prompts/builder.py +850 -88
  473. package/src/deepscientist/quest/__init__.py +2 -2
  474. package/src/deepscientist/quest/layout.py +12 -1
  475. package/src/deepscientist/quest/node_traces.py +10 -0
  476. package/src/deepscientist/quest/service.py +1852 -161
  477. package/src/deepscientist/quest/stage_views.py +1 -1
  478. package/src/deepscientist/runners/__init__.py +18 -0
  479. package/src/deepscientist/runners/base.py +89 -1
  480. package/src/deepscientist/runners/builtins.py +13 -1
  481. package/src/deepscientist/runners/claude.py +391 -0
  482. package/src/deepscientist/runners/codex.py +480 -35
  483. package/src/deepscientist/runners/codex_telemetry.py +127 -0
  484. package/src/deepscientist/runners/kimi.py +334 -0
  485. package/src/deepscientist/runners/metadata.py +68 -0
  486. package/src/deepscientist/runners/opencode.py +414 -0
  487. package/src/deepscientist/runners/runtime_overrides.py +100 -0
  488. package/src/deepscientist/runners/simple_cli.py +538 -0
  489. package/src/deepscientist/runtime_storage.py +303 -0
  490. package/src/deepscientist/shared.py +80 -16
  491. package/src/deepscientist/skills/installer.py +37 -0
  492. package/src/deepscientist/skills/registry.py +2 -0
  493. package/src/deepscientist/tinytex.py +2 -2
  494. package/src/deepscientist/tui.py +10 -3
  495. package/src/prompts/benchstore/system.md +77 -0
  496. package/src/prompts/connectors/qq.md +33 -2
  497. package/src/prompts/connectors/weixin.md +208 -23
  498. package/src/prompts/contracts/admin_ops.md +74 -0
  499. package/src/prompts/contracts/admin_ops_knowledge.md +138 -0
  500. package/src/prompts/contracts/shared_interaction.md +5 -10
  501. package/src/prompts/start_setup/system.md +422 -0
  502. package/src/prompts/system.md +411 -304
  503. package/src/prompts/system_copilot.md +89 -0
  504. package/src/skills/analysis-campaign/SKILL.md +239 -578
  505. package/src/skills/analysis-campaign/references/artifact-flow-examples.md +102 -0
  506. package/src/skills/analysis-campaign/references/boundary-cases.md +98 -0
  507. package/src/skills/analysis-campaign/references/campaign-checklist-template.md +39 -24
  508. package/src/skills/analysis-campaign/references/campaign-design.md +26 -10
  509. package/src/skills/analysis-campaign/references/campaign-plan-template.md +53 -54
  510. package/src/skills/analysis-campaign/references/operational-guidance.md +97 -0
  511. package/src/skills/analysis-campaign/references/writing-facing-slice-examples.md +10 -20
  512. package/src/skills/baseline/SKILL.md +183 -461
  513. package/src/skills/baseline/references/artifact-flow-examples.md +106 -0
  514. package/src/skills/baseline/references/artifact-payload-examples.md +1 -1
  515. package/src/skills/baseline/references/baseline-checklist-template.md +27 -35
  516. package/src/skills/baseline/references/baseline-plan-template.md +37 -76
  517. package/src/skills/baseline/references/boundary-cases.md +86 -0
  518. package/src/skills/baseline/references/codebase-audit-checklist.md +2 -6
  519. package/src/skills/baseline/references/comparability-contract.md +7 -12
  520. package/src/skills/baseline/references/operational-guidance.md +56 -0
  521. package/src/skills/baseline/references/route-selection.md +5 -25
  522. package/src/skills/decision/SKILL.md +113 -306
  523. package/src/skills/decision/references/checkpoint-memory-template.md +47 -0
  524. package/src/skills/decision/references/operational-guidance.md +94 -0
  525. package/src/skills/decision/references/research-route-criteria.md +7 -8
  526. package/src/skills/decision/references/strategic-decision-template.md +13 -26
  527. package/src/skills/experiment/SKILL.md +132 -670
  528. package/src/skills/experiment/references/execution-playbook.md +374 -0
  529. package/src/skills/experiment/references/main-experiment-checklist-template.md +26 -2
  530. package/src/skills/experiment/references/main-experiment-plan-template.md +28 -17
  531. package/src/skills/experiment/references/operational-guidance.md +108 -0
  532. package/src/skills/finalize/SKILL.md +62 -0
  533. package/src/skills/finalize/references/checkpoint-memory-template.md +49 -0
  534. package/src/skills/finalize/references/resume-packet-template.md +7 -0
  535. package/src/skills/idea/SKILL.md +228 -15
  536. package/src/skills/idea/references/controlled-brainstorming-playbook.md +78 -0
  537. package/src/skills/idea/references/current-board-packet-template.md +61 -0
  538. package/src/skills/idea/references/high-value-idea-sourcing.md +119 -0
  539. package/src/skills/idea/references/idea-generation-playbook.md +21 -0
  540. package/src/skills/idea/references/idea-thinking-flow.md +6 -0
  541. package/src/skills/idea/references/literature-survey-template.md +3 -0
  542. package/src/skills/idea/references/objective-contract-template.md +54 -0
  543. package/src/skills/idea/references/outline-seeding-example.md +56 -0
  544. package/src/skills/idea/references/pre-idea-draft-template.md +105 -0
  545. package/src/skills/idea/references/related-work-playbook.md +75 -2
  546. package/src/skills/idea/references/research-history-playbook.md +114 -0
  547. package/src/skills/idea/references/selection-gate.md +58 -6
  548. package/src/skills/intake-audit/SKILL.md +43 -2
  549. package/src/skills/intake-audit/references/state-audit-template.md +10 -0
  550. package/src/skills/nature-data/SKILL.md +128 -0
  551. package/src/skills/nature-data/UPSTREAM_LICENSE.txt +21 -0
  552. package/src/skills/nature-data/agents/openai.yaml +4 -0
  553. package/src/skills/nature-data/references/chinese-author-alignment.md +84 -0
  554. package/src/skills/nature-data/references/fair-metadata-checklist.md +105 -0
  555. package/src/skills/nature-data/references/policy-principles.md +103 -0
  556. package/src/skills/nature-data/references/repository-and-identifiers.md +96 -0
  557. package/src/skills/nature-data/references/source-basis.md +54 -0
  558. package/src/skills/nature-data/references/statement-patterns.md +153 -0
  559. package/src/skills/nature-figure/SKILL.md +197 -0
  560. package/src/skills/nature-figure/UPSTREAM_LICENSE.txt +21 -0
  561. package/src/skills/nature-figure/agents/openai.yaml +4 -0
  562. package/src/skills/nature-figure/evals/evals.json +37 -0
  563. package/src/skills/nature-figure/references/api.md +428 -0
  564. package/src/skills/nature-figure/references/backend-selection.md +100 -0
  565. package/src/skills/nature-figure/references/chart-types.md +281 -0
  566. package/src/skills/nature-figure/references/common-patterns.md +349 -0
  567. package/src/skills/nature-figure/references/design-theory.md +436 -0
  568. package/src/skills/nature-figure/references/figure-contract.md +93 -0
  569. package/src/skills/nature-figure/references/nature-2026-observations.md +112 -0
  570. package/src/skills/nature-figure/references/qa-contract.md +119 -0
  571. package/src/skills/nature-figure/references/r-template-index.md +66 -0
  572. package/src/skills/nature-figure/references/r-workflow.md +161 -0
  573. package/src/skills/nature-figure/references/tutorials.md +250 -0
  574. package/src/skills/nature-paper2ppt/SKILL.md +507 -0
  575. package/src/skills/nature-paper2ppt/UPSTREAM_LICENSE.txt +21 -0
  576. package/src/skills/nature-paper2ppt/agents/openai.yaml +4 -0
  577. package/src/skills/nature-polishing/SKILL.md +385 -0
  578. package/src/skills/nature-polishing/UPSTREAM_LICENSE.txt +21 -0
  579. package/src/skills/nature-polishing/agents/openai.yaml +4 -0
  580. package/src/skills/nature-polishing/references/phrasebank-playbook.md +162 -0
  581. package/src/skills/nature-polishing/references/section-moves.md +240 -0
  582. package/src/skills/nature-polishing/references/style-guardrails.md +94 -0
  583. package/src/skills/nature-polishing/references/writing-strategy.md +148 -0
  584. package/src/skills/optimize/SKILL.md +177 -1568
  585. package/src/skills/optimize/references/brief-shaping-playbook.md +95 -0
  586. package/src/skills/optimize/references/candidate-board-template.md +13 -0
  587. package/src/skills/optimize/references/candidate-ranking-template.md +51 -0
  588. package/src/skills/optimize/references/codegen-route-playbook.md +50 -0
  589. package/src/skills/optimize/references/debug-response-template.md +29 -0
  590. package/src/skills/optimize/references/frontier-review-template.md +32 -0
  591. package/src/skills/optimize/references/fusion-playbook.md +36 -0
  592. package/src/skills/optimize/references/method-brief-template.md +73 -0
  593. package/src/skills/optimize/references/operational-guidance.md +621 -0
  594. package/src/skills/optimize/references/optimization-memory-template.md +30 -0
  595. package/src/skills/optimize/references/optimize-checklist-template.md +18 -0
  596. package/src/skills/optimize/references/plateau-response-playbook.md +28 -0
  597. package/src/skills/optimize/references/prompt-patterns.md +49 -0
  598. package/src/skills/paper-outline/SKILL.md +227 -0
  599. package/src/skills/paper-outline/references/outline-patterns.md +87 -0
  600. package/src/skills/paper-plot/SKILL.md +79 -0
  601. package/src/skills/paper-plot/agents/openai.yaml +4 -0
  602. package/src/skills/paper-plot/references/bar_grouped_hatch.md +96 -0
  603. package/src/skills/paper-plot/references/bar_paired_delta.md +72 -0
  604. package/src/skills/paper-plot/references/line_confidence_band.md +75 -0
  605. package/src/skills/paper-plot/references/line_loss_with_inset.md +65 -0
  606. package/src/skills/paper-plot/references/line_training_curve.md +44 -0
  607. package/src/skills/paper-plot/references/radar_dual_series.md +59 -0
  608. package/src/skills/paper-plot/references/scatter_broken_axis.md +59 -0
  609. package/src/skills/paper-plot/references/scatter_tsne_cluster.md +72 -0
  610. package/src/skills/paper-plot/scripts/bar_memevolve.py +109 -0
  611. package/src/skills/paper-plot/scripts/bar_spice.py +166 -0
  612. package/src/skills/paper-plot/scripts/line_aime.py +94 -0
  613. package/src/skills/paper-plot/scripts/line_loss_inset.py +157 -0
  614. package/src/skills/paper-plot/scripts/line_selfdistill.py +168 -0
  615. package/src/skills/paper-plot/scripts/radar_dora.py +151 -0
  616. package/src/skills/paper-plot/scripts/scatter_break.py +169 -0
  617. package/src/skills/paper-plot/scripts/scatter_tsne.py +133 -0
  618. package/src/skills/rebuttal/SKILL.md +9 -0
  619. package/src/skills/references/tool-usage-by-stage.md +438 -0
  620. package/src/skills/review/SKILL.md +105 -7
  621. package/src/skills/science/PROVENANCE.md +44 -0
  622. package/src/skills/science/SKILL.md +137 -0
  623. package/src/skills/science/references/artifact-science-tool.md +110 -0
  624. package/src/skills/science/references/claim-type-discipline.md +56 -0
  625. package/src/skills/science/references/domain-index.md +422 -0
  626. package/src/skills/science/references/hpc-via-bash-exec.md +42 -0
  627. package/src/skills/science/references/package-check-playbook.md +64 -0
  628. package/src/skills/science/references/package-index.min.json +3616 -0
  629. package/src/skills/science/references/packages/abinit.md +80 -0
  630. package/src/skills/science/references/packages/acts.md +73 -0
  631. package/src/skills/science/references/packages/aiida-core.md +80 -0
  632. package/src/skills/science/references/packages/alamode.md +80 -0
  633. package/src/skills/science/references/packages/amuse.md +88 -0
  634. package/src/skills/science/references/packages/anndata.md +88 -0
  635. package/src/skills/science/references/packages/arbor.md +80 -0
  636. package/src/skills/science/references/packages/arc.md +73 -0
  637. package/src/skills/science/references/packages/astropy.md +88 -0
  638. package/src/skills/science/references/packages/astroquery.md +88 -0
  639. package/src/skills/science/references/packages/atomate2.md +80 -0
  640. package/src/skills/science/references/packages/atomsmltr.md +73 -0
  641. package/src/skills/science/references/packages/awkward.md +73 -0
  642. package/src/skills/science/references/packages/batman.md +88 -0
  643. package/src/skills/science/references/packages/biopython.md +88 -0
  644. package/src/skills/science/references/packages/bloqade.md +73 -0
  645. package/src/skills/science/references/packages/brian2.md +73 -0
  646. package/src/skills/science/references/packages/bullet3.md +73 -0
  647. package/src/skills/science/references/packages/calculix.md +80 -0
  648. package/src/skills/science/references/packages/cantera.md +73 -0
  649. package/src/skills/science/references/packages/cavity-md-ipi.md +80 -0
  650. package/src/skills/science/references/packages/ccdproc.md +88 -0
  651. package/src/skills/science/references/packages/celerite2.md +88 -0
  652. package/src/skills/science/references/packages/cellrank.md +73 -0
  653. package/src/skills/science/references/packages/cesm.md +80 -0
  654. package/src/skills/science/references/packages/chemicals.md +73 -0
  655. package/src/skills/science/references/packages/chempy.md +73 -0
  656. package/src/skills/science/references/packages/cirq.md +73 -0
  657. package/src/skills/science/references/packages/coffea.md +73 -0
  658. package/src/skills/science/references/packages/cp2k.md +88 -0
  659. package/src/skills/science/references/packages/custodian.md +80 -0
  660. package/src/skills/science/references/packages/dart.md +73 -0
  661. package/src/skills/science/references/packages/datamol.md +88 -0
  662. package/src/skills/science/references/packages/dd4hep.md +73 -0
  663. package/src/skills/science/references/packages/dealii.md +80 -0
  664. package/src/skills/science/references/packages/deepchem.md +88 -0
  665. package/src/skills/science/references/packages/delphes.md +73 -0
  666. package/src/skills/science/references/packages/devito.md +80 -0
  667. package/src/skills/science/references/packages/dftb.md +88 -0
  668. package/src/skills/science/references/packages/dftd4.md +88 -0
  669. package/src/skills/science/references/packages/dftk-jl.md +80 -0
  670. package/src/skills/science/references/packages/dolfinx.md +80 -0
  671. package/src/skills/science/references/packages/drake.md +73 -0
  672. package/src/skills/science/references/packages/dumux.md +73 -0
  673. package/src/skills/science/references/packages/elk.md +80 -0
  674. package/src/skills/science/references/packages/elmerfem.md +80 -0
  675. package/src/skills/science/references/packages/enzo-e.md +88 -0
  676. package/src/skills/science/references/packages/espresso.md +80 -0
  677. package/src/skills/science/references/packages/exoplanet.md +88 -0
  678. package/src/skills/science/references/packages/fairroot.md +73 -0
  679. package/src/skills/science/references/packages/fbpic.md +80 -0
  680. package/src/skills/science/references/packages/fdtdbath-meep.md +80 -0
  681. package/src/skills/science/references/packages/geant4.md +73 -0
  682. package/src/skills/science/references/packages/geosx.md +80 -0
  683. package/src/skills/science/references/packages/gprmax.md +80 -0
  684. package/src/skills/science/references/packages/gromacs.md +80 -0
  685. package/src/skills/science/references/packages/gwaslab.md +73 -0
  686. package/src/skills/science/references/packages/gz-sim.md +73 -0
  687. package/src/skills/science/references/packages/hail.md +88 -0
  688. package/src/skills/science/references/packages/hiphive.md +80 -0
  689. package/src/skills/science/references/packages/hoomd-blue.md +80 -0
  690. package/src/skills/science/references/packages/itensor.md +73 -0
  691. package/src/skills/science/references/packages/itensors-jl.md +73 -0
  692. package/src/skills/science/references/packages/jdftx.md +73 -0
  693. package/src/skills/science/references/packages/jobflow.md +80 -0
  694. package/src/skills/science/references/packages/kadanoffbaym-jl.md +73 -0
  695. package/src/skills/science/references/packages/kite.md +80 -0
  696. package/src/skills/science/references/packages/kratos.md +80 -0
  697. package/src/skills/science/references/packages/kwant.md +73 -0
  698. package/src/skills/science/references/packages/lammps.md +80 -0
  699. package/src/skills/science/references/packages/lightkurve.md +88 -0
  700. package/src/skills/science/references/packages/limix.md +73 -0
  701. package/src/skills/science/references/packages/maxwelllink.md +80 -0
  702. package/src/skills/science/references/packages/mcdc.md +73 -0
  703. package/src/skills/science/references/packages/meep.md +80 -0
  704. package/src/skills/science/references/packages/mfem.md +80 -0
  705. package/src/skills/science/references/packages/mitgcm.md +73 -0
  706. package/src/skills/science/references/packages/modflow6.md +73 -0
  707. package/src/skills/science/references/packages/molecool.md +73 -0
  708. package/src/skills/science/references/packages/mom6.md +73 -0
  709. package/src/skills/science/references/packages/moose.md +80 -0
  710. package/src/skills/science/references/packages/mpas-model.md +73 -0
  711. package/src/skills/science/references/packages/mujoco.md +73 -0
  712. package/src/skills/science/references/packages/mumax3.md +73 -0
  713. package/src/skills/science/references/packages/nekrs.md +80 -0
  714. package/src/skills/science/references/packages/nessi.md +73 -0
  715. package/src/skills/science/references/packages/nest-simulator.md +73 -0
  716. package/src/skills/science/references/packages/netket.md +73 -0
  717. package/src/skills/science/references/packages/neuron.md +73 -0
  718. package/src/skills/science/references/packages/nextflow.md +88 -0
  719. package/src/skills/science/references/packages/nwchem.md +88 -0
  720. package/src/skills/science/references/packages/openbabel.md +88 -0
  721. package/src/skills/science/references/packages/openems.md +80 -0
  722. package/src/skills/science/references/packages/openff-toolkit.md +88 -0
  723. package/src/skills/science/references/packages/openfoam-dev.md +80 -0
  724. package/src/skills/science/references/packages/openmc.md +73 -0
  725. package/src/skills/science/references/packages/openmm.md +80 -0
  726. package/src/skills/science/references/packages/openmoc.md +73 -0
  727. package/src/skills/science/references/packages/openmx.md +80 -0
  728. package/src/skills/science/references/packages/opensees.md +80 -0
  729. package/src/skills/science/references/packages/opensn.md +80 -0
  730. package/src/skills/science/references/packages/opm-simulators.md +73 -0
  731. package/src/skills/science/references/packages/oqupy.md +73 -0
  732. package/src/skills/science/references/packages/packmol.md +80 -0
  733. package/src/skills/science/references/packages/palabos.md +80 -0
  734. package/src/skills/science/references/packages/parflow.md +80 -0
  735. package/src/skills/science/references/packages/pennylane.md +88 -0
  736. package/src/skills/science/references/packages/perceval.md +73 -0
  737. package/src/skills/science/references/packages/phono3py.md +73 -0
  738. package/src/skills/science/references/packages/phonopy.md +73 -0
  739. package/src/skills/science/references/packages/photutils.md +88 -0
  740. package/src/skills/science/references/packages/picongpu.md +80 -0
  741. package/src/skills/science/references/packages/plink-ng.md +88 -0
  742. package/src/skills/science/references/packages/precice.md +73 -0
  743. package/src/skills/science/references/packages/psc.md +80 -0
  744. package/src/skills/science/references/packages/psi4.md +88 -0
  745. package/src/skills/science/references/packages/pybinding.md +73 -0
  746. package/src/skills/science/references/packages/pyfr.md +80 -0
  747. package/src/skills/science/references/packages/pyhf.md +73 -0
  748. package/src/skills/science/references/packages/pyiron_base.md +80 -0
  749. package/src/skills/science/references/packages/pylcp.md +73 -0
  750. package/src/skills/science/references/packages/pylith.md +80 -0
  751. package/src/skills/science/references/packages/pynbody.md +88 -0
  752. package/src/skills/science/references/packages/pysam.md +88 -0
  753. package/src/skills/science/references/packages/pyscf.md +88 -0
  754. package/src/skills/science/references/packages/q-e.md +73 -0
  755. package/src/skills/science/references/packages/qibo.md +73 -0
  756. package/src/skills/science/references/packages/qiskit.md +73 -0
  757. package/src/skills/science/references/packages/quantica-jl.md +73 -0
  758. package/src/skills/science/references/packages/quantumoptics-jl.md +73 -0
  759. package/src/skills/science/references/packages/quimb.md +73 -0
  760. package/src/skills/science/references/packages/qulacs.md +73 -0
  761. package/src/skills/science/references/packages/qutip.md +73 -0
  762. package/src/skills/science/references/packages/rdkit.md +88 -0
  763. package/src/skills/science/references/packages/rmg-py.md +73 -0
  764. package/src/skills/science/references/packages/root.md +73 -0
  765. package/src/skills/science/references/packages/scanpy.md +88 -0
  766. package/src/skills/science/references/packages/scikit-allel.md +88 -0
  767. package/src/skills/science/references/packages/scikit-bio.md +88 -0
  768. package/src/skills/science/references/packages/scqubits.md +73 -0
  769. package/src/skills/science/references/packages/scuff-em.md +80 -0
  770. package/src/skills/science/references/packages/scvi-tools.md +73 -0
  771. package/src/skills/science/references/packages/seissol.md +73 -0
  772. package/src/skills/science/references/packages/sfepy.md +80 -0
  773. package/src/skills/science/references/packages/sisl.md +73 -0
  774. package/src/skills/science/references/packages/smilei.md +80 -0
  775. package/src/skills/science/references/packages/snakemake.md +88 -0
  776. package/src/skills/science/references/packages/specfem3d-globe.md +80 -0
  777. package/src/skills/science/references/packages/specutils.md +88 -0
  778. package/src/skills/science/references/packages/spglib.md +80 -0
  779. package/src/skills/science/references/packages/squidpy.md +88 -0
  780. package/src/skills/science/references/packages/starry.md +88 -0
  781. package/src/skills/science/references/packages/strawberryfields.md +73 -0
  782. package/src/skills/science/references/packages/su2.md +80 -0
  783. package/src/skills/science/references/packages/sunny-jl.md +73 -0
  784. package/src/skills/science/references/packages/sw4.md +73 -0
  785. package/src/skills/science/references/packages/swift.md +88 -0
  786. package/src/skills/science/references/packages/tdnegf.md +73 -0
  787. package/src/skills/science/references/packages/tenpy.md +73 -0
  788. package/src/skills/science/references/packages/thermo.md +73 -0
  789. package/src/skills/science/references/packages/tkwant.md +73 -0
  790. package/src/skills/science/references/packages/tvb-root.md +73 -0
  791. package/src/skills/science/references/packages/uproot5.md +73 -0
  792. package/src/skills/science/references/packages/vampire.md +80 -0
  793. package/src/skills/science/references/packages/wannier_tools.md +73 -0
  794. package/src/skills/science/references/packages/warpx.md +80 -0
  795. package/src/skills/science/references/packages/wrf.md +73 -0
  796. package/src/skills/science/references/packages/xtb.md +88 -0
  797. package/src/skills/science/references/packages/yt.md +73 -0
  798. package/src/skills/science/references/science-task-brief-template.md +71 -0
  799. package/src/skills/scout/SKILL.md +83 -425
  800. package/src/skills/scout/references/literature-scout-template.md +5 -24
  801. package/src/skills/scout/references/operational-guidance.md +191 -0
  802. package/src/skills/scout/references/paper-triage-playbook.md +11 -35
  803. package/src/skills/write/SKILL.md +744 -1246
  804. package/src/skills/write/references/experiments_analysis_patterns.md +129 -0
  805. package/src/skills/write/references/oral_package_patterns.md +252 -0
  806. package/src/skills/write/references/oral_writing_principles.md +291 -0
  807. package/src/skills/write/references/section_rewrite_checklist.md +234 -0
  808. package/src/tui/dist/app/AppContainer.js +1314 -27
  809. package/src/tui/dist/components/Composer.js +26 -1
  810. package/src/tui/dist/components/ConfigScreen.js +2 -1
  811. package/src/tui/dist/components/InputPrompt.js +25 -9
  812. package/src/tui/dist/components/MainContent.js +18 -3
  813. package/src/tui/dist/components/QuestScreen.js +3 -2
  814. package/src/tui/dist/components/UtilityScreen.js +37 -0
  815. package/src/tui/dist/hooks/useSafeInput.js +10 -0
  816. package/src/tui/dist/index.js +13 -1
  817. package/src/tui/dist/layouts/DefaultAppLayout.js +11 -8
  818. package/src/tui/dist/lib/api.js +89 -1
  819. package/src/tui/package.json +1 -1
  820. package/src/ui/dist/assets/{AnalysisPlugin-DnSm0GZn.js → AnalysisPlugin-CA94NGmI.js} +1 -1
  821. package/src/ui/dist/assets/CliPlugin-DHBzphZU.js +79 -0
  822. package/src/ui/dist/assets/CodeEditorPlugin-BOFwD2rn.js +2 -0
  823. package/src/ui/dist/assets/{CodeViewerPlugin-itb0tltR.js → CodeViewerPlugin-CqDpgjik.js} +4 -4
  824. package/src/ui/dist/assets/{DocViewerPlugin-DqKkiCI6.js → DocViewerPlugin-UDBgt8-4.js} +3 -3
  825. package/src/ui/dist/assets/GitCommitViewerPlugin-BmHtZ0bZ.js +6 -0
  826. package/src/ui/dist/assets/{GitDiffViewerPlugin-DxL2ezFG.js → GitDiffViewerPlugin-CAxjNorQ.js} +2 -2
  827. package/src/ui/dist/assets/{GitSnapshotViewer-B_RQm1YZ.js → GitSnapshotViewer-CweA6VON.js} +2 -2
  828. package/src/ui/dist/assets/{ImageViewerPlugin-tHqlXY3n.js → ImageViewerPlugin-C8wHGvGN.js} +5 -5
  829. package/src/ui/dist/assets/LabPlugin-COyyLUol.js +32 -0
  830. package/src/ui/dist/assets/{LatexPlugin-B495DTXC.js → LatexPlugin-BQjAaA5J.js} +4 -4
  831. package/src/ui/dist/assets/{MarkdownViewerPlugin-DG28-61B.js → MarkdownViewerPlugin-Dy1NE2dI.js} +3 -3
  832. package/src/ui/dist/assets/{MarketplacePlugin-BiOGT-Kj.js → MarketplacePlugin-DMIZtEJ2.js} +2 -2
  833. package/src/ui/dist/assets/NotebookEditor-CFHMq_Qt.js +91 -0
  834. package/src/ui/dist/assets/{NotebookEditor-CVsj8h_T.js → NotebookEditor-WFyd8Ybt.js} +23 -23
  835. package/src/ui/dist/assets/{PdfLoader-CASDQmxJ.js → PdfLoader-CLE5u5TS.js} +3 -3
  836. package/src/ui/dist/assets/{PdfMarkdownPlugin-BFhwoKsY.js → PdfMarkdownPlugin-_iNK_H83.js} +1 -1
  837. package/src/ui/dist/assets/PdfViewerPlugin-DgWsbInT.js +22 -0
  838. package/src/ui/dist/assets/SearchPlugin-DrZmn5iw.js +11 -0
  839. package/src/ui/dist/assets/{TextViewerPlugin-CB4DYfWO.js → TextViewerPlugin-D1-T3aC7.js} +4 -4
  840. package/src/ui/dist/assets/branding/runner-claude.svg +107 -0
  841. package/src/ui/dist/assets/branding/runner-codex.svg +10 -0
  842. package/src/ui/dist/assets/branding/runner-kimi.svg +14 -0
  843. package/src/ui/dist/assets/branding/runner-opencode.svg +7 -0
  844. package/src/ui/dist/assets/cli-store-CoZ-x5Ip.js +1 -0
  845. package/src/ui/dist/assets/{code-DLC6G24T.js → code-DbsmSd3Y.js} +1 -1
  846. package/src/ui/dist/assets/file-diff-panel-DsvyRz47.js +1 -0
  847. package/src/ui/dist/assets/{wrap-text-CwMn-iqb.js → file-jump-queue-DeQBikaw.js} +3 -3
  848. package/src/ui/dist/assets/{file-socket-Cu4Qln7Y.js → file-socket-DA5XIx88.js} +1 -1
  849. package/src/ui/dist/assets/fonts/ds-fonts.css +50 -4
  850. package/src/ui/dist/assets/images/deepxiv/register-guide.png +0 -0
  851. package/src/ui/dist/assets/index-39vY9LmZ.js +1 -0
  852. package/src/ui/dist/assets/{index-wQ7RIIRd.js → index-BsO46tJA.js} +1 -1
  853. package/src/ui/dist/assets/index-CHzJ2xtB.js +3530 -0
  854. package/src/ui/dist/assets/index-DH-zxoZ3.css +33 -0
  855. package/src/ui/dist/assets/{plugin-notebook-HbW2K-1c.js → plugin-notebook-JRhysCqj.js} +2 -2
  856. package/src/ui/dist/assets/{project-sync-CsX08Qno.js → project-sync-DPmWKmKD.js} +1 -1
  857. package/src/ui/dist/assets/{zoom-out-R-GWEhzS.js → zoom-out-DAukFWen.js} +3 -3
  858. package/src/ui/dist/index.html +3 -3
  859. package/src/skills/analysis-campaign/references/artifact-orchestration.md +0 -58
  860. package/src/skills/baseline/references/memory-playbook.md +0 -40
  861. package/src/skills/baseline/references/publishable-baseline-package.md +0 -30
  862. package/src/skills/write/references/outline-evidence-contract-example.md +0 -107
  863. package/src/skills/write/references/paper-experiment-matrix-template.md +0 -131
  864. package/src/skills/write/references/paper-section-playbook.md +0 -64
  865. package/src/skills/write/references/reviewer-first-writing.md +0 -64
  866. package/src/skills/write/references/revision-checklist.md +0 -70
  867. package/src/skills/write/references/section-contracts.md +0 -82
  868. package/src/skills/write/references/sentence-level-proofing.md +0 -49
  869. package/src/ui/dist/assets/AiManusChatView-COFACy7V.js +0 -204
  870. package/src/ui/dist/assets/CliPlugin-CvwCmDQ5.js +0 -109
  871. package/src/ui/dist/assets/CodeEditorPlugin-cOqSa0xq.js +0 -2
  872. package/src/ui/dist/assets/GitCommitViewerPlugin-DVgNHBCS.js +0 -1
  873. package/src/ui/dist/assets/LabCopilotPanel-ClMbq5Yu.js +0 -14
  874. package/src/ui/dist/assets/LabPlugin-L_SuE8ow.js +0 -22
  875. package/src/ui/dist/assets/NotebookEditor-C-4Kt1p9.js +0 -81
  876. package/src/ui/dist/assets/PdfViewerPlugin-DcOzU9vd.js +0 -17
  877. package/src/ui/dist/assets/SearchPlugin-CHj7M58O.js +0 -16
  878. package/src/ui/dist/assets/VNCViewer-CjlbyCB3.js +0 -11
  879. package/src/ui/dist/assets/bot-CFkZY-JP.js +0 -6
  880. package/src/ui/dist/assets/chevron-up-Dq5ofbht.js +0 -6
  881. package/src/ui/dist/assets/file-content-Dv4LoZec.js +0 -1
  882. package/src/ui/dist/assets/file-diff-panel-Denq-lC3.js +0 -1
  883. package/src/ui/dist/assets/file-jump-queue-DA-SdG__.js +0 -1
  884. package/src/ui/dist/assets/git-commit-horizontal-BUh6G52n.js +0 -6
  885. package/src/ui/dist/assets/image-B9HUUddG.js +0 -6
  886. package/src/ui/dist/assets/index-B2B1sg-M.js +0 -1
  887. package/src/ui/dist/assets/index-Cgla8biy.css +0 -33
  888. package/src/ui/dist/assets/index-DRyx7vAc.js +0 -1
  889. package/src/ui/dist/assets/index-Gbl53BNp.js +0 -2496
  890. package/src/ui/dist/assets/pdf-effect-queue-ZtnHFCAi.js +0 -6
  891. package/src/ui/dist/assets/popover-DL6h35vr.js +0 -1
  892. package/src/ui/dist/assets/select-DvmXt1yY.js +0 -11
  893. package/src/ui/dist/assets/sigma-7jpXazui.js +0 -6
  894. package/src/ui/dist/assets/trash-xA7kFt8i.js +0 -11
  895. package/src/ui/dist/assets/useCliAccess-DsMwDjOp.js +0 -1
  896. package/src/ui/dist/assets/useFileDiffOverlay-FuhcnKiw.js +0 -1
@@ -11,17 +11,35 @@ from typing import Any
11
11
 
12
12
  from ..artifact import ArtifactService
13
13
  from ..codex_cli_compat import (
14
+ active_provider_metadata_from_home,
14
15
  materialize_codex_runtime_home,
15
16
  normalize_codex_reasoning_effort,
16
17
  provider_profile_metadata_from_home,
17
18
  )
18
19
  from ..config import ConfigManager
20
+ from ..evidence_packets import compact_runner_tool_event
19
21
  from ..gitops import export_git_graph
22
+ from ..process_control import process_session_popen_kwargs
20
23
  from ..prompts import PromptBuilder
21
24
  from ..runtime_logs import JsonlLogger
22
- from ..shared import append_jsonl, ensure_dir, generate_id, read_yaml, resolve_runner_binary, utc_now, write_json, write_text
25
+ from ..shared import append_jsonl, ensure_dir, ensure_utf8_subprocess_env, generate_id, read_yaml, resolve_runner_binary, utc_now, write_json, write_text
23
26
  from ..web_search import extract_web_search_payload
24
- from .base import RunRequest, RunResult
27
+ from .base import (
28
+ SETTINGS_ISSUE_CUSTOM_PROFILE,
29
+ START_SETUP_PREPARE_PROFILE,
30
+ RunRequest,
31
+ RunResult,
32
+ builtin_mcp_server_names_for_custom_profile,
33
+ extract_start_setup_patch_from_text,
34
+ extract_start_setup_session_patch_from_text,
35
+ resolve_mcp_tool_profile_for_quest,
36
+ )
37
+ from .codex_telemetry import (
38
+ DEFAULT_TURN_TOOL_CALL_BUDGET,
39
+ _finalize_tool_budget_telemetry,
40
+ _new_tool_budget_telemetry,
41
+ _record_tool_budget_event,
42
+ )
25
43
 
26
44
  _TOOL_EVENT_ARGS_TEXT_LIMIT = 8_000
27
45
  _TOOL_EVENT_OUTPUT_TEXT_LIMIT = 16_000
@@ -37,6 +55,7 @@ _BUILTIN_MCP_TOOL_APPROVALS: dict[str, tuple[str, ...]] = {
37
55
  ),
38
56
  "artifact": (
39
57
  "record",
58
+ "science",
40
59
  "checkpoint",
41
60
  "prepare_branch",
42
61
  "activate_branch",
@@ -44,6 +63,10 @@ _BUILTIN_MCP_TOOL_APPROVALS: dict[str, tuple[str, ...]] = {
44
63
  "list_research_branches",
45
64
  "resolve_runtime_refs",
46
65
  "get_paper_contract_health",
66
+ "validate_manuscript_coverage",
67
+ "validate_academic_outline",
68
+ "validate_manuscript_language",
69
+ "compile_outline_to_writing_plan",
47
70
  "get_quest_state",
48
71
  "get_global_status",
49
72
  "get_method_scoreboard",
@@ -60,6 +83,7 @@ _BUILTIN_MCP_TOOL_APPROVALS: dict[str, tuple[str, ...]] = {
60
83
  "publish_baseline",
61
84
  "attach_baseline",
62
85
  "confirm_baseline",
86
+ "overwrite_baseline",
63
87
  "waive_baseline",
64
88
  "arxiv",
65
89
  "refresh_summary",
@@ -72,10 +96,82 @@ _BUILTIN_MCP_TOOL_APPROVALS: dict[str, tuple[str, ...]] = {
72
96
  ),
73
97
  }
74
98
 
99
+
100
+ def _builtin_mcp_tool_approvals_for_profile(custom_profile: str | None) -> dict[str, tuple[str, ...]]:
101
+ normalized = str(custom_profile or "").strip().lower()
102
+ if normalized == SETTINGS_ISSUE_CUSTOM_PROFILE:
103
+ return {
104
+ "artifact": ("prepare_github_issue",),
105
+ "bash_exec": _BUILTIN_MCP_TOOL_APPROVALS.get("bash_exec", ()),
106
+ }
107
+ if normalized == START_SETUP_PREPARE_PROFILE:
108
+ return {
109
+ "artifact": ("prepare_start_setup_form",),
110
+ "bash_exec": _BUILTIN_MCP_TOOL_APPROVALS.get("bash_exec", ()),
111
+ }
112
+ return _BUILTIN_MCP_TOOL_APPROVALS
113
+
75
114
  _PROVIDER_ENV_CONFLICT_KEYS = (
76
115
  "OPENAI_API_KEY",
77
116
  "OPENAI_BASE_URL",
78
117
  )
118
+ _CHAT_WIRE_TOOL_CALL_GUARD_MARKER = "## Codex Chat-Wire Tool Call Compatibility"
119
+ _WINDOWS_GBK_SAFE_REPLACEMENTS: dict[str, str] = {
120
+ "•": "-",
121
+ "…": "...",
122
+ "→": "->",
123
+ "←": "<-",
124
+ "↔": "<->",
125
+ "≤": "<=",
126
+ "≥": ">=",
127
+ "—": "-",
128
+ "–": "-",
129
+ "✓": "[ok]",
130
+ "✗": "[x]",
131
+ "✨": "*",
132
+ "🚀": "[launch]",
133
+ "📄": "[file]",
134
+ "📊": "[chart]",
135
+ "📌": "[pin]",
136
+ "💡": "[idea]",
137
+ "📎": "[attachment]",
138
+ "̀": "",
139
+ "́": "",
140
+ }
141
+
142
+
143
+ def _usage_metrics_from_event(event: dict[str, Any]) -> dict[str, int]:
144
+ candidates: list[dict[str, Any]] = []
145
+ for key in ("usage", "token_usage", "turn_usage"):
146
+ value = event.get(key)
147
+ if isinstance(value, dict):
148
+ candidates.append(value)
149
+ item = event.get("item")
150
+ if isinstance(item, dict):
151
+ for key in ("usage", "token_usage", "turn_usage"):
152
+ value = item.get(key)
153
+ if isinstance(value, dict):
154
+ candidates.append(value)
155
+ aliases = {
156
+ "input_tokens": ("input_tokens", "prompt_tokens"),
157
+ "cached_input_tokens": ("cached_input_tokens", "cached_tokens", "cached_prompt_tokens"),
158
+ "output_tokens": ("output_tokens", "completion_tokens"),
159
+ "total_tokens": ("total_tokens",),
160
+ }
161
+ merged: dict[str, int] = {}
162
+ for candidate in candidates:
163
+ for target, source_keys in aliases.items():
164
+ if target in merged:
165
+ continue
166
+ for key in source_keys:
167
+ value = candidate.get(key)
168
+ if isinstance(value, int):
169
+ merged[target] = value
170
+ break
171
+ if isinstance(value, float):
172
+ merged[target] = int(value)
173
+ break
174
+ return merged
79
175
 
80
176
 
81
177
  def _compact_text(value: object, *, limit: int = 1200) -> str:
@@ -93,6 +189,29 @@ def _compact_text(value: object, *, limit: int = 1200) -> str:
93
189
  return text[: limit - 1].rstrip() + "…"
94
190
 
95
191
 
192
+ def _sanitize_text_for_windows_gbk(text: str) -> tuple[str, dict[str, str]]:
193
+ source = str(text or "")
194
+ if not source:
195
+ return source, {}
196
+ try:
197
+ source.encode("gbk")
198
+ return source, {}
199
+ except UnicodeEncodeError:
200
+ pass
201
+
202
+ replacements: dict[str, str] = {}
203
+ rendered: list[str] = []
204
+ for char in source:
205
+ try:
206
+ char.encode("gbk")
207
+ rendered.append(char)
208
+ except UnicodeEncodeError:
209
+ replacement = _WINDOWS_GBK_SAFE_REPLACEMENTS.get(char, "?")
210
+ replacements.setdefault(char, replacement)
211
+ rendered.append(replacement)
212
+ return "".join(rendered), replacements
213
+
214
+
96
215
  def _truncate_leaf_text(text: str, *, limit: int) -> str:
97
216
  if limit <= 0 or len(text) <= limit:
98
217
  return text
@@ -461,6 +580,56 @@ def _mcp_result_payload(item: dict[str, Any]) -> dict[str, Any]:
461
580
  return {}
462
581
 
463
582
 
583
+ def _parse_single_text_content(value: Any) -> Any | None:
584
+ if not isinstance(value, list) or len(value) != 1:
585
+ return None
586
+ item = value[0]
587
+ if not isinstance(item, dict):
588
+ return None
589
+ text = item.get("text")
590
+ if not isinstance(text, str) or not text.strip():
591
+ return None
592
+ try:
593
+ return json.loads(text)
594
+ except json.JSONDecodeError:
595
+ return text
596
+
597
+
598
+ def _raw_tool_result_payload(event: dict[str, Any]) -> Any | None:
599
+ item = event.get("item") if isinstance(event.get("item"), dict) else {}
600
+ item_type = str(item.get("type") or event.get("item_type") or "")
601
+ if item_type == "mcp_tool_call":
602
+ result = item.get("result")
603
+ if isinstance(result, dict):
604
+ structured = result.get("structured_content") or result.get("structuredContent")
605
+ if structured is not None:
606
+ return structured
607
+ parsed_content = _parse_single_text_content(result.get("content"))
608
+ if parsed_content is not None:
609
+ return parsed_content
610
+ return result
611
+ if result is not None:
612
+ return result
613
+
614
+ for value in (
615
+ item.get("result"),
616
+ item.get("aggregated_output"),
617
+ item.get("changes"),
618
+ item.get("output"),
619
+ item.get("content"),
620
+ item.get("error"),
621
+ event.get("result"),
622
+ event.get("aggregated_output"),
623
+ event.get("changes"),
624
+ event.get("output"),
625
+ event.get("content"),
626
+ event.get("error"),
627
+ ):
628
+ if value is not None:
629
+ return value
630
+ return None
631
+
632
+
464
633
  def _mcp_tool_metadata(
465
634
  *,
466
635
  quest_id: str,
@@ -731,6 +900,20 @@ class CodexRunner:
731
900
  self._process_lock = threading.Lock()
732
901
  self._active_processes: dict[str, subprocess.Popen[str]] = {}
733
902
 
903
+ @staticmethod
904
+ def _subprocess_popen_kwargs(*, workspace_root: Path, env: dict[str, str]) -> dict[str, Any]:
905
+ return {
906
+ "cwd": str(workspace_root),
907
+ "env": env,
908
+ "stdin": subprocess.PIPE,
909
+ "stdout": subprocess.PIPE,
910
+ "stderr": subprocess.PIPE,
911
+ "text": True,
912
+ "encoding": "utf-8",
913
+ "errors": "replace",
914
+ **process_session_popen_kwargs(hide_window=True),
915
+ }
916
+
734
917
  def run(self, request: RunRequest) -> RunResult:
735
918
  workspace_root = request.worktree_root or request.quest_root
736
919
  run_root = ensure_dir(request.quest_root / ".ds" / "runs" / request.run_id)
@@ -746,7 +929,17 @@ class CodexRunner:
746
929
  turn_mode=request.turn_mode,
747
930
  retry_context=request.retry_context,
748
931
  )
932
+ prompt = self._apply_chat_wire_tool_call_guard(prompt, runner_config=runner_config)
933
+ prompt_to_send = prompt
934
+ prompt_sanitization: dict[str, str] = {}
935
+ sanitized_prompt_path: str | None = None
936
+ if os.name == "nt":
937
+ prompt_to_send, prompt_sanitization = _sanitize_text_for_windows_gbk(prompt)
749
938
  write_text(run_root / "prompt.md", prompt)
939
+ if prompt_sanitization:
940
+ sanitized_path = run_root / "prompt.windows-gbk-sanitized.md"
941
+ write_text(sanitized_path, prompt_to_send)
942
+ sanitized_prompt_path = str(sanitized_path)
750
943
 
751
944
  codex_home = self._prepare_project_codex_home(
752
945
  workspace_root,
@@ -755,7 +948,7 @@ class CodexRunner:
755
948
  run_id=request.run_id,
756
949
  runner_config=runner_config,
757
950
  )
758
- command = self._build_command(request, prompt, runner_config=runner_config)
951
+ command = self._build_command(request, prompt_to_send, runner_config=runner_config)
759
952
  write_json(
760
953
  run_root / "command.json",
761
954
  {
@@ -767,8 +960,39 @@ class CodexRunner:
767
960
  "turn_reason": request.turn_reason,
768
961
  "turn_intent": request.turn_intent,
769
962
  "turn_mode": request.turn_mode,
963
+ "windows_gbk_prompt_sanitized": bool(prompt_sanitization),
964
+ "windows_gbk_sanitized_prompt_path": sanitized_prompt_path,
965
+ "windows_gbk_replacements": prompt_sanitization,
770
966
  },
771
967
  )
968
+ configured_tool_budget = runner_config.get("tool_call_budget")
969
+ if not isinstance(configured_tool_budget, int):
970
+ configured_tool_budget = DEFAULT_TURN_TOOL_CALL_BUDGET
971
+ tool_budget_telemetry = _new_tool_budget_telemetry(tool_call_budget=configured_tool_budget)
972
+ telemetry: dict[str, Any] = {
973
+ "version": 1,
974
+ "quest_id": request.quest_id,
975
+ "run_id": request.run_id,
976
+ "skill_id": request.skill_id,
977
+ "turn_reason": request.turn_reason,
978
+ "turn_intent": request.turn_intent,
979
+ "turn_mode": request.turn_mode,
980
+ "model": request.model,
981
+ "model_inherited": str(request.model or "").strip().lower()
982
+ in {"", "inherit", "default", "codex-default", "inherit_local_codex_default"},
983
+ "reasoning_effort": request.reasoning_effort,
984
+ "runner_profile": str(runner_config.get("profile") or "").strip() or None,
985
+ "prompt_bytes": len(prompt.encode("utf-8", errors="replace")),
986
+ "stdout_event_count": 0,
987
+ "stdout_bytes": 0,
988
+ "tool_result_count": 0,
989
+ "tool_result_bytes_total": 0,
990
+ "compacted_tool_result_count": 0,
991
+ "full_detail_tool_call_count": 0,
992
+ **tool_budget_telemetry,
993
+ "token_usage": {},
994
+ "created_at": utc_now(),
995
+ }
772
996
 
773
997
  env = dict(**os.environ)
774
998
  runner_env = runner_config.get("env") if isinstance(runner_config.get("env"), dict) else {}
@@ -783,6 +1007,7 @@ class CodexRunner:
783
1007
  env["CODEX_HOME"] = str(codex_home)
784
1008
  env = self._sanitize_provider_env(env, runner_config=runner_config)
785
1009
  env["DEEPSCIENTIST_HOME"] = str(self.home)
1010
+ env["DEEPSCIENTIST_REPO_ROOT"] = str(self.repo_root)
786
1011
  env["DS_HOME"] = str(self.home)
787
1012
  env["DS_QUEST_ID"] = request.quest_id
788
1013
  env["DS_QUEST_ROOT"] = str(request.quest_root)
@@ -796,18 +1021,8 @@ class CodexRunner:
796
1021
  env["DS_CONVERSATION_ID"] = f"quest:{request.quest_id}"
797
1022
  env["DS_AGENT_ROLE"] = request.skill_id
798
1023
  env["DS_TEAM_MODE"] = "single"
799
- popen_kwargs: dict[str, Any] = {
800
- "cwd": str(workspace_root),
801
- "env": env,
802
- "stdin": subprocess.PIPE,
803
- "stdout": subprocess.PIPE,
804
- "stderr": subprocess.PIPE,
805
- "text": True,
806
- }
807
- if os.name == "nt" and hasattr(subprocess, "CREATE_NEW_PROCESS_GROUP"):
808
- popen_kwargs["creationflags"] = getattr(subprocess, "CREATE_NEW_PROCESS_GROUP")
809
- else:
810
- popen_kwargs["start_new_session"] = True
1024
+ env = ensure_utf8_subprocess_env(env)
1025
+ popen_kwargs = self._subprocess_popen_kwargs(workspace_root=workspace_root, env=env)
811
1026
  process = subprocess.Popen(command, **popen_kwargs)
812
1027
  with self._process_lock:
813
1028
  self._active_processes[request.quest_id] = process
@@ -815,11 +1030,6 @@ class CodexRunner:
815
1030
  assert process.stdout is not None
816
1031
  assert process.stderr is not None
817
1032
  try:
818
- process.stdin.write(prompt)
819
- process.stdin.close()
820
-
821
- output_parts: list[str] = []
822
- final_output_parts: list[str] = []
823
1033
  history_events = history_root / "events.jsonl"
824
1034
  stdout_events = run_root / "stdout.jsonl"
825
1035
  quest_events = request.quest_root / ".ds" / "events.jsonl"
@@ -838,15 +1048,74 @@ class CodexRunner:
838
1048
  "created_at": utc_now(),
839
1049
  },
840
1050
  )
1051
+ if prompt_sanitization:
1052
+ append_jsonl(
1053
+ quest_events,
1054
+ {
1055
+ "event_id": generate_id("evt"),
1056
+ "type": "runner.prompt_sanitized",
1057
+ "quest_id": request.quest_id,
1058
+ "run_id": request.run_id,
1059
+ "source": "codex",
1060
+ "skill_id": request.skill_id,
1061
+ "summary": (
1062
+ "Windows GBK-compatible prompt sanitization replaced non-encodable characters "
1063
+ "before sending the prompt to Codex."
1064
+ ),
1065
+ "replacements": prompt_sanitization,
1066
+ "created_at": utc_now(),
1067
+ },
1068
+ )
1069
+
1070
+ try:
1071
+ process.stdin.write(prompt_to_send)
1072
+ except UnicodeEncodeError as exc:
1073
+ if os.name == "nt" and not prompt_sanitization:
1074
+ prompt_to_send, prompt_sanitization = _sanitize_text_for_windows_gbk(prompt)
1075
+ if not prompt_sanitization:
1076
+ raise exc
1077
+ sanitized_path = run_root / "prompt.windows-gbk-sanitized.md"
1078
+ write_text(sanitized_path, prompt_to_send)
1079
+ append_jsonl(
1080
+ quest_events,
1081
+ {
1082
+ "event_id": generate_id("evt"),
1083
+ "type": "runner.prompt_sanitized",
1084
+ "quest_id": request.quest_id,
1085
+ "run_id": request.run_id,
1086
+ "source": "codex",
1087
+ "skill_id": request.skill_id,
1088
+ "summary": (
1089
+ "Windows GBK-compatible prompt sanitization retried after a UnicodeEncodeError "
1090
+ "while writing the prompt to Codex."
1091
+ ),
1092
+ "replacements": prompt_sanitization,
1093
+ "created_at": utc_now(),
1094
+ },
1095
+ )
1096
+ process.stdin.write(prompt_to_send)
1097
+ else:
1098
+ raise exc
1099
+ process.stdin.close()
1100
+
1101
+ output_parts: list[str] = []
1102
+ final_output_parts: list[str] = []
841
1103
 
842
1104
  for raw_line in process.stdout:
843
1105
  line = raw_line.rstrip("\n")
844
1106
  if not line:
845
1107
  continue
1108
+ telemetry["stdout_event_count"] = int(telemetry.get("stdout_event_count") or 0) + 1
1109
+ telemetry["stdout_bytes"] = int(telemetry.get("stdout_bytes") or 0) + len(
1110
+ line.encode("utf-8", errors="replace")
1111
+ )
846
1112
  try:
847
1113
  payload = json.loads(line)
848
1114
  except json.JSONDecodeError:
849
1115
  payload = {"raw": line}
1116
+ usage_metrics = _usage_metrics_from_event(payload)
1117
+ if usage_metrics:
1118
+ telemetry["token_usage"] = usage_metrics
850
1119
  timestamp = utc_now()
851
1120
  append_jsonl(history_events, {"timestamp": timestamp, "event": payload})
852
1121
  append_jsonl(stdout_events, {"timestamp": timestamp, "line": line})
@@ -866,6 +1135,39 @@ class CodexRunner:
866
1135
  created_at=timestamp,
867
1136
  )
868
1137
  if tool_event is not None:
1138
+ if str(tool_event.get("type") or "") == "runner.tool_call":
1139
+ _record_tool_budget_event(telemetry, tool_event)
1140
+ args_text = str(tool_event.get("args") or "")
1141
+ if "detail" in args_text and "full" in args_text.lower():
1142
+ telemetry["full_detail_tool_call_count"] = int(
1143
+ telemetry.get("full_detail_tool_call_count") or 0
1144
+ ) + 1
1145
+ if str(tool_event.get("type") or "") == "runner.tool_result":
1146
+ raw_tool_payload = _raw_tool_result_payload(payload)
1147
+ compaction_kwargs: dict[str, Any] = {}
1148
+ if raw_tool_payload is not None:
1149
+ compaction_kwargs["raw_payload"] = raw_tool_payload
1150
+ compacted_tool_event, compaction_meta = compact_runner_tool_event(
1151
+ tool_event,
1152
+ quest_root=request.quest_root,
1153
+ run_id=request.run_id,
1154
+ **compaction_kwargs,
1155
+ )
1156
+ tool_event = compacted_tool_event
1157
+ telemetry["tool_result_count"] = int(telemetry.get("tool_result_count") or 0) + 1
1158
+ telemetry["tool_result_bytes_total"] = int(
1159
+ telemetry.get("tool_result_bytes_total") or 0
1160
+ ) + int(
1161
+ compaction_meta.get("source_payload_bytes")
1162
+ or compaction_meta.get("output_bytes")
1163
+ or compaction_meta.get("payload_bytes")
1164
+ or 0
1165
+ )
1166
+ if bool(compaction_meta.get("compacted")):
1167
+ telemetry["compacted_tool_result_count"] = int(
1168
+ telemetry.get("compacted_tool_result_count") or 0
1169
+ ) + 1
1170
+ _record_tool_budget_event(telemetry, tool_event)
869
1171
  append_jsonl(quest_events, tool_event)
870
1172
  message_events, message_output_parts = _message_events(
871
1173
  payload,
@@ -896,6 +1198,18 @@ class CodexRunner:
896
1198
  )
897
1199
  or summary_text
898
1200
  )
1201
+ self._apply_start_setup_patch_fallback_if_present(
1202
+ request=request,
1203
+ output_text=output_text,
1204
+ quest_events=quest_events,
1205
+ )
1206
+ telemetry["exit_code"] = exit_code
1207
+ telemetry["stderr_bytes"] = len(stderr_text.encode("utf-8", errors="replace"))
1208
+ telemetry["output_text_bytes"] = len(output_text.encode("utf-8", errors="replace"))
1209
+ telemetry["completed_at"] = utc_now()
1210
+ _finalize_tool_budget_telemetry(telemetry)
1211
+ telemetry_path = run_root / "telemetry.json"
1212
+ write_json(telemetry_path, telemetry)
899
1213
  append_jsonl(
900
1214
  quest_events,
901
1215
  {
@@ -912,6 +1226,37 @@ class CodexRunner:
912
1226
  "created_at": utc_now(),
913
1227
  },
914
1228
  )
1229
+ append_jsonl(
1230
+ quest_events,
1231
+ {
1232
+ "event_id": generate_id("evt"),
1233
+ "type": "runner.turn_telemetry",
1234
+ "quest_id": request.quest_id,
1235
+ "run_id": request.run_id,
1236
+ "source": "codex",
1237
+ "skill_id": request.skill_id,
1238
+ "model": request.model,
1239
+ "prompt_bytes": telemetry.get("prompt_bytes"),
1240
+ "stdout_bytes": telemetry.get("stdout_bytes"),
1241
+ "tool_call_budget": telemetry.get("tool_call_budget"),
1242
+ "tool_call_count": telemetry.get("tool_call_count"),
1243
+ "tool_count": telemetry.get("tool_count"),
1244
+ "tool_call_budget_remaining": telemetry.get("tool_call_budget_remaining"),
1245
+ "tool_call_budget_exceeded": telemetry.get("tool_call_budget_exceeded"),
1246
+ "unique_command_count": telemetry.get("unique_command_count"),
1247
+ "read_tool_call_count": telemetry.get("read_tool_call_count"),
1248
+ "repeated_read_result_count": telemetry.get("repeated_read_result_count"),
1249
+ "repeated_read_ratio": telemetry.get("repeated_read_ratio"),
1250
+ "tool_result_bytes_total": telemetry.get("tool_result_bytes_total"),
1251
+ "compacted_tool_result_count": telemetry.get("compacted_tool_result_count"),
1252
+ "saved_bytes": telemetry.get("saved_bytes"),
1253
+ "full_detail_tool_call_count": telemetry.get("full_detail_tool_call_count"),
1254
+ "full_detail_count": telemetry.get("full_detail_count"),
1255
+ "token_usage": telemetry.get("token_usage"),
1256
+ "telemetry_path": str(telemetry_path),
1257
+ "created_at": utc_now(),
1258
+ },
1259
+ )
915
1260
  write_text(history_root / "assistant.md", (output_text or "") + ("\n" if output_text else ""))
916
1261
  write_text(run_root / "stderr.txt", stderr_text)
917
1262
  result_payload = {
@@ -921,6 +1266,7 @@ class CodexRunner:
921
1266
  "exit_code": exit_code,
922
1267
  "history_root": str(history_root),
923
1268
  "run_root": str(run_root),
1269
+ "telemetry_path": str(telemetry_path),
924
1270
  "output_text": output_text,
925
1271
  "stderr_text": stderr_text,
926
1272
  "completed_at": utc_now(),
@@ -1022,6 +1368,50 @@ class CodexRunner:
1022
1368
  process.wait(timeout=3)
1023
1369
  return interrupted
1024
1370
 
1371
+ def _apply_start_setup_patch_fallback_if_present(
1372
+ self,
1373
+ *,
1374
+ request: RunRequest,
1375
+ output_text: str,
1376
+ quest_events: Path,
1377
+ ) -> None:
1378
+ quest_yaml = read_yaml(request.quest_root / "quest.yaml", {})
1379
+ startup_contract = quest_yaml.get("startup_contract") if isinstance(quest_yaml.get("startup_contract"), dict) else {}
1380
+ if not isinstance(startup_contract.get("start_setup_session"), dict):
1381
+ return
1382
+ patch = extract_start_setup_patch_from_text(output_text)
1383
+ session_patch = extract_start_setup_session_patch_from_text(output_text)
1384
+ if not patch and not session_patch:
1385
+ return
1386
+ result = self.artifact_service.apply_start_setup_form_patch(
1387
+ request.quest_root,
1388
+ form_patch=patch,
1389
+ session_patch=session_patch,
1390
+ message="Applied from runner fallback `start_setup_patch` block.",
1391
+ )
1392
+ patch_keys = sorted(result.get("form_patch", {}).keys()) if isinstance(result.get("form_patch"), dict) else sorted((patch or {}).keys())
1393
+ append_jsonl(
1394
+ quest_events,
1395
+ {
1396
+ "event_id": generate_id("evt"),
1397
+ "type": "runner.turn_postprocess_info",
1398
+ "quest_id": request.quest_id,
1399
+ "run_id": request.run_id,
1400
+ "source": "codex",
1401
+ "skill_id": request.skill_id,
1402
+ "summary": (
1403
+ "Applied the fenced `start_setup_patch` fallback block to the quest startup form "
1404
+ "so the suggested form stays synchronized even when Codex answered with a patch block "
1405
+ "instead of a direct MCP tool call."
1406
+ ),
1407
+ "details": {
1408
+ "warning_code": "start_setup_patch_fallback_applied",
1409
+ "patch_keys": patch_keys,
1410
+ },
1411
+ "created_at": utc_now(),
1412
+ },
1413
+ )
1414
+
1025
1415
  def _build_command(self, request: RunRequest, prompt: str, *, runner_config: dict[str, Any] | None = None) -> list[str]:
1026
1416
  workspace_root = request.worktree_root or request.quest_root
1027
1417
  resolved_binary = resolve_runner_binary(self.binary, runner_name="codex")
@@ -1058,13 +1448,55 @@ class CodexRunner:
1058
1448
  tool_timeout_sec = self._positive_timeout_seconds(resolved_runner_config.get("mcp_tool_timeout_sec"))
1059
1449
  if tool_timeout_sec is not None:
1060
1450
  timeout_value = int(tool_timeout_sec) if float(tool_timeout_sec).is_integer() else float(tool_timeout_sec)
1061
- for server_name in ("memory", "artifact", "bash_exec"):
1451
+ custom_profile = resolve_mcp_tool_profile_for_quest(request.quest_root)
1452
+ server_names = builtin_mcp_server_names_for_custom_profile(custom_profile)
1453
+ for server_name in server_names:
1062
1454
  command.extend(["-c", f"mcp_servers.{server_name}.tool_timeout_sec={timeout_value}"])
1063
1455
  if request.sandbox_mode:
1064
1456
  command.extend(["--sandbox", request.sandbox_mode])
1065
1457
  command.append("-")
1066
1458
  return command
1067
1459
 
1460
+ def _apply_chat_wire_tool_call_guard(
1461
+ self,
1462
+ prompt: str,
1463
+ *,
1464
+ runner_config: dict[str, Any] | None = None,
1465
+ ) -> str:
1466
+ prompt_text = str(prompt or "")
1467
+ if not prompt_text or _CHAT_WIRE_TOOL_CALL_GUARD_MARKER in prompt_text:
1468
+ return prompt_text
1469
+
1470
+ resolved_runner_config = runner_config if isinstance(runner_config, dict) else self._load_runner_config()
1471
+ profile = str(resolved_runner_config.get("profile") or "").strip()
1472
+ if not profile:
1473
+ return prompt_text
1474
+ config_home = str(resolved_runner_config.get("config_dir") or os.environ.get("CODEX_HOME") or "").strip()
1475
+ if not config_home:
1476
+ return prompt_text
1477
+
1478
+ metadata = active_provider_metadata_from_home(config_home, profile=profile or None)
1479
+ wire_api = str(metadata.get("wire_api") or "").strip().lower()
1480
+ if wire_api != "chat":
1481
+ return prompt_text
1482
+
1483
+ provider = str(metadata.get("provider") or "").strip() or "unknown"
1484
+ guard_lines = [
1485
+ _CHAT_WIRE_TOOL_CALL_GUARD_MARKER,
1486
+ f"active_provider_profile: {profile}",
1487
+ f"active_provider_name: {provider}",
1488
+ "active_provider_wire_api: chat",
1489
+ "single_tool_call_per_turn_rule: emit at most one tool call in each assistant message.",
1490
+ "tool_call_serialization_rule: after each tool result, decide whether to make the next tool call or produce the answer.",
1491
+ "no_batched_mcp_rule: never bundle multiple `artifact.*`, `memory.*`, or `bash_exec.*` calls into the same response, even when the reads look independent.",
1492
+ "no_immediate_repeat_rule: if a tool already returned the information needed for the current subtask, do not immediately call that same tool again; move to the next tool or answer.",
1493
+ "state_recovery_preference_rule: on a fresh quest turn, prefer `artifact.get_quest_state`, `artifact.read_quest_documents`, and `memory.list_recent` to recover context before reaching for `bash_exec`.",
1494
+ "bash_exec_after_context_rule: use `bash_exec` only after you know the exact command you need and why the `artifact` / `memory` path is insufficient.",
1495
+ "tool_call_json_rule: every tool call must contain exactly one complete JSON object argument with no trailing characters.",
1496
+ ]
1497
+ guard_block = "\n".join(guard_lines)
1498
+ return f"{prompt_text.rstrip()}\n\n{guard_block}\n"
1499
+
1068
1500
  def _prepare_project_codex_home(
1069
1501
  self,
1070
1502
  workspace_root: Path,
@@ -1117,8 +1549,9 @@ class CodexRunner:
1117
1549
  resolved_runner_config = runner_config if isinstance(runner_config, dict) else self._load_runner_config()
1118
1550
  tool_timeout_sec = self._positive_timeout_seconds(resolved_runner_config.get("mcp_tool_timeout_sec"))
1119
1551
 
1120
- shared_env = {
1552
+ shared_env = ensure_utf8_subprocess_env({
1121
1553
  "DEEPSCIENTIST_HOME": str(self.home),
1554
+ "DEEPSCIENTIST_REPO_ROOT": str(self.repo_root),
1122
1555
  "DS_HOME": str(self.home),
1123
1556
  "DS_QUEST_ID": quest_id,
1124
1557
  "DS_QUEST_ROOT": str(quest_root),
@@ -1129,26 +1562,38 @@ class CodexRunner:
1129
1562
  "DS_CONVERSATION_ID": f"quest:{quest_id}",
1130
1563
  "DS_AGENT_ROLE": "pi",
1131
1564
  "DS_TEAM_MODE": "single",
1132
- }
1565
+ })
1566
+ custom_profile = resolve_mcp_tool_profile_for_quest(quest_root)
1567
+ if custom_profile:
1568
+ shared_env["DS_CUSTOM_PROFILE"] = custom_profile
1133
1569
  if pythonpath:
1134
1570
  shared_env["PYTHONPATH"] = pythonpath
1135
1571
 
1572
+ server_names = builtin_mcp_server_names_for_custom_profile(custom_profile)
1573
+ tool_approvals = _builtin_mcp_tool_approvals_for_profile(custom_profile)
1136
1574
  block = "\n".join(
1137
- [
1138
- marker_start,
1139
- self._mcp_block("memory", shared_env, tool_timeout_sec=tool_timeout_sec),
1140
- "",
1141
- self._mcp_block("artifact", shared_env, tool_timeout_sec=tool_timeout_sec),
1142
- "",
1143
- self._mcp_block("bash_exec", shared_env, tool_timeout_sec=tool_timeout_sec),
1144
- marker_end,
1575
+ [marker_start]
1576
+ + [
1577
+ item
1578
+ for index, name in enumerate(server_names)
1579
+ for item in (
1580
+ [self._mcp_block(name, shared_env, tool_timeout_sec=tool_timeout_sec, approvals=tool_approvals.get(name, ()))]
1581
+ + ([""] if index < len(server_names) - 1 else [])
1582
+ )
1145
1583
  ]
1584
+ + [marker_end]
1146
1585
  ).strip()
1147
1586
  new_text = f"{prefix}\n\n{block}\n" if prefix else f"{block}\n"
1148
1587
  write_text(config_path, new_text)
1149
1588
 
1150
1589
  @staticmethod
1151
- def _mcp_block(name: str, env: dict[str, str], *, tool_timeout_sec: float | None = None) -> str:
1590
+ def _mcp_block(
1591
+ name: str,
1592
+ env: dict[str, str],
1593
+ *,
1594
+ tool_timeout_sec: float | None = None,
1595
+ approvals: tuple[str, ...] = (),
1596
+ ) -> str:
1152
1597
  args = ["-m", "deepscientist.mcp.server", "--namespace", name]
1153
1598
  lines = [
1154
1599
  f"[mcp_servers.{name}]",
@@ -1167,7 +1612,7 @@ class CodexRunner:
1167
1612
  )
1168
1613
  for key, value in env.items():
1169
1614
  lines.append(f"{key} = {json.dumps(value)}")
1170
- for tool_name in _BUILTIN_MCP_TOOL_APPROVALS.get(name, ()):
1615
+ for tool_name in approvals:
1171
1616
  lines.extend(
1172
1617
  [
1173
1618
  "",
@@ -1202,9 +1647,9 @@ class CodexRunner:
1202
1647
  resolved_runner_config = runner_config if isinstance(runner_config, dict) else {}
1203
1648
  profile = str(resolved_runner_config.get("profile") or "").strip()
1204
1649
  config_home = str(resolved_runner_config.get("config_dir") or env.get("CODEX_HOME") or "").strip()
1205
- if not profile or not config_home:
1650
+ if not config_home:
1206
1651
  return env
1207
- metadata = provider_profile_metadata_from_home(config_home, profile=profile)
1652
+ metadata = active_provider_metadata_from_home(config_home, profile=profile or None)
1208
1653
  requires_openai_auth = metadata.get("requires_openai_auth")
1209
1654
  if requires_openai_auth is not False:
1210
1655
  return env