aboutsummaryrefslogtreecommitdiffstats
path: root/Tests/ca.mcgill.ecse.dslreasoner.vampire.test/xtend-gen/ca/mcgill/ecse/dslreasoner/vampire/icse/FileSystemTest.java
blob: 7579bd987f915df6bfaf47d305e2193461995a05 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
package ca.mcgill.ecse.dslreasoner.vampire.icse;

import ca.mcgill.ecse.dslreasoner.standalone.test.filesystem.Dir;
import ca.mcgill.ecse.dslreasoner.standalone.test.filesystem.File;
import ca.mcgill.ecse.dslreasoner.standalone.test.filesystem.filesystemPackage;
import ca.mcgill.ecse.dslreasoner.vampire.icse.GeneralTest;
import ca.mcgill.ecse.dslreasoner.vampire.reasoner.VampireSolver;
import ca.mcgill.ecse.dslreasoner.vampire.reasoner.VampireSolverConfiguration;
import hu.bme.mit.inf.dslreasoner.ecore2logic.Ecore2Logic;
import hu.bme.mit.inf.dslreasoner.ecore2logic.Ecore2LogicConfiguration;
import hu.bme.mit.inf.dslreasoner.ecore2logic.Ecore2Logic_Trace;
import hu.bme.mit.inf.dslreasoner.ecore2logic.EcoreMetamodelDescriptor;
import hu.bme.mit.inf.dslreasoner.logic.model.builder.DocumentationLevel;
import hu.bme.mit.inf.dslreasoner.logic.model.builder.TracedOutput;
import hu.bme.mit.inf.dslreasoner.logic.model.logiclanguage.Type;
import hu.bme.mit.inf.dslreasoner.logic.model.logicproblem.LogicProblem;
import hu.bme.mit.inf.dslreasoner.logic.model.logicresult.LogicResult;
import hu.bme.mit.inf.dslreasoner.viatra2logic.Viatra2Logic;
import hu.bme.mit.inf.dslreasoner.viatrasolver.partialinterpretation2logic.InstanceModel2Logic;
import hu.bme.mit.inf.dslreasoner.workspace.FileSystemWorkspace;
import java.util.HashMap;
import java.util.Map;
import org.eclipse.emf.common.util.EList;
import org.eclipse.emf.ecore.EObject;
import org.eclipse.emf.ecore.resource.Resource;
import org.eclipse.emf.ecore.xmi.impl.XMIResourceFactoryImpl;
import org.eclipse.xtend2.lib.StringConcatenation;
import org.eclipse.xtext.xbase.lib.InputOutput;
import org.eclipse.xtext.xbase.lib.ObjectExtensions;
import org.eclipse.xtext.xbase.lib.Procedures.Procedure1;

@SuppressWarnings("all")
public class FileSystemTest {
  public static void main(final String[] args) {
    final Ecore2Logic ecore2Logic = new Ecore2Logic();
    final Viatra2Logic viatra2Logic = new Viatra2Logic(ecore2Logic);
    final InstanceModel2Logic instanceModel2Logic = new InstanceModel2Logic();
    StringConcatenation _builder = new StringConcatenation();
    _builder.append("initialModels/");
    final FileSystemWorkspace inputs = new FileSystemWorkspace(_builder.toString(), "");
    StringConcatenation _builder_1 = new StringConcatenation();
    _builder_1.append("output/FileSystemTest/");
    final FileSystemWorkspace workspace = new FileSystemWorkspace(_builder_1.toString(), "");
    workspace.initAndClear();
    final Resource.Factory.Registry reg = Resource.Factory.Registry.INSTANCE;
    final Map<String, Object> map = reg.getExtensionToFactoryMap();
    XMIResourceFactoryImpl _xMIResourceFactoryImpl = new XMIResourceFactoryImpl();
    map.put("logicproblem", _xMIResourceFactoryImpl);
    InputOutput.<String>println("Input and output workspaces are created");
    final EcoreMetamodelDescriptor metamodel = GeneralTest.loadMetamodel(filesystemPackage.eINSTANCE);
    final EList<EObject> partialModel = GeneralTest.loadPartialModel(inputs, "fs/filesystemInstance.xmi");
    InputOutput.<String>println("DSL loaded");
    Ecore2LogicConfiguration _ecore2LogicConfiguration = new Ecore2LogicConfiguration();
    final TracedOutput<LogicProblem, Ecore2Logic_Trace> modelGenerationProblem = ecore2Logic.transformMetamodel(metamodel, _ecore2LogicConfiguration);
    LogicProblem problem = modelGenerationProblem.getOutput();
    problem = instanceModel2Logic.transform(modelGenerationProblem, partialModel).getOutput();
    workspace.writeModel(problem, "FileSystem.logicproblem");
    InputOutput.<String>println("Problem created");
    long startTime = System.currentTimeMillis();
    VampireSolver reasoner = null;
    VampireSolver _vampireSolver = new VampireSolver();
    reasoner = _vampireSolver;
    final HashMap<Class, Integer> classMapMin = new HashMap<Class, Integer>();
    classMapMin.put(Dir.class, Integer.valueOf(10));
    classMapMin.put(File.class, Integer.valueOf(5));
    final Map<Type, Integer> typeMapMin = GeneralTest.getTypeMap(classMapMin, metamodel, ecore2Logic, modelGenerationProblem.getTrace());
    final HashMap<Class, Integer> classMapMax = new HashMap<Class, Integer>();
    classMapMax.put(File.class, Integer.valueOf(15));
    classMapMax.put(Dir.class, Integer.valueOf(15));
    final Map<Type, Integer> typeMapMax = GeneralTest.getTypeMap(classMapMax, metamodel, ecore2Logic, modelGenerationProblem.getTrace());
    VampireSolverConfiguration _vampireSolverConfiguration = new VampireSolverConfiguration();
    final Procedure1<VampireSolverConfiguration> _function = (VampireSolverConfiguration it) -> {
      it.documentationLevel = DocumentationLevel.FULL;
      it.typeScopes.minNewElements = 10;
      it.typeScopes.maxNewElements = 25;
      int _size = typeMapMin.size();
      boolean _notEquals = (_size != 0);
      if (_notEquals) {
        it.typeScopes.minNewElementsByType = typeMapMin;
      }
      int _size_1 = typeMapMin.size();
      boolean _notEquals_1 = (_size_1 != 0);
      if (_notEquals_1) {
        it.typeScopes.maxNewElementsByType = typeMapMax;
      }
      it.contCycleLevel = 5;
      it.uniquenessDuplicates = false;
    };
    final VampireSolverConfiguration vampireConfig = ObjectExtensions.<VampireSolverConfiguration>operator_doubleArrow(_vampireSolverConfiguration, _function);
    LogicResult solution = reasoner.solve(problem, vampireConfig, workspace, "FS");
    long _currentTimeMillis = System.currentTimeMillis();
    long _minus = (_currentTimeMillis - startTime);
    long totalTimeMin = (_minus / 60000);
    long _currentTimeMillis_1 = System.currentTimeMillis();
    long _minus_1 = (_currentTimeMillis_1 - startTime);
    long _divide = (_minus_1 / 1000);
    long totalTimeSec = (_divide % 60);
    InputOutput.<String>println("Problem solved");
    InputOutput.<String>println(((("Time was: " + Long.valueOf(totalTimeMin)) + ":") + Long.valueOf(totalTimeSec)));
  }
}