adapted adaptRules

This commit is contained in:
Florian Steurer 2016-03-28 20:56:24 +02:00
parent 332dd57de3
commit 639ac8430c
3 changed files with 59 additions and 76 deletions

View File

@ -53,6 +53,8 @@ public interface IFiniteClosure {
public Set<Type> grArg(FunNType type); public Set<Type> grArg(FunNType type);
public Set<Type> smArg(FunNType type); public Set<Type> smArg(FunNType type);
public Optional<Type> findGenericParent(String typeName); public Optional<Type> getLeftHandedType(Type t);
public Set<Type> getAncestors(Type t);
public Set<Type> getAllTypesByName(String typeName); public Set<Type> getAllTypesByName(String typeName);
} }

View File

@ -4,6 +4,7 @@ import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.HashMap; import java.util.HashMap;
import java.util.HashSet; import java.util.HashSet;
import java.util.Map;
import java.util.Optional; import java.util.Optional;
import java.util.Set; import java.util.Set;
import java.util.stream.Collectors; import java.util.stream.Collectors;
@ -271,8 +272,6 @@ public class FiniteClosure implements IFiniteClosure {
Set<Type> result = new HashSet<Type>(); Set<Type> result = new HashSet<Type>();
result.add(type); result.add(type);
// smaller(type).forEach(x -> result.add(new ExtendsType(x))); TODO inkorrekt? daher erstmal raus
return result; return result;
} }
@ -318,8 +317,6 @@ public class FiniteClosure implements IFiniteClosure {
public Set<Type> smArg(PlaceholderType type) { public Set<Type> smArg(PlaceholderType type) {
HashSet<Type> result = new HashSet<>(); HashSet<Type> result = new HashSet<>();
result.add(type); result.add(type);
//result.add(new SuperType(type)); TODO inkorrekt, daher erstmal raus
//result.add(new ExtendsType(type));
return result; return result;
} }
@ -337,25 +334,6 @@ public class FiniteClosure implements IFiniteClosure {
return false; return false;
} }
@Override
public Optional<Type> findGenericParent(String type) {
Type genericType = null;
for(MPair pair : pairs) {
Type lhs = pair.getLhsType();
if(lhs.getName().equals(type)) {
genericType = lhs;
break;
}
}
if(genericType == null)
return Optional.empty();
// TODO reduce reglen überarbeiten, es kann mehrere Typen D geben die eine bedingung
// erfüllen, diese methode ausimplementieren
return Optional.empty();
}
@Override @Override
public Set<Type> getAllTypesByName(String typeName) { public Set<Type> getAllTypesByName(String typeName) {
@ -364,6 +342,25 @@ public class FiniteClosure implements IFiniteClosure {
return strInheritanceGraph.get(typeName).stream().map(x -> x.getContent()).collect(Collectors.toCollection(HashSet::new)); return strInheritanceGraph.get(typeName).stream().map(x -> x.getContent()).collect(Collectors.toCollection(HashSet::new));
} }
@Override
public Optional<Type> getLeftHandedType(Type t) {
if(!strInheritanceGraph.containsKey(t.getName()))
return Optional.empty();
for(MPair pair : pairs)
if(pair.getLhsType().getName().equals(t.getName()))
return Optional.of(pair.getLhsType());
return Optional.empty();
}
@Override
public Set<Type> getAncestors(Type t) {
if(!inheritanceGraph.containsKey(t))
return new HashSet<>();
return inheritanceGraph.get(t).getContentOfPredecessors();
}
protected void permuteParams(ArrayList<Set<Type>> candidates, int idx, Set<TypeParams> result, Type[] current) { protected void permuteParams(ArrayList<Set<Type>> candidates, int idx, Set<TypeParams> result, Type[] current) {
if(candidates.size() == idx) { if(candidates.size() == idx) {
result.add(new TypeParams(Arrays.copyOf(current, current.length))); result.add(new TypeParams(Arrays.copyOf(current, current.length)));

View File

@ -85,26 +85,26 @@ public class RuleSet implements IRuleSet{
if(pair.getPairOp() != PairOperator.SMALLERDOTWC) if(pair.getPairOp() != PairOperator.SMALLERDOTWC)
return Optional.empty(); return Optional.empty();
Type lhsType = pair.getLhsType(); Type x = pair.getLhsType();
if(!(lhsType instanceof SimpleType) && !(lhsType instanceof ExtendsType)) if(!(x instanceof SimpleType) && !(x instanceof ExtendsType))
return Optional.empty(); return Optional.empty();
Type rhsType = pair.getRhsType(); Type extY = pair.getRhsType();
if(!(rhsType instanceof ExtendsType)) if(!(extY instanceof ExtendsType))
return Optional.empty(); return Optional.empty();
if(lhsType.getTypeParams().empty() || rhsType.getTypeParams().size() != lhsType.getTypeParams().size()) if(x.getTypeParams().empty() || extY.getTypeParams().size() != x.getTypeParams().size())
return Optional.empty(); return Optional.empty();
int[] pi = pi(lhsType, rhsType); int[] pi = pi(x, extY);
if(pi.length == 0) if(pi.length == 0)
return Optional.empty(); return Optional.empty();
TypeParams rhsTypeParams = rhsType.getTypeParams(); TypeParams rhsTypeParams = extY.getTypeParams();
TypeParams lhsTypeParams = lhsType.getTypeParams(); TypeParams lhsTypeParams = x.getTypeParams();
Set<MPair> result = new HashSet<>(); Set<MPair> result = new HashSet<>();
for(int rhsIdx = 0; rhsIdx < rhsTypeParams.size(); rhsIdx++) for(int rhsIdx = 0; rhsIdx < rhsTypeParams.size(); rhsIdx++)
@ -160,7 +160,7 @@ public class RuleSet implements IRuleSet{
if(!rhsType.getName().equals(lhsType.getName())) if(!rhsType.getName().equals(lhsType.getName()))
return Optional.empty(); return Optional.empty();
if(rhsType instanceof PlaceholderType || rhsType.getTypeParams().empty()) if(rhsType instanceof PlaceholderType || lhsType instanceof PlaceholderType || rhsType.getTypeParams().empty())
return Optional.empty(); return Optional.empty();
if(rhsType.getTypeParams().size() != lhsType.getTypeParams().size()) if(rhsType.getTypeParams().size() != lhsType.getTypeParams().size())
@ -328,16 +328,16 @@ public class RuleSet implements IRuleSet{
if(typeD.getName().equals(typeDs.getName())) if(typeD.getName().equals(typeDs.getName()))
return Optional.empty(); return Optional.empty();
Optional<Type> opt = finiteClosure.findGenericParent(typeD.getName()); Optional<Type> opt = finiteClosure.getLeftHandedType(typeD);
if(!opt.isPresent()) if(!opt.isPresent())
return Optional.empty(); return Optional.empty();
// The generic Version of Type D (D<a1, a2, a3, ... >) // The generic Version of Type D (D<a1, a2, a3, ... >)
Type typeDgen = opt.get(); Type typeDgen = opt.get();
// Actually greater+ because the types are ensured to have different names // Actually greater+ because the types are ensured to have different names
Set<Type> greater = finiteClosure.greater(typeDgen); Set<Type> greater = finiteClosure.getAncestors(typeDgen);
opt = greater.stream().filter(x -> x.getName().equals(typeDs.getName())).findAny(); opt = greater.stream().filter(x -> x.getName().equals(typeDs.getName())).findAny();
if(!opt.isPresent()) if(!opt.isPresent())
@ -350,7 +350,7 @@ public class RuleSet implements IRuleSet{
Unifier unif = new Unifier((PlaceholderType) typeDgenParams.get(0), typeDParams.get(0)); Unifier unif = new Unifier((PlaceholderType) typeDgenParams.get(0), typeDParams.get(0));
for(int i = 1; i < typeDParams.size(); i++) for(int i = 1; i < typeDParams.size(); i++)
unif.andThen(new Unifier((PlaceholderType) typeDgenParams.get(i), typeDParams.get(i))); unif.Add((PlaceholderType) typeDgenParams.get(i), typeDParams.get(i));
return Optional.of(new MPair(unif.apply(newLhs), typeDs, PairOperator.SMALLERDOT)); return Optional.of(new MPair(unif.apply(newLhs), typeDs, PairOperator.SMALLERDOT));
} }
@ -373,9 +373,9 @@ public class RuleSet implements IRuleSet{
Type typeDgen; Type typeDgen;
if(typeD instanceof SimpleType) if(typeD instanceof SimpleType)
typeDgen = finiteClosure.findGenericParent(typeD.getName()).orElse(null); typeDgen = finiteClosure.getLeftHandedType(typeD).orElse(null);
else { else {
Optional<Type> opt = finiteClosure.findGenericParent(((ExtendsType) typeD).getExtendedType().getName()); Optional<Type> opt = finiteClosure.getLeftHandedType(((ExtendsType) typeD).getExtendedType());
typeDgen = opt.isPresent() ? new ExtendsType(opt.get()) : null; typeDgen = opt.isPresent() ? new ExtendsType(opt.get()) : null;
} }
@ -396,7 +396,7 @@ public class RuleSet implements IRuleSet{
Unifier unif = new Unifier((PlaceholderType) typeDgenParams.get(0), typeDParams.get(0)); Unifier unif = new Unifier((PlaceholderType) typeDgenParams.get(0), typeDParams.get(0));
for(int i = 1; i < typeDParams.size(); i++) for(int i = 1; i < typeDParams.size(); i++)
unif.andThen(new Unifier((PlaceholderType) typeDgenParams.get(i), typeDParams.get(i))); unif.Add((PlaceholderType) typeDgenParams.get(i), typeDParams.get(i));
return Optional.of(new MPair(unif.apply(newLhs), typeExtDs, PairOperator.SMALLERDOTWC)); return Optional.of(new MPair(unif.apply(newLhs), typeExtDs, PairOperator.SMALLERDOTWC));
} }
@ -418,7 +418,7 @@ public class RuleSet implements IRuleSet{
return Optional.empty(); return Optional.empty();
Optional<Type> opt = finiteClosure.findGenericParent(((SuperType) typeSupD).getSuperedType().getName()); Optional<Type> opt = finiteClosure.getLeftHandedType(((SuperType) typeSupD).getSuperedType());
if(!opt.isPresent()) if(!opt.isPresent())
return Optional.empty(); return Optional.empty();
@ -448,7 +448,7 @@ public class RuleSet implements IRuleSet{
Unifier unif = new Unifier((PlaceholderType) typeSupDsgenParams.get(0), typeDParams.get(0)); Unifier unif = new Unifier((PlaceholderType) typeSupDsgenParams.get(0), typeDParams.get(0));
for(int i = 1; i < typeDParams.size(); i++) for(int i = 1; i < typeDParams.size(); i++)
unif.andThen(new Unifier((PlaceholderType) typeSupDsgenParams.get(i), typeDParams.get(i))); unif.Add((PlaceholderType) typeSupDsgenParams.get(i), typeDParams.get(i));
return Optional.of(new MPair(unif.apply(newLhs), newRhs, PairOperator.SMALLERDOTWC)); return Optional.of(new MPair(unif.apply(newLhs), newRhs, PairOperator.SMALLERDOTWC));
} }
@ -460,43 +460,27 @@ public class RuleSet implements IRuleSet{
* @return An array containing the values of pi for every type argument of C or an empty array if the search failed. * @return An array containing the values of pi for every type argument of C or an empty array if the search failed.
*/ */
private int[] pi(Type C, Type D) { private int[] pi(Type C, Type D) {
Type cFromFc = null; String simpleTypeDName = D.getName();
if(C instanceof SimpleType) if(D instanceof ExtendsType)
cFromFc = finiteClosure.findGenericParent(C.getName()).orElse(null); simpleTypeDName = ((ExtendsType) D).getExtendedType().getName();
else if(C instanceof ExtendsType) { else if(D instanceof SuperType)
Optional<Type> opt = finiteClosure.findGenericParent(((ExtendsType) C).getExtendedType().getName()); simpleTypeDName = ((SuperType) D).getSuperedType().getName();
if(opt.isPresent()) cFromFc = new ExtendsType(opt.get());
}
else if(C instanceof SuperType) {
Optional<Type> opt = finiteClosure.findGenericParent(((SuperType) C).getSuperedType().getName());
if(opt.isPresent()) cFromFc = new SuperType(opt.get());
}
if(cFromFc == null) String simpleTypeCName = C.getName();
if(C instanceof ExtendsType)
simpleTypeCName = ((ExtendsType) C).getExtendedType().getName();
if(C instanceof SuperType)
simpleTypeCName = ((SuperType) C).getSuperedType().getName();
Optional<Type[]> typesFromFc = Optional.empty(); //TODO reduce regeln
//finiteClosure.findCandD(simpleTypeCName, simpleTypeDName);
if(typesFromFc == null)
return new int[0]; return new int[0];
Optional<Type> opt = Optional.empty(); Type cFromFc = typesFromFc.get()[0];
if(D instanceof ExtendsType) { Type dFromFc = typesFromFc.get()[1];
SimpleType dSType = (SimpleType) ((ExtendsType) D).getExtendedType();
opt = finiteClosure.grArg(cFromFc).stream()
.filter(x -> x instanceof ExtendsType)
.filter(x -> ((ExtendsType) x).getExtendedType().getName().equals(dSType.getName())).findAny();
}
else if(D instanceof SuperType) {
SimpleType dSType = (SimpleType) ((SuperType) D).getSuperedType();
opt = finiteClosure.grArg(cFromFc).stream()
.filter(x -> x instanceof SuperType)
.filter(x -> ((SuperType) x).getSuperedType().getName().equals(dSType.getName())).findAny();
}
else if (D instanceof SimpleType)
opt = finiteClosure.greater(cFromFc).stream()
.filter(x -> x.getName().equals(D.getName())).findAny();
if(!opt.isPresent())
return new int[0];
Type dFromFc = opt.get();
Assert.assertEquals(cFromFc.getTypeParams().size(), dFromFc.getTypeParams().size()); Assert.assertEquals(cFromFc.getTypeParams().size(), dFromFc.getTypeParams().size());
Assert.assertTrue(dFromFc.getTypeParams().size() > 0); Assert.assertTrue(dFromFc.getTypeParams().size() > 0);