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


C++ Arc::getRelativeMinValue方法代码示例

本文整理汇总了C++中Arc::getRelativeMinValue方法的典型用法代码示例。如果您正苦于以下问题:C++ Arc::getRelativeMinValue方法的具体用法?C++ Arc::getRelativeMinValue怎么用?C++ Arc::getRelativeMinValue使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Arc的用法示例。


在下文中一共展示了Arc::getRelativeMinValue方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: produceTokens

void Place::produceTokens(unsigned int nbOfTokens, unsigned int colorLabel, int tokensTime)
{
	unsigned int oldNumberOfTokens = getNbOfTokens(colorLabel);

	for (unsigned int i = 0; i < nbOfTokens; ++i) {
        Token token(tokensTime);
		m_tokenByColor[colorLabel - 1].push_back(token);
	}

    if(tokensTime < 0){tokensTime = 0;}

	if ((oldNumberOfTokens < NB_OF_TOKEN_TO_ACTIVE_ARC) && (getNbOfTokens(colorLabel) >= NB_OF_TOKEN_TO_ACTIVE_ARC)) { // CB WTF : Si un token et deux arcs sortant, bug ?
		arcList outGoingArcs = outGoingArcsOf(colorLabel);
		for (unsigned int i = 0 ; i < outGoingArcs.size() ; ++i) {
			Arc* arc = outGoingArcs[i];
            
//            if (!arc->getCondition()) { // CB check if the arc can be activated
//                continue;
//            }

            Transition* transitionTo = dynamic_cast<Transition*>(arc->getTo());
            
			if (!transitionTo) {
				throw IncoherentStateException();
			}

			transitionTo->setArcAsActive(arc, tokensTime, true);

			if (transitionTo->isStatic()) {
				if(arc->getRelativeMinValue().getValue() < (int) tokensTime) {
					getPetriNet()->pushTransitionToCrossWhenAcceleration(transitionTo);
				}
			} else {
				if(arc->getRelativeMaxValue().getValue() < (int) tokensTime) {
					getPetriNet()->pushTransitionToCrossWhenAcceleration(transitionTo);
				}
			}
		}
	}
}
开发者ID:ChristianFrisson,项目名称:Score,代码行数:40,代码来源:Place.cpp

示例2: produceTokens

void Place::produceTokens(unsigned int nbOfTokens, unsigned int colorLabel, unsigned int tokensTime) {
	unsigned int oldNumberOfTokens = getNbOfTokens(colorLabel);

	for (unsigned int i = 0; i < nbOfTokens; ++i) {
		Token token;
		token.setRemainingTime(tokensTime);
		m_tokenByColor[colorLabel - 1].push_back(token);
	}

	if ((oldNumberOfTokens < NB_OF_TOKEN_TO_ACTIVE_ARC) && (getNbOfTokens(colorLabel) >= NB_OF_TOKEN_TO_ACTIVE_ARC)) {
		arcList outGoingArcs = outGoingArcsOf(colorLabel);
		for (unsigned int i = 0 ; i < outGoingArcs.size() ; ++i) {
			Arc* arc = outGoingArcs[i];

			if (!(dynamic_cast<Transition*>(arc->getTo()))) {
				throw IncoherentStateException();
			}

			Transition* transitionTo = ((Transition*) arc->getTo());

			transitionTo->setArcAsActive(arc, tokensTime, true);

			if (transitionTo->isStatic()) {
				if(arc->getRelativeMinValue().getValue() < (int) tokensTime) {
					getPetriNet()->pushTransitionToCrossWhenAcceleration(transitionTo);
				}
			} else {
				if(arc->getRelativeMaxValue().getValue() < (int) tokensTime) {
					getPetriNet()->pushTransitionToCrossWhenAcceleration(transitionTo);
				}
			}

		}
	}



}
开发者ID:raphaelmarczak,项目名称:libIscore,代码行数:38,代码来源:Place.cpp

示例3: merge

void Transition::merge(Transition* transitionToMerge)
{
	for (unsigned int i = 0 ; i < transitionToMerge->m_externActions.size() ; ++i) {
		m_externActions.push_back(transitionToMerge->m_externActions[i]);
	}

	arcList mergeInGoingArcs = transitionToMerge->inGoingArcsOf();
	arcList mergeOutGoingArcs = transitionToMerge->outGoingArcsOf();

	for (unsigned int i = 0; i < mergeInGoingArcs.size() ; ++i) {
		Arc* currentArc = mergeInGoingArcs[i];

		ExtendedInt relativeMinValue = currentArc->getRelativeMinValue();
		ExtendedInt relativeMaxValue = currentArc->getRelativeMaxValue();
		ExtendedInt absoluteMinValue = currentArc->getAbsoluteMinValue();
		ExtendedInt absoluteMaxValue = currentArc->getAbsoluteMaxValue();

		Place* inGoingPlace = (Place*) currentArc->getFrom();

		Arc* newArc = getPetriNet()->createArc(inGoingPlace, this);
		newArc->changeAbsoluteTime(absoluteMinValue, absoluteMaxValue);
		newArc->changeRelativeTime(relativeMinValue, relativeMaxValue);

		getPetriNet()->deleteArc(inGoingPlace, transitionToMerge);
	}

	createBitArray();

	for (unsigned int i = 0; i < mergeOutGoingArcs.size() ; ++i) {
		Arc* currentArc = mergeOutGoingArcs[i];

		Place* outGoingPlace = (Place*) currentArc->getTo();
		getPetriNet()->createArc(this, outGoingPlace);

		getPetriNet()->deleteArc(transitionToMerge, outGoingPlace);
	}
}
开发者ID:raphaelmarczak,项目名称:libIscore,代码行数:37,代码来源:Transition.cpp


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