Systems And Methods For Programming Floating-gate Transistors by Graham, David W. et al.
c12) United States Patent 
Graham et al. 
(54) SYSTEMS AND METHODS FOR 
PROGRAMMING FLOATING-GATE 
TRANSISTORS 
(75) Inventors: David W. Graham, Atlanta, GA (US); 
Ethan Farquhar, Austell, GA (US); 
Jordan Gray, Atlanta, GA (US); 
Christopher M. Twigg, Marietta, GA 
(US); Brian Degnan, Atlanta, GA (US); 
Christal Gordon, Atlanta, GA (US); 
David Abramson, Atlanta, GA (US); 
Paul Hasler, Atlanta, GA (US) 
(73) Assignee: Georgia Tech Research Corporation, 
Atlanta, GA (US) 
( *) Notice: Subject to any disclaimer, the term of this 
patent is extended or adjusted under 35 
U.S.C. 154(b) by 0 days. 
(21) Appl. No.: 111382,640 
(22) Filed: May 10, 2006 
(65) Prior Publication Data 
US 2007 /0007999 Al Jan. 11, 2007 
Related U.S. Application Data 
(60) Provisional application No. 60/679,539, filed on May 
10, 2005. 
(51) Int. Cl. 
GllC 16100 (2006.01) 
(52) U.S. Cl. ............. 365/100; 365/185.05; 365/185.23 
(58) Field of Classification Search ................ 365/100, 
365/102 
See application file for complete search history. 
100-. 
139 
I lllll llllllll Ill lllll lllll lllll lllll lllll 111111111111111111111111111111111 
US007269046B2 
(IO) Patent No.: US 7,269,046 B2 
Sep.11,2007 (45) Date of Patent: 
(56) 
EP 
References Cited 
U.S. PATENT DOCUMENTS 
4,486,769 A * 
5,172,196 A * 
6,064,595 A * 
6,295,226 Bl * 
6,300,662 Bl * 
12/1984 Simko ........................ 257 /317 
12/1992 Matsukawa et al. ........ 257 /316 
512000 Logie et al ............ 365/185.18 
9/2001 Yang ..................... 365/185.01 
10/2001 Doyle et al. ................ 257 /390 
FOREIGN PATENT DOCUMENTS 
1 096 502 * 5/2001 
* cited by examiner 
Primary Examiner-Tan T. Nguyen 
(7 4) Attorney, Agent, or Firm-Troutman Sanders LLP; 
Ryan A. Schneider; James E. Schutz 
(57) ABSTRACT 
A floating-gate transistor array and method for progrannning 
the same. The floating-gate transistor array includes a plu-
rality of transistors having a source, drain, and floating-gate, 
whereby the plurality of transistors is arranged into multiple 
rows and columns. Each row of transistors includes a row 
programming switch having an output connected to each 
floating-gate within the row, while each column of transis-
tors includes a column programming switch having an 
output connected to each drain within the column. The 
source of each transistor is coupled with a source line 
corresponding to the specific row of the transistor. The row 
and column progrannning switches are utilized to select and 
program a desired floating-gate transistor. In an indirect 
programming method, two transistors share a floating gate, 
such that programming a programmer transistor modifies the 
current of an agent transistor, which is attached to the circuit, 
thereby permitting run-time programming. 
6 Claims, 38 Drawing Sheets 
U.S. Patent Sep.11,2007 Sheet 1 of 38 US 7,269,046 B2 
100~ 
145 
ramp 
Ve generator 
r 
142 
I 
I 
I 
106A ' 
127A \ Vtun 
' \ JJ12A 
133A ~ 
130A 103A 
1218 
106C prog 
127C Vtun 
\ J112C 
133C \~ 
130C 103C 
prog 
csel<O> 11 BA 
139 
1068 
1278 l Vtun 
\ Jj_ 128 
1338 ~ 
109A 1308 1038 
1060 
1270 Vtun 
\ Jj120 
1330 ~ 
109C 1300 1030 
124A 
csel<1 > 1188 
1368 
1098 
1098 
1248 
FIG. 1 
U.S. Patent Sep.11,2007 Sheet 2 of 38 US 7,269,046 B2 
100~ 
prog 
118 
VD 
~-~~------- --------------- 139 
/ ' 
I 106 \ 
I I 
I 
I 
I VTun 
I 
I 
I 
: v 127 
l, 13?io 109 ) 
~ 112 
' / '-~------------------------/ 
FIG. 2 
U.S. Patent Sep.11,2007 Sheet 3 of 38 US 7,269,046 B2 
0 0.5 1 1.5 2 2.5 3 
V
5 
=Vd + 25mV (V) 
FIG. 3 
U.S. Patent Sep.11,2007 Sheet 4 of 38 US 7,269,046 B2 
103~~~~~~~~~~~~~~~~~~~~ 
0 0.5 1 1.5 2 2.5 3 
_____ \/()1~9.~ (V)_ _______________ _ 
FIG. 4 
U.S. Patent Sep.11,2007 Sheet 5 of 38 US 7,269,046 B2 
503A 5038 
(...-... /\B 
\J 11-\ 
(r'\ DB 
"--''I \ C.AB 
\_ 503C 5030 
FIG. 5 
U.S. Patent 
N' 10 
J: 
~ 
-
.J::. 
.... 
"'O 
~ 
c 
(0 
CD 1 
1 
Sep.11,2007 Sheet 6 of 38 US 7,269,046 B2 
2 3 4 5 
Number of Switch Pairs 
FIG. 6 
U.S. Patent Sep.11,2007 Sheet 7 of 38 US 7,269,046 B2 
FIG. 7 
U.S. Patent 
1 
Sep.11,2007 Sheet 8 of 38 US 7,269,046 B2 
5 
803 
806 
809 
10 15 
Drain Curren( nA) 
--No Resistor 
--10k Resistor 
-20k Resistor 
20 25 
FIG. 8 
U.S. Patent Sep. 11, 2007 Sheet 9 of 38 
FIG. 9A 
FIG. 9C 
I 
I 
103 i 
US 7,269,046 B2 
FIG. 98 
'FIG. 9D 
U.S. Patent Sep.11,2007 Sheet 10 of 38 US 7,269,046 B2 
~ I 
112 
127 
133 
FIG. 10A 
U.S. Patent Sep. 11, 2007 Sheet 11 of 38 US 7,269,046 B2 
100~ 
FIG. 108 
U.S. Patent 
0 0.5 
Sep.11,2007 Sheet 12 of 38 US 7,269,046 B2 
·."' \. 
\ 
\ 
Tunneling \ Injection 
' \. 
' ' \ 
\ 
' \ 
' 
' 
' ' 
-------\ ' ______ __,. \ 
\ 
\ 
\ 
\ 
\ 
1.5 2 
Gate Voltage (V) 
' 
' \ 
\ 
2.5 
' 
' 
' 
' 
' 
FIG. 10C 
3 
U.S. Patent Sep.11,2007 Sheet 13 of 38 US 7,269,046 B2 
-8 
1.3 x 10 
/ 
<9 
I 
20 
-0.2 
20 
40 60 80 100 120 
Floating gate position 
I 
40 60 80 100 
Floating gate position 
120 
FIG. 100 
U.S. Patent Sep. 11, 2007 Sheet 14 of 38 US 7,269,046 B2 
Vtun Vtun 
j_ j_ 
103 ~ ~ 103 FIG. 11A 127 127 
:&,ut 
~ 
-
-
1109 
1109 
r--J_ 
'I' 
.. 
r 
---rn 
..L 
hi 
-
- FIG. 118 
U.S. Patent Sep. 11, 2007 Sheet 15 of 38 US 7,269,046 B2 
-
FIG. 11C 
-
Vpcaso p 1109 
FIG. 11D 
U.S. Patent Sep.11,2007 Sheet 16 of 38 US 7,269,046 B2 
c 
1.1 ,-...---.--T".....-r-r-'"'T--.--.....-...-............... ,----.--r;::::========:;i 
Ul5 
t- IPFG Current Mlrrar 
Non-FG Current Mirror 
~ 0.9 
ti 
.ii 
E 
!l 
~ 
c 
D.B,__ ______ ......._ ______________ ..._ ____ __, 
10'' 
5r-----,.----.-.-,-,,.,.,---,---.--.-,..,rrrr--r-'";J:=:?:::i;:;g;q;::==~==::i::::;i 
- IPFG Current M!rrar 
10·• 10~ 
- Non·FG Current Mirror 
.. _ .. ,,(----~-~-........... \ .~~-~~~-
0 -·····/ ·•····•····•····•··· t·········· .. ········'·····'· .... ~················· 
/r ~-~-~ ... ,+. 
-5 
·10 
-15 
10'' 10·• 
10~ 
:1 + lclea.IGain I 
:I :.: Programmed Gain 
10" 
Input Current 
FIG. 11E 
~ 10"' 
"'O 
.. 
E 
E 
I!! it 1 o·• 
·D. 
1 o"'• 
;o·• 
D.9 
0.6 
0.4 
0 D.:2 t: 
w 
E 
~ 0 
d! 
·D.2 
11r' 
10~ 10' 
' 
10' 
FIG. 11F 
U.S. Patent 
-c: ~ 
::::J () 
a> 
c: 
c: 
ca 
.c: () 
10-4 
Sep.11,2007 
0.5 1 
Sheet 17 of 38 US 7,269,046 B2 
1 
....... ,. Programming pFET I 
-·~~-Agent pFET 
1.5 2 2.5 3 
Gate Voltage (V) 
FIG. 12A 
U.S. Patent Sep.11,2007 Sheet 18 of 38 US 7,269,046 B2 
ur11 ,___.__._"""""""'........__......,.,....._, ............. .___........._ ........... ......___.__......._............, 
to"" 10.. to"' 10"' trf 
~pFEiOnent(A) 
FIG. 128 
U.S. Patent Sep.11,2007 Sheet 19 of 38 US 7,269,046 B2 
10-8 
-< 
-
'E 
~ 
.... 
:::J (...) 
10-9 
0 5 10 15 20 25 30 
. ***** .. **** 
******* ********* · Target= 10nA 
- - - - - ***" ..... *' - - - - - - - - - - - - - ooo 
********* . ·000000000 J 
_ .,,..,c,0 000 000\ .. K-'"-' ·" 
. cm'oooo , ....----------.. 
, , 00000-0000'<) ~ " ·* Programming pFET 
·ooo, o In-Line FET 
0 5 10 15 20 25 
Iteration 
30 35 40 
FIG. 12C 
U.S. Patent Sep. 11, 2007 Sheet 20 of 38 US 7,269,046 B2 
1103 
FIG. 13A 
U.S. Patent Sep.11,2007 Sheet 21 of 38 US 7,269,046 B2 
FIG. 138 
10"' 
.~ 
~· 
3' 
L5 2 2,5 
G68VoltageM 
FIG. 13C 
U.S. Patent 
1~ 
Sep.11,2007 Sheet 22 of 38 
+ ProfillmllllM pFET 
o AgentnFET 
EID 
US 7,269,046 B2 
FIG. 13D 
1!)'1D 10• 1 rt' 10"" 
pFET GulT@flt (A~ 
FIG. 13E 
U.S. Patent Sep.11,2007 Sheet 23 of 38 US 7,269,046 B2 
. 
-
-
to"' 11:r111 
pfET C!JmM11: (A) 
FIG. 13F 
U.S. Patent Sep.11,2007 Sheet 24 of 38 US 7,269,046 B2 
c 
.... gr&;p 
103 "'Q 
C ~ •. p~.: 
f I , ~ 
C .. "il ox,p .. ,,, c;dl> 
FIG. 14A 
5.5~--~--~--~--~--~--~ 
- pFET 
5 ····*···· FG pFET 
... 1:ll-·· Cascoded FG pFET 
4.5 ... ,~),.. Larger cin 
0'--~~"'--~~_._~~-'"-~~--~~_._~~-' 
0 0.5 1 1.5 2 2.5 3 
Source-to-Drain Voltage (V) 
FIG. 148 
U.S. Patent Sep. 11, 2007 Sheet 25 of 38 US 7,269,046 B2 
1503~ 
FIG. 15A 
U.S. Patent Sep.11,2007 Sheet 26 of 38 US 7,269,046 B2 
20 
Initial Program 
10 ....... 
-
Corrected Coefficients 
co 0 "O 
-c: 
"ffi -10 
(.!) 
-20 
-30 
101 102 103 104 105 
10 
-co 
"O 
- 0 
6. Initial Program 
n Second Iteration 
* Corrected Coefficients 
102 
Frequency (Hz) 
FIG. 158 
U.S. Patent 
20 
15 
10 
5 
0 
-CXl 
-5 "O 
-c: 
"ffi -10 (!} 
-15 
-20 
-25 
-30 
-35 
101 
Sep.11,2007 Sheet 27 of 38 
103 
Frequency (Hz) 
US 7,269,046 B2 
FIG. 15C 
U.S. Patent Sep.11,2007 
1600~ 
1603 
Initial Program 
r 1606 
-------""""'---
Circuit 
Measurement 
Operational 
Circuit 
Mismatches 
Programmed Out 
Sheet 28 of 38 US 7,269,046 B2 
1618 
Reprogram 
for Corrected 
Parameters 
Extract 
No Parameters 
1615 
FIG. 16 
U.S. Patent 
1cr1 
Sep.11,2007 Sheet 29 of 38 US 7,269,046 B2 
100nA 
··--·· .. ~M. 
0 1 0 20 30 40 50 60, 70 BO QO 
Time (s) 
FIG. 17A 
U.S. Patent Sep. 11, 2007 Sheet 30 of 38 US 7,269,046 B2 
1703 '::i. 
....._ __ Vaut 
T0t 
....__ _ ___ 
FIG. 178 
U.S. Patent Sep.11,2007 Sheet 31 of 38 US 7,269,046 B2 
c: 
"ffi -30 
CJ 
-40 
-50.___._...._.__._._..........J.~...._...._._........_.........i_~..__._._._._._._..J:.____.__._ ......... ............;;: 
101 102 103 
Frequency (Hz) 
0.8 
·························································~ 
0.6 ----- -
·ffi 0.4 ~ 
CJ 0.2 
0 Injection Turned On 
-0.2'--~"'--~-'-~~~-'-~-'-~--'-~~'--~_._______, 
0 50 100 , 50 200 250 300 350 400 450 
Time (s) 
FIG. 17C 
U.S. Patent Sep.11,2007 Sheet 32 of 38 US 7,269,046 B2 
1800~ 
NO 
1815 
END 
1803 
START 
PULL ALL SOURCE 
LINES OF 
TRANSISTORS IN ALL 
ROWS TO POWER 
SUPPLY 
PULL ALL DRAIN LINES 
OF TRANSISTORS IN 
ALL COLUMNS TO Voo 
IS SWITCH 
DESIRED FOR 
PROGRAMMING? 
1806 
1809 
YES 
FIG. 18A 
U.S. Patent Sep.11,2007 Sheet 33 of 38 US 7,269,046 B2 
A 
, 
CONNECT 
TRANSISTOR DRAIN 
OF DESIRED SWITCH 
TO EXTERNAL POWER 
SOURCE VD 
·~ r 1821 
..--------''-----.....__, 
SWITCH GATE LINES 
OF TRANSISTOR TO 
VGORVDD, 
DEPENDING ON 
CIRCUITRY 
r 1824 
.-----------~--..____, 
ISOLA TE DEVICE BY 
DRIVING ONLY ONE 
TRANSISTOR AT A 
TIME WITH BOTH VSD 
AND VSG TO TURN 
DEVICE "ON" 
~~ r 1821 
..--------...__ __ .....__, 
r 1830 PROGRAM SELECTED 
TRANSISTOR USING 
HOT-ELECTRON 
INJECTION 
----~------~: END ~I 
""------~ 
FIG. 188 
U.S. Patent Sep.11,2007 Sheet 34 of 38 US 7,269,046 B2 
1903 
START 
1900~ 
NO 
END 
NO 
LOWER AGENT AND 
PROGRAMMER 
TRANSISTORS TO 
SUBTHRESHOLD 
IS DESIRED 
CURRENT HIGHER 
THAN PRESENT 
CURRENT? 
IS DESIRED 
CURRENT LOWER 
THAN PRESENT 
CURRENT? 
YES 
1915 
1906 
1909 
YES 
FIG. 19A 
U.S. Patent Sep.11,2007 Sheet 35 of 38 US 7,269,046 B2 
USE HOT-ELECTRON 
INJECTION ON 
PROGRAMMER 
TRANSISTOR UNTIL 
DESIRED CURRENT IS 
REACHED 
1918 
USE TUNNELING ON 
PROGRAMMER 
TRANSISTOR UNTIL 
DESIRED CURRENT IS 
REACHED 
1924 
AGENT TRANSISTOR 
AUTOMATICALLY 
PROGRAMMED FROM 
PROGRAMMER 
TRANSISTOR SHARING 
FLOATING-GATE 
1927 
END 
1921 
FIG. 198 
U.S. Patent Sep.11,2007 Sheet 36 of 38 US 7,269,046 B2 
2003 
START 
2000~ 
NO 
END 
NO 
LOWER AGENT AND 
PROGRAMMER 
TRANSISTORS TO 
SUBTHRESHOLD 
IS DESIRED 
CURRENT LOWER 
THAN PRESENT 
CURRENT? 
IS DESIRED 
CURRENT HIGHER 
THAN PRESENT 
CURRENT? 
YES 
2015 
2006 
YES 
FIG. 20A 
U.S. Patent Sep.11,2007 
USE HOT-ELECTRON 
INJECTION ON 
PROGRAMMER 
TRANSISTOR UNTIL 
DESIRED CURRENT IS 
REACHED 
2018 
Sheet 37 of 38 
USE TUNNELING ON 
PROGRAMMER 
TRANSISTOR UNTIL 
DESIRED CURRENT IS 
REACHED 
2024 
AGENT TRANSISTOR 
AUTOMATICALLY 
PROGRAMMED FROM 
PROGRAMMER 
TRANSISTOR SHARING 
FLOATING-GATE 
2027 
END 
US 7,269,046 B2 
2021 
FIG. 208 
U.S. Patent Sep.11,2007 Sheet 38 of 38 US 7,269,046 B2 
START 
(STEP 1906 OF 
FIG. 19 AND 2006 2103 
2100~ 
NO 
RAISE WELL 
POTENTIAL OF 
PROGRAMMER 
TRANSISTOR 
LOWER SOURCE 
POTENTIAL OF 
PROGRAMMER 
TRANSISTOR 
END 
2112 
2115 
2118 
FIG. 21 
OF FIG. 20) 
r2109 
IS SOURCE OF 
AGENT 
TRANSISTOR 
ACCESSIBLE? 
YES 
DECREASE SOURCE 
OF PROGRAMMER 
TRANSISTOR WITH 
RESPECT TO Vwell 
INCREASE SOURCE 
OF AGENT 
TRANSISTOR WITH 
RESPECT TO Vbulk 
ADJUST CHANNEL 
CURRENTS TO 
SUBTHRESHOLD TO 
CREATE LINEAR 
CURRENT-TO-
CURRENT 
RELATIONSHIP 
BETWEEN 
PROGRAMMER AND 
AGENT TRANSISTORS 
2121 
2124 
2127 
US 7,269,046 B2 
1 
SYSTEMS AND METHODS FOR 
PROGRAMMING FLOATING-GATE 
TRANSISTORS 
CROSS REFERENCE TO RELATED 
APPLICATION 
This application claims priority of U.S. Provisional Patent 
Application No. 60/679,539, filed 10 May 2005, the entire 
contents of which is hereby incorporated by reference. 
BACKGROUND 
1. Field of the Invention 
The present invention relates to floating-gate transistors 
and, more particularly, to programming floating-gate tran-
sistors for use in analog circuitry. 
2. Description of Related Art 
Floating-gate transistors are commonly utilized in non-
volatile storage devices, such as flash memory, erasable 
programmable read-only memory (EPROM), and electri-
cally erasable programmable read-only memory (EE-
PROM). Floating-gate metal-oxide semiconductor field-ef-
fect transistors (MOSFETs), the most commonly used 
floating-gate transistors, are capable of storing an electrical 
charge for extended periods of time without requiring an 
additional power supply. A floating-gate MOSFET typically 
includes a control gate and a floating gate, such that, when 
provided an electrical charge through hot-electron injection 
and/or Fowler-Nordheim tunneling, the charge is retained on 
the floating-gate due to an insulating oxide. 
Floating-gate transistors may also be used in more com-
plicated circuitry. For example, a floating-gate MOSFET 
(FET) may be a desirable switch element for use in a 
field-programmable analog array (FPAA) crossbar switch 
network, due to the programmed FET having a resistance 
similar to that of a transmission gate (T-gate) and the 
capacitance of a single pass-PET, while requiring no digital 
memory to store the state of the switch. 
Generally, an FPAA is a programmable integrated circuit 
capable of implementing an enormous range of analog 
signal processing functions. The FPAA typically comprises 
a computational analog block (CAB) and an interconnect 
network, such that an FPAA may be distinguished from 
another by these two components. For the interconnect 
structure, an FPAA is most commonly connected by metal-
oxide semiconductor (MOS) transistor switches driven by 
digital memory. Such a MOSFET (e.g., pass-PET), however, 
inherently includes non-linear resistance, thereby dramati-
cally reducing the range of passable signals in comparison to 
the range of the power supply. Conventional alternatives to 
pass-FETs and T-gates often provide increased bandwidth 
and include Gm-C amplifiers, 4-transistor transconductors, 
and current conveyors. Unfortunately, each of these alter-
natives trade area for improved switch characteristics and 
require an additional physical memory element for main-
taining connectivity within the FPAA. 
2 
increasingly competitive with digital circuits for applica-
tions requiring dense, low-power, and high-speed signal 
processing. 
Referring back to FPAA crossbar switch networks, the 
utilization of a floating-gate switch (e.g., FET) as the trans-
mission element eliminates the need for digital memory and 
reduces resistance limitations, while maintaining a mini-
mally sized switch element. Unfortunately, programming 
floating-gate switches within an FPAA crossbar switch net-
10 work is no easy task. To complicate matters, the program-
ming circuitry for floating-gate circuits is currently off-chip, 
thereby leading to a large programming time limited mainly 
by the use of an ammeter for current measurement. The 
larger capacitance at the board level also prevents running 
15 the programming circuitry at higher speeds. 
As integrated circuits trend toward the use oflower power 
and lower voltage, the floating-gate transistor provides 
promise for switches functioning on a decreased supply 
voltage (as resistance on a switch increases due to the loss 
20 in the gate drive caused by the lower voltage). Floating-gate 
transistors may also be effectively used for precisely pro-
gramming a large array of current sources in a circuit. 
Unfortunately, present floating-gate programming tech-
niques require disconnection of the floating-gate transistor 
25 from the rest of the circuit, while the floating-gate is 
programmed. 
Conventionally, floating-gate transistors may be directly 
programmed with a combination of hot-electron injection 
and Fowler-Nordheim tunneling, thereby permitting the 
30 floating-gate transistors to act as precise current sources. In 
order to permit programming of these floating-gate transis-
tors, however, T-gates are typically added to the circuit in 
order to permit the disconnection of each floating-gate 
transistor from the circuit during a programming phase and 
35 to permit the reconnection of the floating-gate transistor to 
the circuit during a run-time phase. The addition of a 2-to-l 
multiplexer for every floating-gate transistor to be pro-
grammed can be costly. The process of disconnecting the 
floating-gate transistor from the circuit may decrease the 
40 maximum speed of operation and the overall accuracy of the 
circuitry. Moreover, the addition of the 2-to-l multiplexers 
significantly increases the required die real-estate (e.g., 
silicon footprint) and necessary supply overhead. 
What is needed, therefore, is a system and method of 
45 effectively programming a floating-gate array, such as an 
FPAA crossbar switch network, utilizing programmable 
floating-gate switches, such that digital memory is not 
needed to store the state of the switch. Further, what is 
needed is a system and method for programming floating-
50 gate transistors on-chip to reduce programming delays, 
without compromising circuitry performance. Moreover, 
what is needed is a system and method of programming 
floating-gate transistors that does not require disconnection 
of the floating-gate transistors from the circuitry and that 
55 does not necessarily require the addition of a 2-to-l multi-
plexer for every floating-gate transistor to be programmed. 
It is to such systems and methods that the present invention 
is primarily directed. 
As the industry pushes toward shorter design cycles for 
analog integrated circuits, the need for an efficient and 60 
effective FPAA becomes paramount. Indeed, the role of 
analog integrated circuits in modern electronic systems 
remains important, even with the advent of digital circuits. 
Analog systems, for example, are often used to interface 
with digital electronics in applications such as biomedical 65 
measurements, industrial process control, and analog signal 
processing. More importantly, analog solutions may become 
BRIEF SUMMARY OF THE INVENTION 
Briefly described, the present invention comprises a float-
ing-gate transistor array and method for programming the 
same. The floating-gate transistor array includes a plurality 
of transistors having a source, drain, and floating-gate, 
whereby the plurality of transistors is arranged into multiple 
rows and columns. Each row of transistors includes a row 
US 7,269,046 B2 
3 
programming switch having an output for selecting the row, 
while each column of transistors includes a column pro-
gramming switch having an output for selecting the column. 
Each transistor is associated with a capacitor, such that a first 
terminal of the capacitor is coupled with the floating-gate 
and a second terminal of the capacitor is coupled with the 
output of a corresponding row programming switch. The 
drain of each transistor is coupled to the output of a 
corresponding column programming switch. Further, the 
source of each transistor is coupled with a source line 10 
corresponding to the specific row of the transistor. 
4 
These and other objects, features, and advantages of the 
present invention will become more apparent upon reading 
the following specification in conjunction with the accom-
panying drawings. 
BRIEF DESCRIPTION OF THE FIGURES 
FIG. 1 is a schematic diagram illustrating a field-pro-
grammable analog array (FPAA) crossbar switch network 
utilizing a floating-gate switch as a transmission element in 
accordance with an exemplary embodiment of the present 
invention. 
FIG. 2 is a schematic diagram illustrating a floating-gate 
pFET switch matrix in a crossbar configuration in accor-
15 dance with an exemplary embodiment of the present inven-
tion. 
The row programming switches are coupled to a ramp 
generator adapted to provide voltage pulses during selection 
and prograniming phases. The column prograniming 
switches are coupled to an external voltage source, which 
also assists in the selection and programming phases. In 
order to program a predetermined floating-gate transistor, it 
should first be selected. Selection begins by pulling up the 
source lines of all the transistors to the power supply. The 
drain lines of the transistors are also pulled up to V DD until 20 
selected for prograniming, at which time the drain line is 
connected to an external voltage source. The gate input lines 
FIG. 3 is a chart illustrating resistance measurements of a 
floating-gate switch for different levels of hot-electron injec-
tion in accordance with an exemplary embodiment of the 
present invention. 
FIG. 4 is a chart illustrating an empirical comparison of 
"on" resistance of three types of switch elements. 
FIG. 5 is a schematic diagram illustrating a typical routing 
scheme utilized in FPAA crossbar switches. 
FIG. 6 is a chart illustrating bandwidth measurements for 
a switch network using different routing lengths and cross-
bar configurations. 
of the transistors may be switched between an external 
potential and V DD depending upon the selection circuitry 
used for programming. Once the predetermined floating- 25 
gate transistor is selected, it may be programmed using 
hot-electron injection and tunneling. 
FIG. 7 is a chart illustrating drain current measurements 
of a floating-gate pFET during hot-electron injection in 
30 accordance with an exemplary embodiment of the present 
The present invention provides for programming a single 
floating-gate transistor, a whole row or column of floating-
gate transistors, or a subset of floating-gate transistors within 
a row or column. To select a single floating-gate transistor 
for programming, the row selection switch having an output 
coupled with the desired floating-gate transistor is activated. 
Also, the column selection switch having an output coupled 
with the desired floating-gate transistor is activated. The 35 
point where the output of the row selection switch intersects 
with the output of the columns selection switch is the 
location of the desired floating-gate transistor within the 
invention. 
FIG. 8 is a chart illustrating rate of injection measure-
ments for a floating-gate pFET in accordance with an 
exemplary embodiment of the present invention. 
FIGS. 9A-9D, collectively known as FIG. 9, are sche-
matic diagrams illustrating a prograniming structure for a 
floating-gate transistor utilizing direct and indirect program-
ming techniques in accordance with an exemplary embodi-
ment of the present invention. 
array. 
A complete row or column of floating-gate transistors 
may be selected for programming by activating the row 
selection switch or column selection switch corresponding 
to the row or column desired for programming. For example, 
if a row of floating-gate transistors is desired for selection, 
the corresponding row selection switch is activated. Simi-
larly, if a column of floating-gate transistors is desired for 
selection, the corresponding column selection switch is 
activated. 
A subset of floating-gate transistors within a row or 
column may be selected for programming by first activating 
the row selection switch or column selection switch corre-
sponding to the row or column including the subset of 
floating-gate transistors. Once the correct row or column is 
selected, then a row or column selection switch is activated 
for every intersection of the selected row or column that 
represents the location of a floating-gate transistor included 
in the subset. 
40 FIGS. lOA-lOD, collectively known as FIG. 10, are 
schematic diagrams and charts illustrating circuitry and 
measurements of floating-gate transistors, including a single 
floating-gate transistor, an array of floating-gate transistors, 
a measurement of threshold voltage during injection and 
45 tunneling, and a measurement of accurate prograniming 
with an array of floating-gate devices in accordance with an 
exemplary embodiment of the present invention. 
FIGS. llA-llF, collectively known as FIG. 11, are sche-
matic diagrams and charts illustrating various circuitry used 
50 for direct and indirect prograniming techniques and associ-
ated measurement data in accordance with an exemplary 
embodiment of the present invention. 
FIGS. 12A-12C, collectively known as FIG. 12, are charts 
illustrating various measurements of current for an indirectly 
55 programmed pFET in accordance with an exemplary 
embodiment of the present invention. 
FIGS. 13A-13F, collectively known as FIG. 13, are sche-
matic diagrams and charts illustrating circuitry used for 
indirectly prograniming an nFET using a programmer pFET, 
60 including various measurements of characteristics and accu-
racy, in accordance with an exemplary embodiment of the 
In another embodiment of the present invention, a float-
ing-gate transistor may be progranimed indirectly. In this 
indirect programming method, two transistors share a float-
ing gate allowing one to exist directly in a circuit, while the 
other is reserved for programming. The progranimer tran-
sistor may be programmed using hot-electron injection and 
tunneling. As the charge on the programmer transistor is 65 
modified, the current of the transistor connected to the 
circuit is also modified. 
present invention. 
FIGS. 14A-14B, collectively known as FIG. 14, are a 
schematic diagram and chart illustrating a pair of transistors 
sharing the same floating-gate and measurement of transistor 
drain sweeps in accordance with an exemplary embodiment 
of the present invention. 
US 7,269,046 B2 
5 
FIGS. 15A-15C, collectively known as FIG. 15, are a 
schematic diagram and charts illustrating circuitry and vari-
ous measurements for an indirectly programmed version of 
a capacitively coupled current conveyer in accordance with 
an exemplary embodiment of the present invention. 
FIG. 16 is a flow-chart diagram illustrating an indirect 
programming method used in tuning a circuit to a desired 
performance in accordance with an exemplary embodiment 
of the present invention. 
FIGS. 17A-17C, collectively known as FIG. 17, are a 
schematic diagram and charts illustrating circuitry and mea-
surements of run-time programming using indirectly pro-
grammed floating-gate transistors in accordance with an 
exemplary embodiment of the present invention. 
6 
nents needed to isolate each of the transistors. Obviously, for 
each programmable transistor used within a conventional 
FPAA crossbar switch network, a predetermined and sig-
nificant amount of space would be necessary on the chip for 
the multiple components. 
The present invention removes the isolation switch com-
ponents that would be coupled with each transistor and 
provides a single switch for each row and each column of an 
array, thereby greatly decreasing the amount of die space 
10 required to implement an FPAA crossbar switch network 
with programmable switches. Programming a particular 
transistor, a row or column of transistors, or a subset of 
transistors may be accomplished using the present invention 
through selection programming. 
FIGS. 18A-18B, collectively known as FIG. 18, are a 15 
flow-chart diagram illustrating a method of selecting and 
programming a transistor within an array in accordance with 
Further, the present invention provides an improved 
FPAA crossbar switch network system utilizing a floating-
gate, programmable switch as the transmission element, 
thereby making it possible to eliminate digital memory and 
resistance limitations, while maintaining a minimally sized 
an exemplary embodiment of the present invention. 
FIGS. 19A-19B, collectively known as FIG. 19, are a 
flow-chart diagram illustrating a method for indirectly pro-
gramming an operational transistor (nFET) by programming 
a programmer transistor (pFET) coupled with the opera-
tional transistor via a common floating-gate in accordance 
with an exemplary embodiment of the present invention. 
FIGS. 20A-20B, collectively known as FIG. 20, are a 
flow-chart diagram illustrating a method for indirectly pro-
gramming an operational transistor (pFET) by programming 
a programmer transistor (pFET) coupled with the opera-
tional transistor via a common floating-gate in accordance 
with an exemplary embodiment of the present invention. 
FIG. 21 is a flow-chart diagram illustrating a method of 
lowering programming and agent transistors to subthreshold 
for programming in accordance with an exemplary embodi-
ment of the present invention. 
DETAILED DESCRIPTION OF PREFERRED 
EMBODIMENTS 
20 switch element. A floating-gate transistor is a desirable 
switch element for use in a crossbar switch due to it having 
a resistance similar to that of a transmission gate, the 
capacitance of a single pass-PET, and requires no digital 
memory to store the state of the switch. As a result, a 
25 floating-gate FET crossbar network can achieve a higher 
bandwidth than a transmission gate based network. Addi-
tionally, the resulting floating-gate implementation has a 
smaller silicon footprint than an array of transmission gates 
with the necessary support structures. Moreover, the resis-
30 tance of the floating-gate switch may be adjusted by modu-
lating the input gate voltage during channel hot-electron 
injection. 
The switches described herein may be part of a floating-
gate transistor array 100 used as a crossbar network in 
35 FPAAs. The switches may include multiplexors or other 
suitable switching device. As illustrated in FIG. 1, the 
floating-gate transistor array 100 may comprise a plurality of 
transistors 103, such that each transistor 103 includes a 
source 106, a drain 109, and a floating-gate 112. Generally, Referring now in detail to the drawing figures, wherein 
like reference numerals represent like parts throughout the 
several views, FIG. 1 illustrates a field-programmable ana-
log array (FPAA) crossbar switch network utilizing a float-
ing-gate switch as a transmission element in accordance 
with an exemplary embodiment of the present invention. 
Traditionally, FPAAs are distinguished from one another by 45 
two basic components: a computational analog block 
(CAB), and an interconnect network. An FPAA's intercon-
nect structure is most commonly connected by MOS tran-
sistor switches driven by digital memory. If T-gates are not 
introduced, the range of passable signals within an FPAA is 50 
dramatically smaller than the range of the power supply, 
because of the non-linear resistance of the MOSFET. 
Although alternatives to pass-FETs exist to improve band-
width, such as Gm-C amplifiers, 4-transistor transconduc-
tors, and current conveyors, these alternatives often trade 55 
area for improved switch characteristics and still require 
physical memory for maintaining connectivity. 
40 the floating-gate transistor array 100 may be configured to 
include at least two rows and at least two columns of 
transistors 103, thereby forming a traditional array configu-
ration. Although FIG. 1 provides a floating-gate transistor 
array 100 having two columns of transistors 103 and two 
rows of transistors 103 (e.g., a 2x2 array of transistors 103), 
the present invention may include many additional rows and 
columns of transistors 103 or, alternatively, may include a 
two column, one row (2xl) or one column, two row (lx2) 
transistor configuration. Indeed, the dashed lines in FIG. 1 
indicate that the illustrated floating-gate transistor array 100 
is only a portion of a larger, more complete floating-gate 
transistor array 100. Accordingly, one skilled in the art will 
recognize that the present invention may be scaled to include 
many (e.g., millions) transistors 103. 
The floating-gate transistor array 100 may also include a 
plurality of row programming switches 115 and a plurality 
of column programming switches 118, such that a row 
programming switch 115 exists for each row of transistors 
103 within the floating-gate transistor array 100 and a 
column programming switch 118 exists for each column of 
transistors 103 within the floating-gate transistor array 100. 
Most conventional FPAA crossbar switch networks do not 
have programmable switches (i.e., adjustable conductance) 
and a significant amount of space is required for a memory 60 
element for each switch device within the network. Con-
ventional FPAA crossbar switch networks do not have 
programmable switches, because it would generally require 
that each transistor be surrounded with multiple switching 
components designed to isolate the transistor for program-
ming. As the number of programmable transistors within an 
array increases, so would the number of switching compo-
Each row programming switch 115 includes an output 121 
in communication with each transistor 103 of the corre-
sponding row. Similarly, each column programming switch 
65 118 includes an output 124 in communication with each 
transistor 103 of the corresponding column. More specifi-
cally, each drain 109 of each transistor 103 within a specific 
US 7,269,046 B2 
7 
column is coupled to the output 124 of the corresponding 
column programming switch 118. 
Further, the floating-gate transistor array 100 may include 
a plurality of capacitors 127, for coupling the floating-gate 
112 to the prograrmning selection switch. Each capacitor 
127 includes a first terminal 130 and a second terminal 133. 
The first terminal 130 of a capacitor 127 may be coupled 
with the floating-gate 112 of a corresponding transistor 103, 
while the second terminal 133 of the capacitor 127 may be 
coupled with the output 121 of the corresponding row 
programming switch 115. Accordingly, each floating-gate 
112 of each transistor 103 within a specific row may be in 
communication with the output 121 of the corresponding 
row prograrmning switch 115 via a capacitor 127. 
The floating-gate transistor array 100 may additionally 
include a plurality of source lines 136, such that a source line 
136 exists for each row of transistors 103. The source 106 of 
each transistor 103 within a specific row may be coupled to 
the corresponding source line 136, thereby connecting all of 
the sources 106 of the transistors 103 within a row. 
A ramp generator 142 adapted to provide a voltage pulse 
or ramp may be incorporated within the floating-gate tran-
sistor array 100. The ramp generator 142 includes an output 
145 that connects to the input of each row prograrmning 
switch 115. The voltage pulse provided by the ramp gen-
erator 142, therefore, may be provided to selected rows of 
transistors 103 within the floating-gate transistor array 100. 
The ramp provided by the ramp generator 142 may be 
utilized by the saturation programming method (as described 
more fully below) or sometimes by a rough prograrmning 
method used to move the device into a proper prograrmning 
range. Alternatively, an external ramp generator 142 may be 
used to supply a voltage pulse to the array 100. 
An external voltage source, such as the voltage applied to 
the drain 109 of the transistor 103 (i.e., VD), includes an 
output 139 coupled with the input of each column program-
ming switch 118. Providing a pulse to this output 139 line is 
the usual method of programming, when given a fixed 
source voltage 106 and gate voltage 121. Accordingly, the 
drain 109 for each transistor 103 may be pulled to the 
external voltage source for selection purposes during pro-
gramming (as described below). 
The present invention provides for programming a single 
floating-gate transistor 103, a whole row or column of 
floating-gate transistors 103, or a subset of floating-gate 
transistors 103 within a row or column. For exemplary 
purposes only, to select a single floating-gate transistor 103A 
for prograrmning (as shown in FIG. 1), the row selection 
switch 115B having an output 121B coupled with the desired 
floating-gate transistor 103A is activated. Also, the column 
selection switch 118A having an output 124A coupled with 
the desired floating-gate transistor 103A is activated. The 
point where the output 121A of the row selection switch 
1115B intersects with the output 124A of the columns 
selection switch 118A is the location of the desired floating-
gate transistor 103A within the array 100. 
In another example using FIG. 1, a complete row of 
floating-gate transistors 103C, 103D may be selected for 
programming by activating the row selection switch 115A 
corresponding to the row desired for prograrmning. Alter-
natively, a complete column of floating-gate transistors 
103B, 103D may be selected for prograrmning by activating 
the column selection switch 118B corresponding to the 
column desired for programming. 
8 
corresponding to the row or column including the subset of 
floating-gate transistors 103. This technique utilizes a com-
bination of the methods described above. Next, a row or 
column selection switch 115, 118 is activated for every 
intersection of the selected row or column that represents the 
location of a floating-gate transistor 103 included in the 
subset. 
FIG. 2 shows a floating-gate pFET switch matrix in a 
crossbar configuration utilizing a larger array (e.g., 4x7) 
10 than that of FIG. 1. Each node within the array represents a 
floating-gate pFET 103 that can be selected for program-
ming. Each column of floating-gate pFETs 103 share a 
common drain line 109, while each row of pFETs 103 share 
common gate 112 and source lines 106. The drain and source 
15 lines 109, 106 are not directly driven during "run" mode, 
unless explicitly connected to CAB components via the 
pFET switch elements. Accordingly, any signal driving the 
source or drain lines 106, 109 of the array are able to 
propagate through the crossbar switch, limited only by the 
20 parasitics of the switches. The gate inputs, shown as VG in 
FIG. 2, are all connected to a fixed potential in run mode. 
The state in which the charge on the floating-gate pFETs 
103 may be modified is referred to as the "programming" 
mode. FIGS. 18A-18B provide a flow-chart diagram illus-
25 trating a method for selecting a transistor 103 within the 
array for programming. In programming mode, all of the 
source lines 106 are pulled up to the power supply 1806 by 
a pFET, as shown in FIG. 2. The drain lines 109 are also 
pulled up to V DD 1809 by a pFET until selected for pro-
30 gramming. If it is determined at 1812 that the switch is 
desired for programming, then at 1818 the drain line 109 of 
the switch is connected to an external voltage source 139, 
such as the drain voltage VD· Next, at 1821, the gate input 
lines are also switched between an external potential (e.g., 
35 the gate voltage VG) and V DD' depending upon the selection 
circuitry used for programming. 
An important first step in injecting floating-gate pFET 
arrays is device isolation. At 1824, device isolation is 
achieved by driving only one pFET 103 at a time with both 
40 the source-drain voltage (V sD) and the source-gate voltage 
(V sG) necessary to turn the device "on". Next, at 1827, the 
transistor 103 of the selected switch may now be pro-
grammed using hot-electron injection. Given this architec-
ture, isolation may be maintained until the conduction level 
45 of any pFET 103 along the column exceeds that which can 
be shut-off by connecting the gate input voltage to V DD· 
In order for a device to serve as a viable element in a cross 
bar switch network, it should typically have at least two 
distinct states: an "on" and an "off" state. The ideal switch 
50 is characterized by an "on" state having zero impedance and 
an "off' state having infinite impedance. For practical 
switches, however, the "on" state is typically characterized 
by a small impedance between the switch terminals. In the 
"off' state, the switch has a very high impedance and ideally 
55 should not conduct. With respect to a switch implemented as 
a single MOS transistor, the source 106 and drain 109 of the 
transistor 103 are the switch terminals. As a result, a 
non-zero "on" resistance and a finite "off' resistance will 
occur. The quality of the switch is then determined by those 
60 resistances. For an ordinary MOS transistor, this limit is a 
result of the voltages that may be applied to the gate terminal 
of the device. A floating-gate transistor's switch quality, 
however, may be improved by adjusting the charge on the 
floating node. 
A subset of floating-gate transistors 103 within a row or 65 
column may be selected for programming by first activating 
the row selection switch 115 or column selection switch 118 
FIG. 3 provides a chart illustrating resistance measure-
ments of an exemplary floating-gate switch for different 
levels of hot-electron injection. One skilled in the art will 
US 7,269,046 B2 
9 
recognize that the resistance measurements may vary 
depending on the quality of the floating-gate switch and, 
therefore, the chart in FIG. 3 is used to provide a better 
understanding of the invention, without limiting the scope of 
the invention. Throughout this disclosure various charts and 
graphs are used to illustrate various attributes of the various 
exemplary embodiments. These charts and graphs are pro-
vided to help describe the theories underlying the present 
invention and to show sample results achieve by the exem-
plary embodiments. The charts and graphs are not intended 10 
to limit the present invention in any way. 
The "on" resistance of the switch may be varied by 
several orders of magnitude over the operating voltage of the 
system. For each curve, the V sD may be held fixed to 25 m V 
as the source 106 is swept from 25 m V to 3.3 V. The current 15 
flowing through the drain 109 may be recorded and used to 
calculate the resistance as R=V sdID. Each curve of FIG. 3 
represents a different injection level of the same floating-
gate pFET 103. The curve where the resistance is the lowest 
generally correlates to the highest level of injection. In order 20 
to quantify the movement of the resistance curve, the 
effective gate voltage may be approximated using the fol-
lowing ohmic transistor I-V relationship: 
(1) 
10 
line 109, 106 per switch may be calculated to be approxi-
mately 7 fF for an exemplary embodiment using the speci-
fied component value. When fully considering the capaci-
tance contributions affecting a routed signal, all of the 
parasitic capacitances touching the signal line should be 
summed. In the case of the crossbar switch network, the 
capacitance contribution for each column is the number of 
rows multiplied by the parasitic capacitance of a single 
switch. Accordingly, the capacitance of a row is simply the 
contribution of a single switch multiplied by the number of 
columns, which is the number of switches along the row. 
Based upon this, the floating-gate pFET switch networks 
should have significantly less parasitic capacitance than a 
transmission gate based network and therefore be able to 
achieve higher bandwidths. 
To better illustrate the effects of this parasitic capacitance, 
FIG. 5 provides a schematic diagram illustrating a conven-
tional routing scheme utilized in FPAA crossbar switches. 
Local connections to and from the same CAB 503 may 
generally be accomplished with a single pair of switches as 
illustrated in the upper left crossbar network of FIG. 5. 
Routing between CABs 503 is usually implemented through 
two pairs of switches, unless the CABs 503 are connected to 
The lowest resistance curve is associated with an effective 
gate voltage of nearly -3 V. The negative potential is 
significant in that it is outside the supply range of the chip. 
25 the same set of vertical global routing lines, in which a single 
pair of switches may suffice. 
FIG. 6 is a chart illustrating bandwidth measurements for 
an exemplary switch network using different routing lengths 
and crossbar configurations. More specifically, FIG. 6 illus-
30 trates the effects of the switch network dimensions and 
By achieving such a low effective gate voltage, the switch 
may be turned on much harder (e.g., with a high effective 
gate voltage) than is possible without injection. The basic 
principle defining the movement of the resistance curve is a 
gate modulation effect; as the pFET is injected more, the 
effective gate voltage decreases, which increases the tran-
sistor's 103 conductivity. A secondary effect observed on the 35 
resistance curve is the capacitive coupling of the source 106 
and drain 109 voltages back onto the floating-gate node 112. 
At low terminal voltages the effective gate voltage is low-
ered and at high terminal voltages the effective gate voltage 
routing distance, defined as the number of switch pairs in the 
signal path, upon the bandwidth of the network. Such a plot 
uses a lumped model to estimate the effective bandwidth of 
is increased. 
FIG. 4 provides an empirical comparison for the "on" 
resistance of three different switch elements: a pFET, a 
transmission gate, and a floating-gate pFET 103. One skilled 
in the art will recognize that the comparison for the "on" 
resistance of the three different switch elements is for 45 
exemplary purposes only and, therefore, the chart in FIG. 4 
provides a better understanding of the invention, without 
limiting the scope of the invention. 
the network given different routing scenarios. For expanded 
architectures with higher levels of routing, the routing 
distances greater than the expected 2 pairs of switches may 
be examined. For the given 0.5 µm process, the expected 
bandwidth stays in the megahertz range for most reasonable 
network dimensions and routing lengths. FIG. 6, however, 
40 
clearly shows that FPAAs with higher routing levels should 
have carefully constructed networks to limit the number of 
switches per signal line in order to balance connectivity with 
bandwidth. 
The pFET switch has the least desirable "on" resistance of 
the three devices, with the non-linear resistance inhibiting 50 
the passing of low-voltage signals. The floating-gate pFET 
103 has a resistance that is comparable to the transmission 
gate, accomplished by shifting the resistance curve to the left 
through injection. The coupling effects of the parasitic drain 
and source overlap capacitances may also be observed in 55 
FIG. 4. Accordingly, using the floating-gate pFET 103 as a 
switch element has a slightly higher resistance when passing 
higher voltages than the transmission gate. The change in 
resistance, however, over the operating voltage range is 
more consistent in the floating-gate pFET 103 than the 60 
transmission gate. Moreover, when placed in the "off' 
position, the floating-gate transistor has a resistance that 
exceeds a gigaohm. 
Hot-electron injection may be used to bias the switch into 
the "on" position. Referring again to FIG. 2, the transistors 
103 that make up the crossbar switch may have impedances 
located at the sources 106 and drains 109 resulting from the 
required transmission gates used to isolate a specific device 
during programming. 
The implication of those transmission gates is highlighted 
in the exemplary chart provided by FIG. 7. The chart 
illustrates drain current measurements of an exemplary 
floating-gate pFET during hot-electron injection. One 
skilled in the art will recognize that the data provided by 
FIG. 7 is for exemplary purposes only and, therefore, the 
chart in FIG. 7 is used to provide a better understanding of 
the invention, without limiting the scope of the invention. 
A single, isolated floating-gate pFET 103 may be injected 
over a period of about 40 seconds with a V sD of 5.5 V. This 
source-drain voltage (V sD) may be chosen to provide a 
measurable injection current. The device may be turmeled 
and then injected with a discrete 10 kQ resistor placed 
between the drain node and the voltage source for the drain A serious limitation to the bandwidth of an FPAA is the 
parasitic capacitance associated with the switching network. 
Based upon the architecture and layout of the crossbar 
network, the capacitance contribution to a drain or source 
65 109. The experiment may be repeated for a 20 kQ resistor. 
The introduction of resistors represents the possible worst 
case parasitic resistance due to a transmission gate. The 
US 7,269,046 B2 
11 
addition of resistors may result in a lower drain current, 
implying that the injection may be limited. From the injec-
tion equation, 
( 
ls )a 
fin) = linJO -
Isa 
(2) 
it is shown that the injection may be partly controlled by 
V sD· As the current through the drain 109 increases, the 
voltage dropped across the resistor increases. At 25 mA, the 
drop across the resistors is nearly 5% to 10% of the V sD 
voltage for the 10 kQ and 20 kQ resistors, respectively. With 
a 5% to 10% decrease in the V sD' the rate of injection is 
expected to decrease exponentially. 
By performing a numerical differentiation on the data 
from FIG. 7, the rate of injection may be determined. FIG. 
8 provides a chart illustrating rate of injection measurements 
for an exemplary floating-gate pFET. Again, the data in the 
chart is provided for understanding the invention, not lim-
iting the invention. Plotted against the drain current, the 
relationship between channel current and injection is clear; 
injection and the subsequent rate of injection are highly 
dependent on the channel current. 
The longer the device is injected, the more the channel 
current increases. In a situation where a high level of 
injection is desired, the channel current should constantly be 
reduced in order to facilitate continued injection at a desired 
rate. A convenient method of modulating the channel current 
is accomplished by moving the gate input voltage. Accord-
ingly, a floating-gate pFET 103 may be injected into the "on" 
state by increasing the gate input voltage over time, while 
providing the necessary V sD' thereby limiting the amount of 
current flowing through the channel. 
One of the major limitations of injection in the array 
structure is that in order to get the negative effective gate 
voltage necessary to reduce the switch resistance to the level 
of a transmission gate, isolation can not be maintained with 
the given architecture. If a switch has been programmed to 
an effective gate voltage of -3 V when selected, the dese-
lected device will have an effective gate voltage of approxi-
mately 0 V. This results in a V sG much greater than the 
threshold voltage of the device. Therefore, the switch can no 
longer be turned "off" by means of applying V DD to the 
floating-gate pFET's 103 input capacitor. Once a switch has 
been programmed to the "on" state, a fixed amount of 
current will flow through the shared drain line 109 even if 
the device is not selected. 
In order to achieve the routing necessary to implement the 
desired circuits, multiple switches need to be turned "on" in 
the same column. As already described, the transmission 
gates present in the array of floating-gate devices 103 have 
12 
interleaved injection method should be used as an approxi-
mation. For a given gate voltage, the first switch to be 
injected on a drain line 109 is injected for a short time, from 
tens to hundreds of microseconds. Then, the next switch in 
the colunm is selected and injected for the same short time 
span. Once all the switches have been exposed to the pulse 
injection, the gate voltage is raised by some amount, typi-
cally on the order of a millivolt, and the process is repeated. 
Because the injection time is short, the increase in current 
10 through the switch is small, resulting in a small change in the 
voltage drop across the resistor. Accordingly, all the 
switches being injected in the colunm see nearly the same 
V sD for a given gate voltage. 
To further simplify the circuitry of the FPAA crossbar 
15 switch network, while providing advantages in program-
ming, the present invention introduces a non-invasive 
method of programming (referred to herein as "indirect 
programming") a floating-gate transistor 103, which elimi-
nates the need for disconnection of the floating-gate tran-
20 sistor 103 from a circuit. One skilled in the art will recog-
nize, however, that the proposed method of indirect 
programming may be used in other circuitry configurations 
using floating-gate transistors 103 and, therefore, is not 
25 
limited to application with FPAA crossbar switch networks. 
Indirect programming provides runtime programming 
capabilities without the need for isolating the transistor 103 
from the circuit, thereby eliminating the need for isolation 
switches. Further, the operational transistor 103 may be free 
from any programming components, as all programming 
30 components are associated with the programmer transistor 
103, which is coupled to the operational transistor 103 via a 
common floating-gate 112. The present invention, therefore, 
provides for programming a particular transistor 103 without 
35 
stopping the flow of data on the operational circuitry. 
Indeed, indirect programming may greatly reduce the 
need for direct programming circuitry (e.g., 2-to-l multi-
plexers for every floating-gate to be programmed), thereby 
reducing the size of the silicon footprint necessary to imple-
ment the circuitry. As the transistor 103 does not need to be 
40 disconnected from the circuit during indirect programming, 
the switch count is reduced, resulting in fewer parasitics and 
better overall performance. The use of these indirectly 
programmed floating-gate transistors 103 allows a circuit to 
be tuned such that the effects of any device mismatch are 
45 substantially negated. Further, by using a variation of indi-
rect programming, a circuit may be recalibrated while it is 
still operating within the system (e.g., during run-time). 
The present invention also provides a unique method of 
programming the transistor 103 by utilizing saturation tech-
50 niques, instead of conventional pulse and measure method-
ology. Conventional hot-electron injection requires pulsing 
of the transistor 103 with a drain voltage for a short period 
of time and then measuring the programmed current to 
determine if the desired current has been reached. Such a a significant resistance which will limit the injection of a 
single switch. In the case of turning on a second switch in 55 
a column, the situation is exacerbated by the current that 
flows through the unselected switch already injected to the 
"on" state. Various I Cs have 100 µA to 200 µA of current that 
flow through an "on" switch that is unselected. The resulting 
drop in V sD may be on the order of a volt or more. As a 60 
result, switches should not be turned on sequentially in a 
colunm without isolation. 
process is slow and requires isolation of the transistor 103, 
thereby removing it from the operational circuitry. The 
present invention, however, uses the relationship between 
the gate voltage and the saturation point of the transistor 103 
to accurately program the desired current to the programmer 
transistor 103. As the programmer transistor 103 and the 
operational transistor 103 share a common floating-gate 112, 
the operational transistor 103 is also programmed to the 
desired current, automatically. Advantageously, the present 
invention allows for run-time programming of the opera-
In order to turn on multiple switches in a colunm and 
maintain the same "on" resistance across the switches, the 
pFETs 103 should be injected at the same time. In an 
exemplary embodiment of the present invention, the decoder 
structure limits selection to a single switch at a time, so an 
65 tional transistor 103 (indirectly) without the need to discon-
nect the transistor 103 from the operational circuitry, while 
additionally providing a rapid programming process. 
US 7,269,046 B2 
13 
FIGS. 9A-9D provide schematic diagrams illustrating a 
programming structure for a floating-gate transistor 103 
utilizing direct and indirect programming techniques. More 
specifically, FIG. 9A provides the programming structure of 
14 
lowers the threshold voltage. As n-channel devices (e.g., 
nFETs) in current IC proceseses use process-control param-
eters to reduce the injection of electrons, only p-channel 
devices (e.g., pFETs) are practical for floating-gate program-
ming during indirect programming, because pFETs have a 
higher injection efficiency. 
Generally, floating-gate transistors 103 may be arranged 
in an array 100, so that a large number of floating-gate 
devices may be programmed easily and selectively, as 
a pFET indirectly programming another pFET, FIG. 9B 
provides the programming structure of a pFET indirectly 
programming an nFET, FIG. 9C provides the conventional 
circuitry for directly programming a pFET, and FIG. 9D 
provides the conventional circuitry for directly program-
ming an nFET. Comparing FIGS. 9A with 9C and 9B with 
9D, an obvious reduction in T-gates is realized. 
To effectuate indirect programming, multiple MOSFETs 
may be coupled to a common floating gate 112, such that a 
first transistor 103 (MP) is connected to a programming 
structure, while the source 106 and drain 109 of a second 
transistor 103 (MJ are connected to a respective operational 
circuit, as shown in FIGS. 9A-9B. Generally, the first 
transistor 103 is programmed using hot-electron injection 
and tunneling. Through indirect programming, modification 
10 illustrated in FIG. lOB. Hot-electron injection allows for 
complete selectivity of an individual element and, therefore, 
may be used for precise and accurate programming of 
floating-gate arrays 100. Tunneling, however, does not eas-
ily provide for selectivity and is, consequently, reserved for 
15 globally "erasing" the charges stored on the floating gates 
112. 
of the charge on the floating-gate 112 and the current 20 
through the first transistor 103 (the "programmer") causes 
the charge on the floating-gate 112 and the current through 
the other transistor 103 (the "agent") to also be modified. 
In order to provide an overview of floating-gate transis-
tors 103, FIG. 10 provides a schematic of a single floating- 25 
gate transistor 103 (FIG. lOA), a schematic of an array of 
floating-gate transistors 103 (FIG. lOB), a chart of threshold 
voltage movement based on tunneling and hot-electron 
injection (FIG. lOC), and charts of the floating-gate position 
based on accurate programming with an array of floating- 30 
gate devices (FIG. lOD). One skilled in the art will recognize 
that the data provided in FIGS. lOC-D are for better under-
standing the invention, but not for limiting the invention. 
Each floating-gate transistor 103, as shown in FIG. lOA, 
may be a standard MOSFET device with only capacitors 127 35 
connected to the gate 112. The charge on the gate 112 is 
generally fixed and responsible for establishing the prede-
termined amount of current flowing through the transistor 
103, because the gate 112 is electrically isolated due to 
encapsulation by oxide. The charge on the gate 112 will not 40 
typically change on its own, but the charge may be modified 
by programming processes such as, but not limited to, 
ultraviolet photo injection, Fowler-Nordheim tunneling, and 
hot-electron injection. Primarily, indirect programming uti-
lizes Fowler-Nordheim tunneling and hot-electron injection 45 
for precisely setting the current of a floating-gate transistor 
103. 
In order to select a particular device in the array shown in 
FIG. lOB for hot-electron injection, all the drain lines 109 of 
the unselected rows are connected to V dd' while all gate lines 
of the unselected colunms are also connected to V dd· To 
program a single device, one would select the row and 
column of the desired device. To program more than one 
device, an entire row or colunm may be selected; an entire 
row and particular columns may be selected; or an entire 
column and particular rows may be selected. As illustrated 
in FIG. lOD, the use of this array programming scheme 
achieves a high-degree of programming accuracy. 
The use of hot-electron injection for programming, how-
ever, is not constant over all current ranges. To achieve the 
highest efficiency for hot-electron injection, the present 
invention provides for indirect programming using sub-
threshold currents. While injection of floating-gate transis-
tors 103 can be effective for above threshold current levels, 
hot-electron injection is more often effective when coupled 
with lower current levels (and hence reduced power con-
sumption). Although the present invention, as described 
below, focuses primarily on the operation of indirect pro-
gramming with subthreshold current levels, one skilled in 
the art will recognize that the same concepts may also be 
applied to above-threshold current levels. 
To provide a better understanding behind the motivation 
for indirect programming, the usefulness of indirect pro-
gramming should be examined. FIG. llA provides a sche-
matic diagram of floating-gate transistors 103 for offset 
removal in a current mirror. To allow complete disconnec-
tion during programming of each floating-gate transistor 103 
of FIG. llA, conventional direct programming techniques 
introduce many T-gate switches which add parasitic capaci-
tances and resistances. The resulting pFET floating-gate 
50 current mirror using direct programming is illustrated in 
FIG. llB. 
Using electron tunneling, for example, a large voltage is 
placed across a MOS capacitor. As the tunneling voltage is 
increased, the effective width of the barrier decreases, 
thereby permitting electrons to breach the gap without 
adversely affecting the insulator of the floating-gate transis-
tor 103. Consequently, tunneling may be used to remove 
electrons from the floating-gate transistor 103 in a controlled 
manner and, thus, raises the effective threshold voltage 55 
(referenced to V dd), as illustrated in FIG. lOC. 
Hot-electron injection, for example, may be used to add 
electrons to the floating-gate transistor 103 in a similarly 
controlled manner. For optimized hot-electron injection, an 
appreciable amount of current should be flowing through the 60 
device, whereby a large source-to-drain voltage is placed 
across the transistor 103. At this point, holes in a pFET 
flowing through the channel can build-up sufficiently large 
energy to ionize an electron-hole pair. The resulting electron 
may have enough energy to pass through the insulator and 65 
onto the floating-gate transistor 103, thereby increasing the 
number of electrons on the gate 112, which effectively 
The additional switches increase the required area and 
supply headroom, while concurrently degrading the opera-
tional performance of the current mirror. The increased 
complexity is clearly evident using conventional methods of 
programming, due to the numerous isolation switches 
needed for programming. Specifically, in order to break the 
floating-gate transistors 103 (FIG. llA) out of the mirror for 
conventional programming, additional resistances and 
capacitances must be introduced through the use of eight 
T-gates 1109. These additional resistances and capacitances 
seriously hamper the performance of the current mirror, 
especially at high frequencies. For programming purposes, 
the simple two-transistor current mirror becomes a complex 
18-transistor circuit. 
As illustrated in FIG. llC, the use of indirect programmed 
transistors greatly reduces the complexity of the circuitry for 
US 7,269,046 B2 
15 
the pFET floating-gate current mirror (as compared to direct 
programming) and, therefore, minimizes parasitics. Only a 
minimal amount of isolation switches need to be included. 
Further, the circuit may be implemented using only two 
cascading transistors 1112 and a single T-gate 1109, with the 
cascading transistors 1112 serving the dual purpose of 
isolating the floating-gate transistor 103 and enhancing the 
current response of the mirror. 
Implementation of an nFET floating-gate current mirror is 
virtually impossible using direct programming due to the 10 
process-control techniques that specifically work to avoid 
nFET injection in current IC processes. When an nFET is to 
be used as a precise current source with floating-gates, a 
pFET may be programmed with a current, which is then 
mirrored into the nFET current source, as shown in FIG. 9D. 15 
Creating a progranimable nFET current mirror with the 
direct method of prograniming, however, is not a simple 
task. 
16 
input to the output of a standard two-transistor current 
mirror is approximately 7-10% over a wide range of input 
currents. Such a degree of mismatch is not unexpected for 
small-sized transistors 
(_! = 2.4 µm). L 1.2µm 
In addition to normalizing the floating-gate charge for a 
unity-gain current mirror, the indirectly programmed float-
ing-gate current mirror allows the gain to be set after 
fabrication by programming different charges to the two 
floating nodes. As illustrated in FIG. llF, the programming 
of the current mirror to a variety of gains resulted in gains 
well within 1 % accuracy. While the current gain during 
saturation allows the indirectly programmed floating-gate 
current mirror to achieve unity gain over a wide range of Using indirect programming, however, the current mirror 
design is a simple design as illustrated by FIG. llD. Indeed, 
the process of programming an nFET is more explicit with 
indirect programming. The nFET current may be set by 
programming the pFET, because the nFET and pFET share 
the same floating gate 112. This technique permits the 
construction of a programmable nFET current mirror, as 
illustrated in FIG. llD, that is completely analogous to the 
pFET version shown in FIG. llC. The benefits of utilizing 
not only a floating-gate programmable current mirror, but 
also one using indirect prograniming are evident in FIGS. 
llE-llF. For exemplary purpose only, the data from these 
plots was obtained from an nFET version of the program-
mable current mirror. While data from a pFET version of an 
indirectly programmed current mirror has generally similar 
results, the nFET version, which was not previously capable 
of being built, is provided. Again, the data provided in FIGS. 
llE-llF are for understanding the invention, not for limiting 
the invention. 
20 current levels, this same relationship will only allow the 
current mirror to achieve the desired non-unity gains while 
both transistors 103 stay in the subthreshold range. If, 
however, a transistor 103 enters moderate or strong inver-
sion, then the exponential relationship of the current no 
25 longer holds and the gains will degrade from their pro-
grammed values. Accordingly, the baseline current for mea-
surement in FIG. 11 was a subthreshold current (1 nA). 
Indirect prograniming provides several distinct advan-
tages over conventional methods of programming. For 
30 example, and not limitation, indirect programming of float-
ing-gate transistors 103 allows nFET programming; 
decreases the number of poles/parasitic capacitances for 
faster operational speeds; decreases resistance; decreases 
minimum supply headroom; reduces transistor count (e.g., 
35 real estate on the chip); and permits run-time prograniming 
and calibration. 
Normalizing the charge on the two floating nodes in the 
current mirror allows the current mirror to perform very 
close to ideal, as shown by the results of FIG. llE. Using 40 
identically sized floating-gate transistors 103, the nFET 
version of an indirectly programmed floating-gate current 
mirror was constructed. By normalizing the charge on the 
two floating nodes, identical currents flow through both legs 
The most basic method of indirect programming uses 
hot-electron injection in the programmer pFET (MP) to set 
the current in the agent pFET (M0 ) and tunneling for erasing 
the current. The programmer pFET may be placed in a large 
floating-gate array 100, similar to that shown in FIG. lOB, 
where it may be selected and programmed. Assuming that 
the drain 109 and source 106 potentials of the programmer 
pFET and the agent pFET are similar, the output of the agent 
pFET may be a scaled version of the programmer pFET. 
Generally, scaling is caused by 
of the indirectly programmed floating-gate current mirror. In 45 
saturation, the subthreshold current flowing through a float-
ing-gate transistor 103 is given by 
(3) 50 
w 
L 
resulting in a current gain, I0 jI,n, of 
(4) 
ratios and any mismatch between the two devices. FIG. 12A 
shows the I-V characteristics for a gate sweep of both the 
55 programmer pFET and the agent pFET, which are identically 
sized devices 
lout 
fin foeKVFc,in/ur e-Vs/Ur ev d;v A 
assuming that the drains 109 are at similar potentials. In 
these subthreshold equations, Ur is the thermal voltage, K is 
the capacitive ratio coupling from the gate to the surface 
potential, and VA is the Early voltage. 
60 
As illustrated in FIG. llE, the gain may be made very 65 
close to unity by programming identical charges to the two 
floating nodes. Further, the percentage of error from the 
Typically, the agent current is unobservable, but by utilizing 
an isolated pFET-pFET pair that shares the same floating-
gate 112, certain characteristics may be observed. 
Unfortunately, assuming that the sources 106 and drains 
109 of the two transistors 103 are at similar potentials is not 
US 7,269,046 B2 
17 
always valid. Varying the source 106 potential of the agent 
pFET may generate different results, as shown in FIG. 12B. 
With both transistors 103 in the subthreshold regime, vary-
ing the programmer pFET current yields approximately a 
1: 1 change in the agent pFET current. The exact relationship 
is a ratio of the subthreshold slope, 
18 
increasing the nFET source 106 (referenced to bulk voltage 
V bulk) reduces the current in each transistor 103. Conse-
quently, threshold voltages are moved towards a point in 
which it is possible to operate both transistors 103 in 
subthreshold at the same time. FIG. 13B illustrates the 
pFET-to-nFET current relationship for each set of curves 
provided in FIG. 13A. Lowering the crossover point 
increases the linear range of the current-to-current ratio. A 
linear current-to-current relationship makes predicting the K 
Ur' 10 agent current trivial. Any reasonable current-to-current rela-
tionship (like curve 2 in FIG. 13B) allows accurate pro-
gramming of the nFET. 
The first method, described above, is not always possible, 
because the source 106 of the agent may not always be 
of the two transistors 103, which should be very closely 
matched due to their same orientation and close proximity in 
layout. 
In order to provide characteristics of indirect program-
ming, the charts of FIGS. 12A-12C illustrate various mea-
surements of current for an indirectly programmed pFET. 
One skilled in the art will recognize that the data provided 
is for understanding the invention, but not for limiting the 
scope of the invention. 
15 accessible or may be set to a given potential due to place-
ment within the circuit. Accordingly, a second method of the 
present invention ensures that both transistors 103 are in 
subthrehold by requiring that the programming pFET is in an 
accessible well isolated from the operational circuit. By 
20 raising the potential of the programmer's well and also 
lowering its source potential, the current flowing through the 
pFET is reduced. Using this procedure, the currents flowing 
through the nFET and pFET can be made to cross each other 
in the subthreshold regime. FIG. 13C shows the operation of 
Typically, only the programmer current is observable 
when programming the agent current to a desired value. 
Measurement of the programmer current, therefore, may be 
used to predict the current flowing through the agent. Using 
characterization curves, such as the ones shown in FIG. 12B 
(which account for the subthreshold slopes and the differ-
ences in current due to differing source 106 potentials), the 
agent current may be accurately programmed. Accordingly, 
the characterization curves may be used to set the program- 30 
mer current that will yield the desired agent current. 
25 this method for the worst case scenario in which the pFET 
is much larger than the nFET 
As illustrated in FIG. 12C, this technique may be used to 
accurately set the agent current within tolerance for two 
different values of the agent's source 106 potential. While 
achieving high precision on the actual programmed current 35 
in the agent is important, the ultimate goal of accurate 
programming is to achieve precise control over the operation 
of the overall circuit. 
As described above, an important advantage of indirect 
programming is that it provides a simple mechanism for 40 
programming an nFET, whereas low injection efficiency 
makes direct nFET programming difficult. In this embodi-
ment, a pFET and an nFET share a common floating gate 
112, as illustrated in FIG. 9B. 
In order to appreciate the advantages of programming an 45 
nFET, FIGS. 13A-13F provide schematic diagrams and 
charts that illustrate circuitry used for indirectly program-
ming an nFET using a programmer pFET, and various 
measurements of characteristics and accuracy. The I-V char-
acteristics of both the nFET and the pFET can be viewed in 50 
FIG. 13B. The current level at which both transistors 103 
have equal currents is generally very high when the tran-
sistors 103 are not properly sized (see FIG. 13C). 
Unlike the pFET-pFET embodiment, a direct relationship 
between the two transistors 103 is not easily obtained. A 55 
current-to-current relationship as provided in curve 1 of FIG. 
13B results when the two transistor currents are not in 
subthreshold simultaneously. More specifically, small 
changes in the pFET current result in large changes in the 
nFET current. Accordingly, restricting the operation to 60 
strictly subthreshold is desirable, because it linearizes the 
current-to-current ratio. 
Since the pFET is so much larger than the nFET, larger 
voltage differences from V dd should be used in this example 
to bring the currents to be simultaneously in subthreshold 
operation. Typically, a nearly minimum-sized programmer 
pFET would be used, and the voltage differences would not 
be as large, but, for illustrative purposes, this operation is 
still possible under the worst-case scenario. 
Described more fully below, the movement of the nFET's 
current is due to capacitive coupling onto the floating gate 
112. In this example, the movement is maximized due to the 
large size of the pFET. Additionally, the change in the 
subthreshold slope, as seen in FIG. 13, is another result of 
the pFET's large size and would be minimized for smaller 
transistor sizes. 
Either of the presented methods may be used to accurately 
program a current in the nFET. By keeping both transistors 
103 in subthreshold and measuring the pFET's current, the 
linear relationship of either FIG. 13E or FIG. 13F may be 
used to predict the nFET's current. Further, FIG. 13D 
illustrates an example of accurately programming a current 
in the nFET where only the pFET's current is observable 
during the programming routine. 
The difference between source potentials of the program-
ming pFET and the agent transistor need to be taken into 
account when programming, so that the correct current flows 
through the agent. The drain potentials of the two transistors 
103 are also of concern, especially the drain 109 of the 
agent, because the operation of its connected circuit can 
affect the potential at the drain 109. All transient coupling 
effects may be eliminated by holding constant the terminals 
of the programmer pFET when not programming. In accordance with the present invention, two methods 
may be used to ensure that both transistors 103 are simul-
taneously in the subthreshold regime. A first method requires 
moving the sources 106 of both transistors 103. Decreasing 
the pFET source 106 (referenced to well voltage V well) and 
In order to introduce capacitive coupling with indirect 
65 programming, FIG. 14A provides a schematic of a pair of 
transistors 103 sharing the same floating gate and the 
parasitic capacitances that allow coupling of voltages onto 
US 7,269,046 B2 
19 
the floating node. FIG. 14B provides a chart illustrating 
transistor drain sweeps with regard to subthreshold current 
flowing through a pFET, a floating-gate pFET, a cascaded 
floating-gate pFET, and a larger input capacitance. Typi-
cally, the voltage on any floating-gate node may be set by a 
combination of the floating-gate charge and a sum of the 
inputs to the gate through capacitive dividers. The extension 
of the floating-gate voltage for indirect programming is 
depicted in FIG. 14A and described by 
Vpc = (5) 
Qpc Cin Ctun Cgd,p Cgs,p Cgw,p Cr + Cr Vg +Cr V1un + 0 Vd.p + 0 V,.p + 0 Vw.p + 
Cox,p ,/, + Cgd,a V + Cgs,a V + Cgb,a V + Cox,a ,/, 
Cr 'Pp Cr d,a Cr s,a Cr b,a Cr 'Pa 
20 
With typical capacitance values, the effective Early voltages 
for floating-gate transistors 103 may easily fall into the 
range of IV, much like the floating-gate transistors 103 
shown in FIG. 14B. 
If supply headroom issues are important, then the drain-
coupling effect may be minimized by increasing the input 
gate capacitance. Increasing C,n increases Cn thereby reduc-
ing the effects of coupling through the parasitic capaci-
tances, such as Cgd.a· While the saturation current still has an 
10 exponential increase with drain potential, the effective Early 
voltage is increased, as is shown in FIG. 14B. Alternatively, 
if supply headroom issues are not a concern, then the 
drain-coupling effect may be completely removed by adding 
a cascade transistor 1112 at the drain 109 of the agent. The 
15 saturation current received by the circuit is flatter than even 
a standard transistor 103, as is shown in FIG. 14B. 
Coupling through the gate-to-drain capacitances is not the 
where Cr is the total capacitance connected to the floating- 20 
gate node, the p and a subscripts indicate the programmer 
and the agent, and 1jJ represents the surface potential of each 
transistor 103 (constant 1jJ in subthreshold). The drain 109 of 
the transistor 103 acts as an input to the gate, because cgd.a 25 
is a small parasitic capacitance. As illustrated in FIG. 14B, 
the subthreshold current flowing through the device changes 
exponentially as the drain voltage of the agent is swept. This 
only source of coupling into the floating node. In fact, all the 
terminals affect the drain currents of the two transistors 103 
to varying degrees by coupling into the floating node, as was 
shown in equation (5). These varying degrees depend on 
both the total capacitance, Cn connected to the floating-gate 
112 and also the size of the capacitor 127 through which the 
voltage couples, which is typically a small parasitic capaci-
tance. Increasing Cr decreases the capacitive coupling 
affects, as does decreasing the parasitic capacitances through 
which the coupling takes place. For example, simply 
increasing the drawn c,n and using a minimum-sized tran-
sistor 103 will reduce the effect of the overlap capacitance, 
is a significant alteration from the small slope due to the 
Early voltage of an identically sized transistor 103. 
In essence, this drain coupling of the agent can be viewed 
as reducing the effective Early voltage, which is undesirable 
if using the transistor 103 as a current source. By rewriting 
equation (5) as 
(6) 
where voffeet represents all the other terms in equation (5), 
replacing the gate term in the subthreshold equation (3) with 
equation (6), and dropping the a subscript for the agent, the 
saturation current becomes 
(7) 
Rearranging, this expression takes the form 
30 
Cgd' coupling into the floating gate 112. For this reason, 
when programming an nFET-pFET pair and altering the 
pFET's source and well potentials, these voltages alter the 
charge on the floating node. This is the reason that the 
nFET's curve shifts, as shown in FIG. 13C, because the 
35 pFET is a large device, and the parasitic capacitances 
between the gate and source 106 and the gate and well are 
comparable to Cr. Consequently, nearly minimum-sized 
40 
programmer pFETs should be used when using an nFET-
pFET pair to reduce the parasitic capacitances. 
The change in the subthreshold slope when modifying the 
pFET's source 106 and well potentials provides another 
reason for making the programmer pFET small in an nFET-
pFET pair. The parasitic capacitances of a transistor 103 are 
45 different depending on which mode of operation the tran-
sistor 103 is in (subthreshold or above threshold). To mini-
mize the changes in the coupling affects between modes of 
operation, the transistors 103 should be made small so that 
the input capacitance, c,m dominates the total capacitance, 
50 Cr 
An indirectly programmed transistor 103 may accurately 
bias a current although the direct current operating point of 
the agent transistor 103 is not known and the drain current 
has an exponential dependence upon all of its terminals. This 
I= 
(SJ 55 is true even if no cascade is used to protect the drain terminal 
109. The overall operation of the circuit may be tuned so 
precisely using indirect programming that the effects of 
device mismatches may be negated, even though the current 
through the agent transistor 103 is unobservable. 
The effective Early voltage is thus 
60 To show the versatility of indirect progrannning, FIGS. 
15A-15C provide a schematic diagram and charts illustrat-
ing circuitry and various measurements for an indirectly 
programmed version of a capacitively coupled current con-
(9) veyer (C4 ) 1503. Using the exemplary circuit shown in FIG. 
65 15A, the C4 1503, which is a bandpass filter typically used 
in audio applications, serves as a helpful example of indirect 
programming, because the two corner frequencies are each 
US 7,269,046 B2 
21 
set solely by the current flowing through a single transistor 
103, where one should be an nFET and the other a pFET. 
Generally, the C4 1503 is a capacitively based bandpass 
filter with electronically tunable comer frequencies that are 
independent of each other. The frequency response of the C4 
1503 is given by 
(10) 10 
22 
(12) 
where Kp.effis the effective coupling onto the surface poten-
tial including the input capacitor, C,n. Assuming ideal values 
for the capacitors 127 and Kp.eff' an initial current may be 
programmed into the programmer pFET, such that the 
resulting comer frequency should be the target value. The 
actual programmed corner frequency does not fall within 
tolerance of the target value, because the idealized values are 
not the actual values and the drain 109 of the agent is not the 
where the time constants are 
(11) 
15 same as that of the programmer. The function relating the 
corner frequency and the current, however, only involves a 
single coefficient, because the currents are remaining in 
subthreshold and equation (12) applies. 
By equating all the coefficients of the programmed current 
20 into a single coefficient, equation (12) becomes 
(13) 
As the progrannned current and the circuit output (e.g., the 
corner frequency) are known, the true value for Khigh may be 
25 calculated. Now, 
and a high-frequency zero, which occurs at sufficiently 
high-frequencies, has been neglected. The total capacitance, 
Cn and the output capacitance, C0 , are defined as Cr=C1 + 
C2 +Cwand C 0 =C2 +CL. The currents I,,h and I,,1 are the bias 
currents through the pFET and nFET agents, respectively, as 30 
shown in FIG. 15A. In consequence, the current flowing 
through a pFET alone controls the high corner frequency, 
and the current flowing through an nFET alone controls the 
low comer frequency. As a result, the C4 1503 is a good 
35 
circuit example for showing the proper progrannning pro-
cedure, because the filter's operation is directly affected by 
both a pFET and an nFET. Progrannning a C4 1503 to have 
precisely tuned time constants requires finding an estimate 
of the effective mismatch of the devices involved in each 40 
time constant. 
Progrannning an agent pFET to yield a desired circuit 
performance is a straightforward procedure. The method 
involves two steps in which a current is programmed into the 45 
pFET, and the effects of mismatch are then calibrated out. 
(14) 
where all the device parameters represent their actual values, 
and knc represents the shift in the bias current between the 
agent and the progrannner due to differences in the direct 
current operating point. By using equation (13) with the 
measured value ofKhigh' a second programming step may be 
used to produce the desired comer frequency. 
As illustrated in FIG. 15B, the high-degree of accuracy of 
the indirect programming method is clear for the exemplary 
programming of the C4 's 1503 high comer frequency. The 
crosshairs indicate the location of the ideal -3 dB frequency. 
Further improvements in accuracy may be achieved by 
improving the accuracy of the floating-gate progrannning 
algorithm. 
Progrannning an nFET agent (instead of a pFET agent) 
generally requires a slightly different methodology. The 
current through an nFET agent follows an inverse relation-
ship to the current through its progrannner pFET and, 
therefore, programming a precise current in a pFET-nFET 
50 case is more complicated than the pFET-pFET case. A high 
degree of characterization of the nFET-pFET combination 
will ease the programming procedure. This characterization, 
however, is not required and, through the following 
example, accuracy may be achieved even when an exact 
First, the programmer pFET is initially programmed to the 
current that should yield correct circuit performance of all 
devices. An initial current is programmed into the program-
mer pFET using the designed values and a rubric for the 
correct circuit operation. Unfortunately, the actual perfor-
mance of the circuit will not equal the idealized perfor-
mance, because the direct current operating point of the 
agent will likely differ from the programmer. Nevertheless, 
once the programmed current and the resulting circuit per-
formance are known, the function relating the two may be 
calculated. This function incorporates both the deviations 
from the ideal device parameters and also the difference in 
direct current operating points of the programmer and agent. 60 
Accordingly, the circuit may be reprogrammed to any 
desired performance. 
55 relationship between the nFET and pFET is not initially 
known. 
Using the example of the C4 1503, the pFET agent 
exclusively controls the high comer frequency. The rubric 65 
for knowing correct circuit operation is thus the placement 
of the high corner frequency, which is given by 
The method begins by programming an initial current into 
the programmer pFET that will translate as closely as 
possible to an nFET agent current that will yield the desired 
circuit operation. The translation from programmer current 
to agent current may be estimated by a characterization 
nFET-pFET pair on the periphery of the die area or even by 
simulation. A circuit measurement may be taken to deter-
mine the deviation from the ideal performance. Such a 
deviation is generally due to deviations in parameter sizes 
and values, as well as differences in the agent current from 
the expected value. 
US 7,269,046 B2 
23 
Whereas simply finding the estimate of the device and 
current mismatch for a given parameter was sufficient for the 
pFET-pFET case, this method is no longer sufficient for the 
nFET-pFET case. Placing both the programmer and agent 
transistors 103 into subthreshold simultaneously greatly 
eases the programming procedure, because the relationship 
24 
Then, letting m represent the slope of FIG. 13F and using the 
ratios of equation (18), the slope is given by 
(19) 
ln(/n2J - ln(/n1J 
m=-----
is linearized (on a logarithmic scale), as is shown in FIG. 
13E-13F. Generally, two calibration steps are required to 
accurately program an nFET. The first calibration step 
allows the effective mismatch to be found, and the second 10 
step allows the slope of the relationship between the pro-
grammer and the agent to be determined. After performing 
the two calibration steps, the current may be programmed so 
that the circuit accurately performs the desired action. 
ln(/ p2) - ln(/ pl) 
Now, letting k represent the programming iteration number, 
the slope may be written as 
Again, using the C4 1503 as a circuit example, the low 15 
corner frequency is of interest, because the low corner 
frequency of the C4 1503 requires only the current through 
the nFET agent to be modified. The low corner frequency is 
given by 
(20) 
20 
where knowledge of only the programmer currents and 
(15) resulting corner frequencies are required. By rewriting equa-
tion (20) and letting fk+l represent the desired corner fre-
quency, the exact current that should be programmed into 
25 the programmer is given by 
Using an estimate for the nFET agent's current and the ideal 
values for the device parameters, a current may be pro-
grammed such that the low comer frequency should hit its 
target. The actual comer frequency, however, will likely 
deviate from the desired value due to both device mismatch 30 
and the difference from the desired nFET current. The actual 
=I (fk+!)!/m lp.k+! p.k j, . 
(21) 
Thus, in three steps, the relationship between the nFET and 
pFET has been determined, the effects of mismatch have 
been calibrated out, and the circuit has been programmed to 
the desired comer frequency. 
corner frequency will have a value of 
(16) 35 
The results from using this programming procedure to 
program C4 's 1503 low comer frequency are illustrated in 
FIG. 15B. On the third iteration, the comer frequency fell 
well within the tolerance of the programming algorithm, as 
where f1 is the initial measured corner frequency, K1ow is the 
estimated multiplicative coefficient, and In 1 is the unknown 
and unobservable agent current. 
In addition to the unknown agent current, the relationship 
between the programmer and agent currents is also not yet 
known. An alternative way of viewing this problem is that 
the slope of the curve in FIG. 13F is not known, even when 
assuming subthreshold operation. A second current should 
be programmed into the programmer using equation (16), 
such that 
40 is indicated with the ideal -3 dB point depicted with the 
crosshairs. Again, this percentage error may be improved 
even further by increasing the accuracy of the programming 
algorithm. 
While the C4 1503 served as a good example of indirectly 
45 programming a circuit for precise operation criteria, the C4 
1503 is by no means an exclusive case. In fact, this indirect 
programming method may be applied to a wide variety of 
circuits, and it may be viewed in its generalized form to be 
as that described in the flow diagram of FIG. 16. 
(17) 50 FIG. 16 is a flow-chart diagram illustrating an indirect 
programming method 1600 used in tuning a circuit to a 
desired performance. In all cases, the circuit should be 
initially programmed 1603 so that it would perform per-
fectly, if all device parameters were ideal. Some circuit 
where In2 is the agent current and f2 is the resulting comer 
frequency. This new comer frequency, however, will likely 
not fall within tolerance because the exact value ofln2 is not 
observable. 
Nevertheless, there is now enough information to pro-
gram the circuit accurately on a third iteration, and this is 
done by finding the slope of FIG. 13F, assuming subthresh-
old operation. To find this slope, equation (16) is divided 
through by equation (17), resulting in 
(18) 
55 measurement 1606 should then be taken, be it a frequency 
response, a step response, etc., to determine how far the 
circuit's performance was from ideal. If at any time, this 
circuit operates within system tolerance 1609, then no more 
steps are needed 1612. The initial program, however, will 
60 not likely produce the desired results, but it may be used to 
extract certain parameters 1615 about the circuit's operation. 
These parameters may include a variety of contributions, 
including capacitor sizes and transistor currents. These 
extracted parameters may then be used to reprogram the 
65 circuit 1618, and the circuit is then tested 1606 again to 
determine whether or not it operates within the desired 
tolerances. 
US 7,269,046 B2 
25 26 
This process, as shown in FIG. 16, may be repeated as 
many times as necessary. Typically, only a single time 
through the process is required for programming a pFET, 
because both the programmer and the agent follow the same 
current trends. A second iteration through the process is 
likely required for indirectly programming nFETs, because 
not only device parameters should be determined, but also 
the exact relationship between the currents in the nFET 
agent and the pFET programmer. Keeping both the agent 
and the programmer in subthreshold simultaneously aids this 10 
procedure, because the relationship is linearized, as is shown 
changes in its environment (e.g., temperature) or new desires 
of the circuit's user (e.g., changing the gain of a certain band 
of frequencies in a hearing aid). Run-time programming, 
unlike adaptation techniques, allows programming to be 
turned on temporarily whenever recalibration is desired. 
While typical methods of programming floating-gate tran-
sistors 103 would work even in this run-time programming, 
these methods are not ideal since they involve large, instan-
taneous movements of the transistor's terminal voltages in 
order to cause injection to occur. These conventional meth-
ods of programming may cause large instantaneous changes 
in FIGS. 13E-13F. 
In addition to the ability to program out mismatches in a 
circuit and set precise current sources, which are both 
advantages available with floating-gate circuits and direct 
programming methods, the non-invasive nature of indirect 
programming has several benefits over traditional floating-
gate programming methods. These benefits are largely 
related to the removal of the transmission gates that are 
needed for disconnecting floating-gate transistors for a pro-
gramming phase (as used with direct programming meth-
ods). 
The addition of at least one T-gate 1109 for every floating-
gate transistor 103, and often more T-gates 1109 for certain 
circuit configurations, adds both resistance and capacitance 
to the floating-gate circuit. The added resistance and capaci-
tance may have several harmful effects, by introducing 
parasitics to the circuit. These extra parasitics slow down the 
operation of the circuit and, thus, limit the speed at which the 
circuit can operate. Also, when using large currents in the 
floating-gate transistors 103, the added resistance, which is 
approximately 10 kQ for small devices, will cause a sig-
nificant voltage drop to form across the switch. The voltage 
drop may cause problems with the operation of the circuit 
and it could be large enough to alter the required voltage 
headroom of the circuit. Thus, the circuit would have to run 
on a larger supply voltage. 
in the agent's current that could seriously alter the operation 
of the circuit, because, with the indirect programming con-
figuration, the programmer and the agent share the same 
15 floating-gate node 112 and the movements on the program-
mer's terminals capacitively couple onto the floating-gate 
node 112. Therefore, when recalibrating a circuit while it is 
still operating, care should be taken so that the operation of 
the circuit will not be temporarily rendered useless (and thus 
20 negating the benefits of using of run-time programming). 
To recalibrate a floating-gate agent in run-time operation 
using injection, the actual charge on the floating node should 
remain unaltered by any process except for injection There-
fore, any voltages that couple onto the floating node should 
25 always be balanced by an equal voltage coupling onto the 
floating node in the opposite direction. Referring back to 
equation (5) and FIG. 14A, if one terminal of the program-
mer is moved, then another terminal should also be moved 
in the opposite direction such that the two voltages couple 
30 identical, but opposite amounts. The current flowing through 
the agent will thus not be moved at all. By pulling the source 
106 and drain 109 apart "symmetrically" about V FG' the 
source-to-drain potential is increased until the point at which 
injection occurs. When injection occurs, the charge on the 
35 floating node 112 is altered, and the current flowing through 
the agent is modified (increased for a pFET and decreased 
for an nFET). When the current flowing through the agent 
has reached the desired value, then the injection can be 
turned off by returning the source and drain potentials to 
By using indirect programming many of the parasitics are 
removed, because indirect programming of floating-gate 
transistors 103 does not require the disconnection via T-gate 
switches 1109. Indirectly programmed floating-gate circuits 
have the ability to operate at higher frequencies than do 
directly programmed floating-gate circuits. The increase in 
speed with indirectly programmed floating-gate transistors 
103 was demonstrated with an indirectly programmed float- 45 
ing-gate inverter using an ad hoc programming method. 
Moreover, this indirectly programmed floating-gate inverter 
was able to operate at faster speeds than an identically sized 
inverter not utilizing floating-gates 112. Furthermore, the 
removal of the selection switches removes the added resis- 50 
40 their normal operating values. FIG. 17A shows the operation 
of injecting the current to the desired value with this process. 
The small discontinuities in the current levels at the onset 
and termination of injection are a result of parasitic-capaci-
tance estimates not being perfectly calibrated. Additionally, 
the larger jump at the termination of injection is a result of 
the higher current levels (near or above threshold) and the 
resulting changes in capacitor values, because the parasitic 
capacitances have different values when the transistor 103 is 
operating in either subthreshold or above threshold. These 
discontinuities can be accounted for, and, thus, injection 
may be turned off in anticipation that the final current will tance. Circuit applications requiring very low supply volt-
ages may now utilize the programmability of floating-gate 
transistors 103 without concerns of headroom loss due to 
parasitic resistances. 
FIGS. 17A-17C provide a schematic diagram and charts 
illustrating circuitry and measurements of run-time pro-
gramming using indirectly programmed floating-gate tran-
sistors in accordance with an exemplary embodiment of the 
present invention. As the use of indirect programming does 
not require disconnection of the agent transistor 103 from 
the circuit, there is now no need for a separate programming 
phase to set the charge on the floating-gate nodes. In fact, 
programming can occur during normal operation of the 
circuit so that data acquisition does not need to be stopped 
in order to reprogram the device. The ability to provide for 
"run-time programming," allows a circuit to be recalibrated 
while it is still operating, so that the circuit can respond to 
be the desired value. These discontinuities may also be 
calibrated out and compensated. 
To test the operation of run-time programming within a 
55 circuit, the exemplary circuit of FIG. 17B illustrates that by 
viewing the output of the circuit, the operation of the circuit 
may be recalibrated by using run-time programming. This 
circuit is simply a Gm -C element 1703 constructed to act as 
a first-order lowpass filter in which the time constant is set 
60 by an indirectly programmed transistor 103. The Gm element 
is a five-transistor operational transconductance amplifier 
(OTA) in which the bias current is set with an indirectly 
programmed floating-gate transistor 103. 
To illustrate how run-time programming may be used 
65 with the exemplary circuit, the corner frequency of the filter 
is programmed to below 10 Hz. Without stopping the 
operation of the circuit, it is desired in this example to move 
US 7,269,046 B2 
27 
the comer frequency to exactly 400 Hz. Accordingly, the 
output of the filter is examined as injection is applied to the 
programmer pFET. When the circuit is observed to be 
operating at the desired corner frequency (e.g., 400 Hz), 
injection is removed. FIG. 17 shows frequency responses 
before and after the run-time programming as well as the 
observed output of the circuit while injection was occurring. 
The final output of the filter reflects the desired comer 
frequency. 
The run-time method to programming floating-gate tran- 10 
sistors 103 has promising new possibilities for circuits 
needing frequent updates due to environmental changes and 
consumer needs. Additionally, a circuit using a similar 
approach may be used for adaptive applications by continu-
ously updating the stored charge on the floating gate node. 15 
FIGS. 19A-19B provide a flow-chart diagram that sum-
marizes the method of indirectly programming an opera-
tional transistor 103 (nFET) by using a programmer tran-
sistor 103 (pFET). In a pFET-nFET configuration the 
method 1900 begins at 1906 by first lowering the currents 
through the agent transistor 103 and programmer transistor 20 
103 to the subthreshold regime. At 1909, a determination is 
made as to whether the desired current is higher than the 
present current of the programmer transistor 103. If at 1909 
a determination is made that the desired current is higher 
than the present current, then the method 1900 proceeds to 25 
1918 described below. 
28 
If, however, at 2012 a determination is made that the 
desired current is higher than the present current, then the 
method 2000 proceeds to 2021 where tunneling is used on 
the program transistor 103 until the desired current is 
reached. Next, at 2024, the agent transistor 103 is automati-
cally programmed with the desired current, as the agent 
transistor 103 and the programmer transistor share a com-
mon floating-gate 112, The method 2000 then terminates 
after successful indirect programming of the agent transistor 
103. 
At 2018, hot-electron injection is used on the programmer 
transistor until the desired current is reached. The method 
2000 then proceeds to 2024 where the agent transistor 103, 
as described above, is automatically programmed with the 
desired current. 
FIG. 21 provides a flow-chart diagram that summarizes 
the method of lowering the agent transistor 103 and pro-
grammer transistor 103 to subthreshold. The method 2100 
starts at 2109 where a determination is made as to whether 
the source 106 of the agent transistor 103 is accessible. If, at 
2109, a determination is made that the source 106 of the 
agent transistor 103 is not accessible, then the method 2100 
proceeds to 2112 where the well potential of the programmer 
transistor 103 is raised. Next, at 2115, the source potential of 
the programmer transistor 103 is lowered. The method 2100 
then terminates when subthreshold is achieved for the agent 
and programmer transistors 103. 
If, however, at 2109 a determination is made that the 
source of the agent transistor 103 is accessible, then the 
method 2100 proceeds to 2121 where the source 106 of the 
If, however, at 1909 a determination is made that the 
desired current is not higher than the present current, then at 
1912 a determination is made as to whether the desire 
current is lower than the present current. If at 1912 a 
determination is made that the desired current is not lower 
than the present current, then the method 1900 terminates 
operation, because the present current is equal to the desired 
current. 
30 programmer transistor 103 is decreased with respect to well 
voltage (V well). Next, at 2124, the source of the agent 
transistor 103 is increased with respect to bulk voltage 
CV bulk), where at 2127 the channel currents are adjusted to 
subthreshold, thereby creating a linear current-to-current 
relationship between the programmer and agent transistors 
35 103. The method 2100 then terminates as subthreshold has 
been achieved. 
If, however, at 1912 a determination is made that the 
desired current is lower than the present current, then the 
method 1900 proceeds to 1921 where tunneling is used on 
the program transistor 103 until the desired current is 
reached. Next, at 1924, the agent transistor 103 is automati-
cally programmed with the desired current, as the agent 
transistor 103 and the programmer transistor share a com- 40 
mon floating-gate 112. The method 1900 then terminates 
after successful indirect programming of the agent transistor 
103. 
At 1918, hot-electron injection is used on the programmer 
transistor until the desired current is reached. The method 
1900 then proceeds to 1924 where the agent transistor 103, 
as described above, is automatically programmed with the 
desired current. 
FIGS. 20A-20B provide a flow-chart diagram that sum-
marizes the method of indirectly programming an opera-
tional transistor 103 (pFET) by using a programmer tran-
sistor 103 (pFET-pFET). In a pFET-pFET configuration the 
method 2000 begins at 2006 by first lowering the currents 
through the agent transistor 103 and programmer transistor 
103 to the subthreshold regime. At 2009, a determination is 
made as to whether the desired current is lower than the 
present current of the programmer transistor 103. If at 2009 
a determination is made that the desired current is lower than 
the present current, then the method 2000 proceeds to 2018 
described below. 
If, however, at 2009 a determination is made that the 
desired current is not lower than the present current, then at 
2012 a determination is made as to whether the desire 
current is higher than the present current. If at 2012 a 
determination is made that the desired current is not higher 
than the present current, then the method 2000 terminates 
operation, because the present current is equal to the desired 
current. 
The present invention demonstrates that a floating-gate 
pFET 103 may be used as a viable switch element in a 
crossbar network. The floating-gate pFETs 103 are capable 
of transmission-gate resistance levels with a capacitance on 
the order of a single pass-PET. As a result, switch networks 
using floating-gate pFETs 103 may have a significant band-
width advantage over traditional transmission gate architec-
tures. The present invention also removes the isolation 
45 switch components generally coupled with each transistor 
103 and provides a single switch for each row and each 
column of an array, thereby greatly decreasing the amount of 
die space required to implement the FPAA crossbar switch 
network. Programming a particular transistor 103, a row or 
50 column of transistors 103, or a subset of transistors 103 may 
be accomplished through selection programming. 
Moreover, the present invention provides a new method 
of programming floating-gate transistors 103 that overcome 
problems associated with traditional direct programming, 
55 
such as the difficulty of programming nFETs and the para-
sitics associated with the isolation circuitry needed for direct 
programming. Indirect programming provides for a system-
atic approach to programming both pFETs and nFETs indi-
rectly. Such an approach may easily be extended to large 
arrays of floating-gate devices (such as FPAA crossbar 
60 switch networks), so that a large number of current sources 
may be programmed without invasively disconnecting each 
device from the circuit. Further, directly and indirectly 
programmed floating-gate transistors 103 can coexist in the 
same large array, so that each might be used for a particular 
65 advantage. 
Indirect programming provides runtime programming 
capabilities without the need for isolating the transistor 103 
US 7,269,046 B2 
29 
from the circuit, thereby eliminating the need for isolation 
switches. Further, the operational transistor 103 may be free 
from any programming components, as all progrannning 
components are associated with the progrannner transistor 
103, which is coupled to the operational transistor 103 via a 
common floating-gate 112. The present invention, therefore, 
provides for progrannning a particular transistor 103 without 
stopping the flow of data on the operational circuitry. Also, 
a smaller silicon footprint is necessary to implement the 
indirect programming scheme. 
10 The method of indirect programming provided by the 
present invention also allows certain circuits to be trans-
formed into a progrannnable version that would not have 
been previously possible. The aforementioned program-
mable nFET current mirror is now possible, and a neuron 
15 
circuit that carmot properly operate due to the parasitics of 
the isolation circuitry may now be made. 
30 
a third capacitor having a first terminal and a second 
terminal, wherein the first terminal of the third capaci-
tor is coupled to the third floating gate of the third 
transistor; 
a second row programming switch having a first output, 
wherein the first output of the second row programming 
switch is coupled to the second terminal of the third 
capacitor; 
a first column programming switch having a first output, 
wherein the first output of the first colunm program-
ming switch is coupled to the first drain of the first 
transistor and the third drain of the third transistor; and 
a second colunm programming switch having a first 
output, wherein the first output of the second column 
programming switch is coupled to the second drain of 
the second transistor. 
New possibilities with floating-gate programming also 
exist. As the agent transistor 103 does not need to be 
removed from the circuit, indirect programming removes the 
necessity of a separate programming phase and an opera-
tional phase. This allows the possibility of run-time recali-
bration and adaptation to be carried out by the progrannning 
pFET. Indirect progrannning offers solutions to many of the 
problems of direct programming while also providing new 
and unique capabilities to augment the analog designer's 
toolbox. 
2. The floating-gate transistor array of claim 1, wherein 
20 
the first source line of the first transistor and the second 
source line of the second transistor are coupled to a common 
source node. 
3. The floating-gate transistor array of claim 1, wherein 
25 the first drain line of the first transistor and the third drain 
Further, the present invention provides a unique method 
of programming the transistor 103 by utilizing saturation 
techniques, instead of conventional pulse and measure meth-
30 
odology. The present invention uses the relationship 
between the gate voltage and the saturation point of the 
transistor 103 to accurately program the desired current to 
the programmer transistor 103, and, accordingly, to the 
operational transistor 103. 
35 Numerous characteristics and advantages have been set 
forth in the foregoing description, together with details of 
structure and function. While the invention has been dis-
closed in several forms, it will be apparent to those skilled 
in the art that many modifications, additions, and deletions, 
40 
especially in matters of shape, size, and arrangement of 
parts, can be made therein without departing from the spirit 
and scope of the invention and its equivalents as set forth in 
the following claims. Therefore, other modifications or 
embodiments as may be suggested by the teachings herein 
45 
are particularly reserved as they fall within the breadth and 
scope of the claims here appended. 
What is claimed is: 
1. A floating-gate transistor array comprising: 
a first transistor having a first source, a first drain, and a 50 
first floating gate; 
a second transistor having a second source, a second 
drain, and a second floating gate; 
line of the third transistor are coupled to a common drain 
node. 
4. A programming circuit for indirectly programming a 
floating gate transistor operating within an operational cir-
cuit without isolating the floating gate transistor from the 
remainder of the operational circuit, the progrannning cir-
cuit comprising: 
an operational transistor having a first source, a first drain, 
and a first floating gate, the first source and the first 
drain being connected to an operational circuit; 
a programming transistor having a second source adapted 
for connection to a first programming voltage source, a 
second drain adapted for connection to a second pro-
gramming voltage source, and a second floating gate, 
the second floating gate being electrically coupled to 
the first floating gate of the operational transistor; 
an input capacitor having a first terminal connected to the 
second floating gate and a second terminal adapted for 
connection to a gate voltage source for delivering a 
predetermined gate voltage to the second floating gate; 
and 
wherein the first floating gate is charged to a first gate 
charge when the second floating gate is programmed 
with the first gate charge. 
5. The progrannning circuit of claim 4, further compris-a first capacitor having a first terminal and a second 
terminal, wherein the first terminal of the first capacitor 
is coupled to the first floating gate of first transistor; 
55 ing: 
a second capacitor having a first terminal and a second 
terminal, wherein the first terminal of the second 
capacitor is coupled to the second floating gate of the 
second transistor; 
a first row programming switch having a first output, 
wherein the first output of the first row progrannning 
switch is coupled to the second terminal of the first 
capacitor and the second terminal of the second capaci-
60 
~ ~ 
a third transistor having a third source, a third drain, and 
a third floating gate; 
a tunneling capacitor having a first terminal connected to 
the second floating gate and a second terminal adapted 
for connection to a turmeling voltage source for deliv-
ering a predetermined turmeling voltage to the second 
floating gate; and 
wherein the first gate charge is reduced when the prede-
termined tunneling voltage is delivered to the second 
floating gate. 
6. A method of indirectly programming an operational 
floating gate transistor having a first source, first drain, and 
first floating gate, operating within an operational circuit 
US 7,269,046 B2 
31 
without isolating the operational floating gate transistor from 
the remainder of the operational circuit using a program-
ming floating gate transistor having a second source, a 
second, drain, and a second floating gate, the second floating 
gate being electrically coupled to the first floating gate, the 
method comprising: 
applying a first predetermined voltage signal to the second 
source; 
32 
coupling a second predetermined voltage signal into the 
second floating gate via a capacitor connected to the 
second floating gate; and 
applying a third predetermined voltage signal to the 
second drain until a charge on the first floating gate 
reaches a predetermined value. 
* * * * * 
