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


C++ Gate::typeID方法代码示例

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


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

示例1: logicSim

void Circuit::logicSim( Pattern* PatternSet )
{
    AssignPiValue( PatternSet );

	for(unsigned i = 0 ; i < topologicalSequence.size() ; ++i)
	{
		int gateID = topologicalSequence[i];
		Gate targetGate = gate(gateID);
	    // PI = 1, PO = 2, CUT = 3, CUT_BAR = 4, TIE0 = 5, TIE1 = 6, NORMAL = 7, REMOVED = 8, UNUSED = 0
    	
		int finalValue = value[targetGate.inWire(0)];
		for(unsigned j = 1 ; j < targetGate.numInWire() ; ++j)
		{
			int inWireID = targetGate.inWire(j);
			//assert(level[wire(inWireID).preGate()] <= level[gateID]);
			int inValue = value[inWireID];

			switch(targetGate.typeID())
			{
				case 1:
				case 2:
					finalValue = inValue;
					break;
				case 3:
				case 4:
					finalValue = finalValue & inValue;
					break;
				case 5:
				case 6:
					finalValue = finalValue | inValue;
					break;
				case 7:
				case 8:
					finalValue = finalValue ^ inValue;
					break;
				default:
					cout << "strange gate type id: " << targetGate.typeID() << endl;
					exit(0);
			}
		}
		switch(targetGate.typeID())
		{
			case 1:
			case 4:
			case 6:
			case 8:
				finalValue = ~ finalValue;
				break;
			default:
				break;
		}

        ///cout<< finalValue<<endl;

        Wire fanoutWire = wire( targetGate.outWire() );
		if( fanoutWire.type() != "CUT" && fanoutWire.type() != "CUT_BAR"  )
        {
            wire( targetGate.outWire() ).setValueSet( finalValue );
            value[ targetGate.outWire() ] = finalValue;
        }

	}
	return;
}
开发者ID:bhb811340,项目名称:SoCV_fp,代码行数:64,代码来源:circuit.cpp


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