Bug 16: wieder zurueckgenommen, Zusammenhangskomponenten wieder raus

This commit is contained in:
Martin Plümicke 2015-03-31 16:45:22 +02:00
parent dd7d0edbfe
commit a2997fdd6b

View File

@ -7,9 +7,7 @@ import java.util.Enumeration;
import java.util.Hashtable; import java.util.Hashtable;
import java.util.Iterator; import java.util.Iterator;
import java.util.Vector; import java.util.Vector;
import java.util.TreeSet;
import java.util.stream.Stream; import java.util.stream.Stream;
import java.util.function.BiFunction;
import de.dhbwstuttgart.logger.Logger; import de.dhbwstuttgart.logger.Logger;
import de.dhbwstuttgart.logger.Section; import de.dhbwstuttgart.logger.Section;
@ -154,8 +152,6 @@ public class Unify
//TPH <. ? super Ty entspricht TPH <. Ty //TPH <. ? super Ty entspricht TPH <. Ty
if (p.TA2 instanceof SuperWildcardType) { if (p.TA2 instanceof SuperWildcardType) {
p.TA2 = ((SuperWildcardType)p.TA2).get_SuperType(); p.TA2 = ((SuperWildcardType)p.TA2).get_SuperType();
//HIER GIBT ES EIN PROBLEM, WENN get_SuperType ein TPH LIEFERT PL 15-03-12 //HIER GIBT ES EIN PROBLEM, WENN get_SuperType ein TPH LIEFERT PL 15-03-12
//Dann ist THP <. TPH in Eq2 anstatt in Eq1 //Dann ist THP <. TPH in Eq2 anstatt in Eq1
//Muesste mit folgendem if gelöst sein. PL 15-03-17 //Muesste mit folgendem if gelöst sein. PL 15-03-17
@ -165,6 +161,8 @@ public class Unify
continue; continue;
} }
} }
if(p.OperatorEqual()) if(p.OperatorEqual())
{ {
//Alle Paare die bereits durch sub_unify die richtige Struktur haben einfach durchleiten. //Alle Paare die bereits durch sub_unify die richtige Struktur haben einfach durchleiten.
@ -621,87 +619,10 @@ public class Unify
} }
} }
} }
///////////////////////////////////////////////////////////////////////////////////
//EINSCHUB AUFTEILEN ZUSAMMENHANGSKOMPONENTEN PL 15-03-19 IN SCHRITTEN A. - C.
//BRINGT nichts OverloadingInMethod2
//////////////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//A. Zusammenhangskomponenten bilden
BiFunction<Vector<TypePlaceholder>,Vector<TypePlaceholder>,Vector<TypePlaceholder>> addAllSet =
(v1, v2) -> { for (TypePlaceholder v2elem : v2) { if (!v1.contains(v2elem)) v1.addElement(v2elem); }
return v1;
};
//A.1 Eq1 als Vec<Vec<Eq1>> zu cartProduktSets hinzufuegen
Vector<Vector<Vector<Pair>>> VecVecEq1 = Eq1.stream().map(x -> { Vector<Pair> PVec = new Vector<>();
PVec.addElement(x);
Vector<Vector<Pair>> PVecVec = new Vector<>();
PVecVec.add(PVec);
return PVecVec;})
.collect(Vector::new, Vector::add, Vector::addAll);
cartProduktSets.addAll(VecVecEq1);
//A.2 Schritt 1: Alle Variablen in den Paaren von Elementen einsammeln
//A.2 Schritt 1: Alle Variablen in den Paaren von Elementen einsammeln
Stream<Vector<Vector<TypePlaceholder>>> constraintsclonevars2 =
cartProduktSets.stream()
.map(vecvec_p -> vecvec_p.stream().map(vec_p -> vec_p.stream()
.reduce(new Vector<TypePlaceholder>(), (vTPH, p) -> { addAllSet.apply(vTPH,p.TA1.getInvolvedTypePlaceholder());
addAllSet.apply(vTPH, p.TA2.getInvolvedTypePlaceholder());
return vTPH;},
(x,y) -> {x.addAll(y); return x;})
).collect(Vector::new, Vector::add, Vector::addAll)
);//.collect(Vector::new, Vector::add, Vector::addAll);
Vector<Vector<Vector<TypePlaceholder>>> constraintsclonevars3 = constraintsclonevars2.collect(Vector::new, Vector::add, Vector::addAll);
Vector<Vector<TypePlaceholder>> constraintsclonevars4 =
constraintsclonevars3.stream().map(vars -> vars.stream().reduce(new Vector<TypePlaceholder>(),(vTPH1, vTPH2) -> { addAllSet.apply(vTPH1,vTPH2); return vTPH1;}))
.collect(Vector::new, Vector::add, Vector::addAll);
Vector<Vector<TypePlaceholder>> constraintsclonevars =
cartProduktSets.stream()
.map(vecvec_p -> vecvec_p.stream().map(vec_p -> vec_p.stream()
.reduce(new Vector<TypePlaceholder>(), (vTPH, p) -> { vTPH.addAll(p.TA1.getInvolvedTypePlaceholder());
vTPH.addAll(p.TA2.getInvolvedTypePlaceholder());
return vTPH;},
(x,y) -> {x.addAll(y); return x;})
).reduce(new Vector<TypePlaceholder>(), (vTPH1, vTPH2) -> { vTPH1.addAll(vTPH2); return vTPH1;})
//HIER STIMMT ES NICHT
).collect(Vector::new, Vector::add, Vector::addAll);
//A.3 Schritt 2: Schnittmengen jedes Elements mit jedem Elememt von vars bilden und dann index zusammenfassen
//in indexset sind dann die Mengen von Indizes enthalten, die gemeisam unifiziert wreden müssen
Vector<Vector<Integer>> indexeset = new Vector<>();
if (constraintsclonevars4 != null && constraintsclonevars4.size()>0) {
indexeset = Unify.schnitt(constraintsclonevars4);
}
//A.4 Schritt 3: Umwandlung der Indizes in die zugehoerigen Elemente
// In streamconstraintsclone sind die Mengen von Paar enthalten die unifiziert werden muessen
Stream<Vector<Vector<Vector<Pair>>>> streamconstraintsclone = indexeset.stream().map(x -> x.stream()
.map(i -> cartProduktSets.elementAt(i))//);
.collect(Vector::new, Vector::add, Vector::addAll));
Vector<Vector<Vector<Vector<Pair>>>> vecconstraintsclone = streamconstraintsclone.collect(Vector::new, Vector::add, Vector::addAll);
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//B. Schitte 4. bis 7 der Unifikation auf den Zusammenhangskomponenten getrennt ausfuehren
//Schritt 4, Teil 2: Kartesisches Produkt bilden. //Schritt 4, Teil 2: Kartesisches Produkt bilden.
//Hier wird aus den in Schritt 4, Teil 1 erzeugten Vektoren das Kartesische Produkt gebilden. //Hier wird aus den in Schritt 4, Teil 1 erzeugten Vektoren das Kartesische Produkt gebilden.
Vector<Pair> helpvp; Vector<Pair> helpvp;
Vector<Vector<Pair>> bigCartProductErg = new Vector<Vector<Pair>>(); Vector<Vector<Pair>> bigCartProductErg = new Vector<Vector<Pair>>();
//auskommentiert, da bereits in Schritt A vor der Zusammenhangskomponenetenbildung hinzugefuegt PL 15-03-19
bigCartProductErg.addElement(copyVectorPair(Eq1)); bigCartProductErg.addElement(copyVectorPair(Eq1));
for (Vector<Vector<Pair>> vecvecpair : cartProduktSets) for (Vector<Vector<Pair>> vecvecpair : cartProduktSets)
@ -865,6 +786,7 @@ public class Unify
return ret; return ret;
} }
/** /**
* Diese Methode wird verwendet, um Zuordnungen z.B. TPH a = Integer * Diese Methode wird verwendet, um Zuordnungen z.B. TPH a = Integer
* aus der Ergebnismenge zu entfernen, wenn im Typ in den die eingesetzt werden sollen kein TPH a vorhanden ist. * aus der Ergebnismenge zu entfernen, wenn im Typ in den die eingesetzt werden sollen kein TPH a vorhanden ist.