@stevenvo780/st-lang 4.0.1 → 4.2.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 (393) hide show
  1. package/dist/belief-revision/agm.d.ts +76 -0
  2. package/dist/belief-revision/agm.d.ts.map +1 -0
  3. package/dist/belief-revision/agm.js +249 -0
  4. package/dist/belief-revision/agm.js.map +1 -0
  5. package/dist/belief-revision/index.d.ts +6 -0
  6. package/dist/belief-revision/index.d.ts.map +1 -0
  7. package/dist/belief-revision/index.js +33 -0
  8. package/dist/belief-revision/index.js.map +1 -0
  9. package/dist/belief-revision/parser.d.ts +16 -0
  10. package/dist/belief-revision/parser.d.ts.map +1 -0
  11. package/dist/belief-revision/parser.js +199 -0
  12. package/dist/belief-revision/parser.js.map +1 -0
  13. package/dist/belief-revision/sat.d.ts +19 -0
  14. package/dist/belief-revision/sat.d.ts.map +1 -0
  15. package/dist/belief-revision/sat.js +90 -0
  16. package/dist/belief-revision/sat.js.map +1 -0
  17. package/dist/belief-revision/types.d.ts +51 -0
  18. package/dist/belief-revision/types.d.ts.map +1 -0
  19. package/dist/belief-revision/types.js +10 -0
  20. package/dist/belief-revision/types.js.map +1 -0
  21. package/dist/curry-howard/index.d.ts +7 -0
  22. package/dist/curry-howard/index.d.ts.map +1 -0
  23. package/dist/curry-howard/index.js +46 -0
  24. package/dist/curry-howard/index.js.map +1 -0
  25. package/dist/curry-howard/infer.d.ts +9 -0
  26. package/dist/curry-howard/infer.d.ts.map +1 -0
  27. package/dist/curry-howard/infer.js +129 -0
  28. package/dist/curry-howard/infer.js.map +1 -0
  29. package/dist/curry-howard/proof.d.ts +7 -0
  30. package/dist/curry-howard/proof.d.ts.map +1 -0
  31. package/dist/curry-howard/proof.js +282 -0
  32. package/dist/curry-howard/proof.js.map +1 -0
  33. package/dist/curry-howard/reduce.d.ts +7 -0
  34. package/dist/curry-howard/reduce.d.ts.map +1 -0
  35. package/dist/curry-howard/reduce.js +266 -0
  36. package/dist/curry-howard/reduce.js.map +1 -0
  37. package/dist/curry-howard/types.d.ts +91 -0
  38. package/dist/curry-howard/types.d.ts.map +1 -0
  39. package/dist/curry-howard/types.js +149 -0
  40. package/dist/curry-howard/types.js.map +1 -0
  41. package/dist/fol-prover-equality/demodulate.d.ts +29 -0
  42. package/dist/fol-prover-equality/demodulate.d.ts.map +1 -0
  43. package/dist/fol-prover-equality/demodulate.js +197 -0
  44. package/dist/fol-prover-equality/demodulate.js.map +1 -0
  45. package/dist/fol-prover-equality/index.d.ts +8 -0
  46. package/dist/fol-prover-equality/index.d.ts.map +1 -0
  47. package/dist/fol-prover-equality/index.js +24 -0
  48. package/dist/fol-prover-equality/index.js.map +1 -0
  49. package/dist/fol-prover-equality/paramodulate.d.ts +46 -0
  50. package/dist/fol-prover-equality/paramodulate.d.ts.map +1 -0
  51. package/dist/fol-prover-equality/paramodulate.js +159 -0
  52. package/dist/fol-prover-equality/paramodulate.js.map +1 -0
  53. package/dist/fol-prover-equality/prove.d.ts +7 -0
  54. package/dist/fol-prover-equality/prove.d.ts.map +1 -0
  55. package/dist/fol-prover-equality/prove.js +307 -0
  56. package/dist/fol-prover-equality/prove.js.map +1 -0
  57. package/dist/fol-prover-equality/term-utils.d.ts +43 -0
  58. package/dist/fol-prover-equality/term-utils.d.ts.map +1 -0
  59. package/dist/fol-prover-equality/term-utils.js +230 -0
  60. package/dist/fol-prover-equality/term-utils.js.map +1 -0
  61. package/dist/fol-prover-equality/types.d.ts +20 -0
  62. package/dist/fol-prover-equality/types.d.ts.map +1 -0
  63. package/dist/fol-prover-equality/types.js +5 -0
  64. package/dist/fol-prover-equality/types.js.map +1 -0
  65. package/dist/index.d.ts +4 -0
  66. package/dist/index.d.ts.map +1 -1
  67. package/dist/index.js +18 -1
  68. package/dist/index.js.map +1 -1
  69. package/dist/profiles/ctl/check.d.ts +13 -0
  70. package/dist/profiles/ctl/check.d.ts.map +1 -0
  71. package/dist/profiles/ctl/check.js +359 -0
  72. package/dist/profiles/ctl/check.js.map +1 -0
  73. package/dist/profiles/ctl/index.d.ts +5 -0
  74. package/dist/profiles/ctl/index.d.ts.map +1 -0
  75. package/dist/profiles/ctl/index.js +23 -0
  76. package/dist/profiles/ctl/index.js.map +1 -0
  77. package/dist/profiles/ctl/types.d.ts +74 -0
  78. package/dist/profiles/ctl/types.d.ts.map +1 -0
  79. package/dist/profiles/ctl/types.js +53 -0
  80. package/dist/profiles/ctl/types.js.map +1 -0
  81. package/dist/profiles/ctl/witness.d.ts +20 -0
  82. package/dist/profiles/ctl/witness.d.ts.map +1 -0
  83. package/dist/profiles/ctl/witness.js +149 -0
  84. package/dist/profiles/ctl/witness.js.map +1 -0
  85. package/dist/profiles/default-logic/entailment.d.ts +14 -0
  86. package/dist/profiles/default-logic/entailment.d.ts.map +1 -0
  87. package/dist/profiles/default-logic/entailment.js +36 -0
  88. package/dist/profiles/default-logic/entailment.js.map +1 -0
  89. package/dist/profiles/default-logic/extensions.d.ts +35 -0
  90. package/dist/profiles/default-logic/extensions.d.ts.map +1 -0
  91. package/dist/profiles/default-logic/extensions.js +276 -0
  92. package/dist/profiles/default-logic/extensions.js.map +1 -0
  93. package/dist/profiles/default-logic/index.d.ts +5 -0
  94. package/dist/profiles/default-logic/index.d.ts.map +1 -0
  95. package/dist/profiles/default-logic/index.js +33 -0
  96. package/dist/profiles/default-logic/index.js.map +1 -0
  97. package/dist/profiles/default-logic/types.d.ts +29 -0
  98. package/dist/profiles/default-logic/types.d.ts.map +1 -0
  99. package/dist/profiles/default-logic/types.js +25 -0
  100. package/dist/profiles/default-logic/types.js.map +1 -0
  101. package/dist/profiles/description-logic/index.d.ts +5 -0
  102. package/dist/profiles/description-logic/index.d.ts.map +1 -0
  103. package/dist/profiles/description-logic/index.js +39 -0
  104. package/dist/profiles/description-logic/index.js.map +1 -0
  105. package/dist/profiles/description-logic/nnf.d.ts +13 -0
  106. package/dist/profiles/description-logic/nnf.d.ts.map +1 -0
  107. package/dist/profiles/description-logic/nnf.js +123 -0
  108. package/dist/profiles/description-logic/nnf.js.map +1 -0
  109. package/dist/profiles/description-logic/tableau.d.ts +27 -0
  110. package/dist/profiles/description-logic/tableau.d.ts.map +1 -0
  111. package/dist/profiles/description-logic/tableau.js +491 -0
  112. package/dist/profiles/description-logic/tableau.js.map +1 -0
  113. package/dist/profiles/description-logic/types.d.ts +45 -0
  114. package/dist/profiles/description-logic/types.d.ts.map +1 -0
  115. package/dist/profiles/description-logic/types.js +71 -0
  116. package/dist/profiles/description-logic/types.js.map +1 -0
  117. package/dist/profiles/hybrid-logic/index.d.ts +5 -0
  118. package/dist/profiles/hybrid-logic/index.d.ts.map +1 -0
  119. package/dist/profiles/hybrid-logic/index.js +34 -0
  120. package/dist/profiles/hybrid-logic/index.js.map +1 -0
  121. package/dist/profiles/hybrid-logic/sat.d.ts +15 -0
  122. package/dist/profiles/hybrid-logic/sat.d.ts.map +1 -0
  123. package/dist/profiles/hybrid-logic/sat.js +142 -0
  124. package/dist/profiles/hybrid-logic/sat.js.map +1 -0
  125. package/dist/profiles/hybrid-logic/semantics.d.ts +20 -0
  126. package/dist/profiles/hybrid-logic/semantics.d.ts.map +1 -0
  127. package/dist/profiles/hybrid-logic/semantics.js +107 -0
  128. package/dist/profiles/hybrid-logic/semantics.js.map +1 -0
  129. package/dist/profiles/hybrid-logic/types.d.ts +78 -0
  130. package/dist/profiles/hybrid-logic/types.d.ts.map +1 -0
  131. package/dist/profiles/hybrid-logic/types.js +107 -0
  132. package/dist/profiles/hybrid-logic/types.js.map +1 -0
  133. package/dist/profiles/ltl-sat/index.d.ts +4 -0
  134. package/dist/profiles/ltl-sat/index.d.ts.map +1 -0
  135. package/dist/profiles/ltl-sat/index.js +40 -0
  136. package/dist/profiles/ltl-sat/index.js.map +1 -0
  137. package/dist/profiles/ltl-sat/sat.d.ts +8 -0
  138. package/dist/profiles/ltl-sat/sat.d.ts.map +1 -0
  139. package/dist/profiles/ltl-sat/sat.js +140 -0
  140. package/dist/profiles/ltl-sat/sat.js.map +1 -0
  141. package/dist/profiles/ltl-sat/tableau.d.ts +19 -0
  142. package/dist/profiles/ltl-sat/tableau.d.ts.map +1 -0
  143. package/dist/profiles/ltl-sat/tableau.js +358 -0
  144. package/dist/profiles/ltl-sat/tableau.js.map +1 -0
  145. package/dist/profiles/ltl-sat/types.d.ts +52 -0
  146. package/dist/profiles/ltl-sat/types.d.ts.map +1 -0
  147. package/dist/profiles/ltl-sat/types.js +101 -0
  148. package/dist/profiles/ltl-sat/types.js.map +1 -0
  149. package/dist/profiles/sequent-g3/index.d.ts +5 -0
  150. package/dist/profiles/sequent-g3/index.d.ts.map +1 -0
  151. package/dist/profiles/sequent-g3/index.js +23 -0
  152. package/dist/profiles/sequent-g3/index.js.map +1 -0
  153. package/dist/profiles/sequent-g3/latex.d.ts +7 -0
  154. package/dist/profiles/sequent-g3/latex.d.ts.map +1 -0
  155. package/dist/profiles/sequent-g3/latex.js +107 -0
  156. package/dist/profiles/sequent-g3/latex.js.map +1 -0
  157. package/dist/profiles/sequent-g3/normalize.d.ts +15 -0
  158. package/dist/profiles/sequent-g3/normalize.d.ts.map +1 -0
  159. package/dist/profiles/sequent-g3/normalize.js +121 -0
  160. package/dist/profiles/sequent-g3/normalize.js.map +1 -0
  161. package/dist/profiles/sequent-g3/prover.d.ts +16 -0
  162. package/dist/profiles/sequent-g3/prover.d.ts.map +1 -0
  163. package/dist/profiles/sequent-g3/prover.js +348 -0
  164. package/dist/profiles/sequent-g3/prover.js.map +1 -0
  165. package/dist/profiles/sequent-g3/types.d.ts +30 -0
  166. package/dist/profiles/sequent-g3/types.d.ts.map +1 -0
  167. package/dist/profiles/sequent-g3/types.js +16 -0
  168. package/dist/profiles/sequent-g3/types.js.map +1 -0
  169. package/dist/runtime/countermodel-min/index.d.ts +3 -0
  170. package/dist/runtime/countermodel-min/index.d.ts.map +1 -0
  171. package/dist/runtime/countermodel-min/index.js +9 -0
  172. package/dist/runtime/countermodel-min/index.js.map +1 -0
  173. package/dist/runtime/countermodel-min/minimize.d.ts +17 -0
  174. package/dist/runtime/countermodel-min/minimize.d.ts.map +1 -0
  175. package/dist/runtime/countermodel-min/minimize.js +0 -0
  176. package/dist/runtime/countermodel-min/minimize.js.map +1 -0
  177. package/dist/runtime/countermodel-min/types.d.ts +40 -0
  178. package/dist/runtime/countermodel-min/types.d.ts.map +1 -0
  179. package/dist/runtime/countermodel-min/types.js +6 -0
  180. package/dist/runtime/countermodel-min/types.js.map +1 -0
  181. package/dist/runtime/mus/extract.d.ts +34 -0
  182. package/dist/runtime/mus/extract.d.ts.map +1 -0
  183. package/dist/runtime/mus/extract.js +243 -0
  184. package/dist/runtime/mus/extract.js.map +1 -0
  185. package/dist/runtime/mus/index.d.ts +4 -0
  186. package/dist/runtime/mus/index.d.ts.map +1 -0
  187. package/dist/runtime/mus/index.js +12 -0
  188. package/dist/runtime/mus/index.js.map +1 -0
  189. package/dist/runtime/mus/quickxplain.d.ts +10 -0
  190. package/dist/runtime/mus/quickxplain.d.ts.map +1 -0
  191. package/dist/runtime/mus/quickxplain.js +100 -0
  192. package/dist/runtime/mus/quickxplain.js.map +1 -0
  193. package/dist/runtime/mus/types.d.ts +59 -0
  194. package/dist/runtime/mus/types.d.ts.map +1 -0
  195. package/dist/runtime/mus/types.js +20 -0
  196. package/dist/runtime/mus/types.js.map +1 -0
  197. package/dist/solver/cdcl-v2-incremental/index.d.ts +3 -0
  198. package/dist/solver/cdcl-v2-incremental/index.d.ts.map +1 -0
  199. package/dist/solver/cdcl-v2-incremental/index.js +16 -0
  200. package/dist/solver/cdcl-v2-incremental/index.js.map +1 -0
  201. package/dist/solver/cdcl-v2-incremental/solver.d.ts +83 -0
  202. package/dist/solver/cdcl-v2-incremental/solver.d.ts.map +1 -0
  203. package/dist/solver/cdcl-v2-incremental/solver.js +727 -0
  204. package/dist/solver/cdcl-v2-incremental/solver.js.map +1 -0
  205. package/dist/solver/cdcl-v2-incremental/types.d.ts +47 -0
  206. package/dist/solver/cdcl-v2-incremental/types.d.ts.map +1 -0
  207. package/dist/solver/cdcl-v2-incremental/types.js +13 -0
  208. package/dist/solver/cdcl-v2-incremental/types.js.map +1 -0
  209. package/dist/tests/belief-revision/agm.test.d.ts +2 -0
  210. package/dist/tests/belief-revision/agm.test.d.ts.map +1 -0
  211. package/dist/tests/belief-revision/agm.test.js +173 -0
  212. package/dist/tests/belief-revision/agm.test.js.map +1 -0
  213. package/dist/tests/countermodel-min/minimize.test.d.ts +2 -0
  214. package/dist/tests/countermodel-min/minimize.test.d.ts.map +1 -0
  215. package/dist/tests/countermodel-min/minimize.test.js +241 -0
  216. package/dist/tests/countermodel-min/minimize.test.js.map +1 -0
  217. package/dist/tests/coverage-95/api-and-interpreter-e2e.test.d.ts +2 -0
  218. package/dist/tests/coverage-95/api-and-interpreter-e2e.test.d.ts.map +1 -0
  219. package/dist/tests/coverage-95/api-and-interpreter-e2e.test.js +255 -0
  220. package/dist/tests/coverage-95/api-and-interpreter-e2e.test.js.map +1 -0
  221. package/dist/tests/coverage-95/argumentation.test.d.ts +2 -0
  222. package/dist/tests/coverage-95/argumentation.test.d.ts.map +1 -0
  223. package/dist/tests/coverage-95/argumentation.test.js +105 -0
  224. package/dist/tests/coverage-95/argumentation.test.js.map +1 -0
  225. package/dist/tests/coverage-95/arithmetic.test.d.ts +2 -0
  226. package/dist/tests/coverage-95/arithmetic.test.d.ts.map +1 -0
  227. package/dist/tests/coverage-95/arithmetic.test.js +139 -0
  228. package/dist/tests/coverage-95/arithmetic.test.js.map +1 -0
  229. package/dist/tests/coverage-95/belnap.test.d.ts +2 -0
  230. package/dist/tests/coverage-95/belnap.test.d.ts.map +1 -0
  231. package/dist/tests/coverage-95/belnap.test.js +145 -0
  232. package/dist/tests/coverage-95/belnap.test.js.map +1 -0
  233. package/dist/tests/coverage-95/cdcl-v2-solver.test.d.ts +2 -0
  234. package/dist/tests/coverage-95/cdcl-v2-solver.test.d.ts.map +1 -0
  235. package/dist/tests/coverage-95/cdcl-v2-solver.test.js +61 -0
  236. package/dist/tests/coverage-95/cdcl-v2-solver.test.js.map +1 -0
  237. package/dist/tests/coverage-95/classical-propositional-direct.test.d.ts +2 -0
  238. package/dist/tests/coverage-95/classical-propositional-direct.test.d.ts.map +1 -0
  239. package/dist/tests/coverage-95/classical-propositional-direct.test.js +175 -0
  240. package/dist/tests/coverage-95/classical-propositional-direct.test.js.map +1 -0
  241. package/dist/tests/coverage-95/compat.test.d.ts +2 -0
  242. package/dist/tests/coverage-95/compat.test.d.ts.map +1 -0
  243. package/dist/tests/coverage-95/compat.test.js +82 -0
  244. package/dist/tests/coverage-95/compat.test.js.map +1 -0
  245. package/dist/tests/coverage-95/examples-runner.test.d.ts +2 -0
  246. package/dist/tests/coverage-95/examples-runner.test.d.ts.map +1 -0
  247. package/dist/tests/coverage-95/examples-runner.test.js +34 -0
  248. package/dist/tests/coverage-95/examples-runner.test.js.map +1 -0
  249. package/dist/tests/coverage-95/first-order.test.d.ts +2 -0
  250. package/dist/tests/coverage-95/first-order.test.d.ts.map +1 -0
  251. package/dist/tests/coverage-95/first-order.test.js +138 -0
  252. package/dist/tests/coverage-95/first-order.test.js.map +1 -0
  253. package/dist/tests/coverage-95/fol-prover.test.d.ts +2 -0
  254. package/dist/tests/coverage-95/fol-prover.test.d.ts.map +1 -0
  255. package/dist/tests/coverage-95/fol-prover.test.js +228 -0
  256. package/dist/tests/coverage-95/fol-prover.test.js.map +1 -0
  257. package/dist/tests/coverage-95/interpreter-commands.test.d.ts +2 -0
  258. package/dist/tests/coverage-95/interpreter-commands.test.d.ts.map +1 -0
  259. package/dist/tests/coverage-95/interpreter-commands.test.js +332 -0
  260. package/dist/tests/coverage-95/interpreter-commands.test.js.map +1 -0
  261. package/dist/tests/coverage-95/lsp-server.test.d.ts +2 -0
  262. package/dist/tests/coverage-95/lsp-server.test.d.ts.map +1 -0
  263. package/dist/tests/coverage-95/lsp-server.test.js +181 -0
  264. package/dist/tests/coverage-95/lsp-server.test.js.map +1 -0
  265. package/dist/tests/coverage-95/modal-tableau-profiles.test.d.ts +2 -0
  266. package/dist/tests/coverage-95/modal-tableau-profiles.test.d.ts.map +1 -0
  267. package/dist/tests/coverage-95/modal-tableau-profiles.test.js +157 -0
  268. package/dist/tests/coverage-95/modal-tableau-profiles.test.js.map +1 -0
  269. package/dist/tests/coverage-95/parallel-sat.test.d.ts +2 -0
  270. package/dist/tests/coverage-95/parallel-sat.test.d.ts.map +1 -0
  271. package/dist/tests/coverage-95/parallel-sat.test.js +42 -0
  272. package/dist/tests/coverage-95/parallel-sat.test.js.map +1 -0
  273. package/dist/tests/coverage-95/parser-extra.test.d.ts +2 -0
  274. package/dist/tests/coverage-95/parser-extra.test.d.ts.map +1 -0
  275. package/dist/tests/coverage-95/parser-extra.test.js +210 -0
  276. package/dist/tests/coverage-95/parser-extra.test.js.map +1 -0
  277. package/dist/tests/coverage-95/propositional-utilities.test.d.ts +2 -0
  278. package/dist/tests/coverage-95/propositional-utilities.test.d.ts.map +1 -0
  279. package/dist/tests/coverage-95/propositional-utilities.test.js +281 -0
  280. package/dist/tests/coverage-95/propositional-utilities.test.js.map +1 -0
  281. package/dist/tests/coverage-95/protocol-handler.test.d.ts +2 -0
  282. package/dist/tests/coverage-95/protocol-handler.test.d.ts.map +1 -0
  283. package/dist/tests/coverage-95/protocol-handler.test.js +275 -0
  284. package/dist/tests/coverage-95/protocol-handler.test.js.map +1 -0
  285. package/dist/tests/coverage-95/smt-mock-backend.test.d.ts +2 -0
  286. package/dist/tests/coverage-95/smt-mock-backend.test.d.ts.map +1 -0
  287. package/dist/tests/coverage-95/smt-mock-backend.test.js +201 -0
  288. package/dist/tests/coverage-95/smt-mock-backend.test.js.map +1 -0
  289. package/dist/tests/coverage-95/smt-serializer.test.d.ts +2 -0
  290. package/dist/tests/coverage-95/smt-serializer.test.d.ts.map +1 -0
  291. package/dist/tests/coverage-95/smt-serializer.test.js +143 -0
  292. package/dist/tests/coverage-95/smt-serializer.test.js.map +1 -0
  293. package/dist/tests/coverage-95/smt-subprocess.test.d.ts +2 -0
  294. package/dist/tests/coverage-95/smt-subprocess.test.d.ts.map +1 -0
  295. package/dist/tests/coverage-95/smt-subprocess.test.js +96 -0
  296. package/dist/tests/coverage-95/smt-subprocess.test.js.map +1 -0
  297. package/dist/tests/coverage-95/tableau-engine.test.d.ts +2 -0
  298. package/dist/tests/coverage-95/tableau-engine.test.d.ts.map +1 -0
  299. package/dist/tests/coverage-95/tableau-engine.test.js +125 -0
  300. package/dist/tests/coverage-95/tableau-engine.test.js.map +1 -0
  301. package/dist/tests/coverage-95/temporal-ltl.test.d.ts +2 -0
  302. package/dist/tests/coverage-95/temporal-ltl.test.d.ts.map +1 -0
  303. package/dist/tests/coverage-95/temporal-ltl.test.js +94 -0
  304. package/dist/tests/coverage-95/temporal-ltl.test.js.map +1 -0
  305. package/dist/tests/coverage-95/typecheck-checker.test.d.ts +2 -0
  306. package/dist/tests/coverage-95/typecheck-checker.test.d.ts.map +1 -0
  307. package/dist/tests/coverage-95/typecheck-checker.test.js +191 -0
  308. package/dist/tests/coverage-95/typecheck-checker.test.js.map +1 -0
  309. package/dist/tests/coverage-95/undecidability-detector.test.d.ts +2 -0
  310. package/dist/tests/coverage-95/undecidability-detector.test.d.ts.map +1 -0
  311. package/dist/tests/coverage-95/undecidability-detector.test.js +149 -0
  312. package/dist/tests/coverage-95/undecidability-detector.test.js.map +1 -0
  313. package/dist/tests/coverage-95/visitor.test.d.ts +2 -0
  314. package/dist/tests/coverage-95/visitor.test.d.ts.map +1 -0
  315. package/dist/tests/coverage-95/visitor.test.js +140 -0
  316. package/dist/tests/coverage-95/visitor.test.js.map +1 -0
  317. package/dist/tests/ctl/check.test.d.ts +2 -0
  318. package/dist/tests/ctl/check.test.d.ts.map +1 -0
  319. package/dist/tests/ctl/check.test.js +337 -0
  320. package/dist/tests/ctl/check.test.js.map +1 -0
  321. package/dist/tests/curry-howard/infer.test.d.ts +2 -0
  322. package/dist/tests/curry-howard/infer.test.d.ts.map +1 -0
  323. package/dist/tests/curry-howard/infer.test.js +93 -0
  324. package/dist/tests/curry-howard/infer.test.js.map +1 -0
  325. package/dist/tests/curry-howard/proof.test.d.ts +2 -0
  326. package/dist/tests/curry-howard/proof.test.d.ts.map +1 -0
  327. package/dist/tests/curry-howard/proof.test.js +105 -0
  328. package/dist/tests/curry-howard/proof.test.js.map +1 -0
  329. package/dist/tests/curry-howard/reduce.test.d.ts +2 -0
  330. package/dist/tests/curry-howard/reduce.test.d.ts.map +1 -0
  331. package/dist/tests/curry-howard/reduce.test.js +109 -0
  332. package/dist/tests/curry-howard/reduce.test.js.map +1 -0
  333. package/dist/tests/default-logic/extensions.test.d.ts +2 -0
  334. package/dist/tests/default-logic/extensions.test.d.ts.map +1 -0
  335. package/dist/tests/default-logic/extensions.test.js +323 -0
  336. package/dist/tests/default-logic/extensions.test.js.map +1 -0
  337. package/dist/tests/description-logic/alc.test.d.ts +2 -0
  338. package/dist/tests/description-logic/alc.test.d.ts.map +1 -0
  339. package/dist/tests/description-logic/alc.test.js +253 -0
  340. package/dist/tests/description-logic/alc.test.js.map +1 -0
  341. package/dist/tests/fol-prover-equality/prove.test.d.ts +2 -0
  342. package/dist/tests/fol-prover-equality/prove.test.d.ts.map +1 -0
  343. package/dist/tests/fol-prover-equality/prove.test.js +179 -0
  344. package/dist/tests/fol-prover-equality/prove.test.js.map +1 -0
  345. package/dist/tests/hybrid-logic/semantics.test.d.ts +2 -0
  346. package/dist/tests/hybrid-logic/semantics.test.d.ts.map +1 -0
  347. package/dist/tests/hybrid-logic/semantics.test.js +169 -0
  348. package/dist/tests/hybrid-logic/semantics.test.js.map +1 -0
  349. package/dist/tests/ltl-sat/sat.test.d.ts +2 -0
  350. package/dist/tests/ltl-sat/sat.test.d.ts.map +1 -0
  351. package/dist/tests/ltl-sat/sat.test.js +160 -0
  352. package/dist/tests/ltl-sat/sat.test.js.map +1 -0
  353. package/dist/tests/mus/extract.test.d.ts +2 -0
  354. package/dist/tests/mus/extract.test.d.ts.map +1 -0
  355. package/dist/tests/mus/extract.test.js +352 -0
  356. package/dist/tests/mus/extract.test.js.map +1 -0
  357. package/dist/tests/sat-v2-incremental/basic.test.d.ts +2 -0
  358. package/dist/tests/sat-v2-incremental/basic.test.d.ts.map +1 -0
  359. package/dist/tests/sat-v2-incremental/basic.test.js +352 -0
  360. package/dist/tests/sat-v2-incremental/basic.test.js.map +1 -0
  361. package/dist/tests/sequent-g3/prover.test.d.ts +2 -0
  362. package/dist/tests/sequent-g3/prover.test.d.ts.map +1 -0
  363. package/dist/tests/sequent-g3/prover.test.js +205 -0
  364. package/dist/tests/sequent-g3/prover.test.js.map +1 -0
  365. package/dist/tests/text-layer-v2/mdx-bridge/mdx-bridge.test.d.ts +2 -0
  366. package/dist/tests/text-layer-v2/mdx-bridge/mdx-bridge.test.d.ts.map +1 -0
  367. package/dist/tests/text-layer-v2/mdx-bridge/mdx-bridge.test.js +200 -0
  368. package/dist/tests/text-layer-v2/mdx-bridge/mdx-bridge.test.js.map +1 -0
  369. package/dist/text-layer/v2/index.d.ts +2 -0
  370. package/dist/text-layer/v2/index.d.ts.map +1 -1
  371. package/dist/text-layer/v2/index.js +7 -1
  372. package/dist/text-layer/v2/index.js.map +1 -1
  373. package/dist/text-layer/v2/mdx-bridge/diff.d.ts +13 -0
  374. package/dist/text-layer/v2/mdx-bridge/diff.d.ts.map +1 -0
  375. package/dist/text-layer/v2/mdx-bridge/diff.js +69 -0
  376. package/dist/text-layer/v2/mdx-bridge/diff.js.map +1 -0
  377. package/dist/text-layer/v2/mdx-bridge/index.d.ts +14 -0
  378. package/dist/text-layer/v2/mdx-bridge/index.d.ts.map +1 -0
  379. package/dist/text-layer/v2/mdx-bridge/index.js +21 -0
  380. package/dist/text-layer/v2/mdx-bridge/index.js.map +1 -0
  381. package/dist/text-layer/v2/mdx-bridge/parser.d.ts +33 -0
  382. package/dist/text-layer/v2/mdx-bridge/parser.d.ts.map +1 -0
  383. package/dist/text-layer/v2/mdx-bridge/parser.js +192 -0
  384. package/dist/text-layer/v2/mdx-bridge/parser.js.map +1 -0
  385. package/dist/text-layer/v2/mdx-bridge/serializer.d.ts +17 -0
  386. package/dist/text-layer/v2/mdx-bridge/serializer.d.ts.map +1 -0
  387. package/dist/text-layer/v2/mdx-bridge/serializer.js +69 -0
  388. package/dist/text-layer/v2/mdx-bridge/serializer.js.map +1 -0
  389. package/dist/text-layer/v2/mdx-bridge/types.d.ts +53 -0
  390. package/dist/text-layer/v2/mdx-bridge/types.d.ts.map +1 -0
  391. package/dist/text-layer/v2/mdx-bridge/types.js +19 -0
  392. package/dist/text-layer/v2/mdx-bridge/types.js.map +1 -0
  393. package/package.json +1 -1
@@ -0,0 +1,323 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ /**
4
+ * ST Default Logic (Reiter) — Tests de extensiones y entailment
5
+ * =============================================================
6
+ * Valida cálculo de extensiones, entailment crédulo/escéptico y
7
+ * los casos canónicos de la literatura (Tweety, Nixon diamond,
8
+ * defaults sin prerequisite cumplido, conflictos múltiples).
9
+ */
10
+ const vitest_1 = require("vitest");
11
+ const default_logic_1 = require("../../profiles/default-logic");
12
+ (0, vitest_1.describe)('default-logic — normalizeLiteral', () => {
13
+ (0, vitest_1.it)('canoniza literales positivos y negativos', () => {
14
+ (0, vitest_1.expect)((0, default_logic_1.normalizeLiteral)('P')).toBe('P');
15
+ (0, vitest_1.expect)((0, default_logic_1.normalizeLiteral)(' P ')).toBe('P');
16
+ (0, vitest_1.expect)((0, default_logic_1.normalizeLiteral)('¬P')).toBe('¬P');
17
+ (0, vitest_1.expect)((0, default_logic_1.normalizeLiteral)('!P')).toBe('¬P');
18
+ (0, vitest_1.expect)((0, default_logic_1.normalizeLiteral)('~P')).toBe('¬P');
19
+ (0, vitest_1.expect)((0, default_logic_1.normalizeLiteral)('not P')).toBe('¬P');
20
+ (0, vitest_1.expect)((0, default_logic_1.normalizeLiteral)('NOT P')).toBe('¬P');
21
+ });
22
+ (0, vitest_1.it)('cancela dobles negaciones', () => {
23
+ (0, vitest_1.expect)((0, default_logic_1.normalizeLiteral)('¬¬P')).toBe('P');
24
+ (0, vitest_1.expect)((0, default_logic_1.normalizeLiteral)('!!P')).toBe('P');
25
+ (0, vitest_1.expect)((0, default_logic_1.normalizeLiteral)('¬!P')).toBe('P');
26
+ (0, vitest_1.expect)((0, default_logic_1.normalizeLiteral)('not not P')).toBe('P');
27
+ });
28
+ (0, vitest_1.it)('preserva predicados FOL como literales atómicos', () => {
29
+ (0, vitest_1.expect)((0, default_logic_1.normalizeLiteral)('flies(tweety)')).toBe('flies(tweety)');
30
+ (0, vitest_1.expect)((0, default_logic_1.normalizeLiteral)('¬flies(tweety)')).toBe('¬flies(tweety)');
31
+ (0, vitest_1.expect)((0, default_logic_1.normalizeLiteral)('!penguin(opus)')).toBe('¬penguin(opus)');
32
+ });
33
+ (0, vitest_1.it)('lanza error en literal vacío o sin átomo', () => {
34
+ (0, vitest_1.expect)(() => (0, default_logic_1.normalizeLiteral)('')).toThrow();
35
+ (0, vitest_1.expect)(() => (0, default_logic_1.normalizeLiteral)(' ')).toThrow();
36
+ (0, vitest_1.expect)(() => (0, default_logic_1.normalizeLiteral)('¬¬')).toThrow();
37
+ });
38
+ });
39
+ (0, vitest_1.describe)('default-logic — negate y consistencia', () => {
40
+ (0, vitest_1.it)('negate alterna polaridad', () => {
41
+ (0, vitest_1.expect)((0, default_logic_1.negate)('P')).toBe('¬P');
42
+ (0, vitest_1.expect)((0, default_logic_1.negate)('¬P')).toBe('P');
43
+ (0, vitest_1.expect)((0, default_logic_1.negate)('flies(tweety)')).toBe('¬flies(tweety)');
44
+ });
45
+ (0, vitest_1.it)('isConsistent detecta pares L/¬L', () => {
46
+ (0, vitest_1.expect)((0, default_logic_1.isConsistent)(new Set(['P', 'Q']))).toBe(true);
47
+ (0, vitest_1.expect)((0, default_logic_1.isConsistent)(new Set(['P', '¬P']))).toBe(false);
48
+ (0, vitest_1.expect)((0, default_logic_1.isConsistent)(new Set(['flies(tweety)', '¬flies(tweety)']))).toBe(false);
49
+ (0, vitest_1.expect)((0, default_logic_1.isConsistent)(new Set())).toBe(true);
50
+ });
51
+ });
52
+ (0, vitest_1.describe)('default-logic — teorías triviales', () => {
53
+ (0, vitest_1.it)('sin defaults: extensión única = facts', () => {
54
+ const T = { facts: ['P', 'Q'], defaults: [] };
55
+ const exts = (0, default_logic_1.computeExtensions)(T);
56
+ (0, vitest_1.expect)(exts).toHaveLength(1);
57
+ (0, vitest_1.expect)(Array.from(exts[0].formulas).sort()).toEqual(['P', 'Q']);
58
+ (0, vitest_1.expect)(exts[0].appliedDefaults).toEqual([]);
59
+ });
60
+ (0, vitest_1.it)('sin facts ni defaults: una extensión vacía', () => {
61
+ const T = { facts: [], defaults: [] };
62
+ const exts = (0, default_logic_1.computeExtensions)(T);
63
+ (0, vitest_1.expect)(exts).toHaveLength(1);
64
+ (0, vitest_1.expect)(exts[0].formulas.size).toBe(0);
65
+ });
66
+ (0, vitest_1.it)('default con prerequisite no cumplido NO se aplica', () => {
67
+ const T = {
68
+ facts: ['Q'], // no incluye P
69
+ defaults: [{ id: 'd1', prerequisite: 'P', justifications: ['R'], consequent: 'R' }],
70
+ };
71
+ const exts = (0, default_logic_1.computeExtensions)(T);
72
+ (0, vitest_1.expect)(exts).toHaveLength(1);
73
+ (0, vitest_1.expect)(exts[0].formulas.has('R')).toBe(false);
74
+ (0, vitest_1.expect)(exts[0].appliedDefaults).toEqual([]);
75
+ });
76
+ });
77
+ (0, vitest_1.describe)('default-logic — caso Tweety', () => {
78
+ const facts = ['bird(tweety)'];
79
+ const dBirdsFly = {
80
+ id: 'birds-fly',
81
+ prerequisite: 'bird(tweety)',
82
+ justifications: ['flies(tweety)'],
83
+ consequent: 'flies(tweety)',
84
+ };
85
+ (0, vitest_1.it)('Tweety vuela: única extensión con flies(tweety)', () => {
86
+ const T = { facts, defaults: [dBirdsFly] };
87
+ const exts = (0, default_logic_1.computeExtensions)(T);
88
+ (0, vitest_1.expect)(exts).toHaveLength(1);
89
+ (0, vitest_1.expect)(exts[0].formulas.has('flies(tweety)')).toBe(true);
90
+ (0, vitest_1.expect)(exts[0].appliedDefaults).toEqual(['birds-fly']);
91
+ });
92
+ (0, vitest_1.it)('Tweety + entailment crédulo y escéptico coinciden con extensión única', () => {
93
+ const T = { facts, defaults: [dBirdsFly] };
94
+ (0, vitest_1.expect)((0, default_logic_1.isCredulouslyEntailed)('flies(tweety)', T)).toBe(true);
95
+ (0, vitest_1.expect)((0, default_logic_1.isSkepticallyEntailed)('flies(tweety)', T)).toBe(true);
96
+ (0, vitest_1.expect)((0, default_logic_1.isCredulouslyEntailed)('¬flies(tweety)', T)).toBe(false);
97
+ });
98
+ (0, vitest_1.it)('Penguin + bird: el default "birds fly" queda bloqueado por inconsistencia', () => {
99
+ // Pingüino que también es pájaro, pero el hecho ¬flies bloquea el default.
100
+ const T = {
101
+ facts: ['bird(opus)', 'penguin(opus)', '¬flies(opus)'],
102
+ defaults: [
103
+ {
104
+ id: 'birds-fly',
105
+ prerequisite: 'bird(opus)',
106
+ justifications: ['flies(opus)'],
107
+ consequent: 'flies(opus)',
108
+ },
109
+ ],
110
+ };
111
+ const exts = (0, default_logic_1.computeExtensions)(T);
112
+ (0, vitest_1.expect)(exts).toHaveLength(1);
113
+ (0, vitest_1.expect)(exts[0].formulas.has('flies(opus)')).toBe(false);
114
+ (0, vitest_1.expect)(exts[0].formulas.has('¬flies(opus)')).toBe(true);
115
+ (0, vitest_1.expect)(exts[0].appliedDefaults).toEqual([]);
116
+ });
117
+ (0, vitest_1.it)('Penguin con defaults compitiendo: prioridad por prerequisite más específico se elige por aplicabilidad', () => {
118
+ // Dos defaults en conflicto, sin penguin como hecho duro.
119
+ // En Reiter "puro" (sin priorización) ambos defaults son aplicables
120
+ // pero mutuamente excluyentes → dos extensiones.
121
+ const T = {
122
+ facts: ['bird(opus)', 'penguin(opus)'],
123
+ defaults: [
124
+ {
125
+ id: 'birds-fly',
126
+ prerequisite: 'bird(opus)',
127
+ justifications: ['flies(opus)'],
128
+ consequent: 'flies(opus)',
129
+ },
130
+ {
131
+ id: 'penguins-dont-fly',
132
+ prerequisite: 'penguin(opus)',
133
+ justifications: ['¬flies(opus)'],
134
+ consequent: '¬flies(opus)',
135
+ },
136
+ ],
137
+ };
138
+ const exts = (0, default_logic_1.computeExtensions)(T);
139
+ (0, vitest_1.expect)(exts).toHaveLength(2);
140
+ const fliesExt = exts.find((e) => e.formulas.has('flies(opus)'));
141
+ const noFliesExt = exts.find((e) => e.formulas.has('¬flies(opus)'));
142
+ (0, vitest_1.expect)(fliesExt).toBeDefined();
143
+ (0, vitest_1.expect)(noFliesExt).toBeDefined();
144
+ // Entailment: crédulo ambos, escéptico ninguno
145
+ (0, vitest_1.expect)((0, default_logic_1.isCredulouslyEntailed)('flies(opus)', T)).toBe(true);
146
+ (0, vitest_1.expect)((0, default_logic_1.isCredulouslyEntailed)('¬flies(opus)', T)).toBe(true);
147
+ (0, vitest_1.expect)((0, default_logic_1.isSkepticallyEntailed)('flies(opus)', T)).toBe(false);
148
+ (0, vitest_1.expect)((0, default_logic_1.isSkepticallyEntailed)('¬flies(opus)', T)).toBe(false);
149
+ // bird(opus) y penguin(opus) sí son escépticos
150
+ (0, vitest_1.expect)((0, default_logic_1.isSkepticallyEntailed)('bird(opus)', T)).toBe(true);
151
+ (0, vitest_1.expect)((0, default_logic_1.isSkepticallyEntailed)('penguin(opus)', T)).toBe(true);
152
+ });
153
+ });
154
+ (0, vitest_1.describe)('default-logic — Nixon diamond', () => {
155
+ (0, vitest_1.it)('Nixon: republicano (no pacifista) vs cuáquero (pacifista) → 2 extensiones', () => {
156
+ // Caso canónico de Reiter: Nixon es republicano y cuáquero.
157
+ // Republicanos típicamente NO son pacifistas; cuáqueros típicamente SÍ.
158
+ const T = {
159
+ facts: ['republican(nixon)', 'quaker(nixon)'],
160
+ defaults: [
161
+ {
162
+ id: 'rep-not-pacifist',
163
+ prerequisite: 'republican(nixon)',
164
+ justifications: ['¬pacifist(nixon)'],
165
+ consequent: '¬pacifist(nixon)',
166
+ },
167
+ {
168
+ id: 'quaker-pacifist',
169
+ prerequisite: 'quaker(nixon)',
170
+ justifications: ['pacifist(nixon)'],
171
+ consequent: 'pacifist(nixon)',
172
+ },
173
+ ],
174
+ };
175
+ const exts = (0, default_logic_1.computeExtensions)(T);
176
+ (0, vitest_1.expect)(exts).toHaveLength(2);
177
+ (0, vitest_1.expect)((0, default_logic_1.isCredulouslyEntailed)('pacifist(nixon)', T)).toBe(true);
178
+ (0, vitest_1.expect)((0, default_logic_1.isCredulouslyEntailed)('¬pacifist(nixon)', T)).toBe(true);
179
+ (0, vitest_1.expect)((0, default_logic_1.isSkepticallyEntailed)('pacifist(nixon)', T)).toBe(false);
180
+ (0, vitest_1.expect)((0, default_logic_1.isSkepticallyEntailed)('¬pacifist(nixon)', T)).toBe(false);
181
+ });
182
+ });
183
+ (0, vitest_1.describe)('default-logic — cadenas y dependencias', () => {
184
+ (0, vitest_1.it)('cadena de defaults: P → Q → R', () => {
185
+ const T = {
186
+ facts: ['P'],
187
+ defaults: [
188
+ { id: 'd1', prerequisite: 'P', justifications: ['Q'], consequent: 'Q' },
189
+ { id: 'd2', prerequisite: 'Q', justifications: ['R'], consequent: 'R' },
190
+ ],
191
+ };
192
+ const exts = (0, default_logic_1.computeExtensions)(T);
193
+ (0, vitest_1.expect)(exts).toHaveLength(1);
194
+ (0, vitest_1.expect)(exts[0].formulas.has('Q')).toBe(true);
195
+ (0, vitest_1.expect)(exts[0].formulas.has('R')).toBe(true);
196
+ (0, vitest_1.expect)(exts[0].appliedDefaults.sort()).toEqual(['d1', 'd2']);
197
+ });
198
+ (0, vitest_1.it)('justificación inconsistente con facts bloquea default', () => {
199
+ const T = {
200
+ facts: ['P', '¬Q'],
201
+ defaults: [
202
+ // β=Q, pero ¬Q ∈ facts → no consistente
203
+ { id: 'd1', prerequisite: 'P', justifications: ['Q'], consequent: 'R' },
204
+ ],
205
+ };
206
+ const exts = (0, default_logic_1.computeExtensions)(T);
207
+ (0, vitest_1.expect)(exts).toHaveLength(1);
208
+ (0, vitest_1.expect)(exts[0].formulas.has('R')).toBe(false);
209
+ (0, vitest_1.expect)(exts[0].appliedDefaults).toEqual([]);
210
+ });
211
+ (0, vitest_1.it)('defaults independientes que no compiten: ambos aplican en una sola extensión', () => {
212
+ const T = {
213
+ facts: ['A', 'B'],
214
+ defaults: [
215
+ { id: 'd1', prerequisite: 'A', justifications: ['X'], consequent: 'X' },
216
+ { id: 'd2', prerequisite: 'B', justifications: ['Y'], consequent: 'Y' },
217
+ ],
218
+ };
219
+ const exts = (0, default_logic_1.computeExtensions)(T);
220
+ (0, vitest_1.expect)(exts).toHaveLength(1);
221
+ (0, vitest_1.expect)(exts[0].formulas.has('X')).toBe(true);
222
+ (0, vitest_1.expect)(exts[0].formulas.has('Y')).toBe(true);
223
+ });
224
+ (0, vitest_1.it)('default con consequent que rompería consistencia con facts: 0 extensiones (teoría incoherente en Reiter)', () => {
225
+ // Caso conocido de Reiter: la justificación X es consistente con cualquier
226
+ // candidato E, así que el operador Γ_T fuerza R en E. Pero R contradice
227
+ // ¬R ∈ facts, así que ningún E puede ser punto fijo. Resultado correcto:
228
+ // 0 extensiones (la teoría no tiene extensiones).
229
+ const T = {
230
+ facts: ['P', '¬R'],
231
+ defaults: [{ id: 'd1', prerequisite: 'P', justifications: ['X'], consequent: 'R' }],
232
+ };
233
+ const exts = (0, default_logic_1.computeExtensions)(T);
234
+ (0, vitest_1.expect)(exts).toHaveLength(0);
235
+ // Entailment escéptico/crédulo sobre teoría sin extensiones: false
236
+ (0, vitest_1.expect)((0, default_logic_1.isSkepticallyEntailed)('R', T)).toBe(false);
237
+ (0, vitest_1.expect)((0, default_logic_1.isCredulouslyEntailed)('R', T)).toBe(false);
238
+ });
239
+ });
240
+ (0, vitest_1.describe)('default-logic — múltiples justificaciones', () => {
241
+ (0, vitest_1.it)('default aplica solo si TODAS las justificaciones son consistentes', () => {
242
+ const T = {
243
+ facts: ['P', '¬B'],
244
+ defaults: [
245
+ // Necesita A y B consistentes; ¬B ∈ facts → bloqueado
246
+ { id: 'd1', prerequisite: 'P', justifications: ['A', 'B'], consequent: 'C' },
247
+ ],
248
+ };
249
+ const exts = (0, default_logic_1.computeExtensions)(T);
250
+ (0, vitest_1.expect)(exts).toHaveLength(1);
251
+ (0, vitest_1.expect)(exts[0].formulas.has('C')).toBe(false);
252
+ });
253
+ (0, vitest_1.it)('todas las justificaciones consistentes → consequent se añade', () => {
254
+ const T = {
255
+ facts: ['P'],
256
+ defaults: [{ id: 'd1', prerequisite: 'P', justifications: ['A', 'B'], consequent: 'C' }],
257
+ };
258
+ const exts = (0, default_logic_1.computeExtensions)(T);
259
+ (0, vitest_1.expect)(exts).toHaveLength(1);
260
+ (0, vitest_1.expect)(exts[0].formulas.has('C')).toBe(true);
261
+ });
262
+ });
263
+ (0, vitest_1.describe)('default-logic — isInExtension y validaciones', () => {
264
+ (0, vitest_1.it)('isInExtension acepta formas no-canónicas de literal', () => {
265
+ const T = {
266
+ facts: ['P'],
267
+ defaults: [{ id: 'd1', prerequisite: 'P', justifications: ['Q'], consequent: 'Q' }],
268
+ };
269
+ const ext = (0, default_logic_1.computeExtensions)(T)[0];
270
+ (0, vitest_1.expect)((0, default_logic_1.isInExtension)('Q', ext)).toBe(true);
271
+ (0, vitest_1.expect)((0, default_logic_1.isInExtension)(' Q ', ext)).toBe(true);
272
+ (0, vitest_1.expect)((0, default_logic_1.isInExtension)('¬¬Q', ext)).toBe(true);
273
+ (0, vitest_1.expect)((0, default_logic_1.isInExtension)('¬Q', ext)).toBe(false);
274
+ });
275
+ (0, vitest_1.it)('facts inconsistentes lanzan error', () => {
276
+ const T = { facts: ['P', '¬P'], defaults: [] };
277
+ (0, vitest_1.expect)(() => (0, default_logic_1.computeExtensions)(T)).toThrow(/inconsistentes/i);
278
+ });
279
+ (0, vitest_1.it)('IDs de defaults duplicados lanzan error', () => {
280
+ const T = {
281
+ facts: ['P'],
282
+ defaults: [
283
+ { id: 'd1', prerequisite: 'P', justifications: ['Q'], consequent: 'Q' },
284
+ { id: 'd1', prerequisite: 'P', justifications: ['R'], consequent: 'R' },
285
+ ],
286
+ };
287
+ (0, vitest_1.expect)(() => (0, default_logic_1.computeExtensions)(T)).toThrow(/duplicado/i);
288
+ });
289
+ });
290
+ (0, vitest_1.describe)('default-logic — opciones', () => {
291
+ (0, vitest_1.it)('respeta maxExtensions', () => {
292
+ // Tres pares independientes → 2^3 = 8 extensiones potenciales
293
+ const T = {
294
+ facts: ['A', 'B', 'C'],
295
+ defaults: [
296
+ { id: 'pa', prerequisite: 'A', justifications: ['Pa'], consequent: 'Pa' },
297
+ { id: 'na', prerequisite: 'A', justifications: ['¬Pa'], consequent: '¬Pa' },
298
+ { id: 'pb', prerequisite: 'B', justifications: ['Pb'], consequent: 'Pb' },
299
+ { id: 'nb', prerequisite: 'B', justifications: ['¬Pb'], consequent: '¬Pb' },
300
+ { id: 'pc', prerequisite: 'C', justifications: ['Pc'], consequent: 'Pc' },
301
+ { id: 'nc', prerequisite: 'C', justifications: ['¬Pc'], consequent: '¬Pc' },
302
+ ],
303
+ };
304
+ const exts = (0, default_logic_1.computeExtensions)(T, { maxExtensions: 4 });
305
+ (0, vitest_1.expect)(exts.length).toBeLessThanOrEqual(4);
306
+ (0, vitest_1.expect)(exts.length).toBeGreaterThan(0);
307
+ });
308
+ (0, vitest_1.it)('rechaza teorías con más defaults que maxDefaults', () => {
309
+ const defaults = Array.from({ length: 10 }, (_, i) => ({
310
+ id: `d${i}`,
311
+ prerequisite: 'P',
312
+ justifications: [`Q${i}`],
313
+ consequent: `Q${i}`,
314
+ }));
315
+ const T = { facts: ['P'], defaults };
316
+ (0, vitest_1.expect)(() => (0, default_logic_1.computeExtensions)(T, { maxDefaults: 5 })).toThrow(/excede el límite/);
317
+ // Con maxDefaults amplio funciona
318
+ const exts = (0, default_logic_1.computeExtensions)(T, { maxDefaults: 20 });
319
+ (0, vitest_1.expect)(exts).toHaveLength(1);
320
+ (0, vitest_1.expect)(exts[0].appliedDefaults).toHaveLength(10);
321
+ });
322
+ });
323
+ //# sourceMappingURL=extensions.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"extensions.test.js","sourceRoot":"","sources":["../../../src/tests/default-logic/extensions.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=alc.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"alc.test.d.ts","sourceRoot":"","sources":["../../../src/tests/description-logic/alc.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,253 @@
1
+ "use strict";
2
+ // ============================================================
3
+ // ST Description Logic — Tests del perfil ALC
4
+ // ============================================================
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const vitest_1 = require("vitest");
7
+ const description_logic_1 = require("../../profiles/description-logic");
8
+ (0, vitest_1.describe)('ALC — NNF', () => {
9
+ (0, vitest_1.it)('empuja ¬ al interior y elimina ⊤/⊥ bajo ¬', () => {
10
+ const c = (0, description_logic_1.not)((0, description_logic_1.and)((0, description_logic_1.atomic)('A'), (0, description_logic_1.or)((0, description_logic_1.atomic)('B'), (0, description_logic_1.atomic)('C'))));
11
+ const n = (0, description_logic_1.toNNF)(c);
12
+ // ¬(A ⊓ (B ⊔ C)) = ¬A ⊔ (¬B ⊓ ¬C)
13
+ (0, vitest_1.expect)((0, description_logic_1.conceptEqual)(n, (0, description_logic_1.or)((0, description_logic_1.not)((0, description_logic_1.atomic)('A')), (0, description_logic_1.and)((0, description_logic_1.not)((0, description_logic_1.atomic)('B')), (0, description_logic_1.not)((0, description_logic_1.atomic)('C')))))).toBe(true);
14
+ });
15
+ (0, vitest_1.it)('¬⊤ = ⊥ y ¬⊥ = ⊤', () => {
16
+ (0, vitest_1.expect)((0, description_logic_1.conceptEqual)((0, description_logic_1.toNNF)((0, description_logic_1.not)(description_logic_1.TOP)), description_logic_1.BOTTOM)).toBe(true);
17
+ (0, vitest_1.expect)((0, description_logic_1.conceptEqual)((0, description_logic_1.toNNF)((0, description_logic_1.not)(description_logic_1.BOTTOM)), description_logic_1.TOP)).toBe(true);
18
+ });
19
+ (0, vitest_1.it)('¬∃R.C = ∀R.¬C y viceversa', () => {
20
+ const c = (0, description_logic_1.atomic)('C');
21
+ (0, vitest_1.expect)((0, description_logic_1.conceptEqual)((0, description_logic_1.toNNF)((0, description_logic_1.not)((0, description_logic_1.exists)('R', c))), (0, description_logic_1.forall)('R', (0, description_logic_1.not)(c)))).toBe(true);
22
+ (0, vitest_1.expect)((0, description_logic_1.conceptEqual)((0, description_logic_1.toNNF)((0, description_logic_1.not)((0, description_logic_1.forall)('R', c))), (0, description_logic_1.exists)('R', (0, description_logic_1.not)(c)))).toBe(true);
23
+ });
24
+ (0, vitest_1.it)('conceptToString rinde notación legible', () => {
25
+ (0, vitest_1.expect)((0, description_logic_1.conceptToString)(description_logic_1.TOP)).toBe('⊤');
26
+ (0, vitest_1.expect)((0, description_logic_1.conceptToString)(description_logic_1.BOTTOM)).toBe('⊥');
27
+ (0, vitest_1.expect)((0, description_logic_1.conceptToString)((0, description_logic_1.atomic)('Dog'))).toBe('Dog');
28
+ (0, vitest_1.expect)((0, description_logic_1.conceptToString)((0, description_logic_1.not)((0, description_logic_1.atomic)('A')))).toBe('¬A');
29
+ (0, vitest_1.expect)((0, description_logic_1.conceptToString)((0, description_logic_1.exists)('hasChild', (0, description_logic_1.atomic)('Person')))).toBe('∃hasChild.Person');
30
+ (0, vitest_1.expect)((0, description_logic_1.conceptToString)((0, description_logic_1.forall)('R', (0, description_logic_1.atomic)('A')))).toBe('∀R.A');
31
+ (0, vitest_1.expect)((0, description_logic_1.conceptToString)((0, description_logic_1.and)((0, description_logic_1.atomic)('A'), (0, description_logic_1.atomic)('B')))).toBe('(A ⊓ B)');
32
+ (0, vitest_1.expect)((0, description_logic_1.conceptToString)((0, description_logic_1.or)((0, description_logic_1.atomic)('A'), (0, description_logic_1.atomic)('B')))).toBe('(A ⊔ B)');
33
+ });
34
+ (0, vitest_1.it)('conceptHash es estable y conmutativo en and/or', () => {
35
+ const a = (0, description_logic_1.and)((0, description_logic_1.atomic)('A'), (0, description_logic_1.atomic)('B'));
36
+ const b = (0, description_logic_1.and)((0, description_logic_1.atomic)('B'), (0, description_logic_1.atomic)('A'));
37
+ (0, vitest_1.expect)((0, description_logic_1.conceptHash)(a)).toBe((0, description_logic_1.conceptHash)(b));
38
+ });
39
+ });
40
+ (0, vitest_1.describe)('ALC — Satisfiability básica', () => {
41
+ (0, vitest_1.it)('⊤ es satisfacible', () => {
42
+ (0, vitest_1.expect)((0, description_logic_1.isSatisfiable)(description_logic_1.TOP)).toBe(true);
43
+ });
44
+ (0, vitest_1.it)('⊥ NO es satisfacible', () => {
45
+ (0, vitest_1.expect)((0, description_logic_1.isSatisfiable)(description_logic_1.BOTTOM)).toBe(false);
46
+ });
47
+ (0, vitest_1.it)('A ⊓ ¬A es insatisfacible', () => {
48
+ (0, vitest_1.expect)((0, description_logic_1.isSatisfiable)((0, description_logic_1.and)((0, description_logic_1.atomic)('A'), (0, description_logic_1.not)((0, description_logic_1.atomic)('A'))))).toBe(false);
49
+ });
50
+ (0, vitest_1.it)('A ⊔ ¬A es satisfacible (TND clásico)', () => {
51
+ (0, vitest_1.expect)((0, description_logic_1.isSatisfiable)((0, description_logic_1.or)((0, description_logic_1.atomic)('A'), (0, description_logic_1.not)((0, description_logic_1.atomic)('A'))))).toBe(true);
52
+ });
53
+ (0, vitest_1.it)('A atómico solo es satisfacible', () => {
54
+ (0, vitest_1.expect)((0, description_logic_1.isSatisfiable)((0, description_logic_1.atomic)('A'))).toBe(true);
55
+ });
56
+ (0, vitest_1.it)('∃R.A es satisfacible con KB vacío', () => {
57
+ (0, vitest_1.expect)((0, description_logic_1.isSatisfiable)((0, description_logic_1.exists)('R', (0, description_logic_1.atomic)('A')))).toBe(true);
58
+ });
59
+ (0, vitest_1.it)('∀R.A es satisfacible (trivial: sin sucesores)', () => {
60
+ (0, vitest_1.expect)((0, description_logic_1.isSatisfiable)((0, description_logic_1.forall)('R', (0, description_logic_1.atomic)('A')))).toBe(true);
61
+ });
62
+ });
63
+ (0, vitest_1.describe)('ALC — Interacción ∃/∀', () => {
64
+ (0, vitest_1.it)('∃R.A ⊓ ∀R.¬A es INSATISFACIBLE', () => {
65
+ const c = (0, description_logic_1.and)((0, description_logic_1.exists)('R', (0, description_logic_1.atomic)('A')), (0, description_logic_1.forall)('R', (0, description_logic_1.not)((0, description_logic_1.atomic)('A'))));
66
+ (0, vitest_1.expect)((0, description_logic_1.isSatisfiable)(c)).toBe(false);
67
+ });
68
+ (0, vitest_1.it)('∃R.A ⊓ ∀R.A es satisfacible', () => {
69
+ const c = (0, description_logic_1.and)((0, description_logic_1.exists)('R', (0, description_logic_1.atomic)('A')), (0, description_logic_1.forall)('R', (0, description_logic_1.atomic)('A')));
70
+ (0, vitest_1.expect)((0, description_logic_1.isSatisfiable)(c)).toBe(true);
71
+ });
72
+ (0, vitest_1.it)('∃R.(A ⊓ ¬A) es INSATISFACIBLE', () => {
73
+ const c = (0, description_logic_1.exists)('R', (0, description_logic_1.and)((0, description_logic_1.atomic)('A'), (0, description_logic_1.not)((0, description_logic_1.atomic)('A'))));
74
+ (0, vitest_1.expect)((0, description_logic_1.isSatisfiable)(c)).toBe(false);
75
+ });
76
+ (0, vitest_1.it)('∀R.⊥ ⊓ ∃R.⊤ es INSATISFACIBLE (existe sucesor que debe ser ⊥)', () => {
77
+ const c = (0, description_logic_1.and)((0, description_logic_1.forall)('R', description_logic_1.BOTTOM), (0, description_logic_1.exists)('R', description_logic_1.TOP));
78
+ (0, vitest_1.expect)((0, description_logic_1.isSatisfiable)(c)).toBe(false);
79
+ });
80
+ (0, vitest_1.it)('∃R.∃S.A es satisfacible (cadena de roles)', () => {
81
+ const c = (0, description_logic_1.exists)('R', (0, description_logic_1.exists)('S', (0, description_logic_1.atomic)('A')));
82
+ (0, vitest_1.expect)((0, description_logic_1.isSatisfiable)(c)).toBe(true);
83
+ });
84
+ });
85
+ (0, vitest_1.describe)('ALC — Subsumption', () => {
86
+ (0, vitest_1.it)('A ⊓ B ⊑ A', () => {
87
+ (0, vitest_1.expect)((0, description_logic_1.isSubsumed)((0, description_logic_1.and)((0, description_logic_1.atomic)('A'), (0, description_logic_1.atomic)('B')), (0, description_logic_1.atomic)('A'))).toBe(true);
88
+ });
89
+ (0, vitest_1.it)('A ⊑ A ⊔ B', () => {
90
+ (0, vitest_1.expect)((0, description_logic_1.isSubsumed)((0, description_logic_1.atomic)('A'), (0, description_logic_1.or)((0, description_logic_1.atomic)('A'), (0, description_logic_1.atomic)('B')))).toBe(true);
91
+ });
92
+ (0, vitest_1.it)('A NO subsume a B sin KB', () => {
93
+ (0, vitest_1.expect)((0, description_logic_1.isSubsumed)((0, description_logic_1.atomic)('A'), (0, description_logic_1.atomic)('B'))).toBe(false);
94
+ });
95
+ (0, vitest_1.it)('∃R.A ⊑ ∃R.(A ⊔ B)', () => {
96
+ (0, vitest_1.expect)((0, description_logic_1.isSubsumed)((0, description_logic_1.exists)('R', (0, description_logic_1.atomic)('A')), (0, description_logic_1.exists)('R', (0, description_logic_1.or)((0, description_logic_1.atomic)('A'), (0, description_logic_1.atomic)('B'))))).toBe(true);
97
+ });
98
+ (0, vitest_1.it)('∀R.A ⊓ ∀R.B ⊑ ∀R.(A ⊓ B)', () => {
99
+ (0, vitest_1.expect)((0, description_logic_1.isSubsumed)((0, description_logic_1.and)((0, description_logic_1.forall)('R', (0, description_logic_1.atomic)('A')), (0, description_logic_1.forall)('R', (0, description_logic_1.atomic)('B'))), (0, description_logic_1.forall)('R', (0, description_logic_1.and)((0, description_logic_1.atomic)('A'), (0, description_logic_1.atomic)('B'))))).toBe(true);
100
+ });
101
+ (0, vitest_1.it)('⊥ ⊑ C para todo C', () => {
102
+ (0, vitest_1.expect)((0, description_logic_1.isSubsumed)(description_logic_1.BOTTOM, (0, description_logic_1.atomic)('A'))).toBe(true);
103
+ });
104
+ (0, vitest_1.it)('C ⊑ ⊤ para todo C', () => {
105
+ (0, vitest_1.expect)((0, description_logic_1.isSubsumed)((0, description_logic_1.atomic)('A'), description_logic_1.TOP)).toBe(true);
106
+ });
107
+ });
108
+ (0, vitest_1.describe)('ALC — Subsumption con TBox', () => {
109
+ const kb = {
110
+ tbox: [(0, description_logic_1.subsumes)((0, description_logic_1.atomic)('Dog'), (0, description_logic_1.atomic)('Mammal')), (0, description_logic_1.subsumes)((0, description_logic_1.atomic)('Mammal'), (0, description_logic_1.atomic)('Animal'))],
111
+ abox: [],
112
+ };
113
+ (0, vitest_1.it)('Dog ⊑ Animal (transitividad de subsumption)', () => {
114
+ (0, vitest_1.expect)((0, description_logic_1.isSubsumed)((0, description_logic_1.atomic)('Dog'), (0, description_logic_1.atomic)('Animal'), kb)).toBe(true);
115
+ });
116
+ (0, vitest_1.it)('Dog ⊑ Mammal', () => {
117
+ (0, vitest_1.expect)((0, description_logic_1.isSubsumed)((0, description_logic_1.atomic)('Dog'), (0, description_logic_1.atomic)('Mammal'), kb)).toBe(true);
118
+ });
119
+ (0, vitest_1.it)('Animal NO ⊑ Dog (sin información)', () => {
120
+ (0, vitest_1.expect)((0, description_logic_1.isSubsumed)((0, description_logic_1.atomic)('Animal'), (0, description_logic_1.atomic)('Dog'), kb)).toBe(false);
121
+ });
122
+ (0, vitest_1.it)('equivalencia C ≡ D implica subsumption en ambas direcciones', () => {
123
+ const kb2 = {
124
+ tbox: [(0, description_logic_1.equivalent)((0, description_logic_1.atomic)('Bachelor'), (0, description_logic_1.and)((0, description_logic_1.atomic)('Unmarried'), (0, description_logic_1.atomic)('Man')))],
125
+ abox: [],
126
+ };
127
+ (0, vitest_1.expect)((0, description_logic_1.isSubsumed)((0, description_logic_1.atomic)('Bachelor'), (0, description_logic_1.atomic)('Man'), kb2)).toBe(true);
128
+ (0, vitest_1.expect)((0, description_logic_1.isSubsumed)((0, description_logic_1.and)((0, description_logic_1.atomic)('Unmarried'), (0, description_logic_1.atomic)('Man')), (0, description_logic_1.atomic)('Bachelor'), kb2)).toBe(true);
129
+ });
130
+ });
131
+ (0, vitest_1.describe)('ALC — Instance checking', () => {
132
+ (0, vitest_1.it)('ABox {a:A, R(a,b), b:¬A}, ¿a : ∃R.¬A? → true', () => {
133
+ const kb = {
134
+ tbox: [],
135
+ abox: [
136
+ (0, description_logic_1.instance)('a', (0, description_logic_1.atomic)('A')),
137
+ (0, description_logic_1.roleInstance)('a', 'R', 'b'),
138
+ (0, description_logic_1.instance)('b', (0, description_logic_1.not)((0, description_logic_1.atomic)('A'))),
139
+ ],
140
+ };
141
+ (0, vitest_1.expect)((0, description_logic_1.isInstance)('a', (0, description_logic_1.exists)('R', (0, description_logic_1.not)((0, description_logic_1.atomic)('A'))), kb)).toBe(true);
142
+ });
143
+ (0, vitest_1.it)('ABox {a:A}, a NO es instancia de B', () => {
144
+ const kb = {
145
+ tbox: [],
146
+ abox: [(0, description_logic_1.instance)('a', (0, description_logic_1.atomic)('A'))],
147
+ };
148
+ (0, vitest_1.expect)((0, description_logic_1.isInstance)('a', (0, description_logic_1.atomic)('B'), kb)).toBe(false);
149
+ });
150
+ (0, vitest_1.it)('TBox {A ⊑ B} + ABox {a:A} ⊨ a:B', () => {
151
+ const kb = {
152
+ tbox: [(0, description_logic_1.subsumes)((0, description_logic_1.atomic)('A'), (0, description_logic_1.atomic)('B'))],
153
+ abox: [(0, description_logic_1.instance)('a', (0, description_logic_1.atomic)('A'))],
154
+ };
155
+ (0, vitest_1.expect)((0, description_logic_1.isInstance)('a', (0, description_logic_1.atomic)('B'), kb)).toBe(true);
156
+ });
157
+ (0, vitest_1.it)('inconsistencia: {a:A, a:¬A} hace que a sea instancia de cualquier cosa', () => {
158
+ const kb = {
159
+ tbox: [],
160
+ abox: [(0, description_logic_1.instance)('a', (0, description_logic_1.atomic)('A')), (0, description_logic_1.instance)('a', (0, description_logic_1.not)((0, description_logic_1.atomic)('A')))],
161
+ };
162
+ // KB inconsistente ⇒ todo se sigue (ex falso quodlibet)
163
+ (0, vitest_1.expect)((0, description_logic_1.isInstance)('a', (0, description_logic_1.atomic)('Z'), kb)).toBe(true);
164
+ });
165
+ (0, vitest_1.it)('∀R.A propaga: {R(a,b), a:∀R.A} ⊨ b:A', () => {
166
+ const kb = {
167
+ tbox: [],
168
+ abox: [(0, description_logic_1.roleInstance)('a', 'R', 'b'), (0, description_logic_1.instance)('a', (0, description_logic_1.forall)('R', (0, description_logic_1.atomic)('A')))],
169
+ };
170
+ (0, vitest_1.expect)((0, description_logic_1.isInstance)('b', (0, description_logic_1.atomic)('A'), kb)).toBe(true);
171
+ });
172
+ });
173
+ (0, vitest_1.describe)('ALC — Classify (taxonomía)', () => {
174
+ (0, vitest_1.it)('jerarquía simple Dog ⊑ Mammal ⊑ Animal', () => {
175
+ const kb = {
176
+ tbox: [
177
+ (0, description_logic_1.subsumes)((0, description_logic_1.atomic)('Dog'), (0, description_logic_1.atomic)('Mammal')),
178
+ (0, description_logic_1.subsumes)((0, description_logic_1.atomic)('Mammal'), (0, description_logic_1.atomic)('Animal')),
179
+ ],
180
+ abox: [],
181
+ };
182
+ const tax = (0, description_logic_1.classify)(kb);
183
+ // Dog está subsumido por Dog, Mammal, Animal, ⊤
184
+ (0, vitest_1.expect)(tax.get('Dog').has('Mammal')).toBe(true);
185
+ (0, vitest_1.expect)(tax.get('Dog').has('Animal')).toBe(true);
186
+ (0, vitest_1.expect)(tax.get('Dog').has('⊤')).toBe(true);
187
+ // Mammal por sí mismo + Animal + ⊤ (no Dog)
188
+ (0, vitest_1.expect)(tax.get('Mammal').has('Animal')).toBe(true);
189
+ (0, vitest_1.expect)(tax.get('Mammal').has('Dog')).toBe(false);
190
+ // Animal por sí mismo + ⊤
191
+ (0, vitest_1.expect)(tax.get('Animal').has('Dog')).toBe(false);
192
+ (0, vitest_1.expect)(tax.get('Animal').has('Mammal')).toBe(false);
193
+ (0, vitest_1.expect)(tax.get('Animal').has('⊤')).toBe(true);
194
+ });
195
+ (0, vitest_1.it)('concepto insatisfacible aparece como subsumido por TODO', () => {
196
+ const kb = {
197
+ tbox: [
198
+ (0, description_logic_1.subsumes)((0, description_logic_1.atomic)('Round'), (0, description_logic_1.not)((0, description_logic_1.atomic)('Square'))),
199
+ (0, description_logic_1.subsumes)((0, description_logic_1.atomic)('RoundSquare'), (0, description_logic_1.and)((0, description_logic_1.atomic)('Round'), (0, description_logic_1.atomic)('Square'))),
200
+ ],
201
+ abox: [],
202
+ };
203
+ const tax = (0, description_logic_1.classify)(kb);
204
+ // RoundSquare es insatisfacible → subsumido por todo, incluso conceptos no-relacionados
205
+ const rs = tax.get('RoundSquare');
206
+ (0, vitest_1.expect)(rs.has('Round')).toBe(true);
207
+ (0, vitest_1.expect)(rs.has('Square')).toBe(true);
208
+ (0, vitest_1.expect)(rs.has('⊥')).toBe(true);
209
+ });
210
+ });
211
+ (0, vitest_1.describe)('ALC — emptyKB helper', () => {
212
+ (0, vitest_1.it)('emptyKB devuelve una KB vacía utilizable', () => {
213
+ const kb = (0, description_logic_1.emptyKB)();
214
+ (0, vitest_1.expect)(kb.tbox).toEqual([]);
215
+ (0, vitest_1.expect)(kb.abox).toEqual([]);
216
+ (0, vitest_1.expect)((0, description_logic_1.isSatisfiable)((0, description_logic_1.atomic)('A'), kb)).toBe(true);
217
+ });
218
+ });
219
+ (0, vitest_1.describe)('ALC — Terminación con TBox cíclico (blocking)', () => {
220
+ (0, vitest_1.it)('TBox cíclico Person ≡ ∃hasParent.Person no diverge y A:Person es satisfacible', () => {
221
+ const kb = {
222
+ tbox: [(0, description_logic_1.equivalent)((0, description_logic_1.atomic)('Person'), (0, description_logic_1.exists)('hasParent', (0, description_logic_1.atomic)('Person')))],
223
+ abox: [],
224
+ };
225
+ // No debe colgarse — el blocking garantiza terminación.
226
+ (0, vitest_1.expect)((0, description_logic_1.isSatisfiable)((0, description_logic_1.atomic)('Person'), kb)).toBe(true);
227
+ });
228
+ (0, vitest_1.it)('TBox cíclico contradictorio Person ⊑ ∃hasFoo.Person ⊓ ∀hasFoo.⊥ es insatisfacible', () => {
229
+ const kb = {
230
+ tbox: [
231
+ (0, description_logic_1.subsumes)((0, description_logic_1.atomic)('Person'), (0, description_logic_1.and)((0, description_logic_1.exists)('hasFoo', (0, description_logic_1.atomic)('Person')), (0, description_logic_1.forall)('hasFoo', description_logic_1.BOTTOM))),
232
+ ],
233
+ abox: [],
234
+ };
235
+ (0, vitest_1.expect)((0, description_logic_1.isSatisfiable)((0, description_logic_1.atomic)('Person'), kb)).toBe(false);
236
+ });
237
+ });
238
+ (0, vitest_1.describe)('ALC — Casos clásicos OWL/DL', () => {
239
+ (0, vitest_1.it)('regla de De Morgan a nivel de concepto', () => {
240
+ // ¬(A ⊓ B) ≡ ¬A ⊔ ¬B
241
+ const lhs = (0, description_logic_1.not)((0, description_logic_1.and)((0, description_logic_1.atomic)('A'), (0, description_logic_1.atomic)('B')));
242
+ const rhs = (0, description_logic_1.or)((0, description_logic_1.not)((0, description_logic_1.atomic)('A')), (0, description_logic_1.not)((0, description_logic_1.atomic)('B')));
243
+ (0, vitest_1.expect)((0, description_logic_1.isSubsumed)(lhs, rhs)).toBe(true);
244
+ (0, vitest_1.expect)((0, description_logic_1.isSubsumed)(rhs, lhs)).toBe(true);
245
+ });
246
+ (0, vitest_1.it)('axioma K modal: ∀R.(A ⊓ B) ⊑ ∀R.A ⊓ ∀R.B', () => {
247
+ (0, vitest_1.expect)((0, description_logic_1.isSubsumed)((0, description_logic_1.forall)('R', (0, description_logic_1.and)((0, description_logic_1.atomic)('A'), (0, description_logic_1.atomic)('B'))), (0, description_logic_1.and)((0, description_logic_1.forall)('R', (0, description_logic_1.atomic)('A')), (0, description_logic_1.forall)('R', (0, description_logic_1.atomic)('B'))))).toBe(true);
248
+ });
249
+ (0, vitest_1.it)('∃R.A ⊓ ∀R.B ⊑ ∃R.(A ⊓ B)', () => {
250
+ (0, vitest_1.expect)((0, description_logic_1.isSubsumed)((0, description_logic_1.and)((0, description_logic_1.exists)('R', (0, description_logic_1.atomic)('A')), (0, description_logic_1.forall)('R', (0, description_logic_1.atomic)('B'))), (0, description_logic_1.exists)('R', (0, description_logic_1.and)((0, description_logic_1.atomic)('A'), (0, description_logic_1.atomic)('B'))))).toBe(true);
251
+ });
252
+ });
253
+ //# sourceMappingURL=alc.test.js.map