Module ariths_gen.core.logic_gate_circuits.logic_gate_circuit

Classes

class MultipleInputLogicGate (a: Bus,
two_input_gate_cls,
parent_component: object,
prefix: str = '')

Class representing multiple input logic gate internally composed of corresponding two input logic gates.

Gates are cascaded in a tree like structure to solve fan-in issue concerning multi-input logic gates. Tree like structure increases propagation delay logarithmically with number of inputs.

   ┌──────┐
──►│ FUNC │
   │      ├──┐  ┌──────┐
──►│      │  ├─►│ FUNC │
   └──────┘  │  │      ├─►
   ┌──────┐  ├─►│      │
──►│ FUNC │  │  └──────┘
   │      ├──┘
──►│      │
   └──────┘
   ...

Description of the init method.

Args

a : Bus
Bus containing input wires to form inner composite two input logic gates.
two_input_gate_cls : type
Specific two input logic gate class type that specifies what type of multiple input logic gate the instance represents.
parent_component (object) Object of upper component of which this logic gate is a subcomponent (used for adding composite two input gates into parent_component's list of subcomponents).
prefix : str, optional
Prefix used to name inner composite logic gates. Defaults to "".
Expand source code
class MultipleInputLogicGate():
    """Class representing multiple input logic gate internally composed of corresponding two input logic gates.

    Gates are cascaded in a tree like structure to solve fan-in issue concerning multi-input logic gates.
    Tree like structure increases propagation delay logarithmically with number of inputs.

    ```
       ┌──────┐
    ──►│ FUNC │
       │      ├──┐  ┌──────┐
    ──►│      │  ├─►│ FUNC │
       └──────┘  │  │      ├─►
       ┌──────┐  ├─►│      │
    ──►│ FUNC │  │  └──────┘
       │      ├──┘
    ──►│      │
       └──────┘
       ...
    ```

    Description of the __init__ method.

    Args:
        a (Bus): Bus containing input wires to form inner composite two input logic gates.
        two_input_gate_cls (type): Specific two input logic gate class type that specifies what type of multiple input logic gate the instance represents.
        parent_component (object) Object of upper component of which this logic gate is a subcomponent (used for adding composite two input gates into `parent_component`'s list of subcomponents).
        prefix (str, optional): Prefix used to name inner composite logic gates. Defaults to "".
    """
    def __init__(self, a: Bus, two_input_gate_cls, parent_component: object, prefix: str = ""):
        i = 0
        while a.N != 1:
            N = math.floor(a.N/2)
            out_wires = []
            # Creation of composite two input logic gates from bus `a`'s bit pairs and addition of generated blocks outputs for next iteration
            for bus_index in range(0, N):
                gate = two_input_gate_cls(a=a.get_wire(bus_index), b=a.get_wire(bus_index+N), prefix=prefix+ "_" + str(i) + "_" + str(parent_component.get_instance_num(cls=two_input_gate_cls, count_disabled_gates=False)), parent_component=parent_component)
                parent_component.add_component(gate)
                out_wires.append(gate.out)
                i += 1

            # In case bus `a` has odd number of wires
            if a.N % 2 != 0:
                out_wires.append(a.get_wire(-1))
                N += 1

            # Update bus for next iteration until it contains only one output wire
            a = Bus(prefix=a.prefix, N=N, wires_list=out_wires)
        self.out = a.get_wire(0)
class OneInputLogicGate (a: Wire,
prefix: str = 'gate',
outid: int = 0,
parent_component: object = None)

Class representing one input logic gates.

   ┌──────┐
   │ FUNC │
──►│      │───►
   │      │
   └──────┘

Description of the init method.

Args

a : Wire
First input wire.
prefix : str, optional
Prefix name of logic gate. Defaults to "gate".
outid : int, optional
Index of output wire. Defaults to 0.

parent_component (object, optional) Object of upper component of which logic gate is a subcomponent. Defaults to None.

Expand source code
class OneInputLogicGate(TwoInputLogicGate):
    """Class representing one input logic gates.

    ```
       ┌──────┐
       │ FUNC │
    ──►│      │───►
       │      │
       └──────┘
    ```

    Description of the __init__ method.

    Args:
        a (Wire): First input wire.
        prefix (str, optional): Prefix name of logic gate. Defaults to "gate".
        outid (int, optional): Index of output wire. Defaults to 0.
        parent_component (object, optional) Object of upper component of which logic gate is a subcomponent. Defaults to None.
    """
    def __init__(self, a: Wire, prefix: str = "gate", outid: int = 0, parent_component: object = None):
        self.a = a
        self.prefix = prefix
        self.outid = outid
        # To toggle whether logic gate function ought to be generated or to be replaced
        # by a constant wire for the sake of more optimized circuit generation
        self.disable_generation = False
        # Obtaining the caller object to gain access into its `components` list Used for adding NOT gates as a replacement for two input logic gates with constant input (optimalization)
        # Also used to obtain caller object's `prefix` name for proper wire names generation of flat/hier representations
        self.parent_component = parent_component

    """ C CODE GENERATION """
    # FLAT C #
    def get_prototype_c_flat(self):
        """Generates flat C code function header to describe corresponding one input logic gate's interface in flat C code.

        Returns:
            str: Function's name and parameter in flat C code.
        """
        return f"uint8_t {self.prefix}(uint8_t {self.a.name})" + "{" + "\n"

    def get_function_c(self):
        """Generates C code representing corresponding one input logic gate's Boolean function using bitwise operators between its bitwise shifted input.

        Returns:
            str: C code description of logic gate's Boolean function (with bitwise shifted input).
        """
        return f"{self.operator}({self.a.get_wire_value_c_flat()}) & 0x01"

    # HIERARCHICAL C #
    def get_prototype_c_hier(self):
        """Generates hierarchical C code function header to describe corresponding one input logic gate's interface in hierarchical C code.

        Returns:
            str: Function's name and parameters in hierarchical C code.
        """
        return f"uint8_t {self.gate_type}(uint8_t {self.a.name})" + "{" + "\n"

    def get_function_block_c(self):
        """Generates C code representation of corresponding logic gate used as a function block in hierarchical circuit description.

        Returns:
            str: C code of logic gate's function block description.
        """
        gate_block = type(self)(a=Wire(name="a"))
        return f"{gate_block.get_prototype_c_hier()}" + \
               f"  return "+(gate_block.get_function_c())+";\n}\n\n"

    def get_gate_invocation_c(self):
        """Generates C code invocation of corresponding logic gate's generated function block.

        Returns:
            str: C code of logic gate's function block invocation.
        """
        # No function block is generated if one of the inputs is a wire with constant value.
        # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
        if self.disable_generation:
            return ""
        else:
            return f"  {self.out.name} = {self.gate_type}({self.a.get_wire_value_c_hier()});\n"

    """ VERILOG CODE GENERATION """
    # FLAT VERILOG #
    def get_prototype_v_flat(self):
        """Generates flat Verilog module header to describe corresponding one input logic gate's interface in flat Verilog.

        Returns:
            str: Module's name and parameter in flat Verilog.
        """
        return f"module {self.prefix}(input {self.a.name}" + \
               "".join([f", output {self.out.name});\n" if self.disable_generation is False else f", output {self.out.name}_out);\n" for _ in range(1)])

    def get_function_v(self):
        """Generates Verilog code representing corresponding one input logic gate's Boolean function using bitwise operators between its input.

        Returns:
            str: Verilog description of logic gate's Boolean function.
        """
        return f"{self.operator}{self.a.get_wire_value_v_flat()}"

    # HIERARCHICAL VERILOG #
    def get_prototype_v_hier(self):
        """Generates hierarchical Verilog module header to describe corresponding one input logic gate's interface in hierarchical Verilog.

        Returns:
            str: Module's name and parameter in hierarchical Verilog.
        """
        return f"module {self.gate_type}(input {self.a.name}, output {self.out.name});\n"

    def get_function_block_v(self):
        """Generates Verilog code representation of corresponding logic gate used as a function block in hierarchical circuit description.

        Returns:
            str: Verilog code of logic gate's function block description.
        """
        gate_block = type(self)(a=Wire(name="a"), prefix="out")
        return f"{gate_block.get_prototype_v_hier()}" + \
               f"  assign {gate_block.out.name} = {gate_block.get_function_v()};\n" + \
               f"endmodule\n\n"

    def get_gate_invocation_v(self):
        """Generates Verilog code invocation of corresponding logic gate's generated function block.

        Returns:
            str: Verilog code logic gate's function block invocation.
        """
        # No function block is generated if one of the inputs is a wire with constant value.
        # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
        if self.disable_generation:
            return ""
        else:
            gate_block = self.__class__(a=Wire(name="a"), prefix="out")
            return f"  {self.gate_type} {self.gate_type}_{self.out.prefix}(.{gate_block.a.prefix}({self.a.get_wire_value_v_hier()}), .{gate_block.out.prefix}({self.out.prefix}));\n"

    """ BLIF CODE GENERATION """
    # FLAT BLIF #
    def get_declaration_blif(self):
        """Generates Blif code declaration of one input logic gate's wires.

        Returns:
            str: Blif logic gate's wires declaration.
        """
        return f".inputs {self.a.get_wire_declaration_blif()}\n" + \
               f".outputs" + \
               "".join([f" {self.out.name}\n" if self.disable_generation is False else f" {self.out.name}_out\n" for _ in range(1)]) + \
               f".names vdd\n1\n" + \
               f".names gnd\n0\n"

    # HIERARCHICAL BLIF #
    def get_function_block_blif(self):
        """Generates Blif code representation of corresponding one input logic gate used as subcomponent in hierarchical circuit description.

        Returns:
            str: Blif logic gate subcomponent description.
        """
        gate_block = type(self)(a=Wire(name="a"), prefix="out")
        return f"{gate_block.get_prototype_blif_hier()}" + \
               f"{gate_block.get_declaration_blif()}" + \
               f"{gate_block.get_function_blif()}" + \
               f".end\n"

    def get_invocation_blif_hier(self, top_modul: bool = False, *args, **kwargs):
        """Generates Blif code invocation of corresponding one input logic gate's generated subcomponent.

        Args:
            top_modul (bool, optional): Specifies whether the described circuit has logic gate as its top modul component (used for self logic gate generation). Defaults to False.

        Returns:
            str: Blif logic gate subcomponent invocation.
        """
        # No function block is generated if one of the inputs is a wire with constant value.
        # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
        if self.disable_generation and top_modul is False:
            return ""
        else:
            return f".subckt {self.gate_type} a={self.a.get_wire_value_blif()} out={self.out.get_wire_value_blif()}\n"

    """ CGP CODE GENERATION """
    # FLAT CGP #
    def get_triplet_cgp(self, a_id: int, out_id: int):
        """Generates logic gate triplet (first input wire, second input wire, logic gate function) using wires unique position indexes within the described circuit.

        Each triplet represents unique logic gate within the described circuit. In this case of one input logic gate, the same input wire index is driven to both inputs.
        Besides the contained input wires indexes and gate's inner logic function, an output wire with incremented index position is also created and remembered to be
        appropriately driven as an input to another logic gate or as the circuit's output.

        Constant wire with value 0 has constant index of 0.
        Constant wire with value 1 has constant index of 1.
        Other wires indexes start counting from 2 and up.

        Args:
            a_id (int): First (used also as the second) input wire index position.
            out_id (int): Outpu wire index position

        Returns:
            str: Triplet describing function of corresponding one input logic gate.
        """
        return f"([{out_id}]{a_id},{a_id},{self.cgp_function})"

    @staticmethod
    def get_output_cgp(out_id: int):
        """Generates list of output wires indexes of described one input logic gate from MSB to LSB.

        Args:
            out_id (int): Output wire index position.

        Returns:
            str: List containing logic gate's output wire indexes (one in this case).
        """
        return f"({out_id})"

    def get_gate_triplet_cgp(self):
        """Generates flat CGP triplet and output representation of corresponding logic gate itself.

        Returns:
            str: Triplet and output lists describing function of corresponding one input logic gate.
        """
        if self.a.is_const():
            a_id = self.a.cgp_const
        else:
            a_id = 2

        if self.out.is_const():
            out_id = self.out.cgp_const
        else:
            out_id = a_id+1 if a_id == 2 else 2
        return self.get_triplet_cgp(a_id=a_id, out_id=out_id) + self.get_output_cgp(out_id=out_id)

Ancestors

Subclasses

Static methods

def get_output_cgp(out_id: int)

Generates list of output wires indexes of described one input logic gate from MSB to LSB.

Args

out_id : int
Output wire index position.

Returns

str
List containing logic gate's output wire indexes (one in this case).
Expand source code
@staticmethod
def get_output_cgp(out_id: int):
    """Generates list of output wires indexes of described one input logic gate from MSB to LSB.

    Args:
        out_id (int): Output wire index position.

    Returns:
        str: List containing logic gate's output wire indexes (one in this case).
    """
    return f"({out_id})"

Methods

def get_declaration_blif(self)

Generates Blif code declaration of one input logic gate's wires.

Returns

str
Blif logic gate's wires declaration.
Expand source code
def get_declaration_blif(self):
    """Generates Blif code declaration of one input logic gate's wires.

    Returns:
        str: Blif logic gate's wires declaration.
    """
    return f".inputs {self.a.get_wire_declaration_blif()}\n" + \
           f".outputs" + \
           "".join([f" {self.out.name}\n" if self.disable_generation is False else f" {self.out.name}_out\n" for _ in range(1)]) + \
           f".names vdd\n1\n" + \
           f".names gnd\n0\n"
def get_function_block_blif(self)

Generates Blif code representation of corresponding one input logic gate used as subcomponent in hierarchical circuit description.

Returns

str
Blif logic gate subcomponent description.
Expand source code
def get_function_block_blif(self):
    """Generates Blif code representation of corresponding one input logic gate used as subcomponent in hierarchical circuit description.

    Returns:
        str: Blif logic gate subcomponent description.
    """
    gate_block = type(self)(a=Wire(name="a"), prefix="out")
    return f"{gate_block.get_prototype_blif_hier()}" + \
           f"{gate_block.get_declaration_blif()}" + \
           f"{gate_block.get_function_blif()}" + \
           f".end\n"
def get_function_block_v(self)

Generates Verilog code representation of corresponding logic gate used as a function block in hierarchical circuit description.

Returns

str
Verilog code of logic gate's function block description.
Expand source code
def get_function_block_v(self):
    """Generates Verilog code representation of corresponding logic gate used as a function block in hierarchical circuit description.

    Returns:
        str: Verilog code of logic gate's function block description.
    """
    gate_block = type(self)(a=Wire(name="a"), prefix="out")
    return f"{gate_block.get_prototype_v_hier()}" + \
           f"  assign {gate_block.out.name} = {gate_block.get_function_v()};\n" + \
           f"endmodule\n\n"
def get_function_c(self)

Generates C code representing corresponding one input logic gate's Boolean function using bitwise operators between its bitwise shifted input.

Returns

str
C code description of logic gate's Boolean function (with bitwise shifted input).
Expand source code
def get_function_c(self):
    """Generates C code representing corresponding one input logic gate's Boolean function using bitwise operators between its bitwise shifted input.

    Returns:
        str: C code description of logic gate's Boolean function (with bitwise shifted input).
    """
    return f"{self.operator}({self.a.get_wire_value_c_flat()}) & 0x01"
def get_function_v(self)

Generates Verilog code representing corresponding one input logic gate's Boolean function using bitwise operators between its input.

Returns

str
Verilog description of logic gate's Boolean function.
Expand source code
def get_function_v(self):
    """Generates Verilog code representing corresponding one input logic gate's Boolean function using bitwise operators between its input.

    Returns:
        str: Verilog description of logic gate's Boolean function.
    """
    return f"{self.operator}{self.a.get_wire_value_v_flat()}"
def get_gate_triplet_cgp(self)

Generates flat CGP triplet and output representation of corresponding logic gate itself.

Returns

str
Triplet and output lists describing function of corresponding one input logic gate.
Expand source code
def get_gate_triplet_cgp(self):
    """Generates flat CGP triplet and output representation of corresponding logic gate itself.

    Returns:
        str: Triplet and output lists describing function of corresponding one input logic gate.
    """
    if self.a.is_const():
        a_id = self.a.cgp_const
    else:
        a_id = 2

    if self.out.is_const():
        out_id = self.out.cgp_const
    else:
        out_id = a_id+1 if a_id == 2 else 2
    return self.get_triplet_cgp(a_id=a_id, out_id=out_id) + self.get_output_cgp(out_id=out_id)
def get_invocation_blif_hier(self, top_modul: bool = False, *args, **kwargs)

Generates Blif code invocation of corresponding one input logic gate's generated subcomponent.

Args

top_modul : bool, optional
Specifies whether the described circuit has logic gate as its top modul component (used for self logic gate generation). Defaults to False.

Returns

str
Blif logic gate subcomponent invocation.
Expand source code
def get_invocation_blif_hier(self, top_modul: bool = False, *args, **kwargs):
    """Generates Blif code invocation of corresponding one input logic gate's generated subcomponent.

    Args:
        top_modul (bool, optional): Specifies whether the described circuit has logic gate as its top modul component (used for self logic gate generation). Defaults to False.

    Returns:
        str: Blif logic gate subcomponent invocation.
    """
    # No function block is generated if one of the inputs is a wire with constant value.
    # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
    if self.disable_generation and top_modul is False:
        return ""
    else:
        return f".subckt {self.gate_type} a={self.a.get_wire_value_blif()} out={self.out.get_wire_value_blif()}\n"
def get_prototype_c_flat(self)

Generates flat C code function header to describe corresponding one input logic gate's interface in flat C code.

Returns

str
Function's name and parameter in flat C code.
Expand source code
def get_prototype_c_flat(self):
    """Generates flat C code function header to describe corresponding one input logic gate's interface in flat C code.

    Returns:
        str: Function's name and parameter in flat C code.
    """
    return f"uint8_t {self.prefix}(uint8_t {self.a.name})" + "{" + "\n"
def get_prototype_c_hier(self)

Generates hierarchical C code function header to describe corresponding one input logic gate's interface in hierarchical C code.

Returns

str
Function's name and parameters in hierarchical C code.
Expand source code
def get_prototype_c_hier(self):
    """Generates hierarchical C code function header to describe corresponding one input logic gate's interface in hierarchical C code.

    Returns:
        str: Function's name and parameters in hierarchical C code.
    """
    return f"uint8_t {self.gate_type}(uint8_t {self.a.name})" + "{" + "\n"
def get_prototype_v_flat(self)

Generates flat Verilog module header to describe corresponding one input logic gate's interface in flat Verilog.

Returns

str
Module's name and parameter in flat Verilog.
Expand source code
def get_prototype_v_flat(self):
    """Generates flat Verilog module header to describe corresponding one input logic gate's interface in flat Verilog.

    Returns:
        str: Module's name and parameter in flat Verilog.
    """
    return f"module {self.prefix}(input {self.a.name}" + \
           "".join([f", output {self.out.name});\n" if self.disable_generation is False else f", output {self.out.name}_out);\n" for _ in range(1)])
def get_prototype_v_hier(self)

Generates hierarchical Verilog module header to describe corresponding one input logic gate's interface in hierarchical Verilog.

Returns

str
Module's name and parameter in hierarchical Verilog.
Expand source code
def get_prototype_v_hier(self):
    """Generates hierarchical Verilog module header to describe corresponding one input logic gate's interface in hierarchical Verilog.

    Returns:
        str: Module's name and parameter in hierarchical Verilog.
    """
    return f"module {self.gate_type}(input {self.a.name}, output {self.out.name});\n"
def get_triplet_cgp(self, a_id: int, out_id: int)

Generates logic gate triplet (first input wire, second input wire, logic gate function) using wires unique position indexes within the described circuit.

Each triplet represents unique logic gate within the described circuit. In this case of one input logic gate, the same input wire index is driven to both inputs. Besides the contained input wires indexes and gate's inner logic function, an output wire with incremented index position is also created and remembered to be appropriately driven as an input to another logic gate or as the circuit's output.

Constant wire with value 0 has constant index of 0. Constant wire with value 1 has constant index of 1. Other wires indexes start counting from 2 and up.

Args

a_id : int
First (used also as the second) input wire index position.
out_id : int
Outpu wire index position

Returns

str
Triplet describing function of corresponding one input logic gate.
Expand source code
def get_triplet_cgp(self, a_id: int, out_id: int):
    """Generates logic gate triplet (first input wire, second input wire, logic gate function) using wires unique position indexes within the described circuit.

    Each triplet represents unique logic gate within the described circuit. In this case of one input logic gate, the same input wire index is driven to both inputs.
    Besides the contained input wires indexes and gate's inner logic function, an output wire with incremented index position is also created and remembered to be
    appropriately driven as an input to another logic gate or as the circuit's output.

    Constant wire with value 0 has constant index of 0.
    Constant wire with value 1 has constant index of 1.
    Other wires indexes start counting from 2 and up.

    Args:
        a_id (int): First (used also as the second) input wire index position.
        out_id (int): Outpu wire index position

    Returns:
        str: Triplet describing function of corresponding one input logic gate.
    """
    return f"([{out_id}]{a_id},{a_id},{self.cgp_function})"

Inherited members

class TwoInputInvertedLogicGate (a: Wire,
b: Wire,
prefix: str = 'gate',
outid: int = 0,
parent_component: object = None)

Class representing two input inverted logic gates.

   ┌──────┐
──►│ FUNC │
   │      │O──►
──►│      │
   └──────┘

Description of the init method.

Args

a : Wire
First input wire.
b : Wire
Second input wire.
prefix : str, optional
Prefix name of logic gate. Defaults to "gate".
outid : int, optional
Index of output wire. Defaults to 0.

parent_component (object, optional) Object of upper component of which logic gate is a subcomponent. Defaults to None.

Expand source code
class TwoInputInvertedLogicGate(TwoInputLogicGate):
    """Class representing two input inverted logic gates.

    ```
       ┌──────┐
    ──►│ FUNC │
       │      │O──►
    ──►│      │
       └──────┘
    ```

    Description of the __init__ method.

    Args:
        a (Wire): First input wire.
        b (Wire): Second input wire.
        prefix (str, optional): Prefix name of logic gate. Defaults to "gate".
        outid (int, optional): Index of output wire. Defaults to 0.
        parent_component (object, optional) Object of upper component of which logic gate is a subcomponent. Defaults to None.
    """
    def __init__(self, a: Wire, b: Wire, prefix: str = "gate", outid: int = 0, parent_component: object = None):
        super().__init__(a, b, prefix, outid, parent_component)

    """ C CODE GENERATION """
    # FLAT C #
    def get_function_c(self):
        """Generates C code representing corresponding negated two input logic gate's Boolean function using bitwise operators between its bitwise shifted inputs.

        Returns:
            str: C code description of negated logic gate's Boolean function (with bitwise shifted inputs).
        """
        return "~("+(super().get_function_c()) + ") & 0x01"

    """ VERILOG CODE GENERATION """
    # FLAT VERILOG #
    def get_function_v(self):
        """Generates Verilog code representing corresponding negated two input logic gate's Boolean function using bitwise operators between its inputs.

        Returns:
            str: Verilog description of negated logic gate's Boolean function.
        """
        return "~("+(super().get_function_v())+")"

Ancestors

Subclasses

Methods

def get_function_c(self)

Generates C code representing corresponding negated two input logic gate's Boolean function using bitwise operators between its bitwise shifted inputs.

Returns

str
C code description of negated logic gate's Boolean function (with bitwise shifted inputs).
Expand source code
def get_function_c(self):
    """Generates C code representing corresponding negated two input logic gate's Boolean function using bitwise operators between its bitwise shifted inputs.

    Returns:
        str: C code description of negated logic gate's Boolean function (with bitwise shifted inputs).
    """
    return "~("+(super().get_function_c()) + ") & 0x01"
def get_function_v(self)

Generates Verilog code representing corresponding negated two input logic gate's Boolean function using bitwise operators between its inputs.

Returns

str
Verilog description of negated logic gate's Boolean function.
Expand source code
def get_function_v(self):
    """Generates Verilog code representing corresponding negated two input logic gate's Boolean function using bitwise operators between its inputs.

    Returns:
        str: Verilog description of negated logic gate's Boolean function.
    """
    return "~("+(super().get_function_v())+")"

Inherited members

class TwoInputLogicGate (a: Wire,
b: Wire,
prefix: str = 'gate',
outid: int = 0,
parent_component: object = None)

Class representing two input logic gates.

   ┌──────┐
──►│ FUNC │
   │      ├─►
──►│      │
   └──────┘

Description of the init method.

Args

a : Wire
First input wire.
b : Wire
Second input wire.
prefix : str, optional
Prefix name of logic gate. Defaults to "gate".
outid : int, optional
Index of output wire. Defaults to 0.

parent_component (object, optional) Object of upper component of which logic gate is a subcomponent. Defaults to None.

Expand source code
class TwoInputLogicGate():
    """Class representing two input logic gates.

    ```
       ┌──────┐
    ──►│ FUNC │
       │      ├─►
    ──►│      │
       └──────┘
    ```

    Description of the __init__ method.

    Args:
        a (Wire): First input wire.
        b (Wire): Second input wire.
        prefix (str, optional): Prefix name of logic gate. Defaults to "gate".
        outid (int, optional): Index of output wire. Defaults to 0.
        parent_component (object, optional) Object of upper component of which logic gate is a subcomponent. Defaults to None.
    """
    def __init__(self, a: Wire, b: Wire, prefix: str = "gate", outid: int = 0, parent_component: object = None):
        self.a = a
        self.b = b
        self.prefix = prefix
        self.outid = outid
        # To toggle whether logic gate function ought to be generated or to be replaced
        # by a constant wire for the sake of more optimized circuit generation
        self.disable_generation = False
        # Obtaining the caller object to gain access into its `components` list Used for adding NOT gates as a replacement for two input logic gates with constant input (optimalization)
        # Also used to obtain caller object's `prefix` name for proper wire names generation of flat/hier representations
        self.parent_component = parent_component

    """ C CODE GENERATION """
    # FLAT C #
    @staticmethod
    def get_includes_c():
        """Generates necessary C library includes for output representation.

        Returns:
            str: C code library includes.
        """
        return f"#include <stdio.h>\n#include <stdint.h>\n\n"

    def get_prototype_c_flat(self):
        """Generates flat C code function header to describe corresponding two input logic gate's interface in flat C code.

        Returns:
            str: Function's name and parameters in flat C code.
        """
        return f"uint8_t {self.prefix}(uint8_t {self.a.name}, uint8_t {self.b.name})" + "{" + "\n"

    def get_function_c(self):
        """Generates C code representing corresponding two input logic gate's Boolean function using bitwise operators between its bitwise shifted inputs.

        Returns:
            str: C code description of logic gate's Boolean function (with bitwise shifted inputs).
        """
        if self.out.is_const():
            return self.out.get_wire_value_c_flat()
        return f"{self.a.get_wire_value_c_flat()} {self.operator} {self.b.get_wire_value_c_flat()}"

    def get_declaration_c_flat(self):
        """Generates C code declaration of output wire for flat representation.

        Returns:
            str: C code logic gate's output wire declaration.
        """
        # No gate output wire is generated if one of the inputs is a wire with constant value.
        # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
        if self.disable_generation:
            return ""
        else:
            return f"{self.out.get_declaration_c()}"

    def get_assign_c_flat(self):
        """Generates C code for invocation of logical functions and subsequently provides assignment to their output.

        Returns:
            str: C code invocation of logical function and assignment to output.
        """
        # No gate logic is generated if one of the inputs is a wire with constant value.
        # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
        if self.disable_generation:
            return ""
        else:
            return f"  {self.out.prefix} = {self.get_function_c()};\n"

    # Generating flat C code representation of the logic gate itself
    # (I.e. not as a component of bigger circuit)
    def get_c_code(self, file_object):
        """Generates flat C code representation of corresponding logic gate itself.

        Args:
            file_object (TextIOWrapper): Destination file object where circuit's representation will be written to.
        """
        file_object.write(self.get_includes_c())
        file_object.write(self.get_prototype_c_flat())
        file_object.write("  return "+(self.get_function_c())+";\n}")

    # HIERARCHICAL C #
    def get_prototype_c_hier(self):
        """Generates hierarchical C code function header to describe corresponding two input logic gate's interface in hierarchical C code.

        Returns:
            str: Function's name and parameters in hierarchical C code.
        """
        return f"uint8_t {self.gate_type}(uint8_t {self.a.name}, uint8_t {self.b.name})" + "{" + "\n"

    def get_function_block_c(self):
        """Generates C code representation of corresponding logic gate used as a function block in hierarchical circuit description.

        Returns:
            str: C code of logic gate's function block description.
        """
        gate_block = type(self)(a=Wire(name="a"), b=Wire(name="b"))
        return f"{gate_block.get_prototype_c_hier()}" + \
               f"  return "+(gate_block.get_function_c())+";\n}\n\n"

    def get_declaration_c_hier(self):
        """Generates C code declaration of output wire for hierarchical representation.

        Returns:
            str: C code logic gate's output wire declaration.
        """
        # No gate output wire is generated if one of the inputs is a wire with constant value.
        # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
        if self.disable_generation:
            return ""
        else:
            return f"{self.out.get_declaration_c()}"

    def get_gate_invocation_c(self):
        """Generates C code invocation of corresponding logic gate's generated function block.

        Returns:
            str: C code of logic gate's function block invocation.
        """
        # No function block is generated if one of the inputs is a wire with constant value.
        # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
        if self.disable_generation:
            return ""
        else:
            return f"  {self.out.name} = {self.gate_type}({self.a.get_wire_value_c_hier()}, {self.b.get_wire_value_c_hier()});\n"

    """ PYTHON CODE GENERATION """
    # FLAT PYTHON #
    def get_assign_python_flat(self):
        """Generates Python code for invocation of logical functions and subsequently provides assignment to their output.

        Returns:
            str: Python code invocation of logical function and assignment to output.
        """
        # No gate logic is generated if one of the inputs is a wire with constant value.
        # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
        if self.disable_generation:
            #return f"  {self.out.prefix} = {self.get_function_c()} # DD {self.prefix} \n"

            return ""
        else:
            return f"  {self.out.prefix} = {self.get_function_c()}\n"

    """ VERILOG CODE GENERATION """
    # FLAT VERILOG #
    def get_prototype_v_flat(self):
        """Generates flat Verilog module header to describe corresponding two input logic gate's interface in flat Verilog.

        Returns:
            str: Module's name and parameters in flat Verilog.
        """
        return f"module {self.prefix}(input {self.a.name}, input {self.b.name}" + \
               "".join([f", output {self.out.name}" if self.disable_generation is False else f", output {self.out.name}_out" for _ in range(1)]) + ");\n"

    def get_output_v_flat(self):
        """Generates flat Verilog module's output wire assignment used for self logic gate circuit generation.

        Returns:
            str: Module's output wire assignment in flat Verilog.
        """
        return "".join([f"  assign {self.out.name} = {self.get_function_v()};\n" if self.disable_generation is False else f"  assign {self.out.name}_out = {self.get_function_v()};\n" for _ in range(1)])

    def get_declaration_v_flat(self):
        """Generates Verilog code declaration of output wire for flat representation.

        Returns:
            str: Verilog code logic gate's output wire declaration.
        """
        # No gate output wire is generated if one of the inputs is a wire with constant value.
        # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
        if self.disable_generation:
            return ""
        else:
            return f"{self.out.get_declaration_v_flat()}"

    def get_function_v(self):
        """Generates Verilog code representing corresponding two input logic gate's Boolean function using bitwise operators between its inputs.

        Returns:
            str: Verilog description of logic gate's Boolean function.
        """
        return f"{self.a.get_wire_value_v_flat()} {self.operator} {self.b.get_wire_value_v_flat()}"

    def get_assign_v_flat(self):
        """Generates Verilog code for invocation of logical functions and subsequently provides assignment to their output.

        Returns:
            str: Verilog code invocation of logical function and assignment to output.
        """
        # No gate logic is generated if one of the inputs is a wire with constant value.
        # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
        if self.disable_generation:
            return ""
        else:
            return f"  assign {self.out.prefix} = {self.get_function_v()};\n"

    # Generating flat Verilog code representation of the logic gate itself
    # (I.e. not as a component of bigger circuit)
    def get_v_code(self, file_object):
        """Generates flat Verilog code representation of corresponding logic gate itself.

        Args:
            file_object (TextIOWrapper): Destination file object where circuit's representation will be written to.
        """
        file_object.write(self.get_prototype_v_flat())
        file_object.write(self.get_output_v_flat())
        file_object.write(f"endmodule")

    # HIERARCHICAL VERILOG #
    def get_prototype_v_hier(self):
        """Generates hierarchical Verilog module header to describe corresponding two input logic gate's interface in hierarchical Verilog.

        Returns:
            str: Module's name and parameters in hierarchical Verilog.
        """
        return f"module {self.gate_type}(input {self.a.name}, input {self.b.name}, output {self.out.name});\n"

    def get_function_block_v(self):
        """Generates Verilog code representation of corresponding logic gate used as function block in hierarchical circuit description.

        Returns:
            str: Verilog logic gate's function block description.
        """
        gate_block = type(self)(a=Wire(name="a"), b=Wire(name="b"), prefix="out")
        return f"{gate_block.get_prototype_v_hier()}" + \
               f"  assign {gate_block.out.name} = {gate_block.get_function_v()};\n" + \
               f"endmodule\n\n"

    def get_declaration_v_hier(self):
        """Generates Verilog code declaration of output wire for hierarchical representation.

        Returns:
            str: Verilog code logic gate's output wire declaration.
        """
        # No gate output wire is generated if one of the inputs is a wire with constant value.
        # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
        if self.disable_generation:
            return ""
        else:
            return f"{self.out.get_declaration_v_hier()}"

    def get_gate_invocation_v(self):
        """Generates Verilog code invocation of corresponding logic gate's generated function block.

        Returns:
            str: Verilog code logic gate's function block invocation.
        """
        # No function block is generated if one of the inputs is a wire with constant value.
        # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
        if self.disable_generation:
            return ""
        else:
            gate_block = self.__class__(a=Wire(name="a"), b=Wire(name="b"), prefix="out")
            return f"  {self.gate_type} {self.gate_type}_{self.out.prefix}(.{gate_block.a.prefix}({self.a.get_wire_value_v_hier()}), .{gate_block.b.prefix}({self.b.get_wire_value_v_hier()}), .{gate_block.out.prefix}({self.out.prefix}));\n"

    """ BLIF CODE GENERATION """
    # FLAT BLIF #
    def get_prototype_blif_flat(self):
        """Generates flat Blif model header to describe corresponding logic gate's interface in flat Blif.

        Returns:
            str: Model's name in flat Blif code.
        """
        return f".model {self.prefix}\n"

    def get_declaration_blif(self):
        """Generates Blif code declaration of two input logic gate's wires.

        Returns:
            str: Blif logic gate's wires declaration.
        """
        return f".inputs {self.a.get_wire_declaration_blif()}{self.b.get_wire_declaration_blif()}\n" + \
               f".outputs" + \
               "".join([f" {self.out.name}\n" if self.disable_generation is False else f" {self.out.name}_out\n" for _ in range(1)]) + \
               f".names vdd\n1\n" + \
               f".names gnd\n0\n"

    def get_function_blif_flat(self, top_modul: bool = False):
        """Generates Blif code representing corresponding two input logic gate's Boolean function between its inputs.

        Invokes corresponding logic gate's `get_function_blif` method for its individual description of logic function.

        Args:
            top_modul (bool, optional): Specifies whether the described circuit has logic gate as its top modul component (used for self logic gate generation). Defaults to False.

        Returns:
            str: Blif description of logic gate's Boolean function.
        """
        if top_modul is True:
            return f"{self.get_function_blif()}"
        # No function block is generated if one of the inputs is a wire with constant value.
        # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
        elif self.disable_generation:
            return ""
        else:
            return f"{self.get_function_blif()}"

    # Generating flat BLIF code representation of the logic gate itself
    # (I.e. not as a component of bigger circuit)
    def get_blif_code(self, file_object):
        """Generates flat Blif code representation of corresponding logic gate itself.

        Args:
            file_object (TextIOWrapper): Destination file object where circuit's representation will be written to.
        """
        file_object.write(self.get_prototype_blif_flat())
        file_object.write(self.get_declaration_blif())
        file_object.write(self.get_function_blif_flat(top_modul=True))
        file_object.write(f".end\n")

    # HIERARCHICAL BLIF #
    def get_prototype_blif_hier(self):
        """Generates hierarchical Blif model header to describe corresponding logic gate's interface in hierarchical Blif.

        Returns:
            str: Model's name in hierarchical Blif.
        """
        return f".model {self.gate_type}\n"

    def get_function_block_blif(self):
        """Generates Blif code representation of corresponding two input logic gate used as subcomponent in hierarchical circuit description.

        Returns:
            str: Blif logic gate subcomponent description.
        """
        gate_block = type(self)(a=Wire(name="a"), b=Wire(name="b"), prefix="out")
        return f"{gate_block.get_prototype_blif_hier()}" + \
               f"{gate_block.get_declaration_blif()}" + \
               f"{gate_block.get_function_blif()}" + \
               f".end\n"

    def get_invocation_blif_hier(self, top_modul: bool = False, *args, **kwargs):
        """Generates Blif code invocation of corresponding two input logic gate's generated subcomponent.

        Args:
            top_modul (bool, optional): Specifies whether the described circuit has logic gate as its top modul component (used for self logic gate generation). Defaults to False.

        Returns:
            str: Blif logic gate subcomponent invocation.
        """
        # No function block is generated if one of the inputs is a wire with constant value.
        # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
        if self.disable_generation and top_modul is False:
            return ""
        else:
            return f".subckt {self.gate_type} a={self.a.get_wire_value_blif()} b={self.b.get_wire_value_blif()} out={self.out.get_wire_value_blif()}\n"

    """ CGP CODE GENERATION """
    # FLAT CGP #
    @staticmethod
    def get_parameters_cgp():
        """Generates CGP chromosome parameters of corresponding logic gate.

        In total seven parameters represent: total inputs, total outputs, number of rows, number of columns (gates),
        number of each gate's inputs, number of each gate's outputs, quality constant value.

        Returns:
            str: CGP chromosome parameters of described logic gate.
        """
        return "{2,1,1,1,2,1,0}"

    def get_triplet_cgp(self, a_id: int, b_id: int, out_id: int):
        """Generates logic gate triplet (first input wire, second input wire, logic gate function) using wires unique position indexes within the described circuit.

        Each triplet represents unique logic gate within the described circuit. Besides the contained input wires indexes and gate's inner logic function, an output wire
        with incremented index position is also created and remembered to be appropriately driven as an input to another logic gate or as the circuit's output.

        Constant wire with value 0 has constant index of 0.
        Constant wire with value 1 has constant index of 1.
        Other wires indexes start counting from 2 and up.

        Args:
            a_id (int): First input wire index position.
            b_id (int): Second input wire index position.
            out_id (int): The output wire index position

        Returns:
            str: Triplet describing function of corresponding two input logic gate.
        """
        return f"([{out_id}]{a_id},{b_id},{self.cgp_function})"

    @staticmethod
    def get_output_cgp(out_id: int):
        """Generates list of output wires indexes of described two input logic gate from MSB to LSB.

        Args:
            out_id (int): Output wire index position.

        Returns:
            str: List containing logic gate's output wire indexes (one in this case).
        """
        return f"({out_id})"

    def get_gate_triplet_cgp(self):
        """Generates flat CGP triplet and output representation of corresponding logic gate itself.

        Returns:
            str: Triplet and output lists describing function of corresponding two input logic gate.
        """
        if self.a.is_const() and self.b.is_const():
            a_id = self.a.cgp_const
            b_id = self.b.cgp_const
        elif self.a.is_const():
            a_id = self.a.cgp_const
            b_id = 2
        elif self.b.is_const():
            a_id = 2
            b_id = self.b.cgp_const
        else:
            a_id = 2
            b_id = 3

        if self.out.is_const():
            out_id = self.out.cgp_const
        else:
            out_id = a_id+1 if a_id > b_id else b_id+1
        return self.get_triplet_cgp(a_id=a_id, b_id=b_id, out_id=out_id) + self.get_output_cgp(out_id=out_id)

    def get_cgp_code(self, file_object):
        """Generates flat CGP chromosome representation of corresponding logic gate itself.

        Args:
            file_object (TextIOWrapper): Destination file object where circuit's representation will be written to.
        """
        file_object.write(self.get_parameters_cgp())
        file_object.write(self.get_gate_triplet_cgp())

Subclasses

Static methods

def get_includes_c()

Generates necessary C library includes for output representation.

Returns

str
C code library includes.
Expand source code
@staticmethod
def get_includes_c():
    """Generates necessary C library includes for output representation.

    Returns:
        str: C code library includes.
    """
    return f"#include <stdio.h>\n#include <stdint.h>\n\n"
def get_output_cgp(out_id: int)

Generates list of output wires indexes of described two input logic gate from MSB to LSB.

Args

out_id : int
Output wire index position.

Returns

str
List containing logic gate's output wire indexes (one in this case).
Expand source code
@staticmethod
def get_output_cgp(out_id: int):
    """Generates list of output wires indexes of described two input logic gate from MSB to LSB.

    Args:
        out_id (int): Output wire index position.

    Returns:
        str: List containing logic gate's output wire indexes (one in this case).
    """
    return f"({out_id})"
def get_parameters_cgp()

Generates CGP chromosome parameters of corresponding logic gate.

In total seven parameters represent: total inputs, total outputs, number of rows, number of columns (gates), number of each gate's inputs, number of each gate's outputs, quality constant value.

Returns

str
CGP chromosome parameters of described logic gate.
Expand source code
@staticmethod
def get_parameters_cgp():
    """Generates CGP chromosome parameters of corresponding logic gate.

    In total seven parameters represent: total inputs, total outputs, number of rows, number of columns (gates),
    number of each gate's inputs, number of each gate's outputs, quality constant value.

    Returns:
        str: CGP chromosome parameters of described logic gate.
    """
    return "{2,1,1,1,2,1,0}"

Methods

def get_assign_c_flat(self)

Generates C code for invocation of logical functions and subsequently provides assignment to their output.

Returns

str
C code invocation of logical function and assignment to output.
Expand source code
def get_assign_c_flat(self):
    """Generates C code for invocation of logical functions and subsequently provides assignment to their output.

    Returns:
        str: C code invocation of logical function and assignment to output.
    """
    # No gate logic is generated if one of the inputs is a wire with constant value.
    # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
    if self.disable_generation:
        return ""
    else:
        return f"  {self.out.prefix} = {self.get_function_c()};\n"
def get_assign_python_flat(self)

Generates Python code for invocation of logical functions and subsequently provides assignment to their output.

Returns

str
Python code invocation of logical function and assignment to output.
Expand source code
def get_assign_python_flat(self):
    """Generates Python code for invocation of logical functions and subsequently provides assignment to their output.

    Returns:
        str: Python code invocation of logical function and assignment to output.
    """
    # No gate logic is generated if one of the inputs is a wire with constant value.
    # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
    if self.disable_generation:
        #return f"  {self.out.prefix} = {self.get_function_c()} # DD {self.prefix} \n"

        return ""
    else:
        return f"  {self.out.prefix} = {self.get_function_c()}\n"
def get_assign_v_flat(self)

Generates Verilog code for invocation of logical functions and subsequently provides assignment to their output.

Returns

str
Verilog code invocation of logical function and assignment to output.
Expand source code
def get_assign_v_flat(self):
    """Generates Verilog code for invocation of logical functions and subsequently provides assignment to their output.

    Returns:
        str: Verilog code invocation of logical function and assignment to output.
    """
    # No gate logic is generated if one of the inputs is a wire with constant value.
    # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
    if self.disable_generation:
        return ""
    else:
        return f"  assign {self.out.prefix} = {self.get_function_v()};\n"
def get_blif_code(self, file_object)

Generates flat Blif code representation of corresponding logic gate itself.

Args

file_object : TextIOWrapper
Destination file object where circuit's representation will be written to.
Expand source code
def get_blif_code(self, file_object):
    """Generates flat Blif code representation of corresponding logic gate itself.

    Args:
        file_object (TextIOWrapper): Destination file object where circuit's representation will be written to.
    """
    file_object.write(self.get_prototype_blif_flat())
    file_object.write(self.get_declaration_blif())
    file_object.write(self.get_function_blif_flat(top_modul=True))
    file_object.write(f".end\n")
def get_c_code(self, file_object)

Generates flat C code representation of corresponding logic gate itself.

Args

file_object : TextIOWrapper
Destination file object where circuit's representation will be written to.
Expand source code
def get_c_code(self, file_object):
    """Generates flat C code representation of corresponding logic gate itself.

    Args:
        file_object (TextIOWrapper): Destination file object where circuit's representation will be written to.
    """
    file_object.write(self.get_includes_c())
    file_object.write(self.get_prototype_c_flat())
    file_object.write("  return "+(self.get_function_c())+";\n}")
def get_cgp_code(self, file_object)

Generates flat CGP chromosome representation of corresponding logic gate itself.

Args

file_object : TextIOWrapper
Destination file object where circuit's representation will be written to.
Expand source code
def get_cgp_code(self, file_object):
    """Generates flat CGP chromosome representation of corresponding logic gate itself.

    Args:
        file_object (TextIOWrapper): Destination file object where circuit's representation will be written to.
    """
    file_object.write(self.get_parameters_cgp())
    file_object.write(self.get_gate_triplet_cgp())
def get_declaration_blif(self)

Generates Blif code declaration of two input logic gate's wires.

Returns

str
Blif logic gate's wires declaration.
Expand source code
def get_declaration_blif(self):
    """Generates Blif code declaration of two input logic gate's wires.

    Returns:
        str: Blif logic gate's wires declaration.
    """
    return f".inputs {self.a.get_wire_declaration_blif()}{self.b.get_wire_declaration_blif()}\n" + \
           f".outputs" + \
           "".join([f" {self.out.name}\n" if self.disable_generation is False else f" {self.out.name}_out\n" for _ in range(1)]) + \
           f".names vdd\n1\n" + \
           f".names gnd\n0\n"
def get_declaration_c_flat(self)

Generates C code declaration of output wire for flat representation.

Returns

str
C code logic gate's output wire declaration.
Expand source code
def get_declaration_c_flat(self):
    """Generates C code declaration of output wire for flat representation.

    Returns:
        str: C code logic gate's output wire declaration.
    """
    # No gate output wire is generated if one of the inputs is a wire with constant value.
    # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
    if self.disable_generation:
        return ""
    else:
        return f"{self.out.get_declaration_c()}"
def get_declaration_c_hier(self)

Generates C code declaration of output wire for hierarchical representation.

Returns

str
C code logic gate's output wire declaration.
Expand source code
def get_declaration_c_hier(self):
    """Generates C code declaration of output wire for hierarchical representation.

    Returns:
        str: C code logic gate's output wire declaration.
    """
    # No gate output wire is generated if one of the inputs is a wire with constant value.
    # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
    if self.disable_generation:
        return ""
    else:
        return f"{self.out.get_declaration_c()}"
def get_declaration_v_flat(self)

Generates Verilog code declaration of output wire for flat representation.

Returns

str
Verilog code logic gate's output wire declaration.
Expand source code
def get_declaration_v_flat(self):
    """Generates Verilog code declaration of output wire for flat representation.

    Returns:
        str: Verilog code logic gate's output wire declaration.
    """
    # No gate output wire is generated if one of the inputs is a wire with constant value.
    # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
    if self.disable_generation:
        return ""
    else:
        return f"{self.out.get_declaration_v_flat()}"
def get_declaration_v_hier(self)

Generates Verilog code declaration of output wire for hierarchical representation.

Returns

str
Verilog code logic gate's output wire declaration.
Expand source code
def get_declaration_v_hier(self):
    """Generates Verilog code declaration of output wire for hierarchical representation.

    Returns:
        str: Verilog code logic gate's output wire declaration.
    """
    # No gate output wire is generated if one of the inputs is a wire with constant value.
    # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
    if self.disable_generation:
        return ""
    else:
        return f"{self.out.get_declaration_v_hier()}"
def get_function_blif_flat(self, top_modul: bool = False)

Generates Blif code representing corresponding two input logic gate's Boolean function between its inputs.

Invokes corresponding logic gate's get_function_blif method for its individual description of logic function.

Args

top_modul : bool, optional
Specifies whether the described circuit has logic gate as its top modul component (used for self logic gate generation). Defaults to False.

Returns

str
Blif description of logic gate's Boolean function.
Expand source code
def get_function_blif_flat(self, top_modul: bool = False):
    """Generates Blif code representing corresponding two input logic gate's Boolean function between its inputs.

    Invokes corresponding logic gate's `get_function_blif` method for its individual description of logic function.

    Args:
        top_modul (bool, optional): Specifies whether the described circuit has logic gate as its top modul component (used for self logic gate generation). Defaults to False.

    Returns:
        str: Blif description of logic gate's Boolean function.
    """
    if top_modul is True:
        return f"{self.get_function_blif()}"
    # No function block is generated if one of the inputs is a wire with constant value.
    # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
    elif self.disable_generation:
        return ""
    else:
        return f"{self.get_function_blif()}"
def get_function_block_blif(self)

Generates Blif code representation of corresponding two input logic gate used as subcomponent in hierarchical circuit description.

Returns

str
Blif logic gate subcomponent description.
Expand source code
def get_function_block_blif(self):
    """Generates Blif code representation of corresponding two input logic gate used as subcomponent in hierarchical circuit description.

    Returns:
        str: Blif logic gate subcomponent description.
    """
    gate_block = type(self)(a=Wire(name="a"), b=Wire(name="b"), prefix="out")
    return f"{gate_block.get_prototype_blif_hier()}" + \
           f"{gate_block.get_declaration_blif()}" + \
           f"{gate_block.get_function_blif()}" + \
           f".end\n"
def get_function_block_c(self)

Generates C code representation of corresponding logic gate used as a function block in hierarchical circuit description.

Returns

str
C code of logic gate's function block description.
Expand source code
def get_function_block_c(self):
    """Generates C code representation of corresponding logic gate used as a function block in hierarchical circuit description.

    Returns:
        str: C code of logic gate's function block description.
    """
    gate_block = type(self)(a=Wire(name="a"), b=Wire(name="b"))
    return f"{gate_block.get_prototype_c_hier()}" + \
           f"  return "+(gate_block.get_function_c())+";\n}\n\n"
def get_function_block_v(self)

Generates Verilog code representation of corresponding logic gate used as function block in hierarchical circuit description.

Returns

str
Verilog logic gate's function block description.
Expand source code
def get_function_block_v(self):
    """Generates Verilog code representation of corresponding logic gate used as function block in hierarchical circuit description.

    Returns:
        str: Verilog logic gate's function block description.
    """
    gate_block = type(self)(a=Wire(name="a"), b=Wire(name="b"), prefix="out")
    return f"{gate_block.get_prototype_v_hier()}" + \
           f"  assign {gate_block.out.name} = {gate_block.get_function_v()};\n" + \
           f"endmodule\n\n"
def get_function_c(self)

Generates C code representing corresponding two input logic gate's Boolean function using bitwise operators between its bitwise shifted inputs.

Returns

str
C code description of logic gate's Boolean function (with bitwise shifted inputs).
Expand source code
def get_function_c(self):
    """Generates C code representing corresponding two input logic gate's Boolean function using bitwise operators between its bitwise shifted inputs.

    Returns:
        str: C code description of logic gate's Boolean function (with bitwise shifted inputs).
    """
    if self.out.is_const():
        return self.out.get_wire_value_c_flat()
    return f"{self.a.get_wire_value_c_flat()} {self.operator} {self.b.get_wire_value_c_flat()}"
def get_function_v(self)

Generates Verilog code representing corresponding two input logic gate's Boolean function using bitwise operators between its inputs.

Returns

str
Verilog description of logic gate's Boolean function.
Expand source code
def get_function_v(self):
    """Generates Verilog code representing corresponding two input logic gate's Boolean function using bitwise operators between its inputs.

    Returns:
        str: Verilog description of logic gate's Boolean function.
    """
    return f"{self.a.get_wire_value_v_flat()} {self.operator} {self.b.get_wire_value_v_flat()}"
def get_gate_invocation_c(self)

Generates C code invocation of corresponding logic gate's generated function block.

Returns

str
C code of logic gate's function block invocation.
Expand source code
def get_gate_invocation_c(self):
    """Generates C code invocation of corresponding logic gate's generated function block.

    Returns:
        str: C code of logic gate's function block invocation.
    """
    # No function block is generated if one of the inputs is a wire with constant value.
    # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
    if self.disable_generation:
        return ""
    else:
        return f"  {self.out.name} = {self.gate_type}({self.a.get_wire_value_c_hier()}, {self.b.get_wire_value_c_hier()});\n"
def get_gate_invocation_v(self)

Generates Verilog code invocation of corresponding logic gate's generated function block.

Returns

str
Verilog code logic gate's function block invocation.
Expand source code
def get_gate_invocation_v(self):
    """Generates Verilog code invocation of corresponding logic gate's generated function block.

    Returns:
        str: Verilog code logic gate's function block invocation.
    """
    # No function block is generated if one of the inputs is a wire with constant value.
    # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
    if self.disable_generation:
        return ""
    else:
        gate_block = self.__class__(a=Wire(name="a"), b=Wire(name="b"), prefix="out")
        return f"  {self.gate_type} {self.gate_type}_{self.out.prefix}(.{gate_block.a.prefix}({self.a.get_wire_value_v_hier()}), .{gate_block.b.prefix}({self.b.get_wire_value_v_hier()}), .{gate_block.out.prefix}({self.out.prefix}));\n"
def get_gate_triplet_cgp(self)

Generates flat CGP triplet and output representation of corresponding logic gate itself.

Returns

str
Triplet and output lists describing function of corresponding two input logic gate.
Expand source code
def get_gate_triplet_cgp(self):
    """Generates flat CGP triplet and output representation of corresponding logic gate itself.

    Returns:
        str: Triplet and output lists describing function of corresponding two input logic gate.
    """
    if self.a.is_const() and self.b.is_const():
        a_id = self.a.cgp_const
        b_id = self.b.cgp_const
    elif self.a.is_const():
        a_id = self.a.cgp_const
        b_id = 2
    elif self.b.is_const():
        a_id = 2
        b_id = self.b.cgp_const
    else:
        a_id = 2
        b_id = 3

    if self.out.is_const():
        out_id = self.out.cgp_const
    else:
        out_id = a_id+1 if a_id > b_id else b_id+1
    return self.get_triplet_cgp(a_id=a_id, b_id=b_id, out_id=out_id) + self.get_output_cgp(out_id=out_id)
def get_invocation_blif_hier(self, top_modul: bool = False, *args, **kwargs)

Generates Blif code invocation of corresponding two input logic gate's generated subcomponent.

Args

top_modul : bool, optional
Specifies whether the described circuit has logic gate as its top modul component (used for self logic gate generation). Defaults to False.

Returns

str
Blif logic gate subcomponent invocation.
Expand source code
def get_invocation_blif_hier(self, top_modul: bool = False, *args, **kwargs):
    """Generates Blif code invocation of corresponding two input logic gate's generated subcomponent.

    Args:
        top_modul (bool, optional): Specifies whether the described circuit has logic gate as its top modul component (used for self logic gate generation). Defaults to False.

    Returns:
        str: Blif logic gate subcomponent invocation.
    """
    # No function block is generated if one of the inputs is a wire with constant value.
    # I.e. either the constant or the second input wire is propagated to the output for the corresponding logic gate's logic function.
    if self.disable_generation and top_modul is False:
        return ""
    else:
        return f".subckt {self.gate_type} a={self.a.get_wire_value_blif()} b={self.b.get_wire_value_blif()} out={self.out.get_wire_value_blif()}\n"
def get_output_v_flat(self)

Generates flat Verilog module's output wire assignment used for self logic gate circuit generation.

Returns

str
Module's output wire assignment in flat Verilog.
Expand source code
def get_output_v_flat(self):
    """Generates flat Verilog module's output wire assignment used for self logic gate circuit generation.

    Returns:
        str: Module's output wire assignment in flat Verilog.
    """
    return "".join([f"  assign {self.out.name} = {self.get_function_v()};\n" if self.disable_generation is False else f"  assign {self.out.name}_out = {self.get_function_v()};\n" for _ in range(1)])
def get_prototype_blif_flat(self)

Generates flat Blif model header to describe corresponding logic gate's interface in flat Blif.

Returns

str
Model's name in flat Blif code.
Expand source code
def get_prototype_blif_flat(self):
    """Generates flat Blif model header to describe corresponding logic gate's interface in flat Blif.

    Returns:
        str: Model's name in flat Blif code.
    """
    return f".model {self.prefix}\n"
def get_prototype_blif_hier(self)

Generates hierarchical Blif model header to describe corresponding logic gate's interface in hierarchical Blif.

Returns

str
Model's name in hierarchical Blif.
Expand source code
def get_prototype_blif_hier(self):
    """Generates hierarchical Blif model header to describe corresponding logic gate's interface in hierarchical Blif.

    Returns:
        str: Model's name in hierarchical Blif.
    """
    return f".model {self.gate_type}\n"
def get_prototype_c_flat(self)

Generates flat C code function header to describe corresponding two input logic gate's interface in flat C code.

Returns

str
Function's name and parameters in flat C code.
Expand source code
def get_prototype_c_flat(self):
    """Generates flat C code function header to describe corresponding two input logic gate's interface in flat C code.

    Returns:
        str: Function's name and parameters in flat C code.
    """
    return f"uint8_t {self.prefix}(uint8_t {self.a.name}, uint8_t {self.b.name})" + "{" + "\n"
def get_prototype_c_hier(self)

Generates hierarchical C code function header to describe corresponding two input logic gate's interface in hierarchical C code.

Returns

str
Function's name and parameters in hierarchical C code.
Expand source code
def get_prototype_c_hier(self):
    """Generates hierarchical C code function header to describe corresponding two input logic gate's interface in hierarchical C code.

    Returns:
        str: Function's name and parameters in hierarchical C code.
    """
    return f"uint8_t {self.gate_type}(uint8_t {self.a.name}, uint8_t {self.b.name})" + "{" + "\n"
def get_prototype_v_flat(self)

Generates flat Verilog module header to describe corresponding two input logic gate's interface in flat Verilog.

Returns

str
Module's name and parameters in flat Verilog.
Expand source code
def get_prototype_v_flat(self):
    """Generates flat Verilog module header to describe corresponding two input logic gate's interface in flat Verilog.

    Returns:
        str: Module's name and parameters in flat Verilog.
    """
    return f"module {self.prefix}(input {self.a.name}, input {self.b.name}" + \
           "".join([f", output {self.out.name}" if self.disable_generation is False else f", output {self.out.name}_out" for _ in range(1)]) + ");\n"
def get_prototype_v_hier(self)

Generates hierarchical Verilog module header to describe corresponding two input logic gate's interface in hierarchical Verilog.

Returns

str
Module's name and parameters in hierarchical Verilog.
Expand source code
def get_prototype_v_hier(self):
    """Generates hierarchical Verilog module header to describe corresponding two input logic gate's interface in hierarchical Verilog.

    Returns:
        str: Module's name and parameters in hierarchical Verilog.
    """
    return f"module {self.gate_type}(input {self.a.name}, input {self.b.name}, output {self.out.name});\n"
def get_triplet_cgp(self, a_id: int, b_id: int, out_id: int)

Generates logic gate triplet (first input wire, second input wire, logic gate function) using wires unique position indexes within the described circuit.

Each triplet represents unique logic gate within the described circuit. Besides the contained input wires indexes and gate's inner logic function, an output wire with incremented index position is also created and remembered to be appropriately driven as an input to another logic gate or as the circuit's output.

Constant wire with value 0 has constant index of 0. Constant wire with value 1 has constant index of 1. Other wires indexes start counting from 2 and up.

Args

a_id : int
First input wire index position.
b_id : int
Second input wire index position.
out_id : int
The output wire index position

Returns

str
Triplet describing function of corresponding two input logic gate.
Expand source code
def get_triplet_cgp(self, a_id: int, b_id: int, out_id: int):
    """Generates logic gate triplet (first input wire, second input wire, logic gate function) using wires unique position indexes within the described circuit.

    Each triplet represents unique logic gate within the described circuit. Besides the contained input wires indexes and gate's inner logic function, an output wire
    with incremented index position is also created and remembered to be appropriately driven as an input to another logic gate or as the circuit's output.

    Constant wire with value 0 has constant index of 0.
    Constant wire with value 1 has constant index of 1.
    Other wires indexes start counting from 2 and up.

    Args:
        a_id (int): First input wire index position.
        b_id (int): Second input wire index position.
        out_id (int): The output wire index position

    Returns:
        str: Triplet describing function of corresponding two input logic gate.
    """
    return f"([{out_id}]{a_id},{b_id},{self.cgp_function})"
def get_v_code(self, file_object)

Generates flat Verilog code representation of corresponding logic gate itself.

Args

file_object : TextIOWrapper
Destination file object where circuit's representation will be written to.
Expand source code
def get_v_code(self, file_object):
    """Generates flat Verilog code representation of corresponding logic gate itself.

    Args:
        file_object (TextIOWrapper): Destination file object where circuit's representation will be written to.
    """
    file_object.write(self.get_prototype_v_flat())
    file_object.write(self.get_output_v_flat())
    file_object.write(f"endmodule")