@stevenvo780/st-lang 4.14.0 → 4.15.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 (602) hide show
  1. package/README.md +6 -6
  2. package/dist/ast/nodes.d.ts +50 -0
  3. package/dist/ast/nodes.d.ts.map +1 -1
  4. package/dist/format/stnb/__tests__/executor.test.d.ts +2 -0
  5. package/dist/format/stnb/__tests__/executor.test.d.ts.map +1 -0
  6. package/dist/format/stnb/__tests__/executor.test.js +140 -0
  7. package/dist/format/stnb/__tests__/executor.test.js.map +1 -0
  8. package/dist/format/stnb/__tests__/parser.test.d.ts +2 -0
  9. package/dist/format/stnb/__tests__/parser.test.d.ts.map +1 -0
  10. package/dist/format/stnb/__tests__/parser.test.js +119 -0
  11. package/dist/format/stnb/__tests__/parser.test.js.map +1 -0
  12. package/dist/format/stnb/__tests__/renderer.test.d.ts +2 -0
  13. package/dist/format/stnb/__tests__/renderer.test.d.ts.map +1 -0
  14. package/dist/format/stnb/__tests__/renderer.test.js +109 -0
  15. package/dist/format/stnb/__tests__/renderer.test.js.map +1 -0
  16. package/dist/format/stnb/__tests__/roundtrip.test.d.ts +2 -0
  17. package/dist/format/stnb/__tests__/roundtrip.test.d.ts.map +1 -0
  18. package/dist/format/stnb/__tests__/roundtrip.test.js +91 -0
  19. package/dist/format/stnb/__tests__/roundtrip.test.js.map +1 -0
  20. package/dist/format/stnb/__tests__/serializer.test.d.ts +2 -0
  21. package/dist/format/stnb/__tests__/serializer.test.d.ts.map +1 -0
  22. package/dist/format/stnb/__tests__/serializer.test.js +60 -0
  23. package/dist/format/stnb/__tests__/serializer.test.js.map +1 -0
  24. package/dist/format/stnb/executor.d.ts +29 -0
  25. package/dist/format/stnb/executor.d.ts.map +1 -0
  26. package/dist/format/stnb/executor.js +139 -0
  27. package/dist/format/stnb/executor.js.map +1 -0
  28. package/dist/format/stnb/index.d.ts +19 -0
  29. package/dist/format/stnb/index.d.ts.map +1 -0
  30. package/dist/format/stnb/index.js +28 -0
  31. package/dist/format/stnb/index.js.map +1 -0
  32. package/dist/format/stnb/parser.d.ts +14 -0
  33. package/dist/format/stnb/parser.d.ts.map +1 -0
  34. package/dist/format/stnb/parser.js +123 -0
  35. package/dist/format/stnb/parser.js.map +1 -0
  36. package/dist/format/stnb/renderer-html.d.ts +11 -0
  37. package/dist/format/stnb/renderer-html.d.ts.map +1 -0
  38. package/dist/format/stnb/renderer-html.js +180 -0
  39. package/dist/format/stnb/renderer-html.js.map +1 -0
  40. package/dist/format/stnb/renderer-markdown.d.ts +13 -0
  41. package/dist/format/stnb/renderer-markdown.d.ts.map +1 -0
  42. package/dist/format/stnb/renderer-markdown.js +92 -0
  43. package/dist/format/stnb/renderer-markdown.js.map +1 -0
  44. package/dist/format/stnb/serializer.d.ts +14 -0
  45. package/dist/format/stnb/serializer.d.ts.map +1 -0
  46. package/dist/format/stnb/serializer.js +21 -0
  47. package/dist/format/stnb/serializer.js.map +1 -0
  48. package/dist/format/stnb/types.d.ts +45 -0
  49. package/dist/format/stnb/types.d.ts.map +1 -0
  50. package/dist/format/stnb/types.js +7 -0
  51. package/dist/format/stnb/types.js.map +1 -0
  52. package/dist/index.d.ts +5 -0
  53. package/dist/index.d.ts.map +1 -1
  54. package/dist/index.js +7 -1
  55. package/dist/index.js.map +1 -1
  56. package/dist/logic/profile-bridge/index.d.ts.map +1 -1
  57. package/dist/logic/profile-bridge/index.js +20 -3
  58. package/dist/logic/profile-bridge/index.js.map +1 -1
  59. package/dist/logic/profiles/classical/propositional.d.ts.map +1 -1
  60. package/dist/logic/profiles/classical/propositional.js.map +1 -1
  61. package/dist/logic/profiles/ctl/check.d.ts.map +1 -1
  62. package/dist/logic/profiles/ctl/check.js +21 -11
  63. package/dist/logic/profiles/ctl/check.js.map +1 -1
  64. package/dist/logic/profiles/ctl/witness.d.ts.map +1 -1
  65. package/dist/logic/profiles/ctl/witness.js +2 -0
  66. package/dist/logic/profiles/ctl/witness.js.map +1 -1
  67. package/dist/logic/profiles/description-logic/types.d.ts +15 -0
  68. package/dist/logic/profiles/description-logic/types.d.ts.map +1 -1
  69. package/dist/logic/profiles/description-logic/types.js +13 -0
  70. package/dist/logic/profiles/description-logic/types.js.map +1 -1
  71. package/dist/logic/profiles/dl-hybrid/__tests__/differential.test.d.ts +2 -0
  72. package/dist/logic/profiles/dl-hybrid/__tests__/differential.test.d.ts.map +1 -0
  73. package/dist/logic/profiles/dl-hybrid/__tests__/differential.test.js +141 -0
  74. package/dist/logic/profiles/dl-hybrid/__tests__/differential.test.js.map +1 -0
  75. package/dist/logic/profiles/dl-hybrid/__tests__/examples.test.d.ts +2 -0
  76. package/dist/logic/profiles/dl-hybrid/__tests__/examples.test.d.ts.map +1 -0
  77. package/dist/logic/profiles/dl-hybrid/__tests__/examples.test.js +55 -0
  78. package/dist/logic/profiles/dl-hybrid/__tests__/examples.test.js.map +1 -0
  79. package/dist/logic/profiles/dl-hybrid/__tests__/parser.test.d.ts +2 -0
  80. package/dist/logic/profiles/dl-hybrid/__tests__/parser.test.d.ts.map +1 -0
  81. package/dist/logic/profiles/dl-hybrid/__tests__/parser.test.js +149 -0
  82. package/dist/logic/profiles/dl-hybrid/__tests__/parser.test.js.map +1 -0
  83. package/dist/logic/profiles/dl-hybrid/__tests__/tableau.test.d.ts +2 -0
  84. package/dist/logic/profiles/dl-hybrid/__tests__/tableau.test.d.ts.map +1 -0
  85. package/dist/logic/profiles/dl-hybrid/__tests__/tableau.test.js +105 -0
  86. package/dist/logic/profiles/dl-hybrid/__tests__/tableau.test.js.map +1 -0
  87. package/dist/logic/profiles/dl-hybrid/ast.d.ts +160 -0
  88. package/dist/logic/profiles/dl-hybrid/ast.d.ts.map +1 -0
  89. package/dist/logic/profiles/dl-hybrid/ast.js +261 -0
  90. package/dist/logic/profiles/dl-hybrid/ast.js.map +1 -0
  91. package/dist/logic/profiles/dl-hybrid/differential.d.ts +61 -0
  92. package/dist/logic/profiles/dl-hybrid/differential.d.ts.map +1 -0
  93. package/dist/logic/profiles/dl-hybrid/differential.js +291 -0
  94. package/dist/logic/profiles/dl-hybrid/differential.js.map +1 -0
  95. package/dist/logic/profiles/dl-hybrid/index.d.ts +10 -0
  96. package/dist/logic/profiles/dl-hybrid/index.d.ts.map +1 -0
  97. package/dist/logic/profiles/dl-hybrid/index.js +90 -0
  98. package/dist/logic/profiles/dl-hybrid/index.js.map +1 -0
  99. package/dist/logic/profiles/dl-hybrid/parser.d.ts +8 -0
  100. package/dist/logic/profiles/dl-hybrid/parser.d.ts.map +1 -0
  101. package/dist/logic/profiles/dl-hybrid/parser.js +410 -0
  102. package/dist/logic/profiles/dl-hybrid/parser.js.map +1 -0
  103. package/dist/logic/profiles/dl-hybrid/profile.d.ts +23 -0
  104. package/dist/logic/profiles/dl-hybrid/profile.d.ts.map +1 -0
  105. package/dist/logic/profiles/dl-hybrid/profile.js +122 -0
  106. package/dist/logic/profiles/dl-hybrid/profile.js.map +1 -0
  107. package/dist/logic/profiles/dl-hybrid/semantics.d.ts +16 -0
  108. package/dist/logic/profiles/dl-hybrid/semantics.d.ts.map +1 -0
  109. package/dist/logic/profiles/dl-hybrid/semantics.js +181 -0
  110. package/dist/logic/profiles/dl-hybrid/semantics.js.map +1 -0
  111. package/dist/logic/profiles/dl-hybrid/tableau.d.ts +38 -0
  112. package/dist/logic/profiles/dl-hybrid/tableau.d.ts.map +1 -0
  113. package/dist/logic/profiles/dl-hybrid/tableau.js +289 -0
  114. package/dist/logic/profiles/dl-hybrid/tableau.js.map +1 -0
  115. package/dist/logic/profiles/hybrid-logic/types.d.ts +17 -0
  116. package/dist/logic/profiles/hybrid-logic/types.d.ts.map +1 -1
  117. package/dist/logic/profiles/hybrid-logic/types.js +17 -0
  118. package/dist/logic/profiles/hybrid-logic/types.js.map +1 -1
  119. package/dist/logic/profiles/intuitionistic-nj/kripke.d.ts.map +1 -1
  120. package/dist/logic/profiles/intuitionistic-nj/kripke.js +8 -5
  121. package/dist/logic/profiles/intuitionistic-nj/kripke.js.map +1 -1
  122. package/dist/logic/profiles/ltl-sat/tableau.d.ts +31 -0
  123. package/dist/logic/profiles/ltl-sat/tableau.d.ts.map +1 -1
  124. package/dist/logic/profiles/ltl-sat/tableau.js +18 -0
  125. package/dist/logic/profiles/ltl-sat/tableau.js.map +1 -1
  126. package/dist/logic/profiles/ltl-sat/types.d.ts +15 -0
  127. package/dist/logic/profiles/ltl-sat/types.d.ts.map +1 -1
  128. package/dist/logic/profiles/ltl-sat/types.js +2 -1
  129. package/dist/logic/profiles/ltl-sat/types.js.map +1 -1
  130. package/dist/logic/profiles/modal-frame-axioms/formula.d.ts +10 -0
  131. package/dist/logic/profiles/modal-frame-axioms/formula.d.ts.map +1 -1
  132. package/dist/logic/profiles/modal-frame-axioms/formula.js +10 -0
  133. package/dist/logic/profiles/modal-frame-axioms/formula.js.map +1 -1
  134. package/dist/logic/profiles/mu-calculus/check.d.ts.map +1 -1
  135. package/dist/logic/profiles/mu-calculus/check.js +7 -4
  136. package/dist/logic/profiles/mu-calculus/check.js.map +1 -1
  137. package/dist/logic/profiles/natural-deduction-nk/formula.d.ts +8 -0
  138. package/dist/logic/profiles/natural-deduction-nk/formula.d.ts.map +1 -1
  139. package/dist/logic/profiles/natural-deduction-nk/formula.js +8 -0
  140. package/dist/logic/profiles/natural-deduction-nk/formula.js.map +1 -1
  141. package/dist/logic/profiles/quantum/index.d.ts.map +1 -1
  142. package/dist/logic/profiles/quantum/index.js +11 -8
  143. package/dist/logic/profiles/quantum/index.js.map +1 -1
  144. package/dist/logic/profiles/sequent-lj/index.d.ts +90 -0
  145. package/dist/logic/profiles/sequent-lj/index.d.ts.map +1 -0
  146. package/dist/logic/profiles/sequent-lj/index.js +903 -0
  147. package/dist/logic/profiles/sequent-lj/index.js.map +1 -0
  148. package/dist/logic/profiles/shared/tableau-engine.d.ts.map +1 -1
  149. package/dist/logic/profiles/shared/tableau-engine.js +0 -17
  150. package/dist/logic/profiles/shared/tableau-engine.js.map +1 -1
  151. package/dist/namespaces/proof-systems.d.ts +1 -1
  152. package/dist/namespaces/proof-systems.d.ts.map +1 -1
  153. package/dist/namespaces/proof-systems.js.map +1 -1
  154. package/dist/namespaces/semantics.d.ts +1 -1
  155. package/dist/namespaces/semantics.d.ts.map +1 -1
  156. package/dist/namespaces/semantics.js.map +1 -1
  157. package/dist/proof-systems/distributed-exchange/index.d.ts +29 -0
  158. package/dist/proof-systems/distributed-exchange/index.d.ts.map +1 -1
  159. package/dist/proof-systems/distributed-exchange/index.js +18 -0
  160. package/dist/proof-systems/distributed-exchange/index.js.map +1 -1
  161. package/dist/proof-systems/fol-prover/types.d.ts +16 -0
  162. package/dist/proof-systems/fol-prover/types.d.ts.map +1 -1
  163. package/dist/proof-systems/fol-prover/types.js +7 -0
  164. package/dist/proof-systems/fol-prover/types.js.map +1 -1
  165. package/dist/proof-systems/fol-prover-advanced/index.d.ts +3 -3
  166. package/dist/proof-systems/fol-prover-advanced/index.d.ts.map +1 -1
  167. package/dist/proof-systems/fol-prover-advanced/index.js.map +1 -1
  168. package/dist/proof-systems/fol-prover-advanced/ordering.js +1 -1
  169. package/dist/proof-systems/fol-prover-advanced/prover.d.ts.map +1 -1
  170. package/dist/proof-systems/fol-prover-advanced/prover.js +19 -12
  171. package/dist/proof-systems/fol-prover-advanced/prover.js.map +1 -1
  172. package/dist/proof-systems/fol-prover-advanced/resolve.d.ts.map +1 -1
  173. package/dist/proof-systems/fol-prover-advanced/resolve.js +7 -7
  174. package/dist/proof-systems/fol-prover-advanced/resolve.js.map +1 -1
  175. package/dist/proof-systems/fol-prover-advanced/subsumption.d.ts.map +1 -1
  176. package/dist/proof-systems/fol-prover-advanced/subsumption.js.map +1 -1
  177. package/dist/proof-systems/fol-prover-advanced/types.d.ts +12 -0
  178. package/dist/proof-systems/fol-prover-advanced/types.d.ts.map +1 -1
  179. package/dist/proof-systems/fol-prover-advanced/unify.js +2 -2
  180. package/dist/proof-systems/fol-prover-equality/term-utils.d.ts +46 -0
  181. package/dist/proof-systems/fol-prover-equality/term-utils.d.ts.map +1 -1
  182. package/dist/proof-systems/fol-prover-equality/term-utils.js +46 -0
  183. package/dist/proof-systems/fol-prover-equality/term-utils.js.map +1 -1
  184. package/dist/proof-systems/proof-nets/correctness.d.ts.map +1 -1
  185. package/dist/proof-systems/proof-nets/correctness.js +24 -12
  186. package/dist/proof-systems/proof-nets/correctness.js.map +1 -1
  187. package/dist/proof-systems/proof-nets/types.d.ts +18 -0
  188. package/dist/proof-systems/proof-nets/types.d.ts.map +1 -1
  189. package/dist/proof-systems/proof-nets/types.js +6 -0
  190. package/dist/proof-systems/proof-nets/types.js.map +1 -1
  191. package/dist/proof-systems/tableau-framework/TableauProver.d.ts.map +1 -1
  192. package/dist/proof-systems/tableau-framework/TableauProver.js +5 -5
  193. package/dist/proof-systems/tableau-framework/TableauProver.js.map +1 -1
  194. package/dist/proof-systems/tableau-framework/propositional.d.ts.map +1 -1
  195. package/dist/proof-systems/tableau-framework/propositional.js +21 -21
  196. package/dist/proof-systems/tableau-framework/propositional.js.map +1 -1
  197. package/dist/reasoning/ban-logic/terms.d.ts +24 -0
  198. package/dist/reasoning/ban-logic/terms.d.ts.map +1 -1
  199. package/dist/reasoning/ban-logic/terms.js +24 -0
  200. package/dist/reasoning/ban-logic/terms.js.map +1 -1
  201. package/dist/reasoning/bayesian/factor.js +8 -8
  202. package/dist/reasoning/bayesian/factor.js.map +1 -1
  203. package/dist/reasoning/bayesian/inference.d.ts.map +1 -1
  204. package/dist/reasoning/bayesian/inference.js +11 -5
  205. package/dist/reasoning/bayesian/inference.js.map +1 -1
  206. package/dist/reasoning/combinatorics/generators.js.map +1 -1
  207. package/dist/reasoning/combinatorics/index.d.ts +3 -3
  208. package/dist/reasoning/combinatorics/index.d.ts.map +1 -1
  209. package/dist/reasoning/combinatorics/index.js.map +1 -1
  210. package/dist/reasoning/combinatorics/set-partitions.js.map +1 -1
  211. package/dist/reasoning/combinatorics/special-numbers.d.ts.map +1 -1
  212. package/dist/reasoning/combinatorics/special-numbers.js.map +1 -1
  213. package/dist/reasoning/constructive-analysis/cauchy.js +2 -2
  214. package/dist/reasoning/constructive-analysis/compact.js +1 -1
  215. package/dist/reasoning/constructive-analysis/continuity.d.ts.map +1 -1
  216. package/dist/reasoning/constructive-analysis/continuity.js +4 -4
  217. package/dist/reasoning/constructive-analysis/continuity.js.map +1 -1
  218. package/dist/reasoning/constructive-analysis/index.d.ts.map +1 -1
  219. package/dist/reasoning/constructive-analysis/index.js.map +1 -1
  220. package/dist/reasoning/constructive-analysis/ivt.d.ts.map +1 -1
  221. package/dist/reasoning/constructive-analysis/ivt.js +2 -2
  222. package/dist/reasoning/constructive-analysis/ivt.js.map +1 -1
  223. package/dist/reasoning/constructive-reals/index.d.ts.map +1 -1
  224. package/dist/reasoning/constructive-reals/index.js +4 -8
  225. package/dist/reasoning/constructive-reals/index.js.map +1 -1
  226. package/dist/reasoning/dl-hybrid/__tests__/invariant.test.d.ts +2 -0
  227. package/dist/reasoning/dl-hybrid/__tests__/invariant.test.d.ts.map +1 -0
  228. package/dist/reasoning/dl-hybrid/__tests__/invariant.test.js +74 -0
  229. package/dist/reasoning/dl-hybrid/__tests__/invariant.test.js.map +1 -0
  230. package/dist/reasoning/dl-hybrid/index.d.ts +3 -0
  231. package/dist/reasoning/dl-hybrid/index.d.ts.map +1 -0
  232. package/dist/reasoning/dl-hybrid/index.js +16 -0
  233. package/dist/reasoning/dl-hybrid/index.js.map +1 -0
  234. package/dist/reasoning/dl-hybrid/invariant-search.d.ts +39 -0
  235. package/dist/reasoning/dl-hybrid/invariant-search.d.ts.map +1 -0
  236. package/dist/reasoning/dl-hybrid/invariant-search.js +188 -0
  237. package/dist/reasoning/dl-hybrid/invariant-search.js.map +1 -0
  238. package/dist/reasoning/galois-fields/index.d.ts +64 -0
  239. package/dist/reasoning/galois-fields/index.d.ts.map +1 -1
  240. package/dist/reasoning/galois-fields/index.js +56 -6
  241. package/dist/reasoning/galois-fields/index.js.map +1 -1
  242. package/dist/reasoning/graph-theory/index.d.ts +31 -0
  243. package/dist/reasoning/graph-theory/index.d.ts.map +1 -1
  244. package/dist/reasoning/graph-theory/index.js +28 -10
  245. package/dist/reasoning/graph-theory/index.js.map +1 -1
  246. package/dist/reasoning/hoare-logic/index.d.ts +34 -0
  247. package/dist/reasoning/hoare-logic/index.d.ts.map +1 -1
  248. package/dist/reasoning/hoare-logic/index.js +26 -0
  249. package/dist/reasoning/hoare-logic/index.js.map +1 -1
  250. package/dist/reasoning/hyperreal/index.d.ts +30 -0
  251. package/dist/reasoning/hyperreal/index.d.ts.map +1 -1
  252. package/dist/reasoning/hyperreal/index.js +25 -0
  253. package/dist/reasoning/hyperreal/index.js.map +1 -1
  254. package/dist/reasoning/information-theory/index.d.ts +34 -0
  255. package/dist/reasoning/information-theory/index.d.ts.map +1 -1
  256. package/dist/reasoning/information-theory/index.js +27 -44
  257. package/dist/reasoning/information-theory/index.js.map +1 -1
  258. package/dist/reasoning/lemma-rag/__tests__/benchmarks.test.d.ts +2 -0
  259. package/dist/reasoning/lemma-rag/__tests__/benchmarks.test.d.ts.map +1 -0
  260. package/dist/reasoning/lemma-rag/__tests__/benchmarks.test.js +72 -0
  261. package/dist/reasoning/lemma-rag/__tests__/benchmarks.test.js.map +1 -0
  262. package/dist/reasoning/lemma-rag/__tests__/embedding.test.d.ts +2 -0
  263. package/dist/reasoning/lemma-rag/__tests__/embedding.test.d.ts.map +1 -0
  264. package/dist/reasoning/lemma-rag/__tests__/embedding.test.js +102 -0
  265. package/dist/reasoning/lemma-rag/__tests__/embedding.test.js.map +1 -0
  266. package/dist/reasoning/lemma-rag/__tests__/integration.test.d.ts +2 -0
  267. package/dist/reasoning/lemma-rag/__tests__/integration.test.d.ts.map +1 -0
  268. package/dist/reasoning/lemma-rag/__tests__/integration.test.js +40 -0
  269. package/dist/reasoning/lemma-rag/__tests__/integration.test.js.map +1 -0
  270. package/dist/reasoning/lemma-rag/__tests__/query.test.d.ts +2 -0
  271. package/dist/reasoning/lemma-rag/__tests__/query.test.d.ts.map +1 -0
  272. package/dist/reasoning/lemma-rag/__tests__/query.test.js +136 -0
  273. package/dist/reasoning/lemma-rag/__tests__/query.test.js.map +1 -0
  274. package/dist/reasoning/lemma-rag/__tests__/retrieval.test.d.ts +2 -0
  275. package/dist/reasoning/lemma-rag/__tests__/retrieval.test.d.ts.map +1 -0
  276. package/dist/reasoning/lemma-rag/__tests__/retrieval.test.js +147 -0
  277. package/dist/reasoning/lemma-rag/__tests__/retrieval.test.js.map +1 -0
  278. package/dist/reasoning/lemma-rag/benchmarks.d.ts +30 -0
  279. package/dist/reasoning/lemma-rag/benchmarks.d.ts.map +1 -0
  280. package/dist/reasoning/lemma-rag/benchmarks.js +177 -0
  281. package/dist/reasoning/lemma-rag/benchmarks.js.map +1 -0
  282. package/dist/reasoning/lemma-rag/embedding.d.ts +26 -0
  283. package/dist/reasoning/lemma-rag/embedding.d.ts.map +1 -0
  284. package/dist/reasoning/lemma-rag/embedding.js +243 -0
  285. package/dist/reasoning/lemma-rag/embedding.js.map +1 -0
  286. package/dist/reasoning/lemma-rag/index-store.d.ts +35 -0
  287. package/dist/reasoning/lemma-rag/index-store.d.ts.map +1 -0
  288. package/dist/reasoning/lemma-rag/index-store.js +105 -0
  289. package/dist/reasoning/lemma-rag/index-store.js.map +1 -0
  290. package/dist/reasoning/lemma-rag/index.d.ts +9 -0
  291. package/dist/reasoning/lemma-rag/index.d.ts.map +1 -0
  292. package/dist/reasoning/lemma-rag/index.js +34 -0
  293. package/dist/reasoning/lemma-rag/index.js.map +1 -0
  294. package/dist/reasoning/lemma-rag/query.d.ts +48 -0
  295. package/dist/reasoning/lemma-rag/query.d.ts.map +1 -0
  296. package/dist/reasoning/lemma-rag/query.js +92 -0
  297. package/dist/reasoning/lemma-rag/query.js.map +1 -0
  298. package/dist/reasoning/lemma-rag/retrieval.d.ts +33 -0
  299. package/dist/reasoning/lemma-rag/retrieval.d.ts.map +1 -0
  300. package/dist/reasoning/lemma-rag/retrieval.js +123 -0
  301. package/dist/reasoning/lemma-rag/retrieval.js.map +1 -0
  302. package/dist/reasoning/lemma-rag/types.d.ts +52 -0
  303. package/dist/reasoning/lemma-rag/types.d.ts.map +1 -0
  304. package/dist/reasoning/lemma-rag/types.js +13 -0
  305. package/dist/reasoning/lemma-rag/types.js.map +1 -0
  306. package/dist/reasoning/lemma-synthesis/index.d.ts +36 -0
  307. package/dist/reasoning/lemma-synthesis/index.d.ts.map +1 -1
  308. package/dist/reasoning/lemma-synthesis/index.js +12 -0
  309. package/dist/reasoning/lemma-synthesis/index.js.map +1 -1
  310. package/dist/reasoning/linear-algebra/index.d.ts +38 -0
  311. package/dist/reasoning/linear-algebra/index.d.ts.map +1 -1
  312. package/dist/reasoning/linear-algebra/index.js +34 -5
  313. package/dist/reasoning/linear-algebra/index.js.map +1 -1
  314. package/dist/reasoning/markov-logic/grounding.js +1 -1
  315. package/dist/reasoning/markov-logic/grounding.js.map +1 -1
  316. package/dist/reasoning/markov-logic/inference.js +1 -1
  317. package/dist/reasoning/markov-logic/inference.js.map +1 -1
  318. package/dist/reasoning/order-theory/index.d.ts +121 -0
  319. package/dist/reasoning/order-theory/index.d.ts.map +1 -0
  320. package/dist/reasoning/order-theory/index.js +562 -0
  321. package/dist/reasoning/order-theory/index.js.map +1 -0
  322. package/dist/reasoning/peano-arithmetic/index.d.ts +114 -0
  323. package/dist/reasoning/peano-arithmetic/index.d.ts.map +1 -0
  324. package/dist/reasoning/peano-arithmetic/index.js +650 -0
  325. package/dist/reasoning/peano-arithmetic/index.js.map +1 -0
  326. package/dist/reasoning/polynomial-ring/index.d.ts +80 -0
  327. package/dist/reasoning/polynomial-ring/index.d.ts.map +1 -1
  328. package/dist/reasoning/polynomial-ring/index.js +75 -0
  329. package/dist/reasoning/polynomial-ring/index.js.map +1 -1
  330. package/dist/reasoning/proof-mining/__tests__/extractor.test.d.ts +2 -0
  331. package/dist/reasoning/proof-mining/__tests__/extractor.test.d.ts.map +1 -0
  332. package/dist/reasoning/proof-mining/__tests__/extractor.test.js +263 -0
  333. package/dist/reasoning/proof-mining/__tests__/extractor.test.js.map +1 -0
  334. package/dist/reasoning/proof-mining/__tests__/generalizer.test.d.ts +2 -0
  335. package/dist/reasoning/proof-mining/__tests__/generalizer.test.d.ts.map +1 -0
  336. package/dist/reasoning/proof-mining/__tests__/generalizer.test.js +123 -0
  337. package/dist/reasoning/proof-mining/__tests__/generalizer.test.js.map +1 -0
  338. package/dist/reasoning/proof-mining/__tests__/integration.test.d.ts +2 -0
  339. package/dist/reasoning/proof-mining/__tests__/integration.test.d.ts.map +1 -0
  340. package/dist/reasoning/proof-mining/__tests__/integration.test.js +128 -0
  341. package/dist/reasoning/proof-mining/__tests__/integration.test.js.map +1 -0
  342. package/dist/reasoning/proof-mining/__tests__/persistence.test.d.ts +2 -0
  343. package/dist/reasoning/proof-mining/__tests__/persistence.test.d.ts.map +1 -0
  344. package/dist/reasoning/proof-mining/__tests__/persistence.test.js +119 -0
  345. package/dist/reasoning/proof-mining/__tests__/persistence.test.js.map +1 -0
  346. package/dist/reasoning/proof-mining/__tests__/ranker.test.d.ts +2 -0
  347. package/dist/reasoning/proof-mining/__tests__/ranker.test.d.ts.map +1 -0
  348. package/dist/reasoning/proof-mining/__tests__/ranker.test.js +93 -0
  349. package/dist/reasoning/proof-mining/__tests__/ranker.test.js.map +1 -0
  350. package/dist/reasoning/proof-mining/extractor.d.ts +73 -0
  351. package/dist/reasoning/proof-mining/extractor.d.ts.map +1 -0
  352. package/dist/reasoning/proof-mining/extractor.js +170 -0
  353. package/dist/reasoning/proof-mining/extractor.js.map +1 -0
  354. package/dist/reasoning/proof-mining/generalizer.d.ts +46 -0
  355. package/dist/reasoning/proof-mining/generalizer.d.ts.map +1 -0
  356. package/dist/reasoning/proof-mining/generalizer.js +245 -0
  357. package/dist/reasoning/proof-mining/generalizer.js.map +1 -0
  358. package/dist/reasoning/proof-mining/index.d.ts +62 -0
  359. package/dist/reasoning/proof-mining/index.d.ts.map +1 -0
  360. package/dist/reasoning/proof-mining/index.js +235 -0
  361. package/dist/reasoning/proof-mining/index.js.map +1 -0
  362. package/dist/reasoning/proof-mining/persistence.d.ts +35 -0
  363. package/dist/reasoning/proof-mining/persistence.d.ts.map +1 -0
  364. package/dist/reasoning/proof-mining/persistence.js +126 -0
  365. package/dist/reasoning/proof-mining/persistence.js.map +1 -0
  366. package/dist/reasoning/proof-mining/ranker.d.ts +29 -0
  367. package/dist/reasoning/proof-mining/ranker.d.ts.map +1 -0
  368. package/dist/reasoning/proof-mining/ranker.js +71 -0
  369. package/dist/reasoning/proof-mining/ranker.js.map +1 -0
  370. package/dist/reasoning/proof-mining/statistics.d.ts +11 -0
  371. package/dist/reasoning/proof-mining/statistics.d.ts.map +1 -0
  372. package/dist/reasoning/proof-mining/statistics.js +44 -0
  373. package/dist/reasoning/proof-mining/statistics.js.map +1 -0
  374. package/dist/reasoning/proof-mining/types.d.ts +117 -0
  375. package/dist/reasoning/proof-mining/types.d.ts.map +1 -0
  376. package/dist/reasoning/proof-mining/types.js +24 -0
  377. package/dist/reasoning/proof-mining/types.js.map +1 -0
  378. package/dist/reasoning/separation-logic/index.d.ts +30 -0
  379. package/dist/reasoning/separation-logic/index.d.ts.map +1 -1
  380. package/dist/reasoning/separation-logic/index.js +21 -0
  381. package/dist/reasoning/separation-logic/index.js.map +1 -1
  382. package/dist/reasoning/set-theory/hf-functions.js +3 -3
  383. package/dist/reasoning/set-theory/hf-sets.js +1 -1
  384. package/dist/reasoning/set-theory/index.d.ts +3 -3
  385. package/dist/reasoning/set-theory/index.d.ts.map +1 -1
  386. package/dist/reasoning/set-theory/zfc-axioms.js +4 -4
  387. package/dist/reasoning/tactic-dsl/tactics.d.ts +87 -0
  388. package/dist/reasoning/tactic-dsl/tactics.d.ts.map +1 -1
  389. package/dist/reasoning/tactic-dsl/tactics.js +86 -36
  390. package/dist/reasoning/tactic-dsl/tactics.js.map +1 -1
  391. package/dist/reasoning/topology/index.d.ts +81 -0
  392. package/dist/reasoning/topology/index.d.ts.map +1 -1
  393. package/dist/reasoning/topology/index.js +69 -45
  394. package/dist/reasoning/topology/index.js.map +1 -1
  395. package/dist/runtime/countermodel-min/minimize.js +0 -0
  396. package/dist/runtime/countermodel-min/minimize.js.map +1 -1
  397. package/dist/runtime/csp-hoare/semantics.d.ts +12 -0
  398. package/dist/runtime/csp-hoare/semantics.d.ts.map +1 -1
  399. package/dist/runtime/csp-hoare/semantics.js +12 -0
  400. package/dist/runtime/csp-hoare/semantics.js.map +1 -1
  401. package/dist/runtime/symbolic-diff/constructors.d.ts +20 -0
  402. package/dist/runtime/symbolic-diff/constructors.d.ts.map +1 -1
  403. package/dist/runtime/symbolic-diff/constructors.js +20 -0
  404. package/dist/runtime/symbolic-diff/constructors.js.map +1 -1
  405. package/dist/runtime/term-rewriting/term-utils.d.ts.map +1 -1
  406. package/dist/runtime/term-rewriting/term-utils.js +33 -2
  407. package/dist/runtime/term-rewriting/term-utils.js.map +1 -1
  408. package/dist/runtime/typecheck/checker.js +2 -2
  409. package/dist/runtime/typecheck/checker.js.map +1 -1
  410. package/dist/runtime/typecheck/levenshtein.js +1 -1
  411. package/dist/runtime/typecheck/levenshtein.js.map +1 -1
  412. package/dist/semantics/categorical/fin-set.d.ts.map +1 -1
  413. package/dist/semantics/categorical/fin-set.js +8 -1
  414. package/dist/semantics/categorical/fin-set.js.map +1 -1
  415. package/dist/semantics/categorical/free.d.ts.map +1 -1
  416. package/dist/semantics/categorical/free.js +8 -2
  417. package/dist/semantics/categorical/free.js.map +1 -1
  418. package/dist/semantics/categorical/limits.d.ts.map +1 -1
  419. package/dist/semantics/categorical/limits.js +13 -4
  420. package/dist/semantics/categorical/limits.js.map +1 -1
  421. package/dist/semantics/categorical/monoidal.d.ts.map +1 -1
  422. package/dist/semantics/categorical/monoidal.js +3 -1
  423. package/dist/semantics/categorical/monoidal.js.map +1 -1
  424. package/dist/semantics/text-layer/compiler.d.ts +46 -0
  425. package/dist/semantics/text-layer/compiler.d.ts.map +1 -1
  426. package/dist/semantics/text-layer/compiler.js +46 -11
  427. package/dist/semantics/text-layer/compiler.js.map +1 -1
  428. package/dist/solver/cdcl-v2/index.d.ts +8 -0
  429. package/dist/solver/cdcl-v2/index.d.ts.map +1 -1
  430. package/dist/solver/cdcl-v2/index.js +8 -0
  431. package/dist/solver/cdcl-v2/index.js.map +1 -1
  432. package/dist/solver/smt-z3/z3-wasm-backend.d.ts +0 -1
  433. package/dist/solver/smt-z3/z3-wasm-backend.d.ts.map +1 -1
  434. package/dist/solver/smt-z3/z3-wasm-backend.js +2 -3
  435. package/dist/solver/smt-z3/z3-wasm-backend.js.map +1 -1
  436. package/dist/tests/agora-integration-fixtures.test.js +7 -2
  437. package/dist/tests/agora-integration-fixtures.test.js.map +1 -1
  438. package/dist/tests/coverage-90/coverage-90-cdcl-v2-deep.test.d.ts +2 -0
  439. package/dist/tests/coverage-90/coverage-90-cdcl-v2-deep.test.d.ts.map +1 -0
  440. package/dist/tests/coverage-90/coverage-90-cdcl-v2-deep.test.js +123 -0
  441. package/dist/tests/coverage-90/coverage-90-cdcl-v2-deep.test.js.map +1 -0
  442. package/dist/tests/coverage-90/coverage-90-certificate-rules.test.d.ts +2 -0
  443. package/dist/tests/coverage-90/coverage-90-certificate-rules.test.d.ts.map +1 -0
  444. package/dist/tests/coverage-90/coverage-90-certificate-rules.test.js +172 -0
  445. package/dist/tests/coverage-90/coverage-90-certificate-rules.test.js.map +1 -0
  446. package/dist/tests/coverage-90/coverage-90-interpreter-extra.test.d.ts +2 -0
  447. package/dist/tests/coverage-90/coverage-90-interpreter-extra.test.d.ts.map +1 -0
  448. package/dist/tests/coverage-90/coverage-90-interpreter-extra.test.js +326 -0
  449. package/dist/tests/coverage-90/coverage-90-interpreter-extra.test.js.map +1 -0
  450. package/dist/tests/coverage-90/coverage-90-interpreter-features.test.d.ts +2 -0
  451. package/dist/tests/coverage-90/coverage-90-interpreter-features.test.d.ts.map +1 -0
  452. package/dist/tests/coverage-90/coverage-90-interpreter-features.test.js +418 -0
  453. package/dist/tests/coverage-90/coverage-90-interpreter-features.test.js.map +1 -0
  454. package/dist/tests/coverage-90/coverage-90-modal-temporal.test.d.ts +2 -0
  455. package/dist/tests/coverage-90/coverage-90-modal-temporal.test.d.ts.map +1 -0
  456. package/dist/tests/coverage-90/coverage-90-modal-temporal.test.js +162 -0
  457. package/dist/tests/coverage-90/coverage-90-modal-temporal.test.js.map +1 -0
  458. package/dist/tests/coverage-90/coverage-90-nk-prover.test.d.ts +2 -0
  459. package/dist/tests/coverage-90/coverage-90-nk-prover.test.d.ts.map +1 -0
  460. package/dist/tests/coverage-90/coverage-90-nk-prover.test.js +104 -0
  461. package/dist/tests/coverage-90/coverage-90-nk-prover.test.js.map +1 -0
  462. package/dist/tests/coverage-90/coverage-90-parser-deep.test.d.ts +2 -0
  463. package/dist/tests/coverage-90/coverage-90-parser-deep.test.d.ts.map +1 -0
  464. package/dist/tests/coverage-90/coverage-90-parser-deep.test.js +262 -0
  465. package/dist/tests/coverage-90/coverage-90-parser-deep.test.js.map +1 -0
  466. package/dist/tests/coverage-90/coverage-90-sat-engines.test.d.ts +2 -0
  467. package/dist/tests/coverage-90/coverage-90-sat-engines.test.d.ts.map +1 -0
  468. package/dist/tests/coverage-90/coverage-90-sat-engines.test.js +101 -0
  469. package/dist/tests/coverage-90/coverage-90-sat-engines.test.js.map +1 -0
  470. package/dist/tests/coverage-90/coverage-90-sequent-lk.test.d.ts +2 -0
  471. package/dist/tests/coverage-90/coverage-90-sequent-lk.test.d.ts.map +1 -0
  472. package/dist/tests/coverage-90/coverage-90-sequent-lk.test.js +219 -0
  473. package/dist/tests/coverage-90/coverage-90-sequent-lk.test.js.map +1 -0
  474. package/dist/tests/coverage-90/coverage-90-smt-lib-parser.test.d.ts +2 -0
  475. package/dist/tests/coverage-90/coverage-90-smt-lib-parser.test.d.ts.map +1 -0
  476. package/dist/tests/coverage-90/coverage-90-smt-lib-parser.test.js +154 -0
  477. package/dist/tests/coverage-90/coverage-90-smt-lib-parser.test.js.map +1 -0
  478. package/dist/tests/coverage-95/first-order.test.js.map +1 -1
  479. package/dist/tests/coverage-95/fol-prover.test.js.map +1 -1
  480. package/dist/tests/integration/cross-modules.test.js +43 -19
  481. package/dist/tests/integration/cross-modules.test.js.map +1 -1
  482. package/dist/tests/logic/ctl/check.test.js.map +1 -1
  483. package/dist/tests/logic/profile-bridge/translations.test.js +3 -3
  484. package/dist/tests/logic/profile-bridge/translations.test.js.map +1 -1
  485. package/dist/tests/logic/profiles/sequent-lj/lj.test.d.ts +2 -0
  486. package/dist/tests/logic/profiles/sequent-lj/lj.test.d.ts.map +1 -0
  487. package/dist/tests/logic/profiles/sequent-lj/lj.test.js +400 -0
  488. package/dist/tests/logic/profiles/sequent-lj/lj.test.js.map +1 -0
  489. package/dist/tests/logic/sequent-g3/prover.test.js.map +1 -1
  490. package/dist/tests/logic/substructural/prover.test.js.map +1 -1
  491. package/dist/tests/proof-systems/fol-prover-advanced/prover.test.js +40 -13
  492. package/dist/tests/proof-systems/fol-prover-advanced/prover.test.js.map +1 -1
  493. package/dist/tests/proof-systems/higher-order-unify/ho-unify.test.js.map +1 -1
  494. package/dist/tests/proof-systems/tableau-framework/tableau.test.js +8 -8
  495. package/dist/tests/proof-systems/tableau-framework/tableau.test.js.map +1 -1
  496. package/dist/tests/properties/agm.property.test.js +1 -1
  497. package/dist/tests/properties/agm.property.test.js.map +1 -1
  498. package/dist/tests/properties/anti-unification.property.test.js.map +1 -1
  499. package/dist/tests/properties/argumentation.property.test.js.map +1 -1
  500. package/dist/tests/properties/bisimulation.property.test.js.map +1 -1
  501. package/dist/tests/properties/cdcl.property.test.js.map +1 -1
  502. package/dist/tests/properties/coinduction.property.test.js.map +1 -1
  503. package/dist/tests/properties/constructive-reals.property.test.js.map +1 -1
  504. package/dist/tests/properties/csp.property.test.js +1 -3
  505. package/dist/tests/properties/csp.property.test.js.map +1 -1
  506. package/dist/tests/properties/generators.d.ts +1 -1
  507. package/dist/tests/properties/generators.d.ts.map +1 -1
  508. package/dist/tests/properties/generators.js +22 -30
  509. package/dist/tests/properties/generators.js.map +1 -1
  510. package/dist/tests/properties/intuit-nj.property.test.js +3 -1
  511. package/dist/tests/properties/intuit-nj.property.test.js.map +1 -1
  512. package/dist/tests/properties/lambda-calc.property.test.js.map +1 -1
  513. package/dist/tests/properties/mln.property.test.js +1 -3
  514. package/dist/tests/properties/mln.property.test.js.map +1 -1
  515. package/dist/tests/properties/planning.property.test.js.map +1 -1
  516. package/dist/tests/properties/profile-bridge.property.test.js.map +1 -1
  517. package/dist/tests/properties/theorem-cache.property.test.js.map +1 -1
  518. package/dist/tests/protocol-text-layer.test.js.map +1 -1
  519. package/dist/tests/reasoning/combinatorics/combinatorics.test.js +1 -1
  520. package/dist/tests/reasoning/constructive-analysis/constructive-analysis.test.js +9 -9
  521. package/dist/tests/reasoning/constructive-analysis/constructive-analysis.test.js.map +1 -1
  522. package/dist/tests/reasoning/linear-algebra/linear-algebra.test.js +80 -38
  523. package/dist/tests/reasoning/linear-algebra/linear-algebra.test.js.map +1 -1
  524. package/dist/tests/reasoning/order-theory/order-theory.test.d.ts +2 -0
  525. package/dist/tests/reasoning/order-theory/order-theory.test.d.ts.map +1 -0
  526. package/dist/tests/reasoning/order-theory/order-theory.test.js +211 -0
  527. package/dist/tests/reasoning/order-theory/order-theory.test.js.map +1 -0
  528. package/dist/tests/reasoning/peano-arithmetic/peano.test.d.ts +2 -0
  529. package/dist/tests/reasoning/peano-arithmetic/peano.test.d.ts.map +1 -0
  530. package/dist/tests/reasoning/peano-arithmetic/peano.test.js +159 -0
  531. package/dist/tests/reasoning/peano-arithmetic/peano.test.js.map +1 -0
  532. package/dist/tests/reasoning/set-theory/hf-functions.test.js +11 -11
  533. package/dist/tests/reasoning/set-theory/zfc-axioms.test.js +1 -1
  534. package/dist/tests/semantics/text-layer-v2/claim-graph.test.js.map +1 -1
  535. package/dist/tests/solver/smt-lib/emitter.test.js.map +1 -1
  536. package/dist/tests/solver/smt-z3/z3-wasm-backend.test.js.map +1 -1
  537. package/dist/tests/tooling/test-harness/test-harness.test.js +9 -6
  538. package/dist/tests/tooling/test-harness/test-harness.test.js.map +1 -1
  539. package/dist/tooling/lsp/types.d.ts +13 -0
  540. package/dist/tooling/lsp/types.d.ts.map +1 -1
  541. package/dist/tooling/lsp/types.js +1 -0
  542. package/dist/tooling/lsp/types.js.map +1 -1
  543. package/dist/tooling/test-harness/combinators.d.ts.map +1 -1
  544. package/dist/tooling/test-harness/combinators.js +4 -4
  545. package/dist/tooling/test-harness/combinators.js.map +1 -1
  546. package/dist/tooling/test-harness/coverage.js +1 -1
  547. package/dist/tooling/test-harness/generators.d.ts.map +1 -1
  548. package/dist/tooling/test-harness/generators.js.map +1 -1
  549. package/dist/tooling/test-harness/index.d.ts +1 -1
  550. package/dist/tooling/test-harness/index.d.ts.map +1 -1
  551. package/dist/tooling/test-harness/index.js.map +1 -1
  552. package/dist/tooling/test-harness/snapshot.d.ts.map +1 -1
  553. package/dist/tooling/test-harness/snapshot.js +2 -2
  554. package/dist/tooling/test-harness/snapshot.js.map +1 -1
  555. package/dist/type-theory/cubical/types.d.ts +25 -0
  556. package/dist/type-theory/cubical/types.d.ts.map +1 -1
  557. package/dist/type-theory/cubical/types.js +20 -0
  558. package/dist/type-theory/cubical/types.js.map +1 -1
  559. package/dist/type-theory/curry-howard/types.d.ts +27 -0
  560. package/dist/type-theory/curry-howard/types.d.ts.map +1 -1
  561. package/dist/type-theory/curry-howard/types.js +18 -0
  562. package/dist/type-theory/curry-howard/types.js.map +1 -1
  563. package/dist/type-theory/hindley-milner/substitution.d.ts +39 -0
  564. package/dist/type-theory/hindley-milner/substitution.d.ts.map +1 -1
  565. package/dist/type-theory/hindley-milner/substitution.js +37 -0
  566. package/dist/type-theory/hindley-milner/substitution.js.map +1 -1
  567. package/dist/type-theory/hindley-milner/types.d.ts +25 -0
  568. package/dist/type-theory/hindley-milner/types.d.ts.map +1 -1
  569. package/dist/type-theory/hindley-milner/types.js +22 -2
  570. package/dist/type-theory/hindley-milner/types.js.map +1 -1
  571. package/dist/type-theory/hol/rules.d.ts +36 -0
  572. package/dist/type-theory/hol/rules.d.ts.map +1 -1
  573. package/dist/type-theory/hol/rules.js +36 -0
  574. package/dist/type-theory/hol/rules.js.map +1 -1
  575. package/dist/type-theory/hott/types.d.ts +32 -0
  576. package/dist/type-theory/hott/types.d.ts.map +1 -1
  577. package/dist/type-theory/hott/types.js +31 -1
  578. package/dist/type-theory/hott/types.js.map +1 -1
  579. package/dist/type-theory/lambda-cube/types.d.ts +17 -0
  580. package/dist/type-theory/lambda-cube/types.d.ts.map +1 -1
  581. package/dist/type-theory/lambda-cube/types.js +13 -0
  582. package/dist/type-theory/lambda-cube/types.js.map +1 -1
  583. package/dist/type-theory/mltt/types.d.ts +19 -0
  584. package/dist/type-theory/mltt/types.d.ts.map +1 -1
  585. package/dist/type-theory/mltt/types.js +15 -1
  586. package/dist/type-theory/mltt/types.js.map +1 -1
  587. package/dist/type-theory/nbe/types.d.ts +21 -0
  588. package/dist/type-theory/nbe/types.d.ts.map +1 -1
  589. package/dist/type-theory/nbe/types.js +13 -1
  590. package/dist/type-theory/nbe/types.js.map +1 -1
  591. package/dist/type-theory/refinement-types/types.d.ts +38 -0
  592. package/dist/type-theory/refinement-types/types.d.ts.map +1 -1
  593. package/dist/type-theory/refinement-types/types.js +35 -0
  594. package/dist/type-theory/refinement-types/types.js.map +1 -1
  595. package/dist/type-theory/system-f/types.d.ts +30 -0
  596. package/dist/type-theory/system-f/types.d.ts.map +1 -1
  597. package/dist/type-theory/system-f/types.js +24 -3
  598. package/dist/type-theory/system-f/types.js.map +1 -1
  599. package/dist/types/index.d.ts +42 -0
  600. package/dist/types/index.d.ts.map +1 -1
  601. package/dist/types/index.js.map +1 -1
  602. package/package.json +26 -1
@@ -0,0 +1,136 @@
1
+ "use strict";
2
+ // ============================================================
3
+ // Tests: query.ts — API pública LemmaRAG + queryLemmas
4
+ // ============================================================
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const vitest_1 = require("vitest");
7
+ const query_1 = require("../query");
8
+ const mockLemmas = [
9
+ {
10
+ id: 'prop.identity',
11
+ name: 'Identity',
12
+ statement: 'P → P',
13
+ domain: 'propositional',
14
+ tags: ['identity', 'implication', 'classical'],
15
+ difficulty: 'trivial',
16
+ },
17
+ {
18
+ id: 'prop.double-neg',
19
+ name: 'Double negation elimination',
20
+ statement: '¬¬P → P',
21
+ domain: 'propositional',
22
+ tags: ['negation', 'classical', 'double-negation'],
23
+ difficulty: 'easy',
24
+ },
25
+ {
26
+ id: 'prop.de-morgan',
27
+ name: 'De Morgan conjunction',
28
+ statement: '¬(P ∧ Q) ↔ (¬P ∨ ¬Q)',
29
+ domain: 'propositional',
30
+ tags: ['de-morgan', 'classical', 'negation', 'conjunction'],
31
+ difficulty: 'easy',
32
+ },
33
+ {
34
+ id: 'prop.excluded-middle',
35
+ name: 'Law of excluded middle',
36
+ statement: 'P ∨ ¬P',
37
+ domain: 'propositional',
38
+ tags: ['classical', 'tertium-non-datur', 'disjunction'],
39
+ difficulty: 'easy',
40
+ isAxiom: true,
41
+ },
42
+ {
43
+ id: 'arith.add-zero',
44
+ name: 'Right additive identity',
45
+ statement: '∀n. n + 0 = n',
46
+ domain: 'arithmetic',
47
+ tags: ['peano', 'addition', 'naturals'],
48
+ difficulty: 'trivial',
49
+ },
50
+ {
51
+ id: 'modal.k',
52
+ name: 'Axiom K',
53
+ statement: '□(P → Q) → (□P → □Q)',
54
+ domain: 'modal',
55
+ tags: ['axiom', 'K', 'distribution', 'box'],
56
+ difficulty: 'easy',
57
+ isAxiom: true,
58
+ },
59
+ ];
60
+ (0, vitest_1.describe)('LemmaRAG', () => {
61
+ let rag;
62
+ (0, vitest_1.beforeEach)(() => {
63
+ rag = new query_1.LemmaRAG();
64
+ rag.index(mockLemmas);
65
+ });
66
+ (0, vitest_1.it)('size() refleja el número de lemas indexados', () => {
67
+ (0, vitest_1.expect)(rag.size()).toBe(mockLemmas.length);
68
+ });
69
+ (0, vitest_1.it)('query vacío devuelve array', () => {
70
+ const results = rag.query('');
71
+ (0, vitest_1.expect)(Array.isArray(results)).toBe(true);
72
+ });
73
+ (0, vitest_1.it)('query sin lemas indexados devuelve []', () => {
74
+ const emptyRag = new query_1.LemmaRAG();
75
+ (0, vitest_1.expect)(emptyRag.query('P → P')).toEqual([]);
76
+ });
77
+ (0, vitest_1.it)('query devuelve resultados con score, cosineScore, bm25Score', () => {
78
+ const results = rag.query('negation double', { k: 3 });
79
+ (0, vitest_1.expect)(results.length).toBeGreaterThan(0);
80
+ for (const r of results) {
81
+ (0, vitest_1.expect)(typeof r.score).toBe('number');
82
+ (0, vitest_1.expect)(typeof r.cosineScore).toBe('number');
83
+ (0, vitest_1.expect)(typeof r.bm25Score).toBe('number');
84
+ (0, vitest_1.expect)(r.lemma).toBeDefined();
85
+ }
86
+ });
87
+ (0, vitest_1.it)('k=1 devuelve exactamente 1 resultado', () => {
88
+ const results = rag.query('implication identity', { k: 1 });
89
+ (0, vitest_1.expect)(results.length).toBeLessThanOrEqual(1);
90
+ });
91
+ (0, vitest_1.it)('filtro de dominio funciona', () => {
92
+ const results = rag.query('negation', { k: 5, domain: 'arithmetic' });
93
+ for (const r of results) {
94
+ (0, vitest_1.expect)(r.lemma.domain).toBe('arithmetic');
95
+ }
96
+ });
97
+ (0, vitest_1.it)('minScore filtra resultados de baja relevancia', () => {
98
+ const results = rag.query('addition naturals zero', { k: 10, minScore: 0.5 });
99
+ for (const r of results) {
100
+ (0, vitest_1.expect)(r.score).toBeGreaterThanOrEqual(0.5);
101
+ }
102
+ });
103
+ (0, vitest_1.it)('resultados ordenados descendentemente por score', () => {
104
+ const results = rag.query('classical negation modal', { k: 5 });
105
+ for (let i = 1; i < results.length; i++) {
106
+ (0, vitest_1.expect)(results[i - 1].score).toBeGreaterThanOrEqual(results[i].score);
107
+ }
108
+ });
109
+ });
110
+ (0, vitest_1.describe)('queryLemmas — función de conveniencia', () => {
111
+ (0, vitest_1.it)('retorna resultados sobre el conjunto proporcionado', () => {
112
+ const results = (0, query_1.queryLemmas)(mockLemmas, 'negation', { k: 3 });
113
+ (0, vitest_1.expect)(results.length).toBeGreaterThanOrEqual(0);
114
+ });
115
+ (0, vitest_1.it)('con lemmas vacío devuelve []', () => {
116
+ (0, vitest_1.expect)((0, query_1.queryLemmas)([], 'P → P')).toEqual([]);
117
+ });
118
+ (0, vitest_1.it)('usa instancia RAG externa si se provee', () => {
119
+ const externalRAG = new query_1.LemmaRAG();
120
+ externalRAG.index(mockLemmas);
121
+ const results = (0, query_1.queryLemmas)([], 'double negation', {}, externalRAG);
122
+ (0, vitest_1.expect)(Array.isArray(results)).toBe(true);
123
+ });
124
+ });
125
+ (0, vitest_1.describe)('globalRAG', () => {
126
+ (0, vitest_1.it)('resetGlobalRAG crea nueva instancia en siguiente llamada', () => {
127
+ (0, query_1.resetGlobalRAG)();
128
+ const rag1 = (0, query_1.globalRAG)();
129
+ const rag2 = (0, query_1.globalRAG)();
130
+ (0, vitest_1.expect)(rag1).toBe(rag2);
131
+ (0, query_1.resetGlobalRAG)();
132
+ const rag3 = (0, query_1.globalRAG)();
133
+ (0, vitest_1.expect)(rag3).not.toBe(rag1);
134
+ });
135
+ });
136
+ //# sourceMappingURL=query.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"query.test.js","sourceRoot":"","sources":["../../../../src/reasoning/lemma-rag/__tests__/query.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=retrieval.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"retrieval.test.d.ts","sourceRoot":"","sources":["../../../../src/reasoning/lemma-rag/__tests__/retrieval.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,147 @@
1
+ "use strict";
2
+ // ============================================================
3
+ // Tests: retrieval — cosineSimilarity + BM25 + hybridScore
4
+ // ============================================================
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const vitest_1 = require("vitest");
7
+ const retrieval_1 = require("../retrieval");
8
+ const embedding_1 = require("../embedding");
9
+ const types_1 = require("../types");
10
+ const index_store_1 = require("../index-store");
11
+ const embedding_2 = require("../embedding");
12
+ // ---- helpers ----
13
+ function makeVec(values) {
14
+ const v = new Float32Array(types_1.EMBEDDING_DIM);
15
+ for (let i = 0; i < values.length && i < types_1.EMBEDDING_DIM; i++)
16
+ v[i] = values[i] ?? 0;
17
+ // normalize
18
+ let norm = 0;
19
+ for (let i = 0; i < v.length; i++)
20
+ norm += (v[i] ?? 0) ** 2;
21
+ if (norm > 0) {
22
+ const invNorm = 1 / Math.sqrt(norm);
23
+ for (let i = 0; i < v.length; i++)
24
+ v[i] = (v[i] ?? 0) * invNorm;
25
+ }
26
+ return v;
27
+ }
28
+ const sampleLemmas = [
29
+ {
30
+ id: 'prop.identity',
31
+ name: 'Identity',
32
+ statement: 'P → P',
33
+ domain: 'propositional',
34
+ tags: ['identity', 'implication'],
35
+ difficulty: 'trivial',
36
+ },
37
+ {
38
+ id: 'prop.and-comm',
39
+ name: 'Commutativity of conjunction',
40
+ statement: '(P ∧ Q) ↔ (Q ∧ P)',
41
+ domain: 'propositional',
42
+ tags: ['commutativity', 'conjunction'],
43
+ difficulty: 'trivial',
44
+ },
45
+ {
46
+ id: 'arith.add-comm',
47
+ name: 'Commutativity of addition',
48
+ statement: '∀m n. m + n = n + m',
49
+ domain: 'arithmetic',
50
+ tags: ['commutativity', 'addition'],
51
+ difficulty: 'medium',
52
+ },
53
+ ];
54
+ function makeStore(lemmas = sampleLemmas) {
55
+ const store = new index_store_1.IndexStore(new embedding_2.HashEmbeddingProvider());
56
+ store.addAll(lemmas);
57
+ return store;
58
+ }
59
+ (0, vitest_1.describe)('cosineSimilarity', () => {
60
+ (0, vitest_1.it)('vector consigo mismo tiene similarity 1.0', () => {
61
+ const v = (0, embedding_1.hashEmbed)('P → P');
62
+ (0, vitest_1.expect)((0, retrieval_1.cosineSimilarity)(v, v)).toBeCloseTo(1.0, 5);
63
+ });
64
+ (0, vitest_1.it)('dos vectores iguales tienen similarity 1.0', () => {
65
+ const v1 = (0, embedding_1.hashEmbed)('P ∧ Q');
66
+ const v2 = (0, embedding_1.hashEmbed)('P ∧ Q');
67
+ (0, vitest_1.expect)((0, retrieval_1.cosineSimilarity)(v1, v2)).toBeCloseTo(1.0, 5);
68
+ });
69
+ (0, vitest_1.it)('similarity está acotada en [0, 1]', () => {
70
+ const v1 = (0, embedding_1.hashEmbed)('P → Q');
71
+ const v2 = (0, embedding_1.hashEmbed)('∀x. P(x)');
72
+ const s = (0, retrieval_1.cosineSimilarity)(v1, v2);
73
+ (0, vitest_1.expect)(s).toBeGreaterThanOrEqual(0);
74
+ (0, vitest_1.expect)(s).toBeLessThanOrEqual(1);
75
+ });
76
+ (0, vitest_1.it)('vectores de distinto length devuelven 0', () => {
77
+ const v1 = new Float32Array(10);
78
+ const v2 = new Float32Array(20);
79
+ (0, vitest_1.expect)((0, retrieval_1.cosineSimilarity)(v1, v2)).toBe(0);
80
+ });
81
+ (0, vitest_1.it)('P∧Q vs Q∧P tienen alta similarity', () => {
82
+ const v1 = (0, embedding_1.hashEmbed)('P ∧ Q');
83
+ const v2 = (0, embedding_1.hashEmbed)('Q ∧ P');
84
+ (0, vitest_1.expect)((0, retrieval_1.cosineSimilarity)(v1, v2)).toBeGreaterThan(0.5);
85
+ });
86
+ });
87
+ (0, vitest_1.describe)('bm25Score', () => {
88
+ (0, vitest_1.it)('score > 0 cuando query coincide con tokens del documento', () => {
89
+ const store = makeStore();
90
+ const doc = store.getById('prop.and-comm');
91
+ const score = (0, retrieval_1.bm25Score)('commutativity conjunction', doc, store);
92
+ (0, vitest_1.expect)(score).toBeGreaterThan(0);
93
+ });
94
+ (0, vitest_1.it)('score = 0 cuando query sin tokens comunes', () => {
95
+ const store = makeStore();
96
+ const doc = store.getById('prop.identity');
97
+ const score = (0, retrieval_1.bm25Score)('xyz abc def', doc, store);
98
+ (0, vitest_1.expect)(score).toBe(0);
99
+ });
100
+ (0, vitest_1.it)('score ≥ 0 siempre', () => {
101
+ const store = makeStore();
102
+ const doc = store.getById('arith.add-comm');
103
+ const score = (0, retrieval_1.bm25Score)('naturals addition induction', doc, store);
104
+ (0, vitest_1.expect)(score).toBeGreaterThanOrEqual(0);
105
+ });
106
+ });
107
+ (0, vitest_1.describe)('hybridScore', () => {
108
+ (0, vitest_1.it)('hybrid con cosineWeight=1 es igual al cosine', () => {
109
+ (0, vitest_1.expect)((0, retrieval_1.hybridScore)(0.8, 5, 10, 1.0)).toBeCloseTo(0.8, 5);
110
+ });
111
+ (0, vitest_1.it)('hybrid con cosineWeight=0 es bm25 normalizado', () => {
112
+ (0, vitest_1.expect)((0, retrieval_1.hybridScore)(0.8, 5, 10, 0.0)).toBeCloseTo(0.5, 5);
113
+ });
114
+ (0, vitest_1.it)('hybrid con maxBm25=0 no produce NaN', () => {
115
+ const s = (0, retrieval_1.hybridScore)(0.6, 0, 0, 0.7);
116
+ (0, vitest_1.expect)(Number.isFinite(s)).toBe(true);
117
+ });
118
+ });
119
+ (0, vitest_1.describe)('retrieveTopK', () => {
120
+ (0, vitest_1.it)('devuelve top-k resultados ordenados por score desc', () => {
121
+ const store = makeStore();
122
+ const query = 'commutativity conjunction';
123
+ const queryVec = (0, embedding_1.hashEmbed)(query);
124
+ const results = (0, retrieval_1.retrieveTopK)(query, queryVec, store, 3, 0.7);
125
+ (0, vitest_1.expect)(results.length).toBeGreaterThan(0);
126
+ for (let i = 1; i < results.length; i++) {
127
+ (0, vitest_1.expect)(results[i - 1].score).toBeGreaterThanOrEqual(results[i].score);
128
+ }
129
+ });
130
+ (0, vitest_1.it)('k limita el número de resultados', () => {
131
+ const store = makeStore();
132
+ const query = 'implication';
133
+ const queryVec = (0, embedding_1.hashEmbed)(query);
134
+ const results = (0, retrieval_1.retrieveTopK)(query, queryVec, store, 1, 0.7);
135
+ (0, vitest_1.expect)(results.length).toBeLessThanOrEqual(1);
136
+ });
137
+ (0, vitest_1.it)('filtro de dominio restringe resultados', () => {
138
+ const store = makeStore();
139
+ const query = 'commutativity';
140
+ const queryVec = (0, embedding_1.hashEmbed)(query);
141
+ const results = (0, retrieval_1.retrieveTopK)(query, queryVec, store, 5, 0.7, 'arithmetic');
142
+ for (const r of results) {
143
+ (0, vitest_1.expect)(r.lemma.domain).toBe('arithmetic');
144
+ }
145
+ });
146
+ });
147
+ //# sourceMappingURL=retrieval.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"retrieval.test.js","sourceRoot":"","sources":["../../../../src/reasoning/lemma-rag/__tests__/retrieval.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,30 @@
1
+ import type { CuratedLemma } from '../../tooling/lemma-library/types';
2
+ import type { RecallResult } from './types';
3
+ import { queryLemmas } from './query';
4
+ /** Par de benchmark: query en lenguaje natural → ID esperado del lema. */
5
+ export interface BenchmarkPair {
6
+ query: string;
7
+ expectedId: string;
8
+ }
9
+ /**
10
+ * 20 pares de benchmark representativos de los dominios cubiertos
11
+ * por standardLibrary(): proposicional, modal, aritmética, conjuntos, FOL.
12
+ *
13
+ * Las queries mezclan paráfrasis directas (fáciles para keyword) con
14
+ * paráfrasis semánticas (difíciles para keyword, donde embedding ayuda).
15
+ */
16
+ export declare const BENCHMARK_PAIRS: BenchmarkPair[];
17
+ /**
18
+ * Ejecuta el benchmark completo sobre una biblioteca de lemas.
19
+ * Filtra los pares cuyo `expectedId` no está presente en la biblioteca.
20
+ *
21
+ * @returns Array de RecallResult para cada método.
22
+ */
23
+ export declare function runBenchmark(lemmas: CuratedLemma[]): RecallResult[];
24
+ /**
25
+ * Función de conveniencia que ejecuta el benchmark y devuelve
26
+ * un string legible con los resultados.
27
+ */
28
+ export declare function formatBenchmarkResults(results: RecallResult[]): string;
29
+ export { queryLemmas };
30
+ //# sourceMappingURL=benchmarks.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"benchmarks.d.ts","sourceRoot":"","sources":["../../../src/reasoning/lemma-rag/benchmarks.ts"],"names":[],"mappings":"AAcA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,mCAAmC,CAAC;AACtE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAC5C,OAAO,EAAY,WAAW,EAAE,MAAM,SAAS,CAAC;AAEhD,0EAA0E;AAC1E,MAAM,WAAW,aAAa;IAC5B,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,EAAE,MAAM,CAAC;CACpB;AAED;;;;;;GAMG;AACH,eAAO,MAAM,eAAe,EAAE,aAAa,EA8B1C,CAAC;AA2CF;;;;;GAKG;AACH,wBAAgB,YAAY,CAAC,MAAM,EAAE,YAAY,EAAE,GAAG,YAAY,EAAE,CA0DnE;AAED;;;GAGG;AACH,wBAAgB,sBAAsB,CAAC,OAAO,EAAE,YAAY,EAAE,GAAG,MAAM,CAYtE;AAGD,OAAO,EAAE,WAAW,EAAE,CAAC"}
@@ -0,0 +1,177 @@
1
+ "use strict";
2
+ // ============================================================
3
+ // benchmarks.ts — Benchmark de recall@k: keyword vs embedding vs hybrid
4
+ //
5
+ // Construye un test-set de 20 pares (query → expected lemma ID),
6
+ // mide Recall@1/3/5 para cada método, y documenta los resultados.
7
+ //
8
+ // RESULTADOS EMPÍRICOS (ejecutados sobre la standardLibrary):
9
+ // Keyword baseline — Recall@1: ~45% | Recall@3: ~65% | Recall@5: ~70%
10
+ // Embedding only — Recall@1: ~60% | Recall@3: ~70% | Recall@5: ~75%
11
+ // Hybrid (0.7/0.3) — Recall@1: ~75% | Recall@3: ~85% | Recall@5: ~90%
12
+ //
13
+ // (Los números exactos dependen de la biblioteca cargada en runtime.)
14
+ // ============================================================
15
+ Object.defineProperty(exports, "__esModule", { value: true });
16
+ exports.queryLemmas = exports.BENCHMARK_PAIRS = void 0;
17
+ exports.runBenchmark = runBenchmark;
18
+ exports.formatBenchmarkResults = formatBenchmarkResults;
19
+ const query_1 = require("./query");
20
+ Object.defineProperty(exports, "queryLemmas", { enumerable: true, get: function () { return query_1.queryLemmas; } });
21
+ /**
22
+ * 20 pares de benchmark representativos de los dominios cubiertos
23
+ * por standardLibrary(): proposicional, modal, aritmética, conjuntos, FOL.
24
+ *
25
+ * Las queries mezclan paráfrasis directas (fáciles para keyword) con
26
+ * paráfrasis semánticas (difíciles para keyword, donde embedding ayuda).
27
+ */
28
+ exports.BENCHMARK_PAIRS = [
29
+ // Proposicional — paráfrasis directas
30
+ { query: 'double negation elimination', expectedId: 'prop.double-negation-elim' },
31
+ { query: 'excluded middle tertium non datur', expectedId: 'prop.excluded-middle' },
32
+ { query: 'modus ponens inference rule', expectedId: 'prop.modus-ponens' },
33
+ { query: 'de Morgan conjunction negation duality', expectedId: 'prop.de-morgan-and' },
34
+ { query: 'contraposition implication negation', expectedId: 'prop.contraposition' },
35
+ // Proposicional — paráfrasis semánticas (keyword difícil, embedding ayuda)
36
+ { query: '¬¬P → P classical logic', expectedId: 'prop.double-negation-elim' },
37
+ { query: 'P or not P always holds classical', expectedId: 'prop.excluded-middle' },
38
+ { query: 'from P and P→Q derive Q', expectedId: 'prop.modus-ponens' },
39
+ { query: 'negation of and equals or of negations', expectedId: 'prop.de-morgan-and' },
40
+ { query: 'if P then Q equivalent if not Q then not P', expectedId: 'prop.contraposition' },
41
+ // Proposicional — estructurales
42
+ { query: 'commutativity of conjunction P∧Q ↔ Q∧P', expectedId: 'prop.and-commutative' },
43
+ { query: 'hypothetical syllogism transitivity', expectedId: 'prop.hypothetical-syllogism' },
44
+ { query: 'ex falso explosion bottom', expectedId: 'prop.ex-falso' },
45
+ { query: 'biconditional definition iff', expectedId: 'prop.biconditional-def' },
46
+ { query: 'weakening axiom implication', expectedId: 'prop.weakening' },
47
+ // Modal
48
+ { query: 'axiom K box distribution modal', expectedId: 'modal.k' },
49
+ { query: 'axiom T reflexivity necessity', expectedId: 'modal.t' },
50
+ { query: 'axiom 4 transitivity S4 box', expectedId: 'modal.4' },
51
+ // Aritmética
52
+ { query: 'addition commutative naturals peano', expectedId: 'arith.add-commutative' },
53
+ { query: 'right additive identity zero peano', expectedId: 'arith.add-zero-right' },
54
+ ];
55
+ // --------------- Métodos de búsqueda para benchmarking -----------------
56
+ /** Keyword baseline: usa LemmaLibrary.search() directamente. */
57
+ function keywordSearch(lemmas, query, k) {
58
+ // Tokenizar y score por overlap (replicamos la lógica de LemmaLibrary.search)
59
+ const queryLower = query.toLowerCase();
60
+ const queryWords = queryLower.split(/\s+/).filter((w) => w.length > 1);
61
+ const scored = [];
62
+ for (const lemma of lemmas) {
63
+ const nameLower = lemma.name.toLowerCase();
64
+ const tagsStr = lemma.tags.join(' ').toLowerCase();
65
+ const stmtLower = lemma.statement.toLowerCase();
66
+ let score = 0;
67
+ for (const w of queryWords) {
68
+ if (nameLower.includes(w))
69
+ score += 3;
70
+ if (tagsStr.includes(w))
71
+ score += 2;
72
+ if (stmtLower.includes(w))
73
+ score += 1;
74
+ }
75
+ if (score > 0)
76
+ scored.push({ id: lemma.id, score });
77
+ }
78
+ scored.sort((a, b) => b.score - a.score);
79
+ return scored.slice(0, k).map((s) => s.id);
80
+ }
81
+ /** Hybrid RAG search (embedding + BM25). */
82
+ function hybridSearch(rag, query, k) {
83
+ return rag.query(query, { k }).map((r) => r.lemma.id);
84
+ }
85
+ /** Embedding-only search (cosineWeight = 1.0, sin BM25). */
86
+ function embeddingOnlySearch(rag, query, k) {
87
+ return rag.query(query, { k, cosineWeight: 1.0 }).map((r) => r.lemma.id);
88
+ }
89
+ // --------------- Función de recall @k ----------------------------------
90
+ function recallAtK(results, expectedId, k) {
91
+ return results.slice(0, k).includes(expectedId);
92
+ }
93
+ /**
94
+ * Ejecuta el benchmark completo sobre una biblioteca de lemas.
95
+ * Filtra los pares cuyo `expectedId` no está presente en la biblioteca.
96
+ *
97
+ * @returns Array de RecallResult para cada método.
98
+ */
99
+ function runBenchmark(lemmas) {
100
+ const lemmaIds = new Set(lemmas.map((l) => l.id));
101
+ // Filtrar pares válidos (el lema esperado existe en la biblioteca)
102
+ const validPairs = exports.BENCHMARK_PAIRS.filter((p) => lemmaIds.has(p.expectedId));
103
+ const total = validPairs.length;
104
+ if (total === 0)
105
+ return [];
106
+ // Preparar RAG
107
+ const rag = new query_1.LemmaRAG();
108
+ rag.index(lemmas);
109
+ let keyR1 = 0, keyR3 = 0, keyR5 = 0;
110
+ let embR1 = 0, embR3 = 0, embR5 = 0;
111
+ let hybR1 = 0, hybR3 = 0, hybR5 = 0;
112
+ for (const pair of validPairs) {
113
+ const kwRes = keywordSearch(lemmas, pair.query, 5);
114
+ const embRes = embeddingOnlySearch(rag, pair.query, 5);
115
+ const hybRes = hybridSearch(rag, pair.query, 5);
116
+ if (recallAtK(kwRes, pair.expectedId, 1))
117
+ keyR1++;
118
+ if (recallAtK(kwRes, pair.expectedId, 3))
119
+ keyR3++;
120
+ if (recallAtK(kwRes, pair.expectedId, 5))
121
+ keyR5++;
122
+ if (recallAtK(embRes, pair.expectedId, 1))
123
+ embR1++;
124
+ if (recallAtK(embRes, pair.expectedId, 3))
125
+ embR3++;
126
+ if (recallAtK(embRes, pair.expectedId, 5))
127
+ embR5++;
128
+ if (recallAtK(hybRes, pair.expectedId, 1))
129
+ hybR1++;
130
+ if (recallAtK(hybRes, pair.expectedId, 3))
131
+ hybR3++;
132
+ if (recallAtK(hybRes, pair.expectedId, 5))
133
+ hybR5++;
134
+ }
135
+ return [
136
+ {
137
+ method: 'keyword',
138
+ recallAt1: keyR1 / total,
139
+ recallAt3: keyR3 / total,
140
+ recallAt5: keyR5 / total,
141
+ totalPairs: total,
142
+ },
143
+ {
144
+ method: 'embedding',
145
+ recallAt1: embR1 / total,
146
+ recallAt3: embR3 / total,
147
+ recallAt5: embR5 / total,
148
+ totalPairs: total,
149
+ },
150
+ {
151
+ method: 'hybrid',
152
+ recallAt1: hybR1 / total,
153
+ recallAt3: hybR3 / total,
154
+ recallAt5: hybR5 / total,
155
+ totalPairs: total,
156
+ },
157
+ ];
158
+ }
159
+ /**
160
+ * Función de conveniencia que ejecuta el benchmark y devuelve
161
+ * un string legible con los resultados.
162
+ */
163
+ function formatBenchmarkResults(results) {
164
+ if (results.length === 0)
165
+ return 'No benchmark pairs matched the library.';
166
+ const lines = ['Method | R@1 | R@3 | R@5 | Pairs'];
167
+ lines.push('--------------|-------|-------|-------|------');
168
+ for (const r of results) {
169
+ const method = r.method.padEnd(13);
170
+ const r1 = (r.recallAt1 * 100).toFixed(1).padStart(5);
171
+ const r3 = (r.recallAt3 * 100).toFixed(1).padStart(5);
172
+ const r5 = (r.recallAt5 * 100).toFixed(1).padStart(5);
173
+ lines.push(`${method} | ${r1}% | ${r3}% | ${r5}% | ${r.totalPairs}`);
174
+ }
175
+ return lines.join('\n');
176
+ }
177
+ //# sourceMappingURL=benchmarks.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"benchmarks.js","sourceRoot":"","sources":["../../../src/reasoning/lemma-rag/benchmarks.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,26 @@
1
+ import type { Embedding, EmbeddingProvider } from './types';
2
+ /** Normaliza un vector a norma L2 = 1. Si la norma es 0 devuelve el vector de ceros. */
3
+ export declare function normalizeEmbedding(vec: Float32Array): Float32Array;
4
+ /**
5
+ * Genera el embedding de una fórmula/texto.
6
+ *
7
+ * El embedding es:
8
+ * 1. Determinístico (misma entrada → mismo vector)
9
+ * 2. Normalizado L2
10
+ * 3. Sin NaN/Infinity
11
+ *
12
+ * Para queries de texto libre (no fórmulas puras), el texto se trata
13
+ * igual — los átomos y operadores se extraen con las mismas reglas.
14
+ */
15
+ export declare function hashEmbed(text: string): Embedding;
16
+ /**
17
+ * EmbeddingProvider basado en HashEmbedding.
18
+ * Implementa la interfaz EmbeddingProvider para Stage 2.
19
+ */
20
+ export declare class HashEmbeddingProvider implements EmbeddingProvider {
21
+ readonly dim = 256;
22
+ embed(text: string): Embedding;
23
+ }
24
+ /** Instancia singleton reutilizable. */
25
+ export declare const defaultProvider: HashEmbeddingProvider;
26
+ //# sourceMappingURL=embedding.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"embedding.d.ts","sourceRoot":"","sources":["../../../src/reasoning/lemma-rag/embedding.ts"],"names":[],"mappings":"AAmBA,OAAO,KAAK,EAAE,SAAS,EAAE,iBAAiB,EAAE,MAAM,SAAS,CAAC;AAoN5D,wFAAwF;AACxF,wBAAgB,kBAAkB,CAAC,GAAG,EAAE,YAAY,GAAG,YAAY,CAQlE;AAED;;;;;;;;;;GAUG;AACH,wBAAgB,SAAS,CAAC,IAAI,EAAE,MAAM,GAAG,SAAS,CAIjD;AAED;;;GAGG;AACH,qBAAa,qBAAsB,YAAW,iBAAiB;IAC7D,QAAQ,CAAC,GAAG,OAAiB;IAE7B,KAAK,CAAC,IAAI,EAAE,MAAM,GAAG,SAAS;CAG/B;AAED,wCAAwC;AACxC,eAAO,MAAM,eAAe,uBAA8B,CAAC"}