eyelang 1.2.2 → 1.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (922) hide show
  1. package/README.md +4 -4
  2. package/docs/guide.md +230 -229
  3. package/docs/language-reference.md +169 -157
  4. package/examples/access-control-policy.eye +52 -0
  5. package/examples/ackermann.eye +47 -0
  6. package/examples/age.eye +26 -0
  7. package/examples/aliases-and-namespaces.eye +20 -0
  8. package/examples/alignment-demo.eye +44 -0
  9. package/examples/allen-interval-calculus.eye +64 -0
  10. package/examples/ancestor.eye +22 -0
  11. package/examples/animal.eye +21 -0
  12. package/examples/annotation.eye +34 -0
  13. package/examples/auroracare.eye +309 -0
  14. package/examples/backward.eye +11 -0
  15. package/examples/basic-monadic.eye +10032 -0
  16. package/examples/bayes-diagnosis.eye +108 -0
  17. package/examples/bayes-therapy.eye +189 -0
  18. package/examples/beam-deflection.eye +48 -0
  19. package/examples/binomial-vandermonde.eye +49 -0
  20. package/examples/blocks-world-planning.eye +77 -0
  21. package/examples/bmi.eye +232 -0
  22. package/examples/braking-safety-worlds.eye +69 -0
  23. package/examples/buck-converter-design.eye +83 -0
  24. package/examples/cache-performance.eye +56 -0
  25. package/examples/canary-release.eye +51 -0
  26. package/examples/cat-koko.eye +24 -0
  27. package/examples/catalan-convolution.eye +37 -0
  28. package/examples/chart-parser.eye +65 -0
  29. package/examples/clinical-trial-screening.eye +97 -0
  30. package/examples/collatz-1000.eye +45 -0
  31. package/examples/combinatorics-findall-sort.eye +38 -0
  32. package/examples/competitive-enzyme-kinetics.eye +78 -0
  33. package/examples/complex.eye +133 -0
  34. package/examples/composition-of-injective-functions-is-injective.eye +50 -0
  35. package/examples/context-association.eye +53 -0
  36. package/examples/context-schema-audit.eye +46 -0
  37. package/examples/continued-fraction-sqrt2.eye +36 -0
  38. package/examples/control-system.eye +76 -0
  39. package/examples/critical-path-schedule.eye +82 -0
  40. package/examples/cyclic-path.eye +18 -0
  41. package/examples/d3-group.eye +99 -0
  42. package/examples/dairy-energy-balance.eye +66 -0
  43. package/examples/data-negotiation.eye +38 -0
  44. package/examples/deep-taxonomy-10.eye +115 -0
  45. package/examples/deep-taxonomy-100.eye +385 -0
  46. package/examples/deep-taxonomy-1000.eye +3085 -0
  47. package/examples/deep-taxonomy-10000.eye +30094 -0
  48. package/examples/deep-taxonomy-100000.eye +300184 -0
  49. package/examples/delfour.eye +281 -0
  50. package/examples/deontic-logic.eye +52 -0
  51. package/examples/derived-backward-rule.eye +30 -0
  52. package/examples/derived-rule.eye +27 -0
  53. package/examples/diamond-property.eye +38 -0
  54. package/examples/dijkstra-findall-sort.eye +43 -0
  55. package/examples/dijkstra-risk-path.eye +87 -0
  56. package/examples/dijkstra.eye +50 -0
  57. package/examples/dining-philosophers.eye +147 -0
  58. package/examples/dog.eye +25 -0
  59. package/examples/dpv-odrl-purpose-mapping.eye +48 -0
  60. package/examples/drone-corridor-planner.eye +48 -0
  61. package/examples/easter-computus.eye +88 -0
  62. package/examples/electrical-rc-filter.eye +37 -0
  63. package/examples/epidemic-policy.eye +66 -0
  64. package/examples/equivalence-classes-overlap-implies-same-class.eye +27 -0
  65. package/examples/eulerian-path.eye +87 -0
  66. package/examples/ev-range-worlds.eye +87 -0
  67. package/examples/existential-rule.eye +21 -0
  68. package/examples/exoplanet-validation-worlds.eye +94 -0
  69. package/examples/expression-eval.eye +45 -0
  70. package/examples/family-cousins.eye +67 -0
  71. package/examples/fastpow.eye +61 -0
  72. package/examples/fft8-numeric.eye +85 -0
  73. package/examples/fibonacci.eye +60 -0
  74. package/examples/field-nitrogen-balance.eye +73 -0
  75. package/examples/flandor.eye +296 -0
  76. package/examples/floating-point.eye +28 -0
  77. package/examples/four-color-map.eye +133 -0
  78. package/examples/fundamental-theorem-arithmetic.eye +119 -0
  79. package/examples/gd-step-certified.eye +162 -0
  80. package/examples/gdpr-compliance.eye +69 -0
  81. package/examples/good-cobbler.eye +16 -0
  82. package/examples/gps.eye +146 -0
  83. package/examples/graph-reachability.eye +33 -0
  84. package/examples/graph.eye +35 -0
  85. package/examples/gray-code-counter.eye +47 -0
  86. package/examples/greatest-lower-bound-uniqueness.eye +30 -0
  87. package/examples/group-inverse-uniqueness.eye +36 -0
  88. package/examples/hamiltonian-path.eye +51 -0
  89. package/examples/hamming-code.eye +109 -0
  90. package/examples/hanoi.eye +19 -0
  91. package/examples/heat-loss.eye +56 -0
  92. package/examples/heron-theorem.eye +42 -0
  93. package/examples/ideal-gas-law.eye +39 -0
  94. package/examples/illegitimate-reasoning.eye +88 -0
  95. package/examples/integer-partitions.eye +35 -0
  96. package/examples/intuitionistic-logic-kripke.eye +69 -0
  97. package/examples/job-shop-scheduling.eye +48 -0
  98. package/examples/knapsack-optimization.eye +46 -0
  99. package/examples/knowledge-engineering-alignment-flow.eye +46 -0
  100. package/examples/law-of-cosines.eye +37 -0
  101. package/examples/least-squares-regression.eye +85 -0
  102. package/examples/linear-logic-resources.eye +51 -0
  103. package/examples/list-collection.eye +35 -0
  104. package/examples/lldm.eye +80 -0
  105. package/examples/manufacturing-quality-control.eye +73 -0
  106. package/examples/matrix-chain-order.eye +79 -0
  107. package/examples/microgrid-dispatch.eye +89 -0
  108. package/examples/missionaries-cannibals.eye +53 -0
  109. package/examples/modal-logic-kripke.eye +45 -0
  110. package/examples/modular-exponentiation.eye +35 -0
  111. package/examples/monkey-bananas.eye +45 -0
  112. package/examples/n-queens-8.eye +35 -0
  113. package/examples/network-sla.eye +48 -0
  114. package/examples/newton-raphson.eye +48 -0
  115. package/examples/nixon-diamond.eye +37 -0
  116. package/examples/observability-log-correlation.eye +40 -0
  117. package/examples/odrl-dpv-fpv-trust-flow.eye +51 -0
  118. package/examples/odrl-dpv-healthcare-risk-ranked.eye +270 -0
  119. package/examples/odrl-dpv-risk-ranked.eye +320 -0
  120. package/examples/orbital-transfer-design.eye +116 -0
  121. package/examples/path-discovery.eye +45013 -0
  122. package/examples/peano-arithmetic.eye +33 -0
  123. package/examples/peasant.eye +29 -0
  124. package/examples/pell-equation.eye +34 -0
  125. package/examples/pendulum-period.eye +50 -0
  126. package/examples/polynomial.eye +124 -0
  127. package/examples/proof/access-control-policy.eye +158 -0
  128. package/examples/proof/age.eye +71 -0
  129. package/examples/proof/aliases-and-namespaces.eye +78 -0
  130. package/examples/proof/ancestor.eye +140 -0
  131. package/examples/proof/animal.eye +68 -0
  132. package/examples/proof/annotation.eye +80 -0
  133. package/examples/proof/backward.eye +22 -0
  134. package/examples/proof/bayes-diagnosis.eye +208 -0
  135. package/examples/proof/beam-deflection.eye +227 -0
  136. package/examples/proof/cache-performance.eye +310 -0
  137. package/examples/proof/canary-release.eye +172 -0
  138. package/examples/proof/cat-koko.eye +86 -0
  139. package/examples/proof/chart-parser.eye +474 -0
  140. package/examples/proof/clinical-trial-screening.eye +389 -0
  141. package/examples/proof/composition-of-injective-functions-is-injective.eye +258 -0
  142. package/examples/proof/context-association.eye +78 -0
  143. package/examples/proof/data-negotiation.eye +76 -0
  144. package/examples/proof/deontic-logic.eye +109 -0
  145. package/examples/proof/derived-backward-rule.eye +74 -0
  146. package/examples/proof/derived-rule.eye +43 -0
  147. package/examples/proof/diamond-property.eye +307 -0
  148. package/examples/proof/dog.eye +31 -0
  149. package/examples/proof/dpv-odrl-purpose-mapping.eye +348 -0
  150. package/examples/proof/electrical-rc-filter.eye +105 -0
  151. package/examples/proof/epidemic-policy.eye +774 -0
  152. package/examples/proof/equivalence-classes-overlap-implies-same-class.eye +1098 -0
  153. package/examples/proof/existential-rule.eye +40 -0
  154. package/examples/proof/expression-eval.eye +105 -0
  155. package/examples/proof/floating-point.eye +160 -0
  156. package/examples/proof/gdpr-compliance.eye +199 -0
  157. package/examples/proof/good-cobbler.eye +16 -0
  158. package/examples/proof/graph-reachability.eye +151 -0
  159. package/examples/proof/greatest-lower-bound-uniqueness.eye +150 -0
  160. package/examples/proof/group-inverse-uniqueness.eye +84 -0
  161. package/examples/proof/hanoi.eye +185 -0
  162. package/examples/proof/heat-loss.eye +228 -0
  163. package/examples/proof/ideal-gas-law.eye +151 -0
  164. package/examples/proof/intuitionistic-logic-kripke.eye +133 -0
  165. package/examples/proof/linear-logic-resources.eye +205 -0
  166. package/examples/proof/list-collection.eye +52 -0
  167. package/examples/proof/modal-logic-kripke.eye +125 -0
  168. package/examples/proof/nixon-diamond.eye +181 -0
  169. package/examples/proof/proof-contrapositive.eye +78 -0
  170. package/examples/proof/reusable-builtins.eye +124 -0
  171. package/examples/proof/security-incident-correlation.eye +270 -0
  172. package/examples/proof/socket-age.eye +32 -0
  173. package/examples/proof/socket-family.eye +59 -0
  174. package/examples/proof/socrates.eye +38 -0
  175. package/examples/proof/term-tools.eye +95 -0
  176. package/examples/proof/witch.eye +216 -0
  177. package/examples/proof-contrapositive.eye +27 -0
  178. package/examples/quadratic-formula.eye +56 -0
  179. package/examples/radioactive-decay.eye +58 -0
  180. package/examples/reusable-builtins.eye +36 -0
  181. package/examples/riemann-hypothesis.eye +110 -0
  182. package/examples/security-incident-correlation.eye +69 -0
  183. package/examples/send-more-money.eye +71 -0
  184. package/examples/service-impact.eye +41 -0
  185. package/examples/sieve.eye +20 -0
  186. package/examples/skolem-functions.eye +52 -0
  187. package/examples/socket-age.eye +39 -0
  188. package/examples/socket-family.eye +28 -0
  189. package/examples/socrates.eye +19 -0
  190. package/examples/stable-marriage.eye +92 -0
  191. package/examples/statistics-summary.eye +56 -0
  192. package/examples/stirling-bell-numbers.eye +32 -0
  193. package/examples/sudoku-4x4.eye +54 -0
  194. package/examples/superdense-coding.eye +84 -0
  195. package/examples/term-tools.eye +32 -0
  196. package/examples/totient-summatory.eye +33 -0
  197. package/examples/trust-flow-provenance-threshold.eye +47 -0
  198. package/examples/turing.eye +69 -0
  199. package/examples/vector-similarity.eye +60 -0
  200. package/examples/vulnerability-impact.eye +69 -0
  201. package/examples/web-names.eye +83 -0
  202. package/examples/weighted-interval-scheduling.eye +81 -0
  203. package/examples/witch.eye +38 -0
  204. package/examples/wolf-goat-cabbage.eye +56 -0
  205. package/examples/zebra.eye +45 -0
  206. package/index.d.ts +1 -1
  207. package/package.json +2 -2
  208. package/playground.html +10 -10
  209. package/src/cli.js +2 -2
  210. package/src/explain.js +1 -1
  211. package/src/parser.js +37 -7
  212. package/src/program.js +3 -3
  213. package/src/solver.js +2 -2
  214. package/src/term.js +9 -0
  215. package/test/conformance/README.md +2 -2
  216. package/test/conformance/cases/001_fact_output.eye +4 -0
  217. package/test/conformance/cases/002_rule_recursion.eye +7 -0
  218. package/test/conformance/cases/002_rule_recursion.query +1 -1
  219. package/test/conformance/cases/003_terms_and_readback.eye +16 -0
  220. package/test/conformance/cases/003_terms_and_readback.query +1 -1
  221. package/test/conformance/cases/004_conjunction_and_parentheses.eye +5 -0
  222. package/test/conformance/cases/004_conjunction_and_parentheses.query +1 -1
  223. package/test/conformance/cases/005_list_deconstruction.eye +6 -0
  224. package/test/conformance/cases/005_list_deconstruction.query +1 -1
  225. package/test/conformance/cases/006_comma_formula_data.eye +4 -0
  226. package/test/conformance/cases/006_comma_formula_data.query +1 -1
  227. package/test/conformance/cases/007_anonymous_variables.eye +5 -0
  228. package/test/conformance/cases/007_anonymous_variables.query +1 -1
  229. package/test/conformance/cases/008_graphic_atoms.eye +6 -0
  230. package/test/conformance/cases/008_graphic_atoms.query +1 -1
  231. package/test/conformance/cases/009_comments_and_whitespace.eye +5 -0
  232. package/test/conformance/cases/009_comments_and_whitespace.query +1 -1
  233. package/test/conformance/cases/010_variable_scope_and_reuse.eye +8 -0
  234. package/test/conformance/cases/010_variable_scope_and_reuse.query +1 -1
  235. package/test/conformance/cases/011_predicate_arity.eye +6 -0
  236. package/test/conformance/cases/011_predicate_arity.query +1 -1
  237. package/test/conformance/cases/012_nested_compound_unification.eye +5 -0
  238. package/test/conformance/cases/012_nested_compound_unification.query +1 -1
  239. package/test/conformance/cases/013_multiple_clauses_order.eye +6 -0
  240. package/test/conformance/cases/013_multiple_clauses_order.query +1 -1
  241. package/test/conformance/cases/014_failure_filters_answers.eye +7 -0
  242. package/test/conformance/cases/014_failure_filters_answers.query +1 -1
  243. package/test/conformance/cases/015_improper_list_unification.eye +6 -0
  244. package/test/conformance/cases/015_improper_list_unification.query +1 -1
  245. package/test/conformance/cases/016_arity_zero_atom.eye +4 -0
  246. package/test/conformance/cases/017_three_step_recursion.eye +8 -0
  247. package/test/conformance/cases/017_three_step_recursion.query +1 -1
  248. package/test/conformance/cases/018_quoted_atom_readback.eye +6 -0
  249. package/test/conformance/cases/018_quoted_atom_readback.query +1 -1
  250. package/test/conformance/cases/019_parenthesized_three_conjuncts.eye +7 -0
  251. package/test/conformance/cases/019_parenthesized_three_conjuncts.query +1 -1
  252. package/test/conformance/cases/020_nested_list_terms.eye +5 -0
  253. package/test/conformance/cases/020_nested_list_terms.query +1 -1
  254. package/test/conformance/cases/021_repeated_variable_head.eye +7 -0
  255. package/test/conformance/cases/022_rule_head_structure.eye +5 -0
  256. package/test/conformance/cases/023_quoted_escapes_readback.eye +5 -0
  257. package/test/conformance/cases/024_numeric_literal_readback.eye +6 -0
  258. package/test/conformance/cases/025_body_parentheses_with_formula_data.eye +5 -0
  259. package/test/conformance/cases/026_question_underscore_named_variable_reuse.eye +5 -0
  260. package/test/conformance/cases/027_default_derived_output.eye +5 -0
  261. package/test/conformance/cases/028_materialize_focus.eye +5 -0
  262. package/test/conformance/cases/029_arithmetic_and_comparison.eye +11 -0
  263. package/test/conformance/cases/029_arithmetic_and_comparison.query +1 -1
  264. package/test/conformance/cases/030_strings_and_atoms.eye +4 -0
  265. package/test/conformance/cases/030_strings_and_atoms.query +1 -1
  266. package/test/conformance/cases/031_lists_aggregation_ordering.eye +10 -0
  267. package/test/conformance/cases/031_lists_aggregation_ordering.query +1 -1
  268. package/test/conformance/cases/032_holds_parts.eye +4 -0
  269. package/test/conformance/cases/033_negation_once_generators.eye +7 -0
  270. package/test/conformance/cases/033_negation_once_generators.query +1 -1
  271. package/test/conformance/cases/034_equality_and_inequality.eye +6 -0
  272. package/test/conformance/cases/034_equality_and_inequality.query +1 -1
  273. package/test/conformance/cases/035_list_relations.eye +5 -0
  274. package/test/conformance/cases/035_list_relations.query +1 -1
  275. package/test/conformance/cases/036_append_splits.eye +3 -0
  276. package/test/conformance/cases/036_append_splits.query +1 -1
  277. package/test/conformance/cases/037_matching_and_comparison.query +1 -1
  278. package/test/conformance/cases/038_table_declaration.eye +8 -0
  279. package/test/conformance/cases/038_table_declaration.query +1 -0
  280. package/test/conformance/cases/039_numeric_functions.eye +9 -0
  281. package/test/conformance/cases/039_numeric_functions.query +1 -1
  282. package/test/conformance/cases/040_between_enumeration.eye +3 -0
  283. package/test/conformance/cases/040_between_enumeration.query +1 -1
  284. package/test/conformance/cases/041_smallest_divisor.eye +3 -0
  285. package/test/conformance/cases/041_smallest_divisor.query +1 -1
  286. package/test/conformance/cases/042_negation_filter.eye +7 -0
  287. package/test/conformance/cases/042_negation_filter.query +1 -1
  288. package/test/conformance/cases/043_once_user_predicate.eye +5 -0
  289. package/test/conformance/cases/043_once_user_predicate.query +1 -1
  290. package/test/conformance/cases/044_findall_user_goal.eye +6 -0
  291. package/test/conformance/cases/044_findall_user_goal.query +1 -1
  292. package/test/conformance/cases/045_sort_deduplicates_atoms.eye +3 -0
  293. package/test/conformance/cases/045_sort_deduplicates_atoms.query +1 -1
  294. package/test/conformance/cases/046_append_bound_prefix_suffix.eye +4 -0
  295. package/test/conformance/cases/046_append_bound_prefix_suffix.query +1 -1
  296. package/test/conformance/cases/047_nth0_index_generation.eye +3 -0
  297. package/test/conformance/cases/047_nth0_index_generation.query +1 -1
  298. package/test/conformance/cases/048_set_nth0_edges.eye +4 -0
  299. package/test/conformance/cases/048_set_nth0_edges.query +1 -1
  300. package/test/conformance/cases/049_select_duplicate_occurrences.eye +3 -0
  301. package/test/conformance/cases/049_select_duplicate_occurrences.query +1 -1
  302. package/test/conformance/cases/050_not_member_filter.eye +6 -0
  303. package/test/conformance/cases/050_not_member_filter.query +1 -1
  304. package/test/conformance/cases/051_nested_holds_parts.eye +4 -0
  305. package/test/conformance/cases/052_holds_member.eye +3 -0
  306. package/test/conformance/cases/053_materialize_excludes_source_fact.eye +6 -0
  307. package/test/conformance/cases/054_numeric_and_lexical_comparison.query +1 -1
  308. package/test/conformance/cases/055_string_matching_filters.eye +6 -0
  309. package/test/conformance/cases/055_string_matching_filters.query +1 -1
  310. package/test/conformance/cases/056_string_and_atom_concat.eye +3 -0
  311. package/test/conformance/cases/056_string_and_atom_concat.query +1 -1
  312. package/test/conformance/cases/057_countall_empty_and_nonempty.eye +4 -0
  313. package/test/conformance/cases/057_countall_empty_and_nonempty.query +1 -1
  314. package/test/conformance/cases/058_sumall_numeric_template.eye +5 -0
  315. package/test/conformance/cases/058_sumall_numeric_template.query +1 -1
  316. package/test/conformance/cases/059_aggregate_min_template.eye +5 -0
  317. package/test/conformance/cases/059_aggregate_min_template.query +1 -1
  318. package/test/conformance/cases/060_aggregate_max_compound_key.eye +5 -0
  319. package/test/conformance/cases/060_aggregate_max_compound_key.query +1 -1
  320. package/test/conformance/cases/061_date_difference.eye +4 -0
  321. package/test/conformance/cases/062_reusable_numeric_builtins.eye +10 -0
  322. package/test/conformance/cases/063_reusable_list_builtins.eye +11 -0
  323. package/test/conformance/cases/064_reusable_string_builtins.eye +12 -0
  324. package/test/conformance/cases/065_reusable_term_control_builtins.eye +11 -0
  325. package/test/conformance/cases/066_numeric_edges.eye +14 -0
  326. package/test/conformance/cases/067_list_edges.eye +10 -0
  327. package/test/conformance/cases/068_list_generation_order.eye +7 -0
  328. package/test/conformance/cases/069_list_summaries_and_sets.eye +9 -0
  329. package/test/conformance/cases/070_matches_named_captures.eye +13 -0
  330. package/test/conformance/cases/071_string_edges.eye +10 -0
  331. package/test/conformance/cases/072_string_conversions.eye +10 -0
  332. package/test/conformance/cases/073_term_introspection_edges.eye +10 -0
  333. package/test/conformance/cases/074_forall_edges.eye +10 -0
  334. package/test/conformance/cases/075_aggregation_edges.eye +12 -0
  335. package/test/conformance/cases/076_composed_reusable_builtins.eye +8 -0
  336. package/test/conformance/cases/077_recursive_path_with_lists.eye +10 -0
  337. package/test/conformance/cases/078_mutual_recursion_with_arithmetic.eye +7 -0
  338. package/test/conformance/cases/079_big_integer_arithmetic.eye +8 -0
  339. package/test/conformance/cases/080_rounding_modes.eye +10 -0
  340. package/test/conformance/cases/081_zero_safe_numeric_functions.eye +9 -0
  341. package/test/conformance/cases/083_between_modes_and_empty_ranges.eye +8 -0
  342. package/test/conformance/cases/084_append_and_select_composition.eye +7 -0
  343. package/test/conformance/cases/085_nth_and_update_edges.eye +8 -0
  344. package/test/conformance/cases/086_slicing_pipeline.eye +10 -0
  345. package/test/conformance/cases/087_sort_reverse_length.eye +8 -0
  346. package/test/conformance/cases/088_list_summaries_failures.eye +8 -0
  347. package/test/conformance/cases/089_string_split_join_pipeline.eye +7 -0
  348. package/test/conformance/cases/090_string_substring_replace_edges.eye +9 -0
  349. package/test/conformance/cases/091_string_case_and_trim.eye +7 -0
  350. package/test/conformance/cases/092_scalar_string_conversions.eye +9 -0
  351. package/test/conformance/cases/093_regex_named_captures_context.eye +8 -0
  352. package/test/conformance/cases/094_context_holds_enumeration.eye +7 -0
  353. package/test/conformance/cases/095_term_introspection_roundtrip.eye +8 -0
  354. package/test/conformance/cases/096_functor_scalar_edges.eye +8 -0
  355. package/test/conformance/cases/097_control_negation_once_forall.eye +13 -0
  356. package/test/conformance/cases/098_aggregation_nested_templates.eye +11 -0
  357. package/test/conformance/cases/099_materialize_multiple_arities.eye +8 -0
  358. package/test/conformance/cases/100_reusable_builtin_workflow.eye +10 -0
  359. package/test/conformance/cases/101_question_mark_variables.eye +7 -0
  360. package/test/conformance/cases/102_table_declaration.eye +11 -0
  361. package/test/conformance/cases/103_angle_iri_atoms.eye +7 -0
  362. package/test/conformance/expected/101_question_mark_variables.eye +3 -0
  363. package/test/conformance/expected/102_table_declaration.eye +6 -0
  364. package/test/conformance/expected/103_angle_iri_atoms.eye +3 -0
  365. package/test/run-conformance.mjs +4 -4
  366. package/test/run-examples.mjs +51 -51
  367. package/test/run-regression.mjs +178 -74
  368. package/examples/access-control-policy.pl +0 -52
  369. package/examples/ackermann.pl +0 -47
  370. package/examples/age.pl +0 -26
  371. package/examples/aliases-and-namespaces.pl +0 -20
  372. package/examples/alignment-demo.pl +0 -44
  373. package/examples/allen-interval-calculus.pl +0 -64
  374. package/examples/ancestor.pl +0 -22
  375. package/examples/animal.pl +0 -21
  376. package/examples/annotation.pl +0 -34
  377. package/examples/auroracare.pl +0 -309
  378. package/examples/backward.pl +0 -11
  379. package/examples/basic-monadic.pl +0 -10032
  380. package/examples/bayes-diagnosis.pl +0 -108
  381. package/examples/bayes-therapy.pl +0 -189
  382. package/examples/beam-deflection.pl +0 -48
  383. package/examples/binomial-vandermonde.pl +0 -49
  384. package/examples/blocks-world-planning.pl +0 -77
  385. package/examples/bmi.pl +0 -232
  386. package/examples/braking-safety-worlds.pl +0 -69
  387. package/examples/buck-converter-design.pl +0 -83
  388. package/examples/cache-performance.pl +0 -56
  389. package/examples/canary-release.pl +0 -51
  390. package/examples/cat-koko.pl +0 -24
  391. package/examples/catalan-convolution.pl +0 -37
  392. package/examples/chart-parser.pl +0 -65
  393. package/examples/clinical-trial-screening.pl +0 -97
  394. package/examples/collatz-1000.pl +0 -45
  395. package/examples/combinatorics-findall-sort.pl +0 -38
  396. package/examples/competitive-enzyme-kinetics.pl +0 -78
  397. package/examples/complex.pl +0 -133
  398. package/examples/composition-of-injective-functions-is-injective.pl +0 -50
  399. package/examples/context-association.pl +0 -53
  400. package/examples/context-schema-audit.pl +0 -46
  401. package/examples/continued-fraction-sqrt2.pl +0 -36
  402. package/examples/control-system.pl +0 -76
  403. package/examples/critical-path-schedule.pl +0 -82
  404. package/examples/cyclic-path.pl +0 -18
  405. package/examples/d3-group.pl +0 -99
  406. package/examples/dairy-energy-balance.pl +0 -66
  407. package/examples/data-negotiation.pl +0 -38
  408. package/examples/deep-taxonomy-10.pl +0 -115
  409. package/examples/deep-taxonomy-100.pl +0 -385
  410. package/examples/deep-taxonomy-1000.pl +0 -3085
  411. package/examples/deep-taxonomy-10000.pl +0 -30094
  412. package/examples/deep-taxonomy-100000.pl +0 -300184
  413. package/examples/delfour.pl +0 -281
  414. package/examples/deontic-logic.pl +0 -52
  415. package/examples/derived-backward-rule.pl +0 -30
  416. package/examples/derived-rule.pl +0 -27
  417. package/examples/diamond-property.pl +0 -38
  418. package/examples/dijkstra-findall-sort.pl +0 -43
  419. package/examples/dijkstra-risk-path.pl +0 -87
  420. package/examples/dijkstra.pl +0 -50
  421. package/examples/dining-philosophers.pl +0 -147
  422. package/examples/dog.pl +0 -25
  423. package/examples/dpv-odrl-purpose-mapping.pl +0 -48
  424. package/examples/drone-corridor-planner.pl +0 -48
  425. package/examples/easter-computus.pl +0 -88
  426. package/examples/electrical-rc-filter.pl +0 -37
  427. package/examples/epidemic-policy.pl +0 -66
  428. package/examples/equivalence-classes-overlap-implies-same-class.pl +0 -27
  429. package/examples/eulerian-path.pl +0 -87
  430. package/examples/ev-range-worlds.pl +0 -87
  431. package/examples/existential-rule.pl +0 -21
  432. package/examples/exoplanet-validation-worlds.pl +0 -94
  433. package/examples/expression-eval.pl +0 -45
  434. package/examples/family-cousins.pl +0 -67
  435. package/examples/fastpow.pl +0 -61
  436. package/examples/fft8-numeric.pl +0 -85
  437. package/examples/fibonacci.pl +0 -60
  438. package/examples/field-nitrogen-balance.pl +0 -73
  439. package/examples/flandor.pl +0 -296
  440. package/examples/floating-point.pl +0 -28
  441. package/examples/four-color-map.pl +0 -133
  442. package/examples/fundamental-theorem-arithmetic.pl +0 -119
  443. package/examples/gd-step-certified.pl +0 -162
  444. package/examples/gdpr-compliance.pl +0 -69
  445. package/examples/good-cobbler.pl +0 -16
  446. package/examples/gps.pl +0 -146
  447. package/examples/graph-reachability.pl +0 -33
  448. package/examples/graph.pl +0 -35
  449. package/examples/gray-code-counter.pl +0 -47
  450. package/examples/greatest-lower-bound-uniqueness.pl +0 -30
  451. package/examples/group-inverse-uniqueness.pl +0 -36
  452. package/examples/hamiltonian-path.pl +0 -51
  453. package/examples/hamming-code.pl +0 -109
  454. package/examples/hanoi.pl +0 -19
  455. package/examples/heat-loss.pl +0 -56
  456. package/examples/heron-theorem.pl +0 -42
  457. package/examples/ideal-gas-law.pl +0 -39
  458. package/examples/illegitimate-reasoning.pl +0 -88
  459. package/examples/integer-partitions.pl +0 -35
  460. package/examples/intuitionistic-logic-kripke.pl +0 -69
  461. package/examples/job-shop-scheduling.pl +0 -48
  462. package/examples/knapsack-optimization.pl +0 -46
  463. package/examples/knowledge-engineering-alignment-flow.pl +0 -46
  464. package/examples/law-of-cosines.pl +0 -37
  465. package/examples/least-squares-regression.pl +0 -85
  466. package/examples/linear-logic-resources.pl +0 -51
  467. package/examples/list-collection.pl +0 -35
  468. package/examples/lldm.pl +0 -80
  469. package/examples/manufacturing-quality-control.pl +0 -73
  470. package/examples/matrix-chain-order.pl +0 -79
  471. package/examples/microgrid-dispatch.pl +0 -89
  472. package/examples/missionaries-cannibals.pl +0 -53
  473. package/examples/modal-logic-kripke.pl +0 -45
  474. package/examples/modular-exponentiation.pl +0 -35
  475. package/examples/monkey-bananas.pl +0 -45
  476. package/examples/n-queens-8.pl +0 -35
  477. package/examples/network-sla.pl +0 -48
  478. package/examples/newton-raphson.pl +0 -48
  479. package/examples/nixon-diamond.pl +0 -37
  480. package/examples/observability-log-correlation.pl +0 -40
  481. package/examples/odrl-dpv-fpv-trust-flow.pl +0 -51
  482. package/examples/odrl-dpv-healthcare-risk-ranked.pl +0 -270
  483. package/examples/odrl-dpv-risk-ranked.pl +0 -320
  484. package/examples/orbital-transfer-design.pl +0 -116
  485. package/examples/path-discovery.pl +0 -45013
  486. package/examples/peano-arithmetic.pl +0 -33
  487. package/examples/peasant.pl +0 -29
  488. package/examples/pell-equation.pl +0 -34
  489. package/examples/pendulum-period.pl +0 -50
  490. package/examples/polynomial.pl +0 -124
  491. package/examples/proof/access-control-policy.pl +0 -158
  492. package/examples/proof/age.pl +0 -71
  493. package/examples/proof/aliases-and-namespaces.pl +0 -78
  494. package/examples/proof/ancestor.pl +0 -140
  495. package/examples/proof/animal.pl +0 -68
  496. package/examples/proof/annotation.pl +0 -80
  497. package/examples/proof/backward.pl +0 -22
  498. package/examples/proof/bayes-diagnosis.pl +0 -208
  499. package/examples/proof/beam-deflection.pl +0 -227
  500. package/examples/proof/cache-performance.pl +0 -310
  501. package/examples/proof/canary-release.pl +0 -172
  502. package/examples/proof/cat-koko.pl +0 -86
  503. package/examples/proof/chart-parser.pl +0 -474
  504. package/examples/proof/clinical-trial-screening.pl +0 -389
  505. package/examples/proof/composition-of-injective-functions-is-injective.pl +0 -258
  506. package/examples/proof/context-association.pl +0 -78
  507. package/examples/proof/data-negotiation.pl +0 -76
  508. package/examples/proof/deontic-logic.pl +0 -109
  509. package/examples/proof/derived-backward-rule.pl +0 -74
  510. package/examples/proof/derived-rule.pl +0 -43
  511. package/examples/proof/diamond-property.pl +0 -307
  512. package/examples/proof/dog.pl +0 -31
  513. package/examples/proof/dpv-odrl-purpose-mapping.pl +0 -348
  514. package/examples/proof/electrical-rc-filter.pl +0 -105
  515. package/examples/proof/epidemic-policy.pl +0 -774
  516. package/examples/proof/equivalence-classes-overlap-implies-same-class.pl +0 -1098
  517. package/examples/proof/existential-rule.pl +0 -40
  518. package/examples/proof/expression-eval.pl +0 -105
  519. package/examples/proof/floating-point.pl +0 -160
  520. package/examples/proof/gdpr-compliance.pl +0 -199
  521. package/examples/proof/good-cobbler.pl +0 -16
  522. package/examples/proof/graph-reachability.pl +0 -151
  523. package/examples/proof/greatest-lower-bound-uniqueness.pl +0 -150
  524. package/examples/proof/group-inverse-uniqueness.pl +0 -84
  525. package/examples/proof/hanoi.pl +0 -185
  526. package/examples/proof/heat-loss.pl +0 -228
  527. package/examples/proof/ideal-gas-law.pl +0 -151
  528. package/examples/proof/intuitionistic-logic-kripke.pl +0 -133
  529. package/examples/proof/linear-logic-resources.pl +0 -205
  530. package/examples/proof/list-collection.pl +0 -52
  531. package/examples/proof/modal-logic-kripke.pl +0 -125
  532. package/examples/proof/nixon-diamond.pl +0 -181
  533. package/examples/proof/proof-contrapositive.pl +0 -78
  534. package/examples/proof/reusable-builtins.pl +0 -124
  535. package/examples/proof/security-incident-correlation.pl +0 -270
  536. package/examples/proof/socket-age.pl +0 -32
  537. package/examples/proof/socket-family.pl +0 -59
  538. package/examples/proof/socrates.pl +0 -38
  539. package/examples/proof/term-tools.pl +0 -95
  540. package/examples/proof/witch.pl +0 -216
  541. package/examples/proof-contrapositive.pl +0 -27
  542. package/examples/quadratic-formula.pl +0 -56
  543. package/examples/radioactive-decay.pl +0 -58
  544. package/examples/reusable-builtins.pl +0 -36
  545. package/examples/riemann-hypothesis.pl +0 -110
  546. package/examples/security-incident-correlation.pl +0 -69
  547. package/examples/send-more-money.pl +0 -71
  548. package/examples/service-impact.pl +0 -41
  549. package/examples/sieve.pl +0 -20
  550. package/examples/skolem-functions.pl +0 -52
  551. package/examples/socket-age.pl +0 -39
  552. package/examples/socket-family.pl +0 -28
  553. package/examples/socrates.pl +0 -19
  554. package/examples/stable-marriage.pl +0 -92
  555. package/examples/statistics-summary.pl +0 -56
  556. package/examples/stirling-bell-numbers.pl +0 -32
  557. package/examples/sudoku-4x4.pl +0 -54
  558. package/examples/superdense-coding.pl +0 -84
  559. package/examples/term-tools.pl +0 -32
  560. package/examples/totient-summatory.pl +0 -33
  561. package/examples/trust-flow-provenance-threshold.pl +0 -47
  562. package/examples/turing.pl +0 -69
  563. package/examples/vector-similarity.pl +0 -60
  564. package/examples/vulnerability-impact.pl +0 -69
  565. package/examples/web-names.pl +0 -83
  566. package/examples/weighted-interval-scheduling.pl +0 -81
  567. package/examples/witch.pl +0 -38
  568. package/examples/wolf-goat-cabbage.pl +0 -56
  569. package/examples/zebra.pl +0 -45
  570. package/test/conformance/cases/001_fact_output.pl +0 -4
  571. package/test/conformance/cases/002_rule_recursion.pl +0 -7
  572. package/test/conformance/cases/003_terms_and_readback.pl +0 -16
  573. package/test/conformance/cases/004_conjunction_and_parentheses.pl +0 -5
  574. package/test/conformance/cases/005_list_deconstruction.pl +0 -6
  575. package/test/conformance/cases/006_comma_formula_data.pl +0 -4
  576. package/test/conformance/cases/007_anonymous_variables.pl +0 -5
  577. package/test/conformance/cases/008_graphic_atoms.pl +0 -6
  578. package/test/conformance/cases/009_comments_and_whitespace.pl +0 -5
  579. package/test/conformance/cases/010_variable_scope_and_reuse.pl +0 -8
  580. package/test/conformance/cases/011_predicate_arity.pl +0 -6
  581. package/test/conformance/cases/012_nested_compound_unification.pl +0 -5
  582. package/test/conformance/cases/013_multiple_clauses_order.pl +0 -6
  583. package/test/conformance/cases/014_failure_filters_answers.pl +0 -7
  584. package/test/conformance/cases/015_improper_list_unification.pl +0 -6
  585. package/test/conformance/cases/016_arity_zero_atom.pl +0 -4
  586. package/test/conformance/cases/017_three_step_recursion.pl +0 -8
  587. package/test/conformance/cases/018_quoted_atom_readback.pl +0 -6
  588. package/test/conformance/cases/019_parenthesized_three_conjuncts.pl +0 -7
  589. package/test/conformance/cases/020_nested_list_terms.pl +0 -5
  590. package/test/conformance/cases/021_repeated_variable_head.pl +0 -7
  591. package/test/conformance/cases/022_rule_head_structure.pl +0 -5
  592. package/test/conformance/cases/023_quoted_escapes_readback.pl +0 -5
  593. package/test/conformance/cases/024_numeric_literal_readback.pl +0 -6
  594. package/test/conformance/cases/025_body_parentheses_with_formula_data.pl +0 -5
  595. package/test/conformance/cases/026_underscore_named_variable_reuse.pl +0 -5
  596. package/test/conformance/cases/027_default_derived_output.pl +0 -5
  597. package/test/conformance/cases/028_materialize_focus.pl +0 -5
  598. package/test/conformance/cases/029_arithmetic_and_comparison.pl +0 -11
  599. package/test/conformance/cases/030_strings_and_atoms.pl +0 -4
  600. package/test/conformance/cases/031_lists_aggregation_ordering.pl +0 -10
  601. package/test/conformance/cases/032_holds_parts.pl +0 -4
  602. package/test/conformance/cases/033_negation_once_generators.pl +0 -7
  603. package/test/conformance/cases/034_equality_and_inequality.pl +0 -6
  604. package/test/conformance/cases/035_list_relations.pl +0 -5
  605. package/test/conformance/cases/036_append_splits.pl +0 -3
  606. package/test/conformance/cases/038_memoize_declaration.pl +0 -8
  607. package/test/conformance/cases/038_memoize_declaration.query +0 -1
  608. package/test/conformance/cases/039_numeric_functions.pl +0 -9
  609. package/test/conformance/cases/040_between_enumeration.pl +0 -3
  610. package/test/conformance/cases/041_smallest_divisor.pl +0 -3
  611. package/test/conformance/cases/042_negation_filter.pl +0 -7
  612. package/test/conformance/cases/043_once_user_predicate.pl +0 -5
  613. package/test/conformance/cases/044_findall_user_goal.pl +0 -6
  614. package/test/conformance/cases/045_sort_deduplicates_atoms.pl +0 -3
  615. package/test/conformance/cases/046_append_bound_prefix_suffix.pl +0 -4
  616. package/test/conformance/cases/047_nth0_index_generation.pl +0 -3
  617. package/test/conformance/cases/048_set_nth0_edges.pl +0 -4
  618. package/test/conformance/cases/049_select_duplicate_occurrences.pl +0 -3
  619. package/test/conformance/cases/050_not_member_filter.pl +0 -6
  620. package/test/conformance/cases/051_nested_holds_parts.pl +0 -4
  621. package/test/conformance/cases/052_holds_member.pl +0 -3
  622. package/test/conformance/cases/053_materialize_excludes_source_fact.pl +0 -6
  623. package/test/conformance/cases/055_string_matching_filters.pl +0 -6
  624. package/test/conformance/cases/056_string_and_atom_concat.pl +0 -3
  625. package/test/conformance/cases/057_countall_empty_and_nonempty.pl +0 -4
  626. package/test/conformance/cases/058_sumall_numeric_template.pl +0 -5
  627. package/test/conformance/cases/059_aggregate_min_template.pl +0 -5
  628. package/test/conformance/cases/060_aggregate_max_compound_key.pl +0 -5
  629. package/test/conformance/cases/061_date_difference.pl +0 -4
  630. package/test/conformance/cases/062_reusable_numeric_builtins.pl +0 -10
  631. package/test/conformance/cases/063_reusable_list_builtins.pl +0 -11
  632. package/test/conformance/cases/064_reusable_string_builtins.pl +0 -12
  633. package/test/conformance/cases/065_reusable_term_control_builtins.pl +0 -11
  634. package/test/conformance/cases/066_numeric_edges.pl +0 -14
  635. package/test/conformance/cases/067_list_edges.pl +0 -10
  636. package/test/conformance/cases/068_list_generation_order.pl +0 -7
  637. package/test/conformance/cases/069_list_summaries_and_sets.pl +0 -9
  638. package/test/conformance/cases/070_matches_named_captures.pl +0 -13
  639. package/test/conformance/cases/071_string_edges.pl +0 -10
  640. package/test/conformance/cases/072_string_conversions.pl +0 -10
  641. package/test/conformance/cases/073_term_introspection_edges.pl +0 -10
  642. package/test/conformance/cases/074_forall_edges.pl +0 -10
  643. package/test/conformance/cases/075_aggregation_edges.pl +0 -12
  644. package/test/conformance/cases/076_composed_reusable_builtins.pl +0 -8
  645. package/test/conformance/cases/077_recursive_path_with_lists.pl +0 -10
  646. package/test/conformance/cases/078_mutual_recursion_with_arithmetic.pl +0 -7
  647. package/test/conformance/cases/079_big_integer_arithmetic.pl +0 -8
  648. package/test/conformance/cases/080_rounding_modes.pl +0 -10
  649. package/test/conformance/cases/081_zero_safe_numeric_functions.pl +0 -9
  650. package/test/conformance/cases/083_between_modes_and_empty_ranges.pl +0 -8
  651. package/test/conformance/cases/084_append_and_select_composition.pl +0 -7
  652. package/test/conformance/cases/085_nth_and_update_edges.pl +0 -8
  653. package/test/conformance/cases/086_slicing_pipeline.pl +0 -10
  654. package/test/conformance/cases/087_sort_reverse_length.pl +0 -8
  655. package/test/conformance/cases/088_list_summaries_failures.pl +0 -8
  656. package/test/conformance/cases/089_string_split_join_pipeline.pl +0 -7
  657. package/test/conformance/cases/090_string_substring_replace_edges.pl +0 -9
  658. package/test/conformance/cases/091_string_case_and_trim.pl +0 -7
  659. package/test/conformance/cases/092_scalar_string_conversions.pl +0 -9
  660. package/test/conformance/cases/093_regex_named_captures_context.pl +0 -8
  661. package/test/conformance/cases/094_context_holds_enumeration.pl +0 -7
  662. package/test/conformance/cases/095_term_introspection_roundtrip.pl +0 -8
  663. package/test/conformance/cases/096_functor_scalar_edges.pl +0 -8
  664. package/test/conformance/cases/097_control_negation_once_forall.pl +0 -13
  665. package/test/conformance/cases/098_aggregation_nested_templates.pl +0 -11
  666. package/test/conformance/cases/099_materialize_multiple_arities.pl +0 -8
  667. package/test/conformance/cases/100_reusable_builtin_workflow.pl +0 -10
  668. /package/examples/output/{access-control-policy.pl → access-control-policy.eye} +0 -0
  669. /package/examples/output/{ackermann.pl → ackermann.eye} +0 -0
  670. /package/examples/output/{age.pl → age.eye} +0 -0
  671. /package/examples/output/{aliases-and-namespaces.pl → aliases-and-namespaces.eye} +0 -0
  672. /package/examples/output/{alignment-demo.pl → alignment-demo.eye} +0 -0
  673. /package/examples/output/{allen-interval-calculus.pl → allen-interval-calculus.eye} +0 -0
  674. /package/examples/output/{ancestor.pl → ancestor.eye} +0 -0
  675. /package/examples/output/{animal.pl → animal.eye} +0 -0
  676. /package/examples/output/{annotation.pl → annotation.eye} +0 -0
  677. /package/examples/output/{auroracare.pl → auroracare.eye} +0 -0
  678. /package/examples/output/{backward.pl → backward.eye} +0 -0
  679. /package/examples/output/{basic-monadic.pl → basic-monadic.eye} +0 -0
  680. /package/examples/output/{bayes-diagnosis.pl → bayes-diagnosis.eye} +0 -0
  681. /package/examples/output/{bayes-therapy.pl → bayes-therapy.eye} +0 -0
  682. /package/examples/output/{beam-deflection.pl → beam-deflection.eye} +0 -0
  683. /package/examples/output/{binomial-vandermonde.pl → binomial-vandermonde.eye} +0 -0
  684. /package/examples/output/{blocks-world-planning.pl → blocks-world-planning.eye} +0 -0
  685. /package/examples/output/{bmi.pl → bmi.eye} +0 -0
  686. /package/examples/output/{braking-safety-worlds.pl → braking-safety-worlds.eye} +0 -0
  687. /package/examples/output/{buck-converter-design.pl → buck-converter-design.eye} +0 -0
  688. /package/examples/output/{cache-performance.pl → cache-performance.eye} +0 -0
  689. /package/examples/output/{canary-release.pl → canary-release.eye} +0 -0
  690. /package/examples/output/{cat-koko.pl → cat-koko.eye} +0 -0
  691. /package/examples/output/{catalan-convolution.pl → catalan-convolution.eye} +0 -0
  692. /package/examples/output/{chart-parser.pl → chart-parser.eye} +0 -0
  693. /package/examples/output/{clinical-trial-screening.pl → clinical-trial-screening.eye} +0 -0
  694. /package/examples/output/{collatz-1000.pl → collatz-1000.eye} +0 -0
  695. /package/examples/output/{combinatorics-findall-sort.pl → combinatorics-findall-sort.eye} +0 -0
  696. /package/examples/output/{competitive-enzyme-kinetics.pl → competitive-enzyme-kinetics.eye} +0 -0
  697. /package/examples/output/{complex.pl → complex.eye} +0 -0
  698. /package/examples/output/{composition-of-injective-functions-is-injective.pl → composition-of-injective-functions-is-injective.eye} +0 -0
  699. /package/examples/output/{context-association.pl → context-association.eye} +0 -0
  700. /package/examples/output/{context-schema-audit.pl → context-schema-audit.eye} +0 -0
  701. /package/examples/output/{continued-fraction-sqrt2.pl → continued-fraction-sqrt2.eye} +0 -0
  702. /package/examples/output/{control-system.pl → control-system.eye} +0 -0
  703. /package/examples/output/{critical-path-schedule.pl → critical-path-schedule.eye} +0 -0
  704. /package/examples/output/{cyclic-path.pl → cyclic-path.eye} +0 -0
  705. /package/examples/output/{d3-group.pl → d3-group.eye} +0 -0
  706. /package/examples/output/{dairy-energy-balance.pl → dairy-energy-balance.eye} +0 -0
  707. /package/examples/output/{data-negotiation.pl → data-negotiation.eye} +0 -0
  708. /package/examples/output/{deep-taxonomy-10.pl → deep-taxonomy-10.eye} +0 -0
  709. /package/examples/output/{deep-taxonomy-100.pl → deep-taxonomy-100.eye} +0 -0
  710. /package/examples/output/{deep-taxonomy-1000.pl → deep-taxonomy-1000.eye} +0 -0
  711. /package/examples/output/{deep-taxonomy-10000.pl → deep-taxonomy-10000.eye} +0 -0
  712. /package/examples/output/{deep-taxonomy-100000.pl → deep-taxonomy-100000.eye} +0 -0
  713. /package/examples/output/{delfour.pl → delfour.eye} +0 -0
  714. /package/examples/output/{deontic-logic.pl → deontic-logic.eye} +0 -0
  715. /package/examples/output/{derived-backward-rule.pl → derived-backward-rule.eye} +0 -0
  716. /package/examples/output/{derived-rule.pl → derived-rule.eye} +0 -0
  717. /package/examples/output/{diamond-property.pl → diamond-property.eye} +0 -0
  718. /package/examples/output/{dijkstra-findall-sort.pl → dijkstra-findall-sort.eye} +0 -0
  719. /package/examples/output/{dijkstra-risk-path.pl → dijkstra-risk-path.eye} +0 -0
  720. /package/examples/output/{dijkstra.pl → dijkstra.eye} +0 -0
  721. /package/examples/output/{dining-philosophers.pl → dining-philosophers.eye} +0 -0
  722. /package/examples/output/{dog.pl → dog.eye} +0 -0
  723. /package/examples/output/{dpv-odrl-purpose-mapping.pl → dpv-odrl-purpose-mapping.eye} +0 -0
  724. /package/examples/output/{drone-corridor-planner.pl → drone-corridor-planner.eye} +0 -0
  725. /package/examples/output/{easter-computus.pl → easter-computus.eye} +0 -0
  726. /package/examples/output/{electrical-rc-filter.pl → electrical-rc-filter.eye} +0 -0
  727. /package/examples/output/{epidemic-policy.pl → epidemic-policy.eye} +0 -0
  728. /package/examples/output/{equivalence-classes-overlap-implies-same-class.pl → equivalence-classes-overlap-implies-same-class.eye} +0 -0
  729. /package/examples/output/{eulerian-path.pl → eulerian-path.eye} +0 -0
  730. /package/examples/output/{ev-range-worlds.pl → ev-range-worlds.eye} +0 -0
  731. /package/examples/output/{existential-rule.pl → existential-rule.eye} +0 -0
  732. /package/examples/output/{exoplanet-validation-worlds.pl → exoplanet-validation-worlds.eye} +0 -0
  733. /package/examples/output/{expression-eval.pl → expression-eval.eye} +0 -0
  734. /package/examples/output/{family-cousins.pl → family-cousins.eye} +0 -0
  735. /package/examples/output/{fastpow.pl → fastpow.eye} +0 -0
  736. /package/examples/output/{fft8-numeric.pl → fft8-numeric.eye} +0 -0
  737. /package/examples/output/{fibonacci.pl → fibonacci.eye} +0 -0
  738. /package/examples/output/{field-nitrogen-balance.pl → field-nitrogen-balance.eye} +0 -0
  739. /package/examples/output/{flandor.pl → flandor.eye} +0 -0
  740. /package/examples/output/{floating-point.pl → floating-point.eye} +0 -0
  741. /package/examples/output/{four-color-map.pl → four-color-map.eye} +0 -0
  742. /package/examples/output/{fundamental-theorem-arithmetic.pl → fundamental-theorem-arithmetic.eye} +0 -0
  743. /package/examples/output/{gd-step-certified.pl → gd-step-certified.eye} +0 -0
  744. /package/examples/output/{gdpr-compliance.pl → gdpr-compliance.eye} +0 -0
  745. /package/examples/output/{good-cobbler.pl → good-cobbler.eye} +0 -0
  746. /package/examples/output/{gps.pl → gps.eye} +0 -0
  747. /package/examples/output/{graph-reachability.pl → graph-reachability.eye} +0 -0
  748. /package/examples/output/{graph.pl → graph.eye} +0 -0
  749. /package/examples/output/{gray-code-counter.pl → gray-code-counter.eye} +0 -0
  750. /package/examples/output/{greatest-lower-bound-uniqueness.pl → greatest-lower-bound-uniqueness.eye} +0 -0
  751. /package/examples/output/{group-inverse-uniqueness.pl → group-inverse-uniqueness.eye} +0 -0
  752. /package/examples/output/{hamiltonian-path.pl → hamiltonian-path.eye} +0 -0
  753. /package/examples/output/{hamming-code.pl → hamming-code.eye} +0 -0
  754. /package/examples/output/{hanoi.pl → hanoi.eye} +0 -0
  755. /package/examples/output/{heat-loss.pl → heat-loss.eye} +0 -0
  756. /package/examples/output/{heron-theorem.pl → heron-theorem.eye} +0 -0
  757. /package/examples/output/{ideal-gas-law.pl → ideal-gas-law.eye} +0 -0
  758. /package/examples/output/{illegitimate-reasoning.pl → illegitimate-reasoning.eye} +0 -0
  759. /package/examples/output/{integer-partitions.pl → integer-partitions.eye} +0 -0
  760. /package/examples/output/{intuitionistic-logic-kripke.pl → intuitionistic-logic-kripke.eye} +0 -0
  761. /package/examples/output/{job-shop-scheduling.pl → job-shop-scheduling.eye} +0 -0
  762. /package/examples/output/{knapsack-optimization.pl → knapsack-optimization.eye} +0 -0
  763. /package/examples/output/{knowledge-engineering-alignment-flow.pl → knowledge-engineering-alignment-flow.eye} +0 -0
  764. /package/examples/output/{law-of-cosines.pl → law-of-cosines.eye} +0 -0
  765. /package/examples/output/{least-squares-regression.pl → least-squares-regression.eye} +0 -0
  766. /package/examples/output/{linear-logic-resources.pl → linear-logic-resources.eye} +0 -0
  767. /package/examples/output/{list-collection.pl → list-collection.eye} +0 -0
  768. /package/examples/output/{lldm.pl → lldm.eye} +0 -0
  769. /package/examples/output/{manufacturing-quality-control.pl → manufacturing-quality-control.eye} +0 -0
  770. /package/examples/output/{matrix-chain-order.pl → matrix-chain-order.eye} +0 -0
  771. /package/examples/output/{microgrid-dispatch.pl → microgrid-dispatch.eye} +0 -0
  772. /package/examples/output/{missionaries-cannibals.pl → missionaries-cannibals.eye} +0 -0
  773. /package/examples/output/{modal-logic-kripke.pl → modal-logic-kripke.eye} +0 -0
  774. /package/examples/output/{modular-exponentiation.pl → modular-exponentiation.eye} +0 -0
  775. /package/examples/output/{monkey-bananas.pl → monkey-bananas.eye} +0 -0
  776. /package/examples/output/{n-queens-8.pl → n-queens-8.eye} +0 -0
  777. /package/examples/output/{network-sla.pl → network-sla.eye} +0 -0
  778. /package/examples/output/{newton-raphson.pl → newton-raphson.eye} +0 -0
  779. /package/examples/output/{nixon-diamond.pl → nixon-diamond.eye} +0 -0
  780. /package/examples/output/{observability-log-correlation.pl → observability-log-correlation.eye} +0 -0
  781. /package/examples/output/{odrl-dpv-fpv-trust-flow.pl → odrl-dpv-fpv-trust-flow.eye} +0 -0
  782. /package/examples/output/{odrl-dpv-healthcare-risk-ranked.pl → odrl-dpv-healthcare-risk-ranked.eye} +0 -0
  783. /package/examples/output/{odrl-dpv-risk-ranked.pl → odrl-dpv-risk-ranked.eye} +0 -0
  784. /package/examples/output/{orbital-transfer-design.pl → orbital-transfer-design.eye} +0 -0
  785. /package/examples/output/{path-discovery.pl → path-discovery.eye} +0 -0
  786. /package/examples/output/{peano-arithmetic.pl → peano-arithmetic.eye} +0 -0
  787. /package/examples/output/{peasant.pl → peasant.eye} +0 -0
  788. /package/examples/output/{pell-equation.pl → pell-equation.eye} +0 -0
  789. /package/examples/output/{pendulum-period.pl → pendulum-period.eye} +0 -0
  790. /package/examples/output/{polynomial.pl → polynomial.eye} +0 -0
  791. /package/examples/output/{proof-contrapositive.pl → proof-contrapositive.eye} +0 -0
  792. /package/examples/output/{quadratic-formula.pl → quadratic-formula.eye} +0 -0
  793. /package/examples/output/{radioactive-decay.pl → radioactive-decay.eye} +0 -0
  794. /package/examples/output/{reusable-builtins.pl → reusable-builtins.eye} +0 -0
  795. /package/examples/output/{riemann-hypothesis.pl → riemann-hypothesis.eye} +0 -0
  796. /package/examples/output/{security-incident-correlation.pl → security-incident-correlation.eye} +0 -0
  797. /package/examples/output/{send-more-money.pl → send-more-money.eye} +0 -0
  798. /package/examples/output/{service-impact.pl → service-impact.eye} +0 -0
  799. /package/examples/output/{sieve.pl → sieve.eye} +0 -0
  800. /package/examples/output/{skolem-functions.pl → skolem-functions.eye} +0 -0
  801. /package/examples/output/{socket-age.pl → socket-age.eye} +0 -0
  802. /package/examples/output/{socket-family.pl → socket-family.eye} +0 -0
  803. /package/examples/output/{socrates.pl → socrates.eye} +0 -0
  804. /package/examples/output/{stable-marriage.pl → stable-marriage.eye} +0 -0
  805. /package/examples/output/{statistics-summary.pl → statistics-summary.eye} +0 -0
  806. /package/examples/output/{stirling-bell-numbers.pl → stirling-bell-numbers.eye} +0 -0
  807. /package/examples/output/{sudoku-4x4.pl → sudoku-4x4.eye} +0 -0
  808. /package/examples/output/{superdense-coding.pl → superdense-coding.eye} +0 -0
  809. /package/examples/output/{term-tools.pl → term-tools.eye} +0 -0
  810. /package/examples/output/{totient-summatory.pl → totient-summatory.eye} +0 -0
  811. /package/examples/output/{trust-flow-provenance-threshold.pl → trust-flow-provenance-threshold.eye} +0 -0
  812. /package/examples/output/{turing.pl → turing.eye} +0 -0
  813. /package/examples/output/{vector-similarity.pl → vector-similarity.eye} +0 -0
  814. /package/examples/output/{vulnerability-impact.pl → vulnerability-impact.eye} +0 -0
  815. /package/examples/output/{web-names.pl → web-names.eye} +0 -0
  816. /package/examples/output/{weighted-interval-scheduling.pl → weighted-interval-scheduling.eye} +0 -0
  817. /package/examples/output/{witch.pl → witch.eye} +0 -0
  818. /package/examples/output/{wolf-goat-cabbage.pl → wolf-goat-cabbage.eye} +0 -0
  819. /package/examples/output/{zebra.pl → zebra.eye} +0 -0
  820. /package/test/conformance/cases/{037_matching_and_comparison.pl → 037_matching_and_comparison.eye} +0 -0
  821. /package/test/conformance/cases/{054_numeric_and_lexical_comparison.pl → 054_numeric_and_lexical_comparison.eye} +0 -0
  822. /package/test/conformance/cases/{082_comparison_semantics.pl → 082_comparison_semantics.eye} +0 -0
  823. /package/test/conformance/expected/{001_fact_output.pl → 001_fact_output.eye} +0 -0
  824. /package/test/conformance/expected/{002_rule_recursion.pl → 002_rule_recursion.eye} +0 -0
  825. /package/test/conformance/expected/{003_terms_and_readback.pl → 003_terms_and_readback.eye} +0 -0
  826. /package/test/conformance/expected/{004_conjunction_and_parentheses.pl → 004_conjunction_and_parentheses.eye} +0 -0
  827. /package/test/conformance/expected/{005_list_deconstruction.pl → 005_list_deconstruction.eye} +0 -0
  828. /package/test/conformance/expected/{006_comma_formula_data.pl → 006_comma_formula_data.eye} +0 -0
  829. /package/test/conformance/expected/{007_anonymous_variables.pl → 007_anonymous_variables.eye} +0 -0
  830. /package/test/conformance/expected/{008_graphic_atoms.pl → 008_graphic_atoms.eye} +0 -0
  831. /package/test/conformance/expected/{009_comments_and_whitespace.pl → 009_comments_and_whitespace.eye} +0 -0
  832. /package/test/conformance/expected/{010_variable_scope_and_reuse.pl → 010_variable_scope_and_reuse.eye} +0 -0
  833. /package/test/conformance/expected/{011_predicate_arity.pl → 011_predicate_arity.eye} +0 -0
  834. /package/test/conformance/expected/{012_nested_compound_unification.pl → 012_nested_compound_unification.eye} +0 -0
  835. /package/test/conformance/expected/{013_multiple_clauses_order.pl → 013_multiple_clauses_order.eye} +0 -0
  836. /package/test/conformance/expected/{014_failure_filters_answers.pl → 014_failure_filters_answers.eye} +0 -0
  837. /package/test/conformance/expected/{015_improper_list_unification.pl → 015_improper_list_unification.eye} +0 -0
  838. /package/test/conformance/expected/{016_arity_zero_atom.pl → 016_arity_zero_atom.eye} +0 -0
  839. /package/test/conformance/expected/{017_three_step_recursion.pl → 017_three_step_recursion.eye} +0 -0
  840. /package/test/conformance/expected/{018_quoted_atom_readback.pl → 018_quoted_atom_readback.eye} +0 -0
  841. /package/test/conformance/expected/{019_parenthesized_three_conjuncts.pl → 019_parenthesized_three_conjuncts.eye} +0 -0
  842. /package/test/conformance/expected/{020_nested_list_terms.pl → 020_nested_list_terms.eye} +0 -0
  843. /package/test/conformance/expected/{021_repeated_variable_head.pl → 021_repeated_variable_head.eye} +0 -0
  844. /package/test/conformance/expected/{022_rule_head_structure.pl → 022_rule_head_structure.eye} +0 -0
  845. /package/test/conformance/expected/{023_quoted_escapes_readback.pl → 023_quoted_escapes_readback.eye} +0 -0
  846. /package/test/conformance/expected/{024_numeric_literal_readback.pl → 024_numeric_literal_readback.eye} +0 -0
  847. /package/test/conformance/expected/{025_body_parentheses_with_formula_data.pl → 025_body_parentheses_with_formula_data.eye} +0 -0
  848. /package/test/conformance/expected/{026_underscore_named_variable_reuse.pl → 026_question_underscore_named_variable_reuse.eye} +0 -0
  849. /package/test/conformance/expected/{027_default_derived_output.pl → 027_default_derived_output.eye} +0 -0
  850. /package/test/conformance/expected/{028_materialize_focus.pl → 028_materialize_focus.eye} +0 -0
  851. /package/test/conformance/expected/{029_arithmetic_and_comparison.pl → 029_arithmetic_and_comparison.eye} +0 -0
  852. /package/test/conformance/expected/{030_strings_and_atoms.pl → 030_strings_and_atoms.eye} +0 -0
  853. /package/test/conformance/expected/{031_lists_aggregation_ordering.pl → 031_lists_aggregation_ordering.eye} +0 -0
  854. /package/test/conformance/expected/{032_holds_parts.pl → 032_holds_parts.eye} +0 -0
  855. /package/test/conformance/expected/{033_negation_once_generators.pl → 033_negation_once_generators.eye} +0 -0
  856. /package/test/conformance/expected/{034_equality_and_inequality.pl → 034_equality_and_inequality.eye} +0 -0
  857. /package/test/conformance/expected/{035_list_relations.pl → 035_list_relations.eye} +0 -0
  858. /package/test/conformance/expected/{036_append_splits.pl → 036_append_splits.eye} +0 -0
  859. /package/test/conformance/expected/{037_matching_and_comparison.pl → 037_matching_and_comparison.eye} +0 -0
  860. /package/test/conformance/expected/{038_memoize_declaration.pl → 038_table_declaration.eye} +0 -0
  861. /package/test/conformance/expected/{039_numeric_functions.pl → 039_numeric_functions.eye} +0 -0
  862. /package/test/conformance/expected/{040_between_enumeration.pl → 040_between_enumeration.eye} +0 -0
  863. /package/test/conformance/expected/{041_smallest_divisor.pl → 041_smallest_divisor.eye} +0 -0
  864. /package/test/conformance/expected/{042_negation_filter.pl → 042_negation_filter.eye} +0 -0
  865. /package/test/conformance/expected/{043_once_user_predicate.pl → 043_once_user_predicate.eye} +0 -0
  866. /package/test/conformance/expected/{044_findall_user_goal.pl → 044_findall_user_goal.eye} +0 -0
  867. /package/test/conformance/expected/{045_sort_deduplicates_atoms.pl → 045_sort_deduplicates_atoms.eye} +0 -0
  868. /package/test/conformance/expected/{046_append_bound_prefix_suffix.pl → 046_append_bound_prefix_suffix.eye} +0 -0
  869. /package/test/conformance/expected/{047_nth0_index_generation.pl → 047_nth0_index_generation.eye} +0 -0
  870. /package/test/conformance/expected/{048_set_nth0_edges.pl → 048_set_nth0_edges.eye} +0 -0
  871. /package/test/conformance/expected/{049_select_duplicate_occurrences.pl → 049_select_duplicate_occurrences.eye} +0 -0
  872. /package/test/conformance/expected/{050_not_member_filter.pl → 050_not_member_filter.eye} +0 -0
  873. /package/test/conformance/expected/{051_nested_holds_parts.pl → 051_nested_holds_parts.eye} +0 -0
  874. /package/test/conformance/expected/{052_holds_member.pl → 052_holds_member.eye} +0 -0
  875. /package/test/conformance/expected/{053_materialize_excludes_source_fact.pl → 053_materialize_excludes_source_fact.eye} +0 -0
  876. /package/test/conformance/expected/{054_numeric_and_lexical_comparison.pl → 054_numeric_and_lexical_comparison.eye} +0 -0
  877. /package/test/conformance/expected/{055_string_matching_filters.pl → 055_string_matching_filters.eye} +0 -0
  878. /package/test/conformance/expected/{056_string_and_atom_concat.pl → 056_string_and_atom_concat.eye} +0 -0
  879. /package/test/conformance/expected/{057_countall_empty_and_nonempty.pl → 057_countall_empty_and_nonempty.eye} +0 -0
  880. /package/test/conformance/expected/{058_sumall_numeric_template.pl → 058_sumall_numeric_template.eye} +0 -0
  881. /package/test/conformance/expected/{059_aggregate_min_template.pl → 059_aggregate_min_template.eye} +0 -0
  882. /package/test/conformance/expected/{060_aggregate_max_compound_key.pl → 060_aggregate_max_compound_key.eye} +0 -0
  883. /package/test/conformance/expected/{061_date_difference.pl → 061_date_difference.eye} +0 -0
  884. /package/test/conformance/expected/{062_reusable_numeric_builtins.pl → 062_reusable_numeric_builtins.eye} +0 -0
  885. /package/test/conformance/expected/{063_reusable_list_builtins.pl → 063_reusable_list_builtins.eye} +0 -0
  886. /package/test/conformance/expected/{064_reusable_string_builtins.pl → 064_reusable_string_builtins.eye} +0 -0
  887. /package/test/conformance/expected/{065_reusable_term_control_builtins.pl → 065_reusable_term_control_builtins.eye} +0 -0
  888. /package/test/conformance/expected/{066_numeric_edges.pl → 066_numeric_edges.eye} +0 -0
  889. /package/test/conformance/expected/{067_list_edges.pl → 067_list_edges.eye} +0 -0
  890. /package/test/conformance/expected/{068_list_generation_order.pl → 068_list_generation_order.eye} +0 -0
  891. /package/test/conformance/expected/{069_list_summaries_and_sets.pl → 069_list_summaries_and_sets.eye} +0 -0
  892. /package/test/conformance/expected/{070_matches_named_captures.pl → 070_matches_named_captures.eye} +0 -0
  893. /package/test/conformance/expected/{071_string_edges.pl → 071_string_edges.eye} +0 -0
  894. /package/test/conformance/expected/{072_string_conversions.pl → 072_string_conversions.eye} +0 -0
  895. /package/test/conformance/expected/{073_term_introspection_edges.pl → 073_term_introspection_edges.eye} +0 -0
  896. /package/test/conformance/expected/{074_forall_edges.pl → 074_forall_edges.eye} +0 -0
  897. /package/test/conformance/expected/{075_aggregation_edges.pl → 075_aggregation_edges.eye} +0 -0
  898. /package/test/conformance/expected/{076_composed_reusable_builtins.pl → 076_composed_reusable_builtins.eye} +0 -0
  899. /package/test/conformance/expected/{077_recursive_path_with_lists.pl → 077_recursive_path_with_lists.eye} +0 -0
  900. /package/test/conformance/expected/{078_mutual_recursion_with_arithmetic.pl → 078_mutual_recursion_with_arithmetic.eye} +0 -0
  901. /package/test/conformance/expected/{079_big_integer_arithmetic.pl → 079_big_integer_arithmetic.eye} +0 -0
  902. /package/test/conformance/expected/{080_rounding_modes.pl → 080_rounding_modes.eye} +0 -0
  903. /package/test/conformance/expected/{081_zero_safe_numeric_functions.pl → 081_zero_safe_numeric_functions.eye} +0 -0
  904. /package/test/conformance/expected/{082_comparison_semantics.pl → 082_comparison_semantics.eye} +0 -0
  905. /package/test/conformance/expected/{083_between_modes_and_empty_ranges.pl → 083_between_modes_and_empty_ranges.eye} +0 -0
  906. /package/test/conformance/expected/{084_append_and_select_composition.pl → 084_append_and_select_composition.eye} +0 -0
  907. /package/test/conformance/expected/{085_nth_and_update_edges.pl → 085_nth_and_update_edges.eye} +0 -0
  908. /package/test/conformance/expected/{086_slicing_pipeline.pl → 086_slicing_pipeline.eye} +0 -0
  909. /package/test/conformance/expected/{087_sort_reverse_length.pl → 087_sort_reverse_length.eye} +0 -0
  910. /package/test/conformance/expected/{088_list_summaries_failures.pl → 088_list_summaries_failures.eye} +0 -0
  911. /package/test/conformance/expected/{089_string_split_join_pipeline.pl → 089_string_split_join_pipeline.eye} +0 -0
  912. /package/test/conformance/expected/{090_string_substring_replace_edges.pl → 090_string_substring_replace_edges.eye} +0 -0
  913. /package/test/conformance/expected/{091_string_case_and_trim.pl → 091_string_case_and_trim.eye} +0 -0
  914. /package/test/conformance/expected/{092_scalar_string_conversions.pl → 092_scalar_string_conversions.eye} +0 -0
  915. /package/test/conformance/expected/{093_regex_named_captures_context.pl → 093_regex_named_captures_context.eye} +0 -0
  916. /package/test/conformance/expected/{094_context_holds_enumeration.pl → 094_context_holds_enumeration.eye} +0 -0
  917. /package/test/conformance/expected/{095_term_introspection_roundtrip.pl → 095_term_introspection_roundtrip.eye} +0 -0
  918. /package/test/conformance/expected/{096_functor_scalar_edges.pl → 096_functor_scalar_edges.eye} +0 -0
  919. /package/test/conformance/expected/{097_control_negation_once_forall.pl → 097_control_negation_once_forall.eye} +0 -0
  920. /package/test/conformance/expected/{098_aggregation_nested_templates.pl → 098_aggregation_nested_templates.eye} +0 -0
  921. /package/test/conformance/expected/{099_materialize_multiple_arities.pl → 099_materialize_multiple_arities.eye} +0 -0
  922. /package/test/conformance/expected/{100_reusable_builtin_workflow.pl → 100_reusable_builtin_workflow.eye} +0 -0
@@ -0,0 +1,162 @@
1
+ % Memoize interval computations reused across width, midpoint, gradient, step,
2
+ % objective, and contraction report relations.
3
+ % Output declarations: materialize/2 selects the relations written to this example's golden output.
4
+ %
5
+ % This is a proof-friendly optimization trace: every numeric fact needed to
6
+ % justify the step is materialized, so proof output can certify why the update
7
+ % is accepted.
8
+ materialize(eta, 2).
9
+ materialize(etaLeHalf, 2).
10
+ materialize(xBounds, 2).
11
+ materialize(midpoint, 2).
12
+ materialize(width, 2).
13
+ materialize(gradientBounds, 2).
14
+ materialize(stepBounds, 2).
15
+ materialize(objectiveBounds, 2).
16
+ materialize(widthContractsAt, 2).
17
+
18
+ % Program structure: facts set up the scenario, and rules derive the materialized conclusions.
19
+ table(x_bounds, 3).
20
+ table(width, 2).
21
+ table(g_bounds, 3).
22
+ table(p_bounds, 3).
23
+ table(midpoint, 3).
24
+ table(f_lower, 2).
25
+ table(f_upper, 2).
26
+
27
+ % Adapted from Eyeling's gd-step-certified.n3.
28
+ % One-dimensional gradient descent over certified interval bounds.
29
+
30
+ max_k(10).
31
+ target(1.0).
32
+ % Derivation rules: each rule below contributes one logical step toward the displayed results.
33
+ eta(?eta) :- div(1.0, 5, ?eta).
34
+ x_bounds(0, 0.0, 2.0).
35
+
36
+ index(0). index(1). index(2). index(3). index(4). index(5).
37
+ index(6). index(7). index(8). index(9). index(10).
38
+
39
+ previous(1, 0). previous(2, 1). previous(3, 2). previous(4, 3). previous(5, 4).
40
+ previous(6, 5). previous(7, 6). previous(8, 7). previous(9, 8). previous(10, 9).
41
+
42
+ g_bounds(?k, ?gl, ?gu) :-
43
+ target(?a),
44
+ x_bounds(?k, ?l, ?u),
45
+ sub(?l, ?a, ?dl),
46
+ sub(?u, ?a, ?du),
47
+ mul(2, ?dl, ?gl),
48
+ mul(2, ?du, ?gu).
49
+
50
+ p_bounds(?k, ?pl, ?pu) :-
51
+ eta(?eta),
52
+ g_bounds(?k, ?gl, ?gu),
53
+ mul(?eta, ?gl, ?pl),
54
+ mul(?eta, ?gu, ?pu).
55
+
56
+ x_bounds(?k1, ?l1, ?u1) :-
57
+ previous(?k1, ?k),
58
+ x_bounds(?k, ?l, ?u),
59
+ target(?a),
60
+ eta(?eta),
61
+ sub(?l, ?a, ?dl),
62
+ sub(?u, ?a, ?du),
63
+ mul(2, ?dl, ?gl),
64
+ mul(2, ?du, ?gu),
65
+ mul(?eta, ?gl, ?pl),
66
+ mul(?eta, ?gu, ?pu),
67
+ sub(?l, ?pu, ?l1),
68
+ sub(?u, ?pl, ?u1).
69
+
70
+ width(?k, ?w) :-
71
+ x_bounds(?k, ?l, ?u),
72
+ sub(?u, ?l, ?w).
73
+
74
+ midpoint(?k, ?m, ?halfw) :-
75
+ x_bounds(?k, ?l, ?u),
76
+ width(?k, ?w),
77
+ div(?w, 2, ?halfw),
78
+ add(?l, ?u, ?sum),
79
+ div(?sum, 2, ?m).
80
+
81
+ eta_le_half(true) :-
82
+ eta(?eta),
83
+ div(1.0, 2, ?half),
84
+ le(?eta, ?half).
85
+
86
+ width_contracts_at(?k1, true) :-
87
+ eta_le_half(true),
88
+ previous(?k1, ?k),
89
+ width(?k, ?w),
90
+ width(?k1, ?w1),
91
+ le(?w1, ?w).
92
+
93
+ max2(?a, ?b, ?a) :- ge(?a, ?b).
94
+ max2(?a, ?b, ?b) :- lt(?a, ?b).
95
+ min2(?a, ?b, ?a) :- le(?a, ?b).
96
+ min2(?a, ?b, ?b) :- gt(?a, ?b).
97
+
98
+ end_squares(?k, ?sl, ?su) :-
99
+ target(?a),
100
+ x_bounds(?k, ?l, ?u),
101
+ sub(?l, ?a, ?dl),
102
+ sub(?u, ?a, ?du),
103
+ mul(?dl, ?dl, ?sl),
104
+ mul(?du, ?du, ?su).
105
+
106
+ f_upper(?k, ?fu) :-
107
+ end_squares(?k, ?sl, ?su),
108
+ max2(?sl, ?su, ?fu).
109
+
110
+ f_lower(?k, 0.0) :-
111
+ target(?a),
112
+ x_bounds(?k, ?l, ?u),
113
+ le(?l, ?a),
114
+ le(?a, ?u).
115
+
116
+ f_lower(?k, ?fl) :-
117
+ target(?a),
118
+ x_bounds(?k, ?l, ?u),
119
+ lt(?u, ?a),
120
+ end_squares(?k, ?sl, ?su),
121
+ min2(?sl, ?su, ?fl).
122
+
123
+ f_lower(?k, ?fl) :-
124
+ target(?a),
125
+ x_bounds(?k, ?l, ?u),
126
+ lt(?a, ?l),
127
+ end_squares(?k, ?sl, ?su),
128
+ min2(?sl, ?su, ?fl).
129
+
130
+ eta(result, ?eta) :-
131
+ eta(?eta).
132
+
133
+ etaLeHalf(result, true) :-
134
+ eta_le_half(true).
135
+
136
+ xBounds(result, bounds(?k, ?l, ?u)) :-
137
+ index(?k),
138
+ x_bounds(?k, ?l, ?u).
139
+
140
+ midpoint(result, midpoint(?k, ?m, ?halfw)) :-
141
+ index(?k),
142
+ midpoint(?k, ?m, ?halfw).
143
+
144
+ width(result, width(?k, ?w)) :-
145
+ index(?k),
146
+ width(?k, ?w).
147
+
148
+ gradientBounds(result, gradient(?k, ?gl, ?gu)) :-
149
+ index(?k),
150
+ g_bounds(?k, ?gl, ?gu).
151
+
152
+ stepBounds(result, step(?k, ?pl, ?pu)) :-
153
+ index(?k),
154
+ p_bounds(?k, ?pl, ?pu).
155
+
156
+ objectiveBounds(result, f(?k, ?fl, ?fu)) :-
157
+ index(?k),
158
+ f_lower(?k, ?fl),
159
+ f_upper(?k, ?fu).
160
+
161
+ widthContractsAt(result, ?k) :-
162
+ width_contracts_at(?k, true).
@@ -0,0 +1,69 @@
1
+ % GDPR-style compliance check.
2
+ % Each processing case is tested for purpose compatibility, legal basis,
3
+ % minimisation, special-category safeguards, and international-transfer safety.
4
+ % Separate failure rules produce concise reasons for noncompliant cases.
5
+
6
+ materialize(status, 2).
7
+ materialize(reason, 2).
8
+
9
+ % case_alpha is intended to pass; case_beta is intentionally incomplete.
10
+ processing(case_alpha).
11
+ processing(case_beta).
12
+
13
+ purpose(case_alpha, care_coordination).
14
+ purpose(case_beta, marketing).
15
+
16
+ legal_basis(case_alpha, explicit_consent).
17
+ % case_beta intentionally has no legal basis.
18
+
19
+ minimized(case_alpha).
20
+ not_minimized(case_beta).
21
+
22
+ special_category(case_alpha, health_data).
23
+ special_category(case_beta, health_data).
24
+
25
+ safeguard(case_alpha, encryption).
26
+ safeguard(case_alpha, access_logging).
27
+ safeguard(case_beta, encryption).
28
+
29
+ third_country_transfer(case_beta).
30
+ adequacy_decision(case_alpha).
31
+
32
+ % Compliance is decomposed into reusable checks so reasons can be reported.
33
+ has_required_basis(?case) :- legal_basis(?case, explicit_consent).
34
+ has_required_basis(?case) :- legal_basis(?case, medical_care).
35
+
36
+ has_health_safeguards(?case) :-
37
+ special_category(?case, health_data),
38
+ safeguard(?case, encryption),
39
+ safeguard(?case, access_logging).
40
+
41
+ transfer_ok(?case) :- not(third_country_transfer(?case)).
42
+ transfer_ok(?case) :- adequacy_decision(?case).
43
+
44
+ compliant(?case) :-
45
+ processing(?case),
46
+ has_required_basis(?case),
47
+ minimized(?case),
48
+ has_health_safeguards(?case),
49
+ transfer_ok(?case).
50
+
51
+ % Individual failure rules explain why a case is noncompliant.
52
+ noncompliance_reason(?case, missing_legal_basis) :-
53
+ processing(?case),
54
+ not(has_required_basis(?case)).
55
+
56
+ noncompliance_reason(?case, not_minimized) :-
57
+ not_minimized(?case).
58
+
59
+ noncompliance_reason(?case, missing_access_logging) :-
60
+ special_category(?case, health_data),
61
+ not(safeguard(?case, access_logging)).
62
+
63
+ noncompliance_reason(?case, transfer_without_adequacy) :-
64
+ third_country_transfer(?case),
65
+ not(adequacy_decision(?case)).
66
+
67
+ status(?case, gdpr_compliant) :- compliant(?case).
68
+ status(?case, gdpr_noncompliant) :- noncompliance_reason(?case, ?_reason).
69
+ reason(?case, ?reason) :- noncompliance_reason(?case, ?reason).
@@ -0,0 +1,16 @@
1
+ % Good cobbler, adapted from Eyeling's examples/good-cobbler.n3.
2
+ %
3
+ % The Eyeling result is a quoted assertion saying that joe is a good Cobbler.
4
+ % Here the quoted assertion is represented as an eyelang term.
5
+
6
+ % Output declarations: materialize/2 selects the relations written to this example's golden output.
7
+ materialize(is, 2).
8
+
9
+ % The asserted fact is kept separate from the output form so the rule can show
10
+ % how a quoted Eyeling assertion maps to an ordinary eyelang term.
11
+ assertedIs(joe, good(cobbler)).
12
+
13
+ % The single rule is intentionally simple: it preserves the subject and
14
+ % profession while wrapping the conclusion as is(X, good(Y)).
15
+ is(test, is(?x, good(?y))) :-
16
+ assertedIs(?x, good(?y)).
@@ -0,0 +1,146 @@
1
+ % GPS route-planning example translated from Eyeling's gps.n3.
2
+ % The map is stored as quoted formula data and projected with holds/3. Route
3
+ % paths accumulate action sequence, duration, cost, belief, and comfort; table
4
+ % keeps repeated comparison and explanation queries from recomputing paths.
5
+
6
+ materialize(recommendedRoute, 2).
7
+ materialize(outcome, 2).
8
+ materialize(statement, 3).
9
+ materialize(label, 2).
10
+ materialize(actionSequence, 2).
11
+ materialize(durationSeconds, 2).
12
+ materialize(cost, 2).
13
+ materialize(belief, 2).
14
+ materialize(comfort, 2).
15
+ materialize(selectedRoute, 2).
16
+ materialize(comparison, 2).
17
+
18
+ table(path, 7).
19
+ table(traveller_path, 6).
20
+
21
+ case_graph(caseGraph, (
22
+ location(i1, gent),
23
+ text(question, "Which route should we take from Gent to Oostende?"),
24
+ label(routeDirect, "Gent -> Brugge -> Oostende"),
25
+ label(routeViaKortrijk, "Gent -> Kortrijk -> Brugge -> Oostende")
26
+ )).
27
+
28
+ map_graph(mapBE, (
29
+ gps_description(mapBE, description(location(?s, gent), true, location(?s, brugge), drive_gent_brugge, 1500.0, 0.006, 0.96, 0.99)),
30
+ gps_description(mapBE, description(location(?s, gent), true, location(?s, kortrijk), drive_gent_kortrijk, 1600.0, 0.007, 0.96, 0.99)),
31
+ gps_description(mapBE, description(location(?s, kortrijk), true, location(?s, brugge), drive_kortrijk_brugge, 1600.0, 0.007, 0.96, 0.99)),
32
+ gps_description(mapBE, description(location(?s, brugge), true, location(?s, oostende), drive_brugge_oostende, 900.0, 0.004, 0.98, 1.0))
33
+ )).
34
+
35
+ case_statement(?s, ?p, ?o) :-
36
+ case_graph(caseGraph, ?context),
37
+ holds(?context, ?p, [?s, ?o]).
38
+
39
+ map_description(?from, ?to, ?action, ?duration, ?cost, ?belief, ?comfort) :-
40
+ map_graph(mapBE, ?context),
41
+ holds(?context, gps_description(mapBE, description(?from, true, ?to, ?action, ?duration, ?cost, ?belief, ?comfort))).
42
+
43
+ path(?from, ?to, [?action], ?duration, ?cost, ?belief, ?comfort) :-
44
+ map_description(?from, ?to, ?action, ?duration, ?cost, ?belief, ?comfort).
45
+
46
+ path(?from, ?to, ?actions, ?duration, ?cost, ?belief, ?comfort) :-
47
+ map_description(?from, ?mid, ?action, ?d1, ?c1, ?b1, ?f1),
48
+ path(?mid, ?to, ?restactions, ?d2, ?c2, ?b2, ?f2),
49
+ append([?action], ?restactions, ?actions),
50
+ add(?d1, ?d2, ?duration),
51
+ add(?c1, ?c2, ?cost),
52
+ mul(?b1, ?b2, ?belief),
53
+ mul(?f1, ?f2, ?comfort).
54
+
55
+ traveller_start(i1, location(i1, gent)).
56
+ traveller_goal(i1, location(i1, oostende)).
57
+
58
+ traveller_path(?traveller, ?actions, ?duration, ?cost, ?belief, ?comfort) :-
59
+ traveller_start(?traveller, ?from),
60
+ traveller_goal(?traveller, ?to),
61
+ path(?from, ?to, ?actions, ?duration, ?cost, ?belief, ?comfort).
62
+
63
+ route_metrics(routeDirect, ?duration, ?cost, ?belief, ?comfort) :-
64
+ traveller_path(i1, [drive_gent_brugge, drive_brugge_oostende], ?duration, ?cost, ?belief, ?comfort).
65
+
66
+ route_metrics(routeViaKortrijk, ?duration, ?cost, ?belief, ?comfort) :-
67
+ traveller_path(i1, [drive_gent_kortrijk, drive_kortrijk_brugge, drive_brugge_oostende], ?duration, ?cost, ?belief, ?comfort).
68
+
69
+ recommended_route(routeDirect) :-
70
+ route_metrics(routeDirect, ?directduration, ?directcost, ?directbelief, ?directcomfort),
71
+ route_metrics(routeViaKortrijk, ?viaduration, ?viacost, ?viabelief, ?viacomfort),
72
+ lt(?directduration, ?viaduration),
73
+ lt(?directcost, ?viacost),
74
+ gt(?directbelief, ?viabelief),
75
+ gt(?directcomfort, ?viacomfort).
76
+
77
+ outcome(routeDirect, "Take the direct route via Brugge.").
78
+
79
+ % Verification checks, analogous to the false-producing guards in gps.n3.
80
+ check(c1, true) :-
81
+ traveller_path(i1, [drive_gent_brugge, drive_brugge_oostende], ?_, ?_, ?_, ?_).
82
+
83
+ check(c2, true) :-
84
+ traveller_path(i1, [drive_gent_kortrijk, drive_kortrijk_brugge, drive_brugge_oostende], ?_, ?_, ?_, ?_).
85
+
86
+ check(c3, true) :-
87
+ route_metrics(routeDirect, ?d1, ?_, ?_, ?_),
88
+ route_metrics(routeViaKortrijk, ?d2, ?_, ?_, ?_),
89
+ lt(?d1, ?d2).
90
+
91
+ check(c4, true) :-
92
+ route_metrics(routeDirect, ?_, ?c1, ?_, ?_),
93
+ route_metrics(routeViaKortrijk, ?_, ?c2, ?_, ?_),
94
+ lt(?c1, ?c2).
95
+
96
+ check(c5, true) :-
97
+ route_metrics(routeDirect, ?_, ?_, ?b1, ?f1),
98
+ route_metrics(routeViaKortrijk, ?_, ?_, ?b2, ?f2),
99
+ gt(?b1, ?b2),
100
+ gt(?f1, ?f2).
101
+
102
+ recommendedRoute(decision, ?route) :-
103
+ recommended_route(?route).
104
+
105
+ outcome(decision, ?outcome) :-
106
+ recommended_route(?route),
107
+ outcome(?route, ?outcome).
108
+
109
+ statement(check, ?check, true) :-
110
+ check(?check, true).
111
+
112
+ route_actions(routeDirect, [drive_gent_brugge, drive_brugge_oostende]).
113
+ route_actions(routeViaKortrijk, [drive_gent_kortrijk, drive_kortrijk_brugge, drive_brugge_oostende]).
114
+
115
+ % Derived route and report relations. These are consequences of the route search
116
+ % and comparison, not pre-written markdown output.
117
+ label(?route, ?label) :-
118
+ case_statement(?route, label, ?label),
119
+ route_metrics(?route, ?_duration, ?_cost, ?_belief, ?_comfort).
120
+
121
+ actionSequence(?route, ?actions) :-
122
+ route_actions(?route, ?actions),
123
+ route_metrics(?route, ?_duration, ?_cost, ?_belief, ?_comfort).
124
+
125
+ durationSeconds(?route, ?duration) :-
126
+ route_metrics(?route, ?duration, ?_cost, ?_belief, ?_comfort).
127
+
128
+ cost(?route, ?cost) :-
129
+ route_metrics(?route, ?_duration, ?cost, ?_belief, ?_comfort).
130
+
131
+ belief(?route, ?belief) :-
132
+ route_metrics(?route, ?_duration, ?_cost, ?belief, ?_comfort).
133
+
134
+ comfort(?route, ?comfort) :-
135
+ route_metrics(?route, ?_duration, ?_cost, ?_belief, ?comfort).
136
+
137
+ selectedRoute(report, route(?route, ?actions, ?duration, ?cost, ?belief, ?comfort)) :-
138
+ recommended_route(?route),
139
+ route_actions(?route, ?actions),
140
+ route_metrics(?route, ?duration, ?cost, ?belief, ?comfort).
141
+
142
+ comparison(report, dominates(routeDirect, routeViaKortrijk)) :-
143
+ recommended_route(routeDirect),
144
+ check(c3, true),
145
+ check(c4, true),
146
+ check(c5, true).
@@ -0,0 +1,33 @@
1
+ % Graph reachability example adapted from Eyelet input/graph-reachability.eye.
2
+ % The recursive search carries a Visited list and rejects already-seen nodes with
3
+ % not(member(...)). This keeps reachability finite and also lets the example
4
+ % derive explicit not_reachable/2 evidence for a negative test case.
5
+
6
+ materialize(reachable, 2).
7
+ materialize(not_reachable, 2).
8
+
9
+ edge(a, b).
10
+ edge(a, c).
11
+ edge(b, d).
12
+ edge(c, e).
13
+ edge(d, f).
14
+ edge(e, f).
15
+ edge(f, g).
16
+
17
+ reachable(?node, ?node, ?_visited).
18
+ reachable(?start, ?goal, ?visited) :-
19
+ edge(?start, ?next),
20
+ not(member(?next, ?visited)),
21
+ reachable(?next, ?goal, [?next|?visited]).
22
+
23
+ is_reachable(?start, ?goal) :-
24
+ reachable(?start, ?goal, [?start]).
25
+
26
+ reachable(reachability_case, path(a, f)) :-
27
+ is_reachable(a, f).
28
+
29
+ reachable(reachability_case, path(c, g)) :-
30
+ is_reachable(c, g).
31
+
32
+ not_reachable(reachability_case, path(b, e)) :-
33
+ not(is_reachable(b, e)).
@@ -0,0 +1,35 @@
1
+ % Transitive graph paths over a small map of French cities.
2
+ %
3
+ % The base relation is directed: oneway(A, B) means there is a road from A
4
+ % to B. The derived relation path(A, B) is the transitive closure: B is
5
+ % reachable from A by one or more directed legs.
6
+ %
7
+ % The recursive rule is written in a productive, right-recursive form:
8
+ %
9
+ % path(A, C) :- oneway(A, B), path(B, C).
10
+ %
11
+ % That order matters in a goal-directed reasoner. A left-recursive closure
12
+ % rule such as `path(A, C) :- path(A, B), path(B, C).` starts by asking for
13
+ % the same open relation it is currently proving, so eyelang's recursion guard
14
+ % must stop it to avoid an infinite loop. The result is under-generation: only
15
+ % direct edges are printed. Starting with the concrete generator `oneway/2`
16
+ % first makes each recursive step smaller and yields the complete closure.
17
+
18
+ materialize(path, 2).
19
+
20
+ oneway(paris, orleans).
21
+ oneway(paris, chartres).
22
+ oneway(paris, amiens).
23
+ oneway(orleans, blois).
24
+ oneway(orleans, bourges).
25
+ oneway(blois, tours).
26
+ oneway(chartres, lemans).
27
+ oneway(lemans, angers).
28
+ oneway(lemans, tours).
29
+ oneway(angers, nantes).
30
+
31
+ path(?a, ?b) :-
32
+ oneway(?a, ?b).
33
+ path(?a, ?c) :-
34
+ oneway(?a, ?b),
35
+ path(?b, ?c).
@@ -0,0 +1,47 @@
1
+ % Gray-code counter adapted from Eyeling gray-code-counter.n3.
2
+ % Boolean gates are represented as truth-table facts. The circuit rules compose
3
+ % those gates into next-state logic for three flip-flops, and testgcc/3 runs the
4
+ % counter over a finite clock sequence.
5
+
6
+ materialize(isgcc, 2).
7
+
8
+ % Boolean gates are truth tables; the circuit rules compose them.
9
+ and(0, 0, 0). and(0, 1, 0). and(1, 0, 0). and(1, 1, 1).
10
+ or(0, 0, 0). or(0, 1, 1). or(1, 0, 1). or(1, 1, 1).
11
+ inv(0, 1). inv(1, 0).
12
+
13
+ dff(?d, 0, ?q, ?q).
14
+ dff(?d, 1, ?_q, ?d).
15
+
16
+ neta(?a, ?b, ?q) :-
17
+ and(?a, ?b, ?t1),
18
+ inv(?a, ?na),
19
+ inv(?b, ?nb),
20
+ and(?na, ?nb, ?t2),
21
+ or(?t1, ?t2, ?q).
22
+
23
+ netb(?a, ?b, ?c, ?q1, ?q2) :-
24
+ and(?a, ?c, ?t1),
25
+ inv(?c, ?nc),
26
+ and(?b, ?nc, ?t2),
27
+ inv(?a, ?na),
28
+ and(?na, ?c, ?t3),
29
+ or(?t1, ?t2, ?q1),
30
+ or(?t2, ?t3, ?q2).
31
+
32
+ % One clock step computes D inputs, then updates the three flip-flops.
33
+ gcc(?c, [?qa, ?qb, ?qc], [?za, ?zb, ?zc]) :-
34
+ netb(?qa, ?qb, ?qc, ?d1, ?d2),
35
+ neta(?qa, ?qb, ?d3),
36
+ dff(?d1, ?c, ?qa, ?za),
37
+ dff(?d2, ?c, ?qb, ?zb),
38
+ dff(?d3, ?c, ?qc, ?zc).
39
+
40
+ % testgcc/3 runs the circuit over a list of clock inputs.
41
+ testgcc([], ?_state, []).
42
+ testgcc([?c|?cs], ?state, [?next|?rest]) :-
43
+ gcc(?c, ?state, ?next),
44
+ testgcc(?cs, ?next, ?rest).
45
+
46
+ isgcc([[1, 1, 1, 1, 1, 1, 1, 1, 1], [0, 0, 0]], ?states) :-
47
+ testgcc([1, 1, 1, 1, 1, 1, 1, 1, 1], [0, 0, 0], ?states).
@@ -0,0 +1,30 @@
1
+ % Order-theory proof sketch: greatest lower bounds are unique.
2
+ %
3
+ % Two candidate GLBs are asserted for the same pair. The rules derive that
4
+ % each must be below the other, then use antisymmetry-style sameTerm/2 reasoning
5
+ % to report that the candidates denote the same lower bound.
6
+ materialize(sameGreatestLowerBound, 4).
7
+
8
+ % Adapted from Eyeling greatest-lower-bound-uniqueness.n3. The named facts
9
+ % intentionally use two different symbols, g1 and g2, so the final output shows
10
+ % the equality-style conclusion as an explicit derived relation.
11
+
12
+ glbOf(g1, a, b).
13
+ glbOf(g2, a, b).
14
+
15
+ % leq/2 captures the defining property of a GLB: every lower bound is below it.
16
+ lowerBoundOf(?m, ?a, ?b) :- glbOf(?m, ?a, ?b).
17
+
18
+ leq(?l, ?m) :-
19
+ glbOf(?m, ?a, ?b),
20
+ lowerBoundOf(?l, ?a, ?b).
21
+
22
+ sameTerm(?m, ?n) :-
23
+ leq(?m, ?n),
24
+ leq(?n, ?m).
25
+
26
+ sameGreatestLowerBound(?a, ?b, ?m, ?n) :-
27
+ glbOf(?m, ?a, ?b),
28
+ glbOf(?n, ?a, ?b),
29
+ sameTerm(?m, ?n),
30
+ neq(?m, ?n).
@@ -0,0 +1,36 @@
1
+ % Group inverse uniqueness, adapted from Eyeling's examples/group-inverse-uniqueness.n3.
2
+ %
3
+ % The output mirrors the Eyeling golden result shape:
4
+ % sameInverse(x, i, j) and sameInverse(x, j, i).
5
+
6
+ % Output declarations: materialize/2 selects the relations written to this example's golden output.
7
+ materialize(sameInverse, 3).
8
+
9
+ % The group table is deliberately tiny: e is the identity, and i and j are
10
+ % two names that both behave as the inverse of x.
11
+ element(e).
12
+ element(x).
13
+ element(i).
14
+ element(j).
15
+
16
+ % leftInverse/2 and rightInverse/2 are proved from op/3. sameInverse/3
17
+ % then derives uniqueness by combining both inverse directions with sameTerm/2.
18
+ op(e, ?x, ?x) :- element(?x).
19
+ op(?x, e, ?x) :- element(?x).
20
+ op(i, x, e).
21
+ op(x, j, e).
22
+ op(j, x, e).
23
+ op(x, i, e).
24
+
25
+ sameTerm(?x, ?x) :- element(?x).
26
+ sameTerm(i, j).
27
+ sameTerm(j, i).
28
+
29
+ leftInverse(?a, ?b) :- op(?b, ?a, e).
30
+ rightInverse(?a, ?b) :- op(?a, ?b, e).
31
+
32
+ sameInverse(?a, ?b, ?c) :-
33
+ leftInverse(?a, ?b),
34
+ rightInverse(?a, ?c),
35
+ sameTerm(?b, ?c),
36
+ neq(?b, ?c).
@@ -0,0 +1,51 @@
1
+ % Hamiltonian path, adapted from Eyelet's input/hamiltonian-path.eye.
2
+ %
3
+ % The graph is the same six-vertex undirected graph. eyelang spells the finite
4
+ % vertex set directly and derives every path that visits each vertex exactly
5
+ % once.
6
+
7
+ % Output declarations: materialize/2 selects the relations written to this example's golden output.
8
+ materialize(hasHamiltonianPath, 2).
9
+ materialize(hamiltonianPath, 2).
10
+
11
+ % The finite six-vertex graph is small enough to search directly. adjacent/2
12
+ % is tabled because every candidate path repeatedly asks the same edge tests.
13
+ table(adjacent, 2).
14
+
15
+ edge(v1, v2).
16
+ edge(v1, v3).
17
+ edge(v1, v5).
18
+ edge(v1, v6).
19
+ edge(v2, v3).
20
+ edge(v2, v4).
21
+ edge(v2, v6).
22
+ edge(v3, v4).
23
+ edge(v3, v6).
24
+ edge(v4, v5).
25
+ edge(v4, v6).
26
+
27
+ % hamiltonian_path/1 is intentionally unrolled to six positions: each next
28
+ % vertex must be adjacent to the previous one and absent from the prefix.
29
+ adjacent(?v, ?u) :- edge(?v, ?u).
30
+ adjacent(?v, ?u) :- edge(?u, ?v).
31
+
32
+ vertex(v1).
33
+ vertex(v2).
34
+ vertex(v3).
35
+ vertex(v4).
36
+ vertex(v5).
37
+ vertex(v6).
38
+
39
+ hamiltonian_path([?a, ?b, ?c, ?d, ?e, ?f]) :-
40
+ vertex(?a),
41
+ vertex(?b), adjacent(?a, ?b), not_member(?b, [?a]),
42
+ vertex(?c), adjacent(?b, ?c), not_member(?c, [?a, ?b]),
43
+ vertex(?d), adjacent(?c, ?d), not_member(?d, [?a, ?b, ?c]),
44
+ vertex(?e), adjacent(?d, ?e), not_member(?e, [?a, ?b, ?c, ?d]),
45
+ vertex(?f), adjacent(?e, ?f), not_member(?f, [?a, ?b, ?c, ?d, ?e]).
46
+
47
+ hasHamiltonianPath(graph, true) :-
48
+ hamiltonian_path(?_path).
49
+
50
+ hamiltonianPath(graph, ?path) :-
51
+ hamiltonian_path(?path).