diff options
author | ArenBabikian <aren.babikian@mail.mcgill.ca> | 2019-02-01 16:03:30 -0500 |
---|---|---|
committer | ArenBabikian <aren.babikian@mail.mcgill.ca> | 2020-06-07 19:06:28 -0400 |
commit | 57e614aabedc176ba9965d0ca5e6daa23c5f4758 (patch) | |
tree | 16806454dff463419af99b14f6abfab3d1fa5291 /Tests/ca.mcgill.ecse.dslreasoner.vampire.test/src/ca/mcgill/ecse/dslreasoner/vampire/test | |
parent | FAM MM transformation works (diff) | |
download | VIATRA-Generator-57e614aabedc176ba9965d0ca5e6daa23c5f4758.tar.gz VIATRA-Generator-57e614aabedc176ba9965d0ca5e6daa23c5f4758.tar.zst VIATRA-Generator-57e614aabedc176ba9965d0ca5e6daa23c5f4758.zip |
Fix FAM Test. Begin Grammar Fix.
Diffstat (limited to 'Tests/ca.mcgill.ecse.dslreasoner.vampire.test/src/ca/mcgill/ecse/dslreasoner/vampire/test')
4 files changed, 18 insertions, 117 deletions
diff --git a/Tests/ca.mcgill.ecse.dslreasoner.vampire.test/src/ca/mcgill/ecse/dslreasoner/vampire/test/DslTest.xtend b/Tests/ca.mcgill.ecse.dslreasoner.vampire.test/src/ca/mcgill/ecse/dslreasoner/vampire/test/DslTest.xtend deleted file mode 100644 index a8b4dcfb..00000000 --- a/Tests/ca.mcgill.ecse.dslreasoner.vampire.test/src/ca/mcgill/ecse/dslreasoner/vampire/test/DslTest.xtend +++ /dev/null | |||
@@ -1,103 +0,0 @@ | |||
1 | package ca.mcgill.ecse.dslreasoner.vampire.test | ||
2 | |||
3 | import ca.mcgill.ecse.dslreasoner.vampire.reasoner.VampireSolver | ||
4 | import ca.mcgill.ecse.dslreasoner.vampire.reasoner.VampireSolverConfiguration | ||
5 | import functionalarchitecture.FunctionalarchitecturePackage | ||
6 | import hu.bme.mit.inf.dslreasoner.ecore2logic.Ecore2Logic | ||
7 | import hu.bme.mit.inf.dslreasoner.ecore2logic.Ecore2LogicConfiguration | ||
8 | import hu.bme.mit.inf.dslreasoner.ecore2logic.EcoreMetamodelDescriptor | ||
9 | import hu.bme.mit.inf.dslreasoner.logic.model.builder.LogicReasoner | ||
10 | import hu.bme.mit.inf.dslreasoner.logic.model.logicresult.LogicResult | ||
11 | import hu.bme.mit.inf.dslreasoner.logic2ecore.Logic2Ecore | ||
12 | import hu.bme.mit.inf.dslreasoner.viatra2logic.Viatra2Logic | ||
13 | import hu.bme.mit.inf.dslreasoner.viatrasolver.partialinterpretation2logic.InstanceModel2Logic | ||
14 | import hu.bme.mit.inf.dslreasoner.workspace.FileSystemWorkspace | ||
15 | import hu.bme.mit.inf.dslreasoner.workspace.ReasonerWorkspace | ||
16 | import java.util.List | ||
17 | import org.eclipse.emf.ecore.EAttribute | ||
18 | import org.eclipse.emf.ecore.EClass | ||
19 | import org.eclipse.emf.ecore.EEnum | ||
20 | import org.eclipse.emf.ecore.EEnumLiteral | ||
21 | import org.eclipse.emf.ecore.EObject | ||
22 | import org.eclipse.emf.ecore.EReference | ||
23 | import org.eclipse.emf.ecore.resource.Resource | ||
24 | import org.eclipse.emf.ecore.xmi.impl.XMIResourceFactoryImpl | ||
25 | |||
26 | class DslTest { | ||
27 | def static void main(String[] args) { | ||
28 | val inputs = new FileSystemWorkspace('''initialModels/''', "") | ||
29 | val workspace = new FileSystemWorkspace('''outputDslModels/''', "") | ||
30 | workspace.initAndClear | ||
31 | |||
32 | println("Input and output workspaces are created") | ||
33 | |||
34 | val metamodel = loadMetamodel() | ||
35 | val partialModel = loadPartialModel(inputs) | ||
36 | // val queries = loadQueries(metamodel) | ||
37 | |||
38 | println("DSL loaded") | ||
39 | |||
40 | val Ecore2Logic ecore2Logic = new Ecore2Logic | ||
41 | val Logic2Ecore logic2Ecore = new Logic2Ecore(ecore2Logic) | ||
42 | val Viatra2Logic viatra2Logic = new Viatra2Logic(ecore2Logic) | ||
43 | val InstanceModel2Logic instanceModel2Logic = new InstanceModel2Logic | ||
44 | |||
45 | val modelGenerationProblem = ecore2Logic.transformMetamodel(metamodel,new Ecore2LogicConfiguration()) | ||
46 | // val modelExtensionProblem = instanceModel2Logic.transform(modelGenerationProblem,partialModel) | ||
47 | // val validModelExtensionProblem = viatra2Logic.transformQueries(queries,modelGenerationProblem,new Viatra2LogicConfiguration) | ||
48 | |||
49 | val logicProblem = modelGenerationProblem.output | ||
50 | // val logicProblem = modelExtensionProblem.output | ||
51 | // val logicProblem = validModelExtensionProblem.output | ||
52 | |||
53 | |||
54 | println("Problem created") | ||
55 | |||
56 | var LogicResult solution | ||
57 | var LogicReasoner reasoner | ||
58 | //* | ||
59 | reasoner = new VampireSolver | ||
60 | val vampireConfig = new VampireSolverConfiguration => [ | ||
61 | //add configuration things, in config file first | ||
62 | it.writeToFile = false | ||
63 | ] | ||
64 | |||
65 | solution = reasoner.solve(logicProblem, vampireConfig, workspace) | ||
66 | |||
67 | println("Problem solved") | ||
68 | |||
69 | |||
70 | } | ||
71 | |||
72 | def private static loadMetamodel() { | ||
73 | //FAM | ||
74 | val pckg = FunctionalarchitecturePackage.eINSTANCE | ||
75 | val List<EClass> classes = pckg.EClassifiers.filter(EClass).toList | ||
76 | val List<EEnum> enums = pckg.EClassifiers.filter(EEnum).toList | ||
77 | val List<EEnumLiteral> literals = enums.map[getELiterals].flatten.toList | ||
78 | val List<EReference> references = classes.map[getEReferences].flatten.toList | ||
79 | val List<EAttribute> attributes = classes.map[getEAttributes].flatten.toList | ||
80 | return new EcoreMetamodelDescriptor(classes,#{},false,enums,literals,references,attributes) | ||
81 | } | ||
82 | |||
83 | def private static loadPartialModel(ReasonerWorkspace inputs) { | ||
84 | Resource.Factory.Registry.INSTANCE.getExtensionToFactoryMap().put("*", new XMIResourceFactoryImpl()); | ||
85 | inputs.readModel(EObject,"FunctionalArchitectureModel.xmi").eResource.allContents.toList | ||
86 | // inputs.readModel(EObject,"FAM.xmi").eResource.allContents.toList | ||
87 | } | ||
88 | |||
89 | // def private static loadQueries(EcoreMetamodelDescriptor metamodel) { | ||
90 | // val i = hu.bme.mit.inf.dslreasoner.domains.transima.fam.patterns.Pattern.instance | ||
91 | // val patterns = i.specifications.toList | ||
92 | // val wfPatterns = patterns.filter[it.allAnnotations.exists[it.name== "Constraint"]].toSet | ||
93 | // val derivedFeatures = new LinkedHashMap | ||
94 | // derivedFeatures.put(i.type,metamodel.attributes.filter[it.name == "type"].head) | ||
95 | // derivedFeatures.put(i.model,metamodel.references.filter[it.name == "model"].head) | ||
96 | // val res = new ViatraQuerySetDescriptor( | ||
97 | // patterns, | ||
98 | // wfPatterns, | ||
99 | // derivedFeatures | ||
100 | // ) | ||
101 | // return res | ||
102 | // } | ||
103 | } | ||
diff --git a/Tests/ca.mcgill.ecse.dslreasoner.vampire.test/src/ca/mcgill/ecse/dslreasoner/vampire/test/MedicalSystem.xtend b/Tests/ca.mcgill.ecse.dslreasoner.vampire.test/src/ca/mcgill/ecse/dslreasoner/vampire/test/MedicalSystem.xtend index ccc17617..15f9e1fe 100644 --- a/Tests/ca.mcgill.ecse.dslreasoner.vampire.test/src/ca/mcgill/ecse/dslreasoner/vampire/test/MedicalSystem.xtend +++ b/Tests/ca.mcgill.ecse.dslreasoner.vampire.test/src/ca/mcgill/ecse/dslreasoner/vampire/test/MedicalSystem.xtend | |||
@@ -22,11 +22,12 @@ import org.eclipse.emf.ecore.xmi.impl.XMIResourceFactoryImpl | |||
22 | class MedicalSystem { | 22 | class MedicalSystem { |
23 | def static void main(String[] args) { | 23 | def static void main(String[] args) { |
24 | init() | 24 | init() |
25 | val workspace = new FileSystemWorkspace('''outputModels/''',"") | 25 | val workspace = new FileSystemWorkspace('''output/MedicalSystem/''',"") |
26 | workspace.initAndClear | 26 | workspace.initAndClear |
27 | val root = load() | 27 | val root = load() |
28 | println("Problem Loaded") | 28 | println("Problem Loaded") |
29 | 29 | ||
30 | |||
30 | // val rs = new ResourceSetImpl | 31 | // val rs = new ResourceSetImpl |
31 | // val logRes = rs.createResource(URI.createFileURI("vampireMidel.tptp")) | 32 | // val logRes = rs.createResource(URI.createFileURI("vampireMidel.tptp")) |
32 | // | 33 | // |
@@ -40,7 +41,7 @@ class MedicalSystem { | |||
40 | reasoner = new VampireSolver | 41 | reasoner = new VampireSolver |
41 | val vampireConfig = new VampireSolverConfiguration => [ | 42 | val vampireConfig = new VampireSolverConfiguration => [ |
42 | //add configuration things, in config file first | 43 | //add configuration things, in config file first |
43 | it.writeToFile = false | 44 | it.writeToFile = true |
44 | ] | 45 | ] |
45 | 46 | ||
46 | solution = reasoner.solve(root, vampireConfig, workspace) | 47 | solution = reasoner.solve(root, vampireConfig, workspace) |
diff --git a/Tests/ca.mcgill.ecse.dslreasoner.vampire.test/src/ca/mcgill/ecse/dslreasoner/vampire/test/SimpleRun.xtend b/Tests/ca.mcgill.ecse.dslreasoner.vampire.test/src/ca/mcgill/ecse/dslreasoner/vampire/test/SimpleRun.xtend index 9d2235f0..f99f0a40 100644 --- a/Tests/ca.mcgill.ecse.dslreasoner.vampire.test/src/ca/mcgill/ecse/dslreasoner/vampire/test/SimpleRun.xtend +++ b/Tests/ca.mcgill.ecse.dslreasoner.vampire.test/src/ca/mcgill/ecse/dslreasoner/vampire/test/SimpleRun.xtend | |||
@@ -66,7 +66,7 @@ | |||
66 | // println("Problem created") | 66 | // println("Problem created") |
67 | // var LogicResult solution | 67 | // var LogicResult solution |
68 | // var LogicReasoner reasoner | 68 | // var LogicReasoner reasoner |
69 | // //* | 69 | // /* |
70 | // reasoner = new ViatraReasoner | 70 | // reasoner = new ViatraReasoner |
71 | // val viatraConfig = new ViatraReasonerConfiguration => [ | 71 | // val viatraConfig = new ViatraReasonerConfiguration => [ |
72 | // it.typeScopes.maxNewElements = 40 | 72 | // it.typeScopes.maxNewElements = 40 |
diff --git a/Tests/ca.mcgill.ecse.dslreasoner.vampire.test/src/ca/mcgill/ecse/dslreasoner/vampire/test/VampireTest.xtend b/Tests/ca.mcgill.ecse.dslreasoner.vampire.test/src/ca/mcgill/ecse/dslreasoner/vampire/test/VampireTest.xtend index 3d36bbf7..4fc81ad8 100644 --- a/Tests/ca.mcgill.ecse.dslreasoner.vampire.test/src/ca/mcgill/ecse/dslreasoner/vampire/test/VampireTest.xtend +++ b/Tests/ca.mcgill.ecse.dslreasoner.vampire.test/src/ca/mcgill/ecse/dslreasoner/vampire/test/VampireTest.xtend | |||
@@ -17,6 +17,7 @@ import org.eclipse.emf.common.util.URI | |||
17 | import org.eclipse.emf.ecore.resource.Resource | 17 | import org.eclipse.emf.ecore.resource.Resource |
18 | import org.eclipse.emf.ecore.resource.impl.ResourceSetImpl | 18 | import org.eclipse.emf.ecore.resource.impl.ResourceSetImpl |
19 | import org.eclipse.emf.ecore.xmi.impl.XMIResourceFactoryImpl | 19 | import org.eclipse.emf.ecore.xmi.impl.XMIResourceFactoryImpl |
20 | import java.io.File | ||
20 | 21 | ||
21 | class VampireTest { | 22 | class VampireTest { |
22 | 23 | ||
@@ -39,15 +40,11 @@ class VampireTest { | |||
39 | map.put("logicproblem", new XMIResourceFactoryImpl) | 40 | map.put("logicproblem", new XMIResourceFactoryImpl) |
40 | VampireLanguageStandaloneSetup.doSetup | 41 | VampireLanguageStandaloneSetup.doSetup |
41 | 42 | ||
42 | val workspace = new FileSystemWorkspace('''output/models/''',"") | 43 | val workspace = new FileSystemWorkspace('''output/VampireTest''',"") |
43 | workspace.initAndClear | 44 | workspace.initAndClear |
44 | 45 | ||
45 | // Load and create top level elements | 46 | //Storing the logicProblem |
46 | // Load source model | 47 | val filename = "problem.logicproblem" |
47 | val rs = new ResourceSetImpl | ||
48 | val logicURI = URI.createFileURI("output/files/logProb.logicproblem") | ||
49 | val logRes = rs.createResource(logicURI) | ||
50 | |||
51 | var LogicProblem problem = builder.createProblem | 48 | var LogicProblem problem = builder.createProblem |
52 | 49 | ||
53 | /* | 50 | /* |
@@ -56,8 +53,7 @@ class VampireTest { | |||
56 | rockPaperScisors(problem) | 53 | rockPaperScisors(problem) |
57 | //*/ | 54 | //*/ |
58 | 55 | ||
59 | logRes.contents.add(problem) | 56 | workspace.writeModel(problem, filename) |
60 | logRes.save(Collections.EMPTY_MAP) | ||
61 | 57 | ||
62 | //problem.add(Assertion( Y && X <=> X) ) | 58 | //problem.add(Assertion( Y && X <=> X) ) |
63 | 59 | ||
@@ -69,7 +65,7 @@ class VampireTest { | |||
69 | reasoner = new VampireSolver | 65 | reasoner = new VampireSolver |
70 | val vampireConfig = new VampireSolverConfiguration => [ | 66 | val vampireConfig = new VampireSolverConfiguration => [ |
71 | //add configuration things, in config file first | 67 | //add configuration things, in config file first |
72 | it.writeToFile = false | 68 | it.writeToFile = true |
73 | ] | 69 | ] |
74 | 70 | ||
75 | solution = reasoner.solve(problem, vampireConfig, workspace) | 71 | solution = reasoner.solve(problem, vampireConfig, workspace) |
@@ -88,6 +84,10 @@ class VampireTest { | |||
88 | 84 | ||
89 | } | 85 | } |
90 | 86 | ||
87 | def name() { | ||
88 | return this.class.simpleName | ||
89 | } | ||
90 | |||
91 | static def deMorgan(LogicProblem problem) { | 91 | static def deMorgan(LogicProblem problem) { |
92 | 92 | ||
93 | 93 | ||
@@ -144,7 +144,10 @@ class VampireTest { | |||
144 | //x.range | 144 | //x.range |
145 | Exists[ | 145 | Exists[ |
146 | val y = addVar("y",oldRPS) | 146 | val y = addVar("y",oldRPS) |
147 | beats2.call(x,y) | 147 | And(beats2.call(x,y), |
148 | x != y, | ||
149 | Not(beats2.call(y, x)) | ||
150 | ) | ||
148 | ] | 151 | ] |
149 | ])) | 152 | ])) |
150 | //*/ | 153 | //*/ |