package hu.bme.mit.inf.dslreasoner.run import hu.bme.mit.inf.dslreasoner.workspace.FileSystemWorkspace import hu.bme.mit.inf.dslreasomer.domains.transima.fam.FunctionalArchitecture.FunctionalArchitecturePackage import java.util.List import org.eclipse.emf.ecore.EClass import org.eclipse.emf.ecore.EEnumLiteral import org.eclipse.emf.ecore.EReference import org.eclipse.emf.ecore.EEnum import org.eclipse.emf.ecore.EAttribute import hu.bme.mit.inf.dslreasoner.ecore2logic.EcoreMetamodelDescriptor import hu.bme.mit.inf.dslreasoner.workspace.ReasonerWorkspace import org.eclipse.emf.ecore.EObject import java.util.LinkedHashMap import hu.bme.mit.inf.dslreasoner.viatra2logic.ViatraQuerySetDescriptor import hu.bme.mit.inf.dslreasoner.ecore2logic.Ecore2Logic import hu.bme.mit.inf.dslreasoner.viatra2logic.Viatra2Logic import hu.bme.mit.inf.dslreasoner.viatrasolver.partialinterpretation2logic.InstanceModel2Logic import hu.bme.mit.inf.dslreasoner.ecore2logic.Ecore2LogicConfiguration import hu.bme.mit.inf.dslreasoner.viatra2logic.Viatra2LogicConfiguration import hu.bme.mit.inf.dslreasoner.viatrasolver.reasoner.ViatraReasonerConfiguration import hu.bme.mit.inf.dslreasoner.viatrasolver.logic2viatra.TypeInferenceMethod import hu.bme.mit.inf.dslreasoner.viatrasolver.reasoner.StateCoderStrategy import hu.bme.mit.inf.dslreasoner.viatrasolver.reasoner.ViatraReasoner import hu.bme.mit.inf.dslreasoner.logic.model.logicresult.ModelResult import hu.bme.mit.inf.dslreasoner.viatrasolver.partialinterpretationlanguage.partialinterpretation.PartialInterpretation import hu.bme.mit.inf.dslreasoner.logic.model.logicresult.LogicResult import org.eclipse.emf.ecore.resource.Resource import org.eclipse.emf.ecore.xmi.impl.XMIResourceFactoryImpl import hu.bme.mit.inf.dslreasoner.viatrasolver.partialinterpretationlanguage.visualisation.PartialInterpretation2Gml import hu.bme.mit.inf.dlsreasoner.alloy.reasoner.AlloySolverConfiguration import hu.bme.mit.inf.dlsreasoner.alloy.reasoner.AlloySolver import hu.bme.mit.inf.dslreasoner.logic2ecore.Logic2Ecore import hu.bme.mit.inf.dslreasoner.logic.model.builder.LogicReasoner import java.util.LinkedList import hu.bme.mit.inf.dslreasoner.visualisation.pi2graphviz.GraphvizVisualisation import hu.bme.mit.inf.dslreasoner.logic.model.builder.LogicStructureBuilder import hu.bme.mit.inf.dslreasoner.logic.model.builder.LogicProblemBuilder class SimpleRun { def static void main(String[] args) { val inputs = new FileSystemWorkspace('''initialModels/''',"") val workspace = new FileSystemWorkspace('''outputModels/''',"") workspace.initAndClear println("Input and output workspaces are created") val metamodel = loadMetamodel() val partialModel = loadPartialModel(inputs) val queries = loadQueries(metamodel) println("DSL loaded") val Ecore2Logic ecore2Logic = new Ecore2Logic val Logic2Ecore logic2Ecore = new Logic2Ecore(ecore2Logic) val Viatra2Logic viatra2Logic = new Viatra2Logic(ecore2Logic) val InstanceModel2Logic instanceModel2Logic = new InstanceModel2Logic val modelGenerationProblem = ecore2Logic.transformMetamodel(metamodel,new Ecore2LogicConfiguration()) val modelExtensionProblem = instanceModel2Logic.transform(modelGenerationProblem,partialModel) val validModelExtensionProblem = viatra2Logic.transformQueries(queries,modelGenerationProblem,new Viatra2LogicConfiguration) val logicProblem = validModelExtensionProblem.output println("Problem created") var LogicResult solution var LogicReasoner reasoner //* reasoner = new ViatraReasoner val viatraConfig = new ViatraReasonerConfiguration => [ it.typeScopes.maxNewElements = 40 it.typeScopes.minNewElements = 40 it.solutionScope.numberOfRequiredSolution = 1 it.existingQueries = queries.patterns.map[it.internalQueryRepresentation] it.debugCongiguration.logging = false it.debugCongiguration.partalInterpretationVisualisationFrequency = 1 it.debugCongiguration.partialInterpretatioVisualiser = new GraphvizVisualisation ] solution = reasoner.solve(logicProblem,viatraConfig,workspace) /*/ reasoner = new AlloySolver val alloyConfig = new AlloySolverConfiguration => [ it.typeScopes.maxNewElements = 5 it.typeScopes.minNewElements = 5 it.solutionScope.numberOfRequiredSolution = 1 it.typeScopes.maxNewIntegers = 0 it.writeToFile = true ] solution = reasoner.solve(logicProblem,alloyConfig,workspace) //*/ println("Problem solved") val interpretations = reasoner.getInterpretations(solution as ModelResult) val models = new LinkedList for(interpretation : interpretations) { val extension b = new LogicStructureBuilder val extension a = new LogicProblemBuilder val instanceModel = logic2Ecore.transformInterpretation(interpretation,modelGenerationProblem.trace) models+=instanceModel } solution.writeSolution(workspace, #[]) } def private static loadMetamodel() { val pckg = FunctionalArchitecturePackage.eINSTANCE val List classes = pckg.EClassifiers.filter(EClass).toList val List enums = pckg.EClassifiers.filter(EEnum).toList val List literals = enums.map[ELiterals].flatten.toList val List references = classes.map[EReferences].flatten.toList val List attributes = classes.map[EAttributes].flatten.toList return new EcoreMetamodelDescriptor(classes,#{},false,enums,literals,references,attributes) } def private static loadQueries(EcoreMetamodelDescriptor metamodel) { val i = hu.bme.mit.inf.dslreasoner.domains.transima.fam.patterns.Pattern.instance val patterns = i.specifications.toList val wfPatterns = patterns.filter[it.allAnnotations.exists[it.name== "Constraint"]].toSet val derivedFeatures = new LinkedHashMap derivedFeatures.put(i.type,metamodel.attributes.filter[it.name == "type"].head) derivedFeatures.put(i.model,metamodel.references.filter[it.name == "model"].head) val res = new ViatraQuerySetDescriptor( patterns, wfPatterns, derivedFeatures ) return res } def static loadPartialModel(ReasonerWorkspace inputs) { Resource.Factory.Registry.INSTANCE.getExtensionToFactoryMap().put("*", new XMIResourceFactoryImpl()); inputs.readModel(EObject,"FAM.xmi").eResource.allContents.toList } def static writeSolution(LogicResult solution, ReasonerWorkspace workspace, List models) { if(solution instanceof ModelResult) { val representations = solution.representation for(representationIndex : 0..