forked from JavaTX/JavaCompilerCore
modified: ../../../../main/java/de/dhbwstuttgart/typeinference/unify/TypeUnify2Task.java
modified: ../../../../main/java/de/dhbwstuttgart/typeinference/unify/TypeUnifyTask.java modified: ../../../../main/java/de/dhbwstuttgart/typeinference/unify/model/OrderingUnifyPair.java modified: ../../../../main/java/de/dhbwstuttgart/typeinference/unify/model/UnifyPair.java Noch einige Fehler
This commit is contained in:
parent
728b729f08
commit
2bd6147517
@ -33,7 +33,7 @@ public class TypeUnify2Task extends TypeUnifyTask {
|
|||||||
System.out.println("two");
|
System.out.println("two");
|
||||||
}
|
}
|
||||||
one = true;
|
one = true;
|
||||||
Set<Set<UnifyPair>> res = unify2(setToFlatten, eq, oderConstraintsField, fc, parallel, rekTiefeField);
|
Set<Set<UnifyPair>> res = unify2(setToFlatten, eq, oderConstraintsField, fc, parallel, rekTiefeField, true);
|
||||||
/*if (isUndefinedPairSetSet(res)) {
|
/*if (isUndefinedPairSetSet(res)) {
|
||||||
return new HashSet<>(); }
|
return new HashSet<>(); }
|
||||||
else
|
else
|
||||||
|
@ -217,7 +217,7 @@ public class TypeUnifyTask extends RecursiveTask<Set<Set<UnifyPair>>> {
|
|||||||
ArrayList<Set<Set<UnifyPair>>> remainingOderconstraints = oderConstraintsField.stream()
|
ArrayList<Set<Set<UnifyPair>>> remainingOderconstraints = oderConstraintsField.stream()
|
||||||
.filter(x -> x.size()>1)
|
.filter(x -> x.size()>1)
|
||||||
.collect(Collectors.toCollection(ArrayList::new));
|
.collect(Collectors.toCollection(ArrayList::new));
|
||||||
Set<Set<UnifyPair>> res = unify(neweq, remainingOderconstraints, fc, parallel, rekTiefeField);
|
Set<Set<UnifyPair>> res = unify(neweq, remainingOderconstraints, fc, parallel, rekTiefeField, true);
|
||||||
noOfThread--;
|
noOfThread--;
|
||||||
try {
|
try {
|
||||||
logFile.close();
|
logFile.close();
|
||||||
@ -240,253 +240,7 @@ public class TypeUnifyTask extends RecursiveTask<Set<Set<UnifyPair>>> {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
public Set<Set<UnifyPair>> computeCartesianRecursiveOderConstraints(Set<Set<UnifyPair>> fstElems, List<Set<Set<UnifyPair>>> topLevelSets, IFiniteClosure fc, boolean parallel, int rekTiefe) {
|
|
||||||
//ArrayList<Set<Set<UnifyPair>>> remainingSets = new ArrayList<>(topLevelSets);
|
|
||||||
fstElems.addAll(topLevelSets.stream()
|
|
||||||
.filter(x -> x.size()==1)
|
|
||||||
.map(y -> y.stream().findFirst().get())
|
|
||||||
.collect(Collectors.toCollection(HashSet::new)));
|
|
||||||
ArrayList<Set<Set<UnifyPair>>> remainingSets = topLevelSets.stream()
|
|
||||||
.filter(x -> x.size()>1)
|
|
||||||
.collect(Collectors.toCollection(ArrayList::new));
|
|
||||||
if (remainingSets.isEmpty()) {//Alle Elemente sind 1-elementig
|
|
||||||
Set<UnifyPair> eq = new HashSet<>();
|
|
||||||
fstElems.stream().forEach(x -> eq.addAll(x));
|
|
||||||
Set<Set<UnifyPair>> result = unify(eq, new ArrayList<>(), fc, parallel, rekTiefe);
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
Set<Set<UnifyPair>> nextSet = remainingSets.remove(0);
|
|
||||||
writeLog("nextSet: " + nextSet.toString());
|
|
||||||
List<Set<UnifyPair>> nextSetasList =new ArrayList<>(nextSet);
|
|
||||||
try {
|
|
||||||
//List<Set<UnifyPair>>
|
|
||||||
//nextSetasList = oup.sortedCopy(nextSet);//new ArrayList<>(nextSet);
|
|
||||||
}
|
|
||||||
catch (java.lang.IllegalArgumentException e) {
|
|
||||||
System.out.print("");
|
|
||||||
}
|
|
||||||
Set<Set<UnifyPair>> result = new HashSet<>();
|
|
||||||
int variance = 0;
|
|
||||||
Optional<Integer> xi = nextSetasList.stream().map(x -> x.stream().filter(y -> y.getLhsType() instanceof PlaceholderType)
|
|
||||||
.filter(z -> ((PlaceholderType)z.getLhsType()).getVariance() != 0)
|
|
||||||
.map(c -> ((PlaceholderType)c.getLhsType()).getVariance())
|
|
||||||
.reduce((a,b)-> {if (a==b) return a; else return 0; }))
|
|
||||||
.filter(d -> d.isPresent())
|
|
||||||
.map(e -> e.get())
|
|
||||||
.findAny();
|
|
||||||
if (xi.isPresent()) {
|
|
||||||
variance = xi.get();
|
|
||||||
}
|
|
||||||
//if (variance == 1 && nextSetasList.size() > 1) {
|
|
||||||
// List<Set<UnifyPair>> al = new ArrayList<>(nextSetasList.size());
|
|
||||||
// for (int ii = 0; ii < nextSetasList.size();ii++) {
|
|
||||||
// al.add(0,nextSetasList.get(ii));
|
|
||||||
// }
|
|
||||||
// nextSetasList = al;
|
|
||||||
//}
|
|
||||||
//Set<UnifyPair> a = nextSetasListIt.next();
|
|
||||||
/*if (nextSetasList.size()>1) {zu loeschen
|
|
||||||
if (nextSetasList.iterator().next().iterator().next().getLhsType().getName().equals("D"))
|
|
||||||
System.out.print("");
|
|
||||||
if (variance == 1) {
|
|
||||||
a_next = oup.max(nextSetasList.iterator());
|
|
||||||
}
|
|
||||||
else if (variance == -1) {
|
|
||||||
a_next = oup.min(nextSetasList.iterator());
|
|
||||||
}
|
|
||||||
else if (variance == 0) {
|
|
||||||
a_next = nextSetasList.iterator().next();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
a_next = nextSetasList.iterator().next();
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
if (!nextSetasList.iterator().hasNext())
|
|
||||||
System.out.print("");
|
|
||||||
if (nextSetasList.iterator().next().stream().filter(x -> x.getLhsType().getName().equals("D")).findFirst().isPresent() && nextSetasList.size()>1)
|
|
||||||
System.out.print("");
|
|
||||||
writeLog("nextSetasList: " + nextSetasList.toString());
|
|
||||||
while (nextSetasList.size() > 0) { //(nextSetasList.size() != 0) {
|
|
||||||
Set<UnifyPair> a = null;
|
|
||||||
if (variance == 1) {
|
|
||||||
a = oup.max(nextSetasList.iterator());
|
|
||||||
nextSetasList.remove(a);
|
|
||||||
}
|
|
||||||
else if (variance == -1) {
|
|
||||||
a = oup.min(nextSetasList.iterator());
|
|
||||||
nextSetasList.remove(a);
|
|
||||||
}
|
|
||||||
else if (variance == 0) {
|
|
||||||
a = nextSetasList.remove(0);
|
|
||||||
}
|
|
||||||
//writeLog("nextSet: " + nextSetasList.toString()+ "\n");
|
|
||||||
//nextSetasList.remove(a);
|
|
||||||
/* zu loeschen
|
|
||||||
if (nextSetasList.size() > 0) {
|
|
||||||
if (nextSetasList.size()>1) {
|
|
||||||
if (variance == 1) {
|
|
||||||
a_next = oup.max(nextSetasList.iterator());
|
|
||||||
}
|
|
||||||
else if (variance == -1) {
|
|
||||||
a_next = oup.min(nextSetasList.iterator());
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
a_next = nextSetasList.iterator().next();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
a_next = nextSetasList.iterator().next();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
//PL 2018-03-01
|
|
||||||
//TODO: 1. Maximum und Minimum unterscheiden
|
|
||||||
//TODO: 2. compare noch für alle Elmemente die nicht X =. ty sind erweitern
|
|
||||||
//for(Set<UnifyPair> a : newSet) {
|
|
||||||
i++;
|
|
||||||
Set<Set<UnifyPair>> elems = new HashSet<Set<UnifyPair>>(fstElems);
|
|
||||||
elems.add(a);
|
|
||||||
Set<Set<UnifyPair>> res = new HashSet<>();
|
|
||||||
if (remainingSets.isEmpty()) {
|
|
||||||
noou++;
|
|
||||||
writeLog("Vor unify Aufruf: " + eq.toString());
|
|
||||||
writeLog("No of Unify " + noou);
|
|
||||||
System.out.println(noou);
|
|
||||||
Set<UnifyPair> eq = new HashSet<>();
|
|
||||||
elems.stream().forEach(x -> eq.addAll(x));
|
|
||||||
res = unify(eq, new ArrayList<>(), fc, parallel, rekTiefe);
|
|
||||||
}
|
|
||||||
else {//duerfte gar nicht mehr vorkommen PL 2018-04-03
|
|
||||||
res = computeCartesianRecursiveOderConstraints(elems, remainingSets, fc, parallel, rekTiefe);
|
|
||||||
|
|
||||||
}
|
|
||||||
if (!isUndefinedPairSetSet(res) && isUndefinedPairSetSet(result)) {
|
|
||||||
//wenn korrektes Ergebnis gefunden alle Fehlerfaelle loeschen
|
|
||||||
result = res;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
if ((isUndefinedPairSetSet(res) && isUndefinedPairSetSet(result))
|
|
||||||
|| (!isUndefinedPairSetSet(res) && !isUndefinedPairSetSet(result))
|
|
||||||
|| result.isEmpty()) {
|
|
||||||
//alle Fehlerfaelle und alle korrekten Ergebnis jeweils adden
|
|
||||||
result.addAll(res);
|
|
||||||
}
|
|
||||||
//else {
|
|
||||||
//wenn Korrekte Ergebnisse da und Feherfälle dazukommen Fehlerfälle ignorieren
|
|
||||||
// if (isUndefinedPairSetSet(res) && !isUndefinedPairSetSet(result)) {
|
|
||||||
// result = result;
|
|
||||||
// }
|
|
||||||
//}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* auskommentiert um alle Max und min Betrachtung auszuschalten ANFANG */
|
|
||||||
if (!result.isEmpty() && !isUndefinedPairSetSet(res)) {
|
|
||||||
if (nextSetasList.iterator().hasNext() && nextSetasList.iterator().next().stream().filter(x -> x.getLhsType().getName().equals("B")).findFirst().isPresent() && nextSetasList.size()>1)
|
|
||||||
System.out.print("");
|
|
||||||
Iterator<Set<UnifyPair>> nextSetasListIt = new ArrayList<Set<UnifyPair>>(nextSetasList).iterator();
|
|
||||||
if (variance == 1) {
|
|
||||||
System.out.println("");
|
|
||||||
while (nextSetasListIt.hasNext()) {
|
|
||||||
Set<UnifyPair> a_next = nextSetasListIt.next();
|
|
||||||
if (a.equals(a_next) ||
|
|
||||||
(oup.compare(a, a_next) == 1)) {
|
|
||||||
nextSetasList.remove(a_next);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
System.out.println("");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else { if (variance == -1) {
|
|
||||||
System.out.println("");
|
|
||||||
while (nextSetasListIt.hasNext()) {
|
|
||||||
Set<UnifyPair> a_next = nextSetasListIt.next();
|
|
||||||
if (a.equals(a_next) ||
|
|
||||||
(oup.compare(a, a_next) == -1)) {
|
|
||||||
nextSetasList.remove(0);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
System.out.println("");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (variance == 0) {
|
|
||||||
//break;
|
|
||||||
}}
|
|
||||||
}
|
|
||||||
/* auskommentiert um alle Max und min Betrachtung auszuschalten ENDE */
|
|
||||||
|
|
||||||
/* PL 2018-11-05 wird falsch weil es auf der obersten Ebene ist.
|
|
||||||
if (isUndefinedPairSetSet(res)) {
|
|
||||||
int nofstred= 0;
|
|
||||||
Set<UnifyPair> abhSubst = res.stream()
|
|
||||||
.map(b ->
|
|
||||||
b.stream()
|
|
||||||
.map(x -> x.getAllSubstitutions())
|
|
||||||
.reduce((y,z) -> { y.addAll(z); return y;}).get())
|
|
||||||
.reduce((y,z) -> { y.addAll(z); return y;}).get();
|
|
||||||
Set<UnifyPair> b = a;//effective final a
|
|
||||||
Set<UnifyPair> durchschnitt = abhSubst.stream()
|
|
||||||
.filter(x -> b.contains(x))
|
|
||||||
//.filter(y -> abhSubst.contains(y))
|
|
||||||
.collect(Collectors.toCollection(HashSet::new));
|
|
||||||
//Set<PlaceholderType> vars = durchschnitt.stream().map(x -> (PlaceholderType)x.getLhsType()).collect(Collectors.toCollection(HashSet::new));
|
|
||||||
int len = nextSetasList.size();
|
|
||||||
Set<UnifyPair> undefRes = res.stream().reduce((y,z) -> { y.addAll(z); return y;}).get(); //flatten aller undef results
|
|
||||||
Set<Pair<Set<UnifyPair>, UnifyPair>> reducedUndefResSubstGroundedBasePair = undefRes.stream()
|
|
||||||
.map(x -> { Set<UnifyPair> su = x.getAllSubstitutions(); //alle benutzten Substitutionen
|
|
||||||
su.add(x.getGroundBasePair()); // urspruengliches Paar
|
|
||||||
su.removeAll(durchschnitt); //alle aktuell genänderten Paare entfernen
|
|
||||||
return new Pair<>(su, x.getGroundBasePair());})
|
|
||||||
.collect(Collectors.toCollection(HashSet::new));
|
|
||||||
if (res.size() > 1) {
|
|
||||||
System.out.println();
|
|
||||||
}
|
|
||||||
nextSetasList = nextSetasList.stream().filter(x -> {
|
|
||||||
//Boolean ret = false;
|
|
||||||
//for (PlaceholderType var : vars) {
|
|
||||||
// ret = ret || x.stream().map(b -> b.getLhsType().equals(var)).reduce((c,d) -> c || d).get();
|
|
||||||
//}
|
|
||||||
return (!x.containsAll(durchschnitt));//Was passiert wenn durchschnitt leer ist??
|
|
||||||
})//.filter(y -> couldBecorrect(reducedUndefResSubstGroundedBasePair, y)) //fuer testzwecke auskommentiert um nofstred zu bestimmen PL 2018-10-10
|
|
||||||
.collect(Collectors.toCollection(ArrayList::new));
|
|
||||||
nofstred = nextSetasList.size();
|
|
||||||
//NOCH NICHT korrekt PL 2018-10-12
|
|
||||||
//nextSetasList = nextSetasList.stream().filter(y -> couldBecorrect(reducedUndefResSubstGroundedBasePair, y))
|
|
||||||
// .collect(Collectors.toCollection(ArrayList::new));
|
|
||||||
writeLog("res (undef): " + res.toString());
|
|
||||||
writeLog("abhSubst: " + abhSubst.toString());
|
|
||||||
writeLog("a: " + a.toString());
|
|
||||||
writeLog("Durchschnitt: " + durchschnitt.toString());
|
|
||||||
writeLog("nextSet: " + nextSet.toString());
|
|
||||||
writeLog("nextSetasList: " + nextSetasList.toString());
|
|
||||||
writeLog("Number first erased Elements (undef): " + (len - nofstred));
|
|
||||||
writeLog("Number second erased Elements (undef): " + (nofstred- nextSetasList.size()));
|
|
||||||
writeLog("Number erased Elements (undef): " + (len - nextSetasList.size()));
|
|
||||||
noAllErasedElements = noAllErasedElements + (len - nextSetasList.size());
|
|
||||||
writeLog("Number of all erased Elements (undef): " + noAllErasedElements.toString());
|
|
||||||
noBacktracking++;
|
|
||||||
writeLog("Number of Backtracking: " + noBacktracking);
|
|
||||||
System.out.println("");
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
//if (nextSetasList.size() == 0 && isUndefinedPairSetSet(result) && nextSet.size() > 1) {
|
|
||||||
// return result;
|
|
||||||
//}
|
|
||||||
//else {
|
|
||||||
// result.removeIf(y -> isUndefinedPairSet(y));
|
|
||||||
//}
|
|
||||||
//else result.stream().filter(y -> !isUndefinedPairSet(y));
|
|
||||||
|
|
||||||
|
|
||||||
} // End of while (nextSetasList.size() > 0)
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Computes all principal type unifiers for a set of constraints.
|
* Computes all principal type unifiers for a set of constraints.
|
||||||
@ -494,7 +248,7 @@ public class TypeUnifyTask extends RecursiveTask<Set<Set<UnifyPair>>> {
|
|||||||
* @param fc The finite closure
|
* @param fc The finite closure
|
||||||
* @return The set of all principal type unifiers
|
* @return The set of all principal type unifiers
|
||||||
*/
|
*/
|
||||||
protected Set<Set<UnifyPair>> unify(final Set<UnifyPair> eq, List<Set<Set<UnifyPair>>> oderConstraints, IFiniteClosure fc, boolean parallel, int rekTiefe) {
|
protected Set<Set<UnifyPair>> unify(final Set<UnifyPair> eq, List<Set<Set<UnifyPair>>> oderConstraints, IFiniteClosure fc, boolean parallel, int rekTiefe, Boolean finalresult) {
|
||||||
//Set<UnifyPair> aas = eq.stream().filter(x -> x.getLhsType().getName().equals("AA") //&& x.getPairOp().equals(PairOperator.SMALLERDOT)
|
//Set<UnifyPair> aas = eq.stream().filter(x -> x.getLhsType().getName().equals("AA") //&& x.getPairOp().equals(PairOperator.SMALLERDOT)
|
||||||
// ).collect(Collectors.toCollection(HashSet::new));
|
// ).collect(Collectors.toCollection(HashSet::new));
|
||||||
//writeLog(nOfUnify.toString() + " AA: " + aas.toString());
|
//writeLog(nOfUnify.toString() + " AA: " + aas.toString());
|
||||||
@ -647,12 +401,12 @@ public class TypeUnifyTask extends RecursiveTask<Set<Set<UnifyPair>>> {
|
|||||||
|
|
||||||
//Aufruf von computeCartesianRecursive ANFANG
|
//Aufruf von computeCartesianRecursive ANFANG
|
||||||
//writeLog("topLevelSets: " + topLevelSets.toString());
|
//writeLog("topLevelSets: " + topLevelSets.toString());
|
||||||
return computeCartesianRecursive(new HashSet<>(), new ArrayList<>(topLevelSets), eq, oderConstraintsOutput, fc, parallel, rekTiefe, collectErr);
|
return computeCartesianRecursive(new HashSet<>(), new ArrayList<>(topLevelSets), eq, oderConstraintsOutput, fc, parallel, rekTiefe, collectErr, finalresult);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
Set<Set<UnifyPair>> unify2(Set<Set<UnifyPair>> setToFlatten, Set<UnifyPair> eq, List<Set<Set<UnifyPair>>> oderConstraints, IFiniteClosure fc, boolean parallel, int rekTiefe) {
|
Set<Set<UnifyPair>> unify2(Set<Set<UnifyPair>> setToFlatten, Set<UnifyPair> eq, List<Set<Set<UnifyPair>>> oderConstraints, IFiniteClosure fc, boolean parallel, int rekTiefe, Boolean finalresult) {
|
||||||
//Aufruf von computeCartesianRecursive ENDE
|
//Aufruf von computeCartesianRecursive ENDE
|
||||||
|
|
||||||
//keine Ahnung woher das kommt
|
//keine Ahnung woher das kommt
|
||||||
@ -729,15 +483,17 @@ public class TypeUnifyTask extends RecursiveTask<Set<Set<UnifyPair>>> {
|
|||||||
// System.err.println("log-File nicht vorhanden");
|
// System.err.println("log-File nicht vorhanden");
|
||||||
//}
|
//}
|
||||||
eqPrimePrimeSet.add(eqPrime);
|
eqPrimePrimeSet.add(eqPrime);
|
||||||
urm.notify(eqPrimePrimeSet);
|
if (finalresult) {
|
||||||
|
urm.notify(eqPrimePrimeSet);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if(eqPrimePrime.isPresent()) {
|
else if(eqPrimePrime.isPresent()) {
|
||||||
Set<Set<UnifyPair>> unifyres = unifyres1 = unify(eqPrimePrime.get(), newOderConstraints, fc, parallel, rekTiefe);
|
Set<Set<UnifyPair>> unifyres = unifyres1 = unify(eqPrimePrime.get(), newOderConstraints, fc, parallel, rekTiefe, finalresult);
|
||||||
|
|
||||||
eqPrimePrimeSet.addAll(unifyres);
|
eqPrimePrimeSet.addAll(unifyres);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
Set<Set<UnifyPair>> unifyres = unifyres2 = unify(eqPrime, newOderConstraints, fc, parallel, rekTiefe);
|
Set<Set<UnifyPair>> unifyres = unifyres2 = unify(eqPrime, newOderConstraints, fc, parallel, rekTiefe, finalresult);
|
||||||
|
|
||||||
|
|
||||||
eqPrimePrimeSet.addAll(unifyres);
|
eqPrimePrimeSet.addAll(unifyres);
|
||||||
@ -769,7 +525,7 @@ public class TypeUnifyTask extends RecursiveTask<Set<Set<UnifyPair>>> {
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
Set<Set<UnifyPair>> computeCartesianRecursive(Set<Set<UnifyPair>> fstElems, ArrayList<Set<Set<UnifyPair>>> topLevelSets, Set<UnifyPair> eq, List<Set<Set<UnifyPair>>> oderConstraints, IFiniteClosure fc, boolean parallel, int rekTiefe, Set<Set<UnifyPair>> collectErr) {
|
Set<Set<UnifyPair>> computeCartesianRecursive(Set<Set<UnifyPair>> fstElems, ArrayList<Set<Set<UnifyPair>>> topLevelSets, Set<UnifyPair> eq, List<Set<Set<UnifyPair>>> oderConstraints, IFiniteClosure fc, boolean parallel, int rekTiefe, Set<Set<UnifyPair>> collectErr, Boolean finalresult) {
|
||||||
//ArrayList<Set<Set<UnifyPair>>> remainingSets = new ArrayList<>(topLevelSets);
|
//ArrayList<Set<Set<UnifyPair>>> remainingSets = new ArrayList<>(topLevelSets);
|
||||||
fstElems.addAll(topLevelSets.stream()
|
fstElems.addAll(topLevelSets.stream()
|
||||||
.filter(x -> x.size()==1)
|
.filter(x -> x.size()==1)
|
||||||
@ -779,7 +535,7 @@ public class TypeUnifyTask extends RecursiveTask<Set<Set<UnifyPair>>> {
|
|||||||
.filter(x -> x.size()>1)
|
.filter(x -> x.size()>1)
|
||||||
.collect(Collectors.toCollection(ArrayList::new));
|
.collect(Collectors.toCollection(ArrayList::new));
|
||||||
if (remainingSets.isEmpty()) {//Alle Elemente sind 1-elementig
|
if (remainingSets.isEmpty()) {//Alle Elemente sind 1-elementig
|
||||||
Set<Set<UnifyPair>> result = unify2(fstElems, eq, oderConstraints, fc, parallel, rekTiefe);
|
Set<Set<UnifyPair>> result = unify2(fstElems, eq, oderConstraints, fc, parallel, rekTiefe, finalresult);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
Set<Set<UnifyPair>> nextSet = remainingSets.remove(0);
|
Set<Set<UnifyPair>> nextSet = remainingSets.remove(0);
|
||||||
@ -1128,7 +884,7 @@ public class TypeUnifyTask extends RecursiveTask<Set<Set<UnifyPair>>> {
|
|||||||
} else {
|
} else {
|
||||||
//parallel = false; //Wenn MaxNoOfThreads erreicht ist, sequentiell weiterarbeiten
|
//parallel = false; //Wenn MaxNoOfThreads erreicht ist, sequentiell weiterarbeiten
|
||||||
elems.add(a); //PL 2019-01-16 muss das wirklich hin steht schon in Zeile 859 ja braucht man siehe Zeile 859
|
elems.add(a); //PL 2019-01-16 muss das wirklich hin steht schon in Zeile 859 ja braucht man siehe Zeile 859
|
||||||
res = unify2(elems, eq, oderConstraints, fc, parallel, rekTiefe);
|
res = unify2(elems, eq, oderConstraints, fc, parallel, rekTiefe, finalresult);
|
||||||
}}}
|
}}}
|
||||||
if (!isUndefinedPairSetSet(res) && isUndefinedPairSetSet(result)) {
|
if (!isUndefinedPairSetSet(res) && isUndefinedPairSetSet(result)) {
|
||||||
//wenn korrektes Ergebnis gefunden alle Fehlerfaelle loeschen
|
//wenn korrektes Ergebnis gefunden alle Fehlerfaelle loeschen
|
||||||
@ -1164,6 +920,7 @@ public class TypeUnifyTask extends RecursiveTask<Set<Set<UnifyPair>>> {
|
|||||||
//Alle Variablen bestimmen die nicht hinzugefügt wurden in a_last
|
//Alle Variablen bestimmen die nicht hinzugefügt wurden in a_last
|
||||||
//System.out.println(a_last);
|
//System.out.println(a_last);
|
||||||
a_last.forEach(x -> {writeLog("a_last_elem:" + x + " basepair: " + x.getBasePair());});
|
a_last.forEach(x -> {writeLog("a_last_elem:" + x + " basepair: " + x.getBasePair());});
|
||||||
|
try {//PL eingefuegt 2019-03-06 da bei map mmer wieder Nullpointer kamen
|
||||||
List<PlaceholderType> varsLast_a =
|
List<PlaceholderType> varsLast_a =
|
||||||
a_last.stream().filter(x -> ((x.getLhsType().getName().equals(x.getBasePair().getLhsType().getName())
|
a_last.stream().filter(x -> ((x.getLhsType().getName().equals(x.getBasePair().getLhsType().getName())
|
||||||
&& (x.getLhsType() instanceof PlaceholderType) && (x.getBasePair().getLhsType() instanceof PlaceholderType))
|
&& (x.getLhsType() instanceof PlaceholderType) && (x.getBasePair().getLhsType() instanceof PlaceholderType))
|
||||||
@ -1210,6 +967,10 @@ public class TypeUnifyTask extends RecursiveTask<Set<Set<UnifyPair>>> {
|
|||||||
writeLog("RES var=1 ADD:" + result.toString() + " " + res.toString());
|
writeLog("RES var=1 ADD:" + result.toString() + " " + res.toString());
|
||||||
result.addAll(res);
|
result.addAll(res);
|
||||||
}}}
|
}}}
|
||||||
|
}
|
||||||
|
catch (NullPointerException e) {
|
||||||
|
writeLog("NullPointerException: " + a_last.toString());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
//alle Fehlerfaelle und alle korrekten Ergebnis jeweils adden
|
//alle Fehlerfaelle und alle korrekten Ergebnis jeweils adden
|
||||||
@ -1845,7 +1606,7 @@ public class TypeUnifyTask extends RecursiveTask<Set<Set<UnifyPair>>> {
|
|||||||
Set<UnifyPair> unitedSubst = new HashSet<>(type.getSubstitution());
|
Set<UnifyPair> unitedSubst = new HashSet<>(type.getSubstitution());
|
||||||
unitedSubst.addAll(sameEq.getSubstitution());
|
unitedSubst.addAll(sameEq.getSubstitution());
|
||||||
localEq.add(new UnifyPair(type.getRhsType(), sameEq.getRhsType(), sameEq.getPairOp(), unitedSubst, null));
|
localEq.add(new UnifyPair(type.getRhsType(), sameEq.getRhsType(), sameEq.getPairOp(), unitedSubst, null));
|
||||||
Set<Set<UnifyPair>> localRes = unify(localEq, new ArrayList<>(), fc, parallel, 0);
|
Set<Set<UnifyPair>> localRes = unify(localEq, new ArrayList<>(), fc, false, 0, false);
|
||||||
Boolean localCorr = !isUndefinedPairSetSet(localRes);
|
Boolean localCorr = !isUndefinedPairSetSet(localRes);
|
||||||
if (!localCorr) {
|
if (!localCorr) {
|
||||||
collectErr.addAll(localRes);
|
collectErr.addAll(localRes);
|
||||||
@ -1865,7 +1626,7 @@ public class TypeUnifyTask extends RecursiveTask<Set<Set<UnifyPair>>> {
|
|||||||
Set<UnifyPair> unitedSubst = new HashSet<>(type.getSubstitution());
|
Set<UnifyPair> unitedSubst = new HashSet<>(type.getSubstitution());
|
||||||
unitedSubst.addAll(sameEq.getSubstitution());
|
unitedSubst.addAll(sameEq.getSubstitution());
|
||||||
localEq.add(new UnifyPair(sameEq.getLhsType(), type.getRhsType(), sameEq.getPairOp(), unitedSubst, null));
|
localEq.add(new UnifyPair(sameEq.getLhsType(), type.getRhsType(), sameEq.getPairOp(), unitedSubst, null));
|
||||||
Set<Set<UnifyPair>> localRes = unify(localEq, new ArrayList<>(), fc, parallel, 0);
|
Set<Set<UnifyPair>> localRes = unify(localEq, new ArrayList<>(), fc, false, 0, false);
|
||||||
Boolean localCorr = !isUndefinedPairSetSet(localRes);
|
Boolean localCorr = !isUndefinedPairSetSet(localRes);
|
||||||
if (!localCorr) {
|
if (!localCorr) {
|
||||||
collectErr.addAll(localRes);
|
collectErr.addAll(localRes);
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
package de.dhbwstuttgart.typeinference.unify.model;
|
package de.dhbwstuttgart.typeinference.unify.model;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
@ -31,14 +32,25 @@ public class OrderingUnifyPair extends Ordering<Set<UnifyPair>> {
|
|||||||
* in dem compare(Theta, Theta') aufgerufen wird.
|
* in dem compare(Theta, Theta') aufgerufen wird.
|
||||||
*/
|
*/
|
||||||
public int compareEq (UnifyPair left, UnifyPair right) {
|
public int compareEq (UnifyPair left, UnifyPair right) {
|
||||||
|
try {
|
||||||
//if (left.getRhsType() instanceof WildcardType || right.getRhsType() instanceof WildcardType) {//PL 2019-01-12 ausgetauscht
|
//if (left.getRhsType() instanceof WildcardType || right.getRhsType() instanceof WildcardType) {//PL 2019-01-12 ausgetauscht
|
||||||
if (((PlaceholderType)left.getLhsType()).isInnerType() && ((PlaceholderType)right.getLhsType()).isInnerType()) {
|
if (((PlaceholderType)left.getLhsType()).isInnerType() && ((PlaceholderType)right.getLhsType()).isInnerType()) {
|
||||||
return fc.compare(left.getRhsType(), right.getRhsType(), PairOperator.SMALLERDOTWC);
|
return fc.compare(left.getRhsType(), right.getRhsType(), PairOperator.SMALLERDOTWC);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return fc.compare(left.getRhsType(), right.getRhsType(), PairOperator.SMALLERDOT);
|
return fc.compare(left.getRhsType(), right.getRhsType(), PairOperator.SMALLERDOT);
|
||||||
|
}}
|
||||||
|
catch (ClassCastException e) {
|
||||||
|
try {
|
||||||
|
((FiniteClosure)fc).logFile.write("ClassCastException: " + left.toString() +"\n\n");
|
||||||
|
((FiniteClosure)fc).logFile.flush();
|
||||||
|
}
|
||||||
|
catch (IOException ie) {
|
||||||
|
}
|
||||||
|
return -99;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
public int compareEq (UnifyPair left, UnifyPair right) {
|
public int compareEq (UnifyPair left, UnifyPair right) {
|
||||||
if (left == null || right == null)
|
if (left == null || right == null)
|
||||||
|
@ -177,6 +177,16 @@ public class UnifyPair {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void disableCondWildcards() {
|
||||||
|
if (lhs instanceof PlaceholderType && rhs instanceof PlaceholderType
|
||||||
|
&& (!((PlaceholderType)lhs).isWildcardable() || !((PlaceholderType)rhs).isWildcardable()))
|
||||||
|
{
|
||||||
|
((PlaceholderType)lhs).disableWildcardtable();
|
||||||
|
((PlaceholderType)rhs).disableWildcardtable();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
public Boolean wrongWildcard() {
|
public Boolean wrongWildcard() {
|
||||||
return lhs.wrongWildcard() || rhs.wrongWildcard();
|
return lhs.wrongWildcard() || rhs.wrongWildcard();
|
||||||
}
|
}
|
||||||
@ -219,10 +229,12 @@ public class UnifyPair {
|
|||||||
public String toString() {
|
public String toString() {
|
||||||
String ret = "";
|
String ret = "";
|
||||||
if (lhs instanceof PlaceholderType) {
|
if (lhs instanceof PlaceholderType) {
|
||||||
ret = new Integer(((PlaceholderType)lhs).getVariance()).toString() + " " + ((PlaceholderType)lhs).isInnerType();
|
ret = new Integer(((PlaceholderType)lhs).getVariance()).toString() + " " + ((PlaceholderType)lhs).isInnerType()
|
||||||
|
+ " " + ((PlaceholderType)lhs).isWildcardable();
|
||||||
}
|
}
|
||||||
if (rhs instanceof PlaceholderType) {
|
if (rhs instanceof PlaceholderType) {
|
||||||
ret = ret + ", " + new Integer(((PlaceholderType)rhs).getVariance()).toString() + " " + ((PlaceholderType)rhs).isInnerType();
|
ret = ret + ", " + new Integer(((PlaceholderType)rhs).getVariance()).toString() + " " + ((PlaceholderType)rhs).isInnerType()
|
||||||
|
+ " " + ((PlaceholderType)rhs).isWildcardable();
|
||||||
}
|
}
|
||||||
return "(" + lhs + " " + pairOp + " " + rhs + ", " + ret + ")"; //+ ", [" + getfBounded().toString()+ "])";
|
return "(" + lhs + " " + pairOp + " " + rhs + ", " + ret + ")"; //+ ", [" + getfBounded().toString()+ "])";
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user