occam-verify-cli 1.0.800 → 1.0.806
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/branching.js +2 -2
- package/lib/context/ephemeral.js +186 -69
- package/lib/context/file/nominal.js +87 -52
- package/lib/context/liminal.js +2 -2
- package/lib/context/proof.js +55 -55
- package/lib/context/synthetic.js +151 -74
- package/lib/context.js +57 -17
- package/lib/element/assertion/defined.js +3 -3
- package/lib/element/assumption/metaLevel.js +6 -4
- package/lib/element/combinator.js +4 -2
- package/lib/element/conclusion.js +4 -2
- package/lib/element/constructor.js +4 -2
- package/lib/element/declaration/metavariable.js +10 -9
- package/lib/element/declaration/variable.js +7 -7
- package/lib/element/deduction.js +4 -2
- package/lib/element/label.js +9 -5
- package/lib/element/metavariable.js +34 -34
- package/lib/element/proofAssertion/premise.js +4 -3
- package/lib/element/proofAssertion/step.js +4 -2
- package/lib/element/reference.js +6 -4
- package/lib/element/statement.js +9 -1
- package/lib/element/substitution/frame.js +43 -29
- package/lib/element/substitution/reference.js +38 -28
- package/lib/element/substitution/statement.js +46 -38
- package/lib/element/substitution/term.js +49 -35
- package/lib/element/variable.js +6 -7
- package/lib/preamble.js +1 -2
- package/lib/process/assign.js +11 -10
- package/lib/process/equate.js +3 -2
- package/lib/process/unify.js +7 -7
- package/lib/utilities/context.js +13 -5
- package/lib/utilities/element.js +1 -1
- package/lib/utilities/equivalences.js +131 -0
- package/lib/utilities/json.js +59 -1
- package/lib/utilities/validation.js +4 -3
- package/package.json +2 -2
- package/src/context/branching.js +2 -2
- package/src/context/ephemeral.js +421 -237
- package/src/context/file/nominal.js +127 -77
- package/src/context/liminal.js +2 -2
- package/src/context/proof.js +81 -82
- package/src/context/synthetic.js +198 -88
- package/src/context.js +81 -20
- package/src/element/assertion/defined.js +4 -4
- package/src/element/assumption/metaLevel.js +8 -6
- package/src/element/combinator.js +4 -2
- package/src/element/conclusion.js +4 -2
- package/src/element/constructor.js +4 -2
- package/src/element/declaration/metavariable.js +10 -8
- package/src/element/declaration/variable.js +8 -7
- package/src/element/deduction.js +4 -2
- package/src/element/label.js +11 -7
- package/src/element/metavariable.js +11 -11
- package/src/element/proofAssertion/premise.js +4 -4
- package/src/element/proofAssertion/step.js +4 -2
- package/src/element/reference.js +7 -5
- package/src/element/statement.js +14 -0
- package/src/element/substitution/frame.js +47 -32
- package/src/element/substitution/reference.js +44 -34
- package/src/element/substitution/statement.js +63 -54
- package/src/element/substitution/term.js +53 -38
- package/src/element/variable.js +6 -7
- package/src/preamble.js +0 -1
- package/src/process/assign.js +17 -14
- package/src/process/equate.js +3 -1
- package/src/process/unify.js +10 -13
- package/src/utilities/context.js +13 -6
- package/src/utilities/element.js +1 -0
- package/src/utilities/equivalences.js +158 -0
- package/src/utilities/json.js +66 -0
- package/src/utilities/validation.js +6 -5
- package/lib/element/equivalences.js +0 -173
- package/src/element/equivalences.js +0 -237
|
@@ -1,173 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", {
|
|
3
|
-
value: true
|
|
4
|
-
});
|
|
5
|
-
Object.defineProperty(exports, "default", {
|
|
6
|
-
enumerable: true,
|
|
7
|
-
get: function() {
|
|
8
|
-
return _default;
|
|
9
|
-
}
|
|
10
|
-
});
|
|
11
|
-
const _occamlanguages = require("occam-languages");
|
|
12
|
-
const _necessary = require("necessary");
|
|
13
|
-
const _elements = require("../elements");
|
|
14
|
-
const _constants = require("../constants");
|
|
15
|
-
const _equivalence = require("../utilities/equivalence");
|
|
16
|
-
const { push, separate } = _necessary.arrayUtilities;
|
|
17
|
-
const _default = (0, _elements.define)(class Equivalences extends _occamlanguages.Element {
|
|
18
|
-
constructor(context, string, node, array){
|
|
19
|
-
super(context, string, node);
|
|
20
|
-
this.array = array;
|
|
21
|
-
}
|
|
22
|
-
getArray() {
|
|
23
|
-
return this.array;
|
|
24
|
-
}
|
|
25
|
-
getEquivalencesNode() {
|
|
26
|
-
const node = this.getNode(), equivalencesNode = node; ///
|
|
27
|
-
return equivalencesNode;
|
|
28
|
-
}
|
|
29
|
-
getLength() {
|
|
30
|
-
return this.array.length;
|
|
31
|
-
}
|
|
32
|
-
getTypes() {
|
|
33
|
-
const types = this.array.map((equivalence)=>{
|
|
34
|
-
const type = equivalence.getType();
|
|
35
|
-
return type;
|
|
36
|
-
});
|
|
37
|
-
return types;
|
|
38
|
-
}
|
|
39
|
-
addEquivalence(equivalence) {
|
|
40
|
-
this.array.push(equivalence);
|
|
41
|
-
}
|
|
42
|
-
addEquivalences(equivalences) {
|
|
43
|
-
const array = equivalences.getArray();
|
|
44
|
-
push(this.array, array);
|
|
45
|
-
}
|
|
46
|
-
someEquivalence(callback) {
|
|
47
|
-
return this.array.some(callback);
|
|
48
|
-
}
|
|
49
|
-
everyEquivalence(callback) {
|
|
50
|
-
return this.array.every(callback);
|
|
51
|
-
}
|
|
52
|
-
forEachEquivalence(callback) {
|
|
53
|
-
this.array.forEach(callback);
|
|
54
|
-
}
|
|
55
|
-
findEquivalenceByTerm(term) {
|
|
56
|
-
const equivalence = this.array.find((equivalence)=>{
|
|
57
|
-
const equivalenceComparesToTerm = equivalence.compareTerm(term);
|
|
58
|
-
if (equivalenceComparesToTerm) {
|
|
59
|
-
return true;
|
|
60
|
-
}
|
|
61
|
-
}) || null;
|
|
62
|
-
return equivalence;
|
|
63
|
-
}
|
|
64
|
-
findEquivalenceByTermNodes(termNodes) {
|
|
65
|
-
const equivalence = this.array.find((equivalence)=>{
|
|
66
|
-
const termNodeMatches = equivalence.matchTermNodes(termNodes);
|
|
67
|
-
if (termNodeMatches) {
|
|
68
|
-
return true;
|
|
69
|
-
}
|
|
70
|
-
}) || null;
|
|
71
|
-
return equivalence;
|
|
72
|
-
}
|
|
73
|
-
mergedWith(equivalences, context) {
|
|
74
|
-
let mergedEquivalences = this.clone(context); ///
|
|
75
|
-
equivalences.forEachEquivalence((equivalence)=>{
|
|
76
|
-
mergedEquivalences = mergedEquivalences.mergedWithEquivalence(equivalence, context);
|
|
77
|
-
});
|
|
78
|
-
return mergedEquivalences;
|
|
79
|
-
}
|
|
80
|
-
mergedWithEquivalence(equivalence, context) {
|
|
81
|
-
const equivalences = Equivalences.fromNothing(context);
|
|
82
|
-
let mergedEquivalence = equivalence; ///
|
|
83
|
-
this.forEachEquivalence((equivalence)=>{
|
|
84
|
-
const mergedEquivalenceDisjointFromEquivalence = mergedEquivalence.isDisjointFrom(equivalence);
|
|
85
|
-
if (mergedEquivalenceDisjointFromEquivalence) {
|
|
86
|
-
equivalences.addEquivalence(equivalence);
|
|
87
|
-
} else {
|
|
88
|
-
mergedEquivalence = mergedEquivalence.mergedWith(equivalence, context);
|
|
89
|
-
}
|
|
90
|
-
});
|
|
91
|
-
equivalence = mergedEquivalence; ///
|
|
92
|
-
equivalences.addEquivalence(equivalence);
|
|
93
|
-
return equivalences;
|
|
94
|
-
}
|
|
95
|
-
separateEquivalences(equivalencesA, equivalencesB, callback) {
|
|
96
|
-
const equivalencesAArray = equivalencesA.getArray(), equivalencesBArray = equivalencesB.getArray();
|
|
97
|
-
separate(this.array, equivalencesAArray, equivalencesBArray, callback);
|
|
98
|
-
}
|
|
99
|
-
separateInitiallyGroundedEquivalences(remainingEquivalences, initiallyGroundedEquivalences, context) {
|
|
100
|
-
this.separateEquivalences(remainingEquivalences, initiallyGroundedEquivalences, (equivalence)=>{
|
|
101
|
-
const equivalenceInitiallyGrounded = equivalence.isInitiallyGrounded(context);
|
|
102
|
-
if (!equivalenceInitiallyGrounded) {
|
|
103
|
-
return true;
|
|
104
|
-
}
|
|
105
|
-
});
|
|
106
|
-
}
|
|
107
|
-
separateImplicitlyGroundedEquivalences(remainingEquivalences, implicitlyGroundedEquivalences, definedVariables, context) {
|
|
108
|
-
this.separateEquivalences(remainingEquivalences, implicitlyGroundedEquivalences, (equivalence)=>{
|
|
109
|
-
const equivalenceImplicitlyGrounded = equivalence.isImplicitlyGrounded(definedVariables, context);
|
|
110
|
-
if (!equivalenceImplicitlyGrounded) {
|
|
111
|
-
return true;
|
|
112
|
-
}
|
|
113
|
-
});
|
|
114
|
-
}
|
|
115
|
-
separateGroundedTermsAndDefinedVariables(groundedTerms, definedVariables, context) {
|
|
116
|
-
let equivalences = this, groundedEquivalences, remainingEquivalences, initiallyGroundedEquivalences, implicitlyGroundedEquivalences;
|
|
117
|
-
remainingEquivalences = Equivalences.fromNothing(context);
|
|
118
|
-
initiallyGroundedEquivalences = Equivalences.fromNothing(context);
|
|
119
|
-
equivalences.separateInitiallyGroundedEquivalences(remainingEquivalences, initiallyGroundedEquivalences, context);
|
|
120
|
-
const initiallyGroundedEquivalencesLength = initiallyGroundedEquivalences.getLength();
|
|
121
|
-
if (initiallyGroundedEquivalencesLength > 0) {
|
|
122
|
-
groundedEquivalences = initiallyGroundedEquivalences; ///
|
|
123
|
-
let implicitlyGroundedEquivalencesLength = 1;
|
|
124
|
-
while(implicitlyGroundedEquivalencesLength > 0){
|
|
125
|
-
let definedVariablesLength = 0, previousDefinedVariablesLength = -1;
|
|
126
|
-
while(definedVariablesLength > previousDefinedVariablesLength){
|
|
127
|
-
previousDefinedVariablesLength = definedVariablesLength; ///
|
|
128
|
-
groundedTermsFromGroundedEquivalencesAndDefinedVariables(groundedEquivalences, definedVariables, groundedTerms, context);
|
|
129
|
-
definedVariablesFromGroundedTerms(groundedTerms, definedVariables, context);
|
|
130
|
-
definedVariablesLength = definedVariables.length;
|
|
131
|
-
}
|
|
132
|
-
equivalences = remainingEquivalences; ///
|
|
133
|
-
remainingEquivalences = [];
|
|
134
|
-
implicitlyGroundedEquivalences = [];
|
|
135
|
-
equivalences.separateImplicitlyGroundedEquivalences(remainingEquivalences, implicitlyGroundedEquivalences, definedVariables, context);
|
|
136
|
-
groundedEquivalences.addEquivalences(implicitlyGroundedEquivalences);
|
|
137
|
-
implicitlyGroundedEquivalencesLength = implicitlyGroundedEquivalences.getLength(); ///
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
}
|
|
141
|
-
clone(context) {
|
|
142
|
-
const string = _constants.EMPTY_STRING, node = null, array = [
|
|
143
|
-
...this.array
|
|
144
|
-
], equivalences = new Equivalences(context, string, node, array);
|
|
145
|
-
return equivalences;
|
|
146
|
-
}
|
|
147
|
-
static name = "Equivalences";
|
|
148
|
-
static fromNothing(context) {
|
|
149
|
-
const string = _constants.EMPTY_STRING, node = null, array = [];
|
|
150
|
-
context = null;
|
|
151
|
-
const equivalences = new Equivalences(context, string, node, array);
|
|
152
|
-
return equivalences;
|
|
153
|
-
}
|
|
154
|
-
});
|
|
155
|
-
function definedVariablesFromGroundedTerms(groundedTerms, definedVariables, context) {
|
|
156
|
-
groundedTerms.forEach((groundedTerm)=>{
|
|
157
|
-
const term = groundedTerm, variables = (0, _equivalence.variablesFromTerm)(term, context);
|
|
158
|
-
variables.forEach((variable)=>{
|
|
159
|
-
const definedVariablesIncludesTermVariable = definedVariables.includes(variable);
|
|
160
|
-
if (!definedVariablesIncludesTermVariable) {
|
|
161
|
-
const definedVariable = variable; ///
|
|
162
|
-
definedVariables.push(definedVariable);
|
|
163
|
-
}
|
|
164
|
-
});
|
|
165
|
-
});
|
|
166
|
-
}
|
|
167
|
-
function groundedTermsFromGroundedEquivalencesAndDefinedVariables(groundedEquivalences, definedVariables, groundedTerms, context) {
|
|
168
|
-
groundedEquivalences.forEachEquivalence((groundedEquivalence)=>{
|
|
169
|
-
groundedEquivalence.getGroundedTerms(definedVariables, groundedTerms, context);
|
|
170
|
-
});
|
|
171
|
-
}
|
|
172
|
-
|
|
173
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/element/equivalences.js"],"sourcesContent":["\"use strict\";\n\nimport { Element } from \"occam-languages\";\nimport { arrayUtilities } from \"necessary\";\n\nimport { define } from \"../elements\";\nimport { EMPTY_STRING } from \"../constants\";\nimport { variablesFromTerm } from \"../utilities/equivalence\";\n\nconst { push, separate } = arrayUtilities;\n\nexport default define(class Equivalences extends Element {\n  constructor(context, string, node, array) {\n    super(context, string, node);\n\n    this.array = array;\n  }\n\n  getArray() {\n    return this.array;\n  }\n\n  getEquivalencesNode() {\n    const node = this.getNode(),\n          equivalencesNode = node;  ///\n\n    return equivalencesNode;\n  }\n\n  getLength() { return this.array.length; }\n\n  getTypes() {\n    const types = this.array.map((equivalence) => {\n      const type = equivalence.getType();\n\n      return type;\n    });\n\n    return types;\n  }\n\n  addEquivalence(equivalence) {\n    this.array.push(equivalence);\n  }\n\n  addEquivalences(equivalences) {\n    const array = equivalences.getArray();\n\n    push(this.array, array);\n  }\n\n  someEquivalence(callback) { return this.array.some(callback); }\n\n  everyEquivalence(callback) { return this.array.every(callback); }\n\n  forEachEquivalence(callback) { this.array.forEach(callback); }\n\n  findEquivalenceByTerm(term) {\n    const equivalence = this.array.find((equivalence) => {\n      const equivalenceComparesToTerm = equivalence.compareTerm(term);\n\n      if (equivalenceComparesToTerm) {\n        return true;\n      }\n    }) || null;\n\n    return equivalence;\n  }\n\n  findEquivalenceByTermNodes(termNodes) {\n    const equivalence = this.array.find((equivalence) => {\n      const termNodeMatches = equivalence.matchTermNodes(termNodes);\n\n      if (termNodeMatches) {\n        return true;\n      }\n    }) || null;\n\n    return equivalence;\n  }\n\n  mergedWith(equivalences, context) {\n    let  mergedEquivalences = this.clone(context); ///\n\n    equivalences.forEachEquivalence((equivalence) => {\n      mergedEquivalences = mergedEquivalences.mergedWithEquivalence(equivalence, context);\n    });\n\n    return mergedEquivalences;\n  }\n\n  mergedWithEquivalence(equivalence, context) {\n    const equivalences = Equivalences.fromNothing(context);\n\n    let mergedEquivalence = equivalence; ///\n\n    this.forEachEquivalence((equivalence) => {\n      const mergedEquivalenceDisjointFromEquivalence = mergedEquivalence.isDisjointFrom(equivalence);\n\n      if (mergedEquivalenceDisjointFromEquivalence) {\n        equivalences.addEquivalence(equivalence);\n      } else {\n        mergedEquivalence = mergedEquivalence.mergedWith(equivalence, context);\n      }\n    });\n\n    equivalence = mergedEquivalence;  ///\n\n    equivalences.addEquivalence(equivalence);\n\n    return equivalences;\n  }\n\n  separateEquivalences(equivalencesA, equivalencesB, callback) {\n    const equivalencesAArray = equivalencesA.getArray(),\n          equivalencesBArray = equivalencesB.getArray();\n\n    separate(this.array, equivalencesAArray, equivalencesBArray, callback);\n  }\n\n  separateInitiallyGroundedEquivalences(remainingEquivalences, initiallyGroundedEquivalences, context) {\n    this.separateEquivalences(remainingEquivalences, initiallyGroundedEquivalences, (equivalence) => {\n      const equivalenceInitiallyGrounded = equivalence.isInitiallyGrounded(context);\n\n      if (!equivalenceInitiallyGrounded) {\n        return true;\n      }\n    });\n  }\n\n  separateImplicitlyGroundedEquivalences(remainingEquivalences, implicitlyGroundedEquivalences, definedVariables, context) {\n    this.separateEquivalences(remainingEquivalences, implicitlyGroundedEquivalences, (equivalence) => {\n      const equivalenceImplicitlyGrounded = equivalence.isImplicitlyGrounded(definedVariables, context);\n\n      if (!equivalenceImplicitlyGrounded) {\n        return true;\n      }\n    });\n  }\n\n  separateGroundedTermsAndDefinedVariables(groundedTerms, definedVariables, context) {\n    let equivalences = this,  ///\n        groundedEquivalences,\n        remainingEquivalences,\n        initiallyGroundedEquivalences,\n        implicitlyGroundedEquivalences;\n\n    remainingEquivalences =Equivalences.fromNothing(context);\n\n    initiallyGroundedEquivalences = Equivalences.fromNothing(context);\n\n    equivalences.separateInitiallyGroundedEquivalences(remainingEquivalences, initiallyGroundedEquivalences, context);\n\n    const initiallyGroundedEquivalencesLength = initiallyGroundedEquivalences.getLength();\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        equivalences.separateImplicitlyGroundedEquivalences(remainingEquivalences, implicitlyGroundedEquivalences, definedVariables, context);\n\n        groundedEquivalences.addEquivalences(implicitlyGroundedEquivalences);\n\n        implicitlyGroundedEquivalencesLength = implicitlyGroundedEquivalences.getLength();  ///\n      }\n    }\n  }\n\n  clone(context) {\n    const string = EMPTY_STRING,\n          node = null,\n          array = [\n            ...this.array\n          ],\n          equivalences = new Equivalences(context, string, node, array);\n\n    return equivalences;\n  }\n\n  static name = \"Equivalences\";\n\n  static fromNothing(context) {\n    const string = EMPTY_STRING,\n          node = null,\n          array = [];\n\n    context = null;\n\n    const equivalences = new Equivalences(context, string, node, array);\n\n    return equivalences;\n  }\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 groundedTermsFromGroundedEquivalencesAndDefinedVariables(groundedEquivalences, definedVariables, groundedTerms, context) {\n  groundedEquivalences.forEachEquivalence((groundedEquivalence) => {\n    groundedEquivalence.getGroundedTerms(definedVariables, groundedTerms, context);\n  });\n}\n"],"names":["push","separate","arrayUtilities","define","Equivalences","Element","context","string","node","array","getArray","getEquivalencesNode","getNode","equivalencesNode","getLength","length","getTypes","types","map","equivalence","type","getType","addEquivalence","addEquivalences","equivalences","someEquivalence","callback","some","everyEquivalence","every","forEachEquivalence","forEach","findEquivalenceByTerm","term","find","equivalenceComparesToTerm","compareTerm","findEquivalenceByTermNodes","termNodes","termNodeMatches","matchTermNodes","mergedWith","mergedEquivalences","clone","mergedWithEquivalence","fromNothing","mergedEquivalence","mergedEquivalenceDisjointFromEquivalence","isDisjointFrom","separateEquivalences","equivalencesA","equivalencesB","equivalencesAArray","equivalencesBArray","separateInitiallyGroundedEquivalences","remainingEquivalences","initiallyGroundedEquivalences","equivalenceInitiallyGrounded","isInitiallyGrounded","separateImplicitlyGroundedEquivalences","implicitlyGroundedEquivalences","definedVariables","equivalenceImplicitlyGrounded","isImplicitlyGrounded","separateGroundedTermsAndDefinedVariables","groundedTerms","groundedEquivalences","initiallyGroundedEquivalencesLength","implicitlyGroundedEquivalencesLength","definedVariablesLength","previousDefinedVariablesLength","groundedTermsFromGroundedEquivalencesAndDefinedVariables","definedVariablesFromGroundedTerms","EMPTY_STRING","name","groundedTerm","variables","variablesFromTerm","variable","definedVariablesIncludesTermVariable","includes","definedVariable","groundedEquivalence","getGroundedTerms"],"mappings":"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"}
|
|
@@ -1,237 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
import { Element } from "occam-languages";
|
|
4
|
-
import { arrayUtilities } from "necessary";
|
|
5
|
-
|
|
6
|
-
import { define } from "../elements";
|
|
7
|
-
import { EMPTY_STRING } from "../constants";
|
|
8
|
-
import { variablesFromTerm } from "../utilities/equivalence";
|
|
9
|
-
|
|
10
|
-
const { push, separate } = arrayUtilities;
|
|
11
|
-
|
|
12
|
-
export default define(class Equivalences extends Element {
|
|
13
|
-
constructor(context, string, node, array) {
|
|
14
|
-
super(context, string, node);
|
|
15
|
-
|
|
16
|
-
this.array = array;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
getArray() {
|
|
20
|
-
return this.array;
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
getEquivalencesNode() {
|
|
24
|
-
const node = this.getNode(),
|
|
25
|
-
equivalencesNode = node; ///
|
|
26
|
-
|
|
27
|
-
return equivalencesNode;
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
getLength() { return this.array.length; }
|
|
31
|
-
|
|
32
|
-
getTypes() {
|
|
33
|
-
const types = this.array.map((equivalence) => {
|
|
34
|
-
const type = equivalence.getType();
|
|
35
|
-
|
|
36
|
-
return type;
|
|
37
|
-
});
|
|
38
|
-
|
|
39
|
-
return types;
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
addEquivalence(equivalence) {
|
|
43
|
-
this.array.push(equivalence);
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
addEquivalences(equivalences) {
|
|
47
|
-
const array = equivalences.getArray();
|
|
48
|
-
|
|
49
|
-
push(this.array, array);
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
someEquivalence(callback) { return this.array.some(callback); }
|
|
53
|
-
|
|
54
|
-
everyEquivalence(callback) { return this.array.every(callback); }
|
|
55
|
-
|
|
56
|
-
forEachEquivalence(callback) { this.array.forEach(callback); }
|
|
57
|
-
|
|
58
|
-
findEquivalenceByTerm(term) {
|
|
59
|
-
const equivalence = this.array.find((equivalence) => {
|
|
60
|
-
const equivalenceComparesToTerm = equivalence.compareTerm(term);
|
|
61
|
-
|
|
62
|
-
if (equivalenceComparesToTerm) {
|
|
63
|
-
return true;
|
|
64
|
-
}
|
|
65
|
-
}) || null;
|
|
66
|
-
|
|
67
|
-
return equivalence;
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
findEquivalenceByTermNodes(termNodes) {
|
|
71
|
-
const equivalence = this.array.find((equivalence) => {
|
|
72
|
-
const termNodeMatches = equivalence.matchTermNodes(termNodes);
|
|
73
|
-
|
|
74
|
-
if (termNodeMatches) {
|
|
75
|
-
return true;
|
|
76
|
-
}
|
|
77
|
-
}) || null;
|
|
78
|
-
|
|
79
|
-
return equivalence;
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
mergedWith(equivalences, context) {
|
|
83
|
-
let mergedEquivalences = this.clone(context); ///
|
|
84
|
-
|
|
85
|
-
equivalences.forEachEquivalence((equivalence) => {
|
|
86
|
-
mergedEquivalences = mergedEquivalences.mergedWithEquivalence(equivalence, context);
|
|
87
|
-
});
|
|
88
|
-
|
|
89
|
-
return mergedEquivalences;
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
mergedWithEquivalence(equivalence, context) {
|
|
93
|
-
const equivalences = Equivalences.fromNothing(context);
|
|
94
|
-
|
|
95
|
-
let mergedEquivalence = equivalence; ///
|
|
96
|
-
|
|
97
|
-
this.forEachEquivalence((equivalence) => {
|
|
98
|
-
const mergedEquivalenceDisjointFromEquivalence = mergedEquivalence.isDisjointFrom(equivalence);
|
|
99
|
-
|
|
100
|
-
if (mergedEquivalenceDisjointFromEquivalence) {
|
|
101
|
-
equivalences.addEquivalence(equivalence);
|
|
102
|
-
} else {
|
|
103
|
-
mergedEquivalence = mergedEquivalence.mergedWith(equivalence, context);
|
|
104
|
-
}
|
|
105
|
-
});
|
|
106
|
-
|
|
107
|
-
equivalence = mergedEquivalence; ///
|
|
108
|
-
|
|
109
|
-
equivalences.addEquivalence(equivalence);
|
|
110
|
-
|
|
111
|
-
return equivalences;
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
separateEquivalences(equivalencesA, equivalencesB, callback) {
|
|
115
|
-
const equivalencesAArray = equivalencesA.getArray(),
|
|
116
|
-
equivalencesBArray = equivalencesB.getArray();
|
|
117
|
-
|
|
118
|
-
separate(this.array, equivalencesAArray, equivalencesBArray, callback);
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
separateInitiallyGroundedEquivalences(remainingEquivalences, initiallyGroundedEquivalences, context) {
|
|
122
|
-
this.separateEquivalences(remainingEquivalences, initiallyGroundedEquivalences, (equivalence) => {
|
|
123
|
-
const equivalenceInitiallyGrounded = equivalence.isInitiallyGrounded(context);
|
|
124
|
-
|
|
125
|
-
if (!equivalenceInitiallyGrounded) {
|
|
126
|
-
return true;
|
|
127
|
-
}
|
|
128
|
-
});
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
separateImplicitlyGroundedEquivalences(remainingEquivalences, implicitlyGroundedEquivalences, definedVariables, context) {
|
|
132
|
-
this.separateEquivalences(remainingEquivalences, implicitlyGroundedEquivalences, (equivalence) => {
|
|
133
|
-
const equivalenceImplicitlyGrounded = equivalence.isImplicitlyGrounded(definedVariables, context);
|
|
134
|
-
|
|
135
|
-
if (!equivalenceImplicitlyGrounded) {
|
|
136
|
-
return true;
|
|
137
|
-
}
|
|
138
|
-
});
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
separateGroundedTermsAndDefinedVariables(groundedTerms, definedVariables, context) {
|
|
142
|
-
let equivalences = this, ///
|
|
143
|
-
groundedEquivalences,
|
|
144
|
-
remainingEquivalences,
|
|
145
|
-
initiallyGroundedEquivalences,
|
|
146
|
-
implicitlyGroundedEquivalences;
|
|
147
|
-
|
|
148
|
-
remainingEquivalences =Equivalences.fromNothing(context);
|
|
149
|
-
|
|
150
|
-
initiallyGroundedEquivalences = Equivalences.fromNothing(context);
|
|
151
|
-
|
|
152
|
-
equivalences.separateInitiallyGroundedEquivalences(remainingEquivalences, initiallyGroundedEquivalences, context);
|
|
153
|
-
|
|
154
|
-
const initiallyGroundedEquivalencesLength = initiallyGroundedEquivalences.getLength();
|
|
155
|
-
|
|
156
|
-
if (initiallyGroundedEquivalencesLength > 0) {
|
|
157
|
-
groundedEquivalences = initiallyGroundedEquivalences; ///
|
|
158
|
-
|
|
159
|
-
let implicitlyGroundedEquivalencesLength = 1;
|
|
160
|
-
|
|
161
|
-
while (implicitlyGroundedEquivalencesLength > 0) {
|
|
162
|
-
let definedVariablesLength = 0,
|
|
163
|
-
previousDefinedVariablesLength = -1;
|
|
164
|
-
|
|
165
|
-
while (definedVariablesLength > previousDefinedVariablesLength) {
|
|
166
|
-
previousDefinedVariablesLength = definedVariablesLength; ///
|
|
167
|
-
|
|
168
|
-
groundedTermsFromGroundedEquivalencesAndDefinedVariables(groundedEquivalences, definedVariables, groundedTerms, context);
|
|
169
|
-
|
|
170
|
-
definedVariablesFromGroundedTerms(groundedTerms, definedVariables, context);
|
|
171
|
-
|
|
172
|
-
definedVariablesLength = definedVariables.length;
|
|
173
|
-
}
|
|
174
|
-
|
|
175
|
-
equivalences = remainingEquivalences; ///
|
|
176
|
-
|
|
177
|
-
remainingEquivalences = [];
|
|
178
|
-
|
|
179
|
-
implicitlyGroundedEquivalences = [];
|
|
180
|
-
|
|
181
|
-
equivalences.separateImplicitlyGroundedEquivalences(remainingEquivalences, implicitlyGroundedEquivalences, definedVariables, context);
|
|
182
|
-
|
|
183
|
-
groundedEquivalences.addEquivalences(implicitlyGroundedEquivalences);
|
|
184
|
-
|
|
185
|
-
implicitlyGroundedEquivalencesLength = implicitlyGroundedEquivalences.getLength(); ///
|
|
186
|
-
}
|
|
187
|
-
}
|
|
188
|
-
}
|
|
189
|
-
|
|
190
|
-
clone(context) {
|
|
191
|
-
const string = EMPTY_STRING,
|
|
192
|
-
node = null,
|
|
193
|
-
array = [
|
|
194
|
-
...this.array
|
|
195
|
-
],
|
|
196
|
-
equivalences = new Equivalences(context, string, node, array);
|
|
197
|
-
|
|
198
|
-
return equivalences;
|
|
199
|
-
}
|
|
200
|
-
|
|
201
|
-
static name = "Equivalences";
|
|
202
|
-
|
|
203
|
-
static fromNothing(context) {
|
|
204
|
-
const string = EMPTY_STRING,
|
|
205
|
-
node = null,
|
|
206
|
-
array = [];
|
|
207
|
-
|
|
208
|
-
context = null;
|
|
209
|
-
|
|
210
|
-
const equivalences = new Equivalences(context, string, node, array);
|
|
211
|
-
|
|
212
|
-
return equivalences;
|
|
213
|
-
}
|
|
214
|
-
});
|
|
215
|
-
|
|
216
|
-
function definedVariablesFromGroundedTerms(groundedTerms, definedVariables, context) {
|
|
217
|
-
groundedTerms.forEach((groundedTerm) => {
|
|
218
|
-
const term = groundedTerm, ///
|
|
219
|
-
variables = variablesFromTerm(term, context);
|
|
220
|
-
|
|
221
|
-
variables.forEach((variable) => {
|
|
222
|
-
const definedVariablesIncludesTermVariable = definedVariables.includes(variable);
|
|
223
|
-
|
|
224
|
-
if (!definedVariablesIncludesTermVariable) {
|
|
225
|
-
const definedVariable = variable; ///
|
|
226
|
-
|
|
227
|
-
definedVariables.push(definedVariable);
|
|
228
|
-
}
|
|
229
|
-
});
|
|
230
|
-
});
|
|
231
|
-
}
|
|
232
|
-
|
|
233
|
-
function groundedTermsFromGroundedEquivalencesAndDefinedVariables(groundedEquivalences, definedVariables, groundedTerms, context) {
|
|
234
|
-
groundedEquivalences.forEachEquivalence((groundedEquivalence) => {
|
|
235
|
-
groundedEquivalence.getGroundedTerms(definedVariables, groundedTerms, context);
|
|
236
|
-
});
|
|
237
|
-
}
|