|
|||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||||
java.lang.Objectbyucc.jhdl.base.Nameable
byucc.jhdl.base.Node
byucc.jhdl.base.Cell
byucc.jhdl.base.Structural
byucc.jhdl.Logic.LogicGates
byucc.jhdl.Logic.LogicStatic
byucc.jhdl.Logic.Logic
byucc.jhdl.Logic.Modules.Encoder
encodes the one-hot input value. Care must be taken that only one input is active at a time, or else the output will be a strange mix of the two inputs. If more than one input is possible, consider using a priority encoder.
| Field Summary | |
static CellInterface[] |
cell_interface
cell's interface to the outside world |
static int |
SINGLE_BIT
|
| Fields inherited from class byucc.jhdl.Logic.Logic |
ABOVE, ALIGN_BOTTOM, ALIGN_CENTER, ALIGN_LEFT, ALIGN_LSB, ALIGN_MSB, ALIGN_RIGHT, ALIGN_TOP, BELOW, DOWN, EAST_OF, LEFT_OF, MAX_PACK, NORTH_OF, ON, ONTOP, ONTOP_OF, RIGHT_OF, SOUTH_OF, TOLEFT, TORIGHT, UNCONSTRAINED, UP, WEST_OF |
| Fields inherited from class byucc.jhdl.Logic.LogicGates |
tech_mapper |
| Constructor Summary | |
Encoder(Node parent,
Wire i,
Wire o,
Wire zero)
"Active" output is removed, for performance reasons. |
|
Encoder(Node parent,
Wire i,
Wire o,
Wire zero,
Wire active)
|
|
| Method Summary | |
protected void |
build()
builds the structural circuit for an encoder. |
void |
clock()
Users define synchronous behavior in this method using standard JHDL constructs. |
protected BV |
compute()
|
boolean |
defaultSimulationModelIsBehavioral()
The default simulation model is structural for Structural cells. |
protected void |
getValues()
|
protected void |
initBehavioralModel()
|
void |
propagate()
Users defined propagatable behavior using standard JHDL constructs. |
protected void |
putValues()
|
void |
reset()
If you define a behavior, you must also define a reset method for resetting the synchonous part of your model. |
| Methods inherited from class byucc.jhdl.base.Node |
addObservable, addSimulatorCallback, checkAll, delete, getBuildingFlag, getChildren, getChildrenEnumeration, getInstanceName, getParent, getParentCell, getRelatives, getSystem, getWires, optimize, orphanAllowed, printAllChildren, printTree, removeSimulatorCallback, setDefaultClock |
| Methods inherited from class byucc.jhdl.base.Nameable |
caseSensitivity, caseSensitivity, disableNameClashChecking, getFullName, getFullNameNoTestBench, getHierNameNoTestBench, getInstanceNo, getInstanceNumber, getLeafName, getLeafName, getRelativeName, getUserName, getUserName, hasUserSpecifiedName, isDescendantOf, setInstanceNumber |
| Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
| Field Detail |
public static final int SINGLE_BIT
public static CellInterface[] cell_interface
| Constructor Detail |
public Encoder(Node parent,
Wire i,
Wire o,
Wire zero,
Wire active)
i - the input to be encodedo - the encoded outputzero - '1' if the zeroeth bit of the input is high, '0' otherwiseactive - '1' if any of the input bits are high, '0' otherwise
public Encoder(Node parent,
Wire i,
Wire o,
Wire zero)
i - the input to be encodedo - the encoded outputzero - '1' if the zeroeth bit of the input is high, '0' otherwise| Method Detail |
public void reset()
Structural
reset in interface Clockablereset in class Structuralpublic void clock()
Structural
clock in interface Clockableclock in class Structuralpublic void propagate()
Structural
propagate in interface byucc.jhdl.base.Propagateablepropagate in class Structuralprotected BV compute()
protected void getValues()
protected void putValues()
protected void initBehavioralModel()
public boolean defaultSimulationModelIsBehavioral()
Structural
defaultSimulationModelIsBehavioral in class Structuralprotected void build()
|
|||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||||