eyeling 1.34.5 → 1.34.6

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 (307) hide show
  1. package/README.md +3 -90
  2. package/bin/eyeling.cjs +4 -56
  3. package/dist/browser/eyeling.browser.js +0 -1
  4. package/examples/context-schema-audit.n3 +1 -1
  5. package/eyeling.js +0 -1
  6. package/index.d.ts +3 -37
  7. package/index.js +1 -90
  8. package/lib/cli.js +0 -1
  9. package/package.json +3 -12
  10. package/test/packlist.test.js +0 -2
  11. package/test/run.js +0 -2
  12. package/docs/eyelang-guide.md +0 -535
  13. package/docs/eyelang-language-reference.md +0 -697
  14. package/examples/eyelang/access-control-policy.pl +0 -52
  15. package/examples/eyelang/ackermann.pl +0 -46
  16. package/examples/eyelang/age.pl +0 -28
  17. package/examples/eyelang/aliases-and-namespaces.pl +0 -22
  18. package/examples/eyelang/alignment-demo.pl +0 -44
  19. package/examples/eyelang/allen-interval-calculus.pl +0 -64
  20. package/examples/eyelang/ancestor.pl +0 -21
  21. package/examples/eyelang/animal.pl +0 -21
  22. package/examples/eyelang/annotation.pl +0 -34
  23. package/examples/eyelang/auroracare.pl +0 -309
  24. package/examples/eyelang/backward.pl +0 -12
  25. package/examples/eyelang/basic-monadic.pl +0 -10032
  26. package/examples/eyelang/bayes-diagnosis.pl +0 -108
  27. package/examples/eyelang/bayes-therapy.pl +0 -182
  28. package/examples/eyelang/beam-deflection.pl +0 -50
  29. package/examples/eyelang/blocks-world-planning.pl +0 -75
  30. package/examples/eyelang/bmi.pl +0 -232
  31. package/examples/eyelang/braking-safety-worlds.pl +0 -69
  32. package/examples/eyelang/buck-converter-design.pl +0 -78
  33. package/examples/eyelang/cache-performance.pl +0 -54
  34. package/examples/eyelang/canary-release.pl +0 -49
  35. package/examples/eyelang/cat-koko.pl +0 -24
  36. package/examples/eyelang/clinical-trial-screening.pl +0 -92
  37. package/examples/eyelang/combinatorics-findall-sort.pl +0 -37
  38. package/examples/eyelang/competitive-enzyme-kinetics.pl +0 -78
  39. package/examples/eyelang/complex.pl +0 -121
  40. package/examples/eyelang/composition-of-injective-functions-is-injective.pl +0 -50
  41. package/examples/eyelang/context-association.pl +0 -53
  42. package/examples/eyelang/context-schema-audit.pl +0 -46
  43. package/examples/eyelang/control-system.pl +0 -72
  44. package/examples/eyelang/cyclic-path.pl +0 -16
  45. package/examples/eyelang/d3-group.pl +0 -100
  46. package/examples/eyelang/dairy-energy-balance.pl +0 -65
  47. package/examples/eyelang/data-negotiation.pl +0 -39
  48. package/examples/eyelang/deep-taxonomy-10.pl +0 -115
  49. package/examples/eyelang/deep-taxonomy-100.pl +0 -385
  50. package/examples/eyelang/deep-taxonomy-1000.pl +0 -3085
  51. package/examples/eyelang/deep-taxonomy-10000.pl +0 -30094
  52. package/examples/eyelang/deep-taxonomy-100000.pl +0 -300184
  53. package/examples/eyelang/delfour.pl +0 -281
  54. package/examples/eyelang/deontic-logic.pl +0 -52
  55. package/examples/eyelang/derived-backward-rule.pl +0 -30
  56. package/examples/eyelang/derived-rule.pl +0 -27
  57. package/examples/eyelang/diamond-property.pl +0 -38
  58. package/examples/eyelang/dijkstra-findall-sort.pl +0 -44
  59. package/examples/eyelang/dijkstra-risk-path.pl +0 -86
  60. package/examples/eyelang/dijkstra.pl +0 -46
  61. package/examples/eyelang/dining-philosophers.pl +0 -140
  62. package/examples/eyelang/dog.pl +0 -25
  63. package/examples/eyelang/dpv-odrl-purpose-mapping.pl +0 -46
  64. package/examples/eyelang/drone-corridor-planner.pl +0 -51
  65. package/examples/eyelang/easter-computus.pl +0 -89
  66. package/examples/eyelang/electrical-rc-filter.pl +0 -36
  67. package/examples/eyelang/epidemic-policy.pl +0 -67
  68. package/examples/eyelang/equivalence-classes-overlap-implies-same-class.pl +0 -27
  69. package/examples/eyelang/eulerian-path.pl +0 -85
  70. package/examples/eyelang/ev-range-worlds.pl +0 -82
  71. package/examples/eyelang/existential-rule.pl +0 -18
  72. package/examples/eyelang/exoplanet-validation-worlds.pl +0 -88
  73. package/examples/eyelang/expression-eval.pl +0 -43
  74. package/examples/eyelang/family-cousins.pl +0 -65
  75. package/examples/eyelang/fastpow.pl +0 -53
  76. package/examples/eyelang/fft8-numeric.pl +0 -83
  77. package/examples/eyelang/fibonacci.pl +0 -53
  78. package/examples/eyelang/field-nitrogen-balance.pl +0 -70
  79. package/examples/eyelang/flandor.pl +0 -296
  80. package/examples/eyelang/floating-point.pl +0 -23
  81. package/examples/eyelang/four-color-map.pl +0 -127
  82. package/examples/eyelang/fundamental-theorem-arithmetic.pl +0 -113
  83. package/examples/eyelang/gd-step-certified.pl +0 -158
  84. package/examples/eyelang/gdpr-compliance.pl +0 -69
  85. package/examples/eyelang/good-cobbler.pl +0 -14
  86. package/examples/eyelang/gps.pl +0 -152
  87. package/examples/eyelang/graph-reachability.pl +0 -36
  88. package/examples/eyelang/gray-code-counter.pl +0 -48
  89. package/examples/eyelang/greatest-lower-bound-uniqueness.pl +0 -28
  90. package/examples/eyelang/group-inverse-uniqueness.pl +0 -34
  91. package/examples/eyelang/hamiltonian-path.pl +0 -49
  92. package/examples/eyelang/hamming-code.pl +0 -105
  93. package/examples/eyelang/hanoi.pl +0 -20
  94. package/examples/eyelang/heat-loss.pl +0 -51
  95. package/examples/eyelang/heron-theorem.pl +0 -36
  96. package/examples/eyelang/ideal-gas-law.pl +0 -37
  97. package/examples/eyelang/illegitimate-reasoning.pl +0 -88
  98. package/examples/eyelang/knowledge-engineering-alignment-flow.pl +0 -40
  99. package/examples/eyelang/law-of-cosines.pl +0 -31
  100. package/examples/eyelang/least-squares-regression.pl +0 -81
  101. package/examples/eyelang/list-collection.pl +0 -33
  102. package/examples/eyelang/lldm.pl +0 -78
  103. package/examples/eyelang/manufacturing-quality-control.pl +0 -73
  104. package/examples/eyelang/microgrid-dispatch.pl +0 -85
  105. package/examples/eyelang/monkey-bananas.pl +0 -45
  106. package/examples/eyelang/network-sla.pl +0 -48
  107. package/examples/eyelang/newton-raphson.pl +0 -49
  108. package/examples/eyelang/nixon-diamond.pl +0 -37
  109. package/examples/eyelang/observability-log-correlation.pl +0 -34
  110. package/examples/eyelang/odrl-dpv-fpv-trust-flow.pl +0 -43
  111. package/examples/eyelang/odrl-dpv-healthcare-risk-ranked.pl +0 -266
  112. package/examples/eyelang/odrl-dpv-risk-ranked.pl +0 -320
  113. package/examples/eyelang/orbital-transfer-design.pl +0 -113
  114. package/examples/eyelang/output/access-control-policy.pl +0 -2
  115. package/examples/eyelang/output/ackermann.pl +0 -12
  116. package/examples/eyelang/output/age.pl +0 -2
  117. package/examples/eyelang/output/aliases-and-namespaces.pl +0 -5
  118. package/examples/eyelang/output/alignment-demo.pl +0 -32
  119. package/examples/eyelang/output/allen-interval-calculus.pl +0 -154
  120. package/examples/eyelang/output/ancestor.pl +0 -6
  121. package/examples/eyelang/output/animal.pl +0 -4
  122. package/examples/eyelang/output/annotation.pl +0 -4
  123. package/examples/eyelang/output/auroracare.pl +0 -117
  124. package/examples/eyelang/output/backward.pl +0 -1
  125. package/examples/eyelang/output/basic-monadic.pl +0 -1518
  126. package/examples/eyelang/output/bayes-diagnosis.pl +0 -13
  127. package/examples/eyelang/output/bayes-therapy.pl +0 -23
  128. package/examples/eyelang/output/beam-deflection.pl +0 -5
  129. package/examples/eyelang/output/blocks-world-planning.pl +0 -4
  130. package/examples/eyelang/output/bmi.pl +0 -32
  131. package/examples/eyelang/output/braking-safety-worlds.pl +0 -18
  132. package/examples/eyelang/output/buck-converter-design.pl +0 -6
  133. package/examples/eyelang/output/cache-performance.pl +0 -4
  134. package/examples/eyelang/output/canary-release.pl +0 -5
  135. package/examples/eyelang/output/cat-koko.pl +0 -3
  136. package/examples/eyelang/output/clinical-trial-screening.pl +0 -9
  137. package/examples/eyelang/output/combinatorics-findall-sort.pl +0 -2
  138. package/examples/eyelang/output/competitive-enzyme-kinetics.pl +0 -6
  139. package/examples/eyelang/output/complex.pl +0 -1
  140. package/examples/eyelang/output/composition-of-injective-functions-is-injective.pl +0 -2
  141. package/examples/eyelang/output/context-association.pl +0 -3
  142. package/examples/eyelang/output/context-schema-audit.pl +0 -12
  143. package/examples/eyelang/output/control-system.pl +0 -6
  144. package/examples/eyelang/output/cyclic-path.pl +0 -16
  145. package/examples/eyelang/output/d3-group.pl +0 -2
  146. package/examples/eyelang/output/dairy-energy-balance.pl +0 -13
  147. package/examples/eyelang/output/data-negotiation.pl +0 -1
  148. package/examples/eyelang/output/deep-taxonomy-10.pl +0 -16
  149. package/examples/eyelang/output/deep-taxonomy-100.pl +0 -16
  150. package/examples/eyelang/output/deep-taxonomy-1000.pl +0 -16
  151. package/examples/eyelang/output/deep-taxonomy-10000.pl +0 -16
  152. package/examples/eyelang/output/deep-taxonomy-100000.pl +0 -16
  153. package/examples/eyelang/output/delfour.pl +0 -31
  154. package/examples/eyelang/output/deontic-logic.pl +0 -4
  155. package/examples/eyelang/output/derived-backward-rule.pl +0 -3
  156. package/examples/eyelang/output/derived-rule.pl +0 -2
  157. package/examples/eyelang/output/diamond-property.pl +0 -4
  158. package/examples/eyelang/output/dijkstra-findall-sort.pl +0 -2
  159. package/examples/eyelang/output/dijkstra-risk-path.pl +0 -29
  160. package/examples/eyelang/output/dijkstra.pl +0 -16
  161. package/examples/eyelang/output/dining-philosophers.pl +0 -350
  162. package/examples/eyelang/output/dog.pl +0 -1
  163. package/examples/eyelang/output/dpv-odrl-purpose-mapping.pl +0 -18
  164. package/examples/eyelang/output/drone-corridor-planner.pl +0 -17
  165. package/examples/eyelang/output/easter-computus.pl +0 -30
  166. package/examples/eyelang/output/electrical-rc-filter.pl +0 -3
  167. package/examples/eyelang/output/epidemic-policy.pl +0 -14
  168. package/examples/eyelang/output/equivalence-classes-overlap-implies-same-class.pl +0 -18
  169. package/examples/eyelang/output/eulerian-path.pl +0 -3
  170. package/examples/eyelang/output/ev-range-worlds.pl +0 -19
  171. package/examples/eyelang/output/existential-rule.pl +0 -2
  172. package/examples/eyelang/output/exoplanet-validation-worlds.pl +0 -22
  173. package/examples/eyelang/output/expression-eval.pl +0 -1
  174. package/examples/eyelang/output/family-cousins.pl +0 -28
  175. package/examples/eyelang/output/fastpow.pl +0 -6
  176. package/examples/eyelang/output/fft8-numeric.pl +0 -4
  177. package/examples/eyelang/output/fibonacci.pl +0 -6
  178. package/examples/eyelang/output/field-nitrogen-balance.pl +0 -21
  179. package/examples/eyelang/output/flandor.pl +0 -43
  180. package/examples/eyelang/output/floating-point.pl +0 -9
  181. package/examples/eyelang/output/four-color-map.pl +0 -3
  182. package/examples/eyelang/output/fundamental-theorem-arithmetic.pl +0 -9
  183. package/examples/eyelang/output/gd-step-certified.pl +0 -79
  184. package/examples/eyelang/output/gdpr-compliance.pl +0 -6
  185. package/examples/eyelang/output/good-cobbler.pl +0 -1
  186. package/examples/eyelang/output/gps.pl +0 -21
  187. package/examples/eyelang/output/graph-reachability.pl +0 -3
  188. package/examples/eyelang/output/gray-code-counter.pl +0 -1
  189. package/examples/eyelang/output/greatest-lower-bound-uniqueness.pl +0 -2
  190. package/examples/eyelang/output/group-inverse-uniqueness.pl +0 -2
  191. package/examples/eyelang/output/hamiltonian-path.pl +0 -121
  192. package/examples/eyelang/output/hamming-code.pl +0 -6
  193. package/examples/eyelang/output/hanoi.pl +0 -1
  194. package/examples/eyelang/output/heat-loss.pl +0 -5
  195. package/examples/eyelang/output/heron-theorem.pl +0 -4
  196. package/examples/eyelang/output/ideal-gas-law.pl +0 -3
  197. package/examples/eyelang/output/illegitimate-reasoning.pl +0 -15
  198. package/examples/eyelang/output/knowledge-engineering-alignment-flow.pl +0 -17
  199. package/examples/eyelang/output/law-of-cosines.pl +0 -3
  200. package/examples/eyelang/output/least-squares-regression.pl +0 -5
  201. package/examples/eyelang/output/list-collection.pl +0 -3
  202. package/examples/eyelang/output/lldm.pl +0 -6
  203. package/examples/eyelang/output/manufacturing-quality-control.pl +0 -6
  204. package/examples/eyelang/output/microgrid-dispatch.pl +0 -6
  205. package/examples/eyelang/output/monkey-bananas.pl +0 -5
  206. package/examples/eyelang/output/network-sla.pl +0 -4
  207. package/examples/eyelang/output/newton-raphson.pl +0 -3
  208. package/examples/eyelang/output/nixon-diamond.pl +0 -5
  209. package/examples/eyelang/output/observability-log-correlation.pl +0 -28
  210. package/examples/eyelang/output/odrl-dpv-fpv-trust-flow.pl +0 -9
  211. package/examples/eyelang/output/odrl-dpv-healthcare-risk-ranked.pl +0 -42
  212. package/examples/eyelang/output/odrl-dpv-risk-ranked.pl +0 -120
  213. package/examples/eyelang/output/orbital-transfer-design.pl +0 -7
  214. package/examples/eyelang/output/path-discovery.pl +0 -3
  215. package/examples/eyelang/output/peano-arithmetic.pl +0 -3
  216. package/examples/eyelang/output/peasant.pl +0 -10
  217. package/examples/eyelang/output/pendulum-period.pl +0 -4
  218. package/examples/eyelang/output/polynomial.pl +0 -14
  219. package/examples/eyelang/output/proof-contrapositive.pl +0 -3
  220. package/examples/eyelang/output/quadratic-formula.pl +0 -6
  221. package/examples/eyelang/output/radioactive-decay.pl +0 -5
  222. package/examples/eyelang/output/reusable-builtins.pl +0 -5
  223. package/examples/eyelang/output/riemann-hypothesis.pl +0 -12
  224. package/examples/eyelang/output/security-incident-correlation.pl +0 -3
  225. package/examples/eyelang/output/service-impact.pl +0 -11
  226. package/examples/eyelang/output/sieve.pl +0 -1
  227. package/examples/eyelang/output/skolem-functions.pl +0 -16
  228. package/examples/eyelang/output/socket-age.pl +0 -1
  229. package/examples/eyelang/output/socket-family.pl +0 -3
  230. package/examples/eyelang/output/socrates.pl +0 -2
  231. package/examples/eyelang/output/statistics-summary.pl +0 -4
  232. package/examples/eyelang/output/superdense-coding.pl +0 -6
  233. package/examples/eyelang/output/term-tools.pl +0 -6
  234. package/examples/eyelang/output/trust-flow-provenance-threshold.pl +0 -6
  235. package/examples/eyelang/output/turing.pl +0 -12
  236. package/examples/eyelang/output/vector-similarity.pl +0 -4
  237. package/examples/eyelang/output/vulnerability-impact.pl +0 -20
  238. package/examples/eyelang/output/witch.pl +0 -7
  239. package/examples/eyelang/output/wolf-goat-cabbage.pl +0 -3
  240. package/examples/eyelang/output/zebra.pl +0 -3
  241. package/examples/eyelang/path-discovery.pl +0 -45013
  242. package/examples/eyelang/peano-arithmetic.pl +0 -31
  243. package/examples/eyelang/peasant.pl +0 -30
  244. package/examples/eyelang/pendulum-period.pl +0 -50
  245. package/examples/eyelang/polynomial.pl +0 -124
  246. package/examples/eyelang/proof/age.pl +0 -71
  247. package/examples/eyelang/proof/aliases-and-namespaces.pl +0 -78
  248. package/examples/eyelang/proof/ancestor.pl +0 -140
  249. package/examples/eyelang/proof/animal.pl +0 -68
  250. package/examples/eyelang/proof/annotation.pl +0 -80
  251. package/examples/eyelang/proof/backward.pl +0 -22
  252. package/examples/eyelang/proof/cat-koko.pl +0 -86
  253. package/examples/eyelang/proof/data-negotiation.pl +0 -76
  254. package/examples/eyelang/proof/derived-rule.pl +0 -43
  255. package/examples/eyelang/proof/dog.pl +0 -31
  256. package/examples/eyelang/proof/electrical-rc-filter.pl +0 -105
  257. package/examples/eyelang/proof/existential-rule.pl +0 -40
  258. package/examples/eyelang/proof/floating-point.pl +0 -160
  259. package/examples/eyelang/proof/good-cobbler.pl +0 -16
  260. package/examples/eyelang/proof/group-inverse-uniqueness.pl +0 -84
  261. package/examples/eyelang/proof/list-collection.pl +0 -52
  262. package/examples/eyelang/proof/proof-contrapositive.pl +0 -78
  263. package/examples/eyelang/proof/socket-age.pl +0 -32
  264. package/examples/eyelang/proof/socket-family.pl +0 -59
  265. package/examples/eyelang/proof/socrates.pl +0 -38
  266. package/examples/eyelang/proof-contrapositive.pl +0 -27
  267. package/examples/eyelang/quadratic-formula.pl +0 -54
  268. package/examples/eyelang/radioactive-decay.pl +0 -56
  269. package/examples/eyelang/reusable-builtins.pl +0 -32
  270. package/examples/eyelang/riemann-hypothesis.pl +0 -110
  271. package/examples/eyelang/security-incident-correlation.pl +0 -69
  272. package/examples/eyelang/service-impact.pl +0 -41
  273. package/examples/eyelang/sieve.pl +0 -20
  274. package/examples/eyelang/skolem-functions.pl +0 -52
  275. package/examples/eyelang/socket-age.pl +0 -39
  276. package/examples/eyelang/socket-family.pl +0 -28
  277. package/examples/eyelang/socrates.pl +0 -19
  278. package/examples/eyelang/statistics-summary.pl +0 -54
  279. package/examples/eyelang/superdense-coding.pl +0 -84
  280. package/examples/eyelang/term-tools.pl +0 -23
  281. package/examples/eyelang/trust-flow-provenance-threshold.pl +0 -40
  282. package/examples/eyelang/turing.pl +0 -67
  283. package/examples/eyelang/vector-similarity.pl +0 -56
  284. package/examples/eyelang/vulnerability-impact.pl +0 -70
  285. package/examples/eyelang/witch.pl +0 -38
  286. package/examples/eyelang/wolf-goat-cabbage.pl +0 -56
  287. package/examples/eyelang/zebra.pl +0 -44
  288. package/eyelang.d.ts +0 -80
  289. package/lib/eyelang/bin.js +0 -7
  290. package/lib/eyelang/builtins/aggregation.js +0 -81
  291. package/lib/eyelang/builtins/arithmetic.js +0 -208
  292. package/lib/eyelang/builtins/context.js +0 -42
  293. package/lib/eyelang/builtins/control.js +0 -34
  294. package/lib/eyelang/builtins/core.js +0 -78
  295. package/lib/eyelang/builtins/lists.js +0 -283
  296. package/lib/eyelang/builtins/registry.js +0 -48
  297. package/lib/eyelang/builtins/strings.js +0 -234
  298. package/lib/eyelang/builtins/terms.js +0 -66
  299. package/lib/eyelang/cli.js +0 -180
  300. package/lib/eyelang/explain.js +0 -324
  301. package/lib/eyelang/hash.js +0 -294
  302. package/lib/eyelang/index.js +0 -47
  303. package/lib/eyelang/package.json +0 -3
  304. package/lib/eyelang/parser.js +0 -428
  305. package/lib/eyelang/program.js +0 -237
  306. package/lib/eyelang/solver.js +0 -237
  307. package/lib/eyelang/term.js +0 -328
@@ -1,39 +0,0 @@
1
- % socket-age.pl
2
- %
3
- % A small runnable eyelang Socket example for age reasoning.
4
- %
5
- % The socket facts are ordinary eyelang data. They document the semantic
6
- % openings that this rule module expects:
7
- %
8
- % - a patient registry that provides birthDay/2
9
- % - a policy source that provides duration/2
10
- % - a clock source that provides today/1
11
- %
12
- % The plug facts say which concrete providers are connected.
13
- %
14
- % Run:
15
- % eyelang socket-age.pl
16
-
17
- % Output declarations: materialize/2 selects the relations written to this example's golden output.
18
- materialize(ageAbove, 2).
19
-
20
- % Program structure: facts set up the scenario, and rules derive the materialized conclusions.
21
- socket(patient_registry, provides(birthDay_2)).
22
- socket(policy_source, provides(duration_2)).
23
- socket(clock_source, provides(today_1)).
24
-
25
- plug(test_patients, patient_registry).
26
- plug(test_policy, policy_source).
27
- plug(test_clock, clock_source).
28
-
29
- birthDay(patH, "1944-08-21").
30
- duration(check, "P80Y").
31
- today("2026-05-30").
32
-
33
- % Derivation rules: each rule below contributes one logical step toward the displayed results.
34
- ageAbove(S, A) :-
35
- birthDay(S, B),
36
- duration(check, A),
37
- today(D),
38
- difference(D, B, F),
39
- gt(F, A).
@@ -1,28 +0,0 @@
1
- % socket-family.pl
2
- %
3
- % A small runnable eyelang Socket example.
4
- %
5
- % The socket facts below are ordinary eyelang data. They document the
6
- % semantic opening: this reasoning module expects a provider for parent/2.
7
- % The plug fact says which provider is connected.
8
- %
9
- % Run:
10
- % eyelang socket-family.pl
11
-
12
- % Output declarations: materialize/2 selects the relations written to this example's golden output.
13
- materialize(ancestor, 2).
14
-
15
- % Program structure: facts set up the scenario, and rules derive the materialized conclusions.
16
- socket(family_source, provides(parent_2)).
17
- plug(family_file, family_source).
18
-
19
- parent(pat, jan).
20
- parent(jan, emma).
21
-
22
- % Derivation rules: each rule below contributes one logical step toward the displayed results.
23
- ancestor(X, Y) :-
24
- parent(X, Y).
25
-
26
- ancestor(X, Z) :-
27
- parent(X, Y),
28
- ancestor(Y, Z).
@@ -1,19 +0,0 @@
1
- % Socrates is mortal, adapted from Eyelet's input/socrates.pl.
2
- %
3
- % Eyelet uses type('Socrates', 'Man') and a single rule deriving Mortal.
4
- % eyelang keeps the same reasoning shape and emits relation facts.
5
-
6
- % Output declarations: materialize/2 selects the relations written to this example's golden output.
7
- materialize(type, 2).
8
- materialize(is, 2).
9
-
10
- % Program structure: facts set up the scenario, and rules derive the materialized conclusions.
11
- type(socrates, man).
12
-
13
- % Derivation rules: each rule below contributes one logical step toward the displayed results.
14
- type(X, mortal) :-
15
- type(X, man).
16
-
17
-
18
- is(test, true) :-
19
- type(socrates, mortal).
@@ -1,54 +0,0 @@
1
- % Population statistics for a small numeric sample.
2
- %
3
- % The sample is the textbook data set [2,4,4,4,5,5,7,9], whose population
4
- % mean is 5, variance is 4, and standard deviation is 2.
5
-
6
- % Output declarations: materialize/2 selects the relations written to this example's golden output.
7
- materialize(count, 2).
8
- materialize(mean, 2).
9
- materialize(populationVariance, 2).
10
- materialize(populationStddev, 2).
11
-
12
- % Program structure: facts set up the scenario, and rules derive the materialized conclusions.
13
- sample(scores, [2.0, 4.0, 4.0, 4.0, 5.0, 5.0, 7.0, 9.0]).
14
-
15
- sum([], 0.0).
16
- % Derivation rules: each rule below contributes one logical step toward the displayed results.
17
- sum([X|Xs], Total) :-
18
- sum(Xs, Rest),
19
- add(X, Rest, Total).
20
-
21
- mean(Name, Mean) :-
22
- sample(Name, Values),
23
- sum(Values, Total),
24
- length(Values, Count),
25
- div(Total, Count, Mean).
26
-
27
- squared_error_sum([], _Mean, 0.0).
28
- squared_error_sum([X|Xs], Mean, Total) :-
29
- sub(X, Mean, Delta),
30
- pow(Delta, 2.0, Squared),
31
- squared_error_sum(Xs, Mean, Rest),
32
- add(Squared, Rest, Total).
33
-
34
- population_variance(Name, Variance) :-
35
- sample(Name, Values),
36
- mean(Name, Mean),
37
- squared_error_sum(Values, Mean, SumSquaredErrors),
38
- length(Values, Count),
39
- div(SumSquaredErrors, Count, Variance).
40
-
41
- population_stddev(Name, Stddev) :-
42
- population_variance(Name, Variance),
43
- pow(Variance, 0.5, Stddev).
44
-
45
- count(Name, Count) :-
46
- sample(Name, Values),
47
- length(Values, Count).
48
-
49
-
50
- populationVariance(Name, Variance) :-
51
- population_variance(Name, Variance).
52
-
53
- populationStddev(Name, Stddev) :-
54
- population_stddev(Name, Stddev).
@@ -1,84 +0,0 @@
1
- % Superdense coding using discrete quantum computing, adapted from
2
- % Eyelet's input/superdense-coding.pl.
3
- %
4
- % The Eyelet program toggles dynamic sdcoding/2 facts so answers appearing an
5
- % even number of times cancel. eyelang expresses the same finite example
6
- % declaratively: for this protocol the surviving messages are exactly those
7
- % with a single support path after the interference choices are expanded.
8
-
9
- % |R) = |0, 0) + |1, 1)
10
- % Output declarations: materialize/2 selects the relations written to this example's golden output.
11
- materialize(decodesAs, 2).
12
- materialize(preservesMessage, 2).
13
- materialize(cancelsCrossTalk, 2).
14
-
15
- % Program structure: facts set up the scenario, and rules derive the materialized conclusions.
16
- r(false, false).
17
- r(true, true).
18
-
19
- % ID |0) = |0), ID |1) = |1)
20
- identity(false, false).
21
- identity(true, true).
22
-
23
- % G |0) = |1), G |1) = |0)
24
- g(false, true).
25
- g(true, false).
26
-
27
- % K |0) = |0), K |1) = |0) + |1)
28
- k(false, false).
29
- k(true, false).
30
- k(true, true).
31
-
32
- % KG and GK compositions.
33
- % Derivation rules: each rule below contributes one logical step toward the displayed results.
34
- kg(X, Y) :-
35
- g(X, Z),
36
- k(Z, Y).
37
-
38
- gk(X, Y) :-
39
- k(X, Z),
40
- g(Z, Y).
41
-
42
- % Alice encodes two classical bits as one of four transformations.
43
- alice(0, X, Y) :- identity(X, Y).
44
- alice(1, X, Y) :- g(X, Y).
45
- alice(2, X, Y) :- k(X, Y).
46
- alice(3, X, Y) :- kg(X, Y).
47
-
48
- % Bob decodes with the Bell-style measurement basis.
49
- bob(X, Y, 0) :- gk(X, Y).
50
- bob(X, Y, 1) :- k(X, Y).
51
- bob(X, Y, 2) :- g(X, Y).
52
- bob(X, Y, 3) :- identity(X, Y).
53
-
54
- % One concrete support path through the entangled pair and the two transforms.
55
- sdc_path(N, M, path(X, Y, B)) :-
56
- r(X, Y),
57
- alice(N, X, B),
58
- bob(B, Y, M).
59
-
60
- % If another different support path gives the same answer, this answer cancels
61
- % in pairs in the finite superdense-coding table.
62
- duplicate_sdc_path(N, M, Proof) :-
63
- sdc_path(N, M, Proof),
64
- sdc_path(N, M, Other),
65
- neq(Proof, Other).
66
-
67
- sdcoding(N, M) :-
68
- sdc_path(N, M, Proof),
69
- not(duplicate_sdc_path(N, M, Proof)).
70
-
71
- decodesAs(message(N), M) :-
72
- sdcoding(N, M).
73
-
74
- preservesMessage(protocol, true) :-
75
- sdcoding(0, 0),
76
- sdcoding(1, 1),
77
- sdcoding(2, 2),
78
- sdcoding(3, 3).
79
-
80
- cancelsCrossTalk(protocol, true) :-
81
- not(sdcoding(0, 1)),
82
- not(sdcoding(1, 0)),
83
- not(sdcoding(2, 3)),
84
- not(sdcoding(3, 2)).
@@ -1,23 +0,0 @@
1
- % Term tools: inspect and build structured terms, then validate all facts with forall/2.
2
- materialize(report, 2).
3
-
4
- edge(a, b, 3).
5
- edge(b, c, 4).
6
-
7
- report(shape, shape(Name, Arity)) :-
8
- functor(edge(a, b, 3), Name, Arity).
9
-
10
- report(second_argument, Node) :-
11
- arg(2, edge(a, b, 3), Node).
12
-
13
- report(parts, parts(Name, Args)) :-
14
- compound_name_arguments(edge(a, b, 3), Name, Args).
15
-
16
- report(rebuilt, Term) :-
17
- compound_name_arguments(Term, edge, [c, d, 5]).
18
-
19
- report(rendered, Text) :-
20
- term_string(edge(a, [b, c]), Text).
21
-
22
- report(all_weights_positive, yes) :-
23
- forall(edge(_From, _To, Weight), gt(Weight, 0)).
@@ -1,40 +0,0 @@
1
- % Provenance-derived trust-flow thresholding in eyelang.
2
-
3
- materialize(confidence, 2).
4
- materialize(trust_flow_state, 2).
5
- materialize(status, 2).
6
- materialize(risk, 2).
7
-
8
- message(message_a, publisher_a, transform_a, signature_a, receiver_app).
9
- message(message_b, publisher_b, transform_b, signature_b, receiver_app).
10
-
11
- publisher_trust(publisher_a, 0.95).
12
- publisher_trust(publisher_b, 0.70).
13
- signature_strength(signature_a, 0.98).
14
- signature_strength(signature_b, 0.75).
15
- quality_score(transform_a, 0.96).
16
- quality_score(transform_b, 0.80).
17
- acceptance_threshold(receiver_app, 0.85).
18
-
19
- confidence(Message, Confidence) :-
20
- message(Message, Publisher, Transform, Signature, _Receiver),
21
- publisher_trust(Publisher, PublisherTrust),
22
- signature_strength(Signature, SignatureTrust),
23
- quality_score(Transform, Quality),
24
- mul(PublisherTrust, SignatureTrust, A),
25
- mul(A, Quality, Confidence).
26
-
27
- trust_flow_state(Message, fpv_accepted) :-
28
- message(Message, _Publisher, _Transform, _Signature, Receiver),
29
- confidence(Message, Confidence),
30
- acceptance_threshold(Receiver, Threshold),
31
- ge(Confidence, Threshold).
32
-
33
- trust_flow_state(Message, fpv_quarantine) :-
34
- message(Message, _Publisher, _Transform, _Signature, Receiver),
35
- confidence(Message, Confidence),
36
- acceptance_threshold(Receiver, Threshold),
37
- lt(Confidence, Threshold).
38
-
39
- status(Message, fpv_high_trust_flow) :- trust_flow_state(Message, fpv_accepted).
40
- risk(Message, risk_low_trust_data_source) :- trust_flow_state(Message, fpv_quarantine).
@@ -1,67 +0,0 @@
1
- % Universal Turing machine example adapted from Eyelet's input/turing.pl.
2
- %
3
- % The machine below adds 1 to a binary number represented as a list of bits.
4
- % The blank tape symbol is #.
5
-
6
- % Output declarations: materialize/2 selects the relations written to this example's golden output.
7
- materialize(input, 2).
8
- materialize(output, 2).
9
- materialize(addsOne, 2).
10
-
11
- % Program structure: facts set up the scenario, and rules derive the materialized conclusions.
12
- % Derivation rules: each rule below contributes one logical step toward the displayed results.
13
- compute([], OutTape) :-
14
- start(_Machine, I),
15
- find(I, [], #, [], OutTape).
16
-
17
- compute([Head|Tail], OutTape) :-
18
- start(_Machine, I),
19
- find(I, [], Head, Tail, OutTape).
20
-
21
- find(State, Left, Cell, Right, OutTape) :-
22
- t([State, Cell, Write, Move], Next),
23
- move(Move, Left, Write, Right, A, B, C),
24
- continue(Next, A, B, C, OutTape).
25
-
26
- continue(halt, Left, Cell, Right, OutTape) :-
27
- rever(Left, R),
28
- append(R, [Cell|Right], OutTape).
29
-
30
- continue(State, Left, Cell, Right, OutTape) :-
31
- find(State, Left, Cell, Right, OutTape).
32
-
33
- move(l, [], Cell, Right, [], #, [Cell|Right]).
34
- move(l, [Head|Tail], Cell, Right, Tail, Head, [Cell|Right]).
35
- move(s, Left, Cell, Right, Left, Cell, Right).
36
- move(r, Left, Cell, [], [Cell|Left], #, []).
37
- move(r, Left, Cell, [Head|Tail], [Cell|Left], Head, Tail).
38
-
39
- rever([], []).
40
- rever([A|B], C) :-
41
- rever(B, D),
42
- append(D, [A], C).
43
-
44
- % A Turing machine to add 1 to a binary number.
45
- start(add1, 0).
46
- t([0, 0, 0, r], 0).
47
- t([0, 1, 1, r], 0).
48
- t([0, #, #, l], 1).
49
- t([1, 0, 1, s], halt).
50
- t([1, 1, 0, l], 1).
51
- t([1, #, 1, s], halt).
52
-
53
- case(case1, [1, 0, 1, 0, 0, 1]).
54
- case(case2, [1, 0, 1, 1, 1, 1]).
55
- case(case3, [1, 1, 1, 1, 1, 1]).
56
- case(case4, []).
57
-
58
- input(Case, InTape) :-
59
- case(Case, InTape).
60
-
61
- output(Case, OutTape) :-
62
- case(Case, InTape),
63
- compute(InTape, OutTape).
64
-
65
- addsOne(Case, true) :-
66
- case(Case, InTape),
67
- compute(InTape, _OutTape).
@@ -1,56 +0,0 @@
1
- % Vector dot product, Euclidean norm, and cosine similarity.
2
-
3
- % Output declarations: materialize/2 selects the relations written to this example's golden output.
4
- materialize(dotProduct, 2).
5
- materialize(normA, 2).
6
- materialize(normB, 2).
7
- materialize(cosineSimilarity, 2).
8
-
9
- % Program structure: facts set up the scenario, and rules derive the materialized conclusions.
10
- % Two named vectors form the single cosine-similarity case.
11
- vector(pair1, a, [1.0, 2.0, 3.0]).
12
- vector(pair1, b, [4.0, -5.0, 6.0]).
13
-
14
- % Recursive list folds compute dot products and sums of squares.
15
- dot([], [], 0.0).
16
- % Derivation rules: each rule below contributes one logical step toward the displayed results.
17
- dot([A|As], [B|Bs], Dot) :-
18
- mul(A, B, Product),
19
- dot(As, Bs, Rest),
20
- add(Product, Rest, Dot).
21
-
22
- sum_squares([], 0.0).
23
- sum_squares([X|Xs], Total) :-
24
- pow(X, 2.0, Squared),
25
- sum_squares(Xs, Rest),
26
- add(Squared, Rest, Total).
27
-
28
- norm(Vector, Norm) :-
29
- sum_squares(Vector, SumSquares),
30
- pow(SumSquares, 0.5, Norm).
31
-
32
- % cosine = dot(A,B) / (norm(A) * norm(B)).
33
- cosine_similarity(Case, Similarity) :-
34
- vector(Case, a, A),
35
- vector(Case, b, B),
36
- dot(A, B, Dot),
37
- norm(A, NormA),
38
- norm(B, NormB),
39
- mul(NormA, NormB, Denominator),
40
- div(Dot, Denominator, Similarity).
41
-
42
- dotProduct(Case, Dot) :-
43
- vector(Case, a, A),
44
- vector(Case, b, B),
45
- dot(A, B, Dot).
46
-
47
- normA(Case, NormA) :-
48
- vector(Case, a, A),
49
- norm(A, NormA).
50
-
51
- normB(Case, NormB) :-
52
- vector(Case, b, B),
53
- norm(B, NormB).
54
-
55
- cosineSimilarity(Case, Similarity) :-
56
- cosine_similarity(Case, Similarity).
@@ -1,70 +0,0 @@
1
- % Vulnerability impact analysis over a transitive dependency graph.
2
- %
3
- % This mirrors examples/vulnerability-impact.n3 using eyelang rules.
4
-
5
- % Output declarations: materialize/2 selects the relations written to this example's golden output.
6
- materialize(uses, 2).
7
- materialize(impacted_by, 2).
8
- materialize(risk, 2).
9
- materialize(mitigate, 2).
10
- materialize(urgent_patch, 2).
11
-
12
- % Program structure: facts set up the scenario, and rules derive the materialized conclusions.
13
- service(webapp).
14
- service(worker).
15
- service(frontend).
16
-
17
- critical(webapp).
18
- critical(worker).
19
-
20
- depends_on(webapp, api).
21
- depends_on(worker, queue).
22
- depends_on(frontend, ui).
23
- depends_on(api, auth).
24
- depends_on(auth, openssl).
25
- depends_on(queue, openssl).
26
- depends_on(ui, css).
27
-
28
- vulnerability(openssl, cve_2026_0001).
29
- cvss(cve_2026_0001, 9.8).
30
- fixed_by(cve_2026_0001, openssl_3_0_14).
31
-
32
- vulnerability(css, cve_2026_0002).
33
- cvss(cve_2026_0002, 5.4).
34
- fixed_by(cve_2026_0002, css_2_1_1).
35
-
36
- % Derivation rules: each rule below contributes one logical step toward the displayed results.
37
- uses(Service, Dependency) :-
38
- service(Service),
39
- depends_on(Service, Dependency).
40
-
41
- uses(Service, Dependency) :-
42
- service(Service),
43
- depends_on(Service, Intermediate),
44
- depends_on(Intermediate, Dependency).
45
-
46
- uses(Service, Dependency) :-
47
- service(Service),
48
- depends_on(Service, Intermediate),
49
- depends_on(Intermediate, Next),
50
- depends_on(Next, Dependency).
51
-
52
- impacted_by(Service, Dependency) :-
53
- uses(Service, Dependency).
54
-
55
- exposed_to(Service, Vulnerability) :-
56
- uses(Service, Package),
57
- vulnerability(Package, Vulnerability),
58
- cvss(Vulnerability, Score),
59
- gt(Score, 7.0).
60
-
61
- risk(Service, high) :-
62
- exposed_to(Service, _Vulnerability).
63
-
64
- mitigate(Service, Vulnerability) :-
65
- exposed_to(Service, Vulnerability).
66
-
67
- urgent_patch(Service, Patch) :-
68
- critical(Service),
69
- exposed_to(Service, Vulnerability),
70
- fixed_by(Vulnerability, Patch).
@@ -1,38 +0,0 @@
1
- % Burn the witch, adapted from Eyeling's examples/witch.n3.
2
- %
3
- % This is the classic N3/Semantic Web rule chain in eyelang form: a duck
4
- % floats; something with the same weight as something that floats also floats;
5
- % things that float are made of wood; things made of wood burn; and a woman
6
- % who burns is a witch.
7
-
8
- % Output declarations: materialize/2 selects the relations written to this example's golden output.
9
- materialize(floats, 1).
10
- materialize(madeOfWood, 1).
11
- materialize(burns, 1).
12
- materialize(witch, 1).
13
- materialize(is, 2).
14
-
15
- % Program structure: facts set up the scenario, and rules derive the materialized conclusions.
16
- % Derivation rules: each rule below contributes one logical step toward the displayed results.
17
- witch(X) :-
18
- burns(X),
19
- woman(X).
20
-
21
- woman(girl).
22
-
23
- burns(X) :-
24
- madeOfWood(X).
25
-
26
- madeOfWood(X) :-
27
- floats(X).
28
-
29
- floats(duck).
30
-
31
- floats(Y) :-
32
- sameWeight(X, Y),
33
- floats(X).
34
-
35
- sameWeight(duck, girl).
36
-
37
- is(witchExample, true) :-
38
- witch(girl).
@@ -1,56 +0,0 @@
1
- % Wolf, goat and cabbage puzzle, adapted from Eyelet's
2
- % input/wolf-goat-cabbage.pl.
3
- %
4
- % A configuration is [man, wolf, goat, cabbage], where each item is on the west
5
- % bank w or east bank e. The recursive search keeps a visited list so eyelang
6
- % explores the finite state space without looping.
7
-
8
- % Output declarations: materialize/2 selects the relations written to this example's golden output.
9
- materialize(solution, 2).
10
- materialize(solved, 2).
11
-
12
- % Program structure: facts set up the scenario, and rules derive the materialized conclusions.
13
- memoize(solve, 4).
14
-
15
- % Derivation rules: each rule below contributes one logical step toward the displayed results.
16
- solution(Moves) :-
17
- solve([w, w, w, w], [e, e, e, e], [[w, w, w, w]], Moves),
18
- length(Moves, 7).
19
-
20
- solve(Config, Config, _Visited, []).
21
-
22
- solve(Config, Goal, Visited, [Move|Rest]) :-
23
- move(Config, Move, NextConfig),
24
- safe(NextConfig),
25
- not_member(NextConfig, Visited),
26
- solve(NextConfig, Goal, [NextConfig|Visited], Rest).
27
-
28
- % Each move transforms one configuration into another.
29
- move([X, X, Goat, Cabbage], wolf, [Y, Y, Goat, Cabbage]) :-
30
- change(X, Y).
31
-
32
- move([X, Wolf, X, Cabbage], goat, [Y, Wolf, Y, Cabbage]) :-
33
- change(X, Y).
34
-
35
- move([X, Wolf, Goat, X], cabbage, [Y, Wolf, Goat, Y]) :-
36
- change(X, Y).
37
-
38
- move([X, Wolf, Goat, Cabbage], nothing, [Y, Wolf, Goat, Cabbage]) :-
39
- change(X, Y).
40
-
41
- change(e, w).
42
- change(w, e).
43
-
44
- % Safe if the goat is not left alone with the wolf or cabbage without the man.
45
- safe([Man, Wolf, Goat, Cabbage]) :-
46
- one_eq(Man, Goat, Wolf),
47
- one_eq(Man, Goat, Cabbage).
48
-
49
- one_eq(X, X, _).
50
- one_eq(X, _, X).
51
-
52
- solution(puzzle, Moves) :-
53
- solution(Moves).
54
-
55
- solved(puzzle, true) :-
56
- solution(_Moves).
@@ -1,44 +0,0 @@
1
- % Zebra puzzle, adapted from Eyelet's input/zebra.pl.
2
- %
3
- % Five houses are represented as house(Color, Nationality, Pet, Beverage,
4
- % Cigarette). The answer is the classic one: the Norwegian drinks water and the
5
- % Japanese owns the zebra.
6
-
7
- % Output declarations: materialize/2 selects the relations written to this example's golden output.
8
- materialize(waterDrinker, 2).
9
- materialize(zebraOwner, 2).
10
- materialize(solved, 2).
11
-
12
- % Program structure: facts set up the scenario, and rules derive the materialized conclusions.
13
- % Derivation rules: each rule below contributes one logical step toward the displayed results.
14
- zebra(WaterDrinker, ZebraOwner) :-
15
- eq(Houses, [_, _, _, _, _]),
16
- first(Houses, house(_, norwegian, _, _, _)),
17
- third(Houses, house(_, _, _, milk, _)),
18
- adjacent(house(_, norwegian, _, _, _), house(blue, _, _, _, _), Houses),
19
- next_to(house(ivory, _, _, _, _), house(green, _, _, _, _), Houses),
20
- member(house(red, english, _, _, _), Houses),
21
- member(house(green, _, _, coffee, _), Houses),
22
- member(house(yellow, _, _, _, kools), Houses),
23
- member(house(_, spanish, dog, _, _), Houses),
24
- member(house(_, ukrainian, _, tea, _), Houses),
25
- member(house(_, _, snail, _, old_gold), Houses),
26
- adjacent(house(_, _, _, _, chesterfields), house(_, _, fox, _, _), Houses),
27
- adjacent(house(_, _, _, _, kools), house(_, _, horse, _, _), Houses),
28
- member(house(_, _, _, orange_juice, lucky_strike), Houses),
29
- member(house(_, japanese, _, _, parliaments), Houses),
30
- member(house(_, WaterDrinker, _, water, _), Houses),
31
- member(house(_, ZebraOwner, zebra, _, _), Houses).
32
-
33
- first([X|_], X).
34
- third([_, _, X|_], X).
35
-
36
- adjacent(A, B, List) :- next_to(A, B, List).
37
- adjacent(A, B, List) :- next_to(B, A, List).
38
-
39
- next_to(X, Y, [X, Y|_]).
40
- next_to(X, Y, [_|Zs]) :- next_to(X, Y, Zs).
41
-
42
- waterDrinker(zebraPuzzle, WaterDrinker) :- zebra(WaterDrinker, _ZebraOwner).
43
- zebraOwner(zebraPuzzle, ZebraOwner) :- zebra(_WaterDrinker, ZebraOwner).
44
- solved(zebraPuzzle, true) :- zebra(norwegian, japanese).