当前位置: 首页>>代码示例>>Java>>正文


Java INetSystem类代码示例

本文整理汇总了Java中org.jbpt.petri.INetSystem的典型用法代码示例。如果您正苦于以下问题:Java INetSystem类的具体用法?Java INetSystem怎么用?Java INetSystem使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。


INetSystem类属于org.jbpt.petri包,在下文中一共展示了INetSystem类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: storeNetSystem

import org.jbpt.petri.INetSystem; //导入依赖的package包/类
@Override
@SuppressWarnings("unchecked")
public int storeNetSystem(String pnmlFilePath, String externalID) throws SQLException {
	if (pnmlFilePath==null || externalID==null) return 0;
	
	File pnmlFile = new File(pnmlFilePath);
	
	if (pnmlFile.exists() && pnmlFile.isFile() && pnmlFile.canRead()) {
		try {
			byte[] encoded = Files.readAllBytes(Paths.get(pnmlFilePath));
			String pnmlContent =new String(encoded, StandardCharsets.UTF_8); 
			
			PNMLSerializer PNML = new PNMLSerializer();
			INetSystem<F,N,P,T,M> sys = (INetSystem<F,N,P,T,M>) PNML.parse(pnmlFilePath);
			
			return this.storeNetSystem(pnmlContent, sys, externalID);
		} catch (IOException e) {
			return 0;
		}
	}
	else return 0;
}
 
开发者ID:processquerying,项目名称:PQL,代码行数:23,代码来源:AbstractPetriNetPersistenceLayerMySQL.java

示例2: restoreNetSystem

import org.jbpt.petri.INetSystem; //导入依赖的package包/类
@Override
@SuppressWarnings("unchecked")
public INetSystem<F,N,P,T,M> restoreNetSystem(int internalID) throws SQLException {
	String pnmlContent = this.restorePNMLContent(internalID);
	
	if (pnmlContent == null) return null;
	
	PNMLSerializer PNML = new PNMLSerializer();
	INetSystem<F,N,P,T,M> result = (INetSystem<F,N,P,T,M>)PNML.parse(pnmlContent.getBytes());
	
	// set proper names
	int pi,ti;
	pi = ti = 1;
	
	for (P p : result.getPlaces()) {
		p.setName("p"+pi++);
	}
	
	for (T t : result.getTransitions()) {
		t.setName("t"+ti++);
	}
	
	return result;
}
 
开发者ID:processquerying,项目名称:PQL,代码行数:25,代码来源:AbstractPetriNetPersistenceLayerMySQL.java

示例3: getNumberOfPlaces

import org.jbpt.petri.INetSystem; //导入依赖的package包/类
public int getNumberOfPlaces(String externalID)
{
	int result = 0;
	int internalID = 0;
	INetSystem<F,N,P,T,M> sys = null;
	
	try {
	
		internalID = this.getInternalID(externalID);
		sys = this.restoreNetSystem(internalID);
	
		} catch (SQLException e) {e.printStackTrace();}
	
	result =  sys.getPlaces().size();
	
	return result;
}
 
开发者ID:processquerying,项目名称:PQL,代码行数:18,代码来源:AbstractPetriNetPersistenceLayerMySQL.java

示例4: isReachable

import org.jbpt.petri.INetSystem; //导入依赖的package包/类
@Override
public boolean isReachable(INetSystem<F,N,P,T,M> sys, Collection<P> marking) {
	if (sys==null) return false;
	for (P p : marking)
		if (!sys.getPlaces().contains(p)) return false;
	
	String pred = "";			
	Iterator<P> i = sys.getPlaces().iterator();
	P place = i.next();
	pred += place.getName() + " = " + Collections.frequency(marking,place);
	while (i.hasNext()) {
		pred += " AND ";
		place = i.next();
		pred += place.getName() + " = " + Collections.frequency(marking,place);
	}
	
	return this.isReachable(sys, pred);
}
 
开发者ID:processquerying,项目名称:PQL,代码行数:19,代码来源:AbstractLoLA2ModelChecker.java

示例5: getMarking

import org.jbpt.petri.INetSystem; //导入依赖的package包/类
@SuppressWarnings("unchecked")
private Set<P> getMarking(PQLAlignment alignment, int j, INetSystem<F,N,P,T,M> system)
	{
		system.loadNaturalMarking();
		Set<P> marking = null;
			
		for(int i=0; i<=j; i++)
		{
			PQLMove move = alignment.getAlignment().get(i);
			T t = null;
			
			if(!move.getMoM().equals("SKIP_STEP"))
			t = (T) move.getT();
			
			if(t != null)
			{
			system.fire(t);
			}
		}
			
		marking = system.getMarkedPlaces();
	
		return marking;

	}
 
开发者ID:processquerying,项目名称:PQL,代码行数:26,代码来源:AlignmentAPI.java

示例6: configure

import org.jbpt.petri.INetSystem; //导入依赖的package包/类
@Override
public void configure(Object obj) throws PQLException {
	if (obj == null) throw new PQLException("Configuration object is NULL.");
	
	if (!(obj instanceof INetSystem)) throw new PQLException("Configuration object is not an INetSystem.");
	
	INetSystem<F,N,P,T,M> originalNetSystem = (INetSystem<F,N,P,T,M>) obj;
	
	PetriNetStructuralChecks<F,N,P,T> check = new PetriNetStructuralChecks<F,N,P,T>();
	boolean wf = check.isWorkflowNet(originalNetSystem);
	if (!wf) throw new PQLException("Configuration object is not a workflow net.");
	
	this.n2n.clear();
	this.clonedNetSystem = originalNetSystem.clone(this.n2n);
	this.sinkPlace = this.clonedNetSystem.getSinkPlaces().iterator().next();
	this.TM = new AbstractNetSystemTransformationManager<F,N,P,T,M>(this.clonedNetSystem);
}
 
开发者ID:processquerying,项目名称:PQL,代码行数:18,代码来源:AbstractPQLBasicPredicatesMC.java

示例7: constructRuns

import org.jbpt.petri.INetSystem; //导入依赖的package包/类
@Override
protected void constructRuns(INetSystem<F,N,P,T,M> system) {
	switch (this.setup.SIGNIFICANCE_CHECK) {
		case EXHAUSTIVE:
			this.constructRunsExhaustive(system);
			break;
		case HASHMAP_BASED:
			this.constructRunsHashmapBased(system);
			break;
		case TREE_OF_RUNS:
			this.constructRunsTreeOfRuns(system);
			break;
		default:
			this.constructRunsExhaustive(system);
	}
}
 
开发者ID:jbpt,项目名称:codebase,代码行数:17,代码来源:AbstractBaselineRepresentativeUntangling.java

示例8: constructRuns

import org.jbpt.petri.INetSystem; //导入依赖的package包/类
@Override
protected void constructRuns(INetSystem<F,N,P,T,M> system) {
	map2 = new HashMap<N, N>();
	this.reducedSys = system.clone(map2);
	
	map = new HashMap<N, N>();
	for (Map.Entry<N,N> entry : map2.entrySet())
		map.put(entry.getValue(), entry.getKey());
	
	try {		
		abs = this.reduce(this.reducedSys);
	}
	catch(Exception e) {
		System.err.println(e.getMessage());
	}
	
	super.constructRuns(this.reducedSys);
}
 
开发者ID:jbpt,项目名称:codebase,代码行数:19,代码来源:AbstractReductionBasedRepresentativeUntangling.java

示例9: AbstractRepresentativeUntangling

import org.jbpt.petri.INetSystem; //导入依赖的package包/类
/**
 * Constructor of a representative untangling.
 * 
 * @param sys Net system to untangle.
 */
public AbstractRepresentativeUntangling(INetSystem<F,N,P,T,M> sys, UntanglingSetup setup) {
	if (sys==null) return;
	
	this.setup = setup;
	
	this.sys = sys;
	this.runs = new HashSet<IRun<F, N, P, T, M>>();
	
	long start = System.nanoTime();
	this.constructRuns(this.sys);
	long stop = System.nanoTime();
	this.time = stop - start;
	
	if (this.setup.SIGNIFICANCE_CHECK == SignificanceCheckType.TREE_OF_RUNS) {
		for (TreeStep<F,N,P,T,M> step : this.torLeaves) {
			IRun<F,N,P,T,M> run = this.constructRun(step);
			this.runs.add(run);
		}
	}
	
	this.constructProcesses();
}
 
开发者ID:jbpt,项目名称:codebase,代码行数:28,代码来源:AbstractRepresentativeUntangling.java

示例10: constructRun

import org.jbpt.petri.INetSystem; //导入依赖的package包/类
private IRun<F,N,P,T,M> constructRun(TreeStep<F,N,P,T,M> step) {
	List<TreeStep<F,N,P,T,M>> list = new ArrayList<TreeStep<F, N, P, T, M>>();
	TreeStep<F,N,P,T,M> s = step;
	list.add(s);
	while (s.getParent()!=null) {
		s = s.getParent();
		list.add(0,s);
	}
	
	INetSystem<F,N,P,T,M> netSystem = (this.reducedSys==null) ? this.sys : this.reducedSys;
	IRun<F,N,P,T,M> run = this.createRun(netSystem);
	for (TreeStep<F,N,P,T,M> ss : list) {
		if (ss.getTransition()!=null)
			run.append(ss.getTransition());
	}
	
	return run;
}
 
开发者ID:jbpt,项目名称:codebase,代码行数:19,代码来源:AbstractRepresentativeUntangling.java

示例11: isSoundWorkflowNet

import org.jbpt.petri.INetSystem; //导入依赖的package包/类
@Override
public boolean isSoundWorkflowNet(INetSystem<F,N,P,T,M> sys) {
	if (sys==null) return false;
	
	PetriNetStructuralChecks<F,N,P,T> check = new PetriNetStructuralChecks<F,N,P,T>();
	boolean wf = check.isWorkflowNet(sys);
	
	if (!wf) return false;
	
	P i = sys.getSourcePlaces().iterator().next();
	P o = sys.getSinkPlaces().iterator().next();
	
	for (P p : sys.getPlaces()) {
		if (p.equals(i)) {
			if (sys.getMarking().get(p)!=1) return false;
		} else {
			if (sys.getMarking().get(p)!=0) return false;
		}
	}
	
	T t = sys.createTransition();
	t.setName("TEMP");
	
	sys.addTransition(t);
	sys.addFlow(o,t);
	sys.addFlow(t,i);
		
	boolean result = true;
	
	if (!this.isBounded(sys)) result = false;
	
	if (result)
		if (!this.isLive(sys)) result = false;
	
	sys.removeTransition(t);
	
	return result;
}
 
开发者ID:processquerying,项目名称:PQL,代码行数:39,代码来源:AbstractLoLA2ModelChecker.java

示例12: isLive

import org.jbpt.petri.INetSystem; //导入依赖的package包/类
public boolean isLive(INetSystem<F,N,P,T,M> sys, Set<Process> p) {
	if (sys==null) return false;
	
	for (T t : sys.getTransitions()) {
		if (!this.isLive(sys, t, p))
			return false;
	}
	
	return true;
}
 
开发者ID:processquerying,项目名称:PQL,代码行数:11,代码来源:AbstractLoLA2ModelChecker.java

示例13: isBounded

import org.jbpt.petri.INetSystem; //导入依赖的package包/类
@Override
public boolean isBounded(INetSystem<F,N,P,T,M> sys) {
	if (sys==null) return false;
	
	for (P p : sys.getPlaces()) {
		if (!this.isBounded(sys,p))
			return false;
	}
	
	return true;
}
 
开发者ID:processquerying,项目名称:PQL,代码行数:12,代码来源:AbstractLoLA2ModelChecker.java

示例14: check

import org.jbpt.petri.INetSystem; //导入依赖的package包/类
@Override
public boolean check(INetSystem<F,N,P,T,M> sys, String property) {
	if (sys==null) return false;
	
	boolean result = false;
	
	try 
    {
		String[] cmds = {this.lolaPath, "--formula="+property, "--quiet", "--json"};
		Process p = Runtime.getRuntime().exec(cmds);
		
		BufferedReader input	= new BufferedReader(new InputStreamReader(p.getInputStream()));
		BufferedWriter output	= new BufferedWriter(new OutputStreamWriter(p.getOutputStream()));			
		
		String net = this.sys2lola(sys);
		// System.out.println(net); // debug
		output.write(net);
		output.close();
		
		String jsonString = "";
		String line;
		while ((line = input.readLine()) != null) {
			jsonString += line;
		}
		input.close();
		
		JSONObject json = new JSONObject(jsonString);
		
		//System.out.println(jsonString); // debug
		if (json.getJSONObject("analysis").get("result").toString().equals("true"))
			result = true;
    } 
    catch(Exception e) {}
		
	return result;
}
 
开发者ID:processquerying,项目名称:PQL,代码行数:37,代码来源:AbstractLoLA2ModelChecker.java

示例15: SimpleStateSpace

import org.jbpt.petri.INetSystem; //导入依赖的package包/类
public SimpleStateSpace(INetSystem<F, N, P, T, M> netSystem) {
	super();
	this.netSystem = netSystem;
	this.enabled = new HashMap<M, Set<T>>();
	this.toVisit = new HashMap<M, Set<T>>();
	this.stateTransitions = new HashMap<M, Map<T, M>>();
}
 
开发者ID:jbpt,项目名称:codebase,代码行数:8,代码来源:SimpleStateSpace.java


注:本文中的org.jbpt.petri.INetSystem类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。