From WikiChip
Difference between revisions of "inverter"

m
 
(19 intermediate revisions by 3 users not shown)
Line 1: Line 1:
An '''Inverter''' or less commonly, a '''NOT gate''', is a [[logic gate]] which implements logical negation. When the input is LOW, the output is HIGH and when the input is HIGH, the output is LOW. Inverters are the nucleus of all digital systems. Understanding its operation, behavior, and properties for a specific processor makes it possible to expand its design onto more complex structures such as [[NOR gate|NOR]] and [[NAND gate|NAND]] gates. The electrical behavior of much bigger and complex circuitry can be derived by extrapolating the behavior observed from simple inverters.
+
{{title|Inverter}}{{Logic gates}}
 +
An '''Inverter''' or a '''NOT gate''', is a [[logic gate]] which implements logical negation. When the input is LOW, the output is HIGH and when the input is HIGH, the output is LOW. Inverters are the nucleus of all digital systems. Understanding its operation, behavior, and properties for a specific process makes it possible to expand its design onto more complex structures such as [[NOR gate|NOR]] and [[NAND gate|NAND]] gates. The electrical behavior of much bigger and complex circuitry can be derived by extrapolating the behavior observed from simple inverters.
  
 
== Functionality ==  
 
== Functionality ==  
{| class="wikitable right" style="float:right"
+
An inverter generates a signal that is logically opposite to its input. When the input is sufficiently LOW, the output generate is HIGH. Likewise, when the input is sufficiently HIGH, the output generate becomes LOW.
 +
 
 +
Expression:
 +
 
 +
Q = <span style="text-decoration:overline">A</span> = &#x00AC;A
 +
 
 +
{| class="wikitable"
 
|-
 
|-
 
! colspan="2" | NOT Gate
 
! colspan="2" | NOT Gate
Line 12: Line 19:
 
| 1 || 0
 
| 1 || 0
 
|}
 
|}
An inverter generates a signal that is logically opposite to its input. When the input is sufficiently LOW, the output generate is HIGH. Likewise, when the input is sufficiently HIGH, the output generate becomes LOW.
 
  
Expression:
+
== Standard symbols ==
 +
Below are the three standard symbols that represent the NOT gate:
  
Q = <span style="text-decoration:overline">A</span> = &#x00AC;A
+
{| class="wikitable"
 +
|-
 +
! colspan="3" | Standard Symbols
 +
|-
 +
! ANSI !! IEC !! DIN
 +
|-
 +
! [[File:Not gate ansi.svg]] || [[File:Not gate din.svg]] || [[File:Not gate iec.svg]]
 +
|}
  
 
== Implementation ==
 
== Implementation ==
Line 23: Line 37:
 
=== CMOS Inverter ===
 
=== CMOS Inverter ===
 
[[File:Not gate cmos.png|thumb|right|CMOS Inverter]]
 
[[File:Not gate cmos.png|thumb|right|CMOS Inverter]]
A [[static CMOS]] inverted can be constructed from a single [[nMOS]] transistor and a single [[pMOS]] transistor. As usual, the pMOS is connected to VDD and nMOS is connected to ground. When the input is LOW, the nMOS transistor is off and the pMOS transistor is on. The output is pulled up to HIGH as it's connected to VDD but not GND. When the input is HIGH, the nMOS transistor is on and the pMOS transistor is off yielding an output that is connected to GND.
+
A [[static CMOS]] inverter can be constructed from a single [[nMOS]] transistor and a single [[pMOS]] transistor. As usual, the pMOS is connected to VDD and nMOS is connected to ground. When the input is LOW, the nMOS transistor is off and the pMOS transistor is on. The output is pulled up to HIGH as it's connected to VDD but not GND. When the input is HIGH, the nMOS transistor is on and the pMOS transistor is off yielding an output that is connected to GND. CMOS inverters are typically used to drive other MOS devices by connecting a capacitor on the output end; the capacitor is charged and discharged during each switch.
  
 
{| class="wikitable"
 
{| class="wikitable"
! colspan="2" | Steady State Response
+
! colspan="2" | Steady State Response !! G = 0 !! G = 1
 
|-
 
|-
| [[File:CMOS Inverter functionality.png|300px]] || V<sub>OL</sub> = 0<br />V<sub>OH</sub> = V<sub>DD</sub><br />V<sub>M</sub> = f(R<sub>n></sub>, R<sub>p</sub>)<br />
+
| [[File:CMOS Inverter functionality.png|300px]] || V<sub>OL</sub> = 0<br />V<sub>OH</sub> = V<sub>DD</sub><br />V<sub>M</sub> = f(R<sub>n</sub>, R<sub>p</sub>)<br />  
 +
|| [[File:Not gate cmos 0.png|150px]]
 +
|| [[File:Not gate cmos 1.png|150px]]
 
|}
 
|}
  
The Vth point of a CMOS inverter can be approximated using the following expression:
+
The Vth point of a CMOS inverter can be approximated using the expression \( V_{th} = \frac{V_{DD}-|V_{tp}|+V_{th}\sqrt{\frac{K_n}{K_p}}}{1+\sqrt{\frac{K_n}{K_p}}} \) where \( V_{tn} \) and \( V_{tp} \) are the threshold voltages for nMOS and pMOS devices. \( K_n = (\frac{W}{L})_n \centerdot µ\text{N Cox} \) and \( K_p = (\frac{W}{L})_p \centerdot µ\text{P Cox} \). This equation, however, requires caution as it's not practical for the design process due to non-ideal effects (eg. [[short-channel effect|short-channel effects]]). The static [[power dissipation]] during logic 0 and logic 1 are almost zero because \( i_{DP} = i_{DN} = 0 \). When the input is LOW, pMOS is conducting and nMOS is off; the load capacitor is charged via the pMOS device.The power dissipated in the pMOS transistor is \( P_p = i_LV_{P} = i_L(V_{DD}-V_O) \). Likewise, the current can be related by \( i_L = \frac{C_Ldv_O}{dt} \). The energy dissipation in the pMOS device can be expressed as the output switches from LOW to HIGH,
 +
 
 +
<math>
 +
E_p = \int_0^\infty P_p = \int_0^\infty C_L(V_{DD}-v_O)\frac{dV_O}{dt}dt
 +
</math>
 +
 
 +
<math>
 +
E_p = C_LV_{DD} \int_0^{V_{DD}} dv_O - C_L \int_0^{V_{DD}} V_Odv_O
 +
</math>
 +
 
 +
<math>
 +
E_p = \left[C_LV_{DD}V_O \right]_0^{V_{DD}} - \left[ C_L\frac{V_O^2}{2} \right]_0^{V_{DD}}
 +
</math>
 +
 
 +
<math>
 +
E_p = (C_LV_{DD}V_{DD}-0)-(C_L\frac{V_{DD}^2}{2}-0)
 +
</math>
 +
 
 +
<math>
 +
E_p = \frac{1}{2}C_LV_{DD}^2
 +
</math>, where \( E_p \) is the energy stored in capacitor \( C_L \) during HIGH output.
 +
 
 +
When the inverter's input is HIGH and the output is LOW, all the energy stored in the load capacitor is dissipated in the nMOS device because during that time the pMOS is cut off and the nMOS device is conducting. Therefore the energy dissipated in the nMOS device can be expressed as \( E_n = \frac{1}{2}C_LV_{DD}^2 \). During one complete switch cycle the total energy is the sum of both transistors: \( E_T = E_p + E_n = \frac{1}{2}C_LV_{DD}^2 + \frac{1}{2}C_LV_{DD}^2 = C_LV_{DD}^2 \). The power dissipated in terms of [[frequency]] can be expressed as \( E_T = P \centerdot t \); \( P = \frac{E_T}{t} \); \( P = fE_T \); \( P = fC_LV_{DD}^2 \). Which shows that the switching frequency and \( V_{DD}^2 \) are directly proportional to the [[power dissipation]] of a CMOS inverter. The dynamic capacitive power is \( P_{dyn} = C_LV_{DD}^2f \).
 +
 
 +
== VHDL Implementation ==
 +
Below is a straightforward implementation of an inverter in VHDL. The single wire 'a' is the input and the single wire 'q' is the output.
 +
<source lang="VHDL">
 +
library ieee;
 +
use ieee.std_logic_1164.all;
 +
 
 +
entity inverter is
 +
    port ( a : in  std_logic;
 +
          q : out  std_logic);
 +
end inverter;
 +
 
 +
architecture behavioral of inverter is
 +
begin
 +
q <= not a;
 +
end behavioral;
 +
</source>
 +
 
 +
An inverter [[waveform]] for the code above might look like:
 +
 
 +
[[File:Not vhdl waveform.png]]
  
\( Vth = \frac{test}{test2} \)
+
== Discrete chips ==
 +
The 7404 hex inverter is a TTL chip with 14 pins. Two pins are used for VDD and GND, the other 12 pins are used for the 6 independent inverters. Both chips implement the expression \( Q_n = \overline A_n \) where each circuit functions as an independent inverter. The 4049 is a CMOS Hex Inverting Buffer with 16 pins. Two pins are used for VDD and GND, 12 pins are used for the 6 independent inverters. Pins 13 and 16 are not connected.
  
 +
<gallery>
 +
File:7404.svg|7404 Hex Inverter
 +
File:4049.svg|4049 CMOS Hex Inverting Buffer
 +
</gallery>
  
 
[[Category:logic gates]]
 
[[Category:logic gates]]

Latest revision as of 03:50, 8 November 2015

Logic gates

Basic gates

Compound gates

Other topics

v · d · e

An Inverter or a NOT gate, is a logic gate which implements logical negation. When the input is LOW, the output is HIGH and when the input is HIGH, the output is LOW. Inverters are the nucleus of all digital systems. Understanding its operation, behavior, and properties for a specific process makes it possible to expand its design onto more complex structures such as NOR and NAND gates. The electrical behavior of much bigger and complex circuitry can be derived by extrapolating the behavior observed from simple inverters.

Functionality[edit]

An inverter generates a signal that is logically opposite to its input. When the input is sufficiently LOW, the output generate is HIGH. Likewise, when the input is sufficiently HIGH, the output generate becomes LOW.

Expression:

Q = A = ¬A

NOT Gate
A Q
0 1
1 0

Standard symbols[edit]

Below are the three standard symbols that represent the NOT gate:

Standard Symbols
ANSI IEC DIN
Not gate ansi.svg Not gate din.svg Not gate iec.svg

Implementation[edit]

An inverter can be implemented using various transistor technologies.

CMOS Inverter[edit]

CMOS Inverter

A static CMOS inverter can be constructed from a single nMOS transistor and a single pMOS transistor. As usual, the pMOS is connected to VDD and nMOS is connected to ground. When the input is LOW, the nMOS transistor is off and the pMOS transistor is on. The output is pulled up to HIGH as it's connected to VDD but not GND. When the input is HIGH, the nMOS transistor is on and the pMOS transistor is off yielding an output that is connected to GND. CMOS inverters are typically used to drive other MOS devices by connecting a capacitor on the output end; the capacitor is charged and discharged during each switch.

Steady State Response G = 0 G = 1
CMOS Inverter functionality.png VOL = 0
VOH = VDD
VM = f(Rn, Rp)
Not gate cmos 0.png Not gate cmos 1.png

The Vth point of a CMOS inverter can be approximated using the expression \( V_{th} = \frac{V_{DD}-|V_{tp}|+V_{th}\sqrt{\frac{K_n}{K_p}}}{1+\sqrt{\frac{K_n}{K_p}}} \) where \( V_{tn} \) and \( V_{tp} \) are the threshold voltages for nMOS and pMOS devices. \( K_n = (\frac{W}{L})_n \centerdot µ\text{N Cox} \) and \( K_p = (\frac{W}{L})_p \centerdot µ\text{P Cox} \). This equation, however, requires caution as it's not practical for the design process due to non-ideal effects (eg. short-channel effects). The static power dissipation during logic 0 and logic 1 are almost zero because \( i_{DP} = i_{DN} = 0 \). When the input is LOW, pMOS is conducting and nMOS is off; the load capacitor is charged via the pMOS device.The power dissipated in the pMOS transistor is \( P_p = i_LV_{P} = i_L(V_{DD}-V_O) \). Likewise, the current can be related by \( i_L = \frac{C_Ldv_O}{dt} \). The energy dissipation in the pMOS device can be expressed as the output switches from LOW to HIGH,

Equation upper E Subscript p Baseline equals integral Subscript 0 Superscript normal infinity Baseline upper P Subscript p Baseline equals integral Subscript 0 Superscript normal infinity Baseline upper C Subscript upper L Baseline left-parenthesis upper V Subscript upper D upper D Baseline minus v Subscript upper O Baseline right-parenthesis StartFraction d upper V Subscript upper O Baseline Over d t EndFraction d t

Equation upper E Subscript p Baseline equals upper C Subscript upper L Baseline upper V Subscript upper D upper D Baseline integral Subscript 0 Superscript upper V Subscript upper D upper D Baseline Baseline d v Subscript upper O Baseline minus upper C Subscript upper L Baseline integral Subscript 0 Superscript upper V Subscript upper D upper D Baseline Baseline upper V Subscript upper O Baseline d v Subscript upper O Baseline

Equation upper E Subscript p Baseline equals left-bracket upper C Subscript upper L Baseline upper V Subscript upper D upper D Baseline upper V Subscript upper O Baseline right-bracket Subscript 0 Superscript upper V Super Subscript upper D upper D Baseline minus left-bracket upper C Subscript upper L Baseline StartFraction upper V Subscript upper O Superscript 2 Baseline Over 2 EndFraction right-bracket Subscript 0 Superscript upper V Super Subscript upper D upper D

Equation upper E Subscript p Baseline equals left-parenthesis upper C Subscript upper L Baseline upper V Subscript upper D upper D Baseline upper V Subscript upper D upper D Baseline minus 0 right-parenthesis minus left-parenthesis upper C Subscript upper L Baseline StartFraction upper V Subscript upper D upper D Superscript 2 Baseline Over 2 EndFraction minus 0 right-parenthesis

Equation upper E Subscript p Baseline equals one-half upper C Subscript upper L Baseline upper V Subscript upper D upper D Superscript 2 , where \( E_p \) is the energy stored in capacitor \( C_L \) during HIGH output.

When the inverter's input is HIGH and the output is LOW, all the energy stored in the load capacitor is dissipated in the nMOS device because during that time the pMOS is cut off and the nMOS device is conducting. Therefore the energy dissipated in the nMOS device can be expressed as \( E_n = \frac{1}{2}C_LV_{DD}^2 \). During one complete switch cycle the total energy is the sum of both transistors: \( E_T = E_p + E_n = \frac{1}{2}C_LV_{DD}^2 + \frac{1}{2}C_LV_{DD}^2 = C_LV_{DD}^2 \). The power dissipated in terms of frequency can be expressed as \( E_T = P \centerdot t \); \( P = \frac{E_T}{t} \); \( P = fE_T \); \( P = fC_LV_{DD}^2 \). Which shows that the switching frequency and \( V_{DD}^2 \) are directly proportional to the power dissipation of a CMOS inverter. The dynamic capacitive power is \( P_{dyn} = C_LV_{DD}^2f \).

VHDL Implementation[edit]

Below is a straightforward implementation of an inverter in VHDL. The single wire 'a' is the input and the single wire 'q' is the output.

library ieee;
use ieee.std_logic_1164.all;

entity inverter is
    port ( a : in   std_logic;
           q : out  std_logic);
end inverter;

architecture behavioral of inverter is
begin
	q <= not a;
end behavioral;

An inverter waveform for the code above might look like:

Not vhdl waveform.png

Discrete chips[edit]

The 7404 hex inverter is a TTL chip with 14 pins. Two pins are used for VDD and GND, the other 12 pins are used for the 6 independent inverters. Both chips implement the expression \( Q_n = \overline A_n \) where each circuit functions as an independent inverter. The 4049 is a CMOS Hex Inverting Buffer with 16 pins. Two pins are used for VDD and GND, 12 pins are used for the 6 independent inverters. Pins 13 and 16 are not connected.