eyelang 1.2.2 → 1.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +4 -4
- package/docs/guide.md +230 -229
- package/docs/language-reference.md +169 -157
- package/examples/access-control-policy.eye +52 -0
- package/examples/ackermann.eye +47 -0
- package/examples/age.eye +26 -0
- package/examples/aliases-and-namespaces.eye +20 -0
- package/examples/alignment-demo.eye +44 -0
- package/examples/allen-interval-calculus.eye +64 -0
- package/examples/ancestor.eye +22 -0
- package/examples/animal.eye +21 -0
- package/examples/annotation.eye +34 -0
- package/examples/auroracare.eye +309 -0
- package/examples/backward.eye +11 -0
- package/examples/basic-monadic.eye +10032 -0
- package/examples/bayes-diagnosis.eye +108 -0
- package/examples/bayes-therapy.eye +189 -0
- package/examples/beam-deflection.eye +48 -0
- package/examples/binomial-vandermonde.eye +49 -0
- package/examples/blocks-world-planning.eye +77 -0
- package/examples/bmi.eye +232 -0
- package/examples/braking-safety-worlds.eye +69 -0
- package/examples/buck-converter-design.eye +83 -0
- package/examples/cache-performance.eye +56 -0
- package/examples/canary-release.eye +51 -0
- package/examples/cat-koko.eye +24 -0
- package/examples/catalan-convolution.eye +37 -0
- package/examples/chart-parser.eye +65 -0
- package/examples/clinical-trial-screening.eye +97 -0
- package/examples/collatz-1000.eye +45 -0
- package/examples/combinatorics-findall-sort.eye +38 -0
- package/examples/competitive-enzyme-kinetics.eye +78 -0
- package/examples/complex.eye +133 -0
- package/examples/composition-of-injective-functions-is-injective.eye +50 -0
- package/examples/context-association.eye +53 -0
- package/examples/context-schema-audit.eye +46 -0
- package/examples/continued-fraction-sqrt2.eye +36 -0
- package/examples/control-system.eye +76 -0
- package/examples/critical-path-schedule.eye +82 -0
- package/examples/cyclic-path.eye +18 -0
- package/examples/d3-group.eye +99 -0
- package/examples/dairy-energy-balance.eye +66 -0
- package/examples/data-negotiation.eye +38 -0
- package/examples/deep-taxonomy-10.eye +115 -0
- package/examples/deep-taxonomy-100.eye +385 -0
- package/examples/deep-taxonomy-1000.eye +3085 -0
- package/examples/deep-taxonomy-10000.eye +30094 -0
- package/examples/deep-taxonomy-100000.eye +300184 -0
- package/examples/delfour.eye +281 -0
- package/examples/deontic-logic.eye +52 -0
- package/examples/derived-backward-rule.eye +30 -0
- package/examples/derived-rule.eye +27 -0
- package/examples/diamond-property.eye +38 -0
- package/examples/dijkstra-findall-sort.eye +43 -0
- package/examples/dijkstra-risk-path.eye +87 -0
- package/examples/dijkstra.eye +50 -0
- package/examples/dining-philosophers.eye +147 -0
- package/examples/dog.eye +25 -0
- package/examples/dpv-odrl-purpose-mapping.eye +48 -0
- package/examples/drone-corridor-planner.eye +48 -0
- package/examples/easter-computus.eye +88 -0
- package/examples/electrical-rc-filter.eye +37 -0
- package/examples/epidemic-policy.eye +66 -0
- package/examples/equivalence-classes-overlap-implies-same-class.eye +27 -0
- package/examples/eulerian-path.eye +87 -0
- package/examples/ev-range-worlds.eye +87 -0
- package/examples/existential-rule.eye +21 -0
- package/examples/exoplanet-validation-worlds.eye +94 -0
- package/examples/expression-eval.eye +45 -0
- package/examples/family-cousins.eye +67 -0
- package/examples/fastpow.eye +61 -0
- package/examples/fft8-numeric.eye +85 -0
- package/examples/fibonacci.eye +60 -0
- package/examples/field-nitrogen-balance.eye +73 -0
- package/examples/flandor.eye +296 -0
- package/examples/floating-point.eye +28 -0
- package/examples/four-color-map.eye +133 -0
- package/examples/fundamental-theorem-arithmetic.eye +119 -0
- package/examples/gd-step-certified.eye +162 -0
- package/examples/gdpr-compliance.eye +69 -0
- package/examples/good-cobbler.eye +16 -0
- package/examples/gps.eye +146 -0
- package/examples/graph-reachability.eye +33 -0
- package/examples/graph.eye +35 -0
- package/examples/gray-code-counter.eye +47 -0
- package/examples/greatest-lower-bound-uniqueness.eye +30 -0
- package/examples/group-inverse-uniqueness.eye +36 -0
- package/examples/hamiltonian-path.eye +51 -0
- package/examples/hamming-code.eye +109 -0
- package/examples/hanoi.eye +19 -0
- package/examples/heat-loss.eye +56 -0
- package/examples/heron-theorem.eye +42 -0
- package/examples/ideal-gas-law.eye +39 -0
- package/examples/illegitimate-reasoning.eye +88 -0
- package/examples/integer-partitions.eye +35 -0
- package/examples/intuitionistic-logic-kripke.eye +69 -0
- package/examples/job-shop-scheduling.eye +48 -0
- package/examples/knapsack-optimization.eye +46 -0
- package/examples/knowledge-engineering-alignment-flow.eye +46 -0
- package/examples/law-of-cosines.eye +37 -0
- package/examples/least-squares-regression.eye +85 -0
- package/examples/linear-logic-resources.eye +51 -0
- package/examples/list-collection.eye +35 -0
- package/examples/lldm.eye +80 -0
- package/examples/manufacturing-quality-control.eye +73 -0
- package/examples/matrix-chain-order.eye +79 -0
- package/examples/microgrid-dispatch.eye +89 -0
- package/examples/missionaries-cannibals.eye +53 -0
- package/examples/modal-logic-kripke.eye +45 -0
- package/examples/modular-exponentiation.eye +35 -0
- package/examples/monkey-bananas.eye +45 -0
- package/examples/n-queens-8.eye +35 -0
- package/examples/network-sla.eye +48 -0
- package/examples/newton-raphson.eye +48 -0
- package/examples/nixon-diamond.eye +37 -0
- package/examples/observability-log-correlation.eye +40 -0
- package/examples/odrl-dpv-fpv-trust-flow.eye +51 -0
- package/examples/odrl-dpv-healthcare-risk-ranked.eye +270 -0
- package/examples/odrl-dpv-risk-ranked.eye +320 -0
- package/examples/orbital-transfer-design.eye +116 -0
- package/examples/path-discovery.eye +45013 -0
- package/examples/peano-arithmetic.eye +33 -0
- package/examples/peasant.eye +29 -0
- package/examples/pell-equation.eye +34 -0
- package/examples/pendulum-period.eye +50 -0
- package/examples/polynomial.eye +124 -0
- package/examples/proof/access-control-policy.eye +158 -0
- package/examples/proof/age.eye +71 -0
- package/examples/proof/aliases-and-namespaces.eye +78 -0
- package/examples/proof/ancestor.eye +140 -0
- package/examples/proof/animal.eye +68 -0
- package/examples/proof/annotation.eye +80 -0
- package/examples/proof/backward.eye +22 -0
- package/examples/proof/bayes-diagnosis.eye +208 -0
- package/examples/proof/beam-deflection.eye +227 -0
- package/examples/proof/cache-performance.eye +310 -0
- package/examples/proof/canary-release.eye +172 -0
- package/examples/proof/cat-koko.eye +86 -0
- package/examples/proof/chart-parser.eye +474 -0
- package/examples/proof/clinical-trial-screening.eye +389 -0
- package/examples/proof/composition-of-injective-functions-is-injective.eye +258 -0
- package/examples/proof/context-association.eye +78 -0
- package/examples/proof/data-negotiation.eye +76 -0
- package/examples/proof/deontic-logic.eye +109 -0
- package/examples/proof/derived-backward-rule.eye +74 -0
- package/examples/proof/derived-rule.eye +43 -0
- package/examples/proof/diamond-property.eye +307 -0
- package/examples/proof/dog.eye +31 -0
- package/examples/proof/dpv-odrl-purpose-mapping.eye +348 -0
- package/examples/proof/electrical-rc-filter.eye +105 -0
- package/examples/proof/epidemic-policy.eye +774 -0
- package/examples/proof/equivalence-classes-overlap-implies-same-class.eye +1098 -0
- package/examples/proof/existential-rule.eye +40 -0
- package/examples/proof/expression-eval.eye +105 -0
- package/examples/proof/floating-point.eye +160 -0
- package/examples/proof/gdpr-compliance.eye +199 -0
- package/examples/proof/good-cobbler.eye +16 -0
- package/examples/proof/graph-reachability.eye +151 -0
- package/examples/proof/greatest-lower-bound-uniqueness.eye +150 -0
- package/examples/proof/group-inverse-uniqueness.eye +84 -0
- package/examples/proof/hanoi.eye +185 -0
- package/examples/proof/heat-loss.eye +228 -0
- package/examples/proof/ideal-gas-law.eye +151 -0
- package/examples/proof/intuitionistic-logic-kripke.eye +133 -0
- package/examples/proof/linear-logic-resources.eye +205 -0
- package/examples/proof/list-collection.eye +52 -0
- package/examples/proof/modal-logic-kripke.eye +125 -0
- package/examples/proof/nixon-diamond.eye +181 -0
- package/examples/proof/proof-contrapositive.eye +78 -0
- package/examples/proof/reusable-builtins.eye +124 -0
- package/examples/proof/security-incident-correlation.eye +270 -0
- package/examples/proof/socket-age.eye +32 -0
- package/examples/proof/socket-family.eye +59 -0
- package/examples/proof/socrates.eye +38 -0
- package/examples/proof/term-tools.eye +95 -0
- package/examples/proof/witch.eye +216 -0
- package/examples/proof-contrapositive.eye +27 -0
- package/examples/quadratic-formula.eye +56 -0
- package/examples/radioactive-decay.eye +58 -0
- package/examples/reusable-builtins.eye +36 -0
- package/examples/riemann-hypothesis.eye +110 -0
- package/examples/security-incident-correlation.eye +69 -0
- package/examples/send-more-money.eye +71 -0
- package/examples/service-impact.eye +41 -0
- package/examples/sieve.eye +20 -0
- package/examples/skolem-functions.eye +52 -0
- package/examples/socket-age.eye +39 -0
- package/examples/socket-family.eye +28 -0
- package/examples/socrates.eye +19 -0
- package/examples/stable-marriage.eye +92 -0
- package/examples/statistics-summary.eye +56 -0
- package/examples/stirling-bell-numbers.eye +32 -0
- package/examples/sudoku-4x4.eye +54 -0
- package/examples/superdense-coding.eye +84 -0
- package/examples/term-tools.eye +32 -0
- package/examples/totient-summatory.eye +33 -0
- package/examples/trust-flow-provenance-threshold.eye +47 -0
- package/examples/turing.eye +69 -0
- package/examples/vector-similarity.eye +60 -0
- package/examples/vulnerability-impact.eye +69 -0
- package/examples/web-names.eye +83 -0
- package/examples/weighted-interval-scheduling.eye +81 -0
- package/examples/witch.eye +38 -0
- package/examples/wolf-goat-cabbage.eye +56 -0
- package/examples/zebra.eye +45 -0
- package/index.d.ts +1 -1
- package/package.json +2 -2
- package/playground.html +10 -10
- package/src/cli.js +2 -2
- package/src/explain.js +1 -1
- package/src/parser.js +37 -7
- package/src/program.js +3 -3
- package/src/solver.js +2 -2
- package/src/term.js +9 -0
- package/test/conformance/README.md +2 -2
- package/test/conformance/cases/001_fact_output.eye +4 -0
- package/test/conformance/cases/002_rule_recursion.eye +7 -0
- package/test/conformance/cases/002_rule_recursion.query +1 -1
- package/test/conformance/cases/003_terms_and_readback.eye +16 -0
- package/test/conformance/cases/003_terms_and_readback.query +1 -1
- package/test/conformance/cases/004_conjunction_and_parentheses.eye +5 -0
- package/test/conformance/cases/004_conjunction_and_parentheses.query +1 -1
- package/test/conformance/cases/005_list_deconstruction.eye +6 -0
- package/test/conformance/cases/005_list_deconstruction.query +1 -1
- package/test/conformance/cases/006_comma_formula_data.eye +4 -0
- package/test/conformance/cases/006_comma_formula_data.query +1 -1
- package/test/conformance/cases/007_anonymous_variables.eye +5 -0
- package/test/conformance/cases/007_anonymous_variables.query +1 -1
- package/test/conformance/cases/008_graphic_atoms.eye +6 -0
- package/test/conformance/cases/008_graphic_atoms.query +1 -1
- package/test/conformance/cases/009_comments_and_whitespace.eye +5 -0
- package/test/conformance/cases/009_comments_and_whitespace.query +1 -1
- package/test/conformance/cases/010_variable_scope_and_reuse.eye +8 -0
- package/test/conformance/cases/010_variable_scope_and_reuse.query +1 -1
- package/test/conformance/cases/011_predicate_arity.eye +6 -0
- package/test/conformance/cases/011_predicate_arity.query +1 -1
- package/test/conformance/cases/012_nested_compound_unification.eye +5 -0
- package/test/conformance/cases/012_nested_compound_unification.query +1 -1
- package/test/conformance/cases/013_multiple_clauses_order.eye +6 -0
- package/test/conformance/cases/013_multiple_clauses_order.query +1 -1
- package/test/conformance/cases/014_failure_filters_answers.eye +7 -0
- package/test/conformance/cases/014_failure_filters_answers.query +1 -1
- package/test/conformance/cases/015_improper_list_unification.eye +6 -0
- package/test/conformance/cases/015_improper_list_unification.query +1 -1
- package/test/conformance/cases/016_arity_zero_atom.eye +4 -0
- package/test/conformance/cases/017_three_step_recursion.eye +8 -0
- package/test/conformance/cases/017_three_step_recursion.query +1 -1
- package/test/conformance/cases/018_quoted_atom_readback.eye +6 -0
- package/test/conformance/cases/018_quoted_atom_readback.query +1 -1
- package/test/conformance/cases/019_parenthesized_three_conjuncts.eye +7 -0
- package/test/conformance/cases/019_parenthesized_three_conjuncts.query +1 -1
- package/test/conformance/cases/020_nested_list_terms.eye +5 -0
- package/test/conformance/cases/020_nested_list_terms.query +1 -1
- package/test/conformance/cases/021_repeated_variable_head.eye +7 -0
- package/test/conformance/cases/022_rule_head_structure.eye +5 -0
- package/test/conformance/cases/023_quoted_escapes_readback.eye +5 -0
- package/test/conformance/cases/024_numeric_literal_readback.eye +6 -0
- package/test/conformance/cases/025_body_parentheses_with_formula_data.eye +5 -0
- package/test/conformance/cases/026_question_underscore_named_variable_reuse.eye +5 -0
- package/test/conformance/cases/027_default_derived_output.eye +5 -0
- package/test/conformance/cases/028_materialize_focus.eye +5 -0
- package/test/conformance/cases/029_arithmetic_and_comparison.eye +11 -0
- package/test/conformance/cases/029_arithmetic_and_comparison.query +1 -1
- package/test/conformance/cases/030_strings_and_atoms.eye +4 -0
- package/test/conformance/cases/030_strings_and_atoms.query +1 -1
- package/test/conformance/cases/031_lists_aggregation_ordering.eye +10 -0
- package/test/conformance/cases/031_lists_aggregation_ordering.query +1 -1
- package/test/conformance/cases/032_holds_parts.eye +4 -0
- package/test/conformance/cases/033_negation_once_generators.eye +7 -0
- package/test/conformance/cases/033_negation_once_generators.query +1 -1
- package/test/conformance/cases/034_equality_and_inequality.eye +6 -0
- package/test/conformance/cases/034_equality_and_inequality.query +1 -1
- package/test/conformance/cases/035_list_relations.eye +5 -0
- package/test/conformance/cases/035_list_relations.query +1 -1
- package/test/conformance/cases/036_append_splits.eye +3 -0
- package/test/conformance/cases/036_append_splits.query +1 -1
- package/test/conformance/cases/037_matching_and_comparison.query +1 -1
- package/test/conformance/cases/038_table_declaration.eye +8 -0
- package/test/conformance/cases/038_table_declaration.query +1 -0
- package/test/conformance/cases/039_numeric_functions.eye +9 -0
- package/test/conformance/cases/039_numeric_functions.query +1 -1
- package/test/conformance/cases/040_between_enumeration.eye +3 -0
- package/test/conformance/cases/040_between_enumeration.query +1 -1
- package/test/conformance/cases/041_smallest_divisor.eye +3 -0
- package/test/conformance/cases/041_smallest_divisor.query +1 -1
- package/test/conformance/cases/042_negation_filter.eye +7 -0
- package/test/conformance/cases/042_negation_filter.query +1 -1
- package/test/conformance/cases/043_once_user_predicate.eye +5 -0
- package/test/conformance/cases/043_once_user_predicate.query +1 -1
- package/test/conformance/cases/044_findall_user_goal.eye +6 -0
- package/test/conformance/cases/044_findall_user_goal.query +1 -1
- package/test/conformance/cases/045_sort_deduplicates_atoms.eye +3 -0
- package/test/conformance/cases/045_sort_deduplicates_atoms.query +1 -1
- package/test/conformance/cases/046_append_bound_prefix_suffix.eye +4 -0
- package/test/conformance/cases/046_append_bound_prefix_suffix.query +1 -1
- package/test/conformance/cases/047_nth0_index_generation.eye +3 -0
- package/test/conformance/cases/047_nth0_index_generation.query +1 -1
- package/test/conformance/cases/048_set_nth0_edges.eye +4 -0
- package/test/conformance/cases/048_set_nth0_edges.query +1 -1
- package/test/conformance/cases/049_select_duplicate_occurrences.eye +3 -0
- package/test/conformance/cases/049_select_duplicate_occurrences.query +1 -1
- package/test/conformance/cases/050_not_member_filter.eye +6 -0
- package/test/conformance/cases/050_not_member_filter.query +1 -1
- package/test/conformance/cases/051_nested_holds_parts.eye +4 -0
- package/test/conformance/cases/052_holds_member.eye +3 -0
- package/test/conformance/cases/053_materialize_excludes_source_fact.eye +6 -0
- package/test/conformance/cases/054_numeric_and_lexical_comparison.query +1 -1
- package/test/conformance/cases/055_string_matching_filters.eye +6 -0
- package/test/conformance/cases/055_string_matching_filters.query +1 -1
- package/test/conformance/cases/056_string_and_atom_concat.eye +3 -0
- package/test/conformance/cases/056_string_and_atom_concat.query +1 -1
- package/test/conformance/cases/057_countall_empty_and_nonempty.eye +4 -0
- package/test/conformance/cases/057_countall_empty_and_nonempty.query +1 -1
- package/test/conformance/cases/058_sumall_numeric_template.eye +5 -0
- package/test/conformance/cases/058_sumall_numeric_template.query +1 -1
- package/test/conformance/cases/059_aggregate_min_template.eye +5 -0
- package/test/conformance/cases/059_aggregate_min_template.query +1 -1
- package/test/conformance/cases/060_aggregate_max_compound_key.eye +5 -0
- package/test/conformance/cases/060_aggregate_max_compound_key.query +1 -1
- package/test/conformance/cases/061_date_difference.eye +4 -0
- package/test/conformance/cases/062_reusable_numeric_builtins.eye +10 -0
- package/test/conformance/cases/063_reusable_list_builtins.eye +11 -0
- package/test/conformance/cases/064_reusable_string_builtins.eye +12 -0
- package/test/conformance/cases/065_reusable_term_control_builtins.eye +11 -0
- package/test/conformance/cases/066_numeric_edges.eye +14 -0
- package/test/conformance/cases/067_list_edges.eye +10 -0
- package/test/conformance/cases/068_list_generation_order.eye +7 -0
- package/test/conformance/cases/069_list_summaries_and_sets.eye +9 -0
- package/test/conformance/cases/070_matches_named_captures.eye +13 -0
- package/test/conformance/cases/071_string_edges.eye +10 -0
- package/test/conformance/cases/072_string_conversions.eye +10 -0
- package/test/conformance/cases/073_term_introspection_edges.eye +10 -0
- package/test/conformance/cases/074_forall_edges.eye +10 -0
- package/test/conformance/cases/075_aggregation_edges.eye +12 -0
- package/test/conformance/cases/076_composed_reusable_builtins.eye +8 -0
- package/test/conformance/cases/077_recursive_path_with_lists.eye +10 -0
- package/test/conformance/cases/078_mutual_recursion_with_arithmetic.eye +7 -0
- package/test/conformance/cases/079_big_integer_arithmetic.eye +8 -0
- package/test/conformance/cases/080_rounding_modes.eye +10 -0
- package/test/conformance/cases/081_zero_safe_numeric_functions.eye +9 -0
- package/test/conformance/cases/083_between_modes_and_empty_ranges.eye +8 -0
- package/test/conformance/cases/084_append_and_select_composition.eye +7 -0
- package/test/conformance/cases/085_nth_and_update_edges.eye +8 -0
- package/test/conformance/cases/086_slicing_pipeline.eye +10 -0
- package/test/conformance/cases/087_sort_reverse_length.eye +8 -0
- package/test/conformance/cases/088_list_summaries_failures.eye +8 -0
- package/test/conformance/cases/089_string_split_join_pipeline.eye +7 -0
- package/test/conformance/cases/090_string_substring_replace_edges.eye +9 -0
- package/test/conformance/cases/091_string_case_and_trim.eye +7 -0
- package/test/conformance/cases/092_scalar_string_conversions.eye +9 -0
- package/test/conformance/cases/093_regex_named_captures_context.eye +8 -0
- package/test/conformance/cases/094_context_holds_enumeration.eye +7 -0
- package/test/conformance/cases/095_term_introspection_roundtrip.eye +8 -0
- package/test/conformance/cases/096_functor_scalar_edges.eye +8 -0
- package/test/conformance/cases/097_control_negation_once_forall.eye +13 -0
- package/test/conformance/cases/098_aggregation_nested_templates.eye +11 -0
- package/test/conformance/cases/099_materialize_multiple_arities.eye +8 -0
- package/test/conformance/cases/100_reusable_builtin_workflow.eye +10 -0
- package/test/conformance/cases/101_question_mark_variables.eye +7 -0
- package/test/conformance/cases/102_table_declaration.eye +11 -0
- package/test/conformance/cases/103_angle_iri_atoms.eye +7 -0
- package/test/conformance/expected/101_question_mark_variables.eye +3 -0
- package/test/conformance/expected/102_table_declaration.eye +6 -0
- package/test/conformance/expected/103_angle_iri_atoms.eye +3 -0
- package/test/run-conformance.mjs +4 -4
- package/test/run-examples.mjs +51 -51
- package/test/run-regression.mjs +178 -74
- package/examples/access-control-policy.pl +0 -52
- package/examples/ackermann.pl +0 -47
- package/examples/age.pl +0 -26
- package/examples/aliases-and-namespaces.pl +0 -20
- package/examples/alignment-demo.pl +0 -44
- package/examples/allen-interval-calculus.pl +0 -64
- package/examples/ancestor.pl +0 -22
- package/examples/animal.pl +0 -21
- package/examples/annotation.pl +0 -34
- package/examples/auroracare.pl +0 -309
- package/examples/backward.pl +0 -11
- package/examples/basic-monadic.pl +0 -10032
- package/examples/bayes-diagnosis.pl +0 -108
- package/examples/bayes-therapy.pl +0 -189
- package/examples/beam-deflection.pl +0 -48
- package/examples/binomial-vandermonde.pl +0 -49
- package/examples/blocks-world-planning.pl +0 -77
- package/examples/bmi.pl +0 -232
- package/examples/braking-safety-worlds.pl +0 -69
- package/examples/buck-converter-design.pl +0 -83
- package/examples/cache-performance.pl +0 -56
- package/examples/canary-release.pl +0 -51
- package/examples/cat-koko.pl +0 -24
- package/examples/catalan-convolution.pl +0 -37
- package/examples/chart-parser.pl +0 -65
- package/examples/clinical-trial-screening.pl +0 -97
- package/examples/collatz-1000.pl +0 -45
- package/examples/combinatorics-findall-sort.pl +0 -38
- package/examples/competitive-enzyme-kinetics.pl +0 -78
- package/examples/complex.pl +0 -133
- package/examples/composition-of-injective-functions-is-injective.pl +0 -50
- package/examples/context-association.pl +0 -53
- package/examples/context-schema-audit.pl +0 -46
- package/examples/continued-fraction-sqrt2.pl +0 -36
- package/examples/control-system.pl +0 -76
- package/examples/critical-path-schedule.pl +0 -82
- package/examples/cyclic-path.pl +0 -18
- package/examples/d3-group.pl +0 -99
- package/examples/dairy-energy-balance.pl +0 -66
- package/examples/data-negotiation.pl +0 -38
- package/examples/deep-taxonomy-10.pl +0 -115
- package/examples/deep-taxonomy-100.pl +0 -385
- package/examples/deep-taxonomy-1000.pl +0 -3085
- package/examples/deep-taxonomy-10000.pl +0 -30094
- package/examples/deep-taxonomy-100000.pl +0 -300184
- package/examples/delfour.pl +0 -281
- package/examples/deontic-logic.pl +0 -52
- package/examples/derived-backward-rule.pl +0 -30
- package/examples/derived-rule.pl +0 -27
- package/examples/diamond-property.pl +0 -38
- package/examples/dijkstra-findall-sort.pl +0 -43
- package/examples/dijkstra-risk-path.pl +0 -87
- package/examples/dijkstra.pl +0 -50
- package/examples/dining-philosophers.pl +0 -147
- package/examples/dog.pl +0 -25
- package/examples/dpv-odrl-purpose-mapping.pl +0 -48
- package/examples/drone-corridor-planner.pl +0 -48
- package/examples/easter-computus.pl +0 -88
- package/examples/electrical-rc-filter.pl +0 -37
- package/examples/epidemic-policy.pl +0 -66
- package/examples/equivalence-classes-overlap-implies-same-class.pl +0 -27
- package/examples/eulerian-path.pl +0 -87
- package/examples/ev-range-worlds.pl +0 -87
- package/examples/existential-rule.pl +0 -21
- package/examples/exoplanet-validation-worlds.pl +0 -94
- package/examples/expression-eval.pl +0 -45
- package/examples/family-cousins.pl +0 -67
- package/examples/fastpow.pl +0 -61
- package/examples/fft8-numeric.pl +0 -85
- package/examples/fibonacci.pl +0 -60
- package/examples/field-nitrogen-balance.pl +0 -73
- package/examples/flandor.pl +0 -296
- package/examples/floating-point.pl +0 -28
- package/examples/four-color-map.pl +0 -133
- package/examples/fundamental-theorem-arithmetic.pl +0 -119
- package/examples/gd-step-certified.pl +0 -162
- package/examples/gdpr-compliance.pl +0 -69
- package/examples/good-cobbler.pl +0 -16
- package/examples/gps.pl +0 -146
- package/examples/graph-reachability.pl +0 -33
- package/examples/graph.pl +0 -35
- package/examples/gray-code-counter.pl +0 -47
- package/examples/greatest-lower-bound-uniqueness.pl +0 -30
- package/examples/group-inverse-uniqueness.pl +0 -36
- package/examples/hamiltonian-path.pl +0 -51
- package/examples/hamming-code.pl +0 -109
- package/examples/hanoi.pl +0 -19
- package/examples/heat-loss.pl +0 -56
- package/examples/heron-theorem.pl +0 -42
- package/examples/ideal-gas-law.pl +0 -39
- package/examples/illegitimate-reasoning.pl +0 -88
- package/examples/integer-partitions.pl +0 -35
- package/examples/intuitionistic-logic-kripke.pl +0 -69
- package/examples/job-shop-scheduling.pl +0 -48
- package/examples/knapsack-optimization.pl +0 -46
- package/examples/knowledge-engineering-alignment-flow.pl +0 -46
- package/examples/law-of-cosines.pl +0 -37
- package/examples/least-squares-regression.pl +0 -85
- package/examples/linear-logic-resources.pl +0 -51
- package/examples/list-collection.pl +0 -35
- package/examples/lldm.pl +0 -80
- package/examples/manufacturing-quality-control.pl +0 -73
- package/examples/matrix-chain-order.pl +0 -79
- package/examples/microgrid-dispatch.pl +0 -89
- package/examples/missionaries-cannibals.pl +0 -53
- package/examples/modal-logic-kripke.pl +0 -45
- package/examples/modular-exponentiation.pl +0 -35
- package/examples/monkey-bananas.pl +0 -45
- package/examples/n-queens-8.pl +0 -35
- package/examples/network-sla.pl +0 -48
- package/examples/newton-raphson.pl +0 -48
- package/examples/nixon-diamond.pl +0 -37
- package/examples/observability-log-correlation.pl +0 -40
- package/examples/odrl-dpv-fpv-trust-flow.pl +0 -51
- package/examples/odrl-dpv-healthcare-risk-ranked.pl +0 -270
- package/examples/odrl-dpv-risk-ranked.pl +0 -320
- package/examples/orbital-transfer-design.pl +0 -116
- package/examples/path-discovery.pl +0 -45013
- package/examples/peano-arithmetic.pl +0 -33
- package/examples/peasant.pl +0 -29
- package/examples/pell-equation.pl +0 -34
- package/examples/pendulum-period.pl +0 -50
- package/examples/polynomial.pl +0 -124
- package/examples/proof/access-control-policy.pl +0 -158
- package/examples/proof/age.pl +0 -71
- package/examples/proof/aliases-and-namespaces.pl +0 -78
- package/examples/proof/ancestor.pl +0 -140
- package/examples/proof/animal.pl +0 -68
- package/examples/proof/annotation.pl +0 -80
- package/examples/proof/backward.pl +0 -22
- package/examples/proof/bayes-diagnosis.pl +0 -208
- package/examples/proof/beam-deflection.pl +0 -227
- package/examples/proof/cache-performance.pl +0 -310
- package/examples/proof/canary-release.pl +0 -172
- package/examples/proof/cat-koko.pl +0 -86
- package/examples/proof/chart-parser.pl +0 -474
- package/examples/proof/clinical-trial-screening.pl +0 -389
- package/examples/proof/composition-of-injective-functions-is-injective.pl +0 -258
- package/examples/proof/context-association.pl +0 -78
- package/examples/proof/data-negotiation.pl +0 -76
- package/examples/proof/deontic-logic.pl +0 -109
- package/examples/proof/derived-backward-rule.pl +0 -74
- package/examples/proof/derived-rule.pl +0 -43
- package/examples/proof/diamond-property.pl +0 -307
- package/examples/proof/dog.pl +0 -31
- package/examples/proof/dpv-odrl-purpose-mapping.pl +0 -348
- package/examples/proof/electrical-rc-filter.pl +0 -105
- package/examples/proof/epidemic-policy.pl +0 -774
- package/examples/proof/equivalence-classes-overlap-implies-same-class.pl +0 -1098
- package/examples/proof/existential-rule.pl +0 -40
- package/examples/proof/expression-eval.pl +0 -105
- package/examples/proof/floating-point.pl +0 -160
- package/examples/proof/gdpr-compliance.pl +0 -199
- package/examples/proof/good-cobbler.pl +0 -16
- package/examples/proof/graph-reachability.pl +0 -151
- package/examples/proof/greatest-lower-bound-uniqueness.pl +0 -150
- package/examples/proof/group-inverse-uniqueness.pl +0 -84
- package/examples/proof/hanoi.pl +0 -185
- package/examples/proof/heat-loss.pl +0 -228
- package/examples/proof/ideal-gas-law.pl +0 -151
- package/examples/proof/intuitionistic-logic-kripke.pl +0 -133
- package/examples/proof/linear-logic-resources.pl +0 -205
- package/examples/proof/list-collection.pl +0 -52
- package/examples/proof/modal-logic-kripke.pl +0 -125
- package/examples/proof/nixon-diamond.pl +0 -181
- package/examples/proof/proof-contrapositive.pl +0 -78
- package/examples/proof/reusable-builtins.pl +0 -124
- package/examples/proof/security-incident-correlation.pl +0 -270
- package/examples/proof/socket-age.pl +0 -32
- package/examples/proof/socket-family.pl +0 -59
- package/examples/proof/socrates.pl +0 -38
- package/examples/proof/term-tools.pl +0 -95
- package/examples/proof/witch.pl +0 -216
- package/examples/proof-contrapositive.pl +0 -27
- package/examples/quadratic-formula.pl +0 -56
- package/examples/radioactive-decay.pl +0 -58
- package/examples/reusable-builtins.pl +0 -36
- package/examples/riemann-hypothesis.pl +0 -110
- package/examples/security-incident-correlation.pl +0 -69
- package/examples/send-more-money.pl +0 -71
- package/examples/service-impact.pl +0 -41
- package/examples/sieve.pl +0 -20
- package/examples/skolem-functions.pl +0 -52
- package/examples/socket-age.pl +0 -39
- package/examples/socket-family.pl +0 -28
- package/examples/socrates.pl +0 -19
- package/examples/stable-marriage.pl +0 -92
- package/examples/statistics-summary.pl +0 -56
- package/examples/stirling-bell-numbers.pl +0 -32
- package/examples/sudoku-4x4.pl +0 -54
- package/examples/superdense-coding.pl +0 -84
- package/examples/term-tools.pl +0 -32
- package/examples/totient-summatory.pl +0 -33
- package/examples/trust-flow-provenance-threshold.pl +0 -47
- package/examples/turing.pl +0 -69
- package/examples/vector-similarity.pl +0 -60
- package/examples/vulnerability-impact.pl +0 -69
- package/examples/web-names.pl +0 -83
- package/examples/weighted-interval-scheduling.pl +0 -81
- package/examples/witch.pl +0 -38
- package/examples/wolf-goat-cabbage.pl +0 -56
- package/examples/zebra.pl +0 -45
- package/test/conformance/cases/001_fact_output.pl +0 -4
- package/test/conformance/cases/002_rule_recursion.pl +0 -7
- package/test/conformance/cases/003_terms_and_readback.pl +0 -16
- package/test/conformance/cases/004_conjunction_and_parentheses.pl +0 -5
- package/test/conformance/cases/005_list_deconstruction.pl +0 -6
- package/test/conformance/cases/006_comma_formula_data.pl +0 -4
- package/test/conformance/cases/007_anonymous_variables.pl +0 -5
- package/test/conformance/cases/008_graphic_atoms.pl +0 -6
- package/test/conformance/cases/009_comments_and_whitespace.pl +0 -5
- package/test/conformance/cases/010_variable_scope_and_reuse.pl +0 -8
- package/test/conformance/cases/011_predicate_arity.pl +0 -6
- package/test/conformance/cases/012_nested_compound_unification.pl +0 -5
- package/test/conformance/cases/013_multiple_clauses_order.pl +0 -6
- package/test/conformance/cases/014_failure_filters_answers.pl +0 -7
- package/test/conformance/cases/015_improper_list_unification.pl +0 -6
- package/test/conformance/cases/016_arity_zero_atom.pl +0 -4
- package/test/conformance/cases/017_three_step_recursion.pl +0 -8
- package/test/conformance/cases/018_quoted_atom_readback.pl +0 -6
- package/test/conformance/cases/019_parenthesized_three_conjuncts.pl +0 -7
- package/test/conformance/cases/020_nested_list_terms.pl +0 -5
- package/test/conformance/cases/021_repeated_variable_head.pl +0 -7
- package/test/conformance/cases/022_rule_head_structure.pl +0 -5
- package/test/conformance/cases/023_quoted_escapes_readback.pl +0 -5
- package/test/conformance/cases/024_numeric_literal_readback.pl +0 -6
- package/test/conformance/cases/025_body_parentheses_with_formula_data.pl +0 -5
- package/test/conformance/cases/026_underscore_named_variable_reuse.pl +0 -5
- package/test/conformance/cases/027_default_derived_output.pl +0 -5
- package/test/conformance/cases/028_materialize_focus.pl +0 -5
- package/test/conformance/cases/029_arithmetic_and_comparison.pl +0 -11
- package/test/conformance/cases/030_strings_and_atoms.pl +0 -4
- package/test/conformance/cases/031_lists_aggregation_ordering.pl +0 -10
- package/test/conformance/cases/032_holds_parts.pl +0 -4
- package/test/conformance/cases/033_negation_once_generators.pl +0 -7
- package/test/conformance/cases/034_equality_and_inequality.pl +0 -6
- package/test/conformance/cases/035_list_relations.pl +0 -5
- package/test/conformance/cases/036_append_splits.pl +0 -3
- package/test/conformance/cases/038_memoize_declaration.pl +0 -8
- package/test/conformance/cases/038_memoize_declaration.query +0 -1
- package/test/conformance/cases/039_numeric_functions.pl +0 -9
- package/test/conformance/cases/040_between_enumeration.pl +0 -3
- package/test/conformance/cases/041_smallest_divisor.pl +0 -3
- package/test/conformance/cases/042_negation_filter.pl +0 -7
- package/test/conformance/cases/043_once_user_predicate.pl +0 -5
- package/test/conformance/cases/044_findall_user_goal.pl +0 -6
- package/test/conformance/cases/045_sort_deduplicates_atoms.pl +0 -3
- package/test/conformance/cases/046_append_bound_prefix_suffix.pl +0 -4
- package/test/conformance/cases/047_nth0_index_generation.pl +0 -3
- package/test/conformance/cases/048_set_nth0_edges.pl +0 -4
- package/test/conformance/cases/049_select_duplicate_occurrences.pl +0 -3
- package/test/conformance/cases/050_not_member_filter.pl +0 -6
- package/test/conformance/cases/051_nested_holds_parts.pl +0 -4
- package/test/conformance/cases/052_holds_member.pl +0 -3
- package/test/conformance/cases/053_materialize_excludes_source_fact.pl +0 -6
- package/test/conformance/cases/055_string_matching_filters.pl +0 -6
- package/test/conformance/cases/056_string_and_atom_concat.pl +0 -3
- package/test/conformance/cases/057_countall_empty_and_nonempty.pl +0 -4
- package/test/conformance/cases/058_sumall_numeric_template.pl +0 -5
- package/test/conformance/cases/059_aggregate_min_template.pl +0 -5
- package/test/conformance/cases/060_aggregate_max_compound_key.pl +0 -5
- package/test/conformance/cases/061_date_difference.pl +0 -4
- package/test/conformance/cases/062_reusable_numeric_builtins.pl +0 -10
- package/test/conformance/cases/063_reusable_list_builtins.pl +0 -11
- package/test/conformance/cases/064_reusable_string_builtins.pl +0 -12
- package/test/conformance/cases/065_reusable_term_control_builtins.pl +0 -11
- package/test/conformance/cases/066_numeric_edges.pl +0 -14
- package/test/conformance/cases/067_list_edges.pl +0 -10
- package/test/conformance/cases/068_list_generation_order.pl +0 -7
- package/test/conformance/cases/069_list_summaries_and_sets.pl +0 -9
- package/test/conformance/cases/070_matches_named_captures.pl +0 -13
- package/test/conformance/cases/071_string_edges.pl +0 -10
- package/test/conformance/cases/072_string_conversions.pl +0 -10
- package/test/conformance/cases/073_term_introspection_edges.pl +0 -10
- package/test/conformance/cases/074_forall_edges.pl +0 -10
- package/test/conformance/cases/075_aggregation_edges.pl +0 -12
- package/test/conformance/cases/076_composed_reusable_builtins.pl +0 -8
- package/test/conformance/cases/077_recursive_path_with_lists.pl +0 -10
- package/test/conformance/cases/078_mutual_recursion_with_arithmetic.pl +0 -7
- package/test/conformance/cases/079_big_integer_arithmetic.pl +0 -8
- package/test/conformance/cases/080_rounding_modes.pl +0 -10
- package/test/conformance/cases/081_zero_safe_numeric_functions.pl +0 -9
- package/test/conformance/cases/083_between_modes_and_empty_ranges.pl +0 -8
- package/test/conformance/cases/084_append_and_select_composition.pl +0 -7
- package/test/conformance/cases/085_nth_and_update_edges.pl +0 -8
- package/test/conformance/cases/086_slicing_pipeline.pl +0 -10
- package/test/conformance/cases/087_sort_reverse_length.pl +0 -8
- package/test/conformance/cases/088_list_summaries_failures.pl +0 -8
- package/test/conformance/cases/089_string_split_join_pipeline.pl +0 -7
- package/test/conformance/cases/090_string_substring_replace_edges.pl +0 -9
- package/test/conformance/cases/091_string_case_and_trim.pl +0 -7
- package/test/conformance/cases/092_scalar_string_conversions.pl +0 -9
- package/test/conformance/cases/093_regex_named_captures_context.pl +0 -8
- package/test/conformance/cases/094_context_holds_enumeration.pl +0 -7
- package/test/conformance/cases/095_term_introspection_roundtrip.pl +0 -8
- package/test/conformance/cases/096_functor_scalar_edges.pl +0 -8
- package/test/conformance/cases/097_control_negation_once_forall.pl +0 -13
- package/test/conformance/cases/098_aggregation_nested_templates.pl +0 -11
- package/test/conformance/cases/099_materialize_multiple_arities.pl +0 -8
- package/test/conformance/cases/100_reusable_builtin_workflow.pl +0 -10
- /package/examples/output/{access-control-policy.pl → access-control-policy.eye} +0 -0
- /package/examples/output/{ackermann.pl → ackermann.eye} +0 -0
- /package/examples/output/{age.pl → age.eye} +0 -0
- /package/examples/output/{aliases-and-namespaces.pl → aliases-and-namespaces.eye} +0 -0
- /package/examples/output/{alignment-demo.pl → alignment-demo.eye} +0 -0
- /package/examples/output/{allen-interval-calculus.pl → allen-interval-calculus.eye} +0 -0
- /package/examples/output/{ancestor.pl → ancestor.eye} +0 -0
- /package/examples/output/{animal.pl → animal.eye} +0 -0
- /package/examples/output/{annotation.pl → annotation.eye} +0 -0
- /package/examples/output/{auroracare.pl → auroracare.eye} +0 -0
- /package/examples/output/{backward.pl → backward.eye} +0 -0
- /package/examples/output/{basic-monadic.pl → basic-monadic.eye} +0 -0
- /package/examples/output/{bayes-diagnosis.pl → bayes-diagnosis.eye} +0 -0
- /package/examples/output/{bayes-therapy.pl → bayes-therapy.eye} +0 -0
- /package/examples/output/{beam-deflection.pl → beam-deflection.eye} +0 -0
- /package/examples/output/{binomial-vandermonde.pl → binomial-vandermonde.eye} +0 -0
- /package/examples/output/{blocks-world-planning.pl → blocks-world-planning.eye} +0 -0
- /package/examples/output/{bmi.pl → bmi.eye} +0 -0
- /package/examples/output/{braking-safety-worlds.pl → braking-safety-worlds.eye} +0 -0
- /package/examples/output/{buck-converter-design.pl → buck-converter-design.eye} +0 -0
- /package/examples/output/{cache-performance.pl → cache-performance.eye} +0 -0
- /package/examples/output/{canary-release.pl → canary-release.eye} +0 -0
- /package/examples/output/{cat-koko.pl → cat-koko.eye} +0 -0
- /package/examples/output/{catalan-convolution.pl → catalan-convolution.eye} +0 -0
- /package/examples/output/{chart-parser.pl → chart-parser.eye} +0 -0
- /package/examples/output/{clinical-trial-screening.pl → clinical-trial-screening.eye} +0 -0
- /package/examples/output/{collatz-1000.pl → collatz-1000.eye} +0 -0
- /package/examples/output/{combinatorics-findall-sort.pl → combinatorics-findall-sort.eye} +0 -0
- /package/examples/output/{competitive-enzyme-kinetics.pl → competitive-enzyme-kinetics.eye} +0 -0
- /package/examples/output/{complex.pl → complex.eye} +0 -0
- /package/examples/output/{composition-of-injective-functions-is-injective.pl → composition-of-injective-functions-is-injective.eye} +0 -0
- /package/examples/output/{context-association.pl → context-association.eye} +0 -0
- /package/examples/output/{context-schema-audit.pl → context-schema-audit.eye} +0 -0
- /package/examples/output/{continued-fraction-sqrt2.pl → continued-fraction-sqrt2.eye} +0 -0
- /package/examples/output/{control-system.pl → control-system.eye} +0 -0
- /package/examples/output/{critical-path-schedule.pl → critical-path-schedule.eye} +0 -0
- /package/examples/output/{cyclic-path.pl → cyclic-path.eye} +0 -0
- /package/examples/output/{d3-group.pl → d3-group.eye} +0 -0
- /package/examples/output/{dairy-energy-balance.pl → dairy-energy-balance.eye} +0 -0
- /package/examples/output/{data-negotiation.pl → data-negotiation.eye} +0 -0
- /package/examples/output/{deep-taxonomy-10.pl → deep-taxonomy-10.eye} +0 -0
- /package/examples/output/{deep-taxonomy-100.pl → deep-taxonomy-100.eye} +0 -0
- /package/examples/output/{deep-taxonomy-1000.pl → deep-taxonomy-1000.eye} +0 -0
- /package/examples/output/{deep-taxonomy-10000.pl → deep-taxonomy-10000.eye} +0 -0
- /package/examples/output/{deep-taxonomy-100000.pl → deep-taxonomy-100000.eye} +0 -0
- /package/examples/output/{delfour.pl → delfour.eye} +0 -0
- /package/examples/output/{deontic-logic.pl → deontic-logic.eye} +0 -0
- /package/examples/output/{derived-backward-rule.pl → derived-backward-rule.eye} +0 -0
- /package/examples/output/{derived-rule.pl → derived-rule.eye} +0 -0
- /package/examples/output/{diamond-property.pl → diamond-property.eye} +0 -0
- /package/examples/output/{dijkstra-findall-sort.pl → dijkstra-findall-sort.eye} +0 -0
- /package/examples/output/{dijkstra-risk-path.pl → dijkstra-risk-path.eye} +0 -0
- /package/examples/output/{dijkstra.pl → dijkstra.eye} +0 -0
- /package/examples/output/{dining-philosophers.pl → dining-philosophers.eye} +0 -0
- /package/examples/output/{dog.pl → dog.eye} +0 -0
- /package/examples/output/{dpv-odrl-purpose-mapping.pl → dpv-odrl-purpose-mapping.eye} +0 -0
- /package/examples/output/{drone-corridor-planner.pl → drone-corridor-planner.eye} +0 -0
- /package/examples/output/{easter-computus.pl → easter-computus.eye} +0 -0
- /package/examples/output/{electrical-rc-filter.pl → electrical-rc-filter.eye} +0 -0
- /package/examples/output/{epidemic-policy.pl → epidemic-policy.eye} +0 -0
- /package/examples/output/{equivalence-classes-overlap-implies-same-class.pl → equivalence-classes-overlap-implies-same-class.eye} +0 -0
- /package/examples/output/{eulerian-path.pl → eulerian-path.eye} +0 -0
- /package/examples/output/{ev-range-worlds.pl → ev-range-worlds.eye} +0 -0
- /package/examples/output/{existential-rule.pl → existential-rule.eye} +0 -0
- /package/examples/output/{exoplanet-validation-worlds.pl → exoplanet-validation-worlds.eye} +0 -0
- /package/examples/output/{expression-eval.pl → expression-eval.eye} +0 -0
- /package/examples/output/{family-cousins.pl → family-cousins.eye} +0 -0
- /package/examples/output/{fastpow.pl → fastpow.eye} +0 -0
- /package/examples/output/{fft8-numeric.pl → fft8-numeric.eye} +0 -0
- /package/examples/output/{fibonacci.pl → fibonacci.eye} +0 -0
- /package/examples/output/{field-nitrogen-balance.pl → field-nitrogen-balance.eye} +0 -0
- /package/examples/output/{flandor.pl → flandor.eye} +0 -0
- /package/examples/output/{floating-point.pl → floating-point.eye} +0 -0
- /package/examples/output/{four-color-map.pl → four-color-map.eye} +0 -0
- /package/examples/output/{fundamental-theorem-arithmetic.pl → fundamental-theorem-arithmetic.eye} +0 -0
- /package/examples/output/{gd-step-certified.pl → gd-step-certified.eye} +0 -0
- /package/examples/output/{gdpr-compliance.pl → gdpr-compliance.eye} +0 -0
- /package/examples/output/{good-cobbler.pl → good-cobbler.eye} +0 -0
- /package/examples/output/{gps.pl → gps.eye} +0 -0
- /package/examples/output/{graph-reachability.pl → graph-reachability.eye} +0 -0
- /package/examples/output/{graph.pl → graph.eye} +0 -0
- /package/examples/output/{gray-code-counter.pl → gray-code-counter.eye} +0 -0
- /package/examples/output/{greatest-lower-bound-uniqueness.pl → greatest-lower-bound-uniqueness.eye} +0 -0
- /package/examples/output/{group-inverse-uniqueness.pl → group-inverse-uniqueness.eye} +0 -0
- /package/examples/output/{hamiltonian-path.pl → hamiltonian-path.eye} +0 -0
- /package/examples/output/{hamming-code.pl → hamming-code.eye} +0 -0
- /package/examples/output/{hanoi.pl → hanoi.eye} +0 -0
- /package/examples/output/{heat-loss.pl → heat-loss.eye} +0 -0
- /package/examples/output/{heron-theorem.pl → heron-theorem.eye} +0 -0
- /package/examples/output/{ideal-gas-law.pl → ideal-gas-law.eye} +0 -0
- /package/examples/output/{illegitimate-reasoning.pl → illegitimate-reasoning.eye} +0 -0
- /package/examples/output/{integer-partitions.pl → integer-partitions.eye} +0 -0
- /package/examples/output/{intuitionistic-logic-kripke.pl → intuitionistic-logic-kripke.eye} +0 -0
- /package/examples/output/{job-shop-scheduling.pl → job-shop-scheduling.eye} +0 -0
- /package/examples/output/{knapsack-optimization.pl → knapsack-optimization.eye} +0 -0
- /package/examples/output/{knowledge-engineering-alignment-flow.pl → knowledge-engineering-alignment-flow.eye} +0 -0
- /package/examples/output/{law-of-cosines.pl → law-of-cosines.eye} +0 -0
- /package/examples/output/{least-squares-regression.pl → least-squares-regression.eye} +0 -0
- /package/examples/output/{linear-logic-resources.pl → linear-logic-resources.eye} +0 -0
- /package/examples/output/{list-collection.pl → list-collection.eye} +0 -0
- /package/examples/output/{lldm.pl → lldm.eye} +0 -0
- /package/examples/output/{manufacturing-quality-control.pl → manufacturing-quality-control.eye} +0 -0
- /package/examples/output/{matrix-chain-order.pl → matrix-chain-order.eye} +0 -0
- /package/examples/output/{microgrid-dispatch.pl → microgrid-dispatch.eye} +0 -0
- /package/examples/output/{missionaries-cannibals.pl → missionaries-cannibals.eye} +0 -0
- /package/examples/output/{modal-logic-kripke.pl → modal-logic-kripke.eye} +0 -0
- /package/examples/output/{modular-exponentiation.pl → modular-exponentiation.eye} +0 -0
- /package/examples/output/{monkey-bananas.pl → monkey-bananas.eye} +0 -0
- /package/examples/output/{n-queens-8.pl → n-queens-8.eye} +0 -0
- /package/examples/output/{network-sla.pl → network-sla.eye} +0 -0
- /package/examples/output/{newton-raphson.pl → newton-raphson.eye} +0 -0
- /package/examples/output/{nixon-diamond.pl → nixon-diamond.eye} +0 -0
- /package/examples/output/{observability-log-correlation.pl → observability-log-correlation.eye} +0 -0
- /package/examples/output/{odrl-dpv-fpv-trust-flow.pl → odrl-dpv-fpv-trust-flow.eye} +0 -0
- /package/examples/output/{odrl-dpv-healthcare-risk-ranked.pl → odrl-dpv-healthcare-risk-ranked.eye} +0 -0
- /package/examples/output/{odrl-dpv-risk-ranked.pl → odrl-dpv-risk-ranked.eye} +0 -0
- /package/examples/output/{orbital-transfer-design.pl → orbital-transfer-design.eye} +0 -0
- /package/examples/output/{path-discovery.pl → path-discovery.eye} +0 -0
- /package/examples/output/{peano-arithmetic.pl → peano-arithmetic.eye} +0 -0
- /package/examples/output/{peasant.pl → peasant.eye} +0 -0
- /package/examples/output/{pell-equation.pl → pell-equation.eye} +0 -0
- /package/examples/output/{pendulum-period.pl → pendulum-period.eye} +0 -0
- /package/examples/output/{polynomial.pl → polynomial.eye} +0 -0
- /package/examples/output/{proof-contrapositive.pl → proof-contrapositive.eye} +0 -0
- /package/examples/output/{quadratic-formula.pl → quadratic-formula.eye} +0 -0
- /package/examples/output/{radioactive-decay.pl → radioactive-decay.eye} +0 -0
- /package/examples/output/{reusable-builtins.pl → reusable-builtins.eye} +0 -0
- /package/examples/output/{riemann-hypothesis.pl → riemann-hypothesis.eye} +0 -0
- /package/examples/output/{security-incident-correlation.pl → security-incident-correlation.eye} +0 -0
- /package/examples/output/{send-more-money.pl → send-more-money.eye} +0 -0
- /package/examples/output/{service-impact.pl → service-impact.eye} +0 -0
- /package/examples/output/{sieve.pl → sieve.eye} +0 -0
- /package/examples/output/{skolem-functions.pl → skolem-functions.eye} +0 -0
- /package/examples/output/{socket-age.pl → socket-age.eye} +0 -0
- /package/examples/output/{socket-family.pl → socket-family.eye} +0 -0
- /package/examples/output/{socrates.pl → socrates.eye} +0 -0
- /package/examples/output/{stable-marriage.pl → stable-marriage.eye} +0 -0
- /package/examples/output/{statistics-summary.pl → statistics-summary.eye} +0 -0
- /package/examples/output/{stirling-bell-numbers.pl → stirling-bell-numbers.eye} +0 -0
- /package/examples/output/{sudoku-4x4.pl → sudoku-4x4.eye} +0 -0
- /package/examples/output/{superdense-coding.pl → superdense-coding.eye} +0 -0
- /package/examples/output/{term-tools.pl → term-tools.eye} +0 -0
- /package/examples/output/{totient-summatory.pl → totient-summatory.eye} +0 -0
- /package/examples/output/{trust-flow-provenance-threshold.pl → trust-flow-provenance-threshold.eye} +0 -0
- /package/examples/output/{turing.pl → turing.eye} +0 -0
- /package/examples/output/{vector-similarity.pl → vector-similarity.eye} +0 -0
- /package/examples/output/{vulnerability-impact.pl → vulnerability-impact.eye} +0 -0
- /package/examples/output/{web-names.pl → web-names.eye} +0 -0
- /package/examples/output/{weighted-interval-scheduling.pl → weighted-interval-scheduling.eye} +0 -0
- /package/examples/output/{witch.pl → witch.eye} +0 -0
- /package/examples/output/{wolf-goat-cabbage.pl → wolf-goat-cabbage.eye} +0 -0
- /package/examples/output/{zebra.pl → zebra.eye} +0 -0
- /package/test/conformance/cases/{037_matching_and_comparison.pl → 037_matching_and_comparison.eye} +0 -0
- /package/test/conformance/cases/{054_numeric_and_lexical_comparison.pl → 054_numeric_and_lexical_comparison.eye} +0 -0
- /package/test/conformance/cases/{082_comparison_semantics.pl → 082_comparison_semantics.eye} +0 -0
- /package/test/conformance/expected/{001_fact_output.pl → 001_fact_output.eye} +0 -0
- /package/test/conformance/expected/{002_rule_recursion.pl → 002_rule_recursion.eye} +0 -0
- /package/test/conformance/expected/{003_terms_and_readback.pl → 003_terms_and_readback.eye} +0 -0
- /package/test/conformance/expected/{004_conjunction_and_parentheses.pl → 004_conjunction_and_parentheses.eye} +0 -0
- /package/test/conformance/expected/{005_list_deconstruction.pl → 005_list_deconstruction.eye} +0 -0
- /package/test/conformance/expected/{006_comma_formula_data.pl → 006_comma_formula_data.eye} +0 -0
- /package/test/conformance/expected/{007_anonymous_variables.pl → 007_anonymous_variables.eye} +0 -0
- /package/test/conformance/expected/{008_graphic_atoms.pl → 008_graphic_atoms.eye} +0 -0
- /package/test/conformance/expected/{009_comments_and_whitespace.pl → 009_comments_and_whitespace.eye} +0 -0
- /package/test/conformance/expected/{010_variable_scope_and_reuse.pl → 010_variable_scope_and_reuse.eye} +0 -0
- /package/test/conformance/expected/{011_predicate_arity.pl → 011_predicate_arity.eye} +0 -0
- /package/test/conformance/expected/{012_nested_compound_unification.pl → 012_nested_compound_unification.eye} +0 -0
- /package/test/conformance/expected/{013_multiple_clauses_order.pl → 013_multiple_clauses_order.eye} +0 -0
- /package/test/conformance/expected/{014_failure_filters_answers.pl → 014_failure_filters_answers.eye} +0 -0
- /package/test/conformance/expected/{015_improper_list_unification.pl → 015_improper_list_unification.eye} +0 -0
- /package/test/conformance/expected/{016_arity_zero_atom.pl → 016_arity_zero_atom.eye} +0 -0
- /package/test/conformance/expected/{017_three_step_recursion.pl → 017_three_step_recursion.eye} +0 -0
- /package/test/conformance/expected/{018_quoted_atom_readback.pl → 018_quoted_atom_readback.eye} +0 -0
- /package/test/conformance/expected/{019_parenthesized_three_conjuncts.pl → 019_parenthesized_three_conjuncts.eye} +0 -0
- /package/test/conformance/expected/{020_nested_list_terms.pl → 020_nested_list_terms.eye} +0 -0
- /package/test/conformance/expected/{021_repeated_variable_head.pl → 021_repeated_variable_head.eye} +0 -0
- /package/test/conformance/expected/{022_rule_head_structure.pl → 022_rule_head_structure.eye} +0 -0
- /package/test/conformance/expected/{023_quoted_escapes_readback.pl → 023_quoted_escapes_readback.eye} +0 -0
- /package/test/conformance/expected/{024_numeric_literal_readback.pl → 024_numeric_literal_readback.eye} +0 -0
- /package/test/conformance/expected/{025_body_parentheses_with_formula_data.pl → 025_body_parentheses_with_formula_data.eye} +0 -0
- /package/test/conformance/expected/{026_underscore_named_variable_reuse.pl → 026_question_underscore_named_variable_reuse.eye} +0 -0
- /package/test/conformance/expected/{027_default_derived_output.pl → 027_default_derived_output.eye} +0 -0
- /package/test/conformance/expected/{028_materialize_focus.pl → 028_materialize_focus.eye} +0 -0
- /package/test/conformance/expected/{029_arithmetic_and_comparison.pl → 029_arithmetic_and_comparison.eye} +0 -0
- /package/test/conformance/expected/{030_strings_and_atoms.pl → 030_strings_and_atoms.eye} +0 -0
- /package/test/conformance/expected/{031_lists_aggregation_ordering.pl → 031_lists_aggregation_ordering.eye} +0 -0
- /package/test/conformance/expected/{032_holds_parts.pl → 032_holds_parts.eye} +0 -0
- /package/test/conformance/expected/{033_negation_once_generators.pl → 033_negation_once_generators.eye} +0 -0
- /package/test/conformance/expected/{034_equality_and_inequality.pl → 034_equality_and_inequality.eye} +0 -0
- /package/test/conformance/expected/{035_list_relations.pl → 035_list_relations.eye} +0 -0
- /package/test/conformance/expected/{036_append_splits.pl → 036_append_splits.eye} +0 -0
- /package/test/conformance/expected/{037_matching_and_comparison.pl → 037_matching_and_comparison.eye} +0 -0
- /package/test/conformance/expected/{038_memoize_declaration.pl → 038_table_declaration.eye} +0 -0
- /package/test/conformance/expected/{039_numeric_functions.pl → 039_numeric_functions.eye} +0 -0
- /package/test/conformance/expected/{040_between_enumeration.pl → 040_between_enumeration.eye} +0 -0
- /package/test/conformance/expected/{041_smallest_divisor.pl → 041_smallest_divisor.eye} +0 -0
- /package/test/conformance/expected/{042_negation_filter.pl → 042_negation_filter.eye} +0 -0
- /package/test/conformance/expected/{043_once_user_predicate.pl → 043_once_user_predicate.eye} +0 -0
- /package/test/conformance/expected/{044_findall_user_goal.pl → 044_findall_user_goal.eye} +0 -0
- /package/test/conformance/expected/{045_sort_deduplicates_atoms.pl → 045_sort_deduplicates_atoms.eye} +0 -0
- /package/test/conformance/expected/{046_append_bound_prefix_suffix.pl → 046_append_bound_prefix_suffix.eye} +0 -0
- /package/test/conformance/expected/{047_nth0_index_generation.pl → 047_nth0_index_generation.eye} +0 -0
- /package/test/conformance/expected/{048_set_nth0_edges.pl → 048_set_nth0_edges.eye} +0 -0
- /package/test/conformance/expected/{049_select_duplicate_occurrences.pl → 049_select_duplicate_occurrences.eye} +0 -0
- /package/test/conformance/expected/{050_not_member_filter.pl → 050_not_member_filter.eye} +0 -0
- /package/test/conformance/expected/{051_nested_holds_parts.pl → 051_nested_holds_parts.eye} +0 -0
- /package/test/conformance/expected/{052_holds_member.pl → 052_holds_member.eye} +0 -0
- /package/test/conformance/expected/{053_materialize_excludes_source_fact.pl → 053_materialize_excludes_source_fact.eye} +0 -0
- /package/test/conformance/expected/{054_numeric_and_lexical_comparison.pl → 054_numeric_and_lexical_comparison.eye} +0 -0
- /package/test/conformance/expected/{055_string_matching_filters.pl → 055_string_matching_filters.eye} +0 -0
- /package/test/conformance/expected/{056_string_and_atom_concat.pl → 056_string_and_atom_concat.eye} +0 -0
- /package/test/conformance/expected/{057_countall_empty_and_nonempty.pl → 057_countall_empty_and_nonempty.eye} +0 -0
- /package/test/conformance/expected/{058_sumall_numeric_template.pl → 058_sumall_numeric_template.eye} +0 -0
- /package/test/conformance/expected/{059_aggregate_min_template.pl → 059_aggregate_min_template.eye} +0 -0
- /package/test/conformance/expected/{060_aggregate_max_compound_key.pl → 060_aggregate_max_compound_key.eye} +0 -0
- /package/test/conformance/expected/{061_date_difference.pl → 061_date_difference.eye} +0 -0
- /package/test/conformance/expected/{062_reusable_numeric_builtins.pl → 062_reusable_numeric_builtins.eye} +0 -0
- /package/test/conformance/expected/{063_reusable_list_builtins.pl → 063_reusable_list_builtins.eye} +0 -0
- /package/test/conformance/expected/{064_reusable_string_builtins.pl → 064_reusable_string_builtins.eye} +0 -0
- /package/test/conformance/expected/{065_reusable_term_control_builtins.pl → 065_reusable_term_control_builtins.eye} +0 -0
- /package/test/conformance/expected/{066_numeric_edges.pl → 066_numeric_edges.eye} +0 -0
- /package/test/conformance/expected/{067_list_edges.pl → 067_list_edges.eye} +0 -0
- /package/test/conformance/expected/{068_list_generation_order.pl → 068_list_generation_order.eye} +0 -0
- /package/test/conformance/expected/{069_list_summaries_and_sets.pl → 069_list_summaries_and_sets.eye} +0 -0
- /package/test/conformance/expected/{070_matches_named_captures.pl → 070_matches_named_captures.eye} +0 -0
- /package/test/conformance/expected/{071_string_edges.pl → 071_string_edges.eye} +0 -0
- /package/test/conformance/expected/{072_string_conversions.pl → 072_string_conversions.eye} +0 -0
- /package/test/conformance/expected/{073_term_introspection_edges.pl → 073_term_introspection_edges.eye} +0 -0
- /package/test/conformance/expected/{074_forall_edges.pl → 074_forall_edges.eye} +0 -0
- /package/test/conformance/expected/{075_aggregation_edges.pl → 075_aggregation_edges.eye} +0 -0
- /package/test/conformance/expected/{076_composed_reusable_builtins.pl → 076_composed_reusable_builtins.eye} +0 -0
- /package/test/conformance/expected/{077_recursive_path_with_lists.pl → 077_recursive_path_with_lists.eye} +0 -0
- /package/test/conformance/expected/{078_mutual_recursion_with_arithmetic.pl → 078_mutual_recursion_with_arithmetic.eye} +0 -0
- /package/test/conformance/expected/{079_big_integer_arithmetic.pl → 079_big_integer_arithmetic.eye} +0 -0
- /package/test/conformance/expected/{080_rounding_modes.pl → 080_rounding_modes.eye} +0 -0
- /package/test/conformance/expected/{081_zero_safe_numeric_functions.pl → 081_zero_safe_numeric_functions.eye} +0 -0
- /package/test/conformance/expected/{082_comparison_semantics.pl → 082_comparison_semantics.eye} +0 -0
- /package/test/conformance/expected/{083_between_modes_and_empty_ranges.pl → 083_between_modes_and_empty_ranges.eye} +0 -0
- /package/test/conformance/expected/{084_append_and_select_composition.pl → 084_append_and_select_composition.eye} +0 -0
- /package/test/conformance/expected/{085_nth_and_update_edges.pl → 085_nth_and_update_edges.eye} +0 -0
- /package/test/conformance/expected/{086_slicing_pipeline.pl → 086_slicing_pipeline.eye} +0 -0
- /package/test/conformance/expected/{087_sort_reverse_length.pl → 087_sort_reverse_length.eye} +0 -0
- /package/test/conformance/expected/{088_list_summaries_failures.pl → 088_list_summaries_failures.eye} +0 -0
- /package/test/conformance/expected/{089_string_split_join_pipeline.pl → 089_string_split_join_pipeline.eye} +0 -0
- /package/test/conformance/expected/{090_string_substring_replace_edges.pl → 090_string_substring_replace_edges.eye} +0 -0
- /package/test/conformance/expected/{091_string_case_and_trim.pl → 091_string_case_and_trim.eye} +0 -0
- /package/test/conformance/expected/{092_scalar_string_conversions.pl → 092_scalar_string_conversions.eye} +0 -0
- /package/test/conformance/expected/{093_regex_named_captures_context.pl → 093_regex_named_captures_context.eye} +0 -0
- /package/test/conformance/expected/{094_context_holds_enumeration.pl → 094_context_holds_enumeration.eye} +0 -0
- /package/test/conformance/expected/{095_term_introspection_roundtrip.pl → 095_term_introspection_roundtrip.eye} +0 -0
- /package/test/conformance/expected/{096_functor_scalar_edges.pl → 096_functor_scalar_edges.eye} +0 -0
- /package/test/conformance/expected/{097_control_negation_once_forall.pl → 097_control_negation_once_forall.eye} +0 -0
- /package/test/conformance/expected/{098_aggregation_nested_templates.pl → 098_aggregation_nested_templates.eye} +0 -0
- /package/test/conformance/expected/{099_materialize_multiple_arities.pl → 099_materialize_multiple_arities.eye} +0 -0
- /package/test/conformance/expected/{100_reusable_builtin_workflow.pl → 100_reusable_builtin_workflow.eye} +0 -0
|
@@ -0,0 +1,85 @@
|
|
|
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
|
+
%
|
|
8
|
+
% Accumulating sufficient statistics keeps the regression formulas compact and
|
|
9
|
+
% makes the proof show the same intermediate values a hand calculation would use.
|
|
10
|
+
materialize(slope, 2).
|
|
11
|
+
materialize(intercept, 2).
|
|
12
|
+
materialize(rSquared, 2).
|
|
13
|
+
materialize(status, 2).
|
|
14
|
+
materialize(reason, 2).
|
|
15
|
+
|
|
16
|
+
% Program structure: facts set up the scenario, and rules derive the materialized conclusions.
|
|
17
|
+
dataset(regression1, [point(1.0, 2.0), point(2.0, 3.0), point(3.0, 5.0), point(4.0, 4.0)]).
|
|
18
|
+
threshold(regression1, minimum_r_squared, 0.60).
|
|
19
|
+
|
|
20
|
+
% stats/7 folds points into N, Σx, Σy, Σx², Σxy, and Σy².
|
|
21
|
+
stats([], 0.0, 0.0, 0.0, 0.0, 0.0, 0.0).
|
|
22
|
+
% Derivation rules: each rule below contributes one logical step toward the displayed results.
|
|
23
|
+
stats([point(?x, ?y)|?rest], ?n, ?sumx, ?sumy, ?sumxx, ?sumxy, ?sumyy) :-
|
|
24
|
+
stats(?rest, ?n0, ?sumx0, ?sumy0, ?sumxx0, ?sumxy0, ?sumyy0),
|
|
25
|
+
add(?n0, 1.0, ?n),
|
|
26
|
+
add(?sumx0, ?x, ?sumx),
|
|
27
|
+
add(?sumy0, ?y, ?sumy),
|
|
28
|
+
mul(?x, ?x, ?xx),
|
|
29
|
+
add(?sumxx0, ?xx, ?sumxx),
|
|
30
|
+
mul(?x, ?y, ?xy),
|
|
31
|
+
add(?sumxy0, ?xy, ?sumxy),
|
|
32
|
+
mul(?y, ?y, ?yy),
|
|
33
|
+
add(?sumyy0, ?yy, ?sumyy).
|
|
34
|
+
|
|
35
|
+
sufficient_statistics(?data, ?n, ?sumx, ?sumy, ?sumxx, ?sumxy, ?sumyy) :-
|
|
36
|
+
dataset(?data, ?points),
|
|
37
|
+
stats(?points, ?n, ?sumx, ?sumy, ?sumxx, ?sumxy, ?sumyy).
|
|
38
|
+
|
|
39
|
+
slope(?data, ?slope) :-
|
|
40
|
+
sufficient_statistics(?data, ?n, ?sumx, ?sumy, ?sumxx, ?sumxy, ?_sumyy),
|
|
41
|
+
mul(?n, ?sumxy, ?nsumxy),
|
|
42
|
+
mul(?sumx, ?sumy, ?sumxsumy),
|
|
43
|
+
sub(?nsumxy, ?sumxsumy, ?numerator),
|
|
44
|
+
mul(?n, ?sumxx, ?nsumxx),
|
|
45
|
+
mul(?sumx, ?sumx, ?sumxsquared),
|
|
46
|
+
sub(?nsumxx, ?sumxsquared, ?denominator),
|
|
47
|
+
div(?numerator, ?denominator, ?slope).
|
|
48
|
+
|
|
49
|
+
intercept(?data, ?intercept) :-
|
|
50
|
+
sufficient_statistics(?data, ?n, ?sumx, ?sumy, ?_sumxx, ?_sumxy, ?_sumyy),
|
|
51
|
+
slope(?data, ?slope),
|
|
52
|
+
mul(?slope, ?sumx, ?slopesumx),
|
|
53
|
+
sub(?sumy, ?slopesumx, ?numerator),
|
|
54
|
+
div(?numerator, ?n, ?intercept).
|
|
55
|
+
|
|
56
|
+
r_squared(?data, ?r2) :-
|
|
57
|
+
sufficient_statistics(?data, ?n, ?sumx, ?sumy, ?sumxx, ?sumxy, ?sumyy),
|
|
58
|
+
mul(?n, ?sumxy, ?nsumxy),
|
|
59
|
+
mul(?sumx, ?sumy, ?sumxsumy),
|
|
60
|
+
sub(?nsumxy, ?sumxsumy, ?numeratorbase),
|
|
61
|
+
pow(?numeratorbase, 2.0, ?numerator),
|
|
62
|
+
mul(?n, ?sumxx, ?nsumxx),
|
|
63
|
+
mul(?sumx, ?sumx, ?sumxsquared),
|
|
64
|
+
sub(?nsumxx, ?sumxsquared, ?xspread),
|
|
65
|
+
mul(?n, ?sumyy, ?nsumyy),
|
|
66
|
+
mul(?sumy, ?sumy, ?sumysquared),
|
|
67
|
+
sub(?nsumyy, ?sumysquared, ?yspread),
|
|
68
|
+
mul(?xspread, ?yspread, ?denominator),
|
|
69
|
+
div(?numerator, ?denominator, ?r2).
|
|
70
|
+
|
|
71
|
+
accepted_fit(?data) :-
|
|
72
|
+
r_squared(?data, ?r2),
|
|
73
|
+
threshold(?data, minimum_r_squared, ?minimum),
|
|
74
|
+
ge(?r2, ?minimum).
|
|
75
|
+
|
|
76
|
+
|
|
77
|
+
|
|
78
|
+
rSquared(?data, ?r2) :-
|
|
79
|
+
r_squared(?data, ?r2).
|
|
80
|
+
|
|
81
|
+
status(?data, accepted_linear_fit) :-
|
|
82
|
+
accepted_fit(?data).
|
|
83
|
+
|
|
84
|
+
reason(?data, "R squared meets the minimum explanatory-power threshold") :-
|
|
85
|
+
accepted_fit(?data).
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
% Linear logic emulation with explicit consumable resources.
|
|
2
|
+
%
|
|
3
|
+
% Eyelang predicates are reusable Horn clauses, so this example represents the
|
|
4
|
+
% linear part explicitly as a multiset-like state list. A rule consumes its
|
|
5
|
+
% input resources with select/3 and produces a new state. If a resource is not
|
|
6
|
+
% present, the step fails, which models the “use exactly once” discipline of
|
|
7
|
+
% linear implication.
|
|
8
|
+
%
|
|
9
|
+
% The successful plan turns wheat, yeast, and heat into bread. The rejected
|
|
10
|
+
% double-spend check shows that one coin cannot be consumed by two purchases.
|
|
11
|
+
materialize(linear_result, 3).
|
|
12
|
+
materialize(linear_check, 2).
|
|
13
|
+
|
|
14
|
+
initial(kitchen, [wheat, yeast, heat]).
|
|
15
|
+
initial(wallet, [coin]).
|
|
16
|
+
|
|
17
|
+
% linear_rule(Name, Inputs, Outputs) is an encoded linear implication:
|
|
18
|
+
% Inputs -o Outputs, evaluated against the current resource state.
|
|
19
|
+
linear_rule(mill, [wheat], [flour]).
|
|
20
|
+
linear_rule(mix, [flour, yeast], [dough]).
|
|
21
|
+
linear_rule(bake, [dough, heat], [bread]).
|
|
22
|
+
linear_rule(buy_flour, [coin], [flour]).
|
|
23
|
+
linear_rule(buy_yeast, [coin], [yeast]).
|
|
24
|
+
|
|
25
|
+
% consume_all/3 removes each required resource once. This is the key linear
|
|
26
|
+
% operation: a second attempt to use the same token cannot succeed.
|
|
27
|
+
consume_all([], ?state, ?state).
|
|
28
|
+
consume_all([?need | ?needs], ?state0, ?state2) :-
|
|
29
|
+
select(?need, ?state0, ?state1),
|
|
30
|
+
consume_all(?needs, ?state1, ?state2).
|
|
31
|
+
|
|
32
|
+
linear_step(?state0, ?rule, ?state2) :-
|
|
33
|
+
linear_rule(?rule, ?inputs, ?outputs),
|
|
34
|
+
consume_all(?inputs, ?state0, ?rest),
|
|
35
|
+
append(?outputs, ?rest, ?state2).
|
|
36
|
+
|
|
37
|
+
run_linear(0, ?state, [], ?state).
|
|
38
|
+
run_linear(?steps, ?state0, [?rule | ?plan], ?state2) :-
|
|
39
|
+
gt(?steps, 0),
|
|
40
|
+
linear_step(?state0, ?rule, ?state1),
|
|
41
|
+
sub(?steps, 1, ?remaining),
|
|
42
|
+
run_linear(?remaining, ?state1, ?plan, ?state2).
|
|
43
|
+
|
|
44
|
+
linear_result(kitchen, ?plan, ?finalstate) :-
|
|
45
|
+
initial(kitchen, ?state),
|
|
46
|
+
run_linear(3, ?state, ?plan, ?finalstate),
|
|
47
|
+
eq(?finalstate, [bread]).
|
|
48
|
+
|
|
49
|
+
linear_check(double_spend_rejected, yes) :-
|
|
50
|
+
initial(wallet, ?state),
|
|
51
|
+
not(run_linear(2, ?state, [buy_flour, buy_yeast], ?_finalstate)).
|
|
@@ -0,0 +1,35 @@
|
|
|
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
|
+
% The collection/2 facts keep complete lists as first-class terms rather than
|
|
12
|
+
% expanding them into separate item facts.
|
|
13
|
+
% Lists are first-class terms in facts and rule heads/bodies.
|
|
14
|
+
collection(numbers, [1, 2, 3]).
|
|
15
|
+
collection(letters, [a, b]).
|
|
16
|
+
|
|
17
|
+
% The derived predicates show list length, membership, append, and pattern
|
|
18
|
+
% matching with [Head|Tail] in the smallest possible setting.
|
|
19
|
+
length(numbers, ?n) :-
|
|
20
|
+
collection(numbers, ?list),
|
|
21
|
+
length(?list, ?n).
|
|
22
|
+
|
|
23
|
+
member(numbers, ?x) :-
|
|
24
|
+
collection(numbers, ?list),
|
|
25
|
+
member(?x, ?list).
|
|
26
|
+
|
|
27
|
+
append(letters, ?extended) :-
|
|
28
|
+
collection(letters, ?list),
|
|
29
|
+
append(?list, [c], ?extended).
|
|
30
|
+
|
|
31
|
+
head(letters, ?head) :-
|
|
32
|
+
collection(letters, [?head|?_tail]).
|
|
33
|
+
|
|
34
|
+
tail(letters, ?tail) :-
|
|
35
|
+
collection(letters, [?_head|?tail]).
|
|
@@ -0,0 +1,80 @@
|
|
|
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
|
+
% val/3 stores raw landmark coordinates, derived deltas, line coefficients,
|
|
16
|
+
% projected landmarks, lengths, and alarm values in one measurement namespace.
|
|
17
|
+
measurement(meas47).
|
|
18
|
+
|
|
19
|
+
% measured landmark coordinates, in centimetres
|
|
20
|
+
val(meas47, p1xCm, 10.1).
|
|
21
|
+
val(meas47, p1yCm, 7.8).
|
|
22
|
+
val(meas47, p2xCm, 45.1).
|
|
23
|
+
val(meas47, p2yCm, 5.6).
|
|
24
|
+
val(meas47, p3xCm, 3.6).
|
|
25
|
+
val(meas47, p3yCm, 29.8).
|
|
26
|
+
val(meas47, p4xCm, 54.7).
|
|
27
|
+
val(meas47, p4yCm, 28.5).
|
|
28
|
+
|
|
29
|
+
% threshold used by the alarm rule, in centimetres
|
|
30
|
+
threshold(meas47, lld_alarm_threshold_cm, 1.25).
|
|
31
|
+
|
|
32
|
+
% geometric intermediate values
|
|
33
|
+
% The geometry rules build from coordinate differences to projected knee points,
|
|
34
|
+
% then compute left/right leg lengths and compare the discrepancy with a threshold.
|
|
35
|
+
val(?m, dx12Cm, ?z) :- measurement(?m), val(?m, p1xCm, ?x), val(?m, p2xCm, ?y), sub(?x, ?y, ?z).
|
|
36
|
+
val(?m, dx51Cm, ?z) :- measurement(?m), val(?m, p5xCm, ?x), val(?m, p1xCm, ?y), sub(?x, ?y, ?z).
|
|
37
|
+
val(?m, dx53Cm, ?z) :- measurement(?m), val(?m, p5xCm, ?x), val(?m, p3xCm, ?y), sub(?x, ?y, ?z).
|
|
38
|
+
val(?m, dx62Cm, ?z) :- measurement(?m), val(?m, p6xCm, ?x), val(?m, p2xCm, ?y), sub(?x, ?y, ?z).
|
|
39
|
+
val(?m, dx64Cm, ?z) :- measurement(?m), val(?m, p6xCm, ?x), val(?m, p4xCm, ?y), sub(?x, ?y, ?z).
|
|
40
|
+
val(?m, dy12Cm, ?z) :- measurement(?m), val(?m, p1yCm, ?x), val(?m, p2yCm, ?y), sub(?x, ?y, ?z).
|
|
41
|
+
val(?m, dy13Cm, ?z) :- measurement(?m), val(?m, p1yCm, ?x), val(?m, p3yCm, ?y), sub(?x, ?y, ?z).
|
|
42
|
+
val(?m, dy24Cm, ?z) :- measurement(?m), val(?m, p2yCm, ?x), val(?m, p4yCm, ?y), sub(?x, ?y, ?z).
|
|
43
|
+
val(?m, dy53Cm, ?z) :- measurement(?m), val(?m, p5yCm, ?x), val(?m, p3yCm, ?y), sub(?x, ?y, ?z).
|
|
44
|
+
val(?m, dy64Cm, ?z) :- measurement(?m), val(?m, p6yCm, ?x), val(?m, p4yCm, ?y), sub(?x, ?y, ?z).
|
|
45
|
+
val(?m, cL1, ?z) :- measurement(?m), val(?m, dy12Cm, ?y), val(?m, dx12Cm, ?x), div(?y, ?x, ?z).
|
|
46
|
+
val(?m, dL3m, ?z) :- measurement(?m), val(?m, cL1, ?x), div(1, ?x, ?z).
|
|
47
|
+
val(?m, cL3, ?z) :- measurement(?m), val(?m, dL3m, ?x), sub(0, ?x, ?z).
|
|
48
|
+
val(?m, pL1x1Cm, ?z) :- measurement(?m), val(?m, cL1, ?x), val(?m, p1xCm, ?y), mul(?x, ?y, ?z).
|
|
49
|
+
val(?m, pL1x2Cm, ?z) :- measurement(?m), val(?m, cL1, ?x), val(?m, p2xCm, ?y), mul(?x, ?y, ?z).
|
|
50
|
+
val(?m, pL3x3Cm, ?z) :- measurement(?m), val(?m, cL3, ?x), val(?m, p3xCm, ?y), mul(?x, ?y, ?z).
|
|
51
|
+
val(?m, pL3x4Cm, ?z) :- measurement(?m), val(?m, cL3, ?x), val(?m, p4xCm, ?y), mul(?x, ?y, ?z).
|
|
52
|
+
val(?m, dd13Cm, ?z) :- measurement(?m), val(?m, pL1x1Cm, ?x), val(?m, pL3x3Cm, ?y), sub(?x, ?y, ?z).
|
|
53
|
+
val(?m, ddy13Cm, ?z) :- measurement(?m), val(?m, dd13Cm, ?x), val(?m, dy13Cm, ?y), sub(?x, ?y, ?z).
|
|
54
|
+
val(?m, dd24Cm, ?z) :- measurement(?m), val(?m, pL1x2Cm, ?x), val(?m, pL3x4Cm, ?y), sub(?x, ?y, ?z).
|
|
55
|
+
val(?m, ddy24Cm, ?z) :- measurement(?m), val(?m, dd24Cm, ?x), val(?m, dy24Cm, ?y), sub(?x, ?y, ?z).
|
|
56
|
+
val(?m, ddL13, ?z) :- measurement(?m), val(?m, cL1, ?x), val(?m, cL3, ?y), sub(?x, ?y, ?z).
|
|
57
|
+
val(?m, pL1dx51Cm, ?z) :- measurement(?m), val(?m, cL1, ?x), val(?m, dx51Cm, ?y), mul(?x, ?y, ?z).
|
|
58
|
+
val(?m, pL1dx62Cm, ?z) :- measurement(?m), val(?m, cL1, ?x), val(?m, dx62Cm, ?y), mul(?x, ?y, ?z).
|
|
59
|
+
val(?m, p5xCm, ?z) :- measurement(?m), val(?m, ddy13Cm, ?x), val(?m, ddL13, ?y), div(?x, ?y, ?z).
|
|
60
|
+
val(?m, p5yCm, ?z) :- measurement(?m), val(?m, pL1dx51Cm, ?x), val(?m, p1yCm, ?y), add(?x, ?y, ?z).
|
|
61
|
+
val(?m, p6xCm, ?z) :- measurement(?m), val(?m, ddy24Cm, ?x), val(?m, ddL13, ?y), div(?x, ?y, ?z).
|
|
62
|
+
val(?m, p6yCm, ?z) :- measurement(?m), val(?m, pL1dx62Cm, ?x), val(?m, p2yCm, ?y), add(?x, ?y, ?z).
|
|
63
|
+
val(?m, sdx53Cm2, ?z) :- measurement(?m), val(?m, dx53Cm, ?x), pow(?x, 2, ?z).
|
|
64
|
+
val(?m, sdx64Cm2, ?z) :- measurement(?m), val(?m, dx64Cm, ?x), pow(?x, 2, ?z).
|
|
65
|
+
val(?m, sdy53Cm2, ?z) :- measurement(?m), val(?m, dy53Cm, ?x), pow(?x, 2, ?z).
|
|
66
|
+
val(?m, sdy64Cm2, ?z) :- measurement(?m), val(?m, dy64Cm, ?x), pow(?x, 2, ?z).
|
|
67
|
+
val(?m, ssd53Cm2, ?z) :- measurement(?m), val(?m, sdx53Cm2, ?x), val(?m, sdy53Cm2, ?y), add(?x, ?y, ?z).
|
|
68
|
+
val(?m, ssd64Cm2, ?z) :- measurement(?m), val(?m, sdx64Cm2, ?x), val(?m, sdy64Cm2, ?y), add(?x, ?y, ?z).
|
|
69
|
+
val(?m, d53Cm, ?z) :- measurement(?m), val(?m, ssd53Cm2, ?x), pow(?x, 0.5, ?z).
|
|
70
|
+
val(?m, d64Cm, ?z) :- measurement(?m), val(?m, ssd64Cm2, ?x), pow(?x, 0.5, ?z).
|
|
71
|
+
val(?m, dCm, ?z) :- measurement(?m), val(?m, d53Cm, ?x), val(?m, d64Cm, ?y), sub(?x, ?y, ?z).
|
|
72
|
+
|
|
73
|
+
% concise output layer
|
|
74
|
+
type(?m, lld_alarm) :- measurement(?m), val(?m, dCm, ?d), threshold(?m, lld_alarm_threshold_cm, ?t), sub(0, ?t, ?negt), lt(?d, ?negt).
|
|
75
|
+
type(?m, lld_alarm) :- measurement(?m), val(?m, dCm, ?d), threshold(?m, lld_alarm_threshold_cm, ?t), gt(?d, ?t).
|
|
76
|
+
lld_left_length_cm(?m, ?l) :- type(?m, lld_alarm), val(?m, d53Cm, ?l).
|
|
77
|
+
lld_right_length_cm(?m, ?r) :- type(?m, lld_alarm), val(?m, d64Cm, ?r).
|
|
78
|
+
lld_discrepancy_cm(?m, ?d) :- type(?m, lld_alarm), val(?m, dCm, ?d).
|
|
79
|
+
lld_threshold_cm(?m, ?t) :- type(?m, lld_alarm), threshold(?m, lld_alarm_threshold_cm, ?t).
|
|
80
|
+
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,79 @@
|
|
|
1
|
+
% Matrix-chain multiplication order by tabled interval dynamic programming.
|
|
2
|
+
%
|
|
3
|
+
% cost(I, J, Cost) is the minimum scalar multiplication cost for matrices I..J.
|
|
4
|
+
% best_split/3 records which split obtains that cost, and parenthesization/3
|
|
5
|
+
% reconstructs one optimal multiplication tree.
|
|
6
|
+
materialize(matrix_chain_answer, 2).
|
|
7
|
+
|
|
8
|
+
table(cost, 3).
|
|
9
|
+
|
|
10
|
+
% Matrix dimensions are stored as adjacent p-values: matrix I has dimensions P_{I-1} x P_I.
|
|
11
|
+
|
|
12
|
+
% Dimensions for the CLRS-style chain: A1 is 30x35, A2 is 35x15, and so on.
|
|
13
|
+
% The dim/2 facts store boundary dimensions, so multiplying Ai..Ak by A(k+1)..Aj
|
|
14
|
+
% costs dim(I-1) * dim(K) * dim(J).
|
|
15
|
+
dim(0, 30).
|
|
16
|
+
dim(1, 35).
|
|
17
|
+
dim(2, 15).
|
|
18
|
+
dim(3, 5).
|
|
19
|
+
dim(4, 10).
|
|
20
|
+
dim(5, 20).
|
|
21
|
+
dim(6, 25).
|
|
22
|
+
|
|
23
|
+
matrix_count(6).
|
|
24
|
+
|
|
25
|
+
cost(?i, ?i, 0) :- matrix_count(?n), between(1, ?n, ?i).
|
|
26
|
+
cost(?i, ?j, ?cost) :-
|
|
27
|
+
lt(?i, ?j),
|
|
28
|
+
aggregate_min(?splitcost, ?k,
|
|
29
|
+
(between(?i, ?j, ?k),
|
|
30
|
+
lt(?k, ?j),
|
|
31
|
+
cost(?i, ?k, ?left),
|
|
32
|
+
add(?k, 1, ?k1),
|
|
33
|
+
cost(?k1, ?j, ?right),
|
|
34
|
+
sub(?i, 1, ?i0),
|
|
35
|
+
dim(?i0, ?rows),
|
|
36
|
+
dim(?k, ?shared),
|
|
37
|
+
dim(?j, ?cols),
|
|
38
|
+
mul(?rows, ?shared, ?first),
|
|
39
|
+
mul(?first, ?cols, ?multcost),
|
|
40
|
+
add(?left, ?right, ?partial),
|
|
41
|
+
add(?partial, ?multcost, ?splitcost)),
|
|
42
|
+
?cost, ?_bestk).
|
|
43
|
+
|
|
44
|
+
best_split(?i, ?j, ?k) :-
|
|
45
|
+
lt(?i, ?j),
|
|
46
|
+
aggregate_min(?splitcost, ?k,
|
|
47
|
+
(between(?i, ?j, ?k),
|
|
48
|
+
lt(?k, ?j),
|
|
49
|
+
cost(?i, ?k, ?left),
|
|
50
|
+
add(?k, 1, ?k1),
|
|
51
|
+
cost(?k1, ?j, ?right),
|
|
52
|
+
sub(?i, 1, ?i0),
|
|
53
|
+
dim(?i0, ?rows),
|
|
54
|
+
dim(?k, ?shared),
|
|
55
|
+
dim(?j, ?cols),
|
|
56
|
+
mul(?rows, ?shared, ?first),
|
|
57
|
+
mul(?first, ?cols, ?multcost),
|
|
58
|
+
add(?left, ?right, ?partial),
|
|
59
|
+
add(?partial, ?multcost, ?splitcost)),
|
|
60
|
+
?_cost, ?k).
|
|
61
|
+
|
|
62
|
+
parenthesization(?i, ?i, matrix(?i)).
|
|
63
|
+
parenthesization(?i, ?j, product(?lefttree, ?righttree)) :-
|
|
64
|
+
lt(?i, ?j),
|
|
65
|
+
best_split(?i, ?j, ?k),
|
|
66
|
+
add(?k, 1, ?k1),
|
|
67
|
+
parenthesization(?i, ?k, ?lefttree),
|
|
68
|
+
parenthesization(?k1, ?j, ?righttree).
|
|
69
|
+
|
|
70
|
+
matrix_chain_answer(min_cost, ?cost) :- cost(1, 6, ?cost).
|
|
71
|
+
matrix_chain_answer(best_split_1_6, ?k) :- best_split(1, 6, ?k).
|
|
72
|
+
matrix_chain_answer(best_order, ?tree) :- parenthesization(1, 6, ?tree).
|
|
73
|
+
subproblem(?i, ?j, ?cost) :-
|
|
74
|
+
matrix_count(?n),
|
|
75
|
+
between(1, ?n, ?i),
|
|
76
|
+
between(?i, ?n, ?j),
|
|
77
|
+
cost(?i, ?j, ?cost).
|
|
78
|
+
|
|
79
|
+
matrix_chain_answer(subproblem_count, ?count) :- countall(subproblem(?_i, ?_j, ?_cost), ?count).
|
|
@@ -0,0 +1,89 @@
|
|
|
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
|
+
%
|
|
8
|
+
% The dispatch policy is greedy but auditable: use renewables first, discharge
|
|
9
|
+
% the battery only down to reserve, then import the remaining deficit from grid.
|
|
10
|
+
materialize(renewablePower_kW, 2).
|
|
11
|
+
materialize(batteryDispatch_kW, 2).
|
|
12
|
+
materialize(gridImport_kW, 2).
|
|
13
|
+
materialize(reserveAfterDispatch_kW, 2).
|
|
14
|
+
materialize(status, 2).
|
|
15
|
+
materialize(reason, 2).
|
|
16
|
+
|
|
17
|
+
% Program structure: facts set up the scenario, and rules derive the materialized conclusions.
|
|
18
|
+
site(campus_interval_17).
|
|
19
|
+
|
|
20
|
+
load_kW(campus_interval_17, 620.0).
|
|
21
|
+
solar_kW(campus_interval_17, 180.0).
|
|
22
|
+
wind_kW(campus_interval_17, 90.0).
|
|
23
|
+
battery_max_discharge_kW(campus_interval_17, 320.0).
|
|
24
|
+
required_battery_reserve_kW(campus_interval_17, 80.0).
|
|
25
|
+
grid_contract_limit_kW(campus_interval_17, 150.0).
|
|
26
|
+
|
|
27
|
+
% Derivation rules: each rule below contributes one logical step toward the displayed results.
|
|
28
|
+
renewable_kW(?site, ?renewable) :-
|
|
29
|
+
solar_kW(?site, ?solar),
|
|
30
|
+
wind_kW(?site, ?wind),
|
|
31
|
+
add(?solar, ?wind, ?renewable).
|
|
32
|
+
|
|
33
|
+
net_deficit_kW(?site, ?deficit) :-
|
|
34
|
+
load_kW(?site, ?load),
|
|
35
|
+
renewable_kW(?site, ?renewable),
|
|
36
|
+
sub(?load, ?renewable, ?deficit).
|
|
37
|
+
|
|
38
|
+
reserve_aware_battery_limit_kW(?site, ?limit) :-
|
|
39
|
+
battery_max_discharge_kW(?site, ?maxdischarge),
|
|
40
|
+
required_battery_reserve_kW(?site, ?reserve),
|
|
41
|
+
sub(?maxdischarge, ?reserve, ?limit).
|
|
42
|
+
|
|
43
|
+
battery_dispatch_kW(?site, ?dispatch) :-
|
|
44
|
+
net_deficit_kW(?site, ?deficit),
|
|
45
|
+
reserve_aware_battery_limit_kW(?site, ?limit),
|
|
46
|
+
min(?deficit, ?limit, ?dispatch).
|
|
47
|
+
|
|
48
|
+
grid_import_kW(?site, ?import) :-
|
|
49
|
+
net_deficit_kW(?site, ?deficit),
|
|
50
|
+
battery_dispatch_kW(?site, ?dispatch),
|
|
51
|
+
sub(?deficit, ?dispatch, ?import).
|
|
52
|
+
|
|
53
|
+
battery_reserve_after_dispatch_kW(?site, ?reserveleft) :-
|
|
54
|
+
battery_max_discharge_kW(?site, ?maxdischarge),
|
|
55
|
+
battery_dispatch_kW(?site, ?dispatch),
|
|
56
|
+
sub(?maxdischarge, ?dispatch, ?reserveleft).
|
|
57
|
+
|
|
58
|
+
contract_ok(?site) :-
|
|
59
|
+
grid_import_kW(?site, ?import),
|
|
60
|
+
grid_contract_limit_kW(?site, ?limit),
|
|
61
|
+
le(?import, ?limit).
|
|
62
|
+
|
|
63
|
+
reserve_ok(?site) :-
|
|
64
|
+
battery_reserve_after_dispatch_kW(?site, ?reserveleft),
|
|
65
|
+
required_battery_reserve_kW(?site, ?required),
|
|
66
|
+
ge(?reserveleft, ?required).
|
|
67
|
+
|
|
68
|
+
% stable_dispatch/1 passes only when contract and reserve constraints remain satisfied.
|
|
69
|
+
stable_dispatch(?site) :-
|
|
70
|
+
contract_ok(?site),
|
|
71
|
+
reserve_ok(?site).
|
|
72
|
+
|
|
73
|
+
renewablePower_kW(?site, ?renewable) :-
|
|
74
|
+
renewable_kW(?site, ?renewable).
|
|
75
|
+
|
|
76
|
+
batteryDispatch_kW(?site, ?dispatch) :-
|
|
77
|
+
battery_dispatch_kW(?site, ?dispatch).
|
|
78
|
+
|
|
79
|
+
gridImport_kW(?site, ?import) :-
|
|
80
|
+
grid_import_kW(?site, ?import).
|
|
81
|
+
|
|
82
|
+
reserveAfterDispatch_kW(?site, ?reserveleft) :-
|
|
83
|
+
battery_reserve_after_dispatch_kW(?site, ?reserveleft).
|
|
84
|
+
|
|
85
|
+
status(?site, stable_dispatch) :-
|
|
86
|
+
stable_dispatch(?site).
|
|
87
|
+
|
|
88
|
+
reason(?site, "battery dispatch covers the deficit while preserving reserve and grid contract limits") :-
|
|
89
|
+
stable_dispatch(?site).
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
% Missionaries-and-cannibals river crossing as guarded state-space search.
|
|
2
|
+
%
|
|
3
|
+
% A state records missionaries and cannibals on the left bank plus the boat side.
|
|
4
|
+
% crossing/3 applies one legal boat load and state_safe/1 checks both banks.
|
|
5
|
+
% journey/4 carries a visited list to avoid loops in the finite state graph.
|
|
6
|
+
materialize(missionaries_cannibals_answer, 2).
|
|
7
|
+
|
|
8
|
+
% Boat loads: one or two passengers, with at least one passenger per crossing.
|
|
9
|
+
move(1, 0).
|
|
10
|
+
move(0, 1).
|
|
11
|
+
move(2, 0).
|
|
12
|
+
move(0, 2).
|
|
13
|
+
move(1, 1).
|
|
14
|
+
|
|
15
|
+
% A bank is safe if there are no missionaries or missionaries are not outnumbered.
|
|
16
|
+
bank_safe(0, ?_c).
|
|
17
|
+
bank_safe(?m, ?c) :- gt(?m, 0), ge(?m, ?c).
|
|
18
|
+
|
|
19
|
+
state_safe(state(?mleft, ?cleft, ?_boat)) :-
|
|
20
|
+
between(0, 3, ?mleft),
|
|
21
|
+
between(0, 3, ?cleft),
|
|
22
|
+
sub(3, ?mleft, ?mright),
|
|
23
|
+
sub(3, ?cleft, ?cright),
|
|
24
|
+
bank_safe(?mleft, ?cleft),
|
|
25
|
+
bank_safe(?mright, ?cright).
|
|
26
|
+
|
|
27
|
+
crossing(state(?mleft, ?cleft, left), state(?nextm, ?nextc, right), carry(?movem, ?movec)) :-
|
|
28
|
+
move(?movem, ?movec),
|
|
29
|
+
sub(?mleft, ?movem, ?nextm),
|
|
30
|
+
sub(?cleft, ?movec, ?nextc),
|
|
31
|
+
state_safe(state(?nextm, ?nextc, right)).
|
|
32
|
+
crossing(state(?mleft, ?cleft, right), state(?nextm, ?nextc, left), carry(?movem, ?movec)) :-
|
|
33
|
+
move(?movem, ?movec),
|
|
34
|
+
add(?mleft, ?movem, ?nextm),
|
|
35
|
+
add(?cleft, ?movec, ?nextc),
|
|
36
|
+
state_safe(state(?nextm, ?nextc, left)).
|
|
37
|
+
|
|
38
|
+
journey(?goal, ?goal, ?visited, ?visited).
|
|
39
|
+
journey(?state, ?goal, ?visited, ?path) :-
|
|
40
|
+
crossing(?state, ?next, ?_carry),
|
|
41
|
+
not_member(?next, ?visited),
|
|
42
|
+
journey(?next, ?goal, [?next|?visited], ?path).
|
|
43
|
+
|
|
44
|
+
solution(?path) :-
|
|
45
|
+
journey(state(3, 3, left), state(0, 0, right), [state(3, 3, left)], ?reversepath),
|
|
46
|
+
reverse(?reversepath, ?path).
|
|
47
|
+
|
|
48
|
+
missionaries_cannibals_answer(first_solution, ?path) :- once(solution(?path)).
|
|
49
|
+
missionaries_cannibals_answer(state_count, ?count) :- countall(state_safe(state(?_m, ?_c, ?_boat)), ?count).
|
|
50
|
+
missionaries_cannibals_answer(step_count, ?steps) :-
|
|
51
|
+
once(solution(?path)),
|
|
52
|
+
length(?path, ?states),
|
|
53
|
+
sub(?states, 1, ?steps).
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
% Modal logic emulation with a finite Kripke frame.
|
|
2
|
+
%
|
|
3
|
+
% Worlds and accessibility edges are ordinary facts. mforces/2 interprets modal
|
|
4
|
+
% formula terms such as box(clear) and diamond(repaired). box(F) is true at a
|
|
5
|
+
% world when every accessible world satisfies F; diamond(F) is true when at
|
|
6
|
+
% least one accessible world satisfies F.
|
|
7
|
+
materialize(modal_truth, 3).
|
|
8
|
+
materialize(modal_countermodel, 2).
|
|
9
|
+
|
|
10
|
+
world(w0).
|
|
11
|
+
world(w1).
|
|
12
|
+
world(w2).
|
|
13
|
+
world(w3).
|
|
14
|
+
|
|
15
|
+
accessible(w0, w1).
|
|
16
|
+
accessible(w0, w2).
|
|
17
|
+
accessible(w1, w1).
|
|
18
|
+
accessible(w1, w3).
|
|
19
|
+
accessible(w2, w2).
|
|
20
|
+
accessible(w3, w3).
|
|
21
|
+
|
|
22
|
+
true_at(w1, clear).
|
|
23
|
+
true_at(w2, clear).
|
|
24
|
+
true_at(w3, clear).
|
|
25
|
+
true_at(w2, repaired).
|
|
26
|
+
|
|
27
|
+
mforces(?_world, top).
|
|
28
|
+
mforces(?world, atom(?prop)) :- true_at(?world, ?prop).
|
|
29
|
+
mforces(?world, and(?left, ?right)) :- mforces(?world, ?left), mforces(?world, ?right).
|
|
30
|
+
mforces(?world, diamond(?formula)) :- accessible(?world, ?next), mforces(?next, ?formula).
|
|
31
|
+
mforces(?world, box(?formula)) :-
|
|
32
|
+
world(?world),
|
|
33
|
+
forall(accessible(?world, ?next), mforces(?next, ?formula)).
|
|
34
|
+
|
|
35
|
+
modal_truth(all_accessible_worlds_clear, w0, box(atom(clear))) :-
|
|
36
|
+
mforces(w0, box(atom(clear))).
|
|
37
|
+
|
|
38
|
+
modal_truth(repair_is_possible, w0, diamond(atom(repaired))) :-
|
|
39
|
+
mforces(w0, diamond(atom(repaired))).
|
|
40
|
+
|
|
41
|
+
modal_truth(nested_possibility, w1, diamond(and(atom(clear), atom(clear)))) :-
|
|
42
|
+
mforces(w1, diamond(and(atom(clear), atom(clear)))).
|
|
43
|
+
|
|
44
|
+
modal_countermodel(repair_not_necessary, w0) :-
|
|
45
|
+
not(mforces(w0, box(atom(repaired)))).
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
% Modular exponentiation by repeated squaring.
|
|
2
|
+
%
|
|
3
|
+
% pow_mod(Base, Exp, Modulus, Result) uses the even/odd exponent split, giving
|
|
4
|
+
% logarithmic-depth arithmetic. Memoization matters when the same modular powers
|
|
5
|
+
% are reused by Fermat-style congruence checks.
|
|
6
|
+
materialize(modular_answer, 2).
|
|
7
|
+
|
|
8
|
+
table(pow_mod, 4).
|
|
9
|
+
|
|
10
|
+
% Base case: any nonzero base to exponent zero is 1 modulo Mod.
|
|
11
|
+
pow_mod(?_base, 0, ?mod, ?result) :- mod(1, ?mod, ?result).
|
|
12
|
+
pow_mod(?base, ?exp, ?modulus, ?result) :-
|
|
13
|
+
gt(?exp, 0),
|
|
14
|
+
mod(?exp, 2, 0),
|
|
15
|
+
div(?exp, 2, ?half),
|
|
16
|
+
pow_mod(?base, ?half, ?modulus, ?halfpower),
|
|
17
|
+
mul(?halfpower, ?halfpower, ?square),
|
|
18
|
+
mod(?square, ?modulus, ?result).
|
|
19
|
+
pow_mod(?base, ?exp, ?modulus, ?result) :-
|
|
20
|
+
gt(?exp, 0),
|
|
21
|
+
mod(?exp, 2, 1),
|
|
22
|
+
sub(?exp, 1, ?evenexp),
|
|
23
|
+
pow_mod(?base, ?evenexp, ?modulus, ?evenpower),
|
|
24
|
+
mul(?base, ?evenpower, ?product),
|
|
25
|
+
mod(?product, ?modulus, ?result).
|
|
26
|
+
|
|
27
|
+
% This is a Fermat congruence check, not a full primality proof.
|
|
28
|
+
fermat_witness(?base, ?primecandidate) :-
|
|
29
|
+
sub(?primecandidate, 1, ?exponent),
|
|
30
|
+
pow_mod(?base, ?exponent, ?primecandidate, 1).
|
|
31
|
+
|
|
32
|
+
modular_answer(pow_7_560_mod_561, ?r) :- pow_mod(7, 560, 561, ?r).
|
|
33
|
+
modular_answer(pow_2_1000_mod_1009, ?r) :- pow_mod(2, 1000, 1009, ?r).
|
|
34
|
+
modular_answer(fermat_2_101, true) :- fermat_witness(2, 101).
|
|
35
|
+
modular_answer(fermat_3_101, true) :- fermat_witness(3, 101).
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
% Monkey and bananas planning problem, adapted from Eyelet's
|
|
2
|
+
% input/monkey-bananas.eye.
|
|
3
|
+
%
|
|
4
|
+
% A state is [bananas_location, monkey_location, box_location, on_box,
|
|
5
|
+
% has_bananas]. The selected output searches bounded move lists and derives successful
|
|
6
|
+
% plans.
|
|
7
|
+
|
|
8
|
+
% Output declarations: materialize/2 selects the relations written to this example's golden output.
|
|
9
|
+
materialize(plan, 2).
|
|
10
|
+
materialize(solved, 2).
|
|
11
|
+
|
|
12
|
+
% Program structure: facts set up the scenario, and rules derive the materialized conclusions.
|
|
13
|
+
table(reachable, 3).
|
|
14
|
+
|
|
15
|
+
% Derivation rules: each rule below contributes one logical step toward the displayed results.
|
|
16
|
+
plan(?moves) :-
|
|
17
|
+
candidate_plan(?moves),
|
|
18
|
+
initial_state(?i),
|
|
19
|
+
goal_state(?g),
|
|
20
|
+
reachable(?i, ?moves, ?g).
|
|
21
|
+
|
|
22
|
+
candidate_plan([?_, ?_, ?_]).
|
|
23
|
+
candidate_plan([?_, ?_, ?_, ?_]).
|
|
24
|
+
candidate_plan([?_, ?_, ?_, ?_, ?_]).
|
|
25
|
+
|
|
26
|
+
reachable(?s, [], ?s).
|
|
27
|
+
reachable(?s1, [?m|?l], ?s3) :-
|
|
28
|
+
legal_move(?s1, ?m, ?s2),
|
|
29
|
+
reachable(?s2, ?l, ?s3).
|
|
30
|
+
|
|
31
|
+
initial_state([loc1, loc2, loc3, n, n]).
|
|
32
|
+
goal_state([?_, ?_, ?_, ?_, y]).
|
|
33
|
+
|
|
34
|
+
legal_move([?b, ?m, ?m, n, ?h], climb_on, [?b, ?m, ?m, y, ?h]).
|
|
35
|
+
legal_move([?b, ?m, ?m, y, ?h], climb_off, [?b, ?m, ?m, n, ?h]).
|
|
36
|
+
legal_move([?b, ?b, ?b, y, n], grab, [?b, ?b, ?b, y, y]).
|
|
37
|
+
legal_move([?b, ?m, ?m, n, ?h], push(?x), [?b, ?x, ?x, n, ?h]) :-
|
|
38
|
+
member(?x, [loc1, loc2, loc3]),
|
|
39
|
+
neq(?x, ?m).
|
|
40
|
+
legal_move([?b, ?m, ?l, n, ?h], go(?x), [?b, ?x, ?l, n, ?h]) :-
|
|
41
|
+
member(?x, [loc1, loc2, loc3]),
|
|
42
|
+
neq(?x, ?m).
|
|
43
|
+
|
|
44
|
+
plan(monkeyBananas, ?moves) :- plan(?moves).
|
|
45
|
+
solved(monkeyBananas, true) :- plan(?_moves).
|