The main objective of this contribution is to present a design methodology for application specific fuzzy integrated circuits. This methodology is based on an specific architecture and a user-friendly design environment which enables the specification, verification and synthesis of fuzzy systems taking into account conceptual as well as microelectronics considerations.
Introduction
Nowadays, several circuits known as fuzzy coprocessors are available in the microelectronics market-place. They are general-purpose devices that work together with standard processors to speed up some of the typical operations of fuzzy-logic-based inference systems [ 11. The problem is that this kind of circuits is not efficient enough in terms of silicon area, power consumption and inference speed when considering its application to industrial sectors related to telecommunication and automotive or consumer products. A more advantageous solution, as happens in many other microelectronics areas, is to use dedicated hardware adapted to the particular problem [2] . Viability of this approach is greatly increased by using design methodologies, circuit techniques and CAD tools that ease system realization, thus reducing time-to-market. A design methodology for application specific fuzzy integrated circuits is outlined in this paper. The methodology is based on a set of CAD tools which ease the different stages of specification, verification and synthesis of fuzzy systems [3]. The proposed approach has been validated by applying it to the design of a fuzzy controller for the classical ball and fan problem.
Design Methodology
The main steps to design a fuzzy controller following the proposed methodology are illustrated in Fig. 1 .
1
The starting point is the specification of the controller functionality. For this purpose, the design environment provides a flexible high-level specification language, called XFL, that permits a unified fuzzy system description to be held through all the design process. An XFL specification defines the inference mechanism, the defuzzification method and the knowledge base selected (the rule base as well as the antecedents' and consequents' membership functions). An XFL specification consists of type and module definitions that describe the membership functions and the rules, respectively. XFL Having made these selections, the user has two ways of verifying the functionality of the whole system (the fuzzy controller and the plant). One of them is to simulate the system behavior with the fuzzy system simulator xfsim which is included within the design environment. In this case a software model for the plant is used together with the XFL description. Depending on the problem this firstapproximation model can not be enough to describe the plant behavior. A more realistic approach is to include the plant itself within the simulation loop ("hardware in the loop" strategy). For this purpose, the design environment provides the x$ub utility which basically consists of a data acquisition card and drivers to read and write data.
Using this tool the plant model is replaced by a function that performs the following: (a) it monitors the real plant (reading the input ports of the data acquisition card), (b) it sends the inputs excitation to the XFL controller model, and, finally, (c) it writes the control action to the output port of the acquisition card. Once the controller specifications have been validated, the implementation phase can start. To accomplish this task an adequate controller architecture should have been selected in the XFL specification. The architecture we are currently using enables low-cost and high-inferencespeed silicon implementations of fuzzy logic controllers [5]. This is achieved by applying some simplification concepts like the following: (a) the use of an active rule driven inference mechanism, which only explores the (potentially) active rules instead of the whole rule base, (b) the limitations on the membership functions' overlapping degrees so that the membership function circuits (MFC's) can be simplified by reducing the required memories, and (c) the use of crisp consequents, suitable for simplified defuzzification methods, thus exploring the universe of the rules instead of the universe of discourse (Fig. 2) .
Fuzzifier
An automatic synthesis tool, called xfvhdl, can be used to translate the XFL specification into a VHDL description capable of being implemented as a microelectronics circuit [6] . In addition to the selection of the actual size of the controller buses, the designer can choose among several implementation options when using xfvhdl: (a) vectorial or arithmetic approaches to implement the MFC's, (b) RAM'S or ROM's (that increase the programmability) or combinational blocks (that reduce hardware resources) to store the knowledge base, and (c) four different simplified defuzzification methods are currently supported to obtain the crisp controller output. The output of xfvhdl is a set of VHDL files containing the structural controller description, some constant packages, and a test bench file which helps the simulation of the circuit. The description of some of the controller components are directly generated by xfvhdl, while others are included into a VHDL cell library. The code used in the description of the cell library is compatible with the restricted VHDL implementations of Synopsys and Mentor Graphics tools. The VHDL description generated by xfvhdl can be synthesized by any conventional high-level synthesis tool. Two generic implementation techniques can be followed.
The first one is to use a field programmable gate array (FPGA) [7] . This approach is useful for prototyping purpose because of its inherent capability to change the system functionality by programming. In this case, xfvhdl also produces a script file to control the synthesis process with Synopsys and Xilinx to implement the circuit as an FPGA. The second approach is to design an application specific integrated circuit (ASIC) using a scmi-custom IC design environment and the technology library provided by a silicon foundry [8] . 
Application Case
In order to illustrate the design flow we describe in this section the design of a fuzzy controller aimed at controlling the height of a falling ball by using a fan. The set up employed in our experiments is shown in The plant model employed in the simulation stage is usually a first-order model that does not consider effects like friction or turbulence that are very difficult to describe. Thence, the simulation results can be very different from the real ones if these second-order effects are not negligible. To solve this problem the proposed design environment offers an utility to include the real plant into the simulation loop, thus providing an on-line verification of the control. The graphics represent the temporal evolution of the ball position including several perturbations from an equilibrium point. The position can be seen as quantized into levels that correspond to.the distance between two subsequent photosensors. The last stage of the design process is to implement the verified controller in hardware using the synthesis tools of the design environment. For the application here described the fuzzy controller prototype was integrated with a programmable knowledge base where the rule memory and the blocks that generate the variables' membership functions are implemented with RAM'S. The prototype is a three-input one-output fuzzy controller that can employ up to 8 membership functions with an overlapping degree of 2 and a resolution of 6 bits. The rule base memory is implemented as a RAM of 512x6 bits, thus allowing to define a different consequent for each rule. The defuzzifier block has been optimized for the Fuzzy Mean method. The circuit layout was obtained from the VHDL description provided by the xfvhdl tool by using the Mentor Graphics and Cadence design environments. The controller, whose die photograph is shown in Fig. 7 , was integrated in a 1 .O pm CMOS technology. Its silicon area is 14.36 mm2.
Finally, the behavior of the real plant controlled by the PCB that contains the fuzzy integrated circuit can be monitoring by using again the xjZab utility. The maximum clock frequency measured at laboratory for this IC controller was 27 Mhz, providing an inference speed over 3 MFLIPs. 
Conclusions
A design methodology for application specific fuzzy controllers has been presented in this paper. The key points of this methodology are the choice of an efficient hardware architecture for fuzzy controllers, and the use of a development environment that eases and speeds-up the different stages of description, verification and synthesis in the design process.
