DpgenInv
========

-  **Name** : DpgenInv – Inverter Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenInv', modelname
                , param = { 'nbit'       : n
                          , 'drive'      : d
                          , 'physical'   : True
                          , 'behavioral' : True                   
                          }
                )

-  **Description** : Generates a ``n`` bits inverter with an output
   power of ``d`` named ``modelname``.

-  **Terminal Names** :

   -  **i0** : input (``n`` bits)

   -  **nq** : output (``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **drive** (optional) : Defines the output power of the gates

      -  Valid drive are : 1, 2, 4 or 8

      -  If this parameter is not defined, it’s value is the smallest
         one permitted

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **Behavior** :

   ::

       nq <= not ( i0 )

-  **Example** :

   ::

       from stratus import *

       class inst_inv ( Model ) :

         def Interface ( self ) :
           self.i = SignalIn  ( "i", 54 )
           self.o = SignalOut ( "o", 54 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenInv', 'inv_54'
                    , param = { 'nbit'     : 54
                              , 'physical' : True
                              }
                    )      
           self.I = Inst ( 'inv_54', 'inst'
                         , map = { 'i0'  : self.i
                                 , 'nq'  : self.o
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenBuff
=========

-  **Name** : DpgenBuff – Buffer Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenBuff', modelname
                , param = { 'nbit'       : n
                          , 'drive'      : d
                          , 'physical'   : True
                          , 'behavioral' : True                   
                          }
                )

-  **Description** : Generates a ``n`` bits inverter with an output
   power of ``d`` named ``modelname``.

-  **Terminal Names** :

   -  **i0** : input (``n`` bits)

   -  **q** : output (``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **drive** (optional) : Defines the output power of the gates

      -  Valid drive are : 2, 4 or 8

      -  If this parameter is not defined, it’s value is the smallest
         one permitted

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **Behavior** :

   ::

       nq <= i0

-  **Example** :

   ::

       from stratus import *

       class inst_buff ( Model ) :

         def Interface ( self ) :
           self.i = SignalIn  ( "i", 32 )
           self.o = SignalOut ( "o", 32 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenBuff', 'buff_32'
                    , param = { 'nbit'     : 32
                              , 'physical' : True
                              }
                    )
           self.I = Inst ( 'buff_32', 'inst'
                         , map = { 'i0'  : self.i
                                 , 'q'   : self.o
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
             
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenNand2
==========

-  **Name** : DpgenNand2 – Nand2 Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenNand2', modelname
                , param = { 'nbit'       : n
                          , 'drive'      : d
                          , 'physical'   : True
                          , 'behavioral' : True                   
                          }
                )

-  **Description** : Generates a ``n`` bits two inputs NAND with an
   output power of ``d`` named ``modelname``.

-  **Terminal Names** :

   -  **i0** : input (``n`` bits)

   -  **i1** : input (``n`` bits)

   -  **nq** : output (``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **drive** (optional) : Defines the output power of the gates

      -  Valid drive are : 1 or 4

      -  If this parameter is not defined, it’s value is the smallest
         one permitted

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **Behavior** :

   ::

       nq <= not ( i0 and i1 )

-  **Example** :

   ::

       from stratus import *

       class inst_nand2 ( Model ) :

         def Interface ( self ) :
           self.in1 = SignalIn  ( "in1", 8 )
           self.in2 = SignalIn  ( "in2", 8 )
           self.o   = SignalOut (   "o", 8 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenNand2', 'nand2_8'
                    , param = { 'nbit'     : 8
                              , 'physical' : True
                              }
                    )
           self.I = Inst ( 'nand2_8', 'inst'
                         , map = { 'i0'  : self.in1
                                 , 'i1'  : self.in2
                                 , 'nq'  : self.o
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenNand3
==========

-  **Name** : DpgenNand3 – Nand3 Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenNand3', modelname
                , param = { 'nbit'       : n
                          , 'drive'      : d
                          , 'physical'   : True
                          , 'behavioral' : True                   
                          }
                )

-  **Description** : Generates a ``n`` bits three inputs NAND with an
   output power of ``d`` named ``modelname``.

-  **Terminal Names** :

   -  **i0** : input (``n`` bits)

   -  **i1** : input (``n`` bits)

   -  **i2** : input (``n`` bits)

   -  **nq** : output (``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **drive** (optional) : Defines the output power of the gates

      -  Valid drive are : 1 or 4

      -  If this parameter is not defined, it’s value is the smallest
         one permitted

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **Behavior** :

   ::

       nq <= not ( i0 and i1 and i2 )

-  **Example** :

   ::

       from stratus import *

       class inst_nand3 ( Model ) :

         def Interface ( self ) :
           self.in1 = SignalIn  ( "in1", 20 )
           self.in2 = SignalIn  ( "in2", 20 )
           self.in3 = SignalIn  ( "in3", 20 )
           self.o   = SignalOut (   "o", 20 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenNand3', 'nand3_20'
                    , param = { 'nbit'     : 20
                              , 'physical' : True
                              }
                    )
           self.I = Inst ( 'nand3_20', 'inst'
                         , map = { 'i0'  : self.in1
                                 , 'i1'  : self.in2
                                 , 'i2'  : self.in3
                                 , 'nq'  : self.o
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

Dpgennand4
==========

-  **Name** : DpgenNand4 – Nand4 Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenNand4', modelname
                , param = { 'nbit'       : n
                          , 'drive'      : d
                          , 'physical'   : True
                          , 'behavioral' : True                   
                          }
                )

-  **Description** : Generates a ``n`` bits four inputs NAND with an
   output power of ``d`` named ``modelname``.

-  **Terminal Names** :

   -  **i0** : input (``n`` bits)

   -  **i1** : input (``n`` bits)

   -  **i2** : input (``n`` bits)

   -  **i3** : input (``n`` bits)

   -  **nq** : output (``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **drive** (optional) : Defines the output power of the gates

      -  Valid drive are : 1 or 4

      -  If this parameter is not defined, it’s value is the smallest
         one permitted

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **Behavior** :

   ::

       nq <= not ( i0 and i1 and i2 and i3 )

-  **Example** :

   ::

       from stratus import *

       class inst_nand4 ( Model ) :

         def Interface ( self ) :
           self.in1 = SignalIn  ( "in1", 9 )
           self.in2 = SignalIn  ( "in2", 9 )
           self.in3 = SignalIn  ( "in3", 9 )
           self.in4 = SignalIn  ( "in4", 9 )
           self.o   = SignalOut (   "o", 9 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenNand4', 'nand4_9'
                    , param = { 'nbit'     : 9
                              , 'physical' : True
                              }
                    )
           self.I = Inst ( 'nand4_9', 'inst'
                         , map = { 'i0'  : self.in1
                                 , 'i1'  : self.in2
                                 , 'i2'  : self.in3
                                 , 'i3'  : self.in4
                                 , 'nq'  : self.o
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenAnd2
=========

-  **Name** : DpgenAnd2 – And2 Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenAnd2', modelname
                , param = { 'nbit'       : n
                          , 'drive'      : d
                          , 'physical'   : True
                          , 'behavioral' : True
                          }
                )

-  **Description** : Generates a ``n`` bits two inputs AND with an
   output power of ``d`` named ``modelname``.

-  **Terminal Names** :

   -  **i0** : input (``n`` bits)

   -  **i1** : input (``n`` bits)

   -  **q** : output (``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **drive** (optional) : Defines the output power of the gates

      -  Valid drive are : 2 or 4

      -  If this parameter is not defined, it’s value is the smallest
         one permitted

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **Behavior** :

   ::

       nq <= i0 and i1

-  **Example** :

   ::

       from stratus import *

       class inst_and2 ( Model ) :

         def Interface ( self ) :
           self.in1 = SignalIn  ( "in1", 8 )
           self.in2 = SignalIn  ( "in2", 8 )
           self.out = SignalOut (   "o", 8 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenAnd2', 'and2_8'
                    , param = { 'nbit'     : 8
                              , 'physical' : True
                              }
                    )      
           self.I = Inst ( 'and2_8', 'inst'
                         , map = { 'i0'  : self.in1
                                 , 'i1'  : self.in2
                                 , 'q'   : self.out
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenAnd3
=========

-  **Name** : DpgenAnd3 – And3 Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenAnd3', modelname
                , param = { 'nbit'       : n
                          , 'drive'      : d
                          , 'physical'   : True
                          , 'behavioral' : True
                          }
                )

-  **Description** : Generates a ``n`` bits three inputs AND with an
   output power of ``d`` named ``modelname``.

-  **Terminal Names** :

   -  **i0** : input (``n`` bits)

   -  **i1** : input (``n`` bits)

   -  **i2** : input (``n`` bits)

   -  **q** : output (``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **drive** (optional): Defines the output power of the gates

      -  Valid drive are : 2 or 4

      -  If this parameter is not defined, it’s value is the smallest
         one permitted

   -  **physical** (optional, default value : False): In order to
      generate a layout

   -  **behavioral** (optional, default value : False): In order to
      generate a behavior

-  **Behavior** :

   ::

       nq <= i0 and i1 and i2

-  **Example** :

   ::

       from stratus import *

       class inst_and3 ( Model ) :

         def Interface ( self ) :
           self.in1 = SignalIn  ( "in1", 16 )
           self.in2 = SignalIn  ( "in2", 16 )
           self.in3 = SignalIn  ( "in3", 16 )
           self.out = SignalOut (   "o", 16 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenAnd3', "and3_16"
                    , param = { 'nbit'     : 16
                              , 'physical' : True
                              }
                    )       
           self.I = Inst ( 'and3_16', 'inst'
                         , map = { 'i0'  : self.in1
                                 , 'i1'  : self.in2
                                 , 'i2'  : self.in3
                                 , 'q'   : self.out
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref (0, 0) )

DpgenAnd4
=========

-  **Name** : DpgenAnd4 – And4 Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenAnd4', modelname
                , param = { 'nbit'       : n
                          , 'drive'      : d
                          , 'physical'   : True
                          , 'behavioral' : True                   
                          }
                )

-  **Description** : Generates a ``n`` bits four inputs AND with an
   output power of ``d`` named ``modelname``.

-  Terminal Names :

   -  **i0** : input (``n`` bits)

   -  **i1** : input (``n`` bits)

   -  **i2** : input (``n`` bits)

   -  **i3** : input (``n`` bits)

   -  **q** : output (``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **drive** (optional) : Defines the output power of the gates

      -  Valid drive are : 2 or 4

      -  If this parameter is not defined, it’s value is the smallest
         one permitted

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **Behavior** :

   ::

       nq <= i0 and i1 and i2 and i3

-  **Example** :

   ::

       from stratus import *

       class inst_and4 ( Model ) :

         def Interface ( self ) :
           self.in1   = SignalIn  ( "in1", 2 )
           self.in2   = SignalIn  ( "in2", 2 )
           self.in3   = SignalIn  ( "in3", 2 )
           self.in4   = SignalIn  ( "in4", 2 )
           self.out   = SignalOut (   "o", 2 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenAnd4', 'and4_2'
                    , param = { 'nbit'     : 2
                              , 'physical' : True
                              }
                    )      
           self.I = Inst ( 'and4_2', 'inst'                  
                         , map = { 'i0'  : self.in1
                                 , 'i1'  : self.in2
                                 , 'i2'  : self.in3
                                 , 'i3'  : self.in4
                                 , 'q'   : self.out
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenNor2
=========

-  **Name** : DpgenNor2 – Nor2 Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenNor2', modelname
                , param = { 'nbit'       : n
                          , 'drive'      : d
                          , 'physical'   : True
                          , 'behavioral' : True                   
                          }
                )

-  **Description** : Generates a ``n`` bits two inputs NOR with an
   output power of ``d`` named ``modelname``.

-  **Terminal Names** :

   -  **i0** : input (``n`` bits)

   -  **i1** : input (``n`` bits)

   -  **nq** : output (``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **drive** (optional) : Defines the output power of the gates

      -  Valid drive are : 1 or 4

      -  If this parameter is not defined, it’s value is the smallest
         one permitted

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **Behavior** :

   ::

       nq <= not ( i0 or i1 )

-  **Example** :

   ::

       from stratus import *

       class inst_nor2 ( Model ) :

         def Interface ( self ) :
           self.in1 = SignalIn  ( "in1", 8 )
           self.in2 = SignalIn  ( "in2", 8 )
           self.o   = SignalOut (   "o", 8 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenNor2', 'nor2_8'
                    , param = { 'nbit'     : 8
                              , 'physical' : True
                              }
                    )
           self.I = Inst ( 'nor2_8', 'inst'
                         , map = { 'i0'  : self.in1
                                 , 'i1'  : self.in2
                                 , 'nq'  : self.o
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenNor3
=========

-  **Name** : DpgenNor3 – Nor3 Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenNor3', modelname
                , param = { 'nbit'       : n
                          , 'drive'      : d
                          , 'physical'   : True
                          , 'behavioral' : True                   
                          }
                )

-  **Description** : Generates a ``n`` bits three inputs NOR with an
   output power of ``d`` named ``modelname``.

-  **Terminal Names** :

   -  **i0** : input (``n`` bits)

   -  **i1** : input (``n`` bits)

   -  **i2** : input (``n`` bits)

   -  **nq** : output (``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **drive** (optional) : Defines the output power of the gates

      -  Valid drive are : 1 or 4

      -  If this parameter is not defined, it’s value is the smallest
         one permitted

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **Behavior** :

   ::

       nq <= not ( i0 or i1 or i2 )

-  **Example** :

   ::

       from stratus import *

       class inst_nor3 ( Model ) :

         def Interface ( self ) :
           self.in1 = SignalIn  ( "in1", 3 )
           self.in2 = SignalIn  ( "in2", 3 )
           self.in3 = SignalIn  ( "in3", 3 )
           self.o   = SignalOut ( "out", 3 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenNor3', 'nor3_3'
                    , param = { 'nbit'     : 3
                              , 'physical' : True
                              }
                    )
           self.I = Inst ( 'nor3_3', 'inst'
                         , map = { 'i0'  : self.in1
                                 , 'i1'  : self.in2
                                 , 'i2'  : self.in3
                                 , 'nq'  : self.o
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenNor4
=========

-  **Name** : DpgenNor4 – Nor4 Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenNor4', modelname
                , param = { 'nbit'       : n
                          , 'drive'      : d 
                          , 'physical'   : True
                          , 'behavioral' : True                   
                          }
                )

-  **Description** : Generates a ``n`` bits four inputs NOR with an
   output power of ``d`` named ``modelname``.

-  **Terminal Names** :

   -  **i0** : input (``n`` bits)

   -  **i1** : input (``n`` bits)

   -  **i2** : input (``n`` bits)

   -  **i3** : input (``n`` bits)

   -  **nq** : output (``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **drive** (optional) : Defines the output power of the gates

      -  Valid drive are : 1 or 4

      -  If this parameter is not defined, it’s value is the smallest
         one permitted

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **Behavior** :

   ::

       nq <= not ( i0 or i1 or i2 or i3 )

-  **Example** :

   ::

       from stratus import *

       class inst_nor4 ( Model ) :

         def Interface ( self ) :
           self.in1 = SignalIn  ( "in1", 15 )
           self.in2 = SignalIn  ( "in2", 15 )
           self.in3 = SignalIn  ( "in3", 15 )
           self.in4 = SignalIn  ( "in4", 15 )
           self.out = SignalOut (   "o", 15 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenNor4', 'nor4_15'
                    , param = { 'nbit'     : 15
                              , 'physical' : True
                              }
                    )
           self.I = Inst ( 'nor4_15', 'inst'
                         , map = { 'i0'  : self.in1
                                 , 'i1'  : self.in2
                                 , 'i2'  : self.in3
                                 , 'i3'  : self.in4
                                 , 'nq'  : self.out
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
             
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenOr2
========

-  **Name** : DpgenOr2 – Or2 Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenOr2', modelname
                , param = { 'nbit'       : n
                          , 'drive'      : d
                          , 'physical'   : True
                          , 'behavioral' : True                   
                          }
                )

-  **Description** : Generates a ``n`` bits two inputs OR with an output
   power of ``drive`` named ``modelname``.

-  **Terminal Names** :

   -  **i0** : input (``n`` bits)

   -  **i1** : input (``n`` bits)

   -  **q** : output (``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the a map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **drive** (optional) : Defines the output power of the gates

      -  Valid drive are : 2 or 4

      -  If this parameter is not defined, the ``drive`` is the smallest
         one permitted

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **Behavior** :

   ::

       nq <= i0 or i1

-  **Example** :

   ::

       from stratus import *

       class inst_or2 ( Model ) :

         def Interface ( self ) :
           self.in1 = SignalIn  ( "in1", 8 )
           self.in2 = SignalIn  ( "in2", 8 )
           self.o   = SignalOut (   "o", 8 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenOr2', 'or2_8'
                    , param = { 'nbit'     : 8
                              , 'physical' : True
                              }
                    )
           self.I = Inst ( 'or2_8', 'inst'
                         , map = { 'i0'  : self.in1
                                 , 'i1'  : self.in2
                                 , 'q'   : self.o
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
             
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenOr3
========

-  **Name** : DpgenOr3 – Or3 Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenOr3', modelname
                , param = { 'nbit'       : n
                          , 'drive'      : d
                          , 'physical'   : True
                          , 'behavioral' : True                   
                          }
                )

-  **Description** : Generates a ``n`` bits three inputs OR with an
   output power of ``d`` named ``modelname``.

-  **Terminal Names** :

   -  **i0** : input (``n`` bits)

   -  **i1** : input (``n`` bits)

   -  **i2** : input (``n`` bits)

   -  **q** : output (``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **drive** (optional) : Defines the output power of the gates

      -  Valid drive are : 2 or 4

      -  If this parameter is not defined, it’s value is the smallest
         one permitted

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **Behavior** :

   ::

       nq <= i0 or i1 or i2

-  **Example** :

   ::

       from stratus import *

       class inst_or3 ( Model ) :

         def Interface ( self ) :
           self.in1 = SignalIn  ( "in1", 5 )
           self.in2 = SignalIn  ( "in2", 5 )
           self.in3 = SignalIn  ( "in3", 5 )
           self.o   = SignalOut (   "o", 5 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenOr3', 'or3_5'
                    , param = { 'nbit'     : 5 
                              , 'physical' : True
                              }
                    )
           self.I = Inst ( 'or3_5', 'inst'
                         , map = { 'i0'  : self.in1
                                 , 'i1'  : self.in2
                                 , 'i2'  : self.in3
                                 , 'q'   : self.o
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenOr4
========

-  **Name** : DpgenOr4 – Or4 Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenOr4', modelname
                , param = { 'nbit'       : n
                          , 'drive'      : d
                          , 'physical'   : True
                          , 'behavioral' : True                   
                          }
                )

-  **Description** : Generates a ``n`` bits four inputs OR with an
   output power of ``d`` named ``modelname``.

-  **Terminal Names** :

   -  **i0** : input (``n`` bits)

   -  **i1** : input (``n`` bits)

   -  **i2** : input (``n`` bits)

   -  **i3** : input (``n`` bits)

   -  **q** : output (``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **drive** (optional) : Defines the output power of the gates

      -  Valid drive are : 2 or 4

      -  If this parameter is not defined, it’s value is the smallest
         one permitted

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **Behavior** :

   ::

       nq <= i0 or i1 or i2 or i3

-  **Example** :

   ::

       from stratus import *

       class inst_or4 ( Model ) :

         def Interface ( self ) :
           self.in1 = SignalIn  ( "in1", 16 )
           self.in2 = SignalIn  ( "in2", 16 )
           self.in3 = SignalIn  ( "in3", 16 )
           self.in4 = SignalIn  ( "in4", 16 )
           self.out = SignalOut (   "o", 16 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenOr4', 'or4_16'
                    , param = { 'nbit'     : 16
                              , 'physical' : True 
                              }
                    )
           self.I = Inst ( 'or4_16', 'inst'
                         , map = { 'i0'  : self.in1
                                 , 'i1'  : self.in2
                                 , 'i2'  : self.in3
                                 , 'i3'  : self.in4
                                 , 'q'   : self.out
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenXor2
=========

-  **Name** : DpgenXor2 – Xor2 Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenXor2', modelname
                , param = { 'nbit'       : n
                          , 'drive'      : d
                          , 'physical'   : True
                          , 'behavioral' : True                   
                          }
                )

-  **Description** : Generates a ``n`` bits two inputs XOR with an
   output power of ``d`` named ``modelname``.

-  **Terminal Names** :

   -  **i0** : input (``n`` bits)

   -  **i1** : input (``n`` bits)

   -  **q** : output (``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **drive** (optional) : Defines the output power of the gates

      -  Valid drive are : 2 or 4

      -  If this parameter is not defined, it’s value is the smallest
         one permitted

   -  **physical** (optionnal, default value : False) : In order to
      generate a layout

   -  **behavioral** (optionnal, default value : False) : In order to
      generate a behavior

-  **Behavior** :

   ::

       nq <= i0 xor i1

-  **Example** :

   ::

       from stratus import *

       class inst_xor2 ( Model ) :

         def Interface ( self ) :
           self.in1 = SignalIn  ( "in1", 8 )
           self.in2 = SignalIn  ( "in2", 8 )
           self.o   = SignalOut (   "o", 8 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenXor2', 'xor2_8'
                    , param = { 'nbit' : 8 
                              , 'physical' : True
                              }
                    )
           self.I = Inst ( 'xor2_8', 'inst'
                         , map = { 'i0'  : self.in1
                                 , 'i1'  : self.in2
                                 , 'q'   : self.o
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenXnor2
==========

-  **Name** : DpgenXnor2 – Xnor2 Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenXnor2', modelname
                , param = { 'nbit'       : n
                          , 'drive'      : d
                          , 'physical'   : True
                          , 'behavioral' : True                   
                          }
                )

-  **Description** : Generates a ``n`` bits two inputs XNOR with an
   output power of ``d`` named ``modelname``.

-  **Terminal Names** :

   -  **i0** : input (``n`` bits)

   -  **i1** : input (``n`` bits)

   -  **nq** : output (``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **drive** (optional) : Defines the output power of the gates

      -  Valid drive are : 1 or 4

      -  If this parameter is not defined, it’s value is the smallest
         one permitted

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **Behavior** :

   ::

       nq <= not ( i0 xor i1 )

-  **Example** :

   ::

       from stratus import *

       class inst_xnor2 ( Model ) :

         def Interface ( self ) :
           self.in1 = SignalIn  ( "in1", 8 )
           self.in2 = SignalIn  ( "in2", 8 )
           self.o   = SignalOut (   "o", 8 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenXnor2', 'xnor2_8'
                    , param = { 'nbit'     : 8
                              , 'physical' : True
                              }
                    )
           self.I = Inst ( 'xnor2_8', 'inst'
                         , map = { 'i0'  : self.in1
                                 , 'i1'  : self.in2
                                 , 'nq'  : self.o
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
             
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenNmux2
==========

-  **Name** : DpgenNmux2 – Multiplexer Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenNmux2', modelname
                , param = { 'nbit'       : n
                          , 'physical'   : True
                          , 'behavioral' : True         
                          }
                )

-  **Description** : Generates a ``n`` bits two inputs multiplexer named
   ``modelname``.

-  **Terminal Names** :

   -  **cmd** : select ( 1 bit )

   -  **i0** : input ( ``n`` bits )

   -  **i1** : input ( ``n`` bits )

   -  **nq** : output ( ``n`` bits )

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **Behavior** :

   ::

       nq <= WITH cmd SELECT not i0 WHEN '0',
                             not i1 WHEN '1';

-  **Example** :

   ::

       from stratus import *

       class inst_nmux2 ( Model ) :

         def Interface ( self ) :
           self.in1 = SignalIn  (  "in1", 5 )
           self.in2 = SignalIn  (  "in2", 5 )
           self.cmd = SignalIn  (  "cmd", 1 )
           self.o   = SignalOut (    "o", 5 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenNmux2', 'nmux2_5'
                    , param = { 'nbit'     : 5
                              , 'physical' : True
                              }
                    )
           self.I = Inst ( 'nmux2_5', 'inst'
                         , map = { 'i0'  : self.in1
                                 , 'i1'  : self.in2
                                 , 'cmd' : self.cmd
                                 , 'nq'  : self.o
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
             
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenMux2
=========

-  **Name** : DpgenMux2 – Multiplexer Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenMux2', modelname
                , param = { 'nbit'       : n
                          , 'drive'      : d
                          , 'physical'   : True
                          , 'behavioral' : True                   
                          }
                )

-  **Description** : Generates a ``n`` bits two inputs multiplexer with
   an output power of ``d`` named ``modelname``.

-  **Terminal Names** :

   -  **cmd** : select ( 1 bit )

   -  **i0** : input ( ``n`` bits )

   -  **i1** : input ( ``n`` bits )

   -  **q** : output ( ``n`` bits )

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **nbit\_cmd** (mandatory) : Defines the size of the generator

   -  **drive** (optional) : Defines the output power of the gates

      -  Valid drive are : 2 or 4

      -  If this parameter is not defined, it’s value is the smallest
         one permitted

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **Behavior** :

   ::

       nq <= WITH cmd SELECT i0 WHEN '0',
                             i1 WHEN '1';

-  **Example** :

   ::

       from stratus import *

       class inst_mux2 ( Model ) :

         def Interface ( self ) :
           self.in1  = SignalIn  ( "in1", 8 )
           self.in2  = SignalIn  ( "in2", 8 )
           self.cmd  = SignalIn  ( "cmd", 1 )
           self.o    = SignalOut (   "o", 8 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenMux2', 'mux2_8'
                    , param = { 'nbit'     : 8
                              , 'physical' : True
                              }
                    )
           self.I = Inst ( 'mux2_8', 'inst'
                         , map = { 'i0'  : self.in1
                                 , 'i1'  : self.in2
                                 , 'cmd' : self.cmd
                                 , 'q'   : self.o
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenNbuse
==========

-  **Name** : DpgenNbuse – Tristate Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenNbuse', modelname
                , param = { 'nbit'       : n
                          , 'physical'   : true
                          , 'behavioral' : true         
                          }
                )

-  **Description** : Generates a ``n`` bits tristate with an
   complemented output named ``modelname``.

-  **Terminal Names** :

   -  **cmd** : select ( 1 bit )

   -  **i0** : input ( ``n`` bits )

   -  **nq** : output ( ``n`` bits )

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **Behavior** :

   ::

       nts:BLOCK(cmd = '1') BEGIN
           nq <= GUARDED not(i0);
       END

-  **Example** :

   ::

       from stratus import *

       class inst_nbuse ( Model ) :

         def Interface ( self ) :
           self.i   = SignalIn  (   "i", 29 )
           self.cmd = SignalIn  ( "cmd", 1  )
           self.o   = SignalOut (   "o", 29 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenNbuse', 'nbuse29'
                    , param = { 'nbit'     : 29
                              , 'physical' : True
                              }
                    )
           self.I = Inst ( 'nbuse29', 'inst'
                         , map = { 'i0'  : self.i
                                 , 'cmd' : self.cmd
                                 , 'nq'  : self.o
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenBuse
=========

-  **Name** : DpgenBuse – Tristate Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenBuse', modelname
                , param = { 'nbit'       : n
                          , 'physical'   : True
                          , 'behavioral' : True         
                          }
                )

-  **Description** : Generates a ``n`` bits tristate named
   ``modelname``.

-  **Terminal Names** :

   -  **cmd** : select ( 1 bit )

   -  **i0** : input ( ``n`` bits )

   -  **q** : output ( ``n`` bits )

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **Behavior** :

   ::

       nts:BLOCK(cmd = '1') BEGIN
           q <= GUARDED i0;
       END

-  **Example** :

   ::

       from stratus import *

       class inst_buse ( Model ) :

         def Interface ( self ) :
           self.i   = SignalIn  (   "i", 8 )
           self.cmd = SignalIn  ( "cmd", 1 )
           self.o   = SignalOut (   "o", 8 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenBuse', 'buse_8'
                    , param = { 'nbit'     : 8
                              , 'physical' : True
                              }
                    )      
           self.I = Inst ( 'buse_8', 'inst'
                         , map = { 'i0'  : self.i
                                 , 'cmd' : self.cmd
                                 , 'q'   : self.o
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenNand2mask
==============

-  **Name** : DpgenNand2mask – Programmable Mask Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenNand2mask', modelname
                , param = { 'nbit'       : n
                          , 'const'      : constVal
                          , 'physical'   : True
                          , 'behavioral' : True                   
                          }
                )

-  **Description** : Generates a ``n`` bits conditionnal NAND mask named
   ``modelname``.

-  **Terminal Names** :

   -  **cmd** : mask control ( 1 bit )

   -  **i0** : input ( ``n`` bits )

   -  **nq** : output ( ``n`` bits )

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **const** (mandatory) : Defines the constant (string beginning
      with 0b, 0x or 0o functions of the basis)

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **How it works** :

   -  If the ``cmd`` signal is set to ``zero``, the mask is NOT applied,
      so the whole operator behaves like an inverter.

   -  If the ``cmd`` signal is set to ``one``, the mask is applied, the
      output is the *complemented* result of the input value *ANDed*
      with the mask (suplied by ``constVal``).

   -  The constant ``constVal`` is given to the macro-generator call,
      therefore the value cannot be changed afterward : it’s hard wired
      in the operator.

   -  A common error is to give a real constant for the ``constVal``
      argument. Be aware that it is a character string.

-  **Behavior** :

   ::

       nq <= WITH cmd SELECT not(i0)              WHEN '0',
                             not(i0 and constVal) WHEN '1';

-  **Example** :

   ::

       from stratus import *

       class inst_nand2mask ( Model ) :

         def Interface ( self ) :
           self.i   = SignalIn  (   "i", 32 )
           self.cmd = SignalIn  ( "cmd",  1 )
           self.o   = SignalOut (   "o", 32 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenNand2mask', 'nand2mask_0x0000ffff'
                    , param = { 'nbit'     : 32
                              , 'const'    : "0x0000FFFF"
                              , 'physical' : True
                              }
                    )      
           self.I = Inst ( 'nand2mask_0x0000ffff', 'inst'
                         , map = { 'i0'  : self.i
                                 , 'cmd' : self.cmd
                                 , 'nq'  : self.o
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenNor2mask
=============

-  **Name** : DpgenNor2mask – Programmable Mask Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenNor2mask', modelname
                , param = { 'nbit'       : n
                          , 'const'      : constVal 
                          , 'physical'   : True
                          , 'behavioral' : True                   
                          }
                )

-  **Description** : Generates a ``n`` bits conditionnal NOR mask named
   ``modelname``.

-  **Terminal Names** :

   -  **cmd** : mask control ( 1 bit )

   -  **i0** : input ( ``n`` bits )

   -  **nq** : output ( ``n`` bits )

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **const** (mandatory) : Defines the constant (string beginning
      with 0b, 0x or 0o functions of the basis)

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **How it works** :

   -  If the ``cmd`` signal is set to ``zero``, the mask is NOT applied,
      so the whole operator behaves like an inverter.

   -  If the ``cmd`` signal is set to ``one``, the mask is applied, the
      output is the *complemented* result of the input value *ORed* with
      the mask (suplied by ``constVal``).

   -  The constant ``constVal`` is given to the macro-generator call,
      therefore the value cannot be changed afterward : it’s hard wired
      in the operator.

   -  A common error is to give a real constant for the ``constVal``
      argument. Be aware that it is a character string.

-  **Behavior** :

   ::

       nq <= WITH cmd SELECT not(i0)             WHEN '0',
                             not(i0 or constVal) WHEN '1';

-  **Example** :

   ::

       from stratus import *

       class inst_nor2mask ( Model ) :

         def Interface ( self ) :
           self.i   = SignalIn  (   "i", 8 )
           self.cmd = SignalIn  ( "cmd", 1 )
           self.o   = SignalOut (   "o", 8 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenNor2mask', 'nor2mask_000111'
                    , param = { 'nbit'     : 8
                              , 'const'    : "0b000111"
                              , 'physical' : True
                              }
                    )
           self.I = Inst ( 'nor2mask_000111', 'inst'
                         , map = { 'i0'  : self.i
                                 , 'cmd' : self.cmd
                                 , 'nq'  : self.o
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenXnor2mask
==============

-  **Name** : DpgenXnor2mask – Programmable Mask Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenXnor2mask', modelname
                , param = { 'nbit'       : n
                          , 'const'      : constVal
                          , 'physical'   : True
                          , 'behavioral' : True                   
                          }
                )

-  **Description** : Generates a ``n`` bits conditionnal XNOR mask named
   ``modelname``.

-  **Terminal Names** :

   -  **cmd** : mask control ( 1 bit )

   -  **i0** : input ( ``n`` bits )

   -  **nq** : output ( ``n`` bits )

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **const** (mandatory) : Defines the constant (string beginning
      with 0b, 0x or 0o functions of the basis)

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **How it works** :

   -  If the ``cmd`` signal is set to ``zero``, the mask is NOT applied,
      so the whole operator behaves like an inverter.

   -  If the ``cmd`` signal is set to ``one``, the mask is applied, the
      output is the *complemented* result of the input value *XORed*
      with the mask (suplied by ``constVal``).

   -  The constant ``constVal`` is given to the macro-generator call,
      therefore the value cannot be changed afterward : it’s hard wired
      in the operator.

   -  A common error is to give a real constant for the ``constVal``
      argument. Be aware that it is a character string.

-  **Behavior** :

   ::

       nq <= WITH cmd SELECT not(i0)              WHEN '0',
                             not(i0 xor constVal) WHEN '1';

-  **Example** :

   ::

       from stratus import *

       class inst_xnor2mask ( Model ) :

         def Interface ( self ) :
           self.i   = SignalIn  (   "i", 8 )
           self.cmd = SignalIn  ( "cmd", 1 )
           self.o   = SignalOut (   "o", 8 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenXnor2mask', 'xnor2mask_0b000111'
                    , param = { 'nbit'     : 8
                              , 'const'    : "0b000111"
                              , 'physical' : True
                              }
                    )
           self.I = Inst ( 'xnor2mask_0b000111', 'inst'
                         , map = { 'i0'  : self.i
                                 , 'cmd' : self.cmd
                                 , 'nq'  : self.o
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenAdsb2f
===========

-  **Name** : DpgenAdsb2f – Adder/Substractor Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenAdsb2f', modelname
                , param = { 'nbit'       : n
                          , 'physical'   : True
                          , 'behavioral' : True
                          }
                )

-  **Description** : Generates a ``n`` bits adder/substractor named
   ``modelname``.

-  **Terminal Names** :

   -  **i0** : First operand (input, ``n`` bits)

   -  **i1** : Second operand (input, ``n`` bits)

   -  **q** : Output operand (ouput, ``n`` bits)

   -  **add\_sub** : Select addition or substraction (input, 1 bit)

   -  **c31** : Sarry out. In unsigned mode, this is the overflow
      (output, 1 bit)

   -  **c30** : Used to compute overflow in signed mode :
      ``overflow = c31 xor c30`` (output, 1 bit)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **How it works** :

   -  If the ``add_sub`` signal is set to ``zero``, an addition is
      performed, otherwise it’s a substraction.

   -  Operation can be either signed or unsigned. In unsigned mode
      ``c31`` is the overflow ; in signed mode you have to compute
      overflow by *XORing* ``c31`` and ``c30``

-  **Example** :

   ::

       from stratus import *

       class inst_ADSB2F ( Model ) :

         def Interface ( self ) :
           self.in1 = SignalIn  ( "in1", 8 )
           self.in2 = SignalIn  ( "in2", 8 )
           self.out = SignalOut (   "o", 8 )
           self.as  = SignalIn  (  "as", 1 )
           self.c0  = SignalOut (  "c0", 1 )
           self.c1  = SignalOut (  "c1", 1 )
           
           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenAdsb2f', 'adder_8'
                    , param = { 'nbit'     : 8
                              , 'physical' : True
                              }
                    )       
           self.I = Inst ( 'adder_8', 'inst'
                         , map = { 'i0'      : self.in1
                                 , 'i1'      : self.in2
                                 , 'add_sub' : self.as
                                 , 'q'       : self.out
                                 , 'c30'     : self.c0
                                 , 'c31'     : self.c1
                                 , 'vdd'     : self.vdd
                                 , 'vss'     : self.vss
                                 }
                         )
             
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenShift
==========

-  **Name** : DpgenShift – Shifter Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenShift', modelname
                , param = { 'nbit'     : n
                          , 'physical' : True         
                          }
                )

-  **Description** : Generates a ``n`` bits shifter named ``modelname``.

-  **Terminal Names** :

   -  **op** : select the kind of shift (input, 2 bits)

   -  **shamt** : the shift amount (input, ``Y`` bits)

   -  **i** : value to shift (input, ``n`` bits)

   -  **o** : output (``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **physical** (optional, default value : False) : In order to
      generate a layout

-  **How it works** :

   -  If the ``op[0]`` signal is set to ``one``, performs a right shift,
      performs a left shift otherwise.

   -  If the ``op[1]`` signal is set to ``one``, performs an arithmetic
      shift (only meaningful in case of a right shift).

   -  shamt : specifies the shift amount. The width of this signal
      (``Y``) is computed from the operator’s width : ``Y = ceil(log2(n))`` - 1

-  **Example** :

   ::

       from stratus import *

       class inst_shifter ( Model ) :

         def Interface ( self ) :
           self.instop    = SignalIn  (    "instop", 2 )
           self.instshamt = SignalIn  ( "instshamt", 2 )
           self.insti     = SignalIn  (     "insti", 4 )
           self.insto     = SignalOut (     "insto", 4 )
           
           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenShifter', 'shifter_4'
                    , param = { 'nbit'     : 4
                              , 'physical' : True
                              }
                    )
           self.I = Inst ( 'shifter_4', 'inst'
                         , map = { 'op'    : self.instop
                                 , 'shamt' : self.instshamt
                                 , 'i'     : self.insti
                                 , 'o'     : self.insto
                                 , 'vdd'   : self.vdd
                                 , 'vss'   : self.vss
                                 }
                         )
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenShrot
==========

-  **Name** : DpgenShrot – Shift/Rotation Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenShrot', modelname
                , param = { 'nbit'     : n
                          , 'physical' : True         
                          }
                )

-  **Description** : Generates a ``n`` bits shift/rotation operator
   named ``modelname``.

-  **Terminal Names** :

   -  **op** : select the kind of shift/rotation (input, 3 bits)

   -  **shamt** : the shift amount (input, ``Y`` bits)

   -  **i** : value to shift (input, ``n`` bits)

   -  **o** : output (``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **physical** (optional, default value : False) : In order to
      generate a layout

-  **How it works** :

   -  If the ``op[0]`` signal is set to ``one``, performs a right
      shift/rotation , otherwise left shift/rotation occurs.

   -  If the ``op[1]`` signal is set to ``one``, performs an arithmetic
      shift (only meaningful in case of a right shift).

   -  If the ``op[2]`` signal is set to ``one``, performs a rotation,
      otherwise performs a shift..

   -  ``shamt`` specifies the shift amount. The width of this signal
      (``Y``) is computed from the operator’s width :
      ``Y = ceil(log2(n))`` - 1

-  **Example** :

   ::

       from stratus import *

       class inst_shrot ( Model ) :

         def Interface ( self ) :
           self.rotop     = SignalIn  (     "rotop", 3 )
           self.instshamt = SignalIn  ( "instshamt", 2 )
           self.insti     = SignalIn  (     "insti", 4 )
           self.insto     = SignalOut (     "insto", 4 )
           
           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenShrot', 'shrot_4'
                    , param = { 'nbit'     : 4
                              , 'physical' : True
                              }
                    )
           self.I = Inst ( 'shrot_4', 'inst'
                         , map = { 'op'    : self.rotop
                                 , 'shamt' : self.instshamt
                                 , 'i'     : self.insti
                                 , 'o'     : self.insto
                                 , 'vdd'   : self.vdd
                                 , 'vss'   : self.vss
                                 }
                         )
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenNul
========

-  **Name** : DpgenNul – Zero Detector Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenNul', modelname
                , param = { 'nbit'     : n
                          , 'physical' : True         
                          }
                )

-  **Description** : Generates a ``n`` bits zero detector named
   ``modelname``.

-  **Terminal Names** :

   -  **i0** : value to check (input, ``n`` bits)

   -  **q** : null flag (1 bit)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **physical** (optional, default value : False) : In order to
      generate a layout

-  **Behavior** :

   ::

       q <= '1' WHEN ( i0 = X"00000000" ) ELSE '0';

-  **Example** :

   ::

       from stratus import *

       class inst_nul ( Model ) :

         def Interface ( self ) :
           self.i = SignalIn  ( "i", 4 )
           self.o = SignalOut ( "o", 1 )
           
           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenNul', 'nul_4'
                    , param = { 'nbit'     : 4
                              , 'physical' : True
                              }
                    )
           self.I = Inst ( 'nul_4', 'inst'
                          , map = { 'i0'  : self.i
                                  , 'nul' : self.o
                                  , 'vdd' : self.vdd
                                  , 'vss' : self.vss
                                  }
                          )
             
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenConst
==========

-  **Name** : DpgenConst – Constant Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenConst', modelname
                , param = { 'nbit'       : n
                          , 'const'      : constVal
                          , 'physical'   : True
                          , 'behavioral' : True                   
                          }
                )

-  **Description** : Generates a ``n`` bits constant named
   ``modelname``.

-  **Terminal Names** :

   -  **q** : the constant (output, ``n`` bit)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **const** (mandatory) : Defines the constant (string beginning
      with 0b, 0x or 0o functions of the basis)

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **Behavior** :

   ::

       q <= constVal

-  **Example** :

   ::

       from stratus import *

       class inst_const ( Model ) :

         def Interface ( self ) :
           self.o = SignalOut ( "o", 32 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenConst', 'const_0x0000ffff'
                    , param = { 'nbit'     : 32
                              , 'const'    : "0x0000FFFF"
                              , 'physical' : True
                              }
                    )      
           self.I = Inst ( 'const_0x0000ffff', 'inst'
                         , map = { 'q'   : self.o
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
             
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenRom2
=========

-  **Name** : DpgenRom2 – 2 words ROM Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenRom2', modelname
                , param = { 'nbit'     : n
                          , 'val0'     : constVal0
                          , 'val1'     : constVal1
                          , 'physical' : True                   
                          }
                )

-  **Description** : Generates a ``n`` bits 2 words optimized ROM named
   ``modelname``.

-  **Terminal Names** :

   -  **sel0** : address of the value (input, 1 bit)

   -  **q** : the selected word (output, ``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **val0** (mandatory) : Defines the first word

   -  **val1** (mandatory) : Defines the second word

   -  **physical** (optional, default value : False) : In order to
      generate a layout

-  **Behavior** :

   ::

       q <= WITH sel0 SELECT
            constVal0  WHEN B"0",
            constVal1  WHEN B"1";

-  **Example** :

   ::

       from stratus import *

       class inst_rom2 ( Model ) :

         def Interface ( self ) :
           self.sel0 = SignalIn  (    "sel0", 1 )
           self.q    = SignalOut ( "dataout", 4 )
           
           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenRom2', 'rom2_0b1010_0b1100'
                    , param = { 'nbit'     : 4
                              , 'val0'     : "0b1010"
                              , 'val1'     : "0b1100"
                              , 'physical' : True
                              }
                    )
           self.I = Inst ( 'rom2_0b1010_0b1100', 'inst'
                         , map = { 'sel0' : self.sel0
                                 , 'q'    : self.q
                                 , 'vdd'  : self.vdd
                                 , 'vss'  : self.vss
                                 }
                         )
         
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )  

DpgenRom4
=========

-  **Name** : DpgenRom4 – 4 words ROM Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenRom4', modelname
                , param = { 'nbit'     : n
                          , 'val0'     : constVal0
                          , 'val1'     : constVal1
                          , 'val2'     : constVal2
                          , 'val3'     : constVal3
                          , 'physical' : True                   
                          }
                )

-  **Description** : Generates a ``n`` bits 4 words optimized ROM named
   ``modelname``.

-  **Terminal Names** :

   -  **sel1** : upper bit of the address of the value (input, 1 bit)

   -  **sel0** : lower bit of the address of the value (input, 1 bit)

   -  **q** : the selected word (output, ``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **val0** (mandatory) : Defines the first word

   -  **val1** (mandatory) : Defines the second word

   -  **val2** (mandatory) : Defines the third word

   -  **val3** (mandatory) : Defines the fourth word

   -  **physical** (optional, default value : False) : In order to
      generate a layout

-  **Behavior** :

   ::

       q <= WITH sel1 & sel0 SELECT constVal0  WHEN B"00",
                                    constVal1  WHEN B"01",
                                    constVal2  WHEN B"10",
                                    constVal3  WHEN B"11";

-  **Example** :

   ::

       from stratus import *

       class inst_rom4 ( Model ) :

         def Interface ( self ) :
           self.sel0 = SignalIn  (    "sel0", 1 )
           self.sel1 = SignalIn  (    "sel1", 1 )
           self.q    = SignalOut ( "dataout", 4 )
           
           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenRom4', 'rom4_0b1010_0b1100_0b1111_0b0001'
                    , param = { 'nbit'     : 4
                              , 'val0'     : "0b1010"
                              , 'val1'     : "0b1100"
                              , 'val2'     : "0b1111"
                              , 'val3'     : "0b0001"
                              , 'physical' : True
                              }
                    )      
           self.I = Inst ( 'rom4_0b1010_0b1100_0b1111_0b0001', 'inst'
                         , map = { 'sel0' : self.sel0
                                 , 'sel1' : self.sel1
                                 , 'q'    : self.q
                                 , 'vdd'  : self.vdd
                                 , 'vss'  : self.vss
                                 }
                         )
         
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenRam
========

-  **Name** : DpgenRam – RAM Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenRam', modelname
                , param = { 'nbit'     : n
                          , 'nword'    : regNumber
                          , 'physical' : True                   
                          }
                )

-  **Description** : Generates a RAM of ``regNumber`` words of ``n``
   bits named ``modelname``.

-  **Terminal Names** :

   -  **ck** : clock signal (input, 1 bit)

   -  **w** : write requested (input, 1 bit)

   -  **selram** : select the write bus (input, 1 bit)

   -  **ad** : the address (input, ``Y`` bits)

   -  **datain** : write bus (input, ``n`` bits)

   -  **dataout** : read bus (output, ``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **nword** (mandatory) : Defines the size of the words

   -  **physical** (optional, default value : False) : In order to
      generate a layout

-  **Example** :

   ::

       from stratus import *

       class inst_ram ( Model ) :

         def Interface ( self ) :
           self.ck      = SignalIn  (      "ck",  1 )
           self.w       = SignalIn  (       "w",  1 )
           self.selram  = SignalIn  (  "selram",  1 )
           self.ad      = SignalIn  (      "ad",  5 )
           self.datain  = SignalIn  (  "datain", 32 )
           self.dataout = TriState ( "dataout", 32 )
           
           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenRam', 'ram_32_32'
                    , param = { 'nbit'     : 32
                              , 'nword'    : 32
                              , 'physical' : True
                              }
                    )
           self.I = Inst ( 'ram_32_32', 'inst'
                         , map = { 'ck'      : self.ck
                                 , 'w'       : self.w
                                 , 'selram'  : self.selram
                                 , 'ad'      : self.ad
                                 , 'datain'  : self.datain
                                 , 'dataout' : self.dataout
                                 , 'vdd'     : self.vdd
                                 , 'vss'     : self.vss
                                 }
                         )     
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenRf1
========

-  **Name** : DpgenRf1, DpgenRf1r0 – Register File Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenRf1', modelname
                , param = { 'nbit'     : n
                          , 'nword'    : regNumber
                          , 'physical' : True                   
                          }
                )

-  **Description** : Generates a register file of ``regNumber`` words of
   ``n`` bits without decoder named ``modelname``.

-  **Terminal Names** :

   -  **ckok** : clock signal (input, 1 bit)

   -  **sel** : select the write bus (input, 1 bit)

   -  **selr** : the decoded read address (input, ``regNumber`` bits)

   -  **selw** : the decoded write address (input, ``regNumber`` bits)

   -  **datain0** : first write bus (input, ``n`` bits)

   -  **datain1** : second write bus (input, ``n`` bits)

   -  **dataout** : read bus (output, ``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the words (even,
      between 2 and 64)

   -  **nword** (mandatory) : Defines the number of the words (even,
      between 4 and 32)

   -  **physical** (optional, default value : False) : In order to
      generate a layout

-  **How it works** :

   -  datain0 and datain1 are the two write busses. Only one is used to
      actually write the register word, it is selected by the sel
      signal.

   -  When sel is set to zero datain0 is used to write the register
      word, otherwise it will be datain1

   -  selr, selw : this register file have no decoder, so selr have a
      bus width equal to ``regNumber``. One bit for each word

   -  The DpgenRf1r0 variant differs from the DpgenRf1 in that the
      register of address zero is stuck to zero. You can write into it,
      it will not change the value. When read, it will always return
      zero

-  **Example** :

   ::

       from stratus import *

       class inst_rf1 ( Model ) :

         def Interface ( self ) :
           self.ck      = SignalIn    (       "ck",  1 )
           self.sel     = SignalIn    (      "sel",  1 )
           self.selr    = SignalIn    (     "selr", 16 )
           self.selw    = SignalIn    (     "selw", 16 ) 
           self.datain0 = SignalIn    (  "datain0",  4 )
           self.datain1 = SignalIn    (  "datain1",  4 )
           self.dataout = SignalOut   (  "dataout",  4 ) 
           
           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenRf1', 'rf1_4_16'
                    , param = { 'nbit'     : 4
                              , 'nword'    : 16
                              , 'physical' : True
                              }
                    )
           self.I = Inst ( 'rf1_4_16', 'inst'
                         , map =  { 'ck'      : self.ck
                                  , 'sel'     : self.sel
                                  , 'selr'    : self.selr
                                  , 'selw'    : self.selw
                                  , 'datain0' : self.datain0
                                  , 'datain1' : self.datain1
                                  , 'dataout' : self.dataout
                                  , 'vdd'     : self.vdd
                                  , 'vss'     : self.vss
                                  }
                         )
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenRf1d
=========

-  **Name** : DpgenRf1d, DpgenRf1dr0 – Register File with Decoder
   Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenRf1d', modelname
                , param = { 'nbit'     : n
                          , 'nword'    : regNumber
                          , 'physical' : True                   
                          }
                )

-  **Description** : Generates a register file of ``regNumber`` words of
   ``n`` bits with decoder named ``modelname``.

-  **Terminal Names** :

   -  **ck** : clock signal (input, 1 bit)

   -  **sel** : select the write bus (input, 1 bit)

   -  **wen** : write enable (input, 1 bit)

   -  **ren** : read enable (input, 1 bit)

   -  **adr** : the read address (input, ``Y`` bits)

   -  **adw** : the write address (input, ``Y`` bits)

   -  **datain0** : first write bus (input, ``n`` bits)

   -  **datain1** : second write bus (input, ``n`` bits)

   -  **dataout** : read bus (output, ``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the words (even,
      between 2 and 64)

   -  **nword** (mandatory) : Defines the number of the words (even,
      between 6 and 32)

   -  **physical** (optional, default value : False) : In order to
      generate a layout

-  **How it works** :

   -  datain0 and datain1 are the two write busses. Only one is used to
      actually write the register word, it is selected by the sel
      signal.

   -  When sel is set to zero datain0 is used to write the register
      word, otherwise it will be datain1

   -  adr, adw : the width (Y) of those signals is computed from
      regNumber : ``Y = log2(regNumber)``

   -  wen and ren : write enable and read enable, allows reading and
      writing when sets to ``one``

   -  The DpgenRf1dr0 variant differs from the DpgenRf1d in that the
      register of address zero is stuck to zero. You can write into it,
      it will not change the value. When read, it will always return
      zero

-  **Example** :

   ::

       from stratus import *

       class inst_rf1d ( Model ) :

         def Interface ( self ) :
           self.ck      = SignalIn  (       "ck", 1 )
           self.sel     = SignalIn  (      "sel", 1 )
           self.wen     = SignalIn  (      "wen", 1 )
           self.ren     = SignalIn  (      "ren", 1 )
           self.adr     = SignalIn  (      "adr", 4 )
           self.adw     = SignalIn  (      "adw", 4 )
           self.datain0 = SignalIn  (  "datain0", 4 )
           self.datain1 = SignalIn  (  "datain1", 4 )
           self.dataout = SignalOut (  "dataout", 4 )
             
           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenRf1d', 'rf1d_4_16'
                    , param = { 'nbit'     : 4
                              , 'nword'    : 16
                              , 'physical' : True
                              }
                    )
           self.I = Inst ( 'rf1d_4_16', 'inst'
                         , map = { 'ck'      : self.ck
                                 , 'sel'     : self.sel
                                 , 'wen'     : self.wen
                                 , 'ren'     : self.ren
                                 , 'adr'     : self.adr
                                 , 'adw'     : self.adw
                                 , 'datain0' : self.datain0
                                 , 'datain1' : self.datain1
                                 , 'dataout' : self.dataout
                                 , 'vdd'     : self.vdd
                                 , 'vss'     : self.vss
                                 }
                         )
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenFifo
=========

-  **Name** : DpgenFifo – Fifo Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenFifo', modelname
                , param = { 'nbit'       : n
                          , 'nword'      : regNumber
                          , 'physical'   : True                   
                          }
                )

-  **Description** : Generates a FIFO of ``regNumber`` words of ``n``
   bits named ``modelname``.

-  **Terminal Names** :

   -  **ck** : clock signal (input, 1 bit)

   -  **reset** : reset signal (input, 1 bit)

   -  **r** : read requested (input, 1 bit)

   -  **w** : write requested (input, 1 bit)

   -  **rok** : read acknowledge (output, 1 bit)

   -  **wok** : write acknowledge (output, 1 bit)

   -  **sel** : select the write bus (input, 1 bit)

   -  **datain0** : first write bus (input, ``n`` bits)

   -  **datain1** : second write bus (input, ``n`` bits)

   -  **dataout** : read bus (output, ``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the words (even,
      between 2 and 64)

   -  **nword** (mandatory) : Defines the number of words (even, between
      4 and 32)

   -  **physical** (optional, default value : False) : In order to
      generate a layout

-  **How it works** :

   -  datain0 and datain1 : the two write busses. Only one is used to
      actually write the FIFO, it is selected by the sel signal.

   -  sel : when set to ``zero`` the datain0 is used to write the
      register word, otherwise it will be datain1.

   -  r, rok : set r when a word is requested, rok tells that a word has
      effectively been popped (rok == not empty).

   -  w, wok : set w when a word is pushed, wok tells that the word has
      effectively been pushed (wok == not full).

-  **Example** :

   ::

       from stratus import *

       class inst_fifo ( Model ) :

         def Interface ( self ) :
           self.ck      = SignalIn    (       "ck", 1 )
           self.reset   = SignalIn    (    "reset", 1 )
           self.r       = SignalIn    (        "r", 1 )
           self.w       = SignalIn    (        "w", 1 )
           self.rok     = SignalInOut (      "rok", 1 )
           self.wok     = SignalInOut (      "wok", 1 )
           self.sel     = SignalIn    (      "sel", 1 )
           self.datain0 = SignalIn    (  "datain0", 4 )
           self.datain1 = SignalIn    (  "datain1", 4 )
           self.dataout = SignalOut   (  "dataout", 4 ) 
           
           self.vdd   = VddIn ( "vdd" )
           self.vss   = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenFifo', 'fifo_4_16'
                    , param = { 'nbit'     : 4
                              , 'nword'    : 16
                              , 'physical' : True
                              }
                    )      
           self.I = Inst ( 'fifo_4_16', 'inst'
                         , map = { 'ck'      : self.ck
                                 , 'reset'   : self.reset
                                 , 'r'       : self.r
                                 , 'w'       : self.w
                                 , 'rok'     : self.rok
                                 , 'wok'     : self.wok
                                 , 'sel'     : self.sel
                                 , 'datain0' : self.datain0
                                 , 'datain1' : self.datain1
                                 , 'dataout' : self.dataout
                                 , 'vdd'     : self.vdd
                                 , 'vss'     : self.vss
                                 }
                         )
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenDff
========

-  **Name** : DpgenDff – Dynamic Flip-Flop Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenDff', modelname
                , param = { 'nbit'       : n
                          , 'physical'   : True
                          , 'behavioral' : True         
                          }
                )

-  **Description** : Generates a n bits dynamic flip-flop named
   ``modelname``. The two latches of this flip-flop are dynamic, i.e.
   the data is stored in a capacitor.

-  **Terminal Names** :

   -  **wen** : write enable (1 bit)

   -  **ck** : clock signal (1 bit)

   -  **i0** : data input (``n`` bits)

   -  **q** : output (``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **How it works** :

   -  When wen is set to ``one``, enables the writing of the flip-flop

-  **Example** :

   ::

       from stratus import *

       class inst_dff ( Model ) :

         def Interface ( self ) :
           self.ck  = SignalIn  (  "ck", 1 )
           self.wen = SignalIn  ( "wen", 1 )
           self.i   = SignalIn  (   "i", 4 )
           self.o   = SignalOut (   "o", 4 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenDff', 'dff_4'
                    , param = { 'nbit'     : 4
                              , 'physical' : True
                              }
                    )      
           self.I = Inst ( 'dff_4', 'inst'
                         , map = { "wen" : self.wen
                                 , "ck"  : self.ck
                                 , "i0"  : self.i
                                 ,  "q"  : self.o
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenDfft
=========

-  **Name** : DpgenDfft – Dynamic Flip-Flop with Scan-Path
   Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenDfft', modelname
                , param = { 'nbit'       : n
                          , 'physical'   : True
                          , 'behavioral' : True         
                          }
                )

-  **Description** : Generates a n bits dynamic flip-flop with scan-path
   named ``modelname``. The two latches of this flip-flop are dynamic,
   i.e. the data is stored in a capacitor.

-  **Terminal Names** :

   -  **scan** : scan-path mode (input, 1 bit)

   -  **scin** : scan path in (input, 1 bit)

   -  **wen** : write enable (1 bit)

   -  **ck** : clock signal (1 bit)

   -  **i0** : data input (``n`` bits)

   -  **q** : output (``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **How it works** :

   -  When scan is set to ``one``, it enables the scan-path mode. Note
      that in scan-path mode, the wen signal is not effective

   -  scin is the input of the scan-path. This terminal is different
      from ``i0[0]``. The scout is q[N-1] (in the following example this
      is ``q[31]``)

   -  When wen is set to ``one`` enables the writing of the flip-flop

-  **Example** :

   ::

       from stratus import *

       class inst_dfft ( Model ) :

         def Interface ( self ) :
           self.scan = SignalIn  ( "scin", 1 )
           self.scin = SignalIn  ( "scan", 1 )
           self.ck   = SignalIn  (   "ck", 1 )
           self.wen  = SignalIn  (  "wen", 1 )
           self.i    = SignalIn  (    "i", 4 )
           self.o    = SignalOut (    "o", 4 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenDfft', 'dfft_4'
                    , param = { 'nbit' : 4
                              , 'physical' : True
                              }
                    )      
           self.I = Inst ( 'dfft_4', 'inst'
                         , map = { "wen"  : self.wen
                                 , "ck"   : self.ck
                                 , "scan" : self.scan
                                 , "scin" : self.scin
                                 , "i0"   : self.i
                                 ,  "q"   : self.o
                                 , 'vdd'  : self.vdd
                                 , 'vss'  : self.vss
                                 }
                         )
             
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenSff
========

-  **Name** : DpgenSff – Static Flip-Flop Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenSff', modelname
                , param = { 'nbit'       : n
                          , 'physical'   : True         
                          , 'behavioral' : True         
                          }
                )

-  **Description** : Generates a n bits static flip-flop named
   ``modelname``. The two latches of this flip-flop are static, i.e.
   each one is made of two interters looped together.

-  **Terminal Names** :

   -  **wen** : write enable (1 bit)

   -  **ck** : clock signal (1 bit)

   -  **i0** : data input (``n`` bits)

   -  **q** : output (``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **How it works** :

   -  When wen is set to ``one``, enables the writing of the flip-flop

-  **Example** :

   ::

       from stratus import *

       class inst_sff ( Model ) :

         def Interface ( self ) :
           self.ck  = SignalIn  (  "ck", 1 )
           self.wen = SignalIn  ( "wen", 1 )
           self.i   = SignalIn  (   "i", 4 )
           self.o   = SignalOut (   "o", 4 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenSff', 'sff_4'
                    , param = { 'nbit'     : 4
                              , 'physical' : True
                              }
                    )
           self.I = Inst ( 'sff_4', 'inst'
                         , map = { "wen" : self.wen
                                 , "ck"  : self.ck
                                 , "i0"  : self.i
                                 ,  "q"  : self.o
                                 , 'vdd' : self.vdd
                                 , 'vss' : self.vss
                                 }
                         )
                       
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )

DpgenSfft
=========

-  **Name** : DpgenSfft – Static Flip-Flop with Scan-Path
   Macro-Generator

-  **Synopsys** :

   ::

       Generate ( 'DpgenSfft', modelname
                , param = { 'nbit'       : n
                          , 'physical'   : True
                          , 'behavioral' : True         
                          }
                )

-  **Description** : Generates a n bits static flip-flop with scan-path
   named ``modelname``. The two latches of this flip-flop are static
   i.e. each one is made of two interters looped togethers.

-  **Terminal Names** :

   -  **scan** : scan-path mode (input, 1 bit)

   -  **scin** : scan path in (input, 1 bit)

   -  **wen** : write enable (1 bit)

   -  **ck** : clock signal (1 bit)

   -  **i0** : data input (``n`` bits)

   -  **q** : output (``n`` bits)

   -  **vdd** : power

   -  **vss** : ground

-  **Parameters** : Parameters are given in the a map ``param``.

   -  **nbit** (mandatory) : Defines the size of the generator

   -  **physical** (optional, default value : False) : In order to
      generate a layout

   -  **behavioral** (optional, default value : False) : In order to
      generate a behavior

-  **How it works** :

   -  When scan is set to ``one``, it enables the scan-path mode. Note
      that in scan-path mode, the wen signal is not effective

   -  scin : the input of the scan-path. This terminal is different from
      ``i0[0]``. The scout is ``q[N``-``1]`` (in the following example
      this is ``q[3]``)

   -  When wen is set to ``one``, it enables the writing of the
      flip-flop

-  **Example** :

   ::

       from stratus import *

       class inst_sfft ( Model ) :

         def Interface ( self ) :
           self.scan = SignalIn  ( "scin", 1 )
           self.scin = SignalIn  ( "scan", 1 )
           self.ck   = SignalIn  (   "ck", 1 )
           self.wen  = SignalIn  (  "wen", 1 )
           self.i    = SignalIn  (   "in", 4 )
           self.o    = SignalOut (  "out", 4 )

           self.vdd = VddIn ( "vdd" )
           self.vss = VssIn ( "vss" )
           
         def Netlist ( self ) :
           Generate ( 'DpgenSfft', 'sfft_4'
                    , param = { 'nbit'     : 4
                              , 'physical' : True
                              }
                    )
           self.I = Inst ( 'sfft_4', 'inst'
                         , map = { "wen"  : self.wen
                                 , "ck"   : self.ck
                                 , "scan" : self.scan
                                 , "scin" : self.scin
                                 , "i0"   : self.i
                                 ,  "q"   : self.o
                                 , 'vdd'  : self.vdd
                                 , 'vss'  : self.vss
                                 }
                         )
           
         def Layout ( self ) :
           Place ( self.I, NOSYM, Ref(0, 0) )