Field-programmable analog array
A field-programmable analog array (FPAA) is an integrated circuit device containing computational analog blocks (CAB) and interconnects between these blocks offering field-programmability. Unlike their digital cousin, the FPGA, the devices tend to be more application driven than general purpose as they may be current mode or voltage mode devices. For voltage mode devices, each block usually contains an operational amplifier in combination with programmable configuration of passive components. The blocks can, for example, act as summers or integrators.
FPAAs usually operate in one of two modes: continuous time and discrete time.
- Discrete-time devices possess a system sample clock. In a switched capacitor design, all blocks sample their input signals with a sample and hold circuit composed of a semiconductor switch and a capacitor. This feeds a programmable op amp section which can be routed to a number of other blocks. This design requires more complex semiconductor construction. An alternative, switched-current design, offers simpler construction and does not require the input capacitor, but can be less accurate, and has lower fan-out - it can drive only one following block. Both discrete-time device types must compensate for switching noise, aliasing at the system sample rate, and sample-rate limited bandwidth, during the design phase.
- Continuous-time devices work more like an array of transistors or op amps which can operate at their full bandwidth. The components are connected in a particular arrangement through a configurable array of switches. During circuit design, the switch matrix's parasitic inductance, capacitance and noise contributions must be taken into account.
Currently there are very few manufactures of FPAAs. On-chip resources are still very limited when compared to that of an FPGA. This resource deficit is often cited by researchers as a limiting factor in their research.
This section needs additional citations for verification. (May 2017) (Learn how and when to remove this template message)
AnadigmDesigner®2 EDA Software
AnadigmDesigner®2 is the second generation EDA software that enables engineers to design and implement dynamically reconfigurable analog circuits within a matter of minutes. It includes a time domain functional simulator. The software takes the design and translates it into C code so that it can be used within an embedded system.
DynAMx Design Lab Software
DynAMX Design Lab is used to configure and simulate a FPAA chip. It puts an analog environment comparable to an FPGA in the hands of engineers. Engineers can quickly design complex analog functions into a fully qualified chip. The software allows engineers to adjust the configuration on-the-fly. It is specifically designed to be reconfigurable and reprogrammable in real time, whether in the lab, in the field or in production.
ICE LAB Software
The term FPAA was first used in 1991 by Lee and Gulak. They put forward the concept of CABs that are connected via a routing network and configured digitally. Subsequently, in 1992 and 1995 they further elaborated the concept with the inclusion of op-amps, capacitors, and resistors. This original chip was manufactured using 1.2 µm CMOS technology and operates in the 20 kHz range at a power consumption of 80 mW.
Pierzchala et al introduced a similar concept named electronically-programmable analog circuit (EPAC). It featured only a single integrator. However, they proposed a local interconnect architecture in order to try and avoid the bandwidth limitations.
The reconfigurable analog signal processor (RASP) and a second version were introduced in 2002 by Hall et al. Their design incorporated high-level elements such as second order bandpass filters and 4 by 4 vector matrix multipliers into the CABs. Because of its architecture, it is limited to around 100 kHz and the chip itself is not able to support independent reconfiguration.
In 2004 Joachim Becker picked up the parallel connection of OTAs (operational transconductance amplifiers) and proposed its use in a hexagonal local interconnection architecture. It did not require a routing network and eliminated switching the signal path that enhances the frequency response.
In 2005 Fabian Henrici worked with Joachim Becker to develop a switchable and invertible OTA which doubled the maximum FPAA bandwidth. This collaboration resulted in the first manufactured FPAA in a 0.13 µm CMOS technology
- Field-programmable RF – Field programmable radio frequency devices
- CPLD: Complex Programmable Logic Device
- PSoC: Programmable System-on-Chip
- NoC: Network on a Chip
- Network architecture
- Hall, Tyson; Twigg, Christopher; Hassler, Paul; Anderson, David (2004). "APPLICATION PERFORMANCE OF ELEMENTS IN A FLOATING–GATE FPAA". IEEE-ISCAS 2004. II: 589–592.
- Baskaya, F.; Reddy, S.; Sung, Kyu Lim; Anderson, D.V. "Placement for large-scale floating-gate field-programable analog arrays". IEEE Trans. on VLSI Systems Aug. 2006. 14 (8): 906–910.
- "Tool Download".
- "A CMOS Field-programmable analog array," Solid-State Circuits".
- "Field programmable analogue array based on MOSFET transconductors" (PDF).
- "A transconductor-based field programmable analog array" (PDF).
- "Current Mode amplifier/integrator for field programmable analog array".
- "Field Programmable Analog Arrays: A Floating-Gate Approach" (PDF).
- "Large scale field programmable analog arrays for analog signal processing".
- ".,"A continuous-time field programmable analog array (FPAA) consisting of digitally reconfigurable GM-cells".
- "A Continuous-Time Hexagonal Field-Programmable Analog Array in 0.13 µm CMOS with 186MHz GBW".
- "A Programmable and Configurable Mixed-Mode FPAA SoC" Jennifer Hasler et al., Georgia Tech, January 7, 2016.
- "Analog's Answer to FPGA Opens Field to Masses" Sunny Bains, EE Times, February 21, 2008. Issue 1510.
- "Field programmable analog arrays" Tim Edwards, Johns Hopkins University project, 1999.
- "Field programmable analog arrays" Joachim Becker, et al., University of Freiburg, Department of Microsystems Engineering. Hex FPAA Research Project.