eyelang 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE.md +9 -0
- package/README.md +61 -0
- package/bin/eyelang.js +7 -0
- package/docs/guide.md +525 -0
- package/docs/language-reference.md +697 -0
- package/examples/access-control-policy.pl +52 -0
- package/examples/ackermann.pl +46 -0
- package/examples/age.pl +28 -0
- package/examples/aliases-and-namespaces.pl +22 -0
- package/examples/alignment-demo.pl +44 -0
- package/examples/allen-interval-calculus.pl +64 -0
- package/examples/ancestor.pl +21 -0
- package/examples/animal.pl +21 -0
- package/examples/annotation.pl +34 -0
- package/examples/auroracare.pl +309 -0
- package/examples/backward.pl +12 -0
- package/examples/basic-monadic.pl +10032 -0
- package/examples/bayes-diagnosis.pl +108 -0
- package/examples/bayes-therapy.pl +182 -0
- package/examples/beam-deflection.pl +50 -0
- package/examples/blocks-world-planning.pl +75 -0
- package/examples/bmi.pl +232 -0
- package/examples/braking-safety-worlds.pl +69 -0
- package/examples/buck-converter-design.pl +78 -0
- package/examples/cache-performance.pl +54 -0
- package/examples/canary-release.pl +49 -0
- package/examples/cat-koko.pl +24 -0
- package/examples/clinical-trial-screening.pl +92 -0
- package/examples/combinatorics-findall-sort.pl +37 -0
- package/examples/competitive-enzyme-kinetics.pl +78 -0
- package/examples/complex.pl +121 -0
- package/examples/composition-of-injective-functions-is-injective.pl +50 -0
- package/examples/context-association.pl +53 -0
- package/examples/context-schema-audit.pl +46 -0
- package/examples/control-system.pl +72 -0
- package/examples/cyclic-path.pl +16 -0
- package/examples/d3-group.pl +100 -0
- package/examples/dairy-energy-balance.pl +65 -0
- package/examples/data-negotiation.pl +39 -0
- package/examples/deep-taxonomy-10.pl +115 -0
- package/examples/deep-taxonomy-100.pl +385 -0
- package/examples/deep-taxonomy-1000.pl +3085 -0
- package/examples/deep-taxonomy-10000.pl +30094 -0
- package/examples/deep-taxonomy-100000.pl +300184 -0
- package/examples/delfour.pl +281 -0
- package/examples/deontic-logic.pl +52 -0
- package/examples/derived-backward-rule.pl +30 -0
- package/examples/derived-rule.pl +27 -0
- package/examples/diamond-property.pl +38 -0
- package/examples/dijkstra-findall-sort.pl +44 -0
- package/examples/dijkstra-risk-path.pl +86 -0
- package/examples/dijkstra.pl +46 -0
- package/examples/dining-philosophers.pl +140 -0
- package/examples/dog.pl +25 -0
- package/examples/dpv-odrl-purpose-mapping.pl +46 -0
- package/examples/drone-corridor-planner.pl +51 -0
- package/examples/easter-computus.pl +89 -0
- package/examples/electrical-rc-filter.pl +36 -0
- package/examples/epidemic-policy.pl +67 -0
- package/examples/equivalence-classes-overlap-implies-same-class.pl +27 -0
- package/examples/eulerian-path.pl +85 -0
- package/examples/ev-range-worlds.pl +82 -0
- package/examples/existential-rule.pl +18 -0
- package/examples/exoplanet-validation-worlds.pl +88 -0
- package/examples/expression-eval.pl +43 -0
- package/examples/family-cousins.pl +65 -0
- package/examples/fastpow.pl +53 -0
- package/examples/fft8-numeric.pl +83 -0
- package/examples/fibonacci.pl +53 -0
- package/examples/field-nitrogen-balance.pl +70 -0
- package/examples/flandor.pl +296 -0
- package/examples/floating-point.pl +23 -0
- package/examples/four-color-map.pl +127 -0
- package/examples/fundamental-theorem-arithmetic.pl +113 -0
- package/examples/gd-step-certified.pl +158 -0
- package/examples/gdpr-compliance.pl +69 -0
- package/examples/good-cobbler.pl +14 -0
- package/examples/gps.pl +152 -0
- package/examples/graph-reachability.pl +36 -0
- package/examples/gray-code-counter.pl +48 -0
- package/examples/greatest-lower-bound-uniqueness.pl +28 -0
- package/examples/group-inverse-uniqueness.pl +34 -0
- package/examples/hamiltonian-path.pl +49 -0
- package/examples/hamming-code.pl +105 -0
- package/examples/hanoi.pl +20 -0
- package/examples/heat-loss.pl +51 -0
- package/examples/heron-theorem.pl +36 -0
- package/examples/ideal-gas-law.pl +37 -0
- package/examples/illegitimate-reasoning.pl +88 -0
- package/examples/knowledge-engineering-alignment-flow.pl +40 -0
- package/examples/law-of-cosines.pl +31 -0
- package/examples/least-squares-regression.pl +81 -0
- package/examples/list-collection.pl +33 -0
- package/examples/lldm.pl +78 -0
- package/examples/manufacturing-quality-control.pl +73 -0
- package/examples/microgrid-dispatch.pl +85 -0
- package/examples/monkey-bananas.pl +45 -0
- package/examples/network-sla.pl +48 -0
- package/examples/newton-raphson.pl +49 -0
- package/examples/nixon-diamond.pl +37 -0
- package/examples/observability-log-correlation.pl +34 -0
- package/examples/odrl-dpv-fpv-trust-flow.pl +43 -0
- package/examples/odrl-dpv-healthcare-risk-ranked.pl +266 -0
- package/examples/odrl-dpv-risk-ranked.pl +320 -0
- package/examples/orbital-transfer-design.pl +113 -0
- package/examples/output/access-control-policy.pl +2 -0
- package/examples/output/ackermann.pl +12 -0
- package/examples/output/age.pl +2 -0
- package/examples/output/aliases-and-namespaces.pl +5 -0
- package/examples/output/alignment-demo.pl +32 -0
- package/examples/output/allen-interval-calculus.pl +154 -0
- package/examples/output/ancestor.pl +6 -0
- package/examples/output/animal.pl +4 -0
- package/examples/output/annotation.pl +4 -0
- package/examples/output/auroracare.pl +117 -0
- package/examples/output/backward.pl +1 -0
- package/examples/output/basic-monadic.pl +1518 -0
- package/examples/output/bayes-diagnosis.pl +13 -0
- package/examples/output/bayes-therapy.pl +23 -0
- package/examples/output/beam-deflection.pl +5 -0
- package/examples/output/blocks-world-planning.pl +4 -0
- package/examples/output/bmi.pl +32 -0
- package/examples/output/braking-safety-worlds.pl +18 -0
- package/examples/output/buck-converter-design.pl +6 -0
- package/examples/output/cache-performance.pl +4 -0
- package/examples/output/canary-release.pl +5 -0
- package/examples/output/cat-koko.pl +3 -0
- package/examples/output/clinical-trial-screening.pl +9 -0
- package/examples/output/combinatorics-findall-sort.pl +2 -0
- package/examples/output/competitive-enzyme-kinetics.pl +6 -0
- package/examples/output/complex.pl +1 -0
- package/examples/output/composition-of-injective-functions-is-injective.pl +2 -0
- package/examples/output/context-association.pl +3 -0
- package/examples/output/context-schema-audit.pl +12 -0
- package/examples/output/control-system.pl +6 -0
- package/examples/output/cyclic-path.pl +16 -0
- package/examples/output/d3-group.pl +2 -0
- package/examples/output/dairy-energy-balance.pl +13 -0
- package/examples/output/data-negotiation.pl +1 -0
- package/examples/output/deep-taxonomy-10.pl +16 -0
- package/examples/output/deep-taxonomy-100.pl +16 -0
- package/examples/output/deep-taxonomy-1000.pl +16 -0
- package/examples/output/deep-taxonomy-10000.pl +16 -0
- package/examples/output/deep-taxonomy-100000.pl +16 -0
- package/examples/output/delfour.pl +31 -0
- package/examples/output/deontic-logic.pl +4 -0
- package/examples/output/derived-backward-rule.pl +3 -0
- package/examples/output/derived-rule.pl +2 -0
- package/examples/output/diamond-property.pl +4 -0
- package/examples/output/dijkstra-findall-sort.pl +2 -0
- package/examples/output/dijkstra-risk-path.pl +29 -0
- package/examples/output/dijkstra.pl +16 -0
- package/examples/output/dining-philosophers.pl +350 -0
- package/examples/output/dog.pl +1 -0
- package/examples/output/dpv-odrl-purpose-mapping.pl +18 -0
- package/examples/output/drone-corridor-planner.pl +17 -0
- package/examples/output/easter-computus.pl +30 -0
- package/examples/output/electrical-rc-filter.pl +3 -0
- package/examples/output/epidemic-policy.pl +14 -0
- package/examples/output/equivalence-classes-overlap-implies-same-class.pl +18 -0
- package/examples/output/eulerian-path.pl +3 -0
- package/examples/output/ev-range-worlds.pl +19 -0
- package/examples/output/existential-rule.pl +2 -0
- package/examples/output/exoplanet-validation-worlds.pl +22 -0
- package/examples/output/expression-eval.pl +1 -0
- package/examples/output/family-cousins.pl +28 -0
- package/examples/output/fastpow.pl +6 -0
- package/examples/output/fft8-numeric.pl +4 -0
- package/examples/output/fibonacci.pl +6 -0
- package/examples/output/field-nitrogen-balance.pl +21 -0
- package/examples/output/flandor.pl +43 -0
- package/examples/output/floating-point.pl +9 -0
- package/examples/output/four-color-map.pl +3 -0
- package/examples/output/fundamental-theorem-arithmetic.pl +9 -0
- package/examples/output/gd-step-certified.pl +79 -0
- package/examples/output/gdpr-compliance.pl +6 -0
- package/examples/output/good-cobbler.pl +1 -0
- package/examples/output/gps.pl +21 -0
- package/examples/output/graph-reachability.pl +3 -0
- package/examples/output/gray-code-counter.pl +1 -0
- package/examples/output/greatest-lower-bound-uniqueness.pl +2 -0
- package/examples/output/group-inverse-uniqueness.pl +2 -0
- package/examples/output/hamiltonian-path.pl +121 -0
- package/examples/output/hamming-code.pl +6 -0
- package/examples/output/hanoi.pl +1 -0
- package/examples/output/heat-loss.pl +5 -0
- package/examples/output/heron-theorem.pl +4 -0
- package/examples/output/ideal-gas-law.pl +3 -0
- package/examples/output/illegitimate-reasoning.pl +15 -0
- package/examples/output/knowledge-engineering-alignment-flow.pl +17 -0
- package/examples/output/law-of-cosines.pl +3 -0
- package/examples/output/least-squares-regression.pl +5 -0
- package/examples/output/list-collection.pl +3 -0
- package/examples/output/lldm.pl +6 -0
- package/examples/output/manufacturing-quality-control.pl +6 -0
- package/examples/output/microgrid-dispatch.pl +6 -0
- package/examples/output/monkey-bananas.pl +5 -0
- package/examples/output/network-sla.pl +4 -0
- package/examples/output/newton-raphson.pl +3 -0
- package/examples/output/nixon-diamond.pl +5 -0
- package/examples/output/observability-log-correlation.pl +28 -0
- package/examples/output/odrl-dpv-fpv-trust-flow.pl +9 -0
- package/examples/output/odrl-dpv-healthcare-risk-ranked.pl +42 -0
- package/examples/output/odrl-dpv-risk-ranked.pl +120 -0
- package/examples/output/orbital-transfer-design.pl +7 -0
- package/examples/output/path-discovery.pl +3 -0
- package/examples/output/peano-arithmetic.pl +3 -0
- package/examples/output/peasant.pl +10 -0
- package/examples/output/pendulum-period.pl +4 -0
- package/examples/output/polynomial.pl +14 -0
- package/examples/output/proof-contrapositive.pl +3 -0
- package/examples/output/quadratic-formula.pl +6 -0
- package/examples/output/radioactive-decay.pl +5 -0
- package/examples/output/reusable-builtins.pl +5 -0
- package/examples/output/riemann-hypothesis.pl +12 -0
- package/examples/output/security-incident-correlation.pl +3 -0
- package/examples/output/service-impact.pl +11 -0
- package/examples/output/sieve.pl +1 -0
- package/examples/output/skolem-functions.pl +16 -0
- package/examples/output/socket-age.pl +1 -0
- package/examples/output/socket-family.pl +3 -0
- package/examples/output/socrates.pl +2 -0
- package/examples/output/statistics-summary.pl +4 -0
- package/examples/output/superdense-coding.pl +6 -0
- package/examples/output/term-tools.pl +6 -0
- package/examples/output/trust-flow-provenance-threshold.pl +6 -0
- package/examples/output/turing.pl +12 -0
- package/examples/output/vector-similarity.pl +4 -0
- package/examples/output/vulnerability-impact.pl +20 -0
- package/examples/output/witch.pl +7 -0
- package/examples/output/wolf-goat-cabbage.pl +3 -0
- package/examples/output/zebra.pl +3 -0
- package/examples/path-discovery.pl +45013 -0
- package/examples/peano-arithmetic.pl +31 -0
- package/examples/peasant.pl +30 -0
- package/examples/pendulum-period.pl +50 -0
- package/examples/polynomial.pl +124 -0
- package/examples/proof/age.pl +71 -0
- package/examples/proof/aliases-and-namespaces.pl +78 -0
- package/examples/proof/ancestor.pl +140 -0
- package/examples/proof/animal.pl +68 -0
- package/examples/proof/annotation.pl +80 -0
- package/examples/proof/backward.pl +22 -0
- package/examples/proof/cat-koko.pl +86 -0
- package/examples/proof/data-negotiation.pl +76 -0
- package/examples/proof/derived-rule.pl +43 -0
- package/examples/proof/dog.pl +31 -0
- package/examples/proof/electrical-rc-filter.pl +105 -0
- package/examples/proof/existential-rule.pl +40 -0
- package/examples/proof/floating-point.pl +160 -0
- package/examples/proof/good-cobbler.pl +16 -0
- package/examples/proof/group-inverse-uniqueness.pl +84 -0
- package/examples/proof/list-collection.pl +52 -0
- package/examples/proof/proof-contrapositive.pl +78 -0
- package/examples/proof/socket-age.pl +32 -0
- package/examples/proof/socket-family.pl +59 -0
- package/examples/proof/socrates.pl +38 -0
- package/examples/proof-contrapositive.pl +27 -0
- package/examples/quadratic-formula.pl +54 -0
- package/examples/radioactive-decay.pl +56 -0
- package/examples/reusable-builtins.pl +32 -0
- package/examples/riemann-hypothesis.pl +110 -0
- package/examples/security-incident-correlation.pl +69 -0
- package/examples/service-impact.pl +41 -0
- package/examples/sieve.pl +20 -0
- package/examples/skolem-functions.pl +52 -0
- package/examples/socket-age.pl +39 -0
- package/examples/socket-family.pl +28 -0
- package/examples/socrates.pl +19 -0
- package/examples/statistics-summary.pl +54 -0
- package/examples/superdense-coding.pl +84 -0
- package/examples/term-tools.pl +23 -0
- package/examples/trust-flow-provenance-threshold.pl +40 -0
- package/examples/turing.pl +67 -0
- package/examples/vector-similarity.pl +56 -0
- package/examples/vulnerability-impact.pl +70 -0
- package/examples/witch.pl +38 -0
- package/examples/wolf-goat-cabbage.pl +56 -0
- package/examples/zebra.pl +44 -0
- package/index.d.ts +80 -0
- package/index.js +4 -0
- package/package.json +48 -0
- package/src/bin.js +7 -0
- package/src/builtins/aggregation.js +81 -0
- package/src/builtins/arithmetic.js +208 -0
- package/src/builtins/context.js +42 -0
- package/src/builtins/control.js +34 -0
- package/src/builtins/core.js +78 -0
- package/src/builtins/lists.js +283 -0
- package/src/builtins/registry.js +48 -0
- package/src/builtins/strings.js +234 -0
- package/src/builtins/terms.js +66 -0
- package/src/cli.js +180 -0
- package/src/explain.js +324 -0
- package/src/hash.js +294 -0
- package/src/index.js +47 -0
- package/src/parser.js +428 -0
- package/src/program.js +237 -0
- package/src/solver.js +237 -0
- package/src/term.js +328 -0
- package/test/conformance/README.md +43 -0
- package/test/conformance/cases/001_fact_output.pl +4 -0
- package/test/conformance/cases/002_rule_recursion.pl +7 -0
- package/test/conformance/cases/002_rule_recursion.query +1 -0
- package/test/conformance/cases/003_terms_and_readback.pl +16 -0
- package/test/conformance/cases/003_terms_and_readback.query +1 -0
- package/test/conformance/cases/004_conjunction_and_parentheses.pl +5 -0
- package/test/conformance/cases/004_conjunction_and_parentheses.query +1 -0
- package/test/conformance/cases/005_list_deconstruction.pl +6 -0
- package/test/conformance/cases/005_list_deconstruction.query +1 -0
- package/test/conformance/cases/006_comma_formula_data.pl +4 -0
- package/test/conformance/cases/006_comma_formula_data.query +1 -0
- package/test/conformance/cases/007_anonymous_variables.pl +5 -0
- package/test/conformance/cases/007_anonymous_variables.query +1 -0
- package/test/conformance/cases/008_graphic_atoms.pl +6 -0
- package/test/conformance/cases/008_graphic_atoms.query +1 -0
- package/test/conformance/cases/009_comments_and_whitespace.pl +5 -0
- package/test/conformance/cases/009_comments_and_whitespace.query +1 -0
- package/test/conformance/cases/010_variable_scope_and_reuse.pl +8 -0
- package/test/conformance/cases/010_variable_scope_and_reuse.query +1 -0
- package/test/conformance/cases/011_predicate_arity.pl +6 -0
- package/test/conformance/cases/011_predicate_arity.query +1 -0
- package/test/conformance/cases/012_nested_compound_unification.pl +5 -0
- package/test/conformance/cases/012_nested_compound_unification.query +1 -0
- package/test/conformance/cases/013_multiple_clauses_order.pl +6 -0
- package/test/conformance/cases/013_multiple_clauses_order.query +1 -0
- package/test/conformance/cases/014_failure_filters_answers.pl +7 -0
- package/test/conformance/cases/014_failure_filters_answers.query +1 -0
- package/test/conformance/cases/015_improper_list_unification.pl +6 -0
- package/test/conformance/cases/015_improper_list_unification.query +1 -0
- package/test/conformance/cases/016_zero_arity_compound.pl +4 -0
- package/test/conformance/cases/016_zero_arity_compound.query +1 -0
- package/test/conformance/cases/017_three_step_recursion.pl +8 -0
- package/test/conformance/cases/017_three_step_recursion.query +1 -0
- package/test/conformance/cases/018_quoted_atom_readback.pl +6 -0
- package/test/conformance/cases/018_quoted_atom_readback.query +1 -0
- package/test/conformance/cases/019_parenthesized_three_conjuncts.pl +7 -0
- package/test/conformance/cases/019_parenthesized_three_conjuncts.query +1 -0
- package/test/conformance/cases/020_nested_list_terms.pl +5 -0
- package/test/conformance/cases/020_nested_list_terms.query +1 -0
- package/test/conformance/cases/021_repeated_variable_head.pl +7 -0
- package/test/conformance/cases/022_rule_head_structure.pl +5 -0
- package/test/conformance/cases/023_quoted_escapes_readback.pl +5 -0
- package/test/conformance/cases/024_numeric_literal_readback.pl +6 -0
- package/test/conformance/cases/025_body_parentheses_with_formula_data.pl +5 -0
- package/test/conformance/cases/026_underscore_named_variable_reuse.pl +5 -0
- package/test/conformance/cases/027_default_derived_output.pl +5 -0
- package/test/conformance/cases/028_materialize_focus.pl +5 -0
- package/test/conformance/cases/029_arithmetic_and_comparison.pl +11 -0
- package/test/conformance/cases/029_arithmetic_and_comparison.query +1 -0
- package/test/conformance/cases/030_strings_and_atoms.pl +4 -0
- package/test/conformance/cases/030_strings_and_atoms.query +1 -0
- package/test/conformance/cases/031_lists_aggregation_ordering.pl +10 -0
- package/test/conformance/cases/031_lists_aggregation_ordering.query +1 -0
- package/test/conformance/cases/032_holds_parts.pl +4 -0
- package/test/conformance/cases/033_negation_once_generators.pl +7 -0
- package/test/conformance/cases/033_negation_once_generators.query +1 -0
- package/test/conformance/cases/034_equality_and_inequality.pl +6 -0
- package/test/conformance/cases/034_equality_and_inequality.query +1 -0
- package/test/conformance/cases/035_list_relations.pl +5 -0
- package/test/conformance/cases/035_list_relations.query +1 -0
- package/test/conformance/cases/036_append_splits.pl +3 -0
- package/test/conformance/cases/036_append_splits.query +1 -0
- package/test/conformance/cases/037_matching_and_comparison.pl +7 -0
- package/test/conformance/cases/037_matching_and_comparison.query +1 -0
- package/test/conformance/cases/038_memoize_declaration.pl +8 -0
- package/test/conformance/cases/038_memoize_declaration.query +1 -0
- package/test/conformance/cases/039_numeric_functions.pl +9 -0
- package/test/conformance/cases/039_numeric_functions.query +1 -0
- package/test/conformance/cases/040_between_enumeration.pl +3 -0
- package/test/conformance/cases/040_between_enumeration.query +1 -0
- package/test/conformance/cases/041_smallest_divisor.pl +3 -0
- package/test/conformance/cases/041_smallest_divisor.query +1 -0
- package/test/conformance/cases/042_negation_filter.pl +7 -0
- package/test/conformance/cases/042_negation_filter.query +1 -0
- package/test/conformance/cases/043_once_user_predicate.pl +5 -0
- package/test/conformance/cases/043_once_user_predicate.query +1 -0
- package/test/conformance/cases/044_findall_user_goal.pl +6 -0
- package/test/conformance/cases/044_findall_user_goal.query +1 -0
- package/test/conformance/cases/045_sort_deduplicates_atoms.pl +3 -0
- package/test/conformance/cases/045_sort_deduplicates_atoms.query +1 -0
- package/test/conformance/cases/046_append_bound_prefix_suffix.pl +4 -0
- package/test/conformance/cases/046_append_bound_prefix_suffix.query +1 -0
- package/test/conformance/cases/047_nth0_index_generation.pl +3 -0
- package/test/conformance/cases/047_nth0_index_generation.query +1 -0
- package/test/conformance/cases/048_set_nth0_edges.pl +4 -0
- package/test/conformance/cases/048_set_nth0_edges.query +1 -0
- package/test/conformance/cases/049_select_duplicate_occurrences.pl +3 -0
- package/test/conformance/cases/049_select_duplicate_occurrences.query +1 -0
- package/test/conformance/cases/050_not_member_filter.pl +6 -0
- package/test/conformance/cases/050_not_member_filter.query +1 -0
- package/test/conformance/cases/051_nested_holds_parts.pl +4 -0
- package/test/conformance/cases/052_holds_member.pl +3 -0
- package/test/conformance/cases/053_materialize_excludes_source_fact.pl +6 -0
- package/test/conformance/cases/054_numeric_and_lexical_comparison.pl +5 -0
- package/test/conformance/cases/054_numeric_and_lexical_comparison.query +1 -0
- package/test/conformance/cases/055_string_matching_filters.pl +6 -0
- package/test/conformance/cases/055_string_matching_filters.query +1 -0
- package/test/conformance/cases/056_string_and_atom_concat.pl +3 -0
- package/test/conformance/cases/056_string_and_atom_concat.query +1 -0
- package/test/conformance/cases/057_countall_empty_and_nonempty.pl +4 -0
- package/test/conformance/cases/057_countall_empty_and_nonempty.query +1 -0
- package/test/conformance/cases/058_sumall_numeric_template.pl +5 -0
- package/test/conformance/cases/058_sumall_numeric_template.query +1 -0
- package/test/conformance/cases/059_aggregate_min_template.pl +5 -0
- package/test/conformance/cases/059_aggregate_min_template.query +1 -0
- package/test/conformance/cases/060_aggregate_max_compound_key.pl +5 -0
- package/test/conformance/cases/060_aggregate_max_compound_key.query +1 -0
- package/test/conformance/cases/061_date_difference.pl +4 -0
- package/test/conformance/cases/062_reusable_numeric_builtins.pl +10 -0
- package/test/conformance/cases/063_reusable_list_builtins.pl +11 -0
- package/test/conformance/cases/064_reusable_string_builtins.pl +12 -0
- package/test/conformance/cases/065_reusable_term_control_builtins.pl +11 -0
- package/test/conformance/cases/066_numeric_edges.pl +14 -0
- package/test/conformance/cases/067_list_edges.pl +10 -0
- package/test/conformance/cases/068_list_generation_order.pl +7 -0
- package/test/conformance/cases/069_list_summaries_and_sets.pl +9 -0
- package/test/conformance/cases/070_matches_named_captures.pl +13 -0
- package/test/conformance/cases/071_string_edges.pl +10 -0
- package/test/conformance/cases/072_string_conversions.pl +10 -0
- package/test/conformance/cases/073_term_introspection_edges.pl +10 -0
- package/test/conformance/cases/074_forall_edges.pl +10 -0
- package/test/conformance/cases/075_aggregation_edges.pl +12 -0
- package/test/conformance/cases/076_composed_reusable_builtins.pl +8 -0
- package/test/conformance/cases/077_recursive_path_with_lists.pl +10 -0
- package/test/conformance/cases/078_mutual_recursion_with_arithmetic.pl +7 -0
- package/test/conformance/cases/079_big_integer_arithmetic.pl +8 -0
- package/test/conformance/cases/080_rounding_modes.pl +10 -0
- package/test/conformance/cases/081_zero_safe_numeric_functions.pl +9 -0
- package/test/conformance/cases/082_comparison_semantics.pl +10 -0
- package/test/conformance/cases/083_between_modes_and_empty_ranges.pl +8 -0
- package/test/conformance/cases/084_append_and_select_composition.pl +7 -0
- package/test/conformance/cases/085_nth_and_update_edges.pl +8 -0
- package/test/conformance/cases/086_slicing_pipeline.pl +10 -0
- package/test/conformance/cases/087_sort_reverse_length.pl +8 -0
- package/test/conformance/cases/088_list_summaries_failures.pl +8 -0
- package/test/conformance/cases/089_string_split_join_pipeline.pl +7 -0
- package/test/conformance/cases/090_string_substring_replace_edges.pl +9 -0
- package/test/conformance/cases/091_string_case_and_trim.pl +7 -0
- package/test/conformance/cases/092_scalar_string_conversions.pl +9 -0
- package/test/conformance/cases/093_regex_named_captures_context.pl +8 -0
- package/test/conformance/cases/094_context_holds_enumeration.pl +7 -0
- package/test/conformance/cases/095_term_introspection_roundtrip.pl +8 -0
- package/test/conformance/cases/096_functor_scalar_edges.pl +8 -0
- package/test/conformance/cases/097_control_negation_once_forall.pl +13 -0
- package/test/conformance/cases/098_aggregation_nested_templates.pl +11 -0
- package/test/conformance/cases/099_materialize_multiple_arities.pl +8 -0
- package/test/conformance/cases/100_reusable_builtin_workflow.pl +10 -0
- package/test/conformance/expected/001_fact_output.pl +1 -0
- package/test/conformance/expected/002_rule_recursion.pl +2 -0
- package/test/conformance/expected/003_terms_and_readback.pl +13 -0
- package/test/conformance/expected/004_conjunction_and_parentheses.pl +1 -0
- package/test/conformance/expected/005_list_deconstruction.pl +2 -0
- package/test/conformance/expected/006_comma_formula_data.pl +1 -0
- package/test/conformance/expected/007_anonymous_variables.pl +1 -0
- package/test/conformance/expected/008_graphic_atoms.pl +3 -0
- package/test/conformance/expected/009_comments_and_whitespace.pl +2 -0
- package/test/conformance/expected/010_variable_scope_and_reuse.pl +2 -0
- package/test/conformance/expected/011_predicate_arity.pl +2 -0
- package/test/conformance/expected/012_nested_compound_unification.pl +2 -0
- package/test/conformance/expected/013_multiple_clauses_order.pl +2 -0
- package/test/conformance/expected/014_failure_filters_answers.pl +1 -0
- package/test/conformance/expected/015_improper_list_unification.pl +3 -0
- package/test/conformance/expected/016_zero_arity_compound.pl +1 -0
- package/test/conformance/expected/017_three_step_recursion.pl +3 -0
- package/test/conformance/expected/018_quoted_atom_readback.pl +3 -0
- package/test/conformance/expected/019_parenthesized_three_conjuncts.pl +1 -0
- package/test/conformance/expected/020_nested_list_terms.pl +2 -0
- package/test/conformance/expected/021_repeated_variable_head.pl +2 -0
- package/test/conformance/expected/022_rule_head_structure.pl +2 -0
- package/test/conformance/expected/023_quoted_escapes_readback.pl +2 -0
- package/test/conformance/expected/024_numeric_literal_readback.pl +3 -0
- package/test/conformance/expected/025_body_parentheses_with_formula_data.pl +1 -0
- package/test/conformance/expected/026_underscore_named_variable_reuse.pl +1 -0
- package/test/conformance/expected/027_default_derived_output.pl +3 -0
- package/test/conformance/expected/028_materialize_focus.pl +1 -0
- package/test/conformance/expected/029_arithmetic_and_comparison.pl +9 -0
- package/test/conformance/expected/030_strings_and_atoms.pl +2 -0
- package/test/conformance/expected/031_lists_aggregation_ordering.pl +9 -0
- package/test/conformance/expected/032_holds_parts.pl +3 -0
- package/test/conformance/expected/033_negation_once_generators.pl +2 -0
- package/test/conformance/expected/034_equality_and_inequality.pl +4 -0
- package/test/conformance/expected/035_list_relations.pl +4 -0
- package/test/conformance/expected/036_append_splits.pl +3 -0
- package/test/conformance/expected/037_matching_and_comparison.pl +5 -0
- package/test/conformance/expected/038_memoize_declaration.pl +2 -0
- package/test/conformance/expected/039_numeric_functions.pl +7 -0
- package/test/conformance/expected/040_between_enumeration.pl +3 -0
- package/test/conformance/expected/041_smallest_divisor.pl +1 -0
- package/test/conformance/expected/042_negation_filter.pl +2 -0
- package/test/conformance/expected/043_once_user_predicate.pl +1 -0
- package/test/conformance/expected/044_findall_user_goal.pl +1 -0
- package/test/conformance/expected/045_sort_deduplicates_atoms.pl +1 -0
- package/test/conformance/expected/046_append_bound_prefix_suffix.pl +2 -0
- package/test/conformance/expected/047_nth0_index_generation.pl +1 -0
- package/test/conformance/expected/048_set_nth0_edges.pl +2 -0
- package/test/conformance/expected/049_select_duplicate_occurrences.pl +2 -0
- package/test/conformance/expected/050_not_member_filter.pl +1 -0
- package/test/conformance/expected/051_nested_holds_parts.pl +3 -0
- package/test/conformance/expected/052_holds_member.pl +2 -0
- package/test/conformance/expected/053_materialize_excludes_source_fact.pl +1 -0
- package/test/conformance/expected/054_numeric_and_lexical_comparison.pl +3 -0
- package/test/conformance/expected/055_string_matching_filters.pl +2 -0
- package/test/conformance/expected/056_string_and_atom_concat.pl +1 -0
- package/test/conformance/expected/057_countall_empty_and_nonempty.pl +1 -0
- package/test/conformance/expected/058_sumall_numeric_template.pl +1 -0
- package/test/conformance/expected/059_aggregate_min_template.pl +1 -0
- package/test/conformance/expected/060_aggregate_max_compound_key.pl +1 -0
- package/test/conformance/expected/061_date_difference.pl +2 -0
- package/test/conformance/expected/062_reusable_numeric_builtins.pl +8 -0
- package/test/conformance/expected/063_reusable_list_builtins.pl +9 -0
- package/test/conformance/expected/064_reusable_string_builtins.pl +10 -0
- package/test/conformance/expected/065_reusable_term_control_builtins.pl +6 -0
- package/test/conformance/expected/066_numeric_edges.pl +12 -0
- package/test/conformance/expected/067_list_edges.pl +8 -0
- package/test/conformance/expected/068_list_generation_order.pl +10 -0
- package/test/conformance/expected/069_list_summaries_and_sets.pl +7 -0
- package/test/conformance/expected/070_matches_named_captures.pl +1 -0
- package/test/conformance/expected/071_string_edges.pl +8 -0
- package/test/conformance/expected/072_string_conversions.pl +8 -0
- package/test/conformance/expected/073_term_introspection_edges.pl +8 -0
- package/test/conformance/expected/074_forall_edges.pl +5 -0
- package/test/conformance/expected/075_aggregation_edges.pl +7 -0
- package/test/conformance/expected/076_composed_reusable_builtins.pl +5 -0
- package/test/conformance/expected/077_recursive_path_with_lists.pl +3 -0
- package/test/conformance/expected/078_mutual_recursion_with_arithmetic.pl +7 -0
- package/test/conformance/expected/079_big_integer_arithmetic.pl +6 -0
- package/test/conformance/expected/080_rounding_modes.pl +8 -0
- package/test/conformance/expected/081_zero_safe_numeric_functions.pl +7 -0
- package/test/conformance/expected/082_comparison_semantics.pl +8 -0
- package/test/conformance/expected/083_between_modes_and_empty_ranges.pl +8 -0
- package/test/conformance/expected/084_append_and_select_composition.pl +10 -0
- package/test/conformance/expected/085_nth_and_update_edges.pl +8 -0
- package/test/conformance/expected/086_slicing_pipeline.pl +7 -0
- package/test/conformance/expected/087_sort_reverse_length.pl +6 -0
- package/test/conformance/expected/088_list_summaries_failures.pl +6 -0
- package/test/conformance/expected/089_string_split_join_pipeline.pl +4 -0
- package/test/conformance/expected/090_string_substring_replace_edges.pl +7 -0
- package/test/conformance/expected/091_string_case_and_trim.pl +5 -0
- package/test/conformance/expected/092_scalar_string_conversions.pl +7 -0
- package/test/conformance/expected/093_regex_named_captures_context.pl +5 -0
- package/test/conformance/expected/094_context_holds_enumeration.pl +8 -0
- package/test/conformance/expected/095_term_introspection_roundtrip.pl +6 -0
- package/test/conformance/expected/096_functor_scalar_edges.pl +6 -0
- package/test/conformance/expected/097_control_negation_once_forall.pl +5 -0
- package/test/conformance/expected/098_aggregation_nested_templates.pl +5 -0
- package/test/conformance/expected/099_materialize_multiple_arities.pl +4 -0
- package/test/conformance/expected/100_reusable_builtin_workflow.pl +6 -0
- package/test/run-all.mjs +20 -0
- package/test/run-conformance.mjs +78 -0
- package/test/run-examples.mjs +125 -0
- package/test/run-regression.mjs +612 -0
- package/test/test-style.mjs +94 -0
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
% Towers of Hanoi adapted from Eyeling hanoi.n3.
|
|
2
|
+
% Output is the complete list of moves for size 3.
|
|
3
|
+
|
|
4
|
+
% Output declarations: materialize/2 selects the relations written to this example's golden output.
|
|
5
|
+
materialize(answer, 2).
|
|
6
|
+
|
|
7
|
+
% Program structure: facts set up the scenario, and rules derive the materialized conclusions.
|
|
8
|
+
memoize(hanoi, 5).
|
|
9
|
+
|
|
10
|
+
hanoi(0, _From, _To, _Via, []).
|
|
11
|
+
% Derivation rules: each rule below contributes one logical step toward the displayed results.
|
|
12
|
+
hanoi(N, From, To, Via, Moves) :-
|
|
13
|
+
gt(N, 0),
|
|
14
|
+
sub(N, 1, N1),
|
|
15
|
+
hanoi(N1, From, Via, To, Before),
|
|
16
|
+
hanoi(N1, Via, To, From, After),
|
|
17
|
+
append(Before, [[From, To]|After], Moves).
|
|
18
|
+
|
|
19
|
+
answer(3, Moves) :-
|
|
20
|
+
hanoi(3, left, right, center, Moves).
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
% Engineering example: one-dimensional conductive heat loss through a wall.
|
|
2
|
+
%
|
|
3
|
+
% Thermal resistance is L/(k*A), and heat loss is DeltaT/R.
|
|
4
|
+
|
|
5
|
+
% Output declarations: materialize/2 selects the relations written to this example's golden output.
|
|
6
|
+
materialize(type, 2).
|
|
7
|
+
materialize(temperatureDifference_K, 2).
|
|
8
|
+
materialize(thermalResistance_K_W, 2).
|
|
9
|
+
materialize(heatLoss_W, 2).
|
|
10
|
+
materialize(status, 2).
|
|
11
|
+
|
|
12
|
+
% Program structure: facts set up the scenario, and rules derive the materialized conclusions.
|
|
13
|
+
wall(wall1, conductivity_W_mK, 0.8).
|
|
14
|
+
wall(wall1, area_m2, 12.0).
|
|
15
|
+
wall(wall1, thickness_m, 0.2).
|
|
16
|
+
wall(wall1, indoor_C, 21.0).
|
|
17
|
+
wall(wall1, outdoor_C, -4.0).
|
|
18
|
+
|
|
19
|
+
% Derivation rules: each rule below contributes one logical step toward the displayed results.
|
|
20
|
+
temperature_difference(Wall, DeltaT) :-
|
|
21
|
+
wall(Wall, indoor_C, Indoor),
|
|
22
|
+
wall(Wall, outdoor_C, Outdoor),
|
|
23
|
+
sub(Indoor, Outdoor, DeltaT).
|
|
24
|
+
|
|
25
|
+
thermal_resistance(Wall, Resistance) :-
|
|
26
|
+
wall(Wall, thickness_m, Thickness),
|
|
27
|
+
wall(Wall, conductivity_W_mK, Conductivity),
|
|
28
|
+
wall(Wall, area_m2, Area),
|
|
29
|
+
mul(Conductivity, Area, Conductance),
|
|
30
|
+
div(Thickness, Conductance, Resistance).
|
|
31
|
+
|
|
32
|
+
heat_loss(Wall, HeatLoss) :-
|
|
33
|
+
temperature_difference(Wall, DeltaT),
|
|
34
|
+
thermal_resistance(Wall, Resistance),
|
|
35
|
+
div(DeltaT, Resistance, HeatLoss).
|
|
36
|
+
|
|
37
|
+
type(Wall, conduction_heat_loss) :-
|
|
38
|
+
wall(Wall, thickness_m, _Thickness).
|
|
39
|
+
|
|
40
|
+
temperatureDifference_K(Wall, DeltaT) :-
|
|
41
|
+
temperature_difference(Wall, DeltaT).
|
|
42
|
+
|
|
43
|
+
thermalResistance_K_W(Wall, Resistance) :-
|
|
44
|
+
thermal_resistance(Wall, Resistance).
|
|
45
|
+
|
|
46
|
+
heatLoss_W(Wall, HeatLoss) :-
|
|
47
|
+
heat_loss(Wall, HeatLoss).
|
|
48
|
+
|
|
49
|
+
status(Wall, high_heat_loss) :-
|
|
50
|
+
heat_loss(Wall, HeatLoss),
|
|
51
|
+
gt(HeatLoss, 1000.0).
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
% Heron's theorem: area = sqrt(s(s-a)(s-b)(s-c)).
|
|
2
|
+
|
|
3
|
+
% Output declarations: materialize/2 selects the relations written to this example's golden output.
|
|
4
|
+
materialize(semiperimeter, 2).
|
|
5
|
+
materialize(heronProduct, 2).
|
|
6
|
+
materialize(area, 2).
|
|
7
|
+
materialize(status, 2).
|
|
8
|
+
|
|
9
|
+
% Program structure: facts set up the scenario, and rules derive the materialized conclusions.
|
|
10
|
+
% 13-14-15 is a classic integer-sided triangle with area 84.
|
|
11
|
+
triangle(field_plot, 13, 14, 15).
|
|
12
|
+
|
|
13
|
+
% Derivation rules: each rule below contributes one logical step toward the displayed results.
|
|
14
|
+
semiperimeter(Triangle, S) :-
|
|
15
|
+
triangle(Triangle, A, B, C),
|
|
16
|
+
add(A, B, AB),
|
|
17
|
+
add(AB, C, Sum),
|
|
18
|
+
div(Sum, 2, S).
|
|
19
|
+
|
|
20
|
+
% Area is obtained by taking the square root of this Heron product.
|
|
21
|
+
heron_product(Triangle, Product) :-
|
|
22
|
+
triangle(Triangle, A, B, C),
|
|
23
|
+
semiperimeter(Triangle, S),
|
|
24
|
+
sub(S, A, SA),
|
|
25
|
+
sub(S, B, SB),
|
|
26
|
+
sub(S, C, SC),
|
|
27
|
+
mul(S, SA, T1),
|
|
28
|
+
mul(T1, SB, T2),
|
|
29
|
+
mul(T2, SC, Product).
|
|
30
|
+
|
|
31
|
+
area(Triangle, Area) :-
|
|
32
|
+
heron_product(Triangle, Product),
|
|
33
|
+
pow(Product, 0.5, Area).
|
|
34
|
+
|
|
35
|
+
heronProduct(Triangle, P) :- heron_product(Triangle, P).
|
|
36
|
+
status(Triangle, valid_survey_triangle) :- area(Triangle, A), gt(A, 0).
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
% Science example: ideal gas law.
|
|
2
|
+
%
|
|
3
|
+
% A simple gas cell uses P*V = n*R*T. The constants are chosen so that the
|
|
4
|
+
% computed pressure is exactly near one atmosphere in this small example.
|
|
5
|
+
|
|
6
|
+
% Output declarations: materialize/2 selects the relations written to this example's golden output.
|
|
7
|
+
materialize(pressure_Pa, 2).
|
|
8
|
+
materialize(status, 2).
|
|
9
|
+
materialize(reason, 2).
|
|
10
|
+
|
|
11
|
+
% Program structure: facts set up the scenario, and rules derive the materialized conclusions.
|
|
12
|
+
gas_cell(cell1, 1.0, 8.0, 300.0, 0.024).
|
|
13
|
+
pressure_limit(cell1, low_Pa, 95000.0).
|
|
14
|
+
pressure_limit(cell1, high_Pa, 105000.0).
|
|
15
|
+
|
|
16
|
+
% Derivation rules: each rule below contributes one logical step toward the displayed results.
|
|
17
|
+
pressure(Cell, Pressure) :-
|
|
18
|
+
gas_cell(Cell, Moles, GasConstant, Temperature, Volume),
|
|
19
|
+
mul(Moles, GasConstant, NR),
|
|
20
|
+
mul(NR, Temperature, NRT),
|
|
21
|
+
div(NRT, Volume, Pressure).
|
|
22
|
+
|
|
23
|
+
near_atmospheric(Cell) :-
|
|
24
|
+
pressure(Cell, Pressure),
|
|
25
|
+
pressure_limit(Cell, low_Pa, Low),
|
|
26
|
+
pressure_limit(Cell, high_Pa, High),
|
|
27
|
+
gt(Pressure, Low),
|
|
28
|
+
lt(Pressure, High).
|
|
29
|
+
|
|
30
|
+
pressure_Pa(Cell, Pressure) :-
|
|
31
|
+
pressure(Cell, Pressure).
|
|
32
|
+
|
|
33
|
+
status(Cell, near_atmospheric) :-
|
|
34
|
+
near_atmospheric(Cell).
|
|
35
|
+
|
|
36
|
+
reason(Cell, "pressure is inside the one-atmosphere tolerance band") :-
|
|
37
|
+
near_atmospheric(Cell).
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
% Illegitimate reasoning detector.
|
|
2
|
+
%
|
|
3
|
+
% The input facts describe arguments and their surface reasoning pattern. Helper
|
|
4
|
+
% predicates identify common invalid inference forms. The output layer emits only
|
|
5
|
+
% concise report relations: the argument is illegitimate, which fallacy was found,
|
|
6
|
+
% the challenged conclusion, and a short reason why.
|
|
7
|
+
|
|
8
|
+
% Affirming the consequent:
|
|
9
|
+
% If it rained, the street is wet. The street is wet. Therefore it rained.
|
|
10
|
+
% Output declarations: materialize/2 selects the relations written to this example's golden output.
|
|
11
|
+
materialize(type, 2).
|
|
12
|
+
materialize(fallacy, 2).
|
|
13
|
+
materialize(conclusion, 2).
|
|
14
|
+
materialize(reason, 2).
|
|
15
|
+
materialize(sampleSize, 2).
|
|
16
|
+
materialize(requiredSampleSize, 2).
|
|
17
|
+
materialize(omittedAlternative, 2).
|
|
18
|
+
|
|
19
|
+
% Program structure: facts set up the scenario, and rules derive the materialized conclusions.
|
|
20
|
+
argument(arg_affirming_consequent).
|
|
21
|
+
implication(arg_affirming_consequent, rain, street_wet).
|
|
22
|
+
observed(arg_affirming_consequent, street_wet).
|
|
23
|
+
concludes(arg_affirming_consequent, rain).
|
|
24
|
+
|
|
25
|
+
% Denying the antecedent:
|
|
26
|
+
% If the key is present, the door opens. The key is not present. Therefore the door does not open.
|
|
27
|
+
argument(arg_denying_antecedent).
|
|
28
|
+
implication(arg_denying_antecedent, key_present, door_opens).
|
|
29
|
+
observed(arg_denying_antecedent, neg(key_present)).
|
|
30
|
+
concludes(arg_denying_antecedent, neg(door_opens)).
|
|
31
|
+
|
|
32
|
+
% Hasty generalization:
|
|
33
|
+
% Three sampled cases are treated as enough for a universal conclusion.
|
|
34
|
+
argument(arg_hasty_generalization).
|
|
35
|
+
sample_size(arg_hasty_generalization, 3).
|
|
36
|
+
required_sample_size(arg_hasty_generalization, 30).
|
|
37
|
+
concludes(arg_hasty_generalization, all(crows, black)).
|
|
38
|
+
|
|
39
|
+
% False dilemma:
|
|
40
|
+
% Only two choices are presented even though a relevant third option exists.
|
|
41
|
+
argument(arg_false_dilemma).
|
|
42
|
+
presented_alternatives(arg_false_dilemma, [approve_now, reject_forever]).
|
|
43
|
+
omitted_alternative(arg_false_dilemma, revise_proposal).
|
|
44
|
+
concludes(arg_false_dilemma, approve_now).
|
|
45
|
+
|
|
46
|
+
% A contrast case: modus ponens is not flagged.
|
|
47
|
+
argument(arg_modus_ponens).
|
|
48
|
+
implication(arg_modus_ponens, subscription_paid, access_allowed).
|
|
49
|
+
observed(arg_modus_ponens, subscription_paid).
|
|
50
|
+
concludes(arg_modus_ponens, access_allowed).
|
|
51
|
+
|
|
52
|
+
% Derivation rules: each rule below contributes one logical step toward the displayed results.
|
|
53
|
+
fallacy(A, affirming_consequent) :-
|
|
54
|
+
argument(A),
|
|
55
|
+
implication(A, Antecedent, Consequent),
|
|
56
|
+
observed(A, Consequent),
|
|
57
|
+
concludes(A, Antecedent).
|
|
58
|
+
|
|
59
|
+
fallacy(A, denying_antecedent) :-
|
|
60
|
+
argument(A),
|
|
61
|
+
implication(A, Antecedent, Consequent),
|
|
62
|
+
observed(A, neg(Antecedent)),
|
|
63
|
+
concludes(A, neg(Consequent)).
|
|
64
|
+
|
|
65
|
+
fallacy(A, hasty_generalization) :-
|
|
66
|
+
argument(A),
|
|
67
|
+
sample_size(A, N),
|
|
68
|
+
required_sample_size(A, Min),
|
|
69
|
+
lt(N, Min),
|
|
70
|
+
concludes(A, all(_, _)).
|
|
71
|
+
|
|
72
|
+
fallacy(A, false_dilemma) :-
|
|
73
|
+
argument(A),
|
|
74
|
+
presented_alternatives(A, _),
|
|
75
|
+
omitted_alternative(A, _),
|
|
76
|
+
concludes(A, _).
|
|
77
|
+
|
|
78
|
+
reason(arg_affirming_consequent, "observing the consequent does not prove the antecedent").
|
|
79
|
+
reason(arg_denying_antecedent, "denying the antecedent does not disprove the consequent").
|
|
80
|
+
reason(arg_hasty_generalization, "sample size is below the threshold for a universal conclusion").
|
|
81
|
+
reason(arg_false_dilemma, "a relevant alternative is omitted").
|
|
82
|
+
|
|
83
|
+
type(A, illegitimate_reasoning) :- fallacy(A, _).
|
|
84
|
+
conclusion(A, C) :- fallacy(A, _), concludes(A, C).
|
|
85
|
+
reason(A, R) :- fallacy(A, _), reason(A, R).
|
|
86
|
+
sampleSize(A, N) :- fallacy(A, hasty_generalization), sample_size(A, N).
|
|
87
|
+
requiredSampleSize(A, Min) :- fallacy(A, hasty_generalization), required_sample_size(A, Min).
|
|
88
|
+
omittedAlternative(A, Alt) :- fallacy(A, false_dilemma), omitted_alternative(A, Alt).
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
% Knowledge-engineering alignment flow in eyelang.
|
|
2
|
+
% Local source predicates are aligned once and then reused to produce a target-shaped flow view.
|
|
3
|
+
% fpv_* atoms denote a tiny local Flow/Policy Vocabulary profile.
|
|
4
|
+
|
|
5
|
+
materialize(type, 2).
|
|
6
|
+
materialize(target_fact, 3).
|
|
7
|
+
materialize(runtime_rule, 2).
|
|
8
|
+
materialize(target_predicate, 2).
|
|
9
|
+
materialize(flow_emits, 2).
|
|
10
|
+
materialize(trusted_by, 2).
|
|
11
|
+
|
|
12
|
+
sub_class(local_observation, sosa_observation).
|
|
13
|
+
sub_class(temperature_probe, sosa_sensor).
|
|
14
|
+
sub_property(observed_by, sosa_madeBySensor).
|
|
15
|
+
sub_property(observed_at, sosa_resultTime).
|
|
16
|
+
sub_property(temperature_celsius, sosa_hasSimpleResult).
|
|
17
|
+
sub_property(in_flow, fpv_hasFlowStep).
|
|
18
|
+
equivalent_property(observed_feature, sosa_hasFeatureOfInterest).
|
|
19
|
+
|
|
20
|
+
type(msg1, local_observation).
|
|
21
|
+
type(probe7, temperature_probe).
|
|
22
|
+
triple(msg1, observed_by, probe7).
|
|
23
|
+
triple(msg1, observed_at, "2026-06-17T12:34:56Z").
|
|
24
|
+
triple(msg1, temperature_celsius, 18.6).
|
|
25
|
+
triple(msg1, observed_feature, platform_b).
|
|
26
|
+
triple(msg1, in_flow, ingest_step).
|
|
27
|
+
|
|
28
|
+
% Generic alignment rules.
|
|
29
|
+
type(Thing, Super) :- type(Thing, Class), sub_class(Class, Super).
|
|
30
|
+
target_fact(Subject, SuperPredicate, Object) :- triple(Subject, Predicate, Object), sub_property(Predicate, SuperPredicate).
|
|
31
|
+
target_fact(Subject, TargetPredicate, Object) :- triple(Subject, Predicate, Object), equivalent_property(Predicate, TargetPredicate).
|
|
32
|
+
target_fact(Subject, SourcePredicate, Object) :- triple(Subject, Predicate, Object), equivalent_property(SourcePredicate, Predicate).
|
|
33
|
+
|
|
34
|
+
runtime_rule(SourcePredicate, copy_to_target) :- sub_property(SourcePredicate, _TargetPredicate).
|
|
35
|
+
runtime_rule(SourcePredicate, copy_to_target) :- equivalent_property(SourcePredicate, _TargetPredicate).
|
|
36
|
+
target_predicate(SourcePredicate, TargetPredicate) :- sub_property(SourcePredicate, TargetPredicate).
|
|
37
|
+
target_predicate(SourcePredicate, TargetPredicate) :- equivalent_property(SourcePredicate, TargetPredicate).
|
|
38
|
+
|
|
39
|
+
flow_emits(Step, Message) :- type(Message, sosa_observation), target_fact(Message, fpv_hasFlowStep, Step), target_fact(Message, sosa_madeBySensor, _Sensor).
|
|
40
|
+
trusted_by(Step, Sensor) :- type(Message, sosa_observation), target_fact(Message, fpv_hasFlowStep, Step), target_fact(Message, sosa_madeBySensor, Sensor).
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
% Law of cosines: c^2 = a^2 + b^2 - 2ab cos(C).
|
|
2
|
+
% The example uses a 60-degree included angle, so cos(C) is represented as 0.5.
|
|
3
|
+
|
|
4
|
+
% Output declarations: materialize/2 selects the relations written to this example's golden output.
|
|
5
|
+
materialize(sideCSquared, 2).
|
|
6
|
+
materialize(sideC, 2).
|
|
7
|
+
materialize(status, 2).
|
|
8
|
+
|
|
9
|
+
% Program structure: facts set up the scenario, and rules derive the materialized conclusions.
|
|
10
|
+
% Stored tuple is triangle(Name, sideA, sideB, cosIncludedAngle).
|
|
11
|
+
triangle(tri60, 7, 9, 0.5).
|
|
12
|
+
|
|
13
|
+
% Compute c^2 first so both squared and square-rooted outputs can be shown.
|
|
14
|
+
% Derivation rules: each rule below contributes one logical step toward the displayed results.
|
|
15
|
+
side_c_squared(Triangle, C2) :-
|
|
16
|
+
triangle(Triangle, A, B, CosC),
|
|
17
|
+
mul(A, A, A2),
|
|
18
|
+
mul(B, B, B2),
|
|
19
|
+
add(A2, B2, Sum),
|
|
20
|
+
mul(2, A, TwoA),
|
|
21
|
+
mul(TwoA, B, TwoAB),
|
|
22
|
+
mul(TwoAB, CosC, Projection),
|
|
23
|
+
sub(Sum, Projection, C2).
|
|
24
|
+
|
|
25
|
+
side_c(Triangle, C) :-
|
|
26
|
+
side_c_squared(Triangle, C2),
|
|
27
|
+
pow(C2, 0.5, C).
|
|
28
|
+
|
|
29
|
+
sideCSquared(Triangle, C2) :- side_c_squared(Triangle, C2).
|
|
30
|
+
sideC(Triangle, C) :- side_c(Triangle, C).
|
|
31
|
+
status(Triangle, acute_triangle) :- side_c_squared(Triangle, C2), gt(C2, 0).
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
% Math example: least-squares linear regression.
|
|
2
|
+
%
|
|
3
|
+
% The rules reduce a list of points to sufficient statistics, then derive the
|
|
4
|
+
% fitted slope, intercept, and coefficient of determination R^2.
|
|
5
|
+
|
|
6
|
+
% Output declarations: materialize/2 selects the relations written to this example's golden output.
|
|
7
|
+
materialize(slope, 2).
|
|
8
|
+
materialize(intercept, 2).
|
|
9
|
+
materialize(rSquared, 2).
|
|
10
|
+
materialize(status, 2).
|
|
11
|
+
materialize(reason, 2).
|
|
12
|
+
|
|
13
|
+
% Program structure: facts set up the scenario, and rules derive the materialized conclusions.
|
|
14
|
+
dataset(regression1, [point(1.0, 2.0), point(2.0, 3.0), point(3.0, 5.0), point(4.0, 4.0)]).
|
|
15
|
+
threshold(regression1, minimum_r_squared, 0.60).
|
|
16
|
+
|
|
17
|
+
stats([], 0.0, 0.0, 0.0, 0.0, 0.0, 0.0).
|
|
18
|
+
% Derivation rules: each rule below contributes one logical step toward the displayed results.
|
|
19
|
+
stats([point(X, Y)|Rest], N, SumX, SumY, SumXX, SumXY, SumYY) :-
|
|
20
|
+
stats(Rest, N0, SumX0, SumY0, SumXX0, SumXY0, SumYY0),
|
|
21
|
+
add(N0, 1.0, N),
|
|
22
|
+
add(SumX0, X, SumX),
|
|
23
|
+
add(SumY0, Y, SumY),
|
|
24
|
+
mul(X, X, XX),
|
|
25
|
+
add(SumXX0, XX, SumXX),
|
|
26
|
+
mul(X, Y, XY),
|
|
27
|
+
add(SumXY0, XY, SumXY),
|
|
28
|
+
mul(Y, Y, YY),
|
|
29
|
+
add(SumYY0, YY, SumYY).
|
|
30
|
+
|
|
31
|
+
sufficient_statistics(Data, N, SumX, SumY, SumXX, SumXY, SumYY) :-
|
|
32
|
+
dataset(Data, Points),
|
|
33
|
+
stats(Points, N, SumX, SumY, SumXX, SumXY, SumYY).
|
|
34
|
+
|
|
35
|
+
slope(Data, Slope) :-
|
|
36
|
+
sufficient_statistics(Data, N, SumX, SumY, SumXX, SumXY, _SumYY),
|
|
37
|
+
mul(N, SumXY, NSumXY),
|
|
38
|
+
mul(SumX, SumY, SumXSumY),
|
|
39
|
+
sub(NSumXY, SumXSumY, Numerator),
|
|
40
|
+
mul(N, SumXX, NSumXX),
|
|
41
|
+
mul(SumX, SumX, SumXSquared),
|
|
42
|
+
sub(NSumXX, SumXSquared, Denominator),
|
|
43
|
+
div(Numerator, Denominator, Slope).
|
|
44
|
+
|
|
45
|
+
intercept(Data, Intercept) :-
|
|
46
|
+
sufficient_statistics(Data, N, SumX, SumY, _SumXX, _SumXY, _SumYY),
|
|
47
|
+
slope(Data, Slope),
|
|
48
|
+
mul(Slope, SumX, SlopeSumX),
|
|
49
|
+
sub(SumY, SlopeSumX, Numerator),
|
|
50
|
+
div(Numerator, N, Intercept).
|
|
51
|
+
|
|
52
|
+
r_squared(Data, R2) :-
|
|
53
|
+
sufficient_statistics(Data, N, SumX, SumY, SumXX, SumXY, SumYY),
|
|
54
|
+
mul(N, SumXY, NSumXY),
|
|
55
|
+
mul(SumX, SumY, SumXSumY),
|
|
56
|
+
sub(NSumXY, SumXSumY, NumeratorBase),
|
|
57
|
+
pow(NumeratorBase, 2.0, Numerator),
|
|
58
|
+
mul(N, SumXX, NSumXX),
|
|
59
|
+
mul(SumX, SumX, SumXSquared),
|
|
60
|
+
sub(NSumXX, SumXSquared, XSpread),
|
|
61
|
+
mul(N, SumYY, NSumYY),
|
|
62
|
+
mul(SumY, SumY, SumYSquared),
|
|
63
|
+
sub(NSumYY, SumYSquared, YSpread),
|
|
64
|
+
mul(XSpread, YSpread, Denominator),
|
|
65
|
+
div(Numerator, Denominator, R2).
|
|
66
|
+
|
|
67
|
+
accepted_fit(Data) :-
|
|
68
|
+
r_squared(Data, R2),
|
|
69
|
+
threshold(Data, minimum_r_squared, Minimum),
|
|
70
|
+
ge(R2, Minimum).
|
|
71
|
+
|
|
72
|
+
|
|
73
|
+
|
|
74
|
+
rSquared(Data, R2) :-
|
|
75
|
+
r_squared(Data, R2).
|
|
76
|
+
|
|
77
|
+
status(Data, accepted_linear_fit) :-
|
|
78
|
+
accepted_fit(Data).
|
|
79
|
+
|
|
80
|
+
reason(Data, "R squared meets the minimum explanatory-power threshold") :-
|
|
81
|
+
accepted_fit(Data).
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
% List collections inspired by the Eyeling collection example.
|
|
2
|
+
% Demonstrates list literals, member/2, length/2, append/3, and [Head|Tail].
|
|
3
|
+
% Each materialized relation demonstrates one list operation.
|
|
4
|
+
% Output declarations: materialize/2 selects the relations written to this example's golden output.
|
|
5
|
+
materialize(length, 2).
|
|
6
|
+
materialize(member, 2).
|
|
7
|
+
materialize(append, 2).
|
|
8
|
+
materialize(head, 2).
|
|
9
|
+
materialize(tail, 2).
|
|
10
|
+
|
|
11
|
+
% Program structure: facts set up the scenario, and rules derive the materialized conclusions.
|
|
12
|
+
% Lists are first-class terms in facts and rule heads/bodies.
|
|
13
|
+
collection(numbers, [1, 2, 3]).
|
|
14
|
+
collection(letters, [a, b]).
|
|
15
|
+
|
|
16
|
+
% Derivation rules: each rule below contributes one logical step toward the displayed results.
|
|
17
|
+
length(numbers, N) :-
|
|
18
|
+
collection(numbers, List),
|
|
19
|
+
length(List, N).
|
|
20
|
+
|
|
21
|
+
member(numbers, X) :-
|
|
22
|
+
collection(numbers, List),
|
|
23
|
+
member(X, List).
|
|
24
|
+
|
|
25
|
+
append(letters, Extended) :-
|
|
26
|
+
collection(letters, List),
|
|
27
|
+
append(List, [c], Extended).
|
|
28
|
+
|
|
29
|
+
head(letters, Head) :-
|
|
30
|
+
collection(letters, [Head|_Tail]).
|
|
31
|
+
|
|
32
|
+
tail(letters, Tail) :-
|
|
33
|
+
collection(letters, [_Head|Tail]).
|
package/examples/lldm.pl
ADDED
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
% Leg Length Discrepancy Measurement, adapted from Eyeling lldm.n3.
|
|
2
|
+
%
|
|
3
|
+
% The measurement and intermediate geometry are kept in helper predicates so
|
|
4
|
+
% the default relation materialization stays concise. The visible output is
|
|
5
|
+
% the alarm plus the small set of relations explaining why the alarm fired.
|
|
6
|
+
|
|
7
|
+
% Output declarations: materialize/2 selects the relations written to this example's golden output.
|
|
8
|
+
materialize(type, 2).
|
|
9
|
+
materialize(lld_left_length_cm, 2).
|
|
10
|
+
materialize(lld_right_length_cm, 2).
|
|
11
|
+
materialize(lld_discrepancy_cm, 2).
|
|
12
|
+
materialize(lld_threshold_cm, 2).
|
|
13
|
+
materialize(lld_reason, 2).
|
|
14
|
+
|
|
15
|
+
% Program structure: facts set up the scenario, and rules derive the materialized conclusions.
|
|
16
|
+
measurement(meas47).
|
|
17
|
+
|
|
18
|
+
% measured landmark coordinates, in centimetres
|
|
19
|
+
val(meas47, p1xCm, 10.1).
|
|
20
|
+
val(meas47, p1yCm, 7.8).
|
|
21
|
+
val(meas47, p2xCm, 45.1).
|
|
22
|
+
val(meas47, p2yCm, 5.6).
|
|
23
|
+
val(meas47, p3xCm, 3.6).
|
|
24
|
+
val(meas47, p3yCm, 29.8).
|
|
25
|
+
val(meas47, p4xCm, 54.7).
|
|
26
|
+
val(meas47, p4yCm, 28.5).
|
|
27
|
+
|
|
28
|
+
% threshold used by the alarm rule, in centimetres
|
|
29
|
+
threshold(meas47, lld_alarm_threshold_cm, 1.25).
|
|
30
|
+
|
|
31
|
+
% geometric intermediate values
|
|
32
|
+
% Derivation rules: each rule below contributes one logical step toward the displayed results.
|
|
33
|
+
val(M, dx12Cm, Z) :- measurement(M), val(M, p1xCm, X), val(M, p2xCm, Y), sub(X, Y, Z).
|
|
34
|
+
val(M, dx51Cm, Z) :- measurement(M), val(M, p5xCm, X), val(M, p1xCm, Y), sub(X, Y, Z).
|
|
35
|
+
val(M, dx53Cm, Z) :- measurement(M), val(M, p5xCm, X), val(M, p3xCm, Y), sub(X, Y, Z).
|
|
36
|
+
val(M, dx62Cm, Z) :- measurement(M), val(M, p6xCm, X), val(M, p2xCm, Y), sub(X, Y, Z).
|
|
37
|
+
val(M, dx64Cm, Z) :- measurement(M), val(M, p6xCm, X), val(M, p4xCm, Y), sub(X, Y, Z).
|
|
38
|
+
val(M, dy12Cm, Z) :- measurement(M), val(M, p1yCm, X), val(M, p2yCm, Y), sub(X, Y, Z).
|
|
39
|
+
val(M, dy13Cm, Z) :- measurement(M), val(M, p1yCm, X), val(M, p3yCm, Y), sub(X, Y, Z).
|
|
40
|
+
val(M, dy24Cm, Z) :- measurement(M), val(M, p2yCm, X), val(M, p4yCm, Y), sub(X, Y, Z).
|
|
41
|
+
val(M, dy53Cm, Z) :- measurement(M), val(M, p5yCm, X), val(M, p3yCm, Y), sub(X, Y, Z).
|
|
42
|
+
val(M, dy64Cm, Z) :- measurement(M), val(M, p6yCm, X), val(M, p4yCm, Y), sub(X, Y, Z).
|
|
43
|
+
val(M, cL1, Z) :- measurement(M), val(M, dy12Cm, Y), val(M, dx12Cm, X), div(Y, X, Z).
|
|
44
|
+
val(M, dL3m, Z) :- measurement(M), val(M, cL1, X), div(1, X, Z).
|
|
45
|
+
val(M, cL3, Z) :- measurement(M), val(M, dL3m, X), sub(0, X, Z).
|
|
46
|
+
val(M, pL1x1Cm, Z) :- measurement(M), val(M, cL1, X), val(M, p1xCm, Y), mul(X, Y, Z).
|
|
47
|
+
val(M, pL1x2Cm, Z) :- measurement(M), val(M, cL1, X), val(M, p2xCm, Y), mul(X, Y, Z).
|
|
48
|
+
val(M, pL3x3Cm, Z) :- measurement(M), val(M, cL3, X), val(M, p3xCm, Y), mul(X, Y, Z).
|
|
49
|
+
val(M, pL3x4Cm, Z) :- measurement(M), val(M, cL3, X), val(M, p4xCm, Y), mul(X, Y, Z).
|
|
50
|
+
val(M, dd13Cm, Z) :- measurement(M), val(M, pL1x1Cm, X), val(M, pL3x3Cm, Y), sub(X, Y, Z).
|
|
51
|
+
val(M, ddy13Cm, Z) :- measurement(M), val(M, dd13Cm, X), val(M, dy13Cm, Y), sub(X, Y, Z).
|
|
52
|
+
val(M, dd24Cm, Z) :- measurement(M), val(M, pL1x2Cm, X), val(M, pL3x4Cm, Y), sub(X, Y, Z).
|
|
53
|
+
val(M, ddy24Cm, Z) :- measurement(M), val(M, dd24Cm, X), val(M, dy24Cm, Y), sub(X, Y, Z).
|
|
54
|
+
val(M, ddL13, Z) :- measurement(M), val(M, cL1, X), val(M, cL3, Y), sub(X, Y, Z).
|
|
55
|
+
val(M, pL1dx51Cm, Z) :- measurement(M), val(M, cL1, X), val(M, dx51Cm, Y), mul(X, Y, Z).
|
|
56
|
+
val(M, pL1dx62Cm, Z) :- measurement(M), val(M, cL1, X), val(M, dx62Cm, Y), mul(X, Y, Z).
|
|
57
|
+
val(M, p5xCm, Z) :- measurement(M), val(M, ddy13Cm, X), val(M, ddL13, Y), div(X, Y, Z).
|
|
58
|
+
val(M, p5yCm, Z) :- measurement(M), val(M, pL1dx51Cm, X), val(M, p1yCm, Y), add(X, Y, Z).
|
|
59
|
+
val(M, p6xCm, Z) :- measurement(M), val(M, ddy24Cm, X), val(M, ddL13, Y), div(X, Y, Z).
|
|
60
|
+
val(M, p6yCm, Z) :- measurement(M), val(M, pL1dx62Cm, X), val(M, p2yCm, Y), add(X, Y, Z).
|
|
61
|
+
val(M, sdx53Cm2, Z) :- measurement(M), val(M, dx53Cm, X), pow(X, 2, Z).
|
|
62
|
+
val(M, sdx64Cm2, Z) :- measurement(M), val(M, dx64Cm, X), pow(X, 2, Z).
|
|
63
|
+
val(M, sdy53Cm2, Z) :- measurement(M), val(M, dy53Cm, X), pow(X, 2, Z).
|
|
64
|
+
val(M, sdy64Cm2, Z) :- measurement(M), val(M, dy64Cm, X), pow(X, 2, Z).
|
|
65
|
+
val(M, ssd53Cm2, Z) :- measurement(M), val(M, sdx53Cm2, X), val(M, sdy53Cm2, Y), add(X, Y, Z).
|
|
66
|
+
val(M, ssd64Cm2, Z) :- measurement(M), val(M, sdx64Cm2, X), val(M, sdy64Cm2, Y), add(X, Y, Z).
|
|
67
|
+
val(M, d53Cm, Z) :- measurement(M), val(M, ssd53Cm2, X), pow(X, 0.5, Z).
|
|
68
|
+
val(M, d64Cm, Z) :- measurement(M), val(M, ssd64Cm2, X), pow(X, 0.5, Z).
|
|
69
|
+
val(M, dCm, Z) :- measurement(M), val(M, d53Cm, X), val(M, d64Cm, Y), sub(X, Y, Z).
|
|
70
|
+
|
|
71
|
+
% concise output layer
|
|
72
|
+
type(M, lld_alarm) :- measurement(M), val(M, dCm, D), threshold(M, lld_alarm_threshold_cm, T), sub(0, T, NegT), lt(D, NegT).
|
|
73
|
+
type(M, lld_alarm) :- measurement(M), val(M, dCm, D), threshold(M, lld_alarm_threshold_cm, T), gt(D, T).
|
|
74
|
+
lld_left_length_cm(M, L) :- type(M, lld_alarm), val(M, d53Cm, L).
|
|
75
|
+
lld_right_length_cm(M, R) :- type(M, lld_alarm), val(M, d64Cm, R).
|
|
76
|
+
lld_discrepancy_cm(M, D) :- type(M, lld_alarm), val(M, dCm, D).
|
|
77
|
+
lld_threshold_cm(M, T) :- type(M, lld_alarm), threshold(M, lld_alarm_threshold_cm, T).
|
|
78
|
+
lld_reason(M, "discrepancy below negative threshold") :- type(M, lld_alarm).
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
% Representative example: manufacturing quality-control capability.
|
|
2
|
+
%
|
|
3
|
+
% The rules compute process capability indices from measurement summaries and
|
|
4
|
+
% classify production lines using a practical Cpk threshold.
|
|
5
|
+
|
|
6
|
+
% Output declarations: materialize/2 selects the relations written to this example's golden output.
|
|
7
|
+
materialize(cpk, 2).
|
|
8
|
+
materialize(status, 2).
|
|
9
|
+
materialize(reason, 2).
|
|
10
|
+
|
|
11
|
+
% Program structure: facts set up the scenario, and rules derive the materialized conclusions.
|
|
12
|
+
run(line7_shift_a).
|
|
13
|
+
run(line8_shift_b).
|
|
14
|
+
|
|
15
|
+
spec(line7_shift_a, lower_mm, 10.0).
|
|
16
|
+
spec(line7_shift_a, upper_mm, 10.2).
|
|
17
|
+
summary(line7_shift_a, mean_mm, 10.12).
|
|
18
|
+
summary(line7_shift_a, sigma_mm, 0.04).
|
|
19
|
+
|
|
20
|
+
spec(line8_shift_b, lower_mm, 10.0).
|
|
21
|
+
spec(line8_shift_b, upper_mm, 10.2).
|
|
22
|
+
summary(line8_shift_b, mean_mm, 10.1).
|
|
23
|
+
summary(line8_shift_b, sigma_mm, 0.02).
|
|
24
|
+
|
|
25
|
+
capability_threshold(cpk, 1.33).
|
|
26
|
+
|
|
27
|
+
% Derivation rules: each rule below contributes one logical step toward the displayed results.
|
|
28
|
+
upper_margin_mm(Run, Margin) :-
|
|
29
|
+
spec(Run, upper_mm, Upper),
|
|
30
|
+
summary(Run, mean_mm, Mean),
|
|
31
|
+
sub(Upper, Mean, Margin).
|
|
32
|
+
|
|
33
|
+
lower_margin_mm(Run, Margin) :-
|
|
34
|
+
summary(Run, mean_mm, Mean),
|
|
35
|
+
spec(Run, lower_mm, Lower),
|
|
36
|
+
sub(Mean, Lower, Margin).
|
|
37
|
+
|
|
38
|
+
nearest_spec_margin_mm(Run, Margin) :-
|
|
39
|
+
upper_margin_mm(Run, UpperMargin),
|
|
40
|
+
lower_margin_mm(Run, LowerMargin),
|
|
41
|
+
min(UpperMargin, LowerMargin, Margin).
|
|
42
|
+
|
|
43
|
+
three_sigma_mm(Run, ThreeSigma) :-
|
|
44
|
+
summary(Run, sigma_mm, Sigma),
|
|
45
|
+
mul(3.0, Sigma, ThreeSigma).
|
|
46
|
+
|
|
47
|
+
cpk(Run, Cpk) :-
|
|
48
|
+
nearest_spec_margin_mm(Run, Margin),
|
|
49
|
+
three_sigma_mm(Run, ThreeSigma),
|
|
50
|
+
div(Margin, ThreeSigma, Cpk).
|
|
51
|
+
|
|
52
|
+
capable(Run) :-
|
|
53
|
+
cpk(Run, Cpk),
|
|
54
|
+
capability_threshold(cpk, Threshold),
|
|
55
|
+
ge(Cpk, Threshold).
|
|
56
|
+
|
|
57
|
+
needs_adjustment(Run) :-
|
|
58
|
+
cpk(Run, Cpk),
|
|
59
|
+
capability_threshold(cpk, Threshold),
|
|
60
|
+
lt(Cpk, Threshold).
|
|
61
|
+
|
|
62
|
+
|
|
63
|
+
status(Run, capable_process) :-
|
|
64
|
+
capable(Run).
|
|
65
|
+
|
|
66
|
+
status(Run, needs_process_adjustment) :-
|
|
67
|
+
needs_adjustment(Run).
|
|
68
|
+
|
|
69
|
+
reason(Run, "Cpk meets the production capability threshold") :-
|
|
70
|
+
capable(Run).
|
|
71
|
+
|
|
72
|
+
reason(Run, "Cpk is below the production capability threshold") :-
|
|
73
|
+
needs_adjustment(Run).
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
% Representative example: microgrid dispatch planning.
|
|
2
|
+
%
|
|
3
|
+
% The rules compute renewable supply, reserve-aware battery dispatch, remaining
|
|
4
|
+
% grid import, and a concise feasibility report for a campus microgrid interval.
|
|
5
|
+
|
|
6
|
+
% Output declarations: materialize/2 selects the relations written to this example's golden output.
|
|
7
|
+
materialize(renewablePower_kW, 2).
|
|
8
|
+
materialize(batteryDispatch_kW, 2).
|
|
9
|
+
materialize(gridImport_kW, 2).
|
|
10
|
+
materialize(reserveAfterDispatch_kW, 2).
|
|
11
|
+
materialize(status, 2).
|
|
12
|
+
materialize(reason, 2).
|
|
13
|
+
|
|
14
|
+
% Program structure: facts set up the scenario, and rules derive the materialized conclusions.
|
|
15
|
+
site(campus_interval_17).
|
|
16
|
+
|
|
17
|
+
load_kW(campus_interval_17, 620.0).
|
|
18
|
+
solar_kW(campus_interval_17, 180.0).
|
|
19
|
+
wind_kW(campus_interval_17, 90.0).
|
|
20
|
+
battery_max_discharge_kW(campus_interval_17, 320.0).
|
|
21
|
+
required_battery_reserve_kW(campus_interval_17, 80.0).
|
|
22
|
+
grid_contract_limit_kW(campus_interval_17, 150.0).
|
|
23
|
+
|
|
24
|
+
% Derivation rules: each rule below contributes one logical step toward the displayed results.
|
|
25
|
+
renewable_kW(Site, Renewable) :-
|
|
26
|
+
solar_kW(Site, Solar),
|
|
27
|
+
wind_kW(Site, Wind),
|
|
28
|
+
add(Solar, Wind, Renewable).
|
|
29
|
+
|
|
30
|
+
net_deficit_kW(Site, Deficit) :-
|
|
31
|
+
load_kW(Site, Load),
|
|
32
|
+
renewable_kW(Site, Renewable),
|
|
33
|
+
sub(Load, Renewable, Deficit).
|
|
34
|
+
|
|
35
|
+
reserve_aware_battery_limit_kW(Site, Limit) :-
|
|
36
|
+
battery_max_discharge_kW(Site, MaxDischarge),
|
|
37
|
+
required_battery_reserve_kW(Site, Reserve),
|
|
38
|
+
sub(MaxDischarge, Reserve, Limit).
|
|
39
|
+
|
|
40
|
+
battery_dispatch_kW(Site, Dispatch) :-
|
|
41
|
+
net_deficit_kW(Site, Deficit),
|
|
42
|
+
reserve_aware_battery_limit_kW(Site, Limit),
|
|
43
|
+
min(Deficit, Limit, Dispatch).
|
|
44
|
+
|
|
45
|
+
grid_import_kW(Site, Import) :-
|
|
46
|
+
net_deficit_kW(Site, Deficit),
|
|
47
|
+
battery_dispatch_kW(Site, Dispatch),
|
|
48
|
+
sub(Deficit, Dispatch, Import).
|
|
49
|
+
|
|
50
|
+
battery_reserve_after_dispatch_kW(Site, ReserveLeft) :-
|
|
51
|
+
battery_max_discharge_kW(Site, MaxDischarge),
|
|
52
|
+
battery_dispatch_kW(Site, Dispatch),
|
|
53
|
+
sub(MaxDischarge, Dispatch, ReserveLeft).
|
|
54
|
+
|
|
55
|
+
contract_ok(Site) :-
|
|
56
|
+
grid_import_kW(Site, Import),
|
|
57
|
+
grid_contract_limit_kW(Site, Limit),
|
|
58
|
+
le(Import, Limit).
|
|
59
|
+
|
|
60
|
+
reserve_ok(Site) :-
|
|
61
|
+
battery_reserve_after_dispatch_kW(Site, ReserveLeft),
|
|
62
|
+
required_battery_reserve_kW(Site, Required),
|
|
63
|
+
ge(ReserveLeft, Required).
|
|
64
|
+
|
|
65
|
+
stable_dispatch(Site) :-
|
|
66
|
+
contract_ok(Site),
|
|
67
|
+
reserve_ok(Site).
|
|
68
|
+
|
|
69
|
+
renewablePower_kW(Site, Renewable) :-
|
|
70
|
+
renewable_kW(Site, Renewable).
|
|
71
|
+
|
|
72
|
+
batteryDispatch_kW(Site, Dispatch) :-
|
|
73
|
+
battery_dispatch_kW(Site, Dispatch).
|
|
74
|
+
|
|
75
|
+
gridImport_kW(Site, Import) :-
|
|
76
|
+
grid_import_kW(Site, Import).
|
|
77
|
+
|
|
78
|
+
reserveAfterDispatch_kW(Site, ReserveLeft) :-
|
|
79
|
+
battery_reserve_after_dispatch_kW(Site, ReserveLeft).
|
|
80
|
+
|
|
81
|
+
status(Site, stable_dispatch) :-
|
|
82
|
+
stable_dispatch(Site).
|
|
83
|
+
|
|
84
|
+
reason(Site, "battery dispatch covers the deficit while preserving reserve and grid contract limits") :-
|
|
85
|
+
stable_dispatch(Site).
|