From fbcb9da573ec00ef8ff625cd1986e777864146da Mon Sep 17 00:00:00 2001 From: Vadim Kuznetsov Date: Sun, 5 Jan 2025 11:19:59 +0300 Subject: [PATCH 1/3] Update digital libraries --- library/CMakeLists.txt | 2 +- library/Digital_CD4000.lib | 698 ------------------------ library/Digital_HC.lib | 1028 ++++++++++++++++++++++++++++++++++-- library/Digital_LV.lib | 819 +++++++++++++++++++++++++++- library/qucs.blacklist | 2 +- library/xyce.blacklist | 2 +- 6 files changed, 1814 insertions(+), 737 deletions(-) delete mode 100644 library/Digital_CD4000.lib diff --git a/library/CMakeLists.txt b/library/CMakeLists.txt index 591ed7d6..457fef24 100644 --- a/library/CMakeLists.txt +++ b/library/CMakeLists.txt @@ -9,7 +9,7 @@ Crystal.lib Diodes.lib DiodesSchottky.lib Diodes_Extended.lib -Digital_CD4000.lib +Digital_CD.lib Digital_HC.lib Digital_LV.lib GeDiodes.lib diff --git a/library/Digital_CD4000.lib b/library/Digital_CD4000.lib deleted file mode 100644 index 31d54503..00000000 --- a/library/Digital_CD4000.lib +++ /dev/null @@ -1,698 +0,0 @@ - - - - -Quad 2-Input CMOS NAND - - -.Def:Digital_CD4000_CD4011 _net0 _net2 _net1 -Sub:X1 _net0 _net2 _net1 gnd Type="CD4011_cir" -.Def:End - - - -* ----------------------- CD4011B ------------------------- -* -* Quad 2-Input NAND Gate -* -* The CMOS Logic Data Book, 1991, Motorola Pages 6-5 to 6-14 -* jds 6/6/94 -* This part is shown in the data book as MC14011B -* -.SUBCKT CD4011B IN1A IN2A OUTA -+ optional: VDD=$G_CD4000_VDD VSS=$G_CD4000_VSS -+ params: MNTYMXDLY=0 IO_LEVEL=0 -* -Uf0 nand(2) VDD VSS -+ IN1A IN2A OUTA -+ DLY_MOD IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} - -.model DLY_MOD ugate (TPLHMN=-1 TPLHTY=125ns TPLHMX=250ns -+ TPHLMN=-1 TPHLTY=125ns TPHLMX=250ns) - -.ENDS CD4011B -* - -.SUBCKT Digital_CD4000_CD4011 gnd _net0 _net2 _net1 -X1 _net0 _net2 _net1 CD4011B -.ENDS - - - - - - - - - <.PortSym -30 -10 1 0 P1> - <.PortSym -30 10 2 0 P2> - <.PortSym 30 0 3 180 P3> - <.ID 10 14 Y> - - - - - -Two D-type CMOS Flip-flops - - -.Def:Digital_CD4000_CD4013 _net0 _net1 _net2 _net3 _net4 _net5 -Sub:X1 _net0 _net1 _net2 _net3 _net4 _net5 gnd Type="CD4013_cir" -.Def:End - - - -* ----------------------------- CD4013B ------------------------ -* -* Dual Type D Flip-Flop -* -* The CMOS Logic Data Book, 1991, Motorola Pages 6-33 to 6-36 -* jds 6/6/94 -* This part is shown in the data book as MC14013B -* -.SUBCKT CD4013B SA RA CA DA QA QABAR -+ optional: VDD=$G_CD4000_VDD VSS=$G_CD4000_VSS -+ params: MNTYMXDLY=0 IO_LEVEL=0 -* -Uf0 inva(2) VDD VSS -+ SA RA prebar clrbar -+ D0_GATE IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} - -Uf1 dff(1) VDD VSS -+ prebar clrbar CA DA Q_A Q_ABAR -+ DFF4013B IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} - -.MODEL DFF4013B UEFF(TWPCLMN=250NS TWPCLTY=125NS TWPCLMX=-1 -+ TWCLKLMN=250NS TWCLKLTY=125NS TWCLKLMX=-1 -+ TWCLKHMN=250NS TWCLKHTY=125NS TWCLKHMX=-1 -+ TSUDCLKMN=-1NS TSUDCLKTY=250NS TSUDCLKMX=-1 -+ THDCLKMN=40NS THDCLKTY=20NS THDCLKMX=-1) - -U3 PINDLY(2,0,3) VDD VSS -+ Q_A Q_ABAR -+ CA SA RA -+ QA QABAR -+ IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} -+ BOOLEAN: -+ EDGE = {CHANGED_LH(CA,0)} -+ SET = {CHANGED_LH(SA,0)} -+ CLEAR = {CHANGED_LH(RA,0)} -+ PINDLY: -+ QA QABAR = { -+ CASE( -+ SET, DELAY(-1,175NS,350NS), -+ CLEAR, DELAY(-1,225NS,450NS), -+ EDGE & (TRN_LH | TRN_HL), DELAY(-1,175NS,350NS), -+ DELAY(-1,226NS,451NS))} - -U4 CONSTRAINT(3) VDD VSS -+ CA SA RA -+ IO_4000B IO_LEVEL={IO_LEVEL} -+ FREQ: -+ NODE = CA -+ MAXFREQ = 2MEG -+ SETUP_HOLD: -+ CLOCK LH = CA -+ DATA(2) = SA RA -+ SETUPTIME_LO = 80NS -+ HOLDTIME_LO = 50NS - -.ENDS CD4013B -* - -.SUBCKT Digital_CD4000_CD4013 gnd _net0 _net1 _net2 _net3 _net4 _net5 -X1 _net0 _net1 _net2 _net3 _net4 _net5 CD4013B -.ENDS - - - - - - - - - - - - <.PortSym -50 20 3 0 CA> - <.PortSym -50 -20 4 0 DA> - <.PortSym 50 -20 5 180 QA> - <.PortSym 50 20 6 180 QAB> - <.PortSym 0 -60 2 0 RA> - <.PortSym 0 60 1 0 SA> - - <.ID 20 44 Y> - - - - - - - - - - -Decade counter with 10 decoded outputs - - -.Def:Digital_CD4000_CD4017 _net13 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 _net12 -Sub:X1 _net13 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 _net12 gnd Type="CD4017_cir" -.Def:End - - - -* ------------------- CD4017B---------------- -* -* Decade Counter -* -* The CMOS Logic Data Book, 1991, Motorola Pages 6-54 to 6-58 -* jds 6/6/94 -* This part is shown in the data book as MC14017B -* Note that the NAND gate feeding into the 3rd flip-flops D input should -* be an AND gate for the circuit to operate as in the timing diagram. -* -.SUBCKT CD4017B CLK CLKENBAR RESET COUT Q0 Q1 Q2 Q3 Q4 Q5 Q6 Q7 Q8 Q9 -+ optional: VDD=$G_CD4000_VDD VSS=$G_CD4000_VSS -+ params: MNTYMXDLY=0 IO_LEVEL=0 - -U14017B LOGICEXP(13,14) VDD VSS -+ CLK CLKENBAR RESET q1ff q2ff q3ff q4ff q5ff -+ q1ffbar q2ffbar q3ffbar q4ffbar q5ffbar -+ clock clear i1 -+ COUT_O Q0_O Q1_O Q2_O Q3_O Q4_O Q5_O Q6_O Q7_O Q8_O Q9_O -+ D0_GATE IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} -+ -+ LOGIC: -+ clock = {( CLK & ~CLKENBAR )} -+ clear = { (~RESET) } -+ i1 = { (q2ff & (q1ff | q3ff)) } -+ Q0_O = { (q1ffbar & q5ffbar) } -+ Q1_O = { (q1ff & q2ffbar) } -+ Q2_O = { (q2ff & q3ffbar) } -+ Q3_O = { (q3ff & q4ffbar) } -+ Q4_O = { (q4ff & q5ffbar) } -+ Q5_O = { (q1ff & q5ff) } -+ Q6_O = { (q1ffbar & q2ff) } -+ Q7_O = { (q2ffbar & q3ff) } -+ Q8_O = { (q3ffbar & q4ff) } -+ Q9_O = { (q5ff & q4ffbar) } -+ COUT_O = { q5ffbar } - -Uf0 dff(5) VDD VSS -+ $D_HI clear clock q5ffbar q1ff i1 q3ff q4ff -+ q1ff q2ff q3ff q4ff q5ff q1ffbar q2ffbar q3ffbar q4ffbar q5ffbar -+ DLY_DFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} - -.MODEL DLY_DFF UEFF(TWCLKLMN=-1 TWCLKLTY=125NS TWCLKLMX=250NS -+ TWCLKHMN=-1 TWCLKHTY=125NS TWCLKHMX=250NS) - -Udly PINDLY (11,0,2) VDD VSS -+ COUT_O Q0_O Q1_O Q2_O Q3_O Q4_O Q5_O Q6_O Q7_O Q8_O Q9_O -+ CLK RESET -+ COUT Q0 Q1 Q2 Q3 Q4 Q5 Q6 Q7 Q8 Q9 -+ IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} -+ -+ BOOLEAN: -+ CP = {CHANGED_LH(CLK,0)} -+ CLR = { CHANGED_LH(RESET,0) } -+ -+ PINDLY: -+ Q0 Q1 Q2 Q3 Q4 Q5 Q6 Q7 Q8 Q9 = { -+ CASE( -+ CLR, DELAY(-1,500ns,1us), -+ CP, DELAY(-1,500ns,1us), -+ DELAY(-1,501ns,1.001us) -+ ) -+ } -+ COUT = { -+ CASE( -+ CLR, DELAY(-1,400ns,800ns), -+ CP, DELAY(-1,400ns,800ns), -+ DELAY(-1,401ns,801ns) -+ ) -+ } - -Ucnstr CONSTRAINT(3) VDD VSS -+ CLKENBAR CLK RESET -+ IO_4000B -+ -+ FREQ: -+ NODE = CLK -+ MAXFREQ = 5MEG -+ WIDTH: -+ NODE = RESET -+ MIN_HI = 250ns -+ SETUP_HOLD: -+ CLOCK LH = CLK -+ DATA(1) = CLKENBAR -+ SETUPTIME_HI = 175ns -+ SETUPTIME_LO = 260ns -+ WHEN = { RESET != '1 } -+ SETUP_HOLD: -+ CLOCK LH = CLK -+ DATA(1) = RESET -+ SETUPTIME_LO = 375ns - -.ENDS CD4017B -* - -.SUBCKT Digital_CD4000_CD4017 gnd _net13 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 _net12 -X1 _net13 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 _net12 CD4017B -.ENDS - - - - - - - - - - - - - - - - - - - - - - - - <.PortSym -50 0 1 0 CLK> - - - <.PortSym 50 0 5 180 Q0> - <.PortSym 50 20 6 180 Q1> - <.PortSym 50 40 7 180 Q2> - <.PortSym 50 60 8 180 Q3> - <.PortSym 50 80 9 180 Q4> - <.PortSym 50 100 10 180 Q5> - <.PortSym 50 120 11 180 Q6> - <.PortSym 50 140 12 180 Q7> - <.PortSym 50 160 13 180 Q8> - <.PortSym 50 180 14 180 Q9> - - - - <.ID -10 234 Y> - <.PortSym -50 60 3 0 RST> - - <.PortSym -50 20 2 0 CLKENB> - - - <.PortSym 50 210 4 180 COUT> - - - - - - - -Octal counter with 8 decoded outputs - - -.Def:Digital_CD4000_CD4022 _net11 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 -Sub:X1 _net11 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 gnd Type="CD4022_cir" -.Def:End - - - -*---------------------------CD4022B---------------------------------- -* -* Divide by 8 Counter/Divider with 8 Decoded Outputs -* National Semiconductor, CMOS Logic Databook, 1988, pages 5-57 to 5-62 -* jat 8/18/95 -* Note that there should only be a single inversion in front of COUT, not -* a double inversion as shown in the logic diagram. - -.SUBCKT CD4022B -+ CLK CLKENBAR RESET COUT Q0 Q1 Q2 Q3 Q4 Q5 Q6 Q7 -+ OPTIONAL: VDD=$G_CD4000_VDD VSS=$G_CD4000_VSS -+ PARAMS: MNTYMXDLY=0 IO_LEVEL=0 - -U1 LOGICEXP(11,12) VDD VSS -+ CLK CLKENBAR RESET Q1FF Q2FF Q3FF Q4FF Q1FFBAR Q2FFBAR Q3FFBAR Q4FFBAR -+ CLOCK CLEAR D3 COUT_O Q0_O Q1_O Q2_O Q3_O Q4_O Q5_O Q6_O Q7_O -+ D0_GATE IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} -+ LOGIC: -+ CLOCK = {(CLK & (~CLKENBAR))} -+ CLEAR = {(~RESET)} -+ D3 = {~(Q2FFBAR | (~(Q1FF | Q2FFBAR | Q3FF)))} -+ Q0_O = {(Q1FFBAR & Q4FFBAR) } -+ Q1_O = {(Q1FF & Q2FFBAR)} -+ Q2_O = {(Q2FF & Q3FFBAR)} -+ Q3_O = {(Q3FF & Q4FFBAR)} -+ Q4_O = {(Q1FF & Q4FF)} -+ Q5_O = {(Q1FFBAR & Q2FF)} -+ Q6_O = {(Q2FFBAR & Q3FF)} -+ Q7_O = {(Q3FFBAR & Q4FF)} -+ COUT_O = {~Q4FF} - -U2 DFF(4) VDD VSS -+ $D_HI CLEAR CLOCK -+ Q4FFBAR Q1FF D3 Q3FF -+ Q1FF Q2FF Q3FF Q4FF Q1FFBAR Q2FFBAR Q3FFBAR Q4FFBAR -+ DLY_DFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} - -.MODEL DLY_DFF UEFF(TWCLKLMN=-1 TWCLKLTY=125NS TWCLKLMX=250NS -+ TWCLKHMN=-1 TWCLKHTY=125NS TWCLKHMX=250NS) - -U3 PINDLY(9,0,2) VDD VSS -+ COUT_O Q0_O Q1_O Q2_O Q3_O Q4_O Q5_O Q6_O Q7_O -+ CLK RESET -+ COUT Q0 Q1 Q2 Q3 Q4 Q5 Q6 Q7 -+ IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} -+ BOOLEAN: -+ EDGE = {CHANGED_LH(CLK,0)} -+ CLR = {CHANGED_LH(RESET,0)} -+ PINDLY: -+ Q0 Q1 Q2 Q3 Q4 Q5 Q6 Q7 = { -+ CASE( -+ EDGE & (TRN_LH | TRN_HL), DELAY(-1,500NS,1000NS), -+ CLR & (TRN_LH | TRN_HL), DELAY(-1,500NS,1000NS), -+ DELAY(-1,501NS,1001NS))} -+ COUT = { -+ CASE( -+ EDGE & (TRN_LH | TRN_HL), DELAY(-1,415NS,800NS), -+ CLR & (TRN_LH | TRN_HL), DELAY(-1,415NS,800NS), -+ DELAY(-1,416NS,801NS))} - -U4 CONSTRAINT(3) VDD VSS -+ CLKENBAR CLK RESET -+ IO_4000B IO_LEVEL={IO_LEVEL} -+ FREQ: -+ NODE = CLK -+ MAXFREQ = 2MEG -+ WIDTH: -+ NODE = RESET -+ MIN_HI = 200NS -+ SETUP_HOLD: -+ CLOCK LH = CLK -+ DATA(1) = CLKENBAR -+ SETUPTIME_HI = 120NS -+ WHEN = { RESET != '1 } -+ SETUP_HOLD: -+ CLOCK LH = CLK -+ DATA(1) = RESET -+ SETUPTIME_LO = 75NS - -.ENDS CD4022B - -.SUBCKT Digital_CD4000_CD4022 gnd _net11 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 -X1 _net11 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 CD4022B -.ENDS - - - - - - - - - - - - - - - - - - - - - - <.PortSym -50 0 1 0 CLK> - - - <.PortSym 50 0 5 180 Q0> - <.PortSym 50 20 6 180 Q1> - <.PortSym 50 40 7 180 Q2> - <.PortSym 50 60 8 180 Q3> - <.PortSym 50 80 9 180 Q4> - <.PortSym 50 100 10 180 Q5> - <.PortSym 50 120 11 180 Q6> - <.PortSym 50 140 12 180 Q7> - - - <.PortSym -50 60 3 0 RST> - - <.PortSym -50 20 2 0 CLKENB> - - - - <.PortSym 50 180 4 180 COUT> - <.ID -10 204 Y> - - - - - - - - -.Def:Digital_CD4000_CD4040 _net12 _net13 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 -Sub:X1 _net12 _net13 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 gnd Type="CD4040_cir" -.Def:End - - - -* ----------------------- CD4040B ----------------------- -* -* 12-Stage Binary Counter -* -* The CMOS Logic Data Book, 1991, Motorola Pages 6-108 to 6-111 -* jds 6/8/94 -* This part is shown in the data book as MC14040B -* -.SUBCKT CD4040B CLK RESET Q1 Q2 Q3 Q4 Q5 Q6 Q7 Q8 Q9 Q10 Q11 Q12 -+ optional: VDD=$G_CD4000_VDD VSS=$G_CD4000_VSS -+ params: MNTYMXDLY=0 IO_LEVEL=0 - -USTBUF BUF VDD VSS -+ CLK CLKST -+ D0_GATE IO_4000B_ST MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} - -uf0 inv VDD VSS -+ RESET clr -+ D0_GATE IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} - -Uf1 jkff(1) VDD VSS -+ $D_HI clr CLKST $D_HI $D_HI Q1_O Q1BAR_O -+ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} - -Uf2 jkff(1) VDD VSS -+ $D_HI clr Q1_O $D_HI $D_HI Q2_O Q2BAR_O -+ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} - -Uf3 jkff(1) VDD VSS -+ $D_HI clr Q2_O $D_HI $D_HI Q3_O Q3BAR_O -+ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} - -Uf4 jkff(1) VDD VSS -+ $D_HI clr Q3_O $D_HI $D_HI Q4_O Q4BAR_O -+ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} - -Uf5 jkff(1) VDD VSS -+ $D_HI clr Q4_O $D_HI $D_HI Q5_O Q5BAR_O -+ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} - -Uf6 jkff(1) VDD VSS -+ $D_HI clr Q5_O $D_HI $D_HI Q6_O Q6BAR_O -+ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} - -Uf7 jkff(1) VDD VSS -+ $D_HI clr Q6_O $D_HI $D_HI Q7_O Q7BAR_O -+ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} - -Uf8 jkff(1) VDD VSS -+ $D_HI clr Q7_O $D_HI $D_HI Q8_O Q8BAR_O -+ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} - -Uf9 jkff(1) VDD VSS -+ $D_HI clr Q8_O $D_HI $D_HI Q9_O Q9BAR_O -+ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} - -Uf10 jkff(1) VDD VSS -+ $D_HI clr Q9_O $D_HI $D_HI Q10_O Q10BAR_O -+ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} - -Uf11 jkff(1) VDD VSS -+ $D_HI clr Q10_O $D_HI $D_HI Q11_O Q11BAR_O -+ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} - -Uf12 jkff(1) VDD VSS -+ $D_HI clr Q11_O $D_HI $D_HI Q12_O Q12BAR_O -+ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} - -Udly PINDLY (12,0,13) VDD VSS -+ Q1_O Q2_O Q3_O Q4_O Q5_O Q6_O Q7_O Q8_O Q9_O Q10_O Q11_O Q12_O -+ CLK RESET Q1BAR Q2BAR Q3BAR Q4BAR Q5BAR Q6BAR Q7BAR -+ Q8BAR Q9BAR Q10BAR Q11BAR -+ Q1 Q2 Q3 Q4 Q5 Q6 Q7 Q8 Q9 Q10 Q11 Q12 -+ IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} -+ -+ PINDLY: -+ Q1 = { -+ CASE( -+ CHANGED(RESET,0) & TRN_HL, DELAY(-1,370ns,740ns), -+ CHANGED_HL(CLK,0), DELAY(-1,260ns,520ns), -+ DELAY(-1,261ns,521ns) -+ ) -+ } -+ Q2 = { -+ CASE( -+ CHANGED(RESET,0) & TRN_HL, DELAY(-1,370ns,740ns), -+ CHANGED_HL(Q1_O,0), DELAY(-1,384.1ns,768.2ns), -+ DELAY(-1,385.1ns,769.2ns) -+ ) -+ } -+ Q3 = { -+ CASE( -+ CHANGED(RESET,0) & TRN_HL, DELAY(-1,370ns,740ns), -+ CHANGED_HL(Q2_O,0), DELAY(-1,508.2ns,1016.4ns), -+ DELAY(-1,509.2ns,1017.4ns) -+ ) -+ } -+ Q4 = { -+ CASE( -+ CHANGED(RESET,0) & TRN_HL, DELAY(-1,370ns,740ns), -+ CHANGED_HL(Q3_O,0), DELAY(-1,632.3ns,1264.6ns), -+ DELAY(-1,633.3ns,1265.6ns) -+ ) -+ } -+ Q5 = { -+ CASE( -+ CHANGED(RESET,0) & TRN_HL, DELAY(-1,370ns,740ns), -+ CHANGED_HL(Q4_O,0), DELAY(-1,756.4ns,1512.8ns), -+ DELAY(-1,757.4ns,1513.8ns) -+ ) -+ } -+ Q6 = { -+ CASE( -+ CHANGED(RESET,0) & TRN_HL, DELAY(-1,370ns,740ns), -+ CHANGED_HL(Q5_O,0), DELAY(-1,880.5ns,1761ns), -+ DELAY(-1,881.5ns,1762ns) -+ ) -+ } -+ Q7 = { -+ CASE( -+ CHANGED(RESET,0) & TRN_HL, DELAY(-1,370ns,740ns), -+ CHANGED_HL(Q6_O,0), DELAY(-1,1004.6ns,2009.2ns), -+ DELAY(-1,1005.6ns,2010.2ns) -+ ) -+ } -+ Q8 = { -+ CASE( -+ CHANGED(RESET,0) & TRN_HL, DELAY(-1,370ns,740ns), -+ CHANGED_HL(Q7_O,0), DELAY(-1,1128.7ns,2257.4ns), -+ DELAY(-1,1129.7ns,2258.4ns) -+ ) -+ } -+ Q9 = { -+ CASE( -+ CHANGED(RESET,0) & TRN_HL, DELAY(-1,370ns,740ns), -+ CHANGED_HL(Q8_O,0), DELAY(-1,1252.8ns,2505.6ns), -+ DELAY(-1,1253.8ns,2506.6ns) -+ ) -+ } -+ Q10 = { -+ CASE( -+ CHANGED(RESET,0) & TRN_HL, DELAY(-1,370ns,740ns), -+ CHANGED_HL(Q9_O,0), DELAY(-1,1376.9ns,2753.8ns), -+ DELAY(-1,1377.9ns,2754.8ns) -+ ) -+ } -+ Q11 = { -+ CASE( -+ CHANGED(RESET,0) & TRN_HL, DELAY(-1,370ns,740ns), -+ CHANGED_HL(Q10_O,0), DELAY(-1,1501ns,3002ns), -+ DELAY(-1,1502ns,3003ns) -+ ) -+ } -+ Q12 = { -+ CASE( -+ CHANGED(RESET,0) & TRN_HL, DELAY(-1,370ns,740ns), -+ CHANGED_HL(Q11_O,0), DELAY(-1,1625ns,3250ns), -+ DELAY(-1,1626ns,3251ns) -+ ) -+ } - -Ucnstr CONSTRAINT(2) VDD VSS -+ CLK RESET -+ IO_4000B -+ -+ FREQ: -+ NODE = CLK -+ MAXFREQ = 2.1MEG -+ WIDTH: -+ NODE = CLK -+ MIN_HI = 140ns -+ WIDTH: -+ NODE = RESET -+ MIN_HI = 320ns -+ SETUP_HOLD: -+ CLOCK HL = CLK -+ DATA(1) = RESET -+ SETUPTIME_LO = 65ns - -.ENDS CD4040B -* - -.SUBCKT Digital_CD4000_CD4040 gnd _net12 _net13 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 -X1 _net12 _net13 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 CD4040B -.ENDS - - - - - - - - - - - - - - - - - - - - - - - - <.PortSym 50 0 3 180 QA> - <.PortSym 50 20 4 180 QB> - <.PortSym 50 40 5 180 QC> - <.PortSym 50 60 6 180 QD> - <.PortSym 50 80 7 180 QE> - <.PortSym 50 100 8 180 QF> - <.PortSym 50 120 9 180 QG> - <.PortSym 50 140 10 180 QH> - <.PortSym 50 160 11 180 QI> - <.PortSym 50 180 12 180 QJ> - - - - - <.ID -10 244 Y> - <.PortSym 50 200 13 180 QK> - <.PortSym 50 220 14 180 QL> - - - - - - <.PortSym -50 60 2 0 RES> - <.PortSym -50 0 1 0 CLK> - - - diff --git a/library/Digital_HC.lib b/library/Digital_HC.lib index a14571e6..9c2b5cfc 100644 --- a/library/Digital_HC.lib +++ b/library/Digital_HC.lib @@ -2,8 +2,8 @@ -2-Input Nand Gate - +2-Input NAND Gate +XSPICE Based Model Requirements: .spiceinit: set ngbehavior=psa .PARAM: vcc=5 @@ -15,7 +15,7 @@ Sub:X1 _net0 _net1 _net2 gnd Type="n74HC00_cir" -* ----------------------------------------------------------- 74HC00 ------ +* ---------------------------------- 74HC00 ------------------------------- * Quad 2-Input Nand Gates * * The High-Speed CMOS Logic Data Book, 1989, TI Pages 2-3 to 2-5 @@ -39,7 +39,7 @@ X1 _net0 _net1 _net2 74HC00 - + @@ -53,8 +53,8 @@ X1 _net0 _net1 _net2 74HC00 -2-Input Nor Gate - +2-Input NOR Gate +XSPICE Based Model Requirements: .spiceinit: set ngbehavior=psa .PARAM: vcc=5 @@ -66,7 +66,7 @@ Sub:X1 _net0 _net2 _net1 gnd Type="n74HC02_cir" -* ----------------------------------------------------------- 74HC02 ------ +* ----------------------------------- 74HC02 ------------------------------ * Quad 2-Input Nor Gates * * The High-Speed CMOS Logic Data Book, 1989, TI Pages 2-13 to 2-15 @@ -99,15 +99,15 @@ X1 _net0 _net2 _net1 74HC02 - - + + Inverter - +XSPICE Based Model Requirements: .spiceinit: set ngbehavior=psa .PARAM: vcc=5 @@ -119,7 +119,7 @@ Sub:X1 _net0 _net1 gnd Type="n74HC04_cir" -* ----------------------------------------------------------- 74HC04 ------ +* ------------------------------- 74HC04 ------------------------- * Hex Inverters * * The High-Speed CMOS Logic Data Book, 1989, TI Pages 2-23 to 2-25 @@ -143,7 +143,7 @@ X1 _net0 _net1 74HC04 - + <.ID 10 14 Y> @@ -155,8 +155,8 @@ X1 _net0 _net1 74HC04 -2-Input And Gate - +2-Input AND Gate +XSPICE Based Model Requirements: .spiceinit: set ngbehavior=psa .PARAM: vcc=5 @@ -168,7 +168,7 @@ Sub:X1 _net0 _net2 _net1 gnd Type="n74HC08_cir" -* ----------------------------------------------------------- 74HC08 ------ +* ---------------------------------- 74HC08 ----------------------- * Quad 2-Input And Gates * * The High-Speed CMOS Logic Data Book, 1989, TI Pages 2-37 to 2-39 @@ -196,7 +196,7 @@ X1 _net0 _net2 _net1 74HC08 <.PortSym 30 0 3 180 P3> <.ID 10 14 Y> - + @@ -205,8 +205,8 @@ X1 _net0 _net2 _net1 74HC08 -2-Input Or Gate - +2-Input OR Gate +XSPICE Based Model Requirements: .spiceinit: set ngbehavior=psa .PARAM: vcc=5 @@ -218,7 +218,7 @@ Sub:X1 _net0 _net2 _net1 gnd Type="n74HC32_cir" -* ----------------------------------------------------------- 74HC32 ------ +* ---------------------------------- 74HC32 ------------------------ * Quad 2-Input Or Gates * * The High-Speed CMOS Logic Data Book, 1989, TI Pages 2-77 to 2-79 @@ -250,15 +250,15 @@ X1 _net0 _net2 _net1 74HC32 - - + + D-Type Positive Edge Triggered Flip-Flop With Preset And Clear - +XSPICE Based Model Requirements: .spiceinit: set ngbehavior=psa .PARAM: vcc=5 @@ -270,7 +270,7 @@ Sub:X1 _net0 _net1 _net2 _net3 _net4 _net5 gnd Type="n74HC74_cir" -* ----------------------------------------------------------- 74HC74 ------ +* --------------------------------- 74HC74 ------------------------- * Dual D-Type Positive Edge Triggered Flip-Flops With Preset And Clear * * The High-Speed CMOS Logic Data Book, 1989, TI Pages 2-101 to 2-103 @@ -326,8 +326,8 @@ X1 _net0 _net1 _net2 _net3 _net4 _net5 74HC74 -2-Input Exclusive-Or Gate - +2-Input Exclusive-OR Gate +XSPICE Based Model Requirements: .spiceinit: set ngbehavior=psa .PARAM: vcc=5 @@ -339,7 +339,7 @@ Sub:X1 _net0 _net2 _net1 gnd Type="n74HC86_cir" -* ----------------------------------------------------------- 74HC86 ------ +* --------------------------------- 74HC86 ------------------------ * Quad 2-Input Exclusive-Or Gates * * The High-Speed CMOS Logic Data Book, 1989, TI Pages 2-129 to 2-131 @@ -377,8 +377,8 @@ X1 _net0 _net2 _net1 74HC86 -2-Input Nand Gate - +2-Input NAND Gate +XSPICE Based Model Requirements: .spiceinit: set ngbehavior=psa .PARAM: vcc=5 @@ -390,7 +390,7 @@ Sub:X1 _net0 _net2 _net1 gnd Type="n74HC132_cir" -* ----------------------------------------------------------- 74HC132 ------ +* ---------------------------------- 74HC132 ---------------------------- * Quad 2-Input Nand Schmitt Triggers * * The High-Speed CMOS Logic Data Book, 1989, TI Pages 2-159 to 2-161 @@ -416,7 +416,7 @@ X1 _net0 _net2 _net1 74HC132 <.PortSym -30 10 2 0 P2> <.PortSym 30 0 3 180 P3> - + @@ -430,3 +430,971 @@ X1 _net0 _net2 _net1 74HC132 + + +8-Bit Parallel-Out Serial Shift Register +XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa +.PARAM: vcc=5 + + +.Def:Digital_HC_74HC164 _net0 _net1 _net3 _net2 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 +Sub:X1 _net0 _net1 _net3 _net2 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 gnd Type="n74HC164_cir" +.Def:End + + + +* ------------------------------- 74HC164 ---------------------------------- +* 8-Bit Parallel-Out Serial Shift Register +* +* The High Speed CMOS Logic Data Book, 1989, TI Pages 2-231 to 2-234 +* jds 3/28/94 +* +.SUBCKT 74HC164B A B CLRBAR CLK QA QB QC QD QE QF QG QH ++ optional: DPWR=$G_DPWR DGND=$G_DGND ++ params: MNTYMXDLY=0 IO_LEVEL=0 + +U74HC164 LOGICEXP (3,3) DPWR DGND ++ CLK A B ++ r0 s0 clkbar ++ D0_GATE IO_HC IO_LEVEL={IO_LEVEL} ++ ++ LOGIC: ++ r0 = { (~(A & B)) } ++ s0 = { (~r0) } ++ clkbar = { (~CLK) } + + +uf0 JKff(8) DPWR DGND ++ $D_HI CLRBAR clkbar ++ s0 QA_O QB_O QC_O QD_O QE_O QF_O QG_O ++ r0 qabar qbbar qcbar qdbar qebar qfbar qgbar ++ QA_O QB_O QC_O QD_O QE_O QF_O QG_O QH_O ++ qabar qbbar qcbar qdbar qebar qfbar qgbar qhbar ++ D0_EFF IO_HC + +Udly PINDLY (8,0,4) DPWR DGND ++ QA_O QB_O QC_O QD_O QE_O QF_O QG_O QH_O ++ CLRBAR CLK A B ++ QA QB QC QD QE QF QG QH ++ IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} ++ ++ BOOLEAN: ++ DATA= { ( CHANGED(A,0) | CHANGED(B,0) ) } ++ CLOCK= { CHANGED(CLK,0) } ++ CLEAR= { CHANGED(CLRBAR,0) } ++ ++ PINDLY: ++ QA QB QC QD QE QF QG QH = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,28ns,41ns), ++ CLOCK & TRN_LH, DELAY(-1,23ns,35ns), ++ CLOCK & TRN_HL, DELAY(-1,23ns,35ns), ++ DELAY(-1,29ns,42ns) ++ ) ++ } + +Ucnstr CONSTRAINT(4) DPWR DGND ++ CLRBAR CLK A B ++ IO_HC ++ ++ FREQ: ++ NODE = CLK ++ MAXFREQ = 31MEG ++ WIDTH: ++ NODE = CLK ++ MIN_LO = 16ns ++ MIN_HI = 16ns ++ WIDTH: ++ NODE = CLRBAR ++ MIN_LO = 20ns ++ SETUP_HOLD: ++ CLOCK LH = CLK ++ DATA(2) = A B ++ SETUPTIME = 20ns ++ HOLDTIME = 5ns ++ WHEN = { CLRBAR != '0 } ++ SETUP_HOLD: ++ DATA(1) = CLRBAR ++ CLOCK LH = CLK ++ SETUPTIME = 20ns + +.ENDS 74HC164B +* + +.SUBCKT Digital_HC_74HC164 gnd _net0 _net1 _net3 _net2 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 +X1 _net0 _net1 _net3 _net2 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 74HC164B +.ENDS + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + <.PortSym -50 60 3 0 CLRBAR> + <.ID -10 164 Y> + <.PortSym -50 0 1 0 A> + <.PortSym -50 20 2 0 B> + <.PortSym -50 140 4 0 CLK> + <.PortSym 50 0 5 180 QA> + <.PortSym 50 20 6 180 QB> + <.PortSym 50 40 7 180 QC> + <.PortSym 50 60 8 180 QD> + <.PortSym 50 80 9 180 QE> + <.PortSym 50 100 10 180 QF> + <.PortSym 50 120 11 180 QG> + <.PortSym 50 140 12 180 QH> + + + + + +5-stage Johnson Decade Counter +with 10 Decoded Outputs +XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa + + +.Def:Digital_HC_74HC4017 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 _net12 _net13 +Sub:X1 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 _net12 _net13 gnd Type="n74HC4017_cir" +.Def:End + + + +*-----------------------------74HC4017----------------------------- + +* Decade Counters/Dividers +* TI High-Speed CMOS Logic Data Book, 1989, pages 2-625 to 2-629 +* jat 12/29/95 + +.SUBCKT 74HC4017B CLKENBAR CLK CLR Y0 Y1 Y2 Y3 Y4 Y5 Y6 Y7 Y8 Y9 CO ++ OPTIONAL: DPWR=$G_DPWR DGND=$G_DGND ++ PARAMS: MNTYMXDLY=0 IO_LEVEL=0 + +U1 LOGICEXP(13,14) DPWR DGND ++ CLK CLKENBAR CLR Q1 Q2 Q3 Q4 Q5 Q1BAR Q2BAR Q3BAR Q4BAR Q5BAR ++ CLOCK CLRBAR D3 Y0O Y1O Y2O Y3O Y4O Y5O Y6O Y7O Y8O Y9O COO ++ D0_GATE IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} ++ LOGIC: ++ CLOCK = {CLK & (~CLKENBAR)} ++ CLRBAR ={~CLR} ++ D3 = {Q2 & (Q1 | Q3)} ++ Y0O = {Q1BAR & Q5BAR} ++ Y1O = {Q1 & Q2BAR} ++ Y2O = {Q2 & Q3BAR} ++ Y3O = {Q3 & Q4BAR} ++ Y4O = {Q4 & Q5BAR} ++ Y5O = {Q1 & Q5} ++ Y6O = {Q2 & Q1BAR} ++ Y7O = {Q3 & Q2BAR} ++ Y8O = {Q4 & Q3BAR} ++ Y9O = {Q5 & Q4BAR} ++ COO = {Q5BAR} + +U2 DFF(5) DPWR DGND ++ $D_HI CLRBAR CLOCK ++ Q5BAR Q1 D3 Q3 Q4 ++ Q1 Q2 Q3 Q4 Q5 ++ Q1BAR Q2BAR Q3BAR Q4BAR Q5BAR ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U3 PINDLY(11,0,3) DPWR DGND ++ Y0O Y1O Y2O Y3O Y4O Y5O Y6O Y7O Y8O Y9O COO ++ CLR CLKENBAR CLK ++ Y0 Y1 Y2 Y3 Y4 Y5 Y6 Y7 Y8 Y9 CO ++ IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} ++ BOOLEAN: ++ CLEAR = {CHANGED(CLR,0)} ++ ENAB = {CHANGED(CLKENBAR,0)} ++ EDGE = {CHANGED_LH(CLK,0)} ++ PINDLY: ++ Y0 Y1 Y2 Y3 Y4 Y5 Y6 Y7 Y8 Y9 = { ++ CASE( ++ CLEAR & (TRN_LH | TRN_HL), DELAY(-1,23NS,46NS), ++ ENAB & (TRN_LH | TRN_HL), DELAY(-1,25NS,50NS), ++ EDGE & (TRN_LH | TRN_HL), DELAY(-1,23NS,46NS), ++ DELAY(-1,26NS,51NS))} ++ PINDLY: ++ CO = { ++ CASE( ++ CLEAR & TRN_LH, DELAY(-1,23NS,46NS), ++ ENAB & (TRN_LH | TRN_HL), DELAY(-1,25NS,50NS), ++ EDGE & (TRN_LH | TRN_HL), DELAY(-1,23NS,46NS), ++ DELAY(-1,26NS,51NS))} + +U4 CONSTRAINT(3) DPWR DGND ++ CLK CLKENBAR CLR ++ IO_HC IO_LEVEL={IO_LEVEL} ++ FREQ: ++ NODE = CLK ++ MAXFREQ = 31MEG ++ FREQ: ++ NODE = CLKENBAR ++ MAXFREQ = 31MEG ++ WIDTH: ++ NODE = CLK ++ MIN_LO = 16NS ++ MIN_HI = 16NS ++ WIDTH: ++ NODE = CLKENBAR ++ MIN_LO = 16NS ++ MIN_HI = 16NS ++ WIDTH: ++ NODE = CLR ++ MIN_HI = 16NS ++ SETUP_HOLD: ++ CLOCK LH = CLK ++ DATA(1) = CLKENBAR ++ SETUPTIME_LO = 10NS ++ HOLDTIME_LO = 5NS ++ SETUP_HOLD: ++ CLOCK HL = CLKENBAR ++ DATA(1) = CLK ++ SETUPTIME_HI = 10NS ++ HOLDTIME_HI = 5NS ++ SETUP_HOLD: ++ CLOCK LH = CLK ++ DATA(1) = CLR ++ SETUPTIME_LO = 10NS ++ SETUP_HOLD: ++ CLOCK HL = CLKENBAR ++ DATA(1) = CLR ++ SETUPTIME_LO = 10NS + +.ENDS 74HC4017 + +.SUBCKT Digital_HC_74HC4017 gnd _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 _net12 _net13 +X1 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 _net12 _net13 74HC4017B +.ENDS + + + + + + + + + + + + + + + + + + + + + + + + + + + + + <.ID -10 234 Y> + <.PortSym -50 60 3 0 CLR> + + + + + + <.PortSym 50 210 14 180 CO> + <.PortSym -50 20 1 0 CLKENB> + <.PortSym -50 0 2 0 CLK> + <.PortSym 50 20 5 180 Y1> + <.PortSym 50 40 6 180 Y2> + <.PortSym 50 60 7 180 Y3> + <.PortSym 50 80 8 180 Y4> + <.PortSym 50 100 9 180 Y5> + <.PortSym 50 120 10 180 Y6> + <.PortSym 50 140 11 180 Y7> + <.PortSym 50 160 12 180 Y8> + <.PortSym 50 180 13 180 Y9> + <.PortSym 50 0 4 180 Y0> + + + + + +14-Stage Binary Ripple Counter +XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa + + +.Def:Digital_HC_74HC4020 _net1 _net2 _net0 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 _net12 _net13 +Sub:X1 _net1 _net2 _net0 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 _net12 _net13 gnd Type="n74HC4020_cir" +.Def:End + + + +* ---------------------------- 74HC4020 ------------------------------------- +* Asynchronous 14-Bit Binary Counters +* +* The High Speed CMOS Logic Data Book, 1989, TI Pages 2-631 to 2-634 +* bss 6/28/94 +* +.SUBCKT 74HC402B CLK CLR QA QD QE QF QG QH QI QJ QK QL QM QN ++ optional: DPWR=$G_DPWR DGND=$G_DGND ++ params: MNTYMXDLY=0 IO_LEVEL=0 + +U1 inv DPWR DGND ++ CLR RESETBAR ++ D0_GATE IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U2 JKFF(1) DPWR DGND ++ $D_HI RESETBAR CLK $D_HI $D_HI QA_O $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U3 JKFF(1) DPWR DGND ++ $D_HI RESETBAR QA_O $D_HI $D_HI QB_O $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U4 JKFF(1) DPWR DGND ++ $D_HI RESETBAR QB_O $D_HI $D_HI QC_O $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U5 JKFF(1) DPWR DGND ++ $D_HI RESETBAR QC_O $D_HI $D_HI QD_O $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U6 JKFF(1) DPWR DGND ++ $D_HI RESETBAR QD_O $D_HI $D_HI QE_O $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U7 JKFF(1) DPWR DGND ++ $D_HI RESETBAR QE_O $D_HI $D_HI QF_O $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U8 JKFF(1) DPWR DGND ++ $D_HI RESETBAR QF_O $D_HI $D_HI QG_O $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U9 JKFF(1) DPWR DGND ++ $D_HI RESETBAR QG_O $D_HI $D_HI QH_O $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U10 JKFF(1) DPWR DGND ++ $D_HI RESETBAR QH_O $D_HI $D_HI QI_O $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U11 JKFF(1) DPWR DGND ++ $D_HI RESETBAR QI_O $D_HI $D_HI QJ_O $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U12 JKFF(1) DPWR DGND ++ $D_HI RESETBAR QJ_O $D_HI $D_HI QK_O $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U13 JKFF(1) DPWR DGND ++ $D_HI RESETBAR QK_O $D_HI $D_HI QL_O $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U14 JKFF(1) DPWR DGND ++ $D_HI RESETBAR QL_O $D_HI $D_HI QM_O $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U15 JKFF(1) DPWR DGND ++ $D_HI RESETBAR QM_O $D_HI $D_HI QN_O $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U16DLY PINDLY(12,0,2) DPWR DGND ++ QA_O QD_O QE_O QF_O QG_O QH_O QI_O QJ_O QK_O QL_O QM_O QN_O ++ CLR CLK ++ QA QD QE QF QG QH QI QJ QK QL QM QN ++ IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} ++ ++ BOOLEAN: ++ CLOCK = {CHANGED_HL(CLK,0)} ++ CLEAR = {CHANGED_LH(CLR,0)} ++ ++ PINDLY: ++ QA = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17ns,28ns), ++ CLOCK & TRN_LH, DELAY(-1,16ns,30ns), ++ CLOCK & TRN_HL, DELAY(-1,16ns,30ns), ++ DELAY(-1,18ns,31ns))} ++ ++ QD = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17ns,28ns), ++ CLOCK & TRN_LH, DELAY(-1,40ns,75ns), ++ CLOCK & TRN_HL, DELAY(-1,40ns,75ns), ++ DELAY(-1,41ns,76ns))} ++ ++ QE = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17ns,28ns), ++ CLOCK & TRN_LH, DELAY(-1,48ns,90ns), ++ CLOCK & TRN_HL, DELAY(-1,48ns,90ns), ++ DELAY(-1,49ns,91ns))} ++ ++ QF = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17ns,28ns), ++ CLOCK & TRN_LH, DELAY(-1,56ns,105ns), ++ CLOCK & TRN_HL, DELAY(-1,56ns,105ns), ++ DELAY(-1,57ns,106ns))} ++ ++ QG = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17ns,28ns), ++ CLOCK & TRN_LH, DELAY(-1,64ns,120ns), ++ CLOCK & TRN_HL, DELAY(-1,64ns,120ns), ++ DELAY(-1,65ns,121ns))} ++ ++ QH = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17ns,28ns), ++ CLOCK & TRN_LH, DELAY(-1,72ns,135ns), ++ CLOCK & TRN_HL, DELAY(-1,72ns,135ns), ++ DELAY(-1,73ns,136ns))} ++ ++ QI = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17ns,28ns), ++ CLOCK & TRN_LH, DELAY(-1,80ns,150ns), ++ CLOCK & TRN_HL, DELAY(-1,80ns,150ns), ++ DELAY(-1,81ns,151ns))} ++ ++ QJ = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17ns,28ns), ++ CLOCK & TRN_LH, DELAY(-1,88ns,165ns), ++ CLOCK & TRN_HL, DELAY(-1,88ns,165ns), ++ DELAY(-1,89ns,166ns))} ++ ++ QK = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17ns,28ns), ++ CLOCK & TRN_LH, DELAY(-1,96ns,180ns), ++ CLOCK & TRN_HL, DELAY(-1,96ns,180ns), ++ DELAY(-1,97ns,181ns))} ++ ++ QL = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17ns,28ns), ++ CLOCK & TRN_LH, DELAY(-1,104ns,195ns), ++ CLOCK & TRN_HL, DELAY(-1,104ns,195ns), ++ DELAY(-1,105ns,196ns))} ++ ++ QM = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17ns,28ns), ++ CLOCK & TRN_LH, DELAY(-1,112ns,210ns), ++ CLOCK & TRN_HL, DELAY(-1,112ns,210ns), ++ DELAY(-1,113ns,211ns))} ++ ++ QN = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17ns,28ns), ++ CLOCK & TRN_LH, DELAY(-1,120ns,225ns), ++ CLOCK & TRN_HL, DELAY(-1,120ns,225ns), ++ DELAY(-1,121ns,226ns))} + +U17CON CONSTRAINT(2) DPWR DGND ++ CLK CLR ++ IO_HC IO_LEVEL={IO_LEVEL} ++ ++ WIDTH: ++ NODE=CLR ++ MIN_HI=18ns ++ ++ WIDTH: ++ NODE=CLK ++ MIN_HI=23ns ++ MIN_LO=23ns ++ ++ SETUP_HOLD: ++ CLOCK HL=CLK ++ DATA(1)=CLR ++ SETUPTIME_LO=15ns + +.ENDS 74HC4020B +* + +.SUBCKT Digital_HC_74HC4020 gnd _net1 _net2 _net0 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 _net12 _net13 +X1 _net1 _net2 _net0 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 _net12 _net13 74HC402B +.ENDS + + + + + + + + + + + + + + + + + + + + + + + <.PortSym 50 0 3 180 QA> + <.PortSym 50 40 5 180 QE> + <.PortSym 50 60 6 180 QF> + <.PortSym 50 80 7 180 QG> + <.PortSym 50 100 8 180 QH> + <.PortSym 50 120 9 180 QI> + <.PortSym 50 140 10 180 QJ> + <.PortSym 50 160 11 180 QK> + <.PortSym 50 180 12 180 QL> + + + <.ID -10 244 Y> + <.PortSym 50 200 13 180 QM> + <.PortSym 50 220 14 180 QN> + + + + + + <.PortSym 50 20 4 180 QD> + <.PortSym -50 60 2 0 CLR> + <.PortSym -50 0 1 0 CLK> + + + + + + + + +7-Stage Binary Ripple Counter +XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa + + +.Def:Digital_HC_74HC4024 _net7 _net8 _net0 _net1 _net2 _net3 _net4 _net5 _net6 +Sub:X1 _net7 _net8 _net0 _net1 _net2 _net3 _net4 _net5 _net6 gnd Type="n74HC4024_cir" +.Def:End + + + +*-----------------------------74HC4024----------------------------------- + +* The 74HC4024 Asynchronous 7-Bit Binary Counter +* TI High Speed CMOS Logic Data Book, 1989, pages 2-635 to 2-638 +* jat 8/9/95 + +.SUBCKT 74HC4024B CLK CLR QA QB QC QD QE QF QG ++ OPTIONAL: DPWR=$G_DPWR DGND=$G_DGND ++ PARAMS: MNTYMXDLY=0 IO_LEVEL=0 + +U1 LOGICEXP(2,2) DPWR DGND ++ CLR CLK ++ CLOCKA CLRBAR ++ D0_GATE IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} ++ LOGIC: ++ CLOCKA = {CLK & (~CLR)} ++ CLRBAR = {~CLR} + +U2 JKFF(1) DPWR DGND ++ $D_HI CLRBAR CLOCKA ++ $D_HI $D_HI Q_A $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U3 JKFF(1) DPWR DGND ++ $D_HI CLRBAR Q_A ++ $D_HI $D_HI Q_B $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U4 JKFF(1) DPWR DGND ++ $D_HI CLRBAR Q_B ++ $D_HI $D_HI Q_C $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U5 JKFF(1) DPWR DGND ++ $D_HI CLRBAR Q_C ++ $D_HI $D_HI Q_D $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U6 JKFF(1) DPWR DGND ++ $D_HI CLRBAR Q_D ++ $D_HI $D_HI Q_E $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U7 JKFF(1) DPWR DGND ++ $D_HI CLRBAR Q_E ++ $D_HI $D_HI Q_F $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U8 JKFF(1) DPWR DGND ++ $D_HI CLRBAR Q_F ++ $D_HI $D_HI Q_G $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U9 PINDLY(7,0,2) DPWR DGND ++ Q_A Q_B Q_C Q_D Q_E Q_F Q_G ++ CLR CLOCKA ++ QA QB QC QD QE QF QG ++ IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} ++ BOOLEAN: ++ CLEAR = {CHANGED_LH(CLR,0)} ++ ACLK = {CHANGED_HL(CLOCKA,0)} ++ PINDLY: ++ QA = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17NS,26NS), ++ ACLK & (TRN_LH | TRN_HL), DELAY(-1,16NS,24NS), ++ DELAY(-1,18NS,27NS))} ++ QB = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17NS,26NS), ++ ACLK & (TRN_LH | TRN_HL), DELAY(-1,24NS,39NS), ++ DELAY(-1,25NS,40NS))} ++ QC = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17NS,26NS), ++ ACLK & (TRN_LH | TRN_HL), DELAY(-1,32NS,54NS), ++ DELAY(-1,33NS,55NS))} ++ QD = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17NS,26NS), ++ ACLK & (TRN_LH | TRN_HL), DELAY(-1,40NS,69NS), ++ DELAY(-1,41NS,70NS))} ++ QE = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17NS,26NS), ++ ACLK & (TRN_LH | TRN_HL), DELAY(-1,48NS,84NS), ++ DELAY(-1,49NS,85NS))} ++ QF = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17NS,26NS), ++ ACLK & (TRN_LH | TRN_HL), DELAY(-1,56NS,99NS), ++ DELAY(-1,57NS,100NS))} ++ QG = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17NS,26NS), ++ ACLK & (TRN_LH | TRN_HL), DELAY(-1,64NS,114NS), ++ DELAY(-1,65NS,115NS))} + +U10 CONSTRAINT(2) DPWR DGND ++ CLK CLR ++ IO_HC IO_LEVEL={IO_LEVEL} ++ SETUP_HOLD: ++ CLOCK HL = CLK ++ DATA(1) = CLR ++ SETUPTIME_LO = 20NS ++ WIDTH: ++ NODE = CLK ++ MIN_HI = 23NS ++ MIN_LO = 23NS ++ WIDTH: ++ NODE = CLR ++ MIN_HI = 20NS ++ FREQ: ++ NODE = CLK ++ MAXFREQ = 22MEG + +.ENDS 74HC4024B + +.SUBCKT Digital_HC_74HC4024 gnd _net7 _net8 _net0 _net1 _net2 _net3 _net4 _net5 _net6 +X1 _net7 _net8 _net0 _net1 _net2 _net3 _net4 _net5 _net6 74HC4024B +.ENDS + + + + + + + + + + + + + + + + + + <.PortSym 50 0 3 180 QA> + <.PortSym 50 20 4 180 QB> + <.PortSym 50 40 5 180 QC> + <.PortSym 50 60 6 180 QD> + <.PortSym 50 80 7 180 QE> + <.PortSym 50 100 8 180 QF> + <.PortSym 50 120 9 180 QG> + + + + + + <.PortSym -50 60 2 0 CLR> + <.PortSym -50 0 1 0 CLK> + <.ID -10 144 Y> + + + + + +12-Stage Binary Ripple Counter +XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa + + +.Def:Digital_HC_74HC4040 _net12 _net13 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 +Sub:X1 _net12 _net13 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 gnd Type="n74HC4040_cir" +.Def:End + + + +*---------------------------------------------------------74HC4040------- + +* The 74HC4040 Asynchronous 12 Bit Binary Counter +* TI High Speed CMOS Logic Data Book, 1989, pages 2-639 to 2-642 +* jat 8/10/95 + +.SUBCKT 74HC4040B CLR CLK QA QB QC QD QE QF QG QH QI QJ QK QL ++ OPTIONAL: DPWR=$G_DPWR DGND=$G_DGND ++ PARAMS: MNTYMXDLY=0 IO_LEVEL=0 + +U1 LOGICEXP(1,1) DPWR DGND ++ CLR ++ RESETBAR ++ D0_GATE IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} ++ LOGIC: ++ RESETBAR = {~CLR} + +U2 JKFF(1) DPWR DGND ++ $D_HI RESETBAR CLK ++ $D_HI $D_HI Q_A $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U3 JKFF(1) DPWR DGND ++ $D_HI RESETBAR Q_A ++ $D_HI $D_HI Q_B $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U4 JKFF(1) DPWR DGND ++ $D_HI RESETBAR Q_B ++ $D_HI $D_HI Q_C $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U5 JKFF(1) DPWR DGND ++ $D_HI RESETBAR Q_C ++ $D_HI $D_HI Q_D $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U6 JKFF(1) DPWR DGND ++ $D_HI RESETBAR Q_D ++ $D_HI $D_HI Q_E $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U7 JKFF(1) DPWR DGND ++ $D_HI RESETBAR Q_E ++ $D_HI $D_HI Q_F $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U8 JKFF(1) DPWR DGND ++ $D_HI RESETBAR Q_F ++ $D_HI $D_HI Q_G $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U9 JKFF(1) DPWR DGND ++ $D_HI RESETBAR Q_G ++ $D_HI $D_HI Q_H $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U10 JKFF(1) DPWR DGND ++ $D_HI RESETBAR Q_H ++ $D_HI $D_HI Q_I $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U11 JKFF(1) DPWR DGND ++ $D_HI RESETBAR Q_I ++ $D_HI $D_HI Q_J $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U12 JKFF(1) DPWR DGND ++ $D_HI RESETBAR Q_J ++ $D_HI $D_HI Q_K $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U13 JKFF(1) DPWR DGND ++ $D_HI RESETBAR Q_K ++ $D_HI $D_HI Q_L $D_NC ++ D0_EFF IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U14 PINDLY(12,0,2) DPWR DGND ++ Q_A Q_B Q_C Q_D Q_E Q_F Q_G Q_H Q_I Q_J Q_K Q_L ++ CLR CLK ++ QA QB QC QD QE QF QG QH QI QJ QK QL ++ IO_HC MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} ++ BOOLEAN: ++ CLEAR = {CHANGED_LH(CLR,0)} ++ ACLK = {CHANGED_HL(CLK,0)} ++ PINDLY: ++ QA = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17NS,28NS), ++ ACLK & (TRN_LH | TRN_HL), DELAY(-1,16NS,30NS), ++ DELAY(-1,17NS,31NS))} ++ QB = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17NS,28NS), ++ ACLK & (TRN_LH | TRN_HL), DELAY(-1,24NS,45NS), ++ DELAY(-1,25NS,46NS))} ++ QC = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17NS,28NS), ++ ACLK & (TRN_LH | TRN_HL), DELAY(-1,32NS,60NS), ++ DELAY(-1,33NS,61NS))} ++ QD = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17NS,28NS), ++ ACLK & (TRN_LH | TRN_HL), DELAY(-1,40NS,75NS), ++ DELAY(-1,41NS,76NS))} ++ QE = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17NS,28NS), ++ ACLK & (TRN_LH | TRN_HL), DELAY(-1,48NS,90NS), ++ DELAY(-1,49NS,91NS))} ++ QF = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17NS,28NS), ++ ACLK & (TRN_LH | TRN_HL), DELAY(-1,56NS,105NS), ++ DELAY(-1,57NS,106NS))} ++ QG = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17NS,28NS), ++ ACLK & (TRN_LH | TRN_HL), DELAY(-1,64NS,120NS), ++ DELAY(-1,65NS,121NS))} ++ QH = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17NS,28NS), ++ ACLK & (TRN_LH | TRN_HL), DELAY(-1,72NS,135NS), ++ DELAY(-1,73NS,136NS))} ++ QI = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17NS,28NS), ++ ACLK & (TRN_LH | TRN_HL), DELAY(-1,80NS,150NS), ++ DELAY(-1,81NS,151NS))} ++ QJ = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17NS,28NS), ++ ACLK & (TRN_LH | TRN_HL), DELAY(-1,88NS,165NS), ++ DELAY(-1,89NS,166NS))} ++ QK = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17NS,28NS), ++ ACLK & (TRN_LH | TRN_HL), DELAY(-1,96NS,180NS), ++ DELAY(-1,97NS,181NS))} ++ QL = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,17NS,28NS), ++ ACLK & (TRN_LH | TRN_HL), DELAY(-1,104NS,195NS), ++ DELAY(-1,105NS,196NS))} + +U15 CONSTRAINT(2) DPWR DGND ++ CLK CLR ++ IO_HC IO_LEVEL={IO_LEVEL} ++ SETUP_HOLD: ++ CLOCK HL = CLK ++ DATA(1) = CLR ++ SETUPTIME_LO = 15NS ++ WIDTH: ++ NODE = CLK ++ MIN_HI = 23NS ++ MIN_LO = 23NS ++ WIDTH: ++ NODE = CLR ++ MIN_HI = 18NS ++ FREQ: ++ NODE = CLK ++ MAXFREQ = 22MEG + +.ENDS 74HC4040B + +.SUBCKT Digital_HC_74HC4040 gnd _net12 _net13 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 +X1 _net12 _net13 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 74HC4040B +.ENDS + + + + + + + + + + + + + + + + + + + + + + + + <.PortSym 50 0 3 180 QA> + <.PortSym 50 20 4 180 QB> + <.PortSym 50 40 5 180 QC> + <.PortSym 50 60 6 180 QD> + <.PortSym 50 80 7 180 QE> + <.PortSym 50 100 8 180 QF> + <.PortSym 50 120 9 180 QG> + <.PortSym 50 140 10 180 QH> + <.PortSym 50 160 11 180 QI> + <.PortSym 50 180 12 180 QJ> + + + + + <.ID -10 244 Y> + <.PortSym 50 200 13 180 QK> + <.PortSym 50 220 14 180 QL> + + + + + + <.PortSym -50 0 2 0 CLK> + <.PortSym -50 60 1 0 CLR> + + \ No newline at end of file diff --git a/library/Digital_LV.lib b/library/Digital_LV.lib index 329c7395..5e1ad39e 100644 --- a/library/Digital_LV.lib +++ b/library/Digital_LV.lib @@ -1,9 +1,9 @@ - + -2-Input Nand Gate - +2-Input NAND Gate +XSPICE Based Model Requirements: .spiceinit: set ngbehavior=psa .PARAM: vcc=5 @@ -43,7 +43,6 @@ X1 _net0 _net1 _net2 74LV00A - @@ -52,13 +51,280 @@ X1 _net0 _net1 _net2 74LV00A <.PortSym -30 10 2 0 P2> <.PortSym 30 0 3 180 P3> <.ID 10 14 Y> + + + + + + +2-Input NOR Gate +XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa +.PARAM: vcc=5 + + +.Def:Digital_LV_74LV02 _net0 _net1 _net2 +Sub:X1 _net0 _net1 _net2 gnd Type="n74LV02_cir" +.Def:End + + + +* ---------------------------------- 74LV02A --------------------- +* Quad 2-Input Nor Gates +* +* TI PDF File +* bss 2/18/03 +* +.SUBCKT 74LV02A 1A 1B 1Y ++ optional: DPWR_3V=$G_DPWR_3V DGND_3V=$G_DGND_3V ++ params: MNTYMXDLY=0 IO_LEVEL=0 + +U1 nor(2) DPWR_3V DGND_3V ++ 1A 1B 1Y ++ DLY_LV02 IO_LV-A MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +.model DLY_LV02 ugate (tplhTY=7.6ns tplhMX=11.4ns tphlTY=7.6ns tphlMX=11.4ns) + +.ENDS 74LV02A +* + +.SUBCKT Digital_LV_74LV02 gnd _net0 _net1 _net2 +X1 _net0 _net1 _net2 74LV02A +.ENDS + + + <.PortSym -30 -10 1 0 P1> + <.PortSym -30 10 2 0 P2> + <.PortSym 30 0 3 180 P3> + <.ID 10 14 Y> + + + + + + + + + + + + + +Inverter +XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa +.PARAM: vcc=5 + + +.Def:Digital_LV_74LV04 _net0 _net1 +Sub:X1 _net0 _net1 gnd Type="n74LV04_cir" +.Def:End + + + +* -------------------------- 74LV04A -------------------------------- +* Hex Inverters +* +* TI PDF File +* bss 1/2/03 +* +.SUBCKT 74LV04A 1A 1Y ++ optional: DPWR_3V=$G_DPWR_3V DGND_3V=$G_DGND_3V ++ params: MNTYMXDLY=0 IO_LEVEL=0 + +U1 inv DPWR_3V DGND_3V ++ 1A 1Y ++ DLY_LV04 IO_LV-A MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +.model DLY_LV04 ugate (tplhTY=7.3ns tplhMX=10.6ns tphlTY=7.3ns tphlMX=10.6ns) + +.ENDS 74LV04A +* + +.SUBCKT Digital_LV_74LV04 gnd _net0 _net1 +X1 _net0 _net1 74LV04A +.ENDS + + + + + + + <.ID 10 14 Y> + <.PortSym 30 0 2 180 P2> + + <.PortSym -30 0 1 0 P1> + + + + + +2-Input AND Gate +XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa +.PARAM: vcc=5 + + +.Def:Digital_LV_74LV08 _net0 _net1 _net2 +Sub:X1 _net0 _net1 _net2 gnd Type="n74LV08_cir" +.Def:End + + + +* ---------------------------- 74LV08A ------------------------------ +* Quad 2-Input AND Gate +* +* TI PDF File +* bss 2/21/03 +* +.SUBCKT 74LV08A 1A 1B 1Y ++ optional: DPWR_3V=$G_DPWR_3V DGND_3V=$G_DGND_3V ++ params: MNTYMXDLY=0 IO_LEVEL=0 + +U1 and(2) DPWR_3V DGND_3V ++ 1A 1B 1Y ++ DLY_LV08 IO_LV-A MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +.model DLY_LV08 ugate (tplhTY=7.5ns tplhMX=12.3ns tphlTY=7.5ns tphlMX=12.3ns) + +.ENDS 74LV08A +* + +.SUBCKT Digital_LV_74LV08 gnd _net0 _net1 _net2 +X1 _net0 _net1 _net2 74LV08A +.ENDS + + + <.PortSym -30 -10 1 0 P1> + <.PortSym -30 10 2 0 P2> + <.PortSym 30 0 3 180 P3> + <.ID 10 14 Y> + + + + + + + + + + +4-Input NAND Gate +XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa +.PARAM: vcc=5 + + +.Def:Digital_LV_74LV20 _net0 _net1 _net2 _net3 _net4 +Sub:X1 _net0 _net1 _net2 _net3 _net4 gnd Type="n74LV20_cir" +.Def:End + + + +* ----------------------------- 74LV20A ------------------------- +* Dual 4-Input Nand Gate +* +* TI PDF File +* bss 2/24/03 +* +.SUBCKT 74LV20A 1A 1B 1C 1D 1Y ++ optional: DPWR_3V=$G_DPWR_3V DGND_3V=$G_DGND_3V ++ params: MNTYMXDLY=0 IO_LEVEL=0 + +U1 nand(4) DPWR_3V DGND_3V ++ 1A 1B 1C 1D 1Y ++ DLY_LV20 IO_LV-A MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +.model DLY_LV20 ugate (tplhTY=6.5ns tplhMX=10.1ns tphlTY=6.5ns tphlMX=10.1ns) + +.ENDS 74LV20A +* + +.SUBCKT Digital_LV_74LV20 gnd _net0 _net1 _net2 _net3 _net4 +X1 _net0 _net1 _net2 _net3 _net4 74LV20A +.ENDS + + + + + + + + + + + <.PortSym -30 -30 1 0 P1> + <.PortSym -30 -10 2 0 P2> + <.PortSym -30 10 3 0 P3> + <.PortSym -30 30 4 0 P4> + <.PortSym 40 0 5 180 P5> + <.ID 20 14 Y> + + + + + + + +2-Input OR Gate +XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa +.PARAM: vcc=5 + + +.Def:Digital_LV_74LV32 _net0 _net1 _net2 +Sub:X1 _net0 _net1 _net2 gnd Type="n74LV32_cir" +.Def:End + + + +* -------------------------- 74LV32A ---------------------------- +* Quad 2-Input Or Gate +* +* TI PDF File +* bss 2/24/03 +* +.SUBCKT 74LV32A 1A 1B 1Y ++ optional: DPWR_3V=$G_DPWR_3V DGND_3V=$G_DGND_3V ++ params: MNTYMXDLY=0 IO_LEVEL=0 + +U1 or(2) DPWR_3V DGND_3V ++ 1A 1B 1Y ++ DLY_LV32 IO_LV-A MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +.model DLY_LV32 ugate (tplhTY=6.9ns tplhMX=11.4ns tphlTY=6.9ns tphlMX=11.4ns) + +.ENDS 74LV32A +* + +.SUBCKT Digital_LV_74LV32 gnd _net0 _net1 _net2 +X1 _net0 _net1 _net2 74LV32A +.ENDS + + + <.PortSym -30 -10 1 0 P1> + <.PortSym -30 10 2 0 P2> + <.PortSym 30 0 3 180 P3> + <.ID 10 14 Y> + + + + + + + D-Type Positive Edge Triggered Flip-Flop With Preset And Clear - +XSPICE Based Model Requirements: .spiceinit: set ngbehavior=psa .PARAM: vcc=5 @@ -73,7 +339,7 @@ Sub:X1 _net0 _net1 _net2 _net3 _net4 _net5 gnd Type="n74LV74_cir" * The timing parameters for all of these models were taken from the specifications for a * 3.3V power supply and a 50pF capacitive load. * -* ----------------------------------------------------------- 74LV74A ------ +* -------------------------------------- 74LV74A --------------------------- * Dual Positive Edge Triggered D-Type Flip-Flop * * TI PDF File @@ -127,3 +393,544 @@ X1 _net0 _net1 _net2 _net3 _net4 _net5 74LV74A + + +2-Input Exclusive-OR Gate +XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa +.PARAM: vcc=5 + + +.Def:Digital_LV_74LV86 _net0 _net1 _net2 +Sub:X1 _net0 _net1 _net2 gnd Type="n74LV86_cir" +.Def:End + + + +* ----------------------------------------------------------- 74LV86A ------ +* Quad 2-Input Exclusive-Or Gate +* +* TI PDF File +* bss 2/24/03 +* +.SUBCKT 74LV86 1A 1B 1Y ++ optional: DPWR_3V=$G_DPWR_3V DGND_3V=$G_DGND_3V ++ params: MNTYMXDLY=0 IO_LEVEL=0 + +U1 xor DPWR_3V DGND_3V ++ 1A 1B 1Y ++ DLY_LV86 IO_LV-A MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +.model DLY_LV86 ugate (tplhTY=7.4ns tplhMX=14.5ns tphlTY=7.4ns tphlMX=14.5ns) + +.ENDS 74LV86 +* + +.SUBCKT Digital_LV_74LV86 gnd _net0 _net1 _net2 +X1 _net0 _net1 _net2 74LV86 +.ENDS + + + <.PortSym -30 -10 1 0 P1> + <.PortSym -30 10 2 0 P2> + <.PortSym 30 0 3 180 P3> + <.ID 10 14 Y> + + + + + + + + + + + +3-Line To 8-Line Decoder/Demultiplexer +XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa +.PARAM: vcc=5 + + +.Def:Digital_LV_74LV138 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 _net12 _net13 +Sub:X1 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 _net12 _net13 gnd Type="n74LV138_cir" +.Def:End + + + +*-----------------------------------------------------------74LV138A----- +* 3-Line To 8-Line Decoder/Demultiplexer +* +* TI PDF File +* bss 2/25/03 + +.SUBCKT 74LV138A A B C G1 G2ABAR G2BBAR Y0 Y1 Y2 Y3 Y4 Y5 Y6 Y7 ++ optional: DPWR_3V=$G_DPWR_3V DGND_3V=$G_DGND_3V ++ params: MNTYMXDLY=0 IO_LEVEL=0 + +U1 LOGICEXP(6,8) DPWR_3V DGND_3V ++ A B C G1 G2ABAR G2BBAR ++ Y0O Y1O Y2O Y3O Y4O Y5O Y6O Y7O ++ D0_GATE IO_LV-A MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} ++ LOGIC: ++ ENAB = {G1 & ~G2ABAR & ~G2BBAR} ++ Y0O = {~(~A & ~B & ~C & ENAB)} ++ Y1O = {~(A & ~B & ~C & ENAB)} ++ Y2O = {~(~A & B & ~C & ENAB)} ++ Y3O = {~(A & B & ~C & ENAB)} ++ Y4O = {~(~A & ~B & C & ENAB)} ++ Y5O = {~(A & ~B & C & ENAB)} ++ Y6O = {~(~A & B & C & ENAB)} ++ Y7O = {~(A & B & C & ENAB)} + +U2 PINDLY(8,0,6) DPWR_3V DGND_3V ++ Y0O Y1O Y2O Y3O Y4O Y5O Y6O Y7O ++ A B C G1 G2ABAR G2BBAR ++ Y0 Y1 Y2 Y3 Y4 Y5 Y6 Y7 ++ IO_LV-A MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} ++ BOOLEAN: ++ IN = {CHANGED(A,0) | CHANGED(B,0) | CHANGED(C,0)} ++ ENBAR = {CHANGED(G2ABAR,0) | CHANGED(G2BBAR,0)} ++ EN = {CHANGED(G1,0)} ++ PINDLY: ++ Y0 Y1 Y2 Y3 Y4 Y5 Y6 Y7 = { ++ CASE( ++ EN & TRN_LH, DELAY(-1,10.6ns,16.3ns), ++ EN & TRN_HL, DELAY(-1,10.6ns,16.3ns), ++ ENBAR & TRN_LH, DELAY(-1,10ns,14.9ns), ++ ENBAR & TRN_HL, DELAY(-1,10ns,14.9ns), ++ IN & TRN_LH, DELAY(-1,10.3ns,15.8ns), ++ IN & TRN_HL, DELAY(-1,10.3ns,15.8ns), ++ DELAY(-1,11ns,17ns))} + +.ENDS 74LV138A +* + +.SUBCKT Digital_LV_74LV138 gnd _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 _net12 _net13 +X1 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 _net12 _net13 74LV138A +.ENDS + + + + + + + + + + + + + <.PortSym 50 0 7 180 Y0> + <.PortSym 50 20 8 180 Y1> + <.PortSym 50 40 9 180 Y2> + <.PortSym 50 60 10 180 Y3> + <.PortSym 50 80 11 180 Y4> + <.PortSym 50 100 12 180 Y5> + <.PortSym 50 120 13 180 Y6> + <.PortSym 50 140 14 180 Y7> + + + <.PortSym -50 20 2 0 B> + <.PortSym -50 0 1 0 A> + <.PortSym -50 40 3 0 C> + + + + + + <.PortSym -50 80 4 0 G1> + <.PortSym -50 100 5 0 G2AB> + <.PortSym -50 120 6 0 G2BB> + + + + + + + + + + + + + + <.ID -10 164 Y> + + + + + + +8-Bit Parallel-Out Serial Shift Register +XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa +.PARAM: vcc=5 + + +.Def:Digital_LV_74LV164 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 +Sub:X1 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 gnd Type="n74LV164_cir" +.Def:End + + + +* ----------------------------------------------------------- 74LV164 ------ +* 8-Bit Parallel-Out Serial Shift Register +* +* TI PDF File +* bss 2/26/03 +* +.SUBCKT 74LV164 A B CLRBAR CLK QA QB QC QD QE QF QG QH ++ optional: DPWR_3V=$G_DPWR_3V DGND_3V=$G_DGND_3V ++ params: MNTYMXDLY=0 IO_LEVEL=0 + +U74164 LOGICEXP (3,3) DPWR_3V DGND_3V ++ CLK A B ++ r0 s0 clkbar ++ D0_GATE IO_LV-A IO_LEVEL={IO_LEVEL} ++ ++ LOGIC: ++ r0 = { (~(A & B)) } ++ s0 = { (~r0) } ++ clkbar = { (~CLK) } + +uf0 JKff(8) DPWR_3V DGND_3V ++ $D_HI CLRBAR clkbar ++ s0 QA_O QB_O QC_O QD_O QE_O QF_O QG_O ++ r0 qabar qbbar qcbar qdbar qebar qfbar qgbar ++ QA_O QB_O QC_O QD_O QE_O QF_O QG_O QH_O ++ qabar qbbar qcbar qdbar qebar qfbar qgbar qhbar ++ D0_EFF IO_LV-A + +Udly PINDLY (8,0,2) DPWR_3V DGND_3V ++ QA_O QB_O QC_O QD_O QE_O QF_O QG_O QH_O ++ CLRBAR CLK ++ QA QB QC QD QE QF QG QH ++ IO_LV-A MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} ++ ++ BOOLEAN: ++ CLOCK= { CHANGED(CLK,0) } ++ CLEAR= { CHANGED_HL(CLRBAR,0) } ++ ++ PINDLY: ++ QA QB QC QD QE QF QG QH = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,7.9ns,16.3ns), ++ CLOCK, DELAY(-1,8.3ns,16.3ns), ++ DELAY(-1,9ns,17ns) ++ ) ++ } + +Ucnstr CONSTRAINT(4) DPWR_3V DGND_3V ++ CLRBAR CLK A B ++ IO_LV-A ++ ++ FREQ: ++ NODE = CLK ++ MAXFREQ = 120MEG ++ WIDTH: ++ NODE = CLK ++ MIN_HI = 5ns ++ MIN_LO = 5ns ++ WIDTH: ++ NODE = CLRBAR ++ MIN_LO = 5ns ++ SETUP_HOLD: ++ CLOCK LH = CLK ++ DATA(2) = A B ++ SETUPTIME = 5ns ++ WHEN = { CLRBAR != '0 } ++ SETUP_HOLD: ++ DATA(1) = CLRBAR ++ CLOCK LH = CLK ++ SETUPTIME_HI = 2.5ns + +.ENDS 74LV164 +* + +.SUBCKT Digital_LV_74LV164 gnd _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 +X1 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 74LV164 +.ENDS + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + <.PortSym -50 60 3 0 CLRBAR> + <.ID -10 164 Y> + <.PortSym -50 0 1 0 A> + <.PortSym -50 20 2 0 B> + <.PortSym -50 140 4 0 CLK> + <.PortSym 50 0 5 180 QA> + <.PortSym 50 20 6 180 QB> + <.PortSym 50 40 7 180 QC> + <.PortSym 50 60 8 180 QD> + <.PortSym 50 80 9 180 QE> + <.PortSym 50 100 10 180 QF> + <.PortSym 50 120 11 180 QG> + <.PortSym 50 140 12 180 QH> + + + + + +12-Stage Binary Ripple Counter +XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa + + +.Def:Digital_LV_74LV4040 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 _net12 _net13 +Sub:X1 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 _net12 _net13 gnd Type="n74LV4040_cir" +.Def:End + + + +* +*---------------------74LV4040A----------------------- +* 12-Bit Asynchronous Binary Counter +* +* TI PDF File +* bss 2/28/03 + +.SUBCKT 74LV4040 CLR CLK QA QB QC QD QE QF QG QH QI QJ QK QL ++ optional: DPWR_3V=$G_DPWR_3V DGND_3V=$G_DGND_3V ++ params: MNTYMXDLY=0 IO_LEVEL=0 + +U1 LOGICEXP(1,1) DPWR_3V DGND_3V ++ CLR ++ RESETBAR ++ D0_GATE IO_LV-A MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} ++ LOGIC: ++ RESETBAR = {~CLR} + +U2 JKFF(1) DPWR_3V DGND_3V ++ $D_HI RESETBAR CLK ++ $D_HI $D_HI Q_A $D_NC ++ D0_EFF IO_LV-A MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U3 JKFF(1) DPWR_3V DGND_3V ++ $D_HI RESETBAR Q_A ++ $D_HI $D_HI Q_B $D_NC ++ D0_EFF IO_LV-A MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U4 JKFF(1) DPWR_3V DGND_3V ++ $D_HI RESETBAR Q_B ++ $D_HI $D_HI Q_C $D_NC ++ D0_EFF IO_LV-A MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U5 JKFF(1) DPWR_3V DGND_3V ++ $D_HI RESETBAR Q_C ++ $D_HI $D_HI Q_D $D_NC ++ D0_EFF IO_LV-A MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U6 JKFF(1) DPWR_3V DGND_3V ++ $D_HI RESETBAR Q_D ++ $D_HI $D_HI Q_E $D_NC ++ D0_EFF IO_LV-A MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U7 JKFF(1) DPWR_3V DGND_3V ++ $D_HI RESETBAR Q_E ++ $D_HI $D_HI Q_F $D_NC ++ D0_EFF IO_LV-A MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U8 JKFF(1) DPWR_3V DGND_3V ++ $D_HI RESETBAR Q_F ++ $D_HI $D_HI Q_G $D_NC ++ D0_EFF IO_LV-A MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U9 JKFF(1) DPWR_3V DGND_3V ++ $D_HI RESETBAR Q_G ++ $D_HI $D_HI Q_H $D_NC ++ D0_EFF IO_LV-A MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U10 JKFF(1) DPWR_3V DGND_3V ++ $D_HI RESETBAR Q_H ++ $D_HI $D_HI Q_I $D_NC ++ D0_EFF IO_LV-A MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U11 JKFF(1) DPWR_3V DGND_3V ++ $D_HI RESETBAR Q_I ++ $D_HI $D_HI Q_J $D_NC ++ D0_EFF IO_LV-A MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U12 JKFF(1) DPWR_3V DGND_3V ++ $D_HI RESETBAR Q_J ++ $D_HI $D_HI Q_K $D_NC ++ D0_EFF IO_LV-A MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U13 JKFF(1) DPWR_3V DGND_3V ++ $D_HI RESETBAR Q_K ++ $D_HI $D_HI Q_L $D_NC ++ D0_EFF IO_LV-A MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U14 PINDLY(12,0,2) DPWR_3V DGND_3V ++ Q_A Q_B Q_C Q_D Q_E Q_F Q_G Q_H Q_I Q_J Q_K Q_L ++ CLR CLK ++ QA QB QC QD QE QF QG QH QI QJ QK QL ++ IO_LV-A MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} ++ BOOLEAN: ++ CLEAR = {CHANGED_LH(CLR,0)} ++ ACLK = {CHANGED_HL(CLK,0)} ++ PINDLY: ++ QA = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,9ns,16.3ns), ++ ACLK, DELAY(-1,7.5ns,15.4ns), ++ DELAY(-1,10ns,17ns))} ++ QB = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,9ns,16.3ns), ++ ACLK, DELAY(-1,8.7ns,19.8ns), ++ DELAY(-1,10ns,20ns))} ++ QC = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,9ns,16.3ns), ++ ACLK, DELAY(-1,9.9ns,24.2ns), ++ DELAY(-1,10ns,25ns))} ++ QD = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,9ns,16.3ns), ++ ACLK, DELAY(-1,11.1ns,28.6ns), ++ DELAY(-1,12ns,29ns))} ++ QE = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,9ns,16.3ns), ++ ACLK, DELAY(-1,12.3ns,33ns), ++ DELAY(-1,13ns,34ns))} ++ QF = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,9ns,16.3ns), ++ ACLK, DELAY(-1,13.5ns,37.4ns), ++ DELAY(-1,14ns,38ns))} ++ QG = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,9ns,16.3ns), ++ ACLK, DELAY(-1,14.7ns,41.8ns), ++ DELAY(-1,15ns,42ns))} ++ QH = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,9ns,16.3ns), ++ ACLK, DELAY(-1,15.9ns,46.2ns), ++ DELAY(-1,16ns,47ns))} ++ QI = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,9ns,16.3ns), ++ ACLK, DELAY(-1,17.1ns,50.6ns), ++ DELAY(-1,18ns,51ns))} ++ QJ = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,9ns,16.3ns), ++ ACLK, DELAY(-1,18.3ns,55ns), ++ DELAY(-1,19ns,56ns))} ++ QK = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,9ns,16.3ns), ++ ACLK, DELAY(-1,19.5ns,59.4ns), ++ DELAY(-1,20ns,60ns))} ++ QL = { ++ CASE( ++ CLEAR & TRN_HL, DELAY(-1,9ns,16.3ns), ++ ACLK, DELAY(-1,20.7ns,63.8ns), ++ DELAY(-1,21ns,64ns))} + +U15 CONSTRAINT(2) DPWR_3V DGND_3V ++ CLK CLR ++ IO_LV-A IO_LEVEL={IO_LEVEL} ++ SETUP_HOLD: ++ CLOCK HL = CLK ++ DATA(1) = CLR ++ SETUPTIME_LO = 5NS ++ WIDTH: ++ NODE = CLK ++ MIN_HI = 5NS ++ MIN_LO = 5NS ++ WIDTH: ++ NODE = CLR ++ MIN_HI = 5NS ++ FREQ: ++ NODE = CLK ++ MAXFREQ = 130MEG + +.ENDS 74LV4040 +* + +.SUBCKT Digital_LV_74LV4040 gnd _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 _net12 _net13 +X1 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 _net12 _net13 74LV4040 +.ENDS + + + + + + + + + + + + + + + + + + + + + + + + <.PortSym 50 0 3 180 QA> + <.PortSym 50 20 4 180 QB> + <.PortSym 50 40 5 180 QC> + <.PortSym 50 60 6 180 QD> + <.PortSym 50 80 7 180 QE> + <.PortSym 50 100 8 180 QF> + <.PortSym 50 120 9 180 QG> + <.PortSym 50 140 10 180 QH> + <.PortSym 50 160 11 180 QI> + <.PortSym 50 180 12 180 QJ> + + + + + <.ID -10 244 Y> + <.PortSym 50 200 13 180 QK> + <.PortSym 50 220 14 180 QL> + <.PortSym -50 0 2 0 CLK> + + + + + + <.PortSym -50 60 1 0 CLR> + + \ No newline at end of file diff --git a/library/qucs.blacklist b/library/qucs.blacklist index 21323617..d52727af 100644 --- a/library/qucs.blacklist +++ b/library/qucs.blacklist @@ -1,6 +1,6 @@ SpiceOpamp.lib Cores.lib -Digital_CD4000.lib +Digital_CD.lib Digital_HC.lib Digital_LV.lib Transformers.lib diff --git a/library/xyce.blacklist b/library/xyce.blacklist index e6a40756..536dfbeb 100644 --- a/library/xyce.blacklist +++ b/library/xyce.blacklist @@ -1,6 +1,6 @@ Substrates.lib Xanalogue.lib PWM_Controller.lib -Digital_CD4000.lib +Digital_CD.lib Digital_HC.lib Digital_LV.lib From d89665b89a943005737d7b887a01c864283afab0 Mon Sep 17 00:00:00 2001 From: Vadim Kuznetsov Date: Sun, 5 Jan 2025 11:35:41 +0300 Subject: [PATCH 2/3] Update readme --- README.md | 36 ++++++++++++++++++++---------------- 1 file changed, 20 insertions(+), 16 deletions(-) diff --git a/README.md b/README.md index 88783457..7c877047 100644 --- a/README.md +++ b/README.md @@ -31,23 +31,30 @@ Use CMake to build Qucs-S. Install all necessary dependencies: GCC, Qt, Flex, Bi ### Dependencies -#### Ubuntu +Qucs-S requires Qt6 libraries including QtCharts, CMake, flex, bison, gperf, and dos2unix as compile time +dependencies. Install these packages using the package manager of your distribution before compiling Qucs-S. +Ngspice is not required at compile time, but it is required as runtime dependency to run the simulation. + +Here are some examples for the popular Linux distributions. + +#### Ubuntu or Debian ~~~ -sudo apt-get install ngspice build-essential git cmake qtbase5-dev qttools5-dev libqt5svg5-dev libqt5charts5-dev flex bison gperf dos2unix +sudo apt-get install ngspice build-essential git cmake flex bison gperf dos2unix +sudo apt-get install qt6-base-dev qt6-tools-dev qt6-tools-dev-tools libglx-dev linguist-qt6 +sudo apt-get install qt6-l10n-tools libqt6svg6-dev libgl1-mesa-dev qt6-charts-dev libqt6opengl6-dev ~~~ -#### OpenSUSE Tumbleweed +#### Fedora ~~~ -sudo zypper install ngspice git cmake libqt5-qtbase-devel libqt5-qttools-devel libqt5-qtsvg-devel libqt5-qtcharts-devel flex bison gperf dos2unix +sudo dnf install gcc-c++ cmake git flex bison gperf dos2unix ngspice +sudo dnf install qt6-qtbase-devel cmake qt6-qtsvg-devel qt6-qttools-devel qt6-qtcharts-devel ~~~ ### Compiling -#### Qt5 - -Then clone this git repository and execute in the top directory: +After installing the dependecies, clone this git repository and execute in the top directory: ~~~ git submodule init @@ -59,19 +66,16 @@ make make install ~~~ -Where `/your_install_prefix/` is desired installation directory. Substitute any -desire path (for example `$HOME/qucs-s`) here. You may omit this option and -installation steps. Default installation directory will be `/usr/local` if +Since the v25.1.0 the Qucs-S will be configured with Qt6 by default. Substutute the `/your_install_prefix/` +as desired installation directory. Substitute any desire path (for example `$HOME/qucs-s`) here. +You may omit this option and installation steps. Default installation directory will be `/usr/local` if `CMAKE_INSTALL_PREFIX` is not defined. -#### Qt6 +### Qt5/Qt6 support -Since v1.0.1 Qucs-S supports build with Qt6. Set the `WITH_QT6` flag to tell CMake use the Qt6. -For example use the following command sequence for Ubuntu-22.04 +Qt5 support has been dropped since v25.1.0. Only Qt6 libraries are supported. Set the `WITH_QT6=ON` +cmake flag if compiling the Qucs-S versions before v25.1.0 -~~~ -cmake .. -DWITH_QT6=ON -DCMAKE_INSTALL_PREFIX=/your_install_prefix/ -~~~ ### Running From 0f5068fca368e647f6880e067942b421c7d62917 Mon Sep 17 00:00:00 2001 From: Vadim Kuznetsov Date: Sun, 5 Jan 2025 12:08:48 +0300 Subject: [PATCH 3/3] Upload CD library --- library/Digital_CD.lib | 1195 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 1195 insertions(+) create mode 100644 library/Digital_CD.lib diff --git a/library/Digital_CD.lib b/library/Digital_CD.lib new file mode 100644 index 00000000..d91e7d25 --- /dev/null +++ b/library/Digital_CD.lib @@ -0,0 +1,1195 @@ + + + + +2-Input NOR Gate +XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa +.PARAM: vcc=5 + + +.Def:Digital_CD_CD4001 _net0 _net1 _net2 +Sub:X1 _net0 _net1 _net2 gnd Type="CD4001_cir" +.Def:End + + + +* -------------------------------- CD4001B------------------------------- +* +* Quad 2-Input NOR Gate +* +* The CMOS Logic Data Book, 1991, Motorola Pages 6-5 to 6-14 +* jds 6/6/94 +* This part is shown in the data book as MC14001B +* +.SUBCKT CD4001B IN1A IN2A OUTA ++ optional: VDD=$G_CD4000_VDD VSS=$G_CD4000_VSS ++ params: MNTYMXDLY=0 IO_LEVEL=0 +* +Uf0 nor(2) VDD VSS ++ IN1A IN2A OUTA ++ DLY_MOD IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +.model DLY_MOD ugate (TPLHMN=-1 TPLHTY=125ns TPLHMX=250ns ++ TPHLMN=-1 TPHLTY=125ns TPHLMX=250ns) + +.ENDS CD4001B +* + +.SUBCKT Digital_CD_CD4001 gnd _net0 _net1 _net2 +X1 _net0 _net1 _net2 CD4001B +.ENDS + + + <.PortSym -30 -10 1 0 P1> + <.PortSym -30 10 2 0 P2> + <.PortSym 30 0 3 180 P3> + <.ID 10 14 Y> + + + + + + + + + + + + + +2-Input NAND Gate +XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa +.PARAM: vcc=5 + + +.Def:Digital_CD_CD4011 _net0 _net2 _net1 +Sub:X1 _net0 _net2 _net1 gnd Type="CD4011_cir" +.Def:End + + + +* ----------------------- CD4011B ------------------------- +* +* Quad 2-Input NAND Gate +* +* The CMOS Logic Data Book, 1991, Motorola Pages 6-5 to 6-14 +* jds 6/6/94 +* This part is shown in the data book as MC14011B +* +.SUBCKT CD4011B IN1A IN2A OUTA ++ optional: VDD=$G_CD4000_VDD VSS=$G_CD4000_VSS ++ params: MNTYMXDLY=0 IO_LEVEL=0 +* +Uf0 nand(2) VDD VSS ++ IN1A IN2A OUTA ++ DLY_MOD IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +.model DLY_MOD ugate (TPLHMN=-1 TPLHTY=125ns TPLHMX=250ns ++ TPHLMN=-1 TPHLTY=125ns TPHLMX=250ns) + +.ENDS CD4011B +* + +.SUBCKT Digital_CD_CD4011 gnd _net0 _net2 _net1 +X1 _net0 _net2 _net1 CD4011B +.ENDS + + + + + + + + + <.PortSym -30 -10 1 0 P1> + <.PortSym -30 10 2 0 P2> + <.PortSym 30 0 3 180 P3> + <.ID 10 14 Y> + + + + + +4-Input NAND Gate +XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa +.PARAM: vcc=5 + + +.Def:Digital_CD_CD4012 _net0 _net1 _net2 _net3 _net4 +Sub:X1 _net0 _net1 _net2 _net3 _net4 gnd Type="CD4012_cir" +.Def:End + + + +* ------------------------------ CD4012B------------------------ +* +* Dual 4-Input NAND Gate +* +* The CMOS Logic Data Book, 1991, Motorola Pages 6-5 to 6-14 +* jds 6/6/94 +* This part is shown in the data book as MC14012B +* +.SUBCKT CD4012B IN1A IN2A IN3A IN4A OUTA ++ optional: VDD=$G_CD4000_VDD VSS=$G_CD4000_VSS ++ params: MNTYMXDLY=0 IO_LEVEL=0 +* +Uf0 nand(4) VDD VSS ++ IN1A IN2A IN3A IN4A OUTA ++ DLY_MOD IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +.model DLY_MOD ugate (TPLHMN=-1 TPLHTY=160ns TPLHMX=300ns ++ TPHLMN=-1 TPHLTY=160ns TPHLMX=300ns) + +.ENDS CD4012B +* + +.SUBCKT Digital_CD_CD4012 gnd _net0 _net1 _net2 _net3 _net4 +X1 _net0 _net1 _net2 _net3 _net4 CD4012B +.ENDS + + + + + + + + + + + <.PortSym -30 -30 1 0 P1> + <.PortSym -30 -10 2 0 P2> + <.PortSym -30 10 3 0 P3> + <.PortSym -30 30 4 0 P4> + <.PortSym 40 0 5 180 P5> + <.ID 20 14 Y> + + + + + + + +D-Type Positive Edge Triggered Flip-Flop With Preset And Clear +XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa +.PARAM: vcc=5 + + +.Def:Digital_CD_CD4013 _net0 _net1 _net2 _net3 _net4 _net5 +Sub:X1 _net0 _net1 _net2 _net3 _net4 _net5 gnd Type="CD4013_cir" +.Def:End + + + +* ----------------------------- CD4013B ------------------------ +* +* Dual Type D Flip-Flop +* +* The CMOS Logic Data Book, 1991, Motorola Pages 6-33 to 6-36 +* jds 6/6/94 +* This part is shown in the data book as MC14013B +* +.SUBCKT CD4013B SA RA CA DA QA QABAR ++ optional: VDD=$G_CD4000_VDD VSS=$G_CD4000_VSS ++ params: MNTYMXDLY=0 IO_LEVEL=0 +* +Uf0 inva(2) VDD VSS ++ SA RA prebar clrbar ++ D0_GATE IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +Uf1 dff(1) VDD VSS ++ prebar clrbar CA DA Q_A Q_ABAR ++ DFF4013B IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +.MODEL DFF4013B UEFF(TWPCLMN=250NS TWPCLTY=125NS TWPCLMX=-1 ++ TWCLKLMN=250NS TWCLKLTY=125NS TWCLKLMX=-1 ++ TWCLKHMN=250NS TWCLKHTY=125NS TWCLKHMX=-1 ++ TSUDCLKMN=-1NS TSUDCLKTY=250NS TSUDCLKMX=-1 ++ THDCLKMN=40NS THDCLKTY=20NS THDCLKMX=-1) + +U3 PINDLY(2,0,3) VDD VSS ++ Q_A Q_ABAR ++ CA SA RA ++ QA QABAR ++ IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} ++ BOOLEAN: ++ EDGE = {CHANGED_LH(CA,0)} ++ SET = {CHANGED_LH(SA,0)} ++ CLEAR = {CHANGED_LH(RA,0)} ++ PINDLY: ++ QA QABAR = { ++ CASE( ++ SET, DELAY(-1,175NS,350NS), ++ CLEAR, DELAY(-1,225NS,450NS), ++ EDGE & (TRN_LH | TRN_HL), DELAY(-1,175NS,350NS), ++ DELAY(-1,226NS,451NS))} + +U4 CONSTRAINT(3) VDD VSS ++ CA SA RA ++ IO_4000B IO_LEVEL={IO_LEVEL} ++ FREQ: ++ NODE = CA ++ MAXFREQ = 2MEG ++ SETUP_HOLD: ++ CLOCK LH = CA ++ DATA(2) = SA RA ++ SETUPTIME_LO = 80NS ++ HOLDTIME_LO = 50NS + +.ENDS CD4013B +* + +.SUBCKT Digital_CD_CD4013 gnd _net0 _net1 _net2 _net3 _net4 _net5 +X1 _net0 _net1 _net2 _net3 _net4 _net5 CD4013B +.ENDS + + + + + + + + + + + + <.PortSym -50 20 3 0 CA> + <.PortSym -50 -20 4 0 DA> + <.PortSym 50 -20 5 180 QA> + <.PortSym 50 20 6 180 QAB> + <.PortSym 0 -60 2 0 RA> + <.PortSym 0 60 1 0 SA> + + <.ID 20 44 Y> + + + + + + + + + + +5-stage Johnson Decade Counter +with 10 Decoded Outputs +XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa + + +.Def:Digital_CD_CD4017 _net13 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 _net12 +Sub:X1 _net13 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 _net12 gnd Type="CD4017_cir" +.Def:End + + + +* ------------------- CD4017B---------------- +* +* Decade Counter +* +* The CMOS Logic Data Book, 1991, Motorola Pages 6-54 to 6-58 +* jds 6/6/94 +* This part is shown in the data book as MC14017B +* Note that the NAND gate feeding into the 3rd flip-flops D input should +* be an AND gate for the circuit to operate as in the timing diagram. +* +.SUBCKT CD4017B CLK CLKENBAR RESET COUT Q0 Q1 Q2 Q3 Q4 Q5 Q6 Q7 Q8 Q9 ++ optional: VDD=$G_CD4000_VDD VSS=$G_CD4000_VSS ++ params: MNTYMXDLY=0 IO_LEVEL=0 + +U14017B LOGICEXP(13,14) VDD VSS ++ CLK CLKENBAR RESET q1ff q2ff q3ff q4ff q5ff ++ q1ffbar q2ffbar q3ffbar q4ffbar q5ffbar ++ clock clear i1 ++ COUT_O Q0_O Q1_O Q2_O Q3_O Q4_O Q5_O Q6_O Q7_O Q8_O Q9_O ++ D0_GATE IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} ++ ++ LOGIC: ++ clock = {( CLK & ~CLKENBAR )} ++ clear = { (~RESET) } ++ i1 = { (q2ff & (q1ff | q3ff)) } ++ Q0_O = { (q1ffbar & q5ffbar) } ++ Q1_O = { (q1ff & q2ffbar) } ++ Q2_O = { (q2ff & q3ffbar) } ++ Q3_O = { (q3ff & q4ffbar) } ++ Q4_O = { (q4ff & q5ffbar) } ++ Q5_O = { (q1ff & q5ff) } ++ Q6_O = { (q1ffbar & q2ff) } ++ Q7_O = { (q2ffbar & q3ff) } ++ Q8_O = { (q3ffbar & q4ff) } ++ Q9_O = { (q5ff & q4ffbar) } ++ COUT_O = { q5ffbar } + +Uf0 dff(5) VDD VSS ++ $D_HI clear clock q5ffbar q1ff i1 q3ff q4ff ++ q1ff q2ff q3ff q4ff q5ff q1ffbar q2ffbar q3ffbar q4ffbar q5ffbar ++ DLY_DFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +.MODEL DLY_DFF UEFF(TWCLKLMN=-1 TWCLKLTY=125NS TWCLKLMX=250NS ++ TWCLKHMN=-1 TWCLKHTY=125NS TWCLKHMX=250NS) + +Udly PINDLY (11,0,2) VDD VSS ++ COUT_O Q0_O Q1_O Q2_O Q3_O Q4_O Q5_O Q6_O Q7_O Q8_O Q9_O ++ CLK RESET ++ COUT Q0 Q1 Q2 Q3 Q4 Q5 Q6 Q7 Q8 Q9 ++ IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} ++ ++ BOOLEAN: ++ CP = {CHANGED_LH(CLK,0)} ++ CLR = { CHANGED_LH(RESET,0) } ++ ++ PINDLY: ++ Q0 Q1 Q2 Q3 Q4 Q5 Q6 Q7 Q8 Q9 = { ++ CASE( ++ CLR, DELAY(-1,500ns,1us), ++ CP, DELAY(-1,500ns,1us), ++ DELAY(-1,501ns,1.001us) ++ ) ++ } ++ COUT = { ++ CASE( ++ CLR, DELAY(-1,400ns,800ns), ++ CP, DELAY(-1,400ns,800ns), ++ DELAY(-1,401ns,801ns) ++ ) ++ } + +Ucnstr CONSTRAINT(3) VDD VSS ++ CLKENBAR CLK RESET ++ IO_4000B ++ ++ FREQ: ++ NODE = CLK ++ MAXFREQ = 5MEG ++ WIDTH: ++ NODE = RESET ++ MIN_HI = 250ns ++ SETUP_HOLD: ++ CLOCK LH = CLK ++ DATA(1) = CLKENBAR ++ SETUPTIME_HI = 175ns ++ SETUPTIME_LO = 260ns ++ WHEN = { RESET != '1 } ++ SETUP_HOLD: ++ CLOCK LH = CLK ++ DATA(1) = RESET ++ SETUPTIME_LO = 375ns + +.ENDS CD4017B +* + +.SUBCKT Digital_CD_CD4017 gnd _net13 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 _net12 +X1 _net13 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 _net12 CD4017B +.ENDS + + + + + + + + + + + + + + + + + + + + + + + + <.PortSym -50 0 1 0 CLK> + + + <.PortSym 50 0 5 180 Q0> + <.PortSym 50 20 6 180 Q1> + <.PortSym 50 40 7 180 Q2> + <.PortSym 50 60 8 180 Q3> + <.PortSym 50 80 9 180 Q4> + <.PortSym 50 100 10 180 Q5> + <.PortSym 50 120 11 180 Q6> + <.PortSym 50 140 12 180 Q7> + <.PortSym 50 160 13 180 Q8> + <.PortSym 50 180 14 180 Q9> + + + + <.ID -10 234 Y> + <.PortSym -50 60 3 0 RST> + + <.PortSym -50 20 2 0 CLKENB> + + + <.PortSym 50 210 4 180 COUT> + + + + + + + +Octal Counter with 8 Decoded Outputs +XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa + + +.Def:Digital_CD_CD4022 _net11 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 +Sub:X1 _net11 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 gnd Type="CD4022_cir" +.Def:End + + + +*---------------------------CD4022B---------------------------------- +* +* Divide by 8 Counter/Divider with 8 Decoded Outputs +* National Semiconductor, CMOS Logic Databook, 1988, pages 5-57 to 5-62 +* jat 8/18/95 +* Note that there should only be a single inversion in front of COUT, not +* a double inversion as shown in the logic diagram. + +.SUBCKT CD4022B ++ CLK CLKENBAR RESET COUT Q0 Q1 Q2 Q3 Q4 Q5 Q6 Q7 ++ OPTIONAL: VDD=$G_CD4000_VDD VSS=$G_CD4000_VSS ++ PARAMS: MNTYMXDLY=0 IO_LEVEL=0 + +U1 LOGICEXP(11,12) VDD VSS ++ CLK CLKENBAR RESET Q1FF Q2FF Q3FF Q4FF Q1FFBAR Q2FFBAR Q3FFBAR Q4FFBAR ++ CLOCK CLEAR D3 COUT_O Q0_O Q1_O Q2_O Q3_O Q4_O Q5_O Q6_O Q7_O ++ D0_GATE IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} ++ LOGIC: ++ CLOCK = {(CLK & (~CLKENBAR))} ++ CLEAR = {(~RESET)} ++ D3 = {~(Q2FFBAR | (~(Q1FF | Q2FFBAR | Q3FF)))} ++ Q0_O = {(Q1FFBAR & Q4FFBAR) } ++ Q1_O = {(Q1FF & Q2FFBAR)} ++ Q2_O = {(Q2FF & Q3FFBAR)} ++ Q3_O = {(Q3FF & Q4FFBAR)} ++ Q4_O = {(Q1FF & Q4FF)} ++ Q5_O = {(Q1FFBAR & Q2FF)} ++ Q6_O = {(Q2FFBAR & Q3FF)} ++ Q7_O = {(Q3FFBAR & Q4FF)} ++ COUT_O = {~Q4FF} + +U2 DFF(4) VDD VSS ++ $D_HI CLEAR CLOCK ++ Q4FFBAR Q1FF D3 Q3FF ++ Q1FF Q2FF Q3FF Q4FF Q1FFBAR Q2FFBAR Q3FFBAR Q4FFBAR ++ DLY_DFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +.MODEL DLY_DFF UEFF(TWCLKLMN=-1 TWCLKLTY=125NS TWCLKLMX=250NS ++ TWCLKHMN=-1 TWCLKHTY=125NS TWCLKHMX=250NS) + +U3 PINDLY(9,0,2) VDD VSS ++ COUT_O Q0_O Q1_O Q2_O Q3_O Q4_O Q5_O Q6_O Q7_O ++ CLK RESET ++ COUT Q0 Q1 Q2 Q3 Q4 Q5 Q6 Q7 ++ IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} ++ BOOLEAN: ++ EDGE = {CHANGED_LH(CLK,0)} ++ CLR = {CHANGED_LH(RESET,0)} ++ PINDLY: ++ Q0 Q1 Q2 Q3 Q4 Q5 Q6 Q7 = { ++ CASE( ++ EDGE & (TRN_LH | TRN_HL), DELAY(-1,500NS,1000NS), ++ CLR & (TRN_LH | TRN_HL), DELAY(-1,500NS,1000NS), ++ DELAY(-1,501NS,1001NS))} ++ COUT = { ++ CASE( ++ EDGE & (TRN_LH | TRN_HL), DELAY(-1,415NS,800NS), ++ CLR & (TRN_LH | TRN_HL), DELAY(-1,415NS,800NS), ++ DELAY(-1,416NS,801NS))} + +U4 CONSTRAINT(3) VDD VSS ++ CLKENBAR CLK RESET ++ IO_4000B IO_LEVEL={IO_LEVEL} ++ FREQ: ++ NODE = CLK ++ MAXFREQ = 2MEG ++ WIDTH: ++ NODE = RESET ++ MIN_HI = 200NS ++ SETUP_HOLD: ++ CLOCK LH = CLK ++ DATA(1) = CLKENBAR ++ SETUPTIME_HI = 120NS ++ WHEN = { RESET != '1 } ++ SETUP_HOLD: ++ CLOCK LH = CLK ++ DATA(1) = RESET ++ SETUPTIME_LO = 75NS + +.ENDS CD4022B + +.SUBCKT Digital_CD_CD4022 gnd _net11 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 +X1 _net11 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 CD4022B +.ENDS + + + + + + + + + + + + + + + + + + + + + + <.PortSym -50 0 1 0 CLK> + + + <.PortSym 50 0 5 180 Q0> + <.PortSym 50 20 6 180 Q1> + <.PortSym 50 40 7 180 Q2> + <.PortSym 50 60 8 180 Q3> + <.PortSym 50 80 9 180 Q4> + <.PortSym 50 100 10 180 Q5> + <.PortSym 50 120 11 180 Q6> + <.PortSym 50 140 12 180 Q7> + + + <.PortSym -50 60 3 0 RST> + + <.PortSym -50 20 2 0 CLKENB> + + + + <.PortSym 50 180 4 180 COUT> + <.ID -10 204 Y> + + + + + +12-Stage Binary Ripple Counter +XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa + + +.Def:Digital_CD_CD4040 _net12 _net13 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 +Sub:X1 _net12 _net13 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 gnd Type="CD4040_cir" +.Def:End + + + +* ----------------------- CD4040B ----------------------- +* +* 12-Stage Binary Counter +* +* The CMOS Logic Data Book, 1991, Motorola Pages 6-108 to 6-111 +* jds 6/8/94 +* This part is shown in the data book as MC14040B +* +.SUBCKT CD4040B CLK RESET Q1 Q2 Q3 Q4 Q5 Q6 Q7 Q8 Q9 Q10 Q11 Q12 ++ optional: VDD=$G_CD4000_VDD VSS=$G_CD4000_VSS ++ params: MNTYMXDLY=0 IO_LEVEL=0 + +USTBUF BUF VDD VSS ++ CLK CLKST ++ D0_GATE IO_4000B_ST MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +uf0 inv VDD VSS ++ RESET clr ++ D0_GATE IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +Uf1 jkff(1) VDD VSS ++ $D_HI clr CLKST $D_HI $D_HI Q1_O Q1BAR_O ++ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +Uf2 jkff(1) VDD VSS ++ $D_HI clr Q1_O $D_HI $D_HI Q2_O Q2BAR_O ++ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +Uf3 jkff(1) VDD VSS ++ $D_HI clr Q2_O $D_HI $D_HI Q3_O Q3BAR_O ++ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +Uf4 jkff(1) VDD VSS ++ $D_HI clr Q3_O $D_HI $D_HI Q4_O Q4BAR_O ++ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +Uf5 jkff(1) VDD VSS ++ $D_HI clr Q4_O $D_HI $D_HI Q5_O Q5BAR_O ++ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +Uf6 jkff(1) VDD VSS ++ $D_HI clr Q5_O $D_HI $D_HI Q6_O Q6BAR_O ++ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +Uf7 jkff(1) VDD VSS ++ $D_HI clr Q6_O $D_HI $D_HI Q7_O Q7BAR_O ++ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +Uf8 jkff(1) VDD VSS ++ $D_HI clr Q7_O $D_HI $D_HI Q8_O Q8BAR_O ++ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +Uf9 jkff(1) VDD VSS ++ $D_HI clr Q8_O $D_HI $D_HI Q9_O Q9BAR_O ++ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +Uf10 jkff(1) VDD VSS ++ $D_HI clr Q9_O $D_HI $D_HI Q10_O Q10BAR_O ++ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +Uf11 jkff(1) VDD VSS ++ $D_HI clr Q10_O $D_HI $D_HI Q11_O Q11BAR_O ++ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +Uf12 jkff(1) VDD VSS ++ $D_HI clr Q11_O $D_HI $D_HI Q12_O Q12BAR_O ++ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +Udly PINDLY (12,0,13) VDD VSS ++ Q1_O Q2_O Q3_O Q4_O Q5_O Q6_O Q7_O Q8_O Q9_O Q10_O Q11_O Q12_O ++ CLK RESET Q1BAR Q2BAR Q3BAR Q4BAR Q5BAR Q6BAR Q7BAR ++ Q8BAR Q9BAR Q10BAR Q11BAR ++ Q1 Q2 Q3 Q4 Q5 Q6 Q7 Q8 Q9 Q10 Q11 Q12 ++ IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} ++ ++ PINDLY: ++ Q1 = { ++ CASE( ++ CHANGED(RESET,0) & TRN_HL, DELAY(-1,370ns,740ns), ++ CHANGED_HL(CLK,0), DELAY(-1,260ns,520ns), ++ DELAY(-1,261ns,521ns) ++ ) ++ } ++ Q2 = { ++ CASE( ++ CHANGED(RESET,0) & TRN_HL, DELAY(-1,370ns,740ns), ++ CHANGED_HL(Q1_O,0), DELAY(-1,384.1ns,768.2ns), ++ DELAY(-1,385.1ns,769.2ns) ++ ) ++ } ++ Q3 = { ++ CASE( ++ CHANGED(RESET,0) & TRN_HL, DELAY(-1,370ns,740ns), ++ CHANGED_HL(Q2_O,0), DELAY(-1,508.2ns,1016.4ns), ++ DELAY(-1,509.2ns,1017.4ns) ++ ) ++ } ++ Q4 = { ++ CASE( ++ CHANGED(RESET,0) & TRN_HL, DELAY(-1,370ns,740ns), ++ CHANGED_HL(Q3_O,0), DELAY(-1,632.3ns,1264.6ns), ++ DELAY(-1,633.3ns,1265.6ns) ++ ) ++ } ++ Q5 = { ++ CASE( ++ CHANGED(RESET,0) & TRN_HL, DELAY(-1,370ns,740ns), ++ CHANGED_HL(Q4_O,0), DELAY(-1,756.4ns,1512.8ns), ++ DELAY(-1,757.4ns,1513.8ns) ++ ) ++ } ++ Q6 = { ++ CASE( ++ CHANGED(RESET,0) & TRN_HL, DELAY(-1,370ns,740ns), ++ CHANGED_HL(Q5_O,0), DELAY(-1,880.5ns,1761ns), ++ DELAY(-1,881.5ns,1762ns) ++ ) ++ } ++ Q7 = { ++ CASE( ++ CHANGED(RESET,0) & TRN_HL, DELAY(-1,370ns,740ns), ++ CHANGED_HL(Q6_O,0), DELAY(-1,1004.6ns,2009.2ns), ++ DELAY(-1,1005.6ns,2010.2ns) ++ ) ++ } ++ Q8 = { ++ CASE( ++ CHANGED(RESET,0) & TRN_HL, DELAY(-1,370ns,740ns), ++ CHANGED_HL(Q7_O,0), DELAY(-1,1128.7ns,2257.4ns), ++ DELAY(-1,1129.7ns,2258.4ns) ++ ) ++ } ++ Q9 = { ++ CASE( ++ CHANGED(RESET,0) & TRN_HL, DELAY(-1,370ns,740ns), ++ CHANGED_HL(Q8_O,0), DELAY(-1,1252.8ns,2505.6ns), ++ DELAY(-1,1253.8ns,2506.6ns) ++ ) ++ } ++ Q10 = { ++ CASE( ++ CHANGED(RESET,0) & TRN_HL, DELAY(-1,370ns,740ns), ++ CHANGED_HL(Q9_O,0), DELAY(-1,1376.9ns,2753.8ns), ++ DELAY(-1,1377.9ns,2754.8ns) ++ ) ++ } ++ Q11 = { ++ CASE( ++ CHANGED(RESET,0) & TRN_HL, DELAY(-1,370ns,740ns), ++ CHANGED_HL(Q10_O,0), DELAY(-1,1501ns,3002ns), ++ DELAY(-1,1502ns,3003ns) ++ ) ++ } ++ Q12 = { ++ CASE( ++ CHANGED(RESET,0) & TRN_HL, DELAY(-1,370ns,740ns), ++ CHANGED_HL(Q11_O,0), DELAY(-1,1625ns,3250ns), ++ DELAY(-1,1626ns,3251ns) ++ ) ++ } + +Ucnstr CONSTRAINT(2) VDD VSS ++ CLK RESET ++ IO_4000B ++ ++ FREQ: ++ NODE = CLK ++ MAXFREQ = 2.1MEG ++ WIDTH: ++ NODE = CLK ++ MIN_HI = 140ns ++ WIDTH: ++ NODE = RESET ++ MIN_HI = 320ns ++ SETUP_HOLD: ++ CLOCK HL = CLK ++ DATA(1) = RESET ++ SETUPTIME_LO = 65ns + +.ENDS CD4040B +* + +.SUBCKT Digital_CD_CD4040 gnd _net12 _net13 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 +X1 _net12 _net13 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net7 _net8 _net9 _net10 _net11 CD4040B +.ENDS + + + + + + + + + + + + + + + + + + + + + + + + <.PortSym 50 0 3 180 QA> + <.PortSym 50 20 4 180 QB> + <.PortSym 50 40 5 180 QC> + <.PortSym 50 60 6 180 QD> + <.PortSym 50 80 7 180 QE> + <.PortSym 50 100 8 180 QF> + <.PortSym 50 120 9 180 QG> + <.PortSym 50 140 10 180 QH> + <.PortSym 50 160 11 180 QI> + <.PortSym 50 180 12 180 QJ> + + + + + <.ID -10 244 Y> + <.PortSym 50 200 13 180 QK> + <.PortSym 50 220 14 180 QL> + + + + + + <.PortSym -50 60 2 0 RES> + <.PortSym -50 0 1 0 CLK> + + + + + +Inverting Buffer +XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa + + +.Def:Digital_CD_CD4069 _net0 _net1 +Sub:X1 _net0 _net1 gnd Type="CD4069_cir" +.Def:End + + + +* ---------------------------- CD4069UB -------------------------- +* +* Hex Inverting Buffer +* +* The CMOS Logic Data Book, 1988, National Semiconductor Pages 5-180 to 5-183 +* jds 6/8/94 +* +.SUBCKT CD4069UB A ABAR ++ optional: VDD=$G_CD4000_VDD VSS=$G_CD4000_VSS ++ params: MNTYMXDLY=0 IO_LEVEL=0 + +uf0 inv VDD VSS ++ A ABAR ++ DLY_MOD IO_4000UB MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +.model DLY_MOD ugate (TPLHMN=-1 TPLHTY=50ns TPLHMX=90ns ++ TPHLMN=-1 TPHLTY=50ns TPHLMX=90ns) + +.ENDS CD4069UB +* + +.SUBCKT Digital_CD_CD4069 gnd _net0 _net1 +X1 _net0 _net1 CD4069UB +.ENDS + + + + + + + <.ID 10 14 Y> + <.PortSym 30 0 2 180 P2> + + <.PortSym -30 0 1 0 P1> + + + + + +2-Input XOR Gate +XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa + + +.Def:Digital_CD_CD4070 _net0 _net1 _net2 +Sub:X1 _net0 _net1 _net2 gnd Type="CD4070_cir" +.Def:End + + + +* -------------------------------- CD4070B ------------------------------- +* +* Quad 2-Input XOR Gate +* +* The CMOS Logic Data Book, 1988, National Semiconductor Pages 5-184 to 5-187 +* jds 6/8/94 +* +.SUBCKT CD4070B IN1A IN2A OUTA ++ optional: VDD=$G_CD4000_VDD VSS=$G_CD4000_VSS ++ params: MNTYMXDLY=0 IO_LEVEL=0 + +uf0 xor VDD VSS ++ IN1A IN2A OUTA ++ DLY_MOD IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +.model DLY_MOD ugate (TPLHMN=-1 TPLHTY=110ns TPLHMX=185ns ++ TPHLMN=-1 TPHLTY=110ns TPHLMX=185ns) + +.ENDS CD4070B +* + +.SUBCKT Digital_CD_CD4070 gnd _net0 _net1 _net2 +X1 _net0 _net1 _net2 CD4070B +.ENDS + + + <.PortSym -30 -10 1 0 P1> + <.PortSym -30 10 2 0 P2> + <.PortSym 30 0 3 180 P3> + <.ID 10 14 Y> + + + + + + + + + + + +2-Input OR Gate + XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa + + +.Def:Digital_CD_CD4071 _net0 _net1 _net2 +Sub:X1 _net0 _net1 _net2 gnd Type="CD4071_cir" +.Def:End + + + +* --------------------------- CD4071B------------------------ +* +* Quad 2-Input OR Gate +* +* The CMOS Logic Data Book, 1991, Motorola Pages 6-5 to 6-14 +* jds 6/6/94 +* This part is shown in the data book as MC14071B +* +.SUBCKT CD4071B IN1A IN2A OUTA ++ optional: VDD=$G_CD4000_VDD VSS=$G_CD4000_VSS ++ params: MNTYMXDLY=0 IO_LEVEL=0 +* +Uf0 or(2) VDD VSS ++ IN1A IN2A OUTA ++ DLY_MOD IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +.model DLY_MOD ugate (TPLHMN=-1 TPLHTY=160ns TPLHMX=300ns ++ TPHLMN=-1 TPHLTY=160ns TPHLMX=300ns) + +.ENDS CD4071B +* + +.SUBCKT Digital_CD_CD4071 gnd _net0 _net1 _net2 +X1 _net0 _net1 _net2 CD4071B +.ENDS + + + <.PortSym -30 -10 1 0 P1> + <.PortSym -30 10 2 0 P2> + <.PortSym 30 0 3 180 P3> + <.ID 10 14 Y> + + + + + + + + + + + + +2-Input AND Gate + XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa + + +.Def:Digital_CD_CD4081 _net0 _net1 _net2 +Sub:X1 _net0 _net1 _net2 gnd Type="CD4081_cir" +.Def:End + + + +* ------------------------------ CD4081B------------------------- +* +* Quad 2-Input AND Gate +* +* The CMOS Logic Data Book, 1991, Motorola Pages 6-5 to 6-14 +* jds 6/6/94 +* This part is shown in the data book as MC14081B +* +.SUBCKT CD4081B IN1A IN2A OUTA ++ optional: VDD=$G_CD4000_VDD VSS=$G_CD4000_VSS ++ params: MNTYMXDLY=0 IO_LEVEL=0 +* +Uf0 and(2) VDD VSS ++ IN1A IN2A OUTA ++ DLY_MOD IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +.model DLY_MOD ugate (TPLHMN=-1 TPLHTY=160ns TPLHMX=300ns ++ TPHLMN=-1 TPHLTY=160ns TPHLMX=300ns) + +.ENDS CD4081B +* + +.SUBCKT Digital_CD_CD4081 gnd _net0 _net1 _net2 +X1 _net0 _net1 _net2 CD4081B +.ENDS + + + <.PortSym -30 -10 1 0 P1> + <.PortSym -30 10 2 0 P2> + <.PortSym 30 0 3 180 P3> + <.ID 10 14 Y> + + + + + + + + + + +8 Bit Static Shift Register/Latch +XSPICE Based Model +Requirements: +.spiceinit: set ngbehavior=psa + + +.Def:Digital_CD_CD4094 _net7 _net8 _net9 _net10 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net11 _net12 _net13 +Sub:X1 _net7 _net8 _net9 _net10 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net11 _net12 _net13 gnd Type="CD4094_cir" +.Def:End + + + +*-------------------------------------------------------------CD4094B----- + +* 8 Bit Static Shift Register/Latch with Tri-State Outputs +* National CMOS Logic Databook +* jat 9/7/95 + +.SUBCKT CD4094B STROBE DATA CLOCK OUTEN Q1 Q2 Q3 Q4 Q5 Q6 Q7 Q8 QS QSPRIME ++ OPTIONAL: VDD=$G_CD4000_VDD VSS=$G_CD4000_VSS ++ PARAMS: MNTYMXDLY=0 IO_LEVEL=0 + +U1 LOGICEXP(1,1) VDD VSS ++ CLOCK CLOCKBAR ++ D0_GATE IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} ++ LOGIC: ++ CLOCKBAR = {~CLOCK} + +U2 DFF(8) VDD VSS ++ $D_HI $D_HI CLOCK ++ DATA Q1I Q2I Q3I Q4I Q5I Q6I Q7I ++ Q1I Q2I Q3I Q4I Q5I Q6I Q7I QSO ++ $D_NC $D_NC $D_NC $D_NC $D_NC $D_NC $D_NC $D_NC ++ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U3 DFF(1) VDD VSS ++ $D_HI $D_HI CLOCKBAR ++ QSO QSPRIMEO $D_NC ++ D0_EFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U4 DLTCH(8) VDD VSS ++ $D_HI $D_HI STROBE ++ Q1I Q2I Q3I Q4I Q5I Q6I Q7I QSO ++ Q1O Q2O Q3O Q4O Q5O Q6O Q7O Q8O ++ $D_NC $D_NC $D_NC $D_NC $D_NC $D_NC $D_NC $D_NC ++ D0_GFF IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} + +U5 PINDLY(10,1,2) VDD VSS ++ Q1O Q2O Q3O Q4O Q5O Q6O Q7O Q8O QSO QSPRIMEO ++ OUTEN ++ STROBE CLOCK ++ Q1 Q2 Q3 Q4 Q5 Q6 Q7 Q8 QS QSPRIME ++ IO_4000B MNTYMXDLY={MNTYMXDLY} IO_LEVEL={IO_LEVEL} ++ BOOLEAN: ++ UNLATCH = {CHANGED_LH(STROBE,0)} ++ EDGE = {CHANGED_LH(CLOCK,0)} ++ TRISTATE: ++ ENABLE HI = OUTEN ++ Q1 Q2 Q3 Q4 Q5 Q6 Q7 Q8 = { ++ CASE( ++ TRN_Z$ | TRN_$Z, DELAY(-1,140NS,280NS), ++ UNLATCH & (TRN_LH | TRN_HL), DELAY(-1,290NS,580NS), ++ EDGE & (TRN_LH | TRN_HL), DELAY(-1,420NS,840NS), ++ DELAY(-1,421NS,841NS))} ++ PINDLY: ++ QS = { ++ CASE( ++ (TRN_LH | TRN_HL), DELAY(-1,300NS,600NS), ++ DELAY(-1,301NS,601NS))} ++ PINDLY: ++ QSPRIME= { ++ CASE( ++ (TRN_LH | TRN_HL), DELAY(-1,230NS,460NS), ++ DELAY(-1,231NS,461NS))} + +U6 CONSTRAINT(3) VDD VSS ++ CLOCK DATA STROBE ++ IO_4000B IO_LEVEL={IO_LEVEL} ++ SETUP_HOLD: ++ CLOCK LH = CLOCK ++ DATA(1) = DATA ++ SETUPTIME = 40NS ++ WIDTH: ++ NODE = CLOCK ++ MIN_HI = 100NS ++ MIN_LO = 100NS ++ WIDTH: ++ NODE = STROBE ++ MIN_HI = 100NS ++ FREQ: ++ NODE = CLOCK ++ MAXFREQ = 3MEG + +.ENDS CD4094B + +.SUBCKT Digital_CD_CD4094 gnd _net7 _net8 _net9 _net10 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net11 _net12 _net13 +X1 _net7 _net8 _net9 _net10 _net0 _net1 _net2 _net3 _net4 _net5 _net6 _net11 _net12 _net13 CD4094B +.ENDS + + + + + + + + + + + + + + + + + <.PortSym 50 0 5 180 QA> + <.PortSym 50 20 6 180 QB> + <.PortSym 50 40 7 180 QC> + <.PortSym 50 60 8 180 QD> + <.PortSym 50 80 9 180 QE> + <.PortSym 50 100 10 180 QF> + <.PortSym 50 120 11 180 QG> + <.PortSym 50 140 12 180 QH> + <.ID -10 214 Y> + + + + <.PortSym 50 170 13 180 QS> + <.PortSym 50 190 14 180 QSP> + <.PortSym -50 0 4 0 OE> + + + + + + + + + <.PortSym -50 100 3 0 CLK> + + + + <.PortSym -50 60 2 0 D> + + <.PortSym -50 20 1 0 STB> + + + \ No newline at end of file