eyeling 1.32.1 → 1.33.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.
- package/README.md +87 -16
- package/bin/eyeling.cjs +56 -4
- package/dist/browser/eyeling.browser.js +2 -11
- package/examples/eyelang/INTEGRATION.md +13 -0
- package/examples/eyelang/README.md +628 -0
- package/examples/eyelang/SPEC.md +684 -0
- package/examples/eyelang/access-control-policy.pl +52 -0
- package/examples/eyelang/ackermann.pl +46 -0
- package/examples/eyelang/age.pl +28 -0
- package/examples/eyelang/aliases-and-namespaces.pl +22 -0
- package/examples/eyelang/alignment-demo.pl +44 -0
- package/examples/eyelang/allen-interval-calculus.pl +64 -0
- package/examples/eyelang/ancestor.pl +21 -0
- package/examples/eyelang/animal.pl +21 -0
- package/examples/eyelang/annotation-rdf12.ttl +12 -0
- package/examples/eyelang/annotation.pl +34 -0
- package/examples/eyelang/auroracare.pl +309 -0
- package/examples/eyelang/backward.pl +12 -0
- package/examples/eyelang/basic-monadic.pl +10018 -0
- package/examples/eyelang/bayes-diagnosis.pl +108 -0
- package/examples/eyelang/bayes-therapy.pl +182 -0
- package/examples/eyelang/beam-deflection.pl +50 -0
- package/examples/eyelang/blocks-world-planning.pl +75 -0
- package/examples/eyelang/bmi.pl +232 -0
- package/examples/eyelang/braking-safety-worlds.pl +69 -0
- package/examples/eyelang/buck-converter-design.pl +78 -0
- package/examples/eyelang/cache-performance.pl +54 -0
- package/examples/eyelang/canary-release.pl +49 -0
- package/examples/eyelang/cat-koko.pl +24 -0
- package/examples/eyelang/clinical-trial-screening.pl +92 -0
- package/examples/eyelang/collatz-1000.pl +14 -0
- package/examples/eyelang/combinatorics-findall-sort.pl +37 -0
- package/examples/eyelang/competitive-enzyme-kinetics.pl +78 -0
- package/examples/eyelang/complex-matrix-stability.pl +45 -0
- package/examples/eyelang/complex.pl +121 -0
- package/examples/eyelang/composition-of-injective-functions-is-injective.pl +50 -0
- package/examples/eyelang/context-association.pl +53 -0
- package/examples/eyelang/control-system.pl +72 -0
- package/examples/eyelang/cryptarithmetic-send-more-money.pl +49 -0
- package/examples/eyelang/cyclic-path.pl +16 -0
- package/examples/eyelang/d3-group.pl +100 -0
- package/examples/eyelang/dairy-energy-balance.pl +65 -0
- package/examples/eyelang/data-negotiation.pl +39 -0
- package/examples/eyelang/deep-taxonomy-10.pl +115 -0
- package/examples/eyelang/deep-taxonomy-100.pl +385 -0
- package/examples/eyelang/deep-taxonomy-1000.pl +3085 -0
- package/examples/eyelang/deep-taxonomy-10000.pl +30094 -0
- package/examples/eyelang/deep-taxonomy-100000.pl +300184 -0
- package/examples/eyelang/delfour.pl +281 -0
- package/examples/eyelang/dense-hamiltonian-cycle.pl +92 -0
- package/examples/eyelang/deontic-logic.pl +52 -0
- package/examples/eyelang/derived-backward-rule.pl +30 -0
- package/examples/eyelang/derived-rule.pl +27 -0
- package/examples/eyelang/diamond-property.pl +38 -0
- package/examples/eyelang/dijkstra-findall-sort.pl +44 -0
- package/examples/eyelang/dijkstra-risk-path.pl +86 -0
- package/examples/eyelang/dijkstra.pl +46 -0
- package/examples/eyelang/dining-philosophers.pl +140 -0
- package/examples/eyelang/directional-language.ttl +9 -0
- package/examples/eyelang/dog.pl +25 -0
- package/examples/eyelang/drone-corridor-planner.pl +51 -0
- package/examples/eyelang/easter-computus.pl +89 -0
- package/examples/eyelang/electrical-rc-filter.pl +36 -0
- package/examples/eyelang/epidemic-policy.pl +67 -0
- package/examples/eyelang/equivalence-classes-overlap-implies-same-class.pl +27 -0
- package/examples/eyelang/eulerian-path.pl +85 -0
- package/examples/eyelang/ev-range-worlds.pl +82 -0
- package/examples/eyelang/exact-cover-sudoku.pl +113 -0
- package/examples/eyelang/existential-rule.pl +18 -0
- package/examples/eyelang/exoplanet-validation-worlds.pl +88 -0
- package/examples/eyelang/expression-eval.pl +43 -0
- package/examples/eyelang/eyeling-ackermann.n3 +41 -0
- package/examples/eyelang/eyeling-age-threshold.n3 +12 -0
- package/examples/eyelang/eyeling-alignment-demo.n3 +11 -0
- package/examples/eyelang/eyeling-allen-interval-calculus-small.n3 +13 -0
- package/examples/eyelang/eyeling-backward-recursion.n3 +11 -0
- package/examples/eyelang/eyeling-backward.n3 +10 -0
- package/examples/eyelang/eyeling-basic-monadic-small.n3 +11 -0
- package/examples/eyelang/eyeling-bmi.n3 +10 -0
- package/examples/eyelang/eyeling-cat-koko.n3 +15 -0
- package/examples/eyelang/eyeling-collatz-small.n3 +11 -0
- package/examples/eyelang/eyeling-collection.n3 +11 -0
- package/examples/eyelang/eyeling-complex-arithmetic.n3 +10 -0
- package/examples/eyelang/eyeling-context-association.n3 +11 -0
- package/examples/eyelang/eyeling-control-system-small.n3 +11 -0
- package/examples/eyelang/eyeling-crypto-builtins-extra.n3 +10 -0
- package/examples/eyelang/eyeling-crypto-builtins.n3 +8 -0
- package/examples/eyelang/eyeling-deep-taxonomy-10.n3 +18 -0
- package/examples/eyelang/eyeling-derived-backward-rule-flat.n3 +10 -0
- package/examples/eyelang/eyeling-derived-rule-flat.n3 +9 -0
- package/examples/eyelang/eyeling-digital-product-passport-small.n3 +11 -0
- package/examples/eyelang/eyeling-dijkstra-tiny.n3 +14 -0
- package/examples/eyelang/eyeling-dog-license.n3 +13 -0
- package/examples/eyelang/eyeling-drone-corridor-planner-small.n3 +13 -0
- package/examples/eyelang/eyeling-equals.n3 +8 -0
- package/examples/eyelang/eyeling-equivalence-classes.n3 +11 -0
- package/examples/eyelang/eyeling-euler-identity.n3 +9 -0
- package/examples/eyelang/eyeling-existential-rule.n3 +9 -0
- package/examples/eyelang/eyeling-expression-eval.n3 +11 -0
- package/examples/eyelang/eyeling-family-cousins-extended.n3 +12 -0
- package/examples/eyelang/eyeling-fastpow.n3 +10 -0
- package/examples/eyelang/eyeling-fibonacci.n3 +44 -0
- package/examples/eyelang/eyeling-french-cities-reachability.n3 +22 -0
- package/examples/eyelang/eyeling-goldbach-small.n3 +22 -0
- package/examples/eyelang/eyeling-good-cobbler.n3 +9 -0
- package/examples/eyelang/eyeling-list-builtins.n3 +10 -0
- package/examples/eyelang/eyeling-list-collection-extra.n3 +9 -0
- package/examples/eyelang/eyeling-math-builtins.n3 +9 -0
- package/examples/eyelang/eyeling-string-builtins-extra.n3 +9 -0
- package/examples/eyelang/eyeling-string-builtins.n3 +10 -0
- package/examples/eyelang/eyeling-time-builtins.n3 +11 -0
- package/examples/eyelang/eyeling-time-components-extra.n3 +10 -0
- package/examples/eyelang/eyeling-witch.n3 +10 -0
- package/examples/eyelang/family-cousins.n3 +17 -0
- package/examples/eyelang/family-cousins.pl +65 -0
- package/examples/eyelang/fastpow.pl +53 -0
- package/examples/eyelang/fft8-numeric.pl +83 -0
- package/examples/eyelang/fibonacci.pl +53 -0
- package/examples/eyelang/field-nitrogen-balance.pl +70 -0
- package/examples/eyelang/flandor.pl +296 -0
- package/examples/eyelang/floating-point.pl +23 -0
- package/examples/eyelang/four-color-map.pl +127 -0
- package/examples/eyelang/fundamental-theorem-arithmetic.pl +113 -0
- package/examples/eyelang/gcd-bezout-identity.pl +48 -0
- package/examples/eyelang/gd-step-certified.pl +158 -0
- package/examples/eyelang/gdpr-compliance.pl +69 -0
- package/examples/eyelang/goldbach-1000.pl +185 -0
- package/examples/eyelang/good-cobbler.pl +14 -0
- package/examples/eyelang/gps.pl +152 -0
- package/examples/eyelang/graph-reachability.pl +36 -0
- package/examples/eyelang/gray-code-counter.pl +48 -0
- package/examples/eyelang/greatest-lower-bound-uniqueness.pl +28 -0
- package/examples/eyelang/group-inverse-uniqueness.pl +34 -0
- package/examples/eyelang/hamiltonian-cycle.pl +55 -0
- package/examples/eyelang/hamiltonian-path.pl +49 -0
- package/examples/eyelang/hamming-code.pl +105 -0
- package/examples/eyelang/hanoi.pl +20 -0
- package/examples/eyelang/heat-loss.pl +51 -0
- package/examples/eyelang/heron-theorem.pl +36 -0
- package/examples/eyelang/ideal-gas-law.pl +37 -0
- package/examples/eyelang/illegitimate-reasoning.pl +88 -0
- package/examples/eyelang/kaprekar.pl +32 -0
- package/examples/eyelang/law-of-cosines.pl +31 -0
- package/examples/eyelang/least-squares-regression.pl +81 -0
- package/examples/eyelang/list-collection.pl +33 -0
- package/examples/eyelang/lldm.pl +78 -0
- package/examples/eyelang/manufacturing-quality-control.pl +73 -0
- package/examples/eyelang/matrix.pl +296 -0
- package/examples/eyelang/microgrid-dispatch.pl +85 -0
- package/examples/eyelang/monkey-bananas.pl +45 -0
- package/examples/eyelang/n-queens.pl +23 -0
- package/examples/eyelang/n3-builtins.n3 +28 -0
- package/examples/eyelang/network-sla.pl +48 -0
- package/examples/eyelang/newton-raphson.pl +49 -0
- package/examples/eyelang/nixon-diamond.pl +37 -0
- package/examples/eyelang/odrl-dpv-healthcare-risk-ranked.pl +266 -0
- package/examples/eyelang/odrl-dpv-risk-ranked.pl +320 -0
- package/examples/eyelang/orbital-transfer-design.pl +113 -0
- package/examples/eyelang/output/access-control-policy.pl +2 -0
- package/examples/eyelang/output/ackermann.pl +12 -0
- package/examples/eyelang/output/age.pl +2 -0
- package/examples/eyelang/output/aliases-and-namespaces.pl +5 -0
- package/examples/eyelang/output/alignment-demo.pl +32 -0
- package/examples/eyelang/output/allen-interval-calculus.pl +154 -0
- package/examples/eyelang/output/ancestor.pl +6 -0
- package/examples/eyelang/output/animal.pl +4 -0
- package/examples/eyelang/output/annotation-rdf12.ttl +1 -0
- package/examples/eyelang/output/annotation.pl +4 -0
- package/examples/eyelang/output/auroracare.pl +117 -0
- package/examples/eyelang/output/backward.pl +1 -0
- package/examples/eyelang/output/basic-monadic.pl +1518 -0
- package/examples/eyelang/output/bayes-diagnosis.pl +13 -0
- package/examples/eyelang/output/bayes-therapy.pl +23 -0
- package/examples/eyelang/output/beam-deflection.pl +5 -0
- package/examples/eyelang/output/blocks-world-planning.pl +4 -0
- package/examples/eyelang/output/bmi.pl +32 -0
- package/examples/eyelang/output/braking-safety-worlds.pl +18 -0
- package/examples/eyelang/output/buck-converter-design.pl +6 -0
- package/examples/eyelang/output/cache-performance.pl +4 -0
- package/examples/eyelang/output/canary-release.pl +5 -0
- package/examples/eyelang/output/cat-koko.pl +3 -0
- package/examples/eyelang/output/clinical-trial-screening.pl +9 -0
- package/examples/eyelang/output/collatz-1000.pl +1000 -0
- package/examples/eyelang/output/combinatorics-findall-sort.pl +2 -0
- package/examples/eyelang/output/competitive-enzyme-kinetics.pl +6 -0
- package/examples/eyelang/output/complex-matrix-stability.pl +5 -0
- package/examples/eyelang/output/complex.pl +1 -0
- package/examples/eyelang/output/composition-of-injective-functions-is-injective.pl +2 -0
- package/examples/eyelang/output/context-association.pl +3 -0
- package/examples/eyelang/output/control-system.pl +6 -0
- package/examples/eyelang/output/cryptarithmetic-send-more-money.pl +6 -0
- package/examples/eyelang/output/cyclic-path.pl +16 -0
- package/examples/eyelang/output/d3-group.pl +2 -0
- package/examples/eyelang/output/dairy-energy-balance.pl +13 -0
- package/examples/eyelang/output/data-negotiation.pl +1 -0
- package/examples/eyelang/output/deep-taxonomy-10.pl +16 -0
- package/examples/eyelang/output/deep-taxonomy-100.pl +16 -0
- package/examples/eyelang/output/deep-taxonomy-1000.pl +16 -0
- package/examples/eyelang/output/deep-taxonomy-10000.pl +16 -0
- package/examples/eyelang/output/deep-taxonomy-100000.pl +16 -0
- package/examples/eyelang/output/delfour.pl +31 -0
- package/examples/eyelang/output/dense-hamiltonian-cycle.pl +4 -0
- package/examples/eyelang/output/deontic-logic.pl +4 -0
- package/examples/eyelang/output/derived-backward-rule.pl +3 -0
- package/examples/eyelang/output/derived-rule.pl +2 -0
- package/examples/eyelang/output/diamond-property.pl +4 -0
- package/examples/eyelang/output/dijkstra-findall-sort.pl +2 -0
- package/examples/eyelang/output/dijkstra-risk-path.pl +29 -0
- package/examples/eyelang/output/dijkstra.pl +16 -0
- package/examples/eyelang/output/dining-philosophers.pl +350 -0
- package/examples/eyelang/output/directional-language.ttl +1 -0
- package/examples/eyelang/output/dog.pl +1 -0
- package/examples/eyelang/output/drone-corridor-planner.pl +17 -0
- package/examples/eyelang/output/easter-computus.pl +30 -0
- package/examples/eyelang/output/electrical-rc-filter.pl +3 -0
- package/examples/eyelang/output/epidemic-policy.pl +14 -0
- package/examples/eyelang/output/equivalence-classes-overlap-implies-same-class.pl +18 -0
- package/examples/eyelang/output/eulerian-path.pl +3 -0
- package/examples/eyelang/output/ev-range-worlds.pl +19 -0
- package/examples/eyelang/output/exact-cover-sudoku.pl +3 -0
- package/examples/eyelang/output/existential-rule.pl +2 -0
- package/examples/eyelang/output/exoplanet-validation-worlds.pl +22 -0
- package/examples/eyelang/output/expression-eval.pl +1 -0
- package/examples/eyelang/output/eyeling-ackermann.n3 +12 -0
- package/examples/eyelang/output/eyeling-age-threshold.n3 +4 -0
- package/examples/eyelang/output/eyeling-alignment-demo.n3 +1 -0
- package/examples/eyelang/output/eyeling-allen-interval-calculus-small.n3 +3 -0
- package/examples/eyelang/output/eyeling-backward-recursion.n3 +9 -0
- package/examples/eyelang/output/eyeling-backward.n3 +1 -0
- package/examples/eyelang/output/eyeling-basic-monadic-small.n3 +8 -0
- package/examples/eyelang/output/eyeling-bmi.n3 +2 -0
- package/examples/eyelang/output/eyeling-cat-koko.n3 +3 -0
- package/examples/eyelang/output/eyeling-collatz-small.n3 +3 -0
- package/examples/eyelang/output/eyeling-collection.n3 +1 -0
- package/examples/eyelang/output/eyeling-complex-arithmetic.n3 +5 -0
- package/examples/eyelang/output/eyeling-context-association.n3 +4 -0
- package/examples/eyelang/output/eyeling-control-system-small.n3 +4 -0
- package/examples/eyelang/output/eyeling-crypto-builtins-extra.n3 +3 -0
- package/examples/eyelang/output/eyeling-crypto-builtins.n3 +2 -0
- package/examples/eyelang/output/eyeling-deep-taxonomy-10.n3 +32 -0
- package/examples/eyelang/output/eyeling-derived-backward-rule-flat.n3 +4 -0
- package/examples/eyelang/output/eyeling-derived-rule-flat.n3 +2 -0
- package/examples/eyelang/output/eyeling-digital-product-passport-small.n3 +3 -0
- package/examples/eyelang/output/eyeling-dijkstra-tiny.n3 +9 -0
- package/examples/eyelang/output/eyeling-dog-license.n3 +1 -0
- package/examples/eyelang/output/eyeling-drone-corridor-planner-small.n3 +5 -0
- package/examples/eyelang/output/eyeling-equals.n3 +1 -0
- package/examples/eyelang/output/eyeling-equivalence-classes.n3 +2 -0
- package/examples/eyelang/output/eyeling-euler-identity.n3 +3 -0
- package/examples/eyelang/output/eyeling-existential-rule.n3 +4 -0
- package/examples/eyelang/output/eyeling-expression-eval.n3 +3 -0
- package/examples/eyelang/output/eyeling-family-cousins-extended.n3 +6 -0
- package/examples/eyelang/output/eyeling-fastpow.n3 +4 -0
- package/examples/eyelang/output/eyeling-fibonacci.n3 +6 -0
- package/examples/eyelang/output/eyeling-french-cities-reachability.n3 +25 -0
- package/examples/eyelang/output/eyeling-goldbach-small.n3 +2 -0
- package/examples/eyelang/output/eyeling-good-cobbler.n3 +2 -0
- package/examples/eyelang/output/eyeling-list-builtins.n3 +6 -0
- package/examples/eyelang/output/eyeling-list-collection-extra.n3 +5 -0
- package/examples/eyelang/output/eyeling-math-builtins.n3 +5 -0
- package/examples/eyelang/output/eyeling-string-builtins-extra.n3 +3 -0
- package/examples/eyelang/output/eyeling-string-builtins.n3 +4 -0
- package/examples/eyelang/output/eyeling-time-builtins.n3 +4 -0
- package/examples/eyelang/output/eyeling-time-components-extra.n3 +5 -0
- package/examples/eyelang/output/eyeling-witch.n3 +2 -0
- package/examples/eyelang/output/family-cousins.n3 +8 -0
- package/examples/eyelang/output/family-cousins.pl +28 -0
- package/examples/eyelang/output/fastpow.pl +6 -0
- package/examples/eyelang/output/fft8-numeric.pl +4 -0
- package/examples/eyelang/output/fibonacci.pl +6 -0
- package/examples/eyelang/output/field-nitrogen-balance.pl +21 -0
- package/examples/eyelang/output/flandor.pl +43 -0
- package/examples/eyelang/output/floating-point.pl +9 -0
- package/examples/eyelang/output/four-color-map.pl +3 -0
- package/examples/eyelang/output/fundamental-theorem-arithmetic.pl +9 -0
- package/examples/eyelang/output/gcd-bezout-identity.pl +36 -0
- package/examples/eyelang/output/gd-step-certified.pl +79 -0
- package/examples/eyelang/output/gdpr-compliance.pl +6 -0
- package/examples/eyelang/output/goldbach-1000.pl +667 -0
- package/examples/eyelang/output/good-cobbler.pl +1 -0
- package/examples/eyelang/output/gps.pl +21 -0
- package/examples/eyelang/output/graph-reachability.pl +3 -0
- package/examples/eyelang/output/gray-code-counter.pl +1 -0
- package/examples/eyelang/output/greatest-lower-bound-uniqueness.pl +2 -0
- package/examples/eyelang/output/group-inverse-uniqueness.pl +2 -0
- package/examples/eyelang/output/hamiltonian-cycle.pl +4 -0
- package/examples/eyelang/output/hamiltonian-path.pl +121 -0
- package/examples/eyelang/output/hamming-code.pl +6 -0
- package/examples/eyelang/output/hanoi.pl +1 -0
- package/examples/eyelang/output/heat-loss.pl +5 -0
- package/examples/eyelang/output/heron-theorem.pl +4 -0
- package/examples/eyelang/output/ideal-gas-law.pl +3 -0
- package/examples/eyelang/output/illegitimate-reasoning.pl +15 -0
- package/examples/eyelang/output/kaprekar.pl +8 -0
- package/examples/eyelang/output/law-of-cosines.pl +3 -0
- package/examples/eyelang/output/least-squares-regression.pl +5 -0
- package/examples/eyelang/output/list-collection.pl +3 -0
- package/examples/eyelang/output/lldm.pl +6 -0
- package/examples/eyelang/output/manufacturing-quality-control.pl +6 -0
- package/examples/eyelang/output/matrix.pl +10 -0
- package/examples/eyelang/output/microgrid-dispatch.pl +6 -0
- package/examples/eyelang/output/monkey-bananas.pl +5 -0
- package/examples/eyelang/output/n-queens.pl +93 -0
- package/examples/eyelang/output/n3-builtins.n3 +6 -0
- package/examples/eyelang/output/network-sla.pl +4 -0
- package/examples/eyelang/output/newton-raphson.pl +3 -0
- package/examples/eyelang/output/nixon-diamond.pl +5 -0
- package/examples/eyelang/output/odrl-dpv-healthcare-risk-ranked.pl +42 -0
- package/examples/eyelang/output/odrl-dpv-risk-ranked.pl +120 -0
- package/examples/eyelang/output/orbital-transfer-design.pl +7 -0
- package/examples/eyelang/output/path-discovery.pl +3 -0
- package/examples/eyelang/output/peano-arithmetic.pl +3 -0
- package/examples/eyelang/output/peasant.pl +10 -0
- package/examples/eyelang/output/pendulum-period.pl +4 -0
- package/examples/eyelang/output/polynomial.pl +14 -0
- package/examples/eyelang/output/project-portfolio-optimization.pl +6 -0
- package/examples/eyelang/output/proof-contrapositive.pl +3 -0
- package/examples/eyelang/output/quadratic-formula.pl +6 -0
- package/examples/eyelang/output/quine-mccluskey.pl +3 -0
- package/examples/eyelang/output/radioactive-decay.pl +5 -0
- package/examples/eyelang/output/resilient-city-orchestration.pl +67 -0
- package/examples/eyelang/output/riemann-hypothesis.pl +12 -0
- package/examples/eyelang/output/sat-dpll.pl +5 -0
- package/examples/eyelang/output/security-incident-correlation.pl +3 -0
- package/examples/eyelang/output/service-impact.pl +11 -0
- package/examples/eyelang/output/sieve.pl +1 -0
- package/examples/eyelang/output/skolem-functions.pl +16 -0
- package/examples/eyelang/output/socket-age.pl +1 -0
- package/examples/eyelang/output/socket-family.pl +3 -0
- package/examples/eyelang/output/socrates.n3 +1 -0
- package/examples/eyelang/output/socrates.pl +2 -0
- package/examples/eyelang/output/statistics-summary.pl +4 -0
- package/examples/eyelang/output/sudoku.pl +2 -0
- package/examples/eyelang/output/superdense-coding.pl +6 -0
- package/examples/eyelang/output/traveling-salesman.pl +1 -0
- package/examples/eyelang/output/triple-term.n3 +2 -0
- package/examples/eyelang/output/turing.pl +12 -0
- package/examples/eyelang/output/vector-similarity.pl +4 -0
- package/examples/eyelang/output/witch.pl +7 -0
- package/examples/eyelang/output/wolf-goat-cabbage.pl +3 -0
- package/examples/eyelang/output/zebra.pl +3 -0
- package/examples/eyelang/path-discovery.pl +44998 -0
- package/examples/eyelang/peano-arithmetic.pl +31 -0
- package/examples/eyelang/peasant.pl +30 -0
- package/examples/eyelang/pendulum-period.pl +50 -0
- package/examples/eyelang/polynomial.pl +124 -0
- package/examples/eyelang/project-portfolio-optimization.pl +101 -0
- package/examples/eyelang/proof/age.pl +71 -0
- package/examples/eyelang/proof/aliases-and-namespaces.pl +78 -0
- package/examples/eyelang/proof/ancestor.pl +140 -0
- package/examples/eyelang/proof/animal.pl +68 -0
- package/examples/eyelang/proof/annotation.pl +80 -0
- package/examples/eyelang/proof/backward.pl +22 -0
- package/examples/eyelang/proof/cat-koko.pl +86 -0
- package/examples/eyelang/proof/data-negotiation.pl +76 -0
- package/examples/eyelang/proof/derived-rule.pl +43 -0
- package/examples/eyelang/proof/dog.pl +31 -0
- package/examples/eyelang/proof/electrical-rc-filter.pl +105 -0
- package/examples/eyelang/proof/existential-rule.pl +40 -0
- package/examples/eyelang/proof/floating-point.pl +160 -0
- package/examples/eyelang/proof/good-cobbler.pl +16 -0
- package/examples/eyelang/proof/group-inverse-uniqueness.pl +84 -0
- package/examples/eyelang/proof/list-collection.pl +52 -0
- package/examples/eyelang/proof/proof-contrapositive.pl +78 -0
- package/examples/eyelang/proof/socket-age.pl +32 -0
- package/examples/eyelang/proof/socket-family.pl +59 -0
- package/examples/eyelang/proof/socrates.pl +38 -0
- package/examples/eyelang/proof-contrapositive.pl +27 -0
- package/examples/eyelang/quadratic-formula.pl +54 -0
- package/examples/eyelang/quine-mccluskey.pl +143 -0
- package/examples/eyelang/radioactive-decay.pl +56 -0
- package/examples/eyelang/resilient-city-orchestration.pl +303 -0
- package/examples/eyelang/riemann-hypothesis.pl +110 -0
- package/examples/eyelang/sat-dpll.pl +80 -0
- package/examples/eyelang/security-incident-correlation.pl +69 -0
- package/examples/eyelang/service-impact.pl +41 -0
- package/examples/eyelang/sieve.pl +20 -0
- package/examples/eyelang/skolem-functions.pl +52 -0
- package/examples/eyelang/socket-age.pl +39 -0
- package/examples/eyelang/socket-family.pl +28 -0
- package/examples/eyelang/socrates.n3 +11 -0
- package/examples/eyelang/socrates.pl +19 -0
- package/examples/eyelang/statistics-summary.pl +54 -0
- package/examples/eyelang/sudoku.pl +20 -0
- package/examples/eyelang/superdense-coding.pl +84 -0
- package/examples/eyelang/traveling-salesman.pl +64 -0
- package/examples/eyelang/triple-term.n3 +9 -0
- package/examples/eyelang/turing.pl +67 -0
- package/examples/eyelang/vector-similarity.pl +56 -0
- package/examples/eyelang/witch.pl +38 -0
- package/examples/eyelang/wolf-goat-cabbage.pl +56 -0
- package/examples/eyelang/zebra.pl +44 -0
- package/eyelang.d.ts +92 -0
- package/eyeling-builtins.ttl +1 -1
- package/eyeling.js +2 -11
- package/index.d.ts +50 -2
- package/index.js +95 -1
- package/lib/builtins.js +1 -11
- package/lib/cli.js +1 -0
- package/lib/eyelang/bin.js +7 -0
- package/lib/eyelang/builtins/aggregation.mjs +81 -0
- package/lib/eyelang/builtins/alphametic.mjs +144 -0
- package/lib/eyelang/builtins/arithmetic.mjs +197 -0
- package/lib/eyelang/builtins/control.mjs +22 -0
- package/lib/eyelang/builtins/core.mjs +78 -0
- package/lib/eyelang/builtins/formula.mjs +42 -0
- package/lib/eyelang/builtins/lists.mjs +149 -0
- package/lib/eyelang/builtins/matrix.mjs +226 -0
- package/lib/eyelang/builtins/n3.mjs +483 -0
- package/lib/eyelang/builtins/number-theory.mjs +114 -0
- package/lib/eyelang/builtins/portfolio.mjs +73 -0
- package/lib/eyelang/builtins/registry.mjs +54 -0
- package/lib/eyelang/builtins/search.mjs +579 -0
- package/lib/eyelang/builtins/strings.mjs +41 -0
- package/lib/eyelang/builtins/sudoku.mjs +141 -0
- package/lib/eyelang/cli.mjs +192 -0
- package/lib/eyelang/explain.mjs +324 -0
- package/lib/eyelang/hash.mjs +294 -0
- package/lib/eyelang/index.mjs +48 -0
- package/lib/eyelang/parser.mjs +428 -0
- package/lib/eyelang/program.mjs +244 -0
- package/lib/eyelang/rdf.mjs +747 -0
- package/lib/eyelang/solver.mjs +237 -0
- package/lib/eyelang/term.mjs +328 -0
- package/package.json +12 -3
- package/test/builtins.test.js +15 -2
- package/test/eyelang/conformance/README.md +45 -0
- package/test/eyelang/conformance/cases/core/001_fact_output.pl +4 -0
- package/test/eyelang/conformance/cases/core/001_fact_query.query +1 -0
- package/test/eyelang/conformance/cases/core/002_rule_recursion.pl +7 -0
- package/test/eyelang/conformance/cases/core/002_rule_recursion.query +1 -0
- package/test/eyelang/conformance/cases/core/003_terms_and_readback.pl +16 -0
- package/test/eyelang/conformance/cases/core/003_terms_and_readback.query +1 -0
- package/test/eyelang/conformance/cases/core/004_conjunction_and_parentheses.pl +5 -0
- package/test/eyelang/conformance/cases/core/004_conjunction_and_parentheses.query +1 -0
- package/test/eyelang/conformance/cases/core/005_list_deconstruction.pl +6 -0
- package/test/eyelang/conformance/cases/core/005_list_deconstruction.query +1 -0
- package/test/eyelang/conformance/cases/core/006_comma_formula_data.pl +4 -0
- package/test/eyelang/conformance/cases/core/006_comma_formula_data.query +1 -0
- package/test/eyelang/conformance/cases/core/007_anonymous_variables.pl +5 -0
- package/test/eyelang/conformance/cases/core/007_anonymous_variables.query +1 -0
- package/test/eyelang/conformance/cases/core/008_graphic_atoms.pl +6 -0
- package/test/eyelang/conformance/cases/core/008_graphic_atoms.query +1 -0
- package/test/eyelang/conformance/cases/core/009_comments_and_whitespace.pl +5 -0
- package/test/eyelang/conformance/cases/core/009_comments_and_whitespace.query +1 -0
- package/test/eyelang/conformance/cases/core/010_variable_scope_and_reuse.pl +8 -0
- package/test/eyelang/conformance/cases/core/010_variable_scope_and_reuse.query +1 -0
- package/test/eyelang/conformance/cases/core/011_predicate_arity.pl +6 -0
- package/test/eyelang/conformance/cases/core/011_predicate_arity.query +1 -0
- package/test/eyelang/conformance/cases/core/012_nested_compound_unification.pl +5 -0
- package/test/eyelang/conformance/cases/core/012_nested_compound_unification.query +1 -0
- package/test/eyelang/conformance/cases/core/013_multiple_clauses_order.pl +6 -0
- package/test/eyelang/conformance/cases/core/013_multiple_clauses_order.query +1 -0
- package/test/eyelang/conformance/cases/core/014_failure_filters_answers.pl +7 -0
- package/test/eyelang/conformance/cases/core/014_failure_filters_answers.query +1 -0
- package/test/eyelang/conformance/cases/core/015_improper_list_unification.pl +6 -0
- package/test/eyelang/conformance/cases/core/015_improper_list_unification.query +1 -0
- package/test/eyelang/conformance/cases/core/016_zero_arity_compound.pl +4 -0
- package/test/eyelang/conformance/cases/core/016_zero_arity_compound.query +1 -0
- package/test/eyelang/conformance/cases/core/017_three_step_recursion.pl +8 -0
- package/test/eyelang/conformance/cases/core/017_three_step_recursion.query +1 -0
- package/test/eyelang/conformance/cases/core/018_quoted_atom_readback.pl +6 -0
- package/test/eyelang/conformance/cases/core/018_quoted_atom_readback.query +1 -0
- package/test/eyelang/conformance/cases/core/019_parenthesized_three_conjuncts.pl +7 -0
- package/test/eyelang/conformance/cases/core/019_parenthesized_three_conjuncts.query +1 -0
- package/test/eyelang/conformance/cases/core/020_nested_list_terms.pl +5 -0
- package/test/eyelang/conformance/cases/core/020_nested_list_terms.query +1 -0
- package/test/eyelang/conformance/cases/core/021_repeated_variable_head.pl +7 -0
- package/test/eyelang/conformance/cases/core/022_rule_head_structure.pl +5 -0
- package/test/eyelang/conformance/cases/core/023_quoted_escapes_readback.pl +5 -0
- package/test/eyelang/conformance/cases/core/024_numeric_literal_readback.pl +6 -0
- package/test/eyelang/conformance/cases/core/025_body_parentheses_with_formula_data.pl +5 -0
- package/test/eyelang/conformance/cases/core/026_underscore_named_variable_reuse.pl +5 -0
- package/test/eyelang/conformance/cases/extension/001_default_derived_output.pl +5 -0
- package/test/eyelang/conformance/cases/extension/002_materialize_focus.pl +5 -0
- package/test/eyelang/conformance/cases/extension/003_arithmetic_and_comparison.pl +12 -0
- package/test/eyelang/conformance/cases/extension/003_arithmetic_and_comparison.query +1 -0
- package/test/eyelang/conformance/cases/extension/004_strings_and_atoms.pl +6 -0
- package/test/eyelang/conformance/cases/extension/004_strings_and_atoms.query +1 -0
- package/test/eyelang/conformance/cases/extension/005_lists_aggregation_ordering.pl +10 -0
- package/test/eyelang/conformance/cases/extension/005_lists_aggregation_ordering.query +1 -0
- package/test/eyelang/conformance/cases/extension/006_formula_terms.pl +5 -0
- package/test/eyelang/conformance/cases/extension/006_formula_terms.query +1 -0
- package/test/eyelang/conformance/cases/extension/007_negation_once_generators.pl +7 -0
- package/test/eyelang/conformance/cases/extension/007_negation_once_generators.query +1 -0
- package/test/eyelang/conformance/cases/extension/008_equality_and_inequality.pl +6 -0
- package/test/eyelang/conformance/cases/extension/008_equality_and_inequality.query +1 -0
- package/test/eyelang/conformance/cases/extension/009_list_relations.pl +6 -0
- package/test/eyelang/conformance/cases/extension/009_list_relations.query +1 -0
- package/test/eyelang/conformance/cases/extension/010_append_splits.pl +3 -0
- package/test/eyelang/conformance/cases/extension/010_append_splits.query +1 -0
- package/test/eyelang/conformance/cases/extension/011_matching_and_comparison.pl +7 -0
- package/test/eyelang/conformance/cases/extension/011_matching_and_comparison.query +1 -0
- package/test/eyelang/conformance/cases/extension/012_memoize_declaration.pl +8 -0
- package/test/eyelang/conformance/cases/extension/012_memoize_declaration.query +1 -0
- package/test/eyelang/conformance/cases/extension/013_numeric_functions.pl +9 -0
- package/test/eyelang/conformance/cases/extension/013_numeric_functions.query +1 -0
- package/test/eyelang/conformance/cases/extension/014_between_enumeration.pl +3 -0
- package/test/eyelang/conformance/cases/extension/014_between_enumeration.query +1 -0
- package/test/eyelang/conformance/cases/extension/015_smallest_divisor.pl +3 -0
- package/test/eyelang/conformance/cases/extension/015_smallest_divisor.query +1 -0
- package/test/eyelang/conformance/cases/extension/016_negation_filter.pl +7 -0
- package/test/eyelang/conformance/cases/extension/016_negation_filter.query +1 -0
- package/test/eyelang/conformance/cases/extension/017_once_user_predicate.pl +5 -0
- package/test/eyelang/conformance/cases/extension/017_once_user_predicate.query +1 -0
- package/test/eyelang/conformance/cases/extension/018_findall_user_goal.pl +6 -0
- package/test/eyelang/conformance/cases/extension/018_findall_user_goal.query +1 -0
- package/test/eyelang/conformance/cases/extension/019_sort_deduplicates_atoms.pl +3 -0
- package/test/eyelang/conformance/cases/extension/019_sort_deduplicates_atoms.query +1 -0
- package/test/eyelang/conformance/cases/extension/020_append_bound_prefix_suffix.pl +4 -0
- package/test/eyelang/conformance/cases/extension/020_append_bound_prefix_suffix.query +1 -0
- package/test/eyelang/conformance/cases/extension/021_nth0_index_generation.pl +3 -0
- package/test/eyelang/conformance/cases/extension/021_nth0_index_generation.query +1 -0
- package/test/eyelang/conformance/cases/extension/022_set_nth0_edges.pl +4 -0
- package/test/eyelang/conformance/cases/extension/022_set_nth0_edges.query +1 -0
- package/test/eyelang/conformance/cases/extension/023_select_duplicate_occurrences.pl +3 -0
- package/test/eyelang/conformance/cases/extension/023_select_duplicate_occurrences.query +1 -0
- package/test/eyelang/conformance/cases/extension/024_not_member_filter.pl +6 -0
- package/test/eyelang/conformance/cases/extension/024_not_member_filter.query +1 -0
- package/test/eyelang/conformance/cases/extension/025_is_list_filter.pl +5 -0
- package/test/eyelang/conformance/cases/extension/025_is_list_filter.query +1 -0
- package/test/eyelang/conformance/cases/extension/026_nested_formula_terms.pl +5 -0
- package/test/eyelang/conformance/cases/extension/026_nested_formula_terms.query +1 -0
- package/test/eyelang/conformance/cases/extension/027_materialize_excludes_source_fact.pl +6 -0
- package/test/eyelang/conformance/cases/extension/028_numeric_and_lexical_comparison.pl +5 -0
- package/test/eyelang/conformance/cases/extension/028_numeric_and_lexical_comparison.query +1 -0
- package/test/eyelang/conformance/cases/extension/029_string_matching_filters.pl +6 -0
- package/test/eyelang/conformance/cases/extension/029_string_matching_filters.query +1 -0
- package/test/eyelang/conformance/cases/extension/030_string_and_atom_concat.pl +4 -0
- package/test/eyelang/conformance/cases/extension/030_string_and_atom_concat.query +1 -0
- package/test/eyelang/conformance/cases/extension/031_countall_empty_and_nonempty.pl +4 -0
- package/test/eyelang/conformance/cases/extension/031_countall_empty_and_nonempty.query +1 -0
- package/test/eyelang/conformance/cases/extension/032_sumall_numeric_template.pl +5 -0
- package/test/eyelang/conformance/cases/extension/032_sumall_numeric_template.query +1 -0
- package/test/eyelang/conformance/cases/extension/033_aggregate_min_template.pl +5 -0
- package/test/eyelang/conformance/cases/extension/033_aggregate_min_template.query +1 -0
- package/test/eyelang/conformance/cases/extension/034_aggregate_max_compound_key.pl +5 -0
- package/test/eyelang/conformance/cases/extension/034_aggregate_max_compound_key.query +1 -0
- package/test/eyelang/conformance/cases/extension/035_date_difference.pl +4 -0
- package/test/eyelang/conformance/cases/extension/036_extended_gcd.pl +3 -0
- package/test/eyelang/conformance/cases/extension/037_collatz_trajectory.pl +3 -0
- package/test/eyelang/conformance/cases/extension/038_kaprekar_steps.pl +3 -0
- package/test/eyelang/conformance/cases/extension/039_goldbach_pair.pl +3 -0
- package/test/eyelang/conformance/cases/extension/040_matrix_operations.pl +5 -0
- package/test/eyelang/conformance/cases/extension/041_atom_range_generators.pl +5 -0
- package/test/eyelang/conformance/cases/extension/042_n_queens_small.pl +3 -0
- package/test/eyelang/conformance/cases/extension/043_cnf_model.pl +3 -0
- package/test/eyelang/conformance/cases/extension/044_cover9_filter.pl +6 -0
- package/test/eyelang/conformance/cases/extension/045_alphametic_sum_small.pl +3 -0
- package/test/eyelang/conformance/cases/extension/046_bounded_subset.pl +4 -0
- package/test/eyelang/conformance/expected/core/001_fact_output.out +1 -0
- package/test/eyelang/conformance/expected/core/002_rule_recursion.out +2 -0
- package/test/eyelang/conformance/expected/core/003_terms_and_readback.out +13 -0
- package/test/eyelang/conformance/expected/core/004_conjunction_and_parentheses.out +1 -0
- package/test/eyelang/conformance/expected/core/005_list_deconstruction.out +2 -0
- package/test/eyelang/conformance/expected/core/006_comma_formula_data.out +1 -0
- package/test/eyelang/conformance/expected/core/007_anonymous_variables.out +1 -0
- package/test/eyelang/conformance/expected/core/008_graphic_atoms.out +3 -0
- package/test/eyelang/conformance/expected/core/009_comments_and_whitespace.out +2 -0
- package/test/eyelang/conformance/expected/core/010_variable_scope_and_reuse.out +2 -0
- package/test/eyelang/conformance/expected/core/011_predicate_arity.out +2 -0
- package/test/eyelang/conformance/expected/core/012_nested_compound_unification.out +2 -0
- package/test/eyelang/conformance/expected/core/013_multiple_clauses_order.out +2 -0
- package/test/eyelang/conformance/expected/core/014_failure_filters_answers.out +1 -0
- package/test/eyelang/conformance/expected/core/015_improper_list_unification.out +3 -0
- package/test/eyelang/conformance/expected/core/016_zero_arity_compound.out +1 -0
- package/test/eyelang/conformance/expected/core/017_three_step_recursion.out +3 -0
- package/test/eyelang/conformance/expected/core/018_quoted_atom_readback.out +3 -0
- package/test/eyelang/conformance/expected/core/019_parenthesized_three_conjuncts.out +1 -0
- package/test/eyelang/conformance/expected/core/020_nested_list_terms.out +2 -0
- package/test/eyelang/conformance/expected/core/021_repeated_variable_head.out +2 -0
- package/test/eyelang/conformance/expected/core/022_rule_head_structure.out +2 -0
- package/test/eyelang/conformance/expected/core/023_quoted_escapes_readback.out +2 -0
- package/test/eyelang/conformance/expected/core/024_numeric_literal_readback.out +3 -0
- package/test/eyelang/conformance/expected/core/025_body_parentheses_with_formula_data.out +1 -0
- package/test/eyelang/conformance/expected/core/026_underscore_named_variable_reuse.out +1 -0
- package/test/eyelang/conformance/expected/extension/001_default_derived_output.out +3 -0
- package/test/eyelang/conformance/expected/extension/002_materialize_focus.out +1 -0
- package/test/eyelang/conformance/expected/extension/003_arithmetic_and_comparison.out +10 -0
- package/test/eyelang/conformance/expected/extension/004_strings_and_atoms.out +4 -0
- package/test/eyelang/conformance/expected/extension/005_lists_aggregation_ordering.out +9 -0
- package/test/eyelang/conformance/expected/extension/006_formula_terms.out +4 -0
- package/test/eyelang/conformance/expected/extension/007_negation_once_generators.out +2 -0
- package/test/eyelang/conformance/expected/extension/008_equality_and_inequality.out +4 -0
- package/test/eyelang/conformance/expected/extension/009_list_relations.out +5 -0
- package/test/eyelang/conformance/expected/extension/010_append_splits.out +3 -0
- package/test/eyelang/conformance/expected/extension/011_matching_and_comparison.out +5 -0
- package/test/eyelang/conformance/expected/extension/012_memoize_declaration.out +2 -0
- package/test/eyelang/conformance/expected/extension/013_numeric_functions.out +7 -0
- package/test/eyelang/conformance/expected/extension/014_between_enumeration.out +3 -0
- package/test/eyelang/conformance/expected/extension/015_smallest_divisor.out +1 -0
- package/test/eyelang/conformance/expected/extension/016_negation_filter.out +2 -0
- package/test/eyelang/conformance/expected/extension/017_once_user_predicate.out +1 -0
- package/test/eyelang/conformance/expected/extension/018_findall_user_goal.out +1 -0
- package/test/eyelang/conformance/expected/extension/019_sort_deduplicates_atoms.out +1 -0
- package/test/eyelang/conformance/expected/extension/020_append_bound_prefix_suffix.out +2 -0
- package/test/eyelang/conformance/expected/extension/021_nth0_index_generation.out +1 -0
- package/test/eyelang/conformance/expected/extension/022_set_nth0_edges.out +2 -0
- package/test/eyelang/conformance/expected/extension/023_select_duplicate_occurrences.out +2 -0
- package/test/eyelang/conformance/expected/extension/024_not_member_filter.out +1 -0
- package/test/eyelang/conformance/expected/extension/025_is_list_filter.out +1 -0
- package/test/eyelang/conformance/expected/extension/026_nested_formula_terms.out +6 -0
- package/test/eyelang/conformance/expected/extension/027_materialize_excludes_source_fact.out +1 -0
- package/test/eyelang/conformance/expected/extension/028_numeric_and_lexical_comparison.out +3 -0
- package/test/eyelang/conformance/expected/extension/029_string_matching_filters.out +2 -0
- package/test/eyelang/conformance/expected/extension/030_string_and_atom_concat.out +2 -0
- package/test/eyelang/conformance/expected/extension/031_countall_empty_and_nonempty.out +1 -0
- package/test/eyelang/conformance/expected/extension/032_sumall_numeric_template.out +1 -0
- package/test/eyelang/conformance/expected/extension/033_aggregate_min_template.out +1 -0
- package/test/eyelang/conformance/expected/extension/034_aggregate_max_compound_key.out +1 -0
- package/test/eyelang/conformance/expected/extension/035_date_difference.out +2 -0
- package/test/eyelang/conformance/expected/extension/036_extended_gcd.out +1 -0
- package/test/eyelang/conformance/expected/extension/037_collatz_trajectory.out +1 -0
- package/test/eyelang/conformance/expected/extension/038_kaprekar_steps.out +1 -0
- package/test/eyelang/conformance/expected/extension/039_goldbach_pair.out +2 -0
- package/test/eyelang/conformance/expected/extension/040_matrix_operations.out +3 -0
- package/test/eyelang/conformance/expected/extension/041_atom_range_generators.out +8 -0
- package/test/eyelang/conformance/expected/extension/042_n_queens_small.out +2 -0
- package/test/eyelang/conformance/expected/extension/043_cnf_model.out +1 -0
- package/test/eyelang/conformance/expected/extension/044_cover9_filter.out +2 -0
- package/test/eyelang/conformance/expected/extension/045_alphametic_sum_small.out +4 -0
- package/test/eyelang/conformance/expected/extension/046_bounded_subset.out +5 -0
- package/test/eyelang/run-all.mjs +20 -0
- package/test/eyelang/run-conformance.mjs +80 -0
- package/test/eyelang/run-examples.mjs +126 -0
- package/test/eyelang/run-regression.mjs +640 -0
- package/test/eyelang/test-style.mjs +91 -0
- package/test/eyelang.test.js +58 -0
- package/test/run.js +1 -0
|
@@ -0,0 +1,197 @@
|
|
|
1
|
+
// Numeric builtins for integer-preserving arithmetic, floating point functions, comparisons, and ranges.
|
|
2
|
+
// The code keeps BigInt paths where possible so large eyelang integers remain exact.
|
|
3
|
+
import { compareIntegerText, deref, isDecimalInteger, lexicalValue, numberTerm, numberTextFromDouble, parseFiniteNumber, unify } from '../term.mjs';
|
|
4
|
+
|
|
5
|
+
const unaryNames = ['neg', 'abs', 'sin', 'cos', 'asin', 'acos', 'rounded', 'log'];
|
|
6
|
+
const binaryNames = ['add', 'sub', 'mul', 'div', 'mod', 'max', 'min', 'pow'];
|
|
7
|
+
const compareNames = ['lt', 'gt', 'le', 'ge'];
|
|
8
|
+
|
|
9
|
+
export const arithmeticBuiltins = {
|
|
10
|
+
register(registry) {
|
|
11
|
+
for (const name of unaryNames) registry.add(name, 2, unary(name), { deterministic: true });
|
|
12
|
+
for (const name of binaryNames) registry.add(name, 3, binary(name), { deterministic: true });
|
|
13
|
+
for (const name of compareNames) registry.add(name, 2, compare(name), { deterministic: true });
|
|
14
|
+
registry.add('between', 3, between);
|
|
15
|
+
registry.add('smallest_divisor_from', 3, smallestDivisorFrom, { deterministic: true });
|
|
16
|
+
}
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
function unary(name) {
|
|
21
|
+
return function* ({ goal, env }) {
|
|
22
|
+
const text = lexicalValue(goal.args[0], env);
|
|
23
|
+
if (text == null) return;
|
|
24
|
+
let out = null;
|
|
25
|
+
if ((name === 'neg' || name === 'abs') && isDecimalInteger(text)) {
|
|
26
|
+
const value = BigInt(text);
|
|
27
|
+
out = (name === 'neg' ? -value : value < 0n ? -value : value).toString();
|
|
28
|
+
} else {
|
|
29
|
+
const input = parseFiniteNumber(text);
|
|
30
|
+
if (input == null) return;
|
|
31
|
+
let value;
|
|
32
|
+
if (name === 'neg') value = -input;
|
|
33
|
+
else if (name === 'abs') value = Math.abs(input);
|
|
34
|
+
else if (name === 'sin') value = Math.sin(input);
|
|
35
|
+
else if (name === 'cos') value = Math.cos(input);
|
|
36
|
+
else if (name === 'asin') value = Math.asin(input);
|
|
37
|
+
else if (name === 'acos') value = Math.acos(input);
|
|
38
|
+
else if (name === 'rounded') value = Math.round(input);
|
|
39
|
+
else if (name === 'log') {
|
|
40
|
+
if (input <= 0) return;
|
|
41
|
+
value = logCompat(input);
|
|
42
|
+
}
|
|
43
|
+
out = name === 'rounded' ? String(Math.trunc(value)) : numberTextFromDouble(value);
|
|
44
|
+
}
|
|
45
|
+
const next = env.clone();
|
|
46
|
+
if (out != null && unify(goal.args[1], numberTerm(out), next)) yield next;
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
function binary(name) {
|
|
51
|
+
return function* ({ goal, env }) {
|
|
52
|
+
const leftText = lexicalValue(goal.args[0], env);
|
|
53
|
+
const rightText = lexicalValue(goal.args[1], env);
|
|
54
|
+
if (leftText == null || rightText == null) return;
|
|
55
|
+
let out = null;
|
|
56
|
+
if (isDecimalInteger(leftText) && isDecimalInteger(rightText) && name !== 'mod') {
|
|
57
|
+
const a = BigInt(leftText);
|
|
58
|
+
const b = BigInt(rightText);
|
|
59
|
+
if (name === 'add') out = (a + b).toString();
|
|
60
|
+
else if (name === 'sub') out = (a - b).toString();
|
|
61
|
+
else if (name === 'mul') out = (a * b).toString();
|
|
62
|
+
else if (name === 'div') { if (b === 0n) return; out = (a / b).toString(); }
|
|
63
|
+
else if (name === 'max') out = (a >= b ? a : b).toString();
|
|
64
|
+
else if (name === 'min') out = (a <= b ? a : b).toString();
|
|
65
|
+
else if (name === 'pow') { if (b < 0n) return; out = (a ** b).toString(); }
|
|
66
|
+
} else if (name === 'mod') {
|
|
67
|
+
if (!isDecimalInteger(leftText) || !isDecimalInteger(rightText)) return;
|
|
68
|
+
const a = BigInt(leftText), b = BigInt(rightText);
|
|
69
|
+
if (b === 0n) return;
|
|
70
|
+
out = (a % b).toString();
|
|
71
|
+
} else {
|
|
72
|
+
const a = parseFiniteNumber(leftText), b = parseFiniteNumber(rightText);
|
|
73
|
+
if (a == null || b == null) return;
|
|
74
|
+
let value;
|
|
75
|
+
if (name === 'add') value = a + b;
|
|
76
|
+
else if (name === 'sub') value = a - b;
|
|
77
|
+
else if (name === 'mul') value = a * b;
|
|
78
|
+
else if (name === 'div') { if (b === 0) return; value = a / b; }
|
|
79
|
+
else if (name === 'pow') value = Math.pow(a, b);
|
|
80
|
+
else if (name === 'max') value = Math.max(a, b);
|
|
81
|
+
else if (name === 'min') value = Math.min(a, b);
|
|
82
|
+
out = numberTextFromDouble(value);
|
|
83
|
+
}
|
|
84
|
+
const next = env.clone();
|
|
85
|
+
if (out != null && unify(goal.args[2], numberTerm(out), next)) yield next;
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
function compare(name) {
|
|
90
|
+
return function* ({ goal, env }) {
|
|
91
|
+
const left = lexicalValue(goal.args[0], env);
|
|
92
|
+
const right = lexicalValue(goal.args[1], env);
|
|
93
|
+
if (left == null || right == null) return;
|
|
94
|
+
const cmp = compareLexicalOrNumeric(left, right);
|
|
95
|
+
const pass = name === 'lt' ? cmp < 0 : name === 'gt' ? cmp > 0 : name === 'le' ? cmp <= 0 : cmp >= 0;
|
|
96
|
+
if (pass) yield env;
|
|
97
|
+
};
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
export function compareLexicalOrNumeric(left, right) {
|
|
101
|
+
if (isDecimalInteger(left) && isDecimalInteger(right)) return compareIntegerText(left, right);
|
|
102
|
+
const dur = compareDuration(left, right);
|
|
103
|
+
if (dur != null) return dur;
|
|
104
|
+
const a = parseFiniteNumber(left), b = parseFiniteNumber(right);
|
|
105
|
+
if (a != null && b != null) return a < b ? -1 : a > b ? 1 : 0;
|
|
106
|
+
return left < right ? -1 : left > right ? 1 : 0;
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
function compareDuration(a, b) {
|
|
110
|
+
const pa = parseDuration(a), pb = parseDuration(b);
|
|
111
|
+
if (!pa || !pb) return null;
|
|
112
|
+
for (let i = 0; i < 3; i++) if (pa[i] !== pb[i]) return pa[i] < pb[i] ? -1 : 1;
|
|
113
|
+
return 0;
|
|
114
|
+
}
|
|
115
|
+
function parseDuration(text) {
|
|
116
|
+
const m = /^P(?:(\d+)Y)?(?:(\d+)M)?(?:(\d+)D)?$/.exec(text);
|
|
117
|
+
if (!m || (!m[1] && !m[2] && !m[3])) return null;
|
|
118
|
+
return [Number(m[1] ?? 0), Number(m[2] ?? 0), Number(m[3] ?? 0)];
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
function* between({ goal, env }) {
|
|
122
|
+
const lowText = lexicalValue(goal.args[0], env), highText = lexicalValue(goal.args[1], env);
|
|
123
|
+
if (!isDecimalInteger(lowText) || !isDecimalInteger(highText)) return;
|
|
124
|
+
const lowNumber = Number(lowText), highNumber = Number(highText);
|
|
125
|
+
const output = deref(goal.args[2], env);
|
|
126
|
+
if (Number.isSafeInteger(lowNumber) && Number.isSafeInteger(highNumber)) {
|
|
127
|
+
if (output.type === 'var') {
|
|
128
|
+
for (let value = lowNumber; value <= highNumber; value++) {
|
|
129
|
+
const next = env.clone();
|
|
130
|
+
next.bind(output.name, numberTerm(String(value)));
|
|
131
|
+
yield next;
|
|
132
|
+
}
|
|
133
|
+
return;
|
|
134
|
+
}
|
|
135
|
+
for (let value = lowNumber; value <= highNumber; value++) {
|
|
136
|
+
const next = env.clone();
|
|
137
|
+
if (unify(goal.args[2], numberTerm(String(value)), next)) yield next;
|
|
138
|
+
}
|
|
139
|
+
return;
|
|
140
|
+
}
|
|
141
|
+
const low = BigInt(lowText), high = BigInt(highText);
|
|
142
|
+
if (output.type === 'var') {
|
|
143
|
+
for (let value = low; value <= high; value++) {
|
|
144
|
+
const next = env.clone();
|
|
145
|
+
next.bind(output.name, numberTerm(value.toString()));
|
|
146
|
+
yield next;
|
|
147
|
+
}
|
|
148
|
+
return;
|
|
149
|
+
}
|
|
150
|
+
for (let value = low; value <= high; value++) {
|
|
151
|
+
const next = env.clone();
|
|
152
|
+
if (unify(goal.args[2], numberTerm(value.toString()), next)) yield next;
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
function* smallestDivisorFrom({ goal, env }) {
|
|
157
|
+
const nText = lexicalValue(goal.args[0], env), dText = lexicalValue(goal.args[1], env);
|
|
158
|
+
if (!isDecimalInteger(nText) || !isDecimalInteger(dText)) return;
|
|
159
|
+
const n = BigInt(nText), start = BigInt(dText);
|
|
160
|
+
if (n < 0n || start <= 0n) return;
|
|
161
|
+
let result = n;
|
|
162
|
+
for (let c = start; c > 0n && c <= n / c; c++) {
|
|
163
|
+
if (n % c === 0n) { result = c; break; }
|
|
164
|
+
}
|
|
165
|
+
const next = env.clone();
|
|
166
|
+
if (unify(goal.args[2], numberTerm(result.toString()), next)) yield next;
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
|
|
170
|
+
const f64 = new Float64Array(1);
|
|
171
|
+
const u64 = new BigUint64Array(f64.buffer);
|
|
172
|
+
|
|
173
|
+
function nextUp(value) {
|
|
174
|
+
if (!Number.isFinite(value)) return value;
|
|
175
|
+
if (value === 0) return Number.MIN_VALUE;
|
|
176
|
+
f64[0] = value;
|
|
177
|
+
u64[0] += value > 0 ? 1n : -1n;
|
|
178
|
+
return f64[0];
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
function nextDown(value) {
|
|
182
|
+
if (!Number.isFinite(value)) return value;
|
|
183
|
+
if (value === 0) return -Number.MIN_VALUE;
|
|
184
|
+
f64[0] = value;
|
|
185
|
+
u64[0] += value > 0 ? -1n : 1n;
|
|
186
|
+
return f64[0];
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
function logCompat(input) {
|
|
190
|
+
const value = Math.log(input);
|
|
191
|
+
// V8 and glibc libm differ by one ulp for a few values reached by the
|
|
192
|
+
// Newton-Raphson example. Align this pure-JS port with the native eyelang
|
|
193
|
+
// reference while leaving ordinary log(1), log(2), log(10), and log(e) alone.
|
|
194
|
+
if (input > 2.5 && input < 2.7182818 && value > 0.95 && value < 1.0) return nextUp(value);
|
|
195
|
+
if (input > 2.7182818 && input < 2.718281828459 && value > 0.999999999999 && value < 1.0) return nextDown(value);
|
|
196
|
+
return value;
|
|
197
|
+
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
// Control builtins. These intentionally use bounded nested solvers so not/1 and once/1 only ask for the answers they need.
|
|
2
|
+
export const controlBuiltins = {
|
|
3
|
+
register(registry) {
|
|
4
|
+
registry.add('not', 1, notBuiltin);
|
|
5
|
+
registry.add('once', 1, onceBuiltin);
|
|
6
|
+
}
|
|
7
|
+
};
|
|
8
|
+
|
|
9
|
+
function* notBuiltin({ solver, goal, env }) {
|
|
10
|
+
const limited = solver.cloneForInnerGoal(1);
|
|
11
|
+
let found = false;
|
|
12
|
+
for (const _ of limited.solve([goal.args[0]], env.clone(), 0)) { found = true; break; }
|
|
13
|
+
if (!found) yield env;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
function* onceBuiltin({ solver, goal, env }) {
|
|
17
|
+
const limited = solver.cloneForInnerGoal(1);
|
|
18
|
+
for (const answerEnv of limited.solve([goal.args[0]], env.clone(), 0)) {
|
|
19
|
+
yield answerEnv;
|
|
20
|
+
break;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
// Core relational builtins that do not naturally belong to arithmetic, strings, lists, or aggregation.
|
|
2
|
+
// They are deterministic filters/projections and should avoid enumerating additional answers.
|
|
3
|
+
import { stringTerm, lexicalValue, unify } from '../term.mjs';
|
|
4
|
+
|
|
5
|
+
function* ok(env) { yield env; }
|
|
6
|
+
|
|
7
|
+
export const coreBuiltins = {
|
|
8
|
+
register(registry) {
|
|
9
|
+
registry.add('eq', 2, function* ({ goal, env }) {
|
|
10
|
+
const next = env.clone();
|
|
11
|
+
if (unify(goal.args[0], goal.args[1], next)) yield next;
|
|
12
|
+
}, { deterministic: true });
|
|
13
|
+
|
|
14
|
+
registry.add('neq', 2, function* ({ goal, env }) {
|
|
15
|
+
const attempt = env.clone();
|
|
16
|
+
if (!unify(goal.args[0], goal.args[1], attempt)) yield env;
|
|
17
|
+
}, { deterministic: true });
|
|
18
|
+
|
|
19
|
+
registry.add('local_time', 1, function* ({ goal, env }) {
|
|
20
|
+
const next = env.clone();
|
|
21
|
+
if (unify(goal.args[0], stringTerm(localDateText()), next)) yield next;
|
|
22
|
+
}, { deterministic: true });
|
|
23
|
+
|
|
24
|
+
registry.add('difference', 3, function* ({ goal, env }) {
|
|
25
|
+
const endText = lexicalValue(goal.args[0], env);
|
|
26
|
+
const startText = lexicalValue(goal.args[1], env);
|
|
27
|
+
if (!endText || !startText) return;
|
|
28
|
+
const end = parseISODate(endText);
|
|
29
|
+
const start = parseISODate(startText);
|
|
30
|
+
if (!end || !start || compareDateParts(end, start) < 0) return;
|
|
31
|
+
let [ey, em, ed] = end;
|
|
32
|
+
const [sy, sm, sd] = start;
|
|
33
|
+
if (ed < sd) {
|
|
34
|
+
let bm = em - 1;
|
|
35
|
+
let by = ey;
|
|
36
|
+
if (bm === 0) { bm = 12; by--; }
|
|
37
|
+
ed += daysInMonth(by, bm);
|
|
38
|
+
em--;
|
|
39
|
+
if (em === 0) { em = 12; ey--; }
|
|
40
|
+
}
|
|
41
|
+
if (em < sm) { em += 12; ey--; }
|
|
42
|
+
const duration = formatDuration(ey - sy, em - sm, ed - sd);
|
|
43
|
+
const next = env.clone();
|
|
44
|
+
if (unify(goal.args[2], stringTerm(duration), next)) yield next;
|
|
45
|
+
}, { deterministic: true });
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
|
|
49
|
+
|
|
50
|
+
function localDateText() {
|
|
51
|
+
const fixed = typeof process !== 'undefined' ? process.env?.EYELANG_LOCAL_TIME : null;
|
|
52
|
+
if (fixed) return fixed;
|
|
53
|
+
|
|
54
|
+
const now = new Date();
|
|
55
|
+
const yyyy = now.getFullYear();
|
|
56
|
+
const mm = String(now.getMonth() + 1).padStart(2, '0');
|
|
57
|
+
const dd = String(now.getDate()).padStart(2, '0');
|
|
58
|
+
return `${yyyy}-${mm}-${dd}`;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
function parseISODate(text) {
|
|
62
|
+
const m = /^(\d{4})-(\d{2})-(\d{2})/.exec(text);
|
|
63
|
+
if (!m) return null;
|
|
64
|
+
const y = Number(m[1]), mo = Number(m[2]), d = Number(m[3]);
|
|
65
|
+
if (mo < 1 || mo > 12 || d < 1 || d > daysInMonth(y, mo)) return null;
|
|
66
|
+
return [y, mo, d];
|
|
67
|
+
}
|
|
68
|
+
function daysInMonth(y, m) {
|
|
69
|
+
return [0,31,((y%4===0&&y%100!==0)||y%400===0)?29:28,31,30,31,30,31,31,30,31,30,31][m] ?? 0;
|
|
70
|
+
}
|
|
71
|
+
function compareDateParts(a, b) {
|
|
72
|
+
for (let i = 0; i < 3; i++) if (a[i] !== b[i]) return a[i] < b[i] ? -1 : 1;
|
|
73
|
+
return 0;
|
|
74
|
+
}
|
|
75
|
+
function formatDuration(y, m, d) {
|
|
76
|
+
if (y === 0 && m === 0 && d === 0) return 'P0D';
|
|
77
|
+
return `P${y ? `${y}Y` : ''}${m ? `${m}M` : ''}${d ? `${d}D` : ''}`;
|
|
78
|
+
}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
// Formula builtins that treat conjunctions as first-class data terms.
|
|
2
|
+
// These are used by examples that construct or inspect rule bodies programmatically.
|
|
3
|
+
import { atom, deref, isConjunction, unify } from '../term.mjs';
|
|
4
|
+
|
|
5
|
+
export const formulaBuiltins = {
|
|
6
|
+
register(registry) {
|
|
7
|
+
registry.add('formula_atom', 2, formulaAtom);
|
|
8
|
+
registry.add('formula_binary', 4, formulaBinary);
|
|
9
|
+
}
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
function* emitFormulaAtoms(formula, target, env) {
|
|
13
|
+
formula = deref(formula, env);
|
|
14
|
+
if (isConjunction(formula)) {
|
|
15
|
+
yield* emitFormulaAtoms(formula.args[0], target, env);
|
|
16
|
+
yield* emitFormulaAtoms(formula.args[1], target, env);
|
|
17
|
+
return;
|
|
18
|
+
}
|
|
19
|
+
if (formula.type !== 'compound') return;
|
|
20
|
+
const next = env.clone();
|
|
21
|
+
if (unify(target, formula, next)) yield next;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
function* formulaAtom({ goal, env }) {
|
|
25
|
+
yield* emitFormulaAtoms(goal.args[0], goal.args[1], env);
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
function* emitFormulaBinary(formula, subject, predicate, object, env) {
|
|
29
|
+
formula = deref(formula, env);
|
|
30
|
+
if (isConjunction(formula)) {
|
|
31
|
+
yield* emitFormulaBinary(formula.args[0], subject, predicate, object, env);
|
|
32
|
+
yield* emitFormulaBinary(formula.args[1], subject, predicate, object, env);
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
if (formula.type !== 'compound' || formula.arity !== 2) return;
|
|
36
|
+
const next = env.clone();
|
|
37
|
+
if (unify(subject, formula.args[0], next) && unify(predicate, atom(formula.name), next) && unify(object, formula.args[1], next)) yield next;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
function* formulaBinary({ goal, env }) {
|
|
41
|
+
yield* emitFormulaBinary(goal.args[0], goal.args[1], goal.args[2], goal.args[3], env);
|
|
42
|
+
}
|
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
// List builtins for proper lists, selection, membership, sorting, and indexing.
|
|
2
|
+
// Several predicates support both checking and generation, so the argument modes are handled explicitly.
|
|
3
|
+
import { compareTerms, copyResolved, deref, isCons, lexicalValue, listFromItems, numberTerm, properListItems, unify } from '../term.mjs';
|
|
4
|
+
|
|
5
|
+
export const listBuiltins = {
|
|
6
|
+
register(registry) {
|
|
7
|
+
registry.add('append', 3, append);
|
|
8
|
+
registry.add('nth0', 3, nth0);
|
|
9
|
+
registry.add('set_nth0', 4, setNth0, { deterministic: true });
|
|
10
|
+
registry.add('rest', 2, rest, { deterministic: true });
|
|
11
|
+
registry.add('member', 2, member);
|
|
12
|
+
registry.add('select', 3, select);
|
|
13
|
+
registry.add('not_member', 2, notMember, { deterministic: true });
|
|
14
|
+
registry.add('reverse', 2, reverse, { deterministic: true });
|
|
15
|
+
registry.add('length', 2, lengthBuiltin, { deterministic: true });
|
|
16
|
+
registry.add('is_list', 1, isList, { deterministic: true });
|
|
17
|
+
registry.add('sort', 2, sortBuiltin, { deterministic: true });
|
|
18
|
+
}
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
function listFromItemsExcept(items, skip) {
|
|
23
|
+
const copy = new Array(items.length - 1);
|
|
24
|
+
for (let i = 0, j = 0; i < items.length; i++) if (i !== skip) copy[j++] = items[i];
|
|
25
|
+
return listFromItems(copy);
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
function* append({ goal, env }) {
|
|
29
|
+
let items = properListItems(goal.args[0], env);
|
|
30
|
+
if (items) {
|
|
31
|
+
const result = listFromItems(items, 0, items.length, deref(goal.args[1], env));
|
|
32
|
+
const next = env.clone();
|
|
33
|
+
if (unify(goal.args[2], result, next)) yield next;
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
items = properListItems(goal.args[2], env);
|
|
37
|
+
if (!items) return;
|
|
38
|
+
for (let split = 0; split <= items.length; split++) {
|
|
39
|
+
const prefix = listFromItems(items, 0, split);
|
|
40
|
+
const suffix = listFromItems(items, split, items.length);
|
|
41
|
+
const next = env.clone();
|
|
42
|
+
if (unify(goal.args[0], prefix, next) && unify(goal.args[1], suffix, next)) yield next;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
function* nth0({ goal, env }) {
|
|
47
|
+
const items = properListItems(goal.args[1], env);
|
|
48
|
+
if (!items) return;
|
|
49
|
+
const indexText = lexicalValue(goal.args[0], env);
|
|
50
|
+
if (/^-?\d+$/.test(indexText ?? '')) {
|
|
51
|
+
const index = Number(indexText);
|
|
52
|
+
if (Number.isSafeInteger(index) && index >= 0 && index < items.length) {
|
|
53
|
+
const next = env.clone();
|
|
54
|
+
if (unify(goal.args[2], items[index], next)) yield next;
|
|
55
|
+
}
|
|
56
|
+
return;
|
|
57
|
+
}
|
|
58
|
+
if (deref(goal.args[0], env).type !== 'var') return;
|
|
59
|
+
for (let i = 0; i < items.length; i++) {
|
|
60
|
+
const next = env.clone();
|
|
61
|
+
if (unify(goal.args[0], numberTerm(i), next) && unify(goal.args[2], items[i], next)) yield next;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
function* setNth0({ goal, env }) {
|
|
66
|
+
const indexText = lexicalValue(goal.args[0], env);
|
|
67
|
+
if (!/^-?\d+$/.test(indexText ?? '')) return;
|
|
68
|
+
const index = Number(indexText);
|
|
69
|
+
if (!Number.isSafeInteger(index) || index < 0) return;
|
|
70
|
+
const items = properListItems(goal.args[1], env);
|
|
71
|
+
if (!items || index >= items.length) return;
|
|
72
|
+
const out = items.slice();
|
|
73
|
+
out[index] = goal.args[2];
|
|
74
|
+
const next = env.clone();
|
|
75
|
+
if (unify(goal.args[3], listFromItems(out), next)) yield next;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
function* rest({ goal, env }) {
|
|
79
|
+
const list = deref(goal.args[0], env);
|
|
80
|
+
if (!isCons(list)) return;
|
|
81
|
+
const next = env.clone();
|
|
82
|
+
if (unify(goal.args[1], list.args[1], next)) yield next;
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
function* member({ goal, env }) {
|
|
86
|
+
const items = properListItems(goal.args[1], env);
|
|
87
|
+
if (!items) return;
|
|
88
|
+
for (const item of items) {
|
|
89
|
+
const next = env.clone();
|
|
90
|
+
if (unify(goal.args[0], item, next)) yield next;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
function* select({ goal, env }) {
|
|
95
|
+
const items = properListItems(goal.args[1], env);
|
|
96
|
+
if (!items) return;
|
|
97
|
+
for (let i = 0; i < items.length; i++) {
|
|
98
|
+
const next = env.clone();
|
|
99
|
+
if (unify(goal.args[0], items[i], next) && unify(goal.args[2], listFromItemsExcept(items, i), next)) yield next;
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
function* notMember({ goal, env }) {
|
|
104
|
+
const items = properListItems(goal.args[1], env);
|
|
105
|
+
if (!items) return;
|
|
106
|
+
const value = deref(goal.args[0], env);
|
|
107
|
+
if (value.type === 'number' || value.type === 'atom' || value.type === 'string') {
|
|
108
|
+
for (const item of items) {
|
|
109
|
+
const resolved = deref(item, env);
|
|
110
|
+
if (resolved.type === value.type && resolved.name === value.name) return;
|
|
111
|
+
}
|
|
112
|
+
yield env;
|
|
113
|
+
return;
|
|
114
|
+
}
|
|
115
|
+
for (const item of items) {
|
|
116
|
+
const attempt = env.clone();
|
|
117
|
+
if (unify(goal.args[0], item, attempt)) return;
|
|
118
|
+
}
|
|
119
|
+
yield env;
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
function* reverse({ goal, env }) {
|
|
123
|
+
const items = properListItems(goal.args[0], env);
|
|
124
|
+
if (!items) return;
|
|
125
|
+
const next = env.clone();
|
|
126
|
+
if (unify(goal.args[1], listFromItems([...items].reverse()), next)) yield next;
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
function* lengthBuiltin({ goal, env }) {
|
|
130
|
+
const items = properListItems(goal.args[0], env);
|
|
131
|
+
if (!items) return;
|
|
132
|
+
const next = env.clone();
|
|
133
|
+
if (unify(goal.args[1], numberTerm(items.length), next)) yield next;
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
function* isList({ goal, env }) {
|
|
137
|
+
const items = properListItems(goal.args[0], env);
|
|
138
|
+
if (items) yield env;
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
function* sortBuiltin({ goal, env }) {
|
|
142
|
+
const items = properListItems(goal.args[0], env);
|
|
143
|
+
if (!items) return;
|
|
144
|
+
const sorted = items.map((item) => copyResolved(item, env)).sort(compareTerms);
|
|
145
|
+
const unique = [];
|
|
146
|
+
for (const item of sorted) if (unique.length === 0 || compareTerms(unique[unique.length - 1], item) !== 0) unique.push(item);
|
|
147
|
+
const next = env.clone();
|
|
148
|
+
if (unify(goal.args[1], listFromItems(unique), next)) yield next;
|
|
149
|
+
}
|