occam-verify-cli 1.0.913 → 1.0.920
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/lib/context/bounded.js +1 -4
- package/lib/element/assertion/signature.js +37 -31
- package/lib/element/deduction.js +1 -14
- package/lib/element/proofAssertion/step.js +27 -40
- package/lib/element/signature.js +26 -59
- package/lib/element/subproof.js +1 -23
- package/lib/element/topLevelAssertion/axiom.js +71 -100
- package/lib/element/topLevelAssertion.js +13 -36
- package/lib/node/proofAssertion/step.js +5 -5
- package/lib/node/qualification.js +4 -4
- package/lib/node/statement.js +4 -4
- package/lib/process/unify.js +21 -5
- package/lib/utilities/context.js +6 -1
- package/lib/utilities/element.js +3 -3
- package/lib/utilities/equivalences.js +1 -13
- package/lib/utilities/unification.js +95 -116
- package/package.json +4 -4
- package/src/context/bounded.js +1 -3
- package/src/element/assertion/signature.js +47 -34
- package/src/element/deduction.js +0 -25
- package/src/element/proofAssertion/step.js +36 -59
- package/src/element/signature.js +37 -91
- package/src/element/subproof.js +0 -35
- package/src/element/topLevelAssertion/axiom.js +95 -131
- package/src/element/topLevelAssertion.js +11 -45
- package/src/node/proofAssertion/step.js +4 -4
- package/src/node/qualification.js +3 -3
- package/src/node/statement.js +3 -3
- package/src/process/unify.js +28 -3
- package/src/utilities/context.js +6 -0
- package/src/utilities/element.js +2 -2
- package/src/utilities/equivalences.js +0 -12
- package/src/utilities/unification.js +117 -145
|
@@ -12,9 +12,6 @@ _export(exports, {
|
|
|
12
12
|
get equivalencesFromEquality () {
|
|
13
13
|
return equivalencesFromEquality;
|
|
14
14
|
},
|
|
15
|
-
get findEquivalenceByTerm () {
|
|
16
|
-
return findEquivalenceByTerm;
|
|
17
|
-
},
|
|
18
15
|
get findEquivalenceByTermNodes () {
|
|
19
16
|
return findEquivalenceByTermNodes;
|
|
20
17
|
},
|
|
@@ -43,15 +40,6 @@ function mergeEquivalences(equivalencesA, equivalencesB, context) {
|
|
|
43
40
|
});
|
|
44
41
|
return equivalencesA;
|
|
45
42
|
}
|
|
46
|
-
function findEquivalenceByTerm(equivalences, term) {
|
|
47
|
-
const equivalence = equivalences.find((equivalence)=>{
|
|
48
|
-
const equivalenceEqualToTerm = equivalence.isEqualTo(term);
|
|
49
|
-
if (equivalenceEqualToTerm) {
|
|
50
|
-
return true;
|
|
51
|
-
}
|
|
52
|
-
}) || null;
|
|
53
|
-
return equivalence;
|
|
54
|
-
}
|
|
55
43
|
function equivalencesFromEquality(equality, context) {
|
|
56
44
|
const { Equivalence } = _elements.default, eaulivalence = Equivalence.fromEquality(equality, context), equivalences = [
|
|
57
45
|
eaulivalence
|
|
@@ -143,4 +131,4 @@ function groundedTermsFromGroundedEquivalencesAndDefinedVariables(groundedEquiva
|
|
|
143
131
|
});
|
|
144
132
|
}
|
|
145
133
|
|
|
146
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utilities/equivalences.js"],"sourcesContent":["\"use strict\";\n\nimport { arrayUtilities } from \"necessary\";\n\nimport elements from \"../elements\";\n\nimport { variablesFromTerm } from \"../utilities/equivalence\";\n\nconst { push, separate } = arrayUtilities;\n\nexport function mergeEquivalences(equivalencesA, equivalencesB, context) {\n  equivalencesA = [  ///\n    ...equivalencesA\n  ];\n\n  equivalencesB.forEach((equivalenceB) => {\n    equivalencesA = mergeEquivalence(equivalencesA, equivalenceB, context);\n  });\n\n  return equivalencesA;\n}\n\nexport function findEquivalenceByTerm(equivalences, term) {\n  const equivalence = equivalences.find((equivalence) => {\n    const equivalenceEqualToTerm = equivalence.isEqualTo(term);\n\n    if (equivalenceEqualToTerm) {\n      return true;\n    }\n  }) || null;\n\n  return equivalence;\n}\n\nexport function equivalencesFromEquality(equality, context) {\n  const { Equivalence } = elements,\n        eaulivalence = Equivalence.fromEquality(equality, context),\n        equivalences = [\n          eaulivalence\n        ];\n\n  return equivalences;\n}\n\nexport function findEquivalenceByTermNodes(equivalences, termNodes) {\n  const equivalence = equivalences.find((equivalence) => {\n    const termNodeMatches = equivalence.matchTermNodes(termNodes);\n\n    if (termNodeMatches) {\n      return true;\n    }\n  }) || null;\n\n  return equivalence;\n}\n\nexport function separateGroundedTermsAndDefinedVariables(equivalences, groundedTerms, definedVariables, context) {\n  let groundedEquivalences,\n      remainingEquivalences,\n      initiallyGroundedEquivalences,\n      implicitlyGroundedEquivalences;\n\n  remainingEquivalences = [];\n\n  initiallyGroundedEquivalences = [];\n\n  separateInitiallyGroundedEquivalences(equivalences, remainingEquivalences, initiallyGroundedEquivalences, context);\n\n  const initiallyGroundedEquivalencesLength = initiallyGroundedEquivalences.length;\n\n  if (initiallyGroundedEquivalencesLength > 0) {\n    groundedEquivalences = initiallyGroundedEquivalences; ///\n\n    let implicitlyGroundedEquivalencesLength = 1;\n\n    while (implicitlyGroundedEquivalencesLength > 0) {\n      let definedVariablesLength = 0,\n            previousDefinedVariablesLength = -1;\n\n      while (definedVariablesLength > previousDefinedVariablesLength) {\n        previousDefinedVariablesLength = definedVariablesLength;  ///\n\n        groundedTermsFromGroundedEquivalencesAndDefinedVariables(groundedEquivalences, definedVariables, groundedTerms, context);\n\n        definedVariablesFromGroundedTerms(groundedTerms, definedVariables, context);\n\n        definedVariablesLength = definedVariables.length;\n      }\n\n      equivalences = remainingEquivalences; ///\n\n      remainingEquivalences = [];\n\n      implicitlyGroundedEquivalences = [];\n\n      separateImplicitlyGroundedEquivalences(equivalences, remainingEquivalences, implicitlyGroundedEquivalences, definedVariables, context);\n\n      push(groundedEquivalences, implicitlyGroundedEquivalences);\n\n      implicitlyGroundedEquivalencesLength = implicitlyGroundedEquivalences.length;  ///\n    }\n  }\n}\n\nfunction mergeEquivalence(equivalencesA, equivalenceB, context) {\n  const mergedEquivalences = [];\n\n  equivalencesA.forEach((equivalenceA) => {\n    const equivalenceBDisjointFromEquivalenceA = equivalenceB.isDisjointFrom(equivalenceA);\n\n    if (equivalenceBDisjointFromEquivalenceA) {\n      const mergedEquivalence = equivalenceB;  ///\n\n      mergedEquivalences.push(mergedEquivalence);\n    } else {\n      equivalenceB = equivalenceB.mergedWith(equivalenceA, context);\n    }\n  });\n\n  const mergedEquivalence = equivalenceB;  ///\n\n  mergedEquivalences.push(mergedEquivalence);\n\n  equivalencesA = mergedEquivalences;  ///\n\n  return equivalencesA;\n}\n\nfunction definedVariablesFromGroundedTerms(groundedTerms, definedVariables, context) {\n  groundedTerms.forEach((groundedTerm) => {\n    const term = groundedTerm,  ///\n          variables = variablesFromTerm(term, context);\n\n    variables.forEach((variable) => {\n      const definedVariablesIncludesTermVariable = definedVariables.includes(variable);\n\n      if (!definedVariablesIncludesTermVariable) {\n        const definedVariable = variable;  ///\n\n        definedVariables.push(definedVariable);\n      }\n    });\n  });\n}\n\nfunction separateInitiallyGroundedEquivalences(equivalences, remainingEquivalences, initiallyGroundedEquivalences, context) {\n  separate(equivalences, remainingEquivalences, initiallyGroundedEquivalences, (equivalence) => {\n    const equivalenceInitiallyGrounded = equivalence.isInitiallyGrounded(context);\n\n    if (!equivalenceInitiallyGrounded) {\n      return true;\n    }\n  });\n}\n\nfunction separateImplicitlyGroundedEquivalences(equivalences, remainingEquivalences, implicitlyGroundedEquivalences, definedVariables, context) {\n  separate(equivalences, remainingEquivalences, implicitlyGroundedEquivalences, (equivalence) => {\n    const equivalenceImplicitlyGrounded = equivalence.isImplicitlyGrounded(definedVariables, context);\n\n    if (!equivalenceImplicitlyGrounded) {\n      return true;\n    }\n  });\n}\n\nfunction groundedTermsFromGroundedEquivalencesAndDefinedVariables(groundedEquivalences, definedVariables, groundedTerms, context) {\n  groundedEquivalences.forEach((groundedEquivalence) => {\n    groundedEquivalence.getGroundedTerms(definedVariables, groundedTerms, context);\n  });\n}\n"],"names":["equivalencesFromEquality","findEquivalenceByTerm","findEquivalenceByTermNodes","mergeEquivalences","separateGroundedTermsAndDefinedVariables","push","separate","arrayUtilities","equivalencesA","equivalencesB","context","forEach","equivalenceB","mergeEquivalence","equivalences","term","equivalence","find","equivalenceEqualToTerm","isEqualTo","equality","Equivalence","elements","eaulivalence","fromEquality","termNodes","termNodeMatches","matchTermNodes","groundedTerms","definedVariables","groundedEquivalences","remainingEquivalences","initiallyGroundedEquivalences","implicitlyGroundedEquivalences","separateInitiallyGroundedEquivalences","initiallyGroundedEquivalencesLength","length","implicitlyGroundedEquivalencesLength","definedVariablesLength","previousDefinedVariablesLength","groundedTermsFromGroundedEquivalencesAndDefinedVariables","definedVariablesFromGroundedTerms","separateImplicitlyGroundedEquivalences","mergedEquivalences","equivalenceA","equivalenceBDisjointFromEquivalenceA","isDisjointFrom","mergedEquivalence","mergedWith","groundedTerm","variables","variablesFromTerm","variable","definedVariablesIncludesTermVariable","includes","definedVariable","equivalenceInitiallyGrounded","isInitiallyGrounded","equivalenceImplicitlyGrounded","isImplicitlyGrounded","groundedEquivalence","getGroundedTerms"],"mappings":"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"}
|
|
134
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utilities/equivalences.js"],"sourcesContent":["\"use strict\";\n\nimport { arrayUtilities } from \"necessary\";\n\nimport elements from \"../elements\";\n\nimport { variablesFromTerm } from \"../utilities/equivalence\";\n\nconst { push, separate } = arrayUtilities;\n\nexport function mergeEquivalences(equivalencesA, equivalencesB, context) {\n  equivalencesA = [  ///\n    ...equivalencesA\n  ];\n\n  equivalencesB.forEach((equivalenceB) => {\n    equivalencesA = mergeEquivalence(equivalencesA, equivalenceB, context);\n  });\n\n  return equivalencesA;\n}\n\nexport function equivalencesFromEquality(equality, context) {\n  const { Equivalence } = elements,\n        eaulivalence = Equivalence.fromEquality(equality, context),\n        equivalences = [\n          eaulivalence\n        ];\n\n  return equivalences;\n}\n\nexport function findEquivalenceByTermNodes(equivalences, termNodes) {\n  const equivalence = equivalences.find((equivalence) => {\n    const termNodeMatches = equivalence.matchTermNodes(termNodes);\n\n    if (termNodeMatches) {\n      return true;\n    }\n  }) || null;\n\n  return equivalence;\n}\n\nexport function separateGroundedTermsAndDefinedVariables(equivalences, groundedTerms, definedVariables, context) {\n  let groundedEquivalences,\n      remainingEquivalences,\n      initiallyGroundedEquivalences,\n      implicitlyGroundedEquivalences;\n\n  remainingEquivalences = [];\n\n  initiallyGroundedEquivalences = [];\n\n  separateInitiallyGroundedEquivalences(equivalences, remainingEquivalences, initiallyGroundedEquivalences, context);\n\n  const initiallyGroundedEquivalencesLength = initiallyGroundedEquivalences.length;\n\n  if (initiallyGroundedEquivalencesLength > 0) {\n    groundedEquivalences = initiallyGroundedEquivalences; ///\n\n    let implicitlyGroundedEquivalencesLength = 1;\n\n    while (implicitlyGroundedEquivalencesLength > 0) {\n      let definedVariablesLength = 0,\n            previousDefinedVariablesLength = -1;\n\n      while (definedVariablesLength > previousDefinedVariablesLength) {\n        previousDefinedVariablesLength = definedVariablesLength;  ///\n\n        groundedTermsFromGroundedEquivalencesAndDefinedVariables(groundedEquivalences, definedVariables, groundedTerms, context);\n\n        definedVariablesFromGroundedTerms(groundedTerms, definedVariables, context);\n\n        definedVariablesLength = definedVariables.length;\n      }\n\n      equivalences = remainingEquivalences; ///\n\n      remainingEquivalences = [];\n\n      implicitlyGroundedEquivalences = [];\n\n      separateImplicitlyGroundedEquivalences(equivalences, remainingEquivalences, implicitlyGroundedEquivalences, definedVariables, context);\n\n      push(groundedEquivalences, implicitlyGroundedEquivalences);\n\n      implicitlyGroundedEquivalencesLength = implicitlyGroundedEquivalences.length;  ///\n    }\n  }\n}\n\nfunction mergeEquivalence(equivalencesA, equivalenceB, context) {\n  const mergedEquivalences = [];\n\n  equivalencesA.forEach((equivalenceA) => {\n    const equivalenceBDisjointFromEquivalenceA = equivalenceB.isDisjointFrom(equivalenceA);\n\n    if (equivalenceBDisjointFromEquivalenceA) {\n      const mergedEquivalence = equivalenceB;  ///\n\n      mergedEquivalences.push(mergedEquivalence);\n    } else {\n      equivalenceB = equivalenceB.mergedWith(equivalenceA, context);\n    }\n  });\n\n  const mergedEquivalence = equivalenceB;  ///\n\n  mergedEquivalences.push(mergedEquivalence);\n\n  equivalencesA = mergedEquivalences;  ///\n\n  return equivalencesA;\n}\n\nfunction definedVariablesFromGroundedTerms(groundedTerms, definedVariables, context) {\n  groundedTerms.forEach((groundedTerm) => {\n    const term = groundedTerm,  ///\n          variables = variablesFromTerm(term, context);\n\n    variables.forEach((variable) => {\n      const definedVariablesIncludesTermVariable = definedVariables.includes(variable);\n\n      if (!definedVariablesIncludesTermVariable) {\n        const definedVariable = variable;  ///\n\n        definedVariables.push(definedVariable);\n      }\n    });\n  });\n}\n\nfunction separateInitiallyGroundedEquivalences(equivalences, remainingEquivalences, initiallyGroundedEquivalences, context) {\n  separate(equivalences, remainingEquivalences, initiallyGroundedEquivalences, (equivalence) => {\n    const equivalenceInitiallyGrounded = equivalence.isInitiallyGrounded(context);\n\n    if (!equivalenceInitiallyGrounded) {\n      return true;\n    }\n  });\n}\n\nfunction separateImplicitlyGroundedEquivalences(equivalences, remainingEquivalences, implicitlyGroundedEquivalences, definedVariables, context) {\n  separate(equivalences, remainingEquivalences, implicitlyGroundedEquivalences, (equivalence) => {\n    const equivalenceImplicitlyGrounded = equivalence.isImplicitlyGrounded(definedVariables, context);\n\n    if (!equivalenceImplicitlyGrounded) {\n      return true;\n    }\n  });\n}\n\nfunction groundedTermsFromGroundedEquivalencesAndDefinedVariables(groundedEquivalences, definedVariables, groundedTerms, context) {\n  groundedEquivalences.forEach((groundedEquivalence) => {\n    groundedEquivalence.getGroundedTerms(definedVariables, groundedTerms, context);\n  });\n}\n"],"names":["equivalencesFromEquality","findEquivalenceByTermNodes","mergeEquivalences","separateGroundedTermsAndDefinedVariables","push","separate","arrayUtilities","equivalencesA","equivalencesB","context","forEach","equivalenceB","mergeEquivalence","equality","Equivalence","elements","eaulivalence","fromEquality","equivalences","termNodes","equivalence","find","termNodeMatches","matchTermNodes","groundedTerms","definedVariables","groundedEquivalences","remainingEquivalences","initiallyGroundedEquivalences","implicitlyGroundedEquivalences","separateInitiallyGroundedEquivalences","initiallyGroundedEquivalencesLength","length","implicitlyGroundedEquivalencesLength","definedVariablesLength","previousDefinedVariablesLength","groundedTermsFromGroundedEquivalencesAndDefinedVariables","definedVariablesFromGroundedTerms","separateImplicitlyGroundedEquivalences","mergedEquivalences","equivalenceA","equivalenceBDisjointFromEquivalenceA","isDisjointFrom","mergedEquivalence","mergedWith","groundedTerm","term","variables","variablesFromTerm","variable","definedVariablesIncludesTermVariable","includes","definedVariable","equivalenceInitiallyGrounded","isInitiallyGrounded","equivalenceImplicitlyGrounded","isImplicitlyGrounded","groundedEquivalence","getGroundedTerms"],"mappings":"AAAA;;;;;;;;;;;QAsBgBA;eAAAA;;QAUAC;eAAAA;;QAtBAC;eAAAA;;QAkCAC;eAAAA;;;2BA1Ce;iEAEV;6BAEa;;;;;;AAElC,MAAM,EAAEC,IAAI,EAAEC,QAAQ,EAAE,GAAGC,yBAAc;AAElC,SAASJ,kBAAkBK,aAAa,EAAEC,aAAa,EAAEC,OAAO;IACrEF,gBAAgB;WACXA;KACJ;IAEDC,cAAcE,OAAO,CAAC,CAACC;QACrBJ,gBAAgBK,iBAAiBL,eAAeI,cAAcF;IAChE;IAEA,OAAOF;AACT;AAEO,SAASP,yBAAyBa,QAAQ,EAAEJ,OAAO;IACxD,MAAM,EAAEK,WAAW,EAAE,GAAGC,iBAAQ,EAC1BC,eAAeF,YAAYG,YAAY,CAACJ,UAAUJ,UAClDS,eAAe;QACbF;KACD;IAEP,OAAOE;AACT;AAEO,SAASjB,2BAA2BiB,YAAY,EAAEC,SAAS;IAChE,MAAMC,cAAcF,aAAaG,IAAI,CAAC,CAACD;QACrC,MAAME,kBAAkBF,YAAYG,cAAc,CAACJ;QAEnD,IAAIG,iBAAiB;YACnB,OAAO;QACT;IACF,MAAM;IAEN,OAAOF;AACT;AAEO,SAASjB,yCAAyCe,YAAY,EAAEM,aAAa,EAAEC,gBAAgB,EAAEhB,OAAO;IAC7G,IAAIiB,sBACAC,uBACAC,+BACAC;IAEJF,wBAAwB,EAAE;IAE1BC,gCAAgC,EAAE;IAElCE,sCAAsCZ,cAAcS,uBAAuBC,+BAA+BnB;IAE1G,MAAMsB,sCAAsCH,8BAA8BI,MAAM;IAEhF,IAAID,sCAAsC,GAAG;QAC3CL,uBAAuBE,+BAA+B,GAAG;QAEzD,IAAIK,uCAAuC;QAE3C,MAAOA,uCAAuC,EAAG;YAC/C,IAAIC,yBAAyB,GACvBC,iCAAiC,CAAC;YAExC,MAAOD,yBAAyBC,+BAAgC;gBAC9DA,iCAAiCD,wBAAyB,GAAG;gBAE7DE,yDAAyDV,sBAAsBD,kBAAkBD,eAAef;gBAEhH4B,kCAAkCb,eAAeC,kBAAkBhB;gBAEnEyB,yBAAyBT,iBAAiBO,MAAM;YAClD;YAEAd,eAAeS,uBAAuB,GAAG;YAEzCA,wBAAwB,EAAE;YAE1BE,iCAAiC,EAAE;YAEnCS,uCAAuCpB,cAAcS,uBAAuBE,gCAAgCJ,kBAAkBhB;YAE9HL,KAAKsB,sBAAsBG;YAE3BI,uCAAuCJ,+BAA+BG,MAAM,EAAG,GAAG;QACpF;IACF;AACF;AAEA,SAASpB,iBAAiBL,aAAa,EAAEI,YAAY,EAAEF,OAAO;IAC5D,MAAM8B,qBAAqB,EAAE;IAE7BhC,cAAcG,OAAO,CAAC,CAAC8B;QACrB,MAAMC,uCAAuC9B,aAAa+B,cAAc,CAACF;QAEzE,IAAIC,sCAAsC;YACxC,MAAME,oBAAoBhC,cAAe,GAAG;YAE5C4B,mBAAmBnC,IAAI,CAACuC;QAC1B,OAAO;YACLhC,eAAeA,aAAaiC,UAAU,CAACJ,cAAc/B;QACvD;IACF;IAEA,MAAMkC,oBAAoBhC,cAAe,GAAG;IAE5C4B,mBAAmBnC,IAAI,CAACuC;IAExBpC,gBAAgBgC,oBAAqB,GAAG;IAExC,OAAOhC;AACT;AAEA,SAAS8B,kCAAkCb,aAAa,EAAEC,gBAAgB,EAAEhB,OAAO;IACjFe,cAAcd,OAAO,CAAC,CAACmC;QACrB,MAAMC,OAAOD,cACPE,YAAYC,IAAAA,8BAAiB,EAACF,MAAMrC;QAE1CsC,UAAUrC,OAAO,CAAC,CAACuC;YACjB,MAAMC,uCAAuCzB,iBAAiB0B,QAAQ,CAACF;YAEvE,IAAI,CAACC,sCAAsC;gBACzC,MAAME,kBAAkBH,UAAW,GAAG;gBAEtCxB,iBAAiBrB,IAAI,CAACgD;YACxB;QACF;IACF;AACF;AAEA,SAAStB,sCAAsCZ,YAAY,EAAES,qBAAqB,EAAEC,6BAA6B,EAAEnB,OAAO;IACxHJ,SAASa,cAAcS,uBAAuBC,+BAA+B,CAACR;QAC5E,MAAMiC,+BAA+BjC,YAAYkC,mBAAmB,CAAC7C;QAErE,IAAI,CAAC4C,8BAA8B;YACjC,OAAO;QACT;IACF;AACF;AAEA,SAASf,uCAAuCpB,YAAY,EAAES,qBAAqB,EAAEE,8BAA8B,EAAEJ,gBAAgB,EAAEhB,OAAO;IAC5IJ,SAASa,cAAcS,uBAAuBE,gCAAgC,CAACT;QAC7E,MAAMmC,gCAAgCnC,YAAYoC,oBAAoB,CAAC/B,kBAAkBhB;QAEzF,IAAI,CAAC8C,+BAA+B;YAClC,OAAO;QACT;IACF;AACF;AAEA,SAASnB,yDAAyDV,oBAAoB,EAAED,gBAAgB,EAAED,aAAa,EAAEf,OAAO;IAC9HiB,qBAAqBhB,OAAO,CAAC,CAAC+C;QAC5BA,oBAAoBC,gBAAgB,CAACjC,kBAAkBD,eAAef;IACxE;AACF"}
|
|
@@ -8,7 +8,6 @@ Object.defineProperty(exports, "unifySteps", {
|
|
|
8
8
|
return unifySteps;
|
|
9
9
|
}
|
|
10
10
|
});
|
|
11
|
-
const _necessary = require("necessary");
|
|
12
11
|
const _elements = /*#__PURE__*/ _interop_require_default(require("../elements"));
|
|
13
12
|
const _context = require("./context");
|
|
14
13
|
function _interop_require_default(obj) {
|
|
@@ -16,12 +15,11 @@ function _interop_require_default(obj) {
|
|
|
16
15
|
default: obj
|
|
17
16
|
};
|
|
18
17
|
}
|
|
19
|
-
const { backwardsSome } = _necessary.arrayUtilities;
|
|
20
18
|
async function unifyStepWithRule(step, context) {
|
|
21
19
|
let stepUnifiesWithRule = false;
|
|
22
|
-
const
|
|
23
|
-
if (
|
|
24
|
-
const
|
|
20
|
+
const reference = step.getReference();
|
|
21
|
+
if (reference !== null) {
|
|
22
|
+
const rule = context.findRuleByReference(reference);
|
|
25
23
|
if (rule !== null) {
|
|
26
24
|
const stepString = step.getString(), ruleString = rule.getString();
|
|
27
25
|
context.trace(`Unifying the '${stepString}' step with the '${ruleString}' rule...`);
|
|
@@ -38,9 +36,9 @@ async function unifyStepWithRule(step, context) {
|
|
|
38
36
|
}
|
|
39
37
|
async function unifyStepWithReference(step, context) {
|
|
40
38
|
let stepUnifiesWithReference = false;
|
|
41
|
-
const
|
|
42
|
-
if (
|
|
43
|
-
const
|
|
39
|
+
const reference = step.getReference();
|
|
40
|
+
if (reference !== null) {
|
|
41
|
+
const stepString = step.getString(), referenceString = reference.getString();
|
|
44
42
|
context.trace(`Unifying the '${stepString}' step with the '${referenceString}' reference...`);
|
|
45
43
|
const topLevelAssertion = context.findTopLevelAssertionByReference(reference);
|
|
46
44
|
if (topLevelAssertion !== null) {
|
|
@@ -64,57 +62,11 @@ async function unifyStepWithReference(step, context) {
|
|
|
64
62
|
}
|
|
65
63
|
return stepUnifiesWithReference;
|
|
66
64
|
}
|
|
67
|
-
async function unifyStepAsSignatureAssertion(step, context) {
|
|
68
|
-
let stepUnifiesAsSignatureAssertion = false;
|
|
69
|
-
const { SignatureAssertion } = _elements.default;
|
|
70
|
-
const signatureAssertion = SignatureAssertion.fromStep(step, context);
|
|
71
|
-
if (signatureAssertion !== null) {
|
|
72
|
-
const stepString = step.getString();
|
|
73
|
-
context.trace(`Unifying the '${stepString}' step as a signature assertion...`);
|
|
74
|
-
(0, _context.descend)((context)=>{
|
|
75
|
-
signatureAssertion.verifySignature(context);
|
|
76
|
-
}, context);
|
|
77
|
-
const unqualified = step.isUnqualified();
|
|
78
|
-
if (unqualified) {
|
|
79
|
-
const subproofOrProofAssertions = context.getSubproofOrProofAssertions();
|
|
80
|
-
stepUnifiesAsSignatureAssertion = backwardsSome(subproofOrProofAssertions, (stepsOrSubproof)=>{
|
|
81
|
-
const stepOrSubProofUnifiesWIthSignatureAssertion = stepsOrSubproof.unifyWithSignatureAssertion(signatureAssertion, context);
|
|
82
|
-
if (stepOrSubProofUnifiesWIthSignatureAssertion) {
|
|
83
|
-
return true;
|
|
84
|
-
}
|
|
85
|
-
});
|
|
86
|
-
} else {
|
|
87
|
-
const reference = signatureAssertion.getReference(), topLevelAssertion = context.findTopLevelAssertionByReference(reference);
|
|
88
|
-
if (topLevelAssertion !== null) {
|
|
89
|
-
const axiom = context.findAxiomByReference(reference);
|
|
90
|
-
if (axiom !== null) {
|
|
91
|
-
const satisfiable = axiom.isSatisfiable();
|
|
92
|
-
if (satisfiable) {
|
|
93
|
-
const topLevelAssertionUnifies = axiom.unifyTopLevelAssertion(topLevelAssertion, context);
|
|
94
|
-
if (topLevelAssertionUnifies) {
|
|
95
|
-
const substitutionsCorrelates = signatureAssertion.correlateSubstitutions(substitutions, context);
|
|
96
|
-
if (substitutionsCorrelates) {
|
|
97
|
-
stepUnifiesAsSignatureAssertion = true;
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
} else {
|
|
101
|
-
const axiomString = axiom.getString();
|
|
102
|
-
context.debug(`Unable to unify with the '${axiomString}' because it is not satisfiable.`);
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
if (stepUnifiesAsSignatureAssertion) {
|
|
108
|
-
context.debug(`...unified the '${stepString}' step as a signature assertion.`);
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
return stepUnifiesAsSignatureAssertion;
|
|
112
|
-
}
|
|
113
65
|
async function unifyStepWithTopLevelAssertion(step, context) {
|
|
114
66
|
let stepUnifiesWithTopLevelAssertion = false;
|
|
115
|
-
const
|
|
116
|
-
if (
|
|
117
|
-
const
|
|
67
|
+
const reference = step.getReference();
|
|
68
|
+
if (reference !== null) {
|
|
69
|
+
const topLevelAssertion = context.findTopLevelAssertionByReference(reference);
|
|
118
70
|
if (topLevelAssertion !== null) {
|
|
119
71
|
const stepString = step.getString(), topLevelAssertionString = reference.getString();
|
|
120
72
|
context.trace(`Unifying the '${stepString}' step with the '${topLevelAssertionString}' top level assertion...`);
|
|
@@ -129,97 +81,123 @@ async function unifyStepWithTopLevelAssertion(step, context) {
|
|
|
129
81
|
}
|
|
130
82
|
return stepUnifiesWithTopLevelAssertion;
|
|
131
83
|
}
|
|
132
|
-
async function
|
|
133
|
-
let
|
|
84
|
+
async function unifyStepWithSignatureAssertion(step, context) {
|
|
85
|
+
let stepUnifiesWithSignatureAssertion = false;
|
|
86
|
+
const signatureAssertion = step.getSignatureAssertion();
|
|
87
|
+
if (signatureAssertion !== null) {
|
|
88
|
+
const stepString = step.getString(), signatureAssertionString = signatureAssertion.getString();
|
|
89
|
+
context.trace(`Unifying the '${stepString}' step with the '${signatureAssertionString}' signature assertion...`);
|
|
90
|
+
const subproofOrProofAssertions = context.getSubproofOrProofAssertions(), stepAndSubproofOrProofAssertionsUnify = await signatureAssertion.unifyStepAndSubproofOrProofAssertions(step, subproofOrProofAssertions, context);
|
|
91
|
+
if (stepAndSubproofOrProofAssertionsUnify) {
|
|
92
|
+
stepUnifiesWithSignatureAssertion = true;
|
|
93
|
+
}
|
|
94
|
+
if (stepUnifiesWithSignatureAssertion) {
|
|
95
|
+
context.debug(`...unified the '${stepString}' step with the '${signatureAssertionString}' signature assertion.`);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
return stepUnifiesWithSignatureAssertion;
|
|
99
|
+
}
|
|
100
|
+
async function unifyStepAsUnqualifiedEquality(step, context) {
|
|
101
|
+
let stepUnifiesAUnqualifiedEquality = false;
|
|
134
102
|
const unqualified = step.isUnqualified();
|
|
135
103
|
if (unqualified) {
|
|
136
104
|
const { Equality } = _elements.default, statement = step.getStatement(), equality = Equality.fromStatement(statement, context);
|
|
137
105
|
if (equality !== null) {
|
|
138
106
|
const stepString = step.getString();
|
|
139
|
-
context.trace(`Unifying the '${stepString}' step as an equality...`);
|
|
140
|
-
|
|
141
|
-
if (
|
|
142
|
-
|
|
143
|
-
}
|
|
144
|
-
if (stepUnifiesAEquality) {
|
|
145
|
-
context.debug(`...unified the '${stepString}' step as an equality.`);
|
|
107
|
+
context.trace(`Unifying the '${stepString}' step as an unqualified equality...`);
|
|
108
|
+
stepUnifiesAUnqualifiedEquality = true;
|
|
109
|
+
if (stepUnifiesAUnqualifiedEquality) {
|
|
110
|
+
context.debug(`...unified the '${stepString}' step as an unqualified equality.`);
|
|
146
111
|
}
|
|
147
112
|
}
|
|
148
113
|
}
|
|
149
|
-
return
|
|
114
|
+
return stepUnifiesAUnqualifiedEquality;
|
|
150
115
|
}
|
|
151
|
-
async function
|
|
152
|
-
let
|
|
116
|
+
async function unifyStepAsUNqualifiedJudgement(step, context) {
|
|
117
|
+
let stepUnifiesAsUnqualifiedJudgement = false;
|
|
153
118
|
const unqualified = step.isUnqualified();
|
|
154
119
|
if (unqualified) {
|
|
155
120
|
const { Judgement } = _elements.default, statement = step.getStatement(), judgement = Judgement.fromStatement(statement, context);
|
|
156
121
|
if (judgement !== null) {
|
|
157
122
|
const stepString = step.getString();
|
|
158
|
-
context.trace(`Unifying the '${stepString}' step as
|
|
159
|
-
|
|
160
|
-
if (
|
|
161
|
-
context.debug(`...unified the '${stepString}' step as
|
|
123
|
+
context.trace(`Unifying the '${stepString}' step as an unqualified judgement...`);
|
|
124
|
+
stepUnifiesAsUnqualifiedJudgement = true;
|
|
125
|
+
if (stepUnifiesAsUnqualifiedJudgement) {
|
|
126
|
+
context.debug(`...unified the '${stepString}' step as an unqualified judgement.`);
|
|
162
127
|
}
|
|
163
128
|
}
|
|
164
129
|
}
|
|
165
|
-
return
|
|
130
|
+
return stepUnifiesAsUnqualifiedJudgement;
|
|
166
131
|
}
|
|
167
|
-
async function
|
|
168
|
-
let
|
|
132
|
+
async function unifyStepAsUnqualifiedTypeAssertion(step, context) {
|
|
133
|
+
let stepUnifiesAsUnqualifiedTypeAssertion = false;
|
|
169
134
|
const unqualified = step.isUnqualified();
|
|
170
135
|
if (unqualified) {
|
|
171
136
|
const { TypeAssertion } = _elements.default, statement = step.getStatement(), typeAssertion = TypeAssertion.fromStatement(statement, context);
|
|
172
137
|
if (typeAssertion !== null) {
|
|
173
138
|
const stepString = step.getString();
|
|
174
|
-
context.trace(`Unifying the '${stepString}' step as
|
|
175
|
-
|
|
176
|
-
|
|
139
|
+
context.trace(`Unifying the '${stepString}' step as an unqualified type assertion...`);
|
|
140
|
+
stepUnifiesAsUnqualifiedTypeAssertion = true;
|
|
141
|
+
if (stepUnifiesAsUnqualifiedTypeAssertion) {
|
|
142
|
+
context.debug(`...unified the '${stepString}' step as an unqualified type assertion.`);
|
|
143
|
+
}
|
|
177
144
|
}
|
|
178
145
|
}
|
|
179
|
-
return
|
|
146
|
+
return stepUnifiesAsUnqualifiedTypeAssertion;
|
|
180
147
|
}
|
|
181
|
-
async function
|
|
182
|
-
let
|
|
148
|
+
async function unifyStepAsUnqualifiedPropertyAssertion(step, context) {
|
|
149
|
+
let stepUnifiesAsUnqualifiedPropertyAssertion = false;
|
|
183
150
|
const unqualified = step.isUnqualified();
|
|
184
151
|
if (unqualified) {
|
|
185
152
|
const { PropertyAssertion } = _elements.default, statement = step.getStatement(), propertyAssertion = PropertyAssertion.fromStatement(statement, context);
|
|
186
153
|
if (propertyAssertion !== null) {
|
|
187
154
|
const stepString = step.getString();
|
|
188
|
-
context.trace(`Unifying the '${stepString}' step as
|
|
189
|
-
|
|
190
|
-
if (
|
|
191
|
-
|
|
192
|
-
const propertyRelation = propertyAssertion.getPropertyRelation(), comparesToTermAndPropertyRelation = context.compareTermAndPropertyRelation(term, propertyRelation);
|
|
193
|
-
if (comparesToTermAndPropertyRelation) {
|
|
194
|
-
return true;
|
|
195
|
-
}
|
|
196
|
-
});
|
|
197
|
-
if (propertyAssertionMatches) {
|
|
198
|
-
stepUnifiesAsPropertyAssertion = true;
|
|
199
|
-
}
|
|
200
|
-
}
|
|
201
|
-
if (stepUnifiesAsPropertyAssertion) {
|
|
202
|
-
context.debug(`...unified the '${stepString}' step as a property assertion.`);
|
|
155
|
+
context.trace(`Unifying the '${stepString}' step as an unqualified property assertion...`);
|
|
156
|
+
stepUnifiesAsUnqualifiedPropertyAssertion = true;
|
|
157
|
+
if (stepUnifiesAsUnqualifiedPropertyAssertion) {
|
|
158
|
+
context.debug(`...unified the '${stepString}' step as an unqualified property assertion.`);
|
|
203
159
|
}
|
|
204
160
|
}
|
|
205
161
|
}
|
|
206
|
-
return
|
|
162
|
+
return stepUnifiesAsUnqualifiedPropertyAssertion;
|
|
207
163
|
}
|
|
208
|
-
async function
|
|
209
|
-
let
|
|
210
|
-
const
|
|
211
|
-
if (
|
|
212
|
-
const
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
164
|
+
async function unifyStepAsUnqualifiedSignatureAssertion(step, context) {
|
|
165
|
+
let stepUnifiesAsUnqualifiedSignatureAssertion = false;
|
|
166
|
+
const unqualified = step.isUnqualified();
|
|
167
|
+
if (unqualified) {
|
|
168
|
+
const { SignatureAssertion } = _elements.default, statement = step.getStatement(), signatureAssertion = SignatureAssertion.fromStatement(statement, context);
|
|
169
|
+
if (signatureAssertion !== null) {
|
|
170
|
+
const stepString = step.getString();
|
|
171
|
+
context.trace(`Unifying the '${stepString}' step as a signature assertion...`);
|
|
172
|
+
stepUnifiesAsUnqualifiedSignatureAssertion = true;
|
|
173
|
+
if (stepUnifiesAsUnqualifiedSignatureAssertion) {
|
|
174
|
+
context.debug(`...unified the '${stepString}' step as a signature assertion.`);
|
|
175
|
+
}
|
|
217
176
|
}
|
|
218
|
-
|
|
219
|
-
|
|
177
|
+
}
|
|
178
|
+
return stepUnifiesAsUnqualifiedSignatureAssertion;
|
|
179
|
+
}
|
|
180
|
+
async function unifyStepAsSignatureAssertionWithReference(step, context) {
|
|
181
|
+
let stepUnifiesAsSignatureAssertionWithReference = false;
|
|
182
|
+
const reference = step.getReference();
|
|
183
|
+
if (reference !== null) {
|
|
184
|
+
const topLevelAssertion = context.findTopLevelAssertionByReference(reference);
|
|
185
|
+
if (topLevelAssertion !== null) {
|
|
186
|
+
const statementNode = step.getStatementNode(), signatureAssertionNode = statementNode.getSignatureAssertionNode();
|
|
187
|
+
if (signatureAssertionNode !== null) {
|
|
188
|
+
const stepString = step.getString(), referenceString = reference.getString(), signatureAssertion = context.findAssertionByAssertionNode(signatureAssertionNode);
|
|
189
|
+
context.trace(`Unifying the '${stepString}' step as a signature assertion with the '${referenceString}' reference...`);
|
|
190
|
+
const unifyTopLevelAssertion = await signatureAssertion.unifyTopLevelAssertion(topLevelAssertion, context);
|
|
191
|
+
if (unifyTopLevelAssertion) {
|
|
192
|
+
stepUnifiesAsSignatureAssertionWithReference = true;
|
|
193
|
+
}
|
|
194
|
+
if (stepUnifiesAsSignatureAssertionWithReference) {
|
|
195
|
+
context.debug(`...unified the '${stepString}' step as a signature assertion with the '${referenceString}' reference.`);
|
|
196
|
+
}
|
|
197
|
+
}
|
|
220
198
|
}
|
|
221
199
|
}
|
|
222
|
-
return
|
|
200
|
+
return stepUnifiesAsSignatureAssertionWithReference;
|
|
223
201
|
}
|
|
224
202
|
async function compareStepWithSubproofOrProofAssertions(step, context) {
|
|
225
203
|
let stepComparesToSubproofOrProofAssertions = false;
|
|
@@ -240,14 +218,15 @@ async function compareStepWithSubproofOrProofAssertions(step, context) {
|
|
|
240
218
|
const unifySteps = [
|
|
241
219
|
unifyStepWithRule,
|
|
242
220
|
unifyStepWithReference,
|
|
243
|
-
unifyStepAsSignatureAssertion,
|
|
244
221
|
unifyStepWithTopLevelAssertion,
|
|
245
|
-
unifyStepAsEquality,
|
|
246
|
-
unifyStepAsJudgement,
|
|
247
|
-
unifyStepAsTypeAssertion,
|
|
248
|
-
unifyStepAsPropertyAssertion,
|
|
249
222
|
unifyStepWithSignatureAssertion,
|
|
223
|
+
unifyStepAsUnqualifiedEquality,
|
|
224
|
+
unifyStepAsUNqualifiedJudgement,
|
|
225
|
+
unifyStepAsUnqualifiedTypeAssertion,
|
|
226
|
+
unifyStepAsUnqualifiedPropertyAssertion,
|
|
227
|
+
unifyStepAsUnqualifiedSignatureAssertion,
|
|
228
|
+
unifyStepAsSignatureAssertionWithReference,
|
|
250
229
|
compareStepWithSubproofOrProofAssertions
|
|
251
230
|
];
|
|
252
231
|
|
|
253
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utilities/unification.js"],"sourcesContent":["\"use strict\";\n\nimport { arrayUtilities } from \"necessary\";\n\nimport elements from \"../elements\";\n\nimport { descend } from \"./context\";\n\nconst { backwardsSome } = arrayUtilities;\n\nasync function unifyStepWithRule(step, context) {\n  let stepUnifiesWithRule = false;\n\n  const qualified = step.isQualified();\n\n  if (qualified) {\n    const reference = step.getReference(),\n          rule = context.findRuleByReference(reference);\n\n    if (rule !== null) {\n      const stepString = step.getString(),\n            ruleString = rule.getString();\n\n      context.trace(`Unifying the '${stepString}' step with the '${ruleString}' rule...`);\n\n      const subproofOrProofAssertions = context.getSubproofOrProofAssertions(),\n            stepAndSubproofOrProofAssertionsUnify = await rule.unifyStepAndSubproofOrProofAssertions(step, subproofOrProofAssertions, context);\n\n      if (stepAndSubproofOrProofAssertionsUnify) {\n        stepUnifiesWithRule = true;\n      }\n\n      if (stepUnifiesWithRule) {\n        context.debug(`...unified the '${stepString}' step with the '${ruleString}' rule.`);\n      }\n    }\n  }\n\n  return stepUnifiesWithRule;\n}\n\nasync function unifyStepWithReference(step, context) {\n  let stepUnifiesWithReference = false;\n\n  const qualified = step.isQualified();\n\n  if (qualified) {\n    const reference = step.getReference(),\n          stepString = step.getString(),\n          referenceString = reference.getString();\n\n    context.trace(`Unifying the '${stepString}' step with the '${referenceString}' reference...`);\n\n    const topLevelAssertion = context.findTopLevelAssertionByReference(reference);\n\n    if (topLevelAssertion !== null) {\n      const subproofOrProofAssertions = context.getSubproofOrProofAssertions(),\n            stepAndSubproofOrProofAssertionsUnify = await topLevelAssertion.unifyStepAndSubproofOrProofAssertions(step, subproofOrProofAssertions, context);\n\n      if (stepAndSubproofOrProofAssertionsUnify) {\n        stepUnifiesWithReference = true;\n      }\n    } else {\n      const metaLevel = context.isMetaLevel();\n\n      if (metaLevel) {\n        descend((context) => {\n          const { MetaLevelAssumption } = elements,\n                metaLevelAssumption = MetaLevelAssumption.fromStep(step, context);\n\n          metaLevelAssumption.validate(context);\n\n          stepUnifiesWithReference = true;\n        }, context);\n      }\n    }\n\n    if (stepUnifiesWithReference) {\n      context.debug(`...unified the '${stepString}' step with the '${referenceString}' reference.`);\n    }\n  }\n\n  return stepUnifiesWithReference;\n}\n\nasync function unifyStepAsSignatureAssertion(step, context) {\n  let stepUnifiesAsSignatureAssertion = false;\n\n  const { SignatureAssertion } = elements;\n\n  const signatureAssertion = SignatureAssertion.fromStep(step, context);\n\n  if (signatureAssertion !== null) {\n    const stepString = step.getString();\n\n    context.trace(`Unifying the '${stepString}' step as a signature assertion...`);\n\n    descend((context) => {\n      signatureAssertion.verifySignature(context);\n    }, context);\n\n    const unqualified = step.isUnqualified();\n\n    if (unqualified) {\n      const subproofOrProofAssertions = context.getSubproofOrProofAssertions();\n\n      stepUnifiesAsSignatureAssertion = backwardsSome(subproofOrProofAssertions, (stepsOrSubproof) => {\n        const stepOrSubProofUnifiesWIthSignatureAssertion = stepsOrSubproof.unifyWithSignatureAssertion(signatureAssertion, context);\n\n        if (stepOrSubProofUnifiesWIthSignatureAssertion) {\n          return true;\n        }\n      });\n    } else {\n      const reference = signatureAssertion.getReference(),\n            topLevelAssertion = context.findTopLevelAssertionByReference(reference);\n\n      if (topLevelAssertion !== null) {\n        const axiom = context.findAxiomByReference(reference);\n\n        if (axiom !== null) {\n          const satisfiable = axiom.isSatisfiable();\n\n          if (satisfiable) {\n            const topLevelAssertionUnifies = axiom.unifyTopLevelAssertion(topLevelAssertion, context);\n\n            if (topLevelAssertionUnifies) {\n              const substitutionsCorrelates = signatureAssertion.correlateSubstitutions(substitutions, context);\n\n              if (substitutionsCorrelates) {\n                stepUnifiesAsSignatureAssertion = true;\n              }\n            }\n          } else {\n            const axiomString = axiom.getString();\n\n            context.debug(`Unable to unify with the '${axiomString}' because it is not satisfiable.`)\n          }\n        }\n      }\n    }\n\n    if (stepUnifiesAsSignatureAssertion) {\n      context.debug(`...unified the '${stepString}' step as a signature assertion.`);\n    }\n  }\n\n  return stepUnifiesAsSignatureAssertion;\n}\n\nasync function unifyStepWithTopLevelAssertion(step, context) {\n  let stepUnifiesWithTopLevelAssertion = false;\n\n  const qualified = step.isQualified();\n\n  if (qualified) {\n    const reference = step.getReference(),\n          topLevelAssertion = context.findTopLevelAssertionByReference(reference);\n\n    if (topLevelAssertion !== null) {\n      const stepString = step.getString(),\n            topLevelAssertionString = reference.getString();\n\n      context.trace(`Unifying the '${stepString}' step with the '${topLevelAssertionString}' top level assertion...`);\n\n      const subproofOrProofAssertions = context.getSubproofOrProofAssertions(),\n            stepAndSubproofOrProofAssertionsUnify = await topLevelAssertion.unifyStepAndSubproofOrProofAssertions(step, subproofOrProofAssertions, context);\n\n      if (stepAndSubproofOrProofAssertionsUnify) {\n        stepUnifiesWithTopLevelAssertion = true;\n      }\n\n      if (stepUnifiesWithTopLevelAssertion) {\n        context.debug(`...unified the '${stepString}' step with the '${topLevelAssertionString}' top level assertion.`);\n      }\n    }\n  }\n\n  return stepUnifiesWithTopLevelAssertion;\n}\n\nasync function unifyStepAsEquality(step, context) {\n  let stepUnifiesAEquality = false;\n\n  const unqualified = step.isUnqualified();\n\n  if (unqualified) {\n    const { Equality } = elements,\n          statement = step.getStatement(),\n          equality = Equality.fromStatement(statement, context);\n\n    if (equality !== null) {\n      const stepString = step.getString();\n\n      context.trace(`Unifying the '${stepString}' step as an equality...`);\n\n      const equalityEqual = equality.isEqual(context);\n\n      if (equalityEqual) {\n        stepUnifiesAEquality = true;\n      }\n\n      if (stepUnifiesAEquality) {\n        context.debug(`...unified the '${stepString}' step as an equality.`);\n      }\n    }\n  }\n\n  return stepUnifiesAEquality;\n}\n\nasync function unifyStepAsJudgement(step, context) {\n  let stepUnifiesAsJudgement = false;\n\n  const unqualified = step.isUnqualified();\n\n  if (unqualified) {\n    const { Judgement } = elements,\n          statement = step.getStatement(),\n          judgement = Judgement.fromStatement(statement, context);\n\n    if (judgement !== null) {\n      const stepString = step.getString();\n\n      context.trace(`Unifying the '${stepString}' step as a judgement...`);\n\n      stepUnifiesAsJudgement = true;\n\n      if (stepUnifiesAsJudgement) {\n        context.debug(`...unified the '${stepString}' step as a judgement.`);\n      }\n    }\n  }\n\n  return stepUnifiesAsJudgement;\n}\n\nasync function unifyStepAsTypeAssertion(step, context) {\n  let stepUnifiesAsTypeAssertion = false;\n\n  const unqualified = step.isUnqualified();\n\n  if (unqualified) {\n    const { TypeAssertion } = elements,\n          statement = step.getStatement(),\n          typeAssertion = TypeAssertion.fromStatement(statement, context);\n\n    if (typeAssertion !== null) {\n      const stepString = step.getString();\n\n      context.trace(`Unifying the '${stepString}' step as a type assertion...`);\n\n      stepUnifiesAsTypeAssertion = true;\n\n      context.debug(`...unified the '${stepString}' step as a type assertion.`);\n    }\n  }\n\n  return stepUnifiesAsTypeAssertion;\n}\n\nasync function unifyStepAsPropertyAssertion(step, context) {\n  let stepUnifiesAsPropertyAssertion = false;\n\n  const unqualified = step.isUnqualified();\n\n  if (unqualified) {\n    const { PropertyAssertion } = elements,\n          statement = step.getStatement(),\n          propertyAssertion = PropertyAssertion.fromStatement(statement, context);\n\n    if (propertyAssertion !== null) {\n      const stepString = step.getString();\n\n      context.trace(`Unifying the '${stepString}' step as a property assertion...`);\n\n      const term = propertyAssertion.getTerm(),\n            equivalence = context.findEquivalenceByTerm(term);\n\n      if (equivalence !== null) {\n        const propertyAssertionMatches = equivalence.someOtherTerm(term, (term) => {  ///\n          const propertyRelation = propertyAssertion.getPropertyRelation(),\n                comparesToTermAndPropertyRelation = context.compareTermAndPropertyRelation(term, propertyRelation);\n\n          if (comparesToTermAndPropertyRelation) {\n            return true;\n          }\n        });\n\n        if (propertyAssertionMatches) {\n          stepUnifiesAsPropertyAssertion = true;\n        }\n      }\n\n      if (stepUnifiesAsPropertyAssertion) {\n        context.debug(`...unified the '${stepString}' step as a property assertion.`);\n      }\n    }\n  }\n\n  return stepUnifiesAsPropertyAssertion;\n}\n\nasync function unifyStepWithSignatureAssertion(step, context) {\n  let stepUnifiesWithSignatureAssertion = false;\n\n  const signatureAssertion = step.getSignatureAssertion();\n\n  if (signatureAssertion !== null) {\n    const stepString = step.getString(),\n          signatureAssertionString = signatureAssertion.getString();\n\n    context.trace(`Unifying the '${stepString}' step with the '${signatureAssertionString}' signature assertion...`);\n\n    const subproofOrProofAssertions = context.getSubproofOrProofAssertions(),\n          stepUnifies = signatureAssertion.unifyStepAndSubproofOrProofAssertions(step, subproofOrProofAssertions, context);\n\n    if (stepUnifies) {\n      stepUnifiesWithSignatureAssertion = true;\n    }\n\n    if (stepUnifiesWithSignatureAssertion) {\n      context.debug(`...unified the '${stepString}' step with the '${signatureAssertionString}' signature assertion.`);\n    }\n  }\n\n  return stepUnifiesWithSignatureAssertion;\n}\n\nasync function compareStepWithSubproofOrProofAssertions(step, context) {\n  let stepComparesToSubproofOrProofAssertions = false;\n\n  const unqualified = step.isUnqualified();\n\n  if (unqualified) {\n    const stepString = step.getString();\n\n    context.trace(`Comparing the '${stepString}' step with the subproofs or proof asssertions...`);\n\n    const subproofOrProofAssertions = context.getSubproofOrProofAssertions(),\n          comparesToSubproofOrProofAssertions = step.compareSubproofOrProofAssertions(subproofOrProofAssertions, context);\n\n    if (comparesToSubproofOrProofAssertions) {\n      stepComparesToSubproofOrProofAssertions = true;\n    }\n\n    if (stepComparesToSubproofOrProofAssertions) {\n      context.debug(`...compared the '${stepString}' step with the subproofs or proof asssertions.`);\n    }\n  }\n\n  return stepComparesToSubproofOrProofAssertions;\n}\n\nexport const unifySteps = [\n  unifyStepWithRule,\n  unifyStepWithReference,\n  unifyStepAsSignatureAssertion,\n  unifyStepWithTopLevelAssertion,\n  unifyStepAsEquality,\n  unifyStepAsJudgement,\n  unifyStepAsTypeAssertion,\n  unifyStepAsPropertyAssertion,\n  unifyStepWithSignatureAssertion,\n  compareStepWithSubproofOrProofAssertions\n];\n"],"names":["unifySteps","backwardsSome","arrayUtilities","unifyStepWithRule","step","context","stepUnifiesWithRule","qualified","isQualified","reference","getReference","rule","findRuleByReference","stepString","getString","ruleString","trace","subproofOrProofAssertions","getSubproofOrProofAssertions","stepAndSubproofOrProofAssertionsUnify","unifyStepAndSubproofOrProofAssertions","debug","unifyStepWithReference","stepUnifiesWithReference","referenceString","topLevelAssertion","findTopLevelAssertionByReference","metaLevel","isMetaLevel","descend","MetaLevelAssumption","elements","metaLevelAssumption","fromStep","validate","unifyStepAsSignatureAssertion","stepUnifiesAsSignatureAssertion","SignatureAssertion","signatureAssertion","verifySignature","unqualified","isUnqualified","stepsOrSubproof","stepOrSubProofUnifiesWIthSignatureAssertion","unifyWithSignatureAssertion","axiom","findAxiomByReference","satisfiable","isSatisfiable","topLevelAssertionUnifies","unifyTopLevelAssertion","substitutionsCorrelates","correlateSubstitutions","substitutions","axiomString","unifyStepWithTopLevelAssertion","stepUnifiesWithTopLevelAssertion","topLevelAssertionString","unifyStepAsEquality","stepUnifiesAEquality","Equality","statement","getStatement","equality","fromStatement","equalityEqual","isEqual","unifyStepAsJudgement","stepUnifiesAsJudgement","Judgement","judgement","unifyStepAsTypeAssertion","stepUnifiesAsTypeAssertion","TypeAssertion","typeAssertion","unifyStepAsPropertyAssertion","stepUnifiesAsPropertyAssertion","PropertyAssertion","propertyAssertion","term","getTerm","equivalence","findEquivalenceByTerm","propertyAssertionMatches","someOtherTerm","propertyRelation","getPropertyRelation","comparesToTermAndPropertyRelation","compareTermAndPropertyRelation","unifyStepWithSignatureAssertion","stepUnifiesWithSignatureAssertion","getSignatureAssertion","signatureAssertionString","stepUnifies","compareStepWithSubproofOrProofAssertions","stepComparesToSubproofOrProofAssertions","comparesToSubproofOrProofAssertions","compareSubproofOrProofAssertions"],"mappings":"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"}
|
|
232
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utilities/unification.js"],"sourcesContent":["\"use strict\";\n\nimport elements from \"../elements\";\n\nimport { descend } from \"./context\";\n\nasync function unifyStepWithRule(step, context) {\n  let stepUnifiesWithRule = false;\n\n  const reference = step.getReference();\n\n  if (reference !== null) {\n    const rule = context.findRuleByReference(reference);\n\n    if (rule !== null) {\n      const stepString = step.getString(),\n            ruleString = rule.getString();\n\n      context.trace(`Unifying the '${stepString}' step with the '${ruleString}' rule...`);\n\n      const subproofOrProofAssertions = context.getSubproofOrProofAssertions(),\n            stepAndSubproofOrProofAssertionsUnify = await rule.unifyStepAndSubproofOrProofAssertions(step, subproofOrProofAssertions, context);\n\n      if (stepAndSubproofOrProofAssertionsUnify) {\n        stepUnifiesWithRule = true;\n      }\n\n      if (stepUnifiesWithRule) {\n        context.debug(`...unified the '${stepString}' step with the '${ruleString}' rule.`);\n      }\n    }\n  }\n\n  return stepUnifiesWithRule;\n}\n\nasync function unifyStepWithReference(step, context) {\n  let stepUnifiesWithReference = false;\n\n  const reference = step.getReference();\n\n  if (reference !== null) {\n    const stepString = step.getString(),\n          referenceString = reference.getString();\n\n    context.trace(`Unifying the '${stepString}' step with the '${referenceString}' reference...`);\n\n    const topLevelAssertion = context.findTopLevelAssertionByReference(reference);\n\n    if (topLevelAssertion !== null) {\n      const subproofOrProofAssertions = context.getSubproofOrProofAssertions(),\n            stepAndSubproofOrProofAssertionsUnify = await topLevelAssertion.unifyStepAndSubproofOrProofAssertions(step, subproofOrProofAssertions, context);\n\n      if (stepAndSubproofOrProofAssertionsUnify) {\n        stepUnifiesWithReference = true;\n      }\n    } else {\n      const metaLevel = context.isMetaLevel();\n\n      if (metaLevel) {\n        descend((context) => {\n          const { MetaLevelAssumption } = elements,\n                metaLevelAssumption = MetaLevelAssumption.fromStep(step, context);\n\n          metaLevelAssumption.validate(context);\n\n          stepUnifiesWithReference = true;\n        }, context);\n      }\n    }\n\n    if (stepUnifiesWithReference) {\n      context.debug(`...unified the '${stepString}' step with the '${referenceString}' reference.`);\n    }\n  }\n\n  return stepUnifiesWithReference;\n}\n\nasync function unifyStepWithTopLevelAssertion(step, context) {\n  let stepUnifiesWithTopLevelAssertion = false;\n\n  const reference = step.getReference();\n\n  if (reference !== null) {\n    const topLevelAssertion = context.findTopLevelAssertionByReference(reference);\n\n    if (topLevelAssertion !== null) {\n      const stepString = step.getString(),\n            topLevelAssertionString = reference.getString();\n\n      context.trace(`Unifying the '${stepString}' step with the '${topLevelAssertionString}' top level assertion...`);\n\n      const subproofOrProofAssertions = context.getSubproofOrProofAssertions(),\n            stepAndSubproofOrProofAssertionsUnify = await topLevelAssertion.unifyStepAndSubproofOrProofAssertions(step, subproofOrProofAssertions, context);\n\n      if (stepAndSubproofOrProofAssertionsUnify) {\n        stepUnifiesWithTopLevelAssertion = true;\n      }\n\n      if (stepUnifiesWithTopLevelAssertion) {\n        context.debug(`...unified the '${stepString}' step with the '${topLevelAssertionString}' top level assertion.`);\n      }\n    }\n  }\n\n  return stepUnifiesWithTopLevelAssertion;\n}\n\nasync function unifyStepWithSignatureAssertion(step, context) {\n  let stepUnifiesWithSignatureAssertion = false;\n\n  const signatureAssertion = step.getSignatureAssertion();\n\n  if (signatureAssertion !== null) {\n    const stepString = step.getString(),\n          signatureAssertionString = signatureAssertion.getString();\n\n    context.trace(`Unifying the '${stepString}' step with the '${signatureAssertionString}' signature assertion...`);\n\n    const subproofOrProofAssertions = context.getSubproofOrProofAssertions(),\n          stepAndSubproofOrProofAssertionsUnify = await signatureAssertion.unifyStepAndSubproofOrProofAssertions(step, subproofOrProofAssertions, context);\n\n    if (stepAndSubproofOrProofAssertionsUnify) {\n      stepUnifiesWithSignatureAssertion = true;\n    }\n\n    if (stepUnifiesWithSignatureAssertion) {\n      context.debug(`...unified the '${stepString}' step with the '${signatureAssertionString}' signature assertion.`);\n    }\n  }\n\n  return stepUnifiesWithSignatureAssertion;\n}\n\nasync function unifyStepAsUnqualifiedEquality(step, context) {\n  let stepUnifiesAUnqualifiedEquality = false;\n\n  const unqualified = step.isUnqualified();\n\n  if (unqualified) {\n    const { Equality } = elements,\n          statement = step.getStatement(),\n          equality = Equality.fromStatement(statement, context);\n\n    if (equality !== null) {\n      const stepString = step.getString();\n\n      context.trace(`Unifying the '${stepString}' step as an unqualified equality...`);\n\n      stepUnifiesAUnqualifiedEquality = true;\n\n      if (stepUnifiesAUnqualifiedEquality) {\n        context.debug(`...unified the '${stepString}' step as an unqualified equality.`);\n      }\n    }\n  }\n\n  return stepUnifiesAUnqualifiedEquality;\n}\n\nasync function unifyStepAsUNqualifiedJudgement(step, context) {\n  let stepUnifiesAsUnqualifiedJudgement = false;\n\n  const unqualified = step.isUnqualified();\n\n  if (unqualified) {\n    const { Judgement } = elements,\n          statement = step.getStatement(),\n          judgement = Judgement.fromStatement(statement, context);\n\n    if (judgement !== null) {\n      const stepString = step.getString();\n\n      context.trace(`Unifying the '${stepString}' step as an unqualified judgement...`);\n\n      stepUnifiesAsUnqualifiedJudgement = true;\n\n      if (stepUnifiesAsUnqualifiedJudgement) {\n        context.debug(`...unified the '${stepString}' step as an unqualified judgement.`);\n      }\n    }\n  }\n\n  return stepUnifiesAsUnqualifiedJudgement;\n}\n\nasync function unifyStepAsUnqualifiedTypeAssertion(step, context) {\n  let stepUnifiesAsUnqualifiedTypeAssertion = false;\n\n  const unqualified = step.isUnqualified();\n\n  if (unqualified) {\n    const { TypeAssertion } = elements,\n          statement = step.getStatement(),\n          typeAssertion = TypeAssertion.fromStatement(statement, context);\n\n    if (typeAssertion !== null) {\n      const stepString = step.getString();\n\n      context.trace(`Unifying the '${stepString}' step as an unqualified type assertion...`);\n\n      stepUnifiesAsUnqualifiedTypeAssertion = true;\n\n      if (stepUnifiesAsUnqualifiedTypeAssertion) {\n        context.debug(`...unified the '${stepString}' step as an unqualified type assertion.`);\n      }\n    }\n  }\n\n  return stepUnifiesAsUnqualifiedTypeAssertion;\n}\n\nasync function unifyStepAsUnqualifiedPropertyAssertion(step, context) {\n  let stepUnifiesAsUnqualifiedPropertyAssertion = false;\n\n  const unqualified = step.isUnqualified();\n\n  if (unqualified) {\n    const { PropertyAssertion } = elements,\n          statement = step.getStatement(),\n          propertyAssertion = PropertyAssertion.fromStatement(statement, context);\n\n    if (propertyAssertion !== null) {\n      const stepString = step.getString();\n\n      context.trace(`Unifying the '${stepString}' step as an unqualified property assertion...`);\n\n      stepUnifiesAsUnqualifiedPropertyAssertion = true;\n\n      if (stepUnifiesAsUnqualifiedPropertyAssertion) {\n        context.debug(`...unified the '${stepString}' step as an unqualified property assertion.`);\n      }\n    }\n  }\n\n  return stepUnifiesAsUnqualifiedPropertyAssertion;\n}\n\nasync function unifyStepAsUnqualifiedSignatureAssertion(step, context) {\n  let stepUnifiesAsUnqualifiedSignatureAssertion = false;\n\n  const unqualified = step.isUnqualified();\n\n  if (unqualified) {\n    const { SignatureAssertion } = elements,\n          statement = step.getStatement(),\n          signatureAssertion = SignatureAssertion.fromStatement(statement, context);\n\n    if (signatureAssertion !== null) {\n      const stepString = step.getString();\n\n      context.trace(`Unifying the '${stepString}' step as a signature assertion...`);\n\n      stepUnifiesAsUnqualifiedSignatureAssertion = true;\n\n      if (stepUnifiesAsUnqualifiedSignatureAssertion) {\n        context.debug(`...unified the '${stepString}' step as a signature assertion.`);\n      }\n    }\n  }\n\n  return stepUnifiesAsUnqualifiedSignatureAssertion;\n}\n\nasync function unifyStepAsSignatureAssertionWithReference(step, context) {\n  let stepUnifiesAsSignatureAssertionWithReference = false;\n\n  const reference = step.getReference();\n\n  if (reference !== null) {\n    const topLevelAssertion = context.findTopLevelAssertionByReference(reference);\n\n    if (topLevelAssertion !== null) {\n      const statementNode = step.getStatementNode(),\n            signatureAssertionNode = statementNode.getSignatureAssertionNode();\n\n      if (signatureAssertionNode !== null) {\n        const stepString = step.getString(),\n              referenceString = reference.getString(),\n              signatureAssertion = context.findAssertionByAssertionNode(signatureAssertionNode);\n\n        context.trace(`Unifying the '${stepString}' step as a signature assertion with the '${referenceString}' reference...`);\n\n        const unifyTopLevelAssertion = await signatureAssertion.unifyTopLevelAssertion(topLevelAssertion, context);\n\n        if (unifyTopLevelAssertion) {\n          stepUnifiesAsSignatureAssertionWithReference = true;\n        }\n\n        if (stepUnifiesAsSignatureAssertionWithReference) {\n          context.debug(`...unified the '${stepString}' step as a signature assertion with the '${referenceString}' reference.`);\n        }\n      }\n    }\n  }\n\n  return stepUnifiesAsSignatureAssertionWithReference;\n}\n\nasync function compareStepWithSubproofOrProofAssertions(step, context) {\n  let stepComparesToSubproofOrProofAssertions = false;\n\n  const unqualified = step.isUnqualified();\n\n  if (unqualified) {\n    const stepString = step.getString();\n\n    context.trace(`Comparing the '${stepString}' step with the subproofs or proof asssertions...`);\n\n    const subproofOrProofAssertions = context.getSubproofOrProofAssertions(),\n          comparesToSubproofOrProofAssertions = step.compareSubproofOrProofAssertions(subproofOrProofAssertions, context);\n\n    if (comparesToSubproofOrProofAssertions) {\n      stepComparesToSubproofOrProofAssertions = true;\n    }\n\n    if (stepComparesToSubproofOrProofAssertions) {\n      context.debug(`...compared the '${stepString}' step with the subproofs or proof asssertions.`);\n    }\n  }\n\n  return stepComparesToSubproofOrProofAssertions;\n}\n\nexport const unifySteps = [\n  unifyStepWithRule,\n  unifyStepWithReference,\n  unifyStepWithTopLevelAssertion,\n  unifyStepWithSignatureAssertion,\n  unifyStepAsUnqualifiedEquality,\n  unifyStepAsUNqualifiedJudgement,\n  unifyStepAsUnqualifiedTypeAssertion,\n  unifyStepAsUnqualifiedPropertyAssertion,\n  unifyStepAsUnqualifiedSignatureAssertion,\n  unifyStepAsSignatureAssertionWithReference,\n  compareStepWithSubproofOrProofAssertions\n];\n"],"names":["unifySteps","unifyStepWithRule","step","context","stepUnifiesWithRule","reference","getReference","rule","findRuleByReference","stepString","getString","ruleString","trace","subproofOrProofAssertions","getSubproofOrProofAssertions","stepAndSubproofOrProofAssertionsUnify","unifyStepAndSubproofOrProofAssertions","debug","unifyStepWithReference","stepUnifiesWithReference","referenceString","topLevelAssertion","findTopLevelAssertionByReference","metaLevel","isMetaLevel","descend","MetaLevelAssumption","elements","metaLevelAssumption","fromStep","validate","unifyStepWithTopLevelAssertion","stepUnifiesWithTopLevelAssertion","topLevelAssertionString","unifyStepWithSignatureAssertion","stepUnifiesWithSignatureAssertion","signatureAssertion","getSignatureAssertion","signatureAssertionString","unifyStepAsUnqualifiedEquality","stepUnifiesAUnqualifiedEquality","unqualified","isUnqualified","Equality","statement","getStatement","equality","fromStatement","unifyStepAsUNqualifiedJudgement","stepUnifiesAsUnqualifiedJudgement","Judgement","judgement","unifyStepAsUnqualifiedTypeAssertion","stepUnifiesAsUnqualifiedTypeAssertion","TypeAssertion","typeAssertion","unifyStepAsUnqualifiedPropertyAssertion","stepUnifiesAsUnqualifiedPropertyAssertion","PropertyAssertion","propertyAssertion","unifyStepAsUnqualifiedSignatureAssertion","stepUnifiesAsUnqualifiedSignatureAssertion","SignatureAssertion","unifyStepAsSignatureAssertionWithReference","stepUnifiesAsSignatureAssertionWithReference","statementNode","getStatementNode","signatureAssertionNode","getSignatureAssertionNode","findAssertionByAssertionNode","unifyTopLevelAssertion","compareStepWithSubproofOrProofAssertions","stepComparesToSubproofOrProofAssertions","comparesToSubproofOrProofAssertions","compareSubproofOrProofAssertions"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "occam-verify-cli",
|
|
3
3
|
"author": "James Smith",
|
|
4
|
-
"version": "1.0.
|
|
4
|
+
"version": "1.0.920",
|
|
5
5
|
"license": "MIT, Anti-996",
|
|
6
6
|
"homepage": "https://github.com/djalbat/occam-verify-cli",
|
|
7
7
|
"description": "Occam's Verifier",
|
|
@@ -12,12 +12,12 @@
|
|
|
12
12
|
"dependencies": {
|
|
13
13
|
"argumentative": "^2.0.47",
|
|
14
14
|
"necessary": "^17.1.7",
|
|
15
|
-
"occam-furtle": "^3.0.
|
|
15
|
+
"occam-furtle": "^3.0.197",
|
|
16
16
|
"occam-grammars": "^1.3.524",
|
|
17
|
-
"occam-languages": "^0.0.
|
|
17
|
+
"occam-languages": "^0.0.202",
|
|
18
18
|
"occam-lexers": "^23.1.44",
|
|
19
19
|
"occam-model": "^1.0.506",
|
|
20
|
-
"occam-nominal": "^1.0.
|
|
20
|
+
"occam-nominal": "^1.0.105",
|
|
21
21
|
"occam-parsers": "^23.1.50",
|
|
22
22
|
"occam-server": "^7.0.7"
|
|
23
23
|
},
|
package/src/context/bounded.js
CHANGED
|
@@ -4,7 +4,7 @@ import { arrayUtilities } from "necessary";
|
|
|
4
4
|
|
|
5
5
|
import Context from "../context";
|
|
6
6
|
|
|
7
|
-
import { mergeEquivalences,
|
|
7
|
+
import { mergeEquivalences, equivalencesFromEquality, separateGroundedTermsAndDefinedVariables } from "../utilities/equivalences";
|
|
8
8
|
|
|
9
9
|
const { last, filter } = arrayUtilities;
|
|
10
10
|
|
|
@@ -240,8 +240,6 @@ class BoundedContext extends Context {
|
|
|
240
240
|
return comparesToTermAndPropertyRelation;
|
|
241
241
|
}
|
|
242
242
|
|
|
243
|
-
findEquivalenceByTerm(term) { return findEquivalenceByTerm(this.equivalences, term); }
|
|
244
|
-
|
|
245
243
|
findDeclaredJudgementByMetavariableNode(metavariableNode) {
|
|
246
244
|
const declaredJudgements = this.getDeclaredJudgements(),
|
|
247
245
|
declaredJudgement = declaredJudgements.find((declaredJudgement) => {
|