Imperial College London

Department of Electrical and Electronic Engineering

Final Year Project Report 2018



| Project Title:      | An Autonomous Readout Circuit for Amperometric Bio-sensing |
|---------------------|------------------------------------------------------------|
| Student:            | Wei Onn Ting                                               |
| CID:                | 00970017                                                   |
| Course:             | EEE4T                                                      |
| Project Supervisor: | Dr Sara Ghoreishizadeh                                     |
| Co-Supervisor:      | Dr Pantelis Georgiou                                       |
| Second Marker:      | Dr Timothy Constandinou                                    |

#### Abstract

In this modern world, most of the medical devices are equipped with biosensors. For example, a biosensor which is based on the electrochemical detection principle is capable of measuring different metabolites such as glucose and lactate in a single finger-stick blood sample. This is achieved by capturing the concentration of the analytes and translating them into an electronic information domain.

This report describes the principle, design process and simulation of an autonomous gain control readout circuit which is capable of measuring current from the working electrode of a sensor with wide dynamic range. The whole system is implemented and simulated using Cadence Hit-Kit v4.10. A mixed-signal integrated circuit is implemented using cadence 350 nm technology. Its analogue part is presented in the report to demonstrate its performance in terms of sensitivity, linearity, dynamic range and noise. The range of the input current of the system is  $\pm 13 \,\mu\text{A}$  with minimum input-referred noise of 44 fA from 3.3 V supply.

To date, there are different topologies of the state-of-the art readout circuits for amperometry biosensors. However, an autonomous gain control readout circuit is introduced and demonstrated for the first time in this report. It enables the system to autonomously vary its operation mode successfully to measure the sensor current. The autonomous gain control algorithm is implemented using Hardware Descriptive Language.

#### Acknowledgements

This report would not have been possible without the contributions of a few key individuals. First and foremost, I would like to express special gratitude to my project supervisor, Dr. Sara Ghoreishizadeh, who in spite of her extraordinarily busy schedule, invested her full effort in guiding me to achieve my project goal. I wish to thank her for her patience and constant guidance and encouragement in the past 9 months. I have been fortunate to learn so much from her technical insight and mentorship.

My thanks and appreciations also go to my co-supervisor, Dr. Pantelis Georgiou who equipped me with invaluable knowledges through all his lectures such as Analogue Integrated Circuit and Systems, Analogue Signal Processing and Biomedical Electronics courses. I wish to thank him for inspiring me to undertake this bio-inspired technology project which I enjoyed throughout the duration of the project.

Furthermore, I would also like to acknowledge the crucial roles played by the research staffs and postgraduate students of Imperial College Centre for Bio-Inspired Technology. Special thanks to Michal, Lieuwe and Nicolas for providing me with technical support on Cadence. I wish to thank Song Luan for giving me vital suggestions and feedback on the digital part of my circuit.

I would also like to thank my friends who supported and encouraged me to strive towards my goals. Many thanks goes to Usama for helping me to debug my VHDL code; Esther for proof-reading my report and giving me suggestions to make my report more presentable.

Last but not least, I would like to express my appreciation to my beloved family. Their words of encouragement and support have strive me towards the completion of my final year project.

# Contents

| 1 | Intro | oduction 1                                    |
|---|-------|-----------------------------------------------|
|   | 1.1   | Project Specifications                        |
|   | 1.2   | Challenges                                    |
|   | 1.3   | Report Outline   2                            |
| 2 | Bios  | ensors - State of Art                         |
|   | 2.1   | Electrochemical Detection                     |
|   | 2.2   | Sensing Circuit                               |
|   | 2.3   | Readout Circuits                              |
|   |       | 2.3.1 Current-to-Time Conversion Circuit      |
|   |       | 2.3.2 Current-to-Frequency Conversion Circuit |
|   |       | 2.3.3 $\Sigma\Delta$ based Circuit            |
|   |       | 2.3.4 Voltage-mode Circuit                    |
|   |       | 2.3.5 Current-mode Circuit                    |
|   |       | 2.3.6 Comparison                              |
| 3 | Initi | al Architecture 13                            |
|   | 3.1   | Current Preamplifier                          |
|   |       | 3.1.1 Small-Signal Analysis                   |
|   |       | 3.1.2 Transconductance Amplifier              |
|   |       | 3.1.3 Circuit Level Simulation                |
|   | 3.2   | Switched-Capacitor Integrator                 |
|   |       | 3.2.1 Circuit-Level Simulation                |
|   | 3.3   | Comparison                                    |
|   | 3.4   | Chapter Summary                               |
| 4 | Ana   | logue Circuit                                 |
|   | 4.1   | Switched-Capacitor Integrator                 |
|   | 4.2   | Low-Leakage Switch                            |
|   | 4.3   | Sample and Hold Circuit                       |
|   | 4.4   | Comparator                                    |
|   | 4.5   | Analogue-To-Digital Converter                 |

|   | 4.6          | Operation Mode Settings                                                                                                                               |  |  |  |
|---|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|   | 4.7          | Circuit Level Simulation                                                                                                                              |  |  |  |
|   |              | 4.7.1 Dynamic Range                                                                                                                                   |  |  |  |
|   |              | 4.7.2 Noise                                                                                                                                           |  |  |  |
|   | 4.8          | Chapter Summary                                                                                                                                       |  |  |  |
| 5 | Digi         | tal Circuit 30                                                                                                                                        |  |  |  |
| 5 | 5 1          | Clock Concretor 40                                                                                                                                    |  |  |  |
|   | 5.1          | 5.1.1. Clock Ontimisation 40                                                                                                                          |  |  |  |
|   | 50           | 3.1.1       Clock Optimisation       40         Auton ornous Coin Control Algorithm       41                                                          |  |  |  |
|   | 5.2          | Autonomous Gain Control Algorithm $\dots \dots \dots$ |  |  |  |
|   |              | 5.2.1 Mode Specification Stage $\dots \dots \dots$    |  |  |  |
|   |              | 5.2.2 Mode Specification Optimisation                                                                                                                 |  |  |  |
|   |              | 5.2.3 Readout Stage                                                                                                                                   |  |  |  |
|   |              | 5.2.4 Hysteresis Operation                                                                                                                            |  |  |  |
|   | 5.3          | RTL Simulation                                                                                                                                        |  |  |  |
|   |              | 5.3.1 Clock Generator                                                                                                                                 |  |  |  |
|   |              | 5.3.2 Autonomous Gain Control                                                                                                                         |  |  |  |
|   | 5.4          | Chapter Summary                                                                                                                                       |  |  |  |
| 6 | Syst         | em Level Simulation 51                                                                                                                                |  |  |  |
|   | 6.1          | Transient Simulation                                                                                                                                  |  |  |  |
|   |              | 6.1.1 Constant Input Current                                                                                                                          |  |  |  |
|   |              | 6.1.2 Noisy Input Current                                                                                                                             |  |  |  |
|   |              | 613 Varving Input Current 56                                                                                                                          |  |  |  |
|   | 62           | Parametric Simulation 60                                                                                                                              |  |  |  |
|   | 6.3          | Chapter Summary 60                                                                                                                                    |  |  |  |
|   | 0.5          |                                                                                                                                                       |  |  |  |
| 7 | Layo         | out 61                                                                                                                                                |  |  |  |
|   | 7.1          | Analogue Layout                                                                                                                                       |  |  |  |
|   | 7.2          | Digital Layout                                                                                                                                        |  |  |  |
| 8 | S Conclusion |                                                                                                                                                       |  |  |  |
| 0 | 8.1          | Conclusion 65                                                                                                                                         |  |  |  |
|   | 8.2          | Achievements 66                                                                                                                                       |  |  |  |
|   | 8.3          | Future Work 66                                                                                                                                        |  |  |  |
|   | 0.5          |                                                                                                                                                       |  |  |  |
| A | VHI          | DL Code 69                                                                                                                                            |  |  |  |
|   | A.1          | Clock Generator                                                                                                                                       |  |  |  |
|   | A.2          | Improved Clock Generator    70                                                                                                                        |  |  |  |
|   | A.3          | Autonomous Gain Control                                                                                                                               |  |  |  |

# **List of Figures**

| 2.1  | Three electrode system                                                                                                                                                                               |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2.2  | Current to time converter                                                                                                                                                                            |
| 2.3  | Current to frequency converter                                                                                                                                                                       |
| 2.4  | Feedback-modulated $\Sigma\Delta$ -based circuit                                                                                                                                                     |
| 2.5  | Input-modulated $\Sigma\Delta$ -based circuit                                                                                                                                                        |
| 2.6  | Voltage-mode circuit                                                                                                                                                                                 |
| 2.7  | Typical switched-capacitor readout circuit                                                                                                                                                           |
| 2.8  | Current conveyor circuit                                                                                                                                                                             |
| 3.1  | Current preamplifier                                                                                                                                                                                 |
| 3.2  | Bidirectional input current flow in the current preamplifier                                                                                                                                         |
| 3.3  | Small-signal model of the current preamplifier                                                                                                                                                       |
| 3.4  | Schematics of folded cascode OTA                                                                                                                                                                     |
| 3.5  | Simulation setup for current preamplifier                                                                                                                                                            |
| 3.6  | $I_{OUT}/I_{IN}$ increases as the sensor resistance increases $\ldots \ldots \ldots$ |
| 3.7  | Deviation of $I_{OUT}$                                                                                                                                                                               |
| 3.8  | Third-order intercept                                                                                                                                                                                |
| 3.9  | Simulation setup for cascoded current preamplifier for different gain settings 20                                                                                                                    |
| 3.10 | Output current against input current of cascode current preamplifier for different gain                                                                                                              |
|      | settings                                                                                                                                                                                             |
| 3.11 | Output voltage against input current for different gain settings                                                                                                                                     |
| 3.12 | Output voltage of the switched-capacitor for an input current of 1 $\mu$ A integrated at 10                                                                                                          |
|      | pF capacitor for 5 $\mu$ s                                                                                                                                                                           |
| 3.13 | Output voltage of the switched-capacitor for an input current of 10 pA integrated at                                                                                                                 |
|      | 50 fF capacitor for 5 ms                                                                                                                                                                             |
| 4.1  | Switched capacitor integrator                                                                                                                                                                        |
| 4.2  | Schematic of folded cascode amplifier                                                                                                                                                                |
| 4.3  | Complementary switch                                                                                                                                                                                 |
| 4.4  | Low leakage switch                                                                                                                                                                                   |
| 4.5  | Initial sample and hold circuit                                                                                                                                                                      |
| 4.6  | Sample and hold circuit                                                                                                                                                                              |
| 4.7  | The operation of sample and hold circuit                                                                                                                                                             |
|      |                                                                                                                                                                                                      |

| 4.8  | Clocked comparator                                               |
|------|------------------------------------------------------------------|
| 4.9  | CMOS 10-Bit ADC                                                  |
| 4.10 | CMOS 10-Bit ADC                                                  |
| 4.11 | Output voltage against input current for different mode settings |
| 5.1  | Mealy diagram for AGC                                            |
| 5.2  | The comparator pair setup for bidirectional current              |
| 5.3  | Symbol of clock generator                                        |
| 5.4  | RTL simulation for clock generator                               |
| 5.5  | Symbol of autonomous gain control circuit                        |
| 5.6  | RTL simulation shows the transition to the readout stage         |
| 5.7  | RTL simulation shows the hysteresis operation                    |
| 6.1  | Readout circuit system block diagram                             |
| 6.2  | The two stages of the digital block                              |
| 6.3  | Readout circuit operation for a constant input current           |
| 6.4  | Simulation setup for noisy input current simulation              |
| 6.5  | Readout circuit operation for an input current with noise        |
| 6.6  | Readout circuit operation for a varying input current            |
| 6.7  | Mode transition timing diagram                                   |
| 6.8  | Mode Transition for ramp input current                           |
| 6.9  | Mode Transition for ramp input                                   |
| 7.1  | Layout for sample and hold circuit                               |
| 7.2  | Layout of sample and hold circuit                                |
| 7.3  | Layout of clocked comparator                                     |
| 7.4  | Digital synthesis and P&R flow using Genus and Innovus           |

# **List of Tables**

| 2.1 | Comparison between state-of-the-art of the amperometric current readout circuits | 12 |
|-----|----------------------------------------------------------------------------------|----|
| 3.1 | Comparison between preliminary choices of readout circuits                       | 13 |
| 3.2 | Folded cascode amplifier characterisation                                        | 16 |
| 3.3 | Typical parameter value in equation 3.10                                         | 18 |
| 3.4 | Comparison between current preamplifier and switched-capacitor integrator        | 24 |
| 4.1 | Folded Cascode amplifier characterisation                                        | 28 |
| 4.2 | Reference voltage setup in ADC for bidirectional current                         | 34 |
| 4.3 | Different mode settings                                                          | 35 |
| 4.4 | PSS and Pnoise analysis settings                                                 | 37 |
| 4.5 | Output noise and input-referred current noise for different mode settings        | 38 |
| 5.1 | The operation of the comparator pairs                                            | 42 |
| 5.2 | An example of the operation of counters                                          | 43 |
| 5.3 | The threshold values for different conditions                                    | 45 |
| 6.1 | Period of clock cycle for each mode                                              | 58 |
| 8.1 | Comparison between state-of-the-art of the amperometric current readout circuits | 65 |

# Chapter 1 Introduction

Nowadays, as health care systems are increasingly stressed, patients are being discharged from hospitals and other healthcare institutions still needing extra care and attention. Patients with chronic illness such as hypertension, diabetes or kidney failure need to constantly monitor their body conditions. Hence, both patients and professional caregivers utilise a wide variety of biosensors in non-institutional settings to manage their own health, assist others with healthcare, and receive assistance with health management [1]. This leads to an increase in demand and development in biosensors where its market is expected to reach approximately USD 360 million by the end of 2023 [2]. These technologies provide support not only for care related to acute and chronic medical conditions, but also for disease prevention and lifestyle choices.

Non-clinical handheld devices to measure different metabolites (such as glucose and lactate) in a single finger-stick blood sample have been developed based on the principle of electrochemical detection using enzymes. Each sensor generates a current which indicates the concentration of targeted metabolite. However, they need to be tuned for each measurement and sensor. Consequently, autonomous gain is needed to be rendered with these technologies while making sure the biosensors are safe, reliable, and effective for use in non-clinical environments. Hence, users of wider demographic can use the biosensors and benefit from these technologies.

## 1.1 Project Specifications

The project involves the creation, implementation and test of a current readout circuit to measure sensor current within a wide range of 1pA to  $1\mu$ A. An automatic-gain-adjustment algorithm should be developed and implemented on-chip to eliminate the need for manual tuning of the front-end electronics.

# 1.2 Challenges

The main challenges of the project are listed below:

- 1. Familiarisation and mastery in Cadence tools.
- 2. Implementation of a readout circuit capable of measuring a wide dynamic range of input sensor current by sectioning into different operating modes.
- 3. The linearity of the decimated output corresponds to the input current in each operating mode.
- 4. Implementation of a digital circuit to perform autonomous gain control by using Hardware Descriptive Language (VHDL).
- 5. Implementation of hysteresis operation in the digital circuit to avoid oscillation between modes.
- 6. The timing of the integrator, comparator, sample and hold, and ADC of the system.
- 7. Implementation of suitable simulations or testbenches to model the performance of the system.
- 8. Optimisation of the system in terms of power consumption, noise and area.

# **1.3 Report Outline**

Following an introduction, this report is organised as follows:

**Chapter 2** describes the literature survey of the project. The basic electrochemical detection principle is explained. Different state-of-art readout circuits which are capable of achieving a wide dynamic range of current are studied. A comparison is then made to compare their performances.

**Chapter 3** focuses on the implementation plan of the project. It describes the initial architecture of the proposed circuit and its simulation results. However, the performance of the initial architecture is below expectation. This leads to the implementation of a different topology which will be discussed in following chapter.

**Chapter 4** describes the analogue part of the circuits in which the design choices are justified, followed by an overall block diagram and the simulation result in terms of dynamic range and noise.

**Chapter 5** focuses on the digital part of the circuit. The autonomous gain algorithm is explained and implemented in VHDL. The RTL simulation result of the algorithm in ModelSim is presented as well.

**Chapter 6** presents the system level simulation of the readout circuit to demonstrate its performance. Transient simulations with noisy signal and varying current are presented. Parametric simulation

which shows changes in mode across input current is also presented.

**Chapter 7** describes the layout of the readout circuit. Different layout techniques are discussed and present in this chapter, followed by the logic synthesis flow of the digital circuit. The layout is then presented at the end of the chapter.

**Chapter 8** contains a conclusion where a summary of the achievements that have been accomplished is presented. The future works are also discussed to point out possible modifications and improvements that can be made to improve the performance of the system.

# Chapter 2

# **Biosensors - State of Art**

### 2.1 Electrochemical Detection

Among the technologies for bio-sensing [3], electrochemical detection techniques have been extensively researched and developed to capture biorecognition events and translate the results into electrical signals. Electrochemical biosensors have several advantages in terms of their performance and utility. For example, they allow label-free detection which reduce time, cost and complexity compared with the use of sample labeling techniques. They also allow continuous real-time measurement in which the concentration of a target metabolite can be determined from time to time. They are well-suited for miniaturisation as well. The electrochemical detection principles such as sensing and readout are explained in detail in the following subsections.

### 2.2 Sensing Circuit

The three-electrode system is one of the most popular topologies for translating biorecognition responses into electrical signals. This can be achieved by immobilising biorecognition elements which are capable of selectively recognising the target analyte on the working electrode (WE) where biochemical processes take place. The reference electrode (RE) supplies a stable reference voltage to the analyte without any current flow on it. The counter electrode (CE) completes the circuit by suppling the sensing current which flows in the WE. The three-electrode system is able to eliminate the undesired IR drop error [4] in the two-electrode system which only consists of the WE and RE.

### 2.3 Readout Circuits

The readout circuits are essential to amplify and process the sensor current from the working electrode and provide front-end signal conditioning. The sensor current is typically within a wide range and varies from time to time depending on the target analyte. Hence a well-designed readout circuit must be able to amplify or process the small sensor current accurately while keeping the signal-to-noise ratio



Figure 2.1 Three electrode system

low. Different readout circuits for a wide dynamic input current range are discussed and evaluated in the following subsections and a comparison between the circuit structures is tabulated thereafter.

#### 2.3.1 Current-to-Time Conversion Circuit

Time-based converter [5] as shown in Fig. 2.2 is one of the most popular readout circuits in which the readout current is converted into time. Time-based conversion can be achieved by measuring the time to discharge a pre-charged capacitor ( $C_d$ ). The capacitor is discharged through the transistor N1 with the input current flowing through WE. The relationship between time to discharge and input current is given by the equation 2.1.

$$\Delta t = \frac{C\Delta V}{I_{in}} \tag{2.1}$$

#### 2.3.2 Current-to-Frequency Conversion Circuit

The sensor current can be converted into frequency using an I-to-F converter. Fig. 2.3 depicts an example of an I-to-F converter [6]. The input current from the WE is mirrored to minimise the kickback effect of the I-to-F converter to the potentiostat. The mirrored current is then integrated at the capacitor. The D-flip flop generates an output pulse which is proportional to the input current by setting or reseting the pulse based on the difference between voltage at the capacitor and two threshold voltages. Hence the output frequency is generated.



Figure 2.2 VLSI potentiostat using a NMOS transistor at the input, used to discharge the capacitor to convert input current into time. Reprinted from [5].



Figure 2.3 Simplified schematic of the potentiostat and I-to-F converter. Reprinted from [6].

#### **2.3.3** $\Sigma \Delta$ based Circuit

Sigma delta ( $\Sigma\Delta$ ) based circuits digitize the input current through  $\Sigma\Delta$  ADC.

#### Feedback-modulated $\Sigma\Delta$

The  $\Sigma\Delta$  modulator which consists of a current integrator, comparator and single-bit DAC is implemented at the feedback loop as shown in Fig. 2.4 [7]. The wide dynamic range of input current which spans over 6 decades is achieved by tuning the delta-sigma oversampling ratio (OSR) and digital gain (G) of the gain-modulation scheme. In the gain-modulation scheme, the duty cycle (1/G) of the shunting sequence in the D/A feedback loop of the  $\Sigma\Delta$  modulator varies based on the input current and sets the gain of the input amplification. Since the duty cycle effectively shunts the strength of the reference current in the D/A feedback loop by the same factor, this gives the relationship between input current and reference current as shown in equation 2.2, where the first term represents the decimated output, and the second term represents the conversion error.

$$I_{in} = \sum_{i=1}^{OSC-1} D[i] \frac{I_{ref}}{G OSR} + \frac{V_{int}[OSR]}{OSR} \frac{C_1}{T}$$
(2.2)

The digital gain modulation over G clock cycles increase the conversion time by a factor of G. As seen in the equation, the OSC can be increased instead of G. However, increasing G is preferred since it produces more precise results owing to reduced noise.



(a) Simplified schematic of the potentiostat system

Figure 2.4 Feedback-modulated  $\Sigma\Delta$  based circuit. Reprinted from [7].

#### Input-modulated $\Sigma\Delta$

Another example of  $\Sigma\Delta$  based circuit is the input-modulated  $\Sigma\Delta$  [8]. The circuit concept is similar to that of the feedback modulated  $\Sigma\Delta$ , but the digital modulation happens at the input stage before the  $\Sigma\Delta$  ADC stage. The input current is modulated wih a square wave with duty cycle of 1/M. This reduces the requirement for  $\Sigma\Delta$  ADC reference current by a factor of M since the average current seen by the ADC input is reduced by a factor of M as well.

The ADC comprises a current integrator and a hysteretic comparator to produce two bit 1-bit pulse-width-modulation (PWM) digital pulses, D and D\*. The digital pulses are used to modulate two reference currents,  $I_{refP}$  and  $I_{refN}$ .

#### 2.3.4 Voltage-mode Circuit

The use of voltage-mode circuit is the simplest approach to measure the sensor current by translating the input current to voltage directly through a resistor, capacitor or switched-capacitor integrator. It is the most common approach for redox current acquisition [9, 10].



(b) System level diagram

Figure 2.5 Input-modulated  $\Sigma\Delta$  based circuit. Reprinted from [8].





(a) Resistive feedback current readout circuit

(b) Capacitive feedback current readout circuit. The capacitor is reset in every clock cycle.

Figure 2.6 Voltage-mode circuit converts the bidirectional input current into voltage.

#### **Resistive Feedback**

Fig. 2.6a depicts a readout circuit which uses a transimpedence amplifier with feedback resistor,  $R_f$  to convert the input sensor current,  $I_{in}$  to voltage,  $V_{out}$ . The sensor current can be calculated by equation 2.3.

$$I_{in} = -\frac{V_{out}}{R_f} \tag{2.3}$$

The dynamic range of the current readout circuit can be tuned by varying  $R_f$ . The feedback resistor should be very large to reduce input noise. However, there is a trade-off between the chip area and noise since the on-chip  $R_f$  cannot be too large due to the constraints on chip area. The feedback resistor also generates thermal noise which limits the readout resolution.

#### **Capacitive Feedback**

A readout circuit with capacitive feedback can eliminate thermal noise introduced in resistive feedback. As shown in Fig. 2.6b, the readout circuit uses an operational amplifier that integrates the input sensor current,  $I_{in}$  to an output voltage,  $V_{out}$  at the capacitor,  $C_f$ . The input sensor current can be calculated by equation 2.4.

$$V_{out} = \frac{1}{C_f} \int_0^T I_{in} dt \tag{2.4}$$

where  $C_f$  is the feedback capacitor and T is the integration time. However, there are noise sources such as charge injection, clock feedthrough and KT/C noise in the feedback switch which limit the resolution of this readout circuit.

#### **Switched-Capacitor**

A switched-capacitor (SC) integrator readout circuit which utilises correlated double sampling (CDS) [11] can be introduced to eliminate the input offset error due to noise sources in the capacitive feedback readout circuit, thereby suppressing the noise at the output. The CDS technique involves sampling the input twice and recording their differences. It rejects slow-charging noise, and reduces 1/f noise, offset and other non-ideal effects inherent to CMOS amplifiers. An example of SC-integrator readout circuit [10] is shown in Fig. 2.7.



Figure 2.7 A typical switched-capacitor readout chain consists of an integrator followed by a PGA followed by a sample and hold. The capacitor is reset in every clock cycle. Ph1, P2, and Ph3 are non overlapping clocks.  $V_{ref2}$  is applied to the WE through OP1 to stimulate the sensor for CA or CV measurements. OP2, C3 and the capacitor array for the PGA. Reprinted from [10].

#### 2.3.5 Current-mode Circuit

#### **Current Conveyor**

Another type of readout circuit that has been widely used is the current conveyor structure. A typical current conveyor schematic is shown in Fig. 2.8. The current conveyor readout circuit performs linear

operations and decoupling in current mode. The input current from working electrode can be measured by equation 2.5.

$$\frac{I_{in}}{I_{out}} = \frac{(W/L)_1}{(W/L)_2}$$
(2.5)

where  $I_{out}$  is the current conveyor output current and W/L is size of the current mirror transistor M1 and M2. Since there is no resistor or capacitor, the current conveyor can be very compact. However, it only allows input current in one direction. Offset current sources could be added to perform bidirectional current measurement.



Figure 2.8 The structure of the typical current conveyor readout circuit with potentiostat. Reprinted from [3].

#### **Current Preamplifier**

Instead of using the typical current-to-voltage conversion obtained by means of resistive feedback transimpedance amplifier as discussed earlier, two double-MOS structures which consists of two couples of matched MOSFET transistors [12] can be used. The input current from WE is first amplified by the current preamplifier, then converted to an output voltage by a transimpedance amplifier. The transistors of the current preamplifier operates in the subthreshold region and are able to provide a wide linear current range. However, the authors did not present the simulation or measurement in detail. Thus, further analysis and simulation need to be carried out.

### 2.3.6 Comparison

The main characteristics of the state-of-the-art integrated readout circuits for amperometry biosensors are presented in Table 2.1. As it can be seen from the table, today's state-of-the-art integrated circuits for electrochemical detection still suffer from a lack of autonomy. This project aims to design the first integrated circuit that able to measure a wide dynamic range of input current autonomously.

|               | Circuit Structure                 | Current Range |                          | Dynamic | Autonomous |
|---------------|-----------------------------------|---------------|--------------------------|---------|------------|
|               |                                   |               | Max                      | Range   | Gain       |
| TCAS'07[5]    | Current to Time                   | 1 pA          | 1 nA                     | 60 dB   | No         |
| TBCAS'13[13]  | Current to Frequency              | 24 pA         | $0.35 \ \mu A$           | 83 dB   | No         |
| TBCAS'07[7]   | Feedback modulated $\Sigma\Delta$ | 0.1 pA        | $\pm 0.5 \ \mu \text{A}$ | 134 dB  | No         |
| TBCAS'16[8]   | Input modulated $\Sigma\Delta$    | 0.1 pA        | $16 \ \mu A$             | 164 dB  | No         |
| TBCAS'17[14]  | Switched-Capacitor                | 0.47 pA       | $\pm 20~\mu { m A}$      | 153 dB  | No         |
| TCAS'13[9]    | Current Conveyor                  | 8.6 pA        | $\pm 350 \text{ nA}$     | 92 dB   | No         |
| JCCS'09[15]   | <b>Current Preamplifier</b>       | 1 fA          | $\pm 1 \mu A$            | 180 dB  | No         |
| Target Design |                                   | 1 pA          | $1 \ \mu A$              | 120 dB  | Yes        |

Table 2.1 Comparison between state-of-the-art of the amperometric current readout circuits

# Chapter 3 Initial Architecture

The preliminary choices on the readout circuit structure are narrowed down and presented in Table 3.1. They are chosen because of their wide linear current range, wide dynamic range and also the simplicity of the circuit which allow easier integration with autonomous gain control. The readout circuits as presented in Table 3.1 also allow bidirectional current measurement.

|              | Circuit<br>Structure | Complexity | Linear Current<br>Range | Input Dynamic<br>Range |
|--------------|----------------------|------------|-------------------------|------------------------|
| JSSC'09[15]  | Current Preamplifier | Low        | 1 fA - ±1 μA            | 180 dB                 |
| TBCAS'17[14] | Switched Capacitor   | Medium     | 0.47 pA - ±20 μA        | 153 dB                 |

Table 3.1 Comparison between preliminary choices of readout circuits

The current preamplifier based on the work of G.Ferrari [15] is chosen as the initial architecture of the readout circuit for the project since it claims to provide a wide dynamic range. The use of the double-MOS structure also reduces the chip area significantly. However, simulations need to be carried out to confirm these. All the implementations and simulations were carried out in the **GPDK 180nm** technology. The switched-capacitor architecture is also implemented and simulated to make comparison with the current preamplifier before making decision on the final readout circuit architecture.

## 3.1 Current Preamplifier

The matched double-MOS structure is the core architecture of the current preamplifier as illustrated in the blue box of Figure 3.1. The characteristics of the double-MOS structure are listed below:

- Consists of both NMOS and PMOS transistors. This structure allows bidirectional input current flow. The direction of current flow is illustrated in Fig. 3.2.
- The transistors have the exact same gate-drain voltages,  $V_{DS}$  and gate-source voltages,  $V_{GS}$ . Hence, they always work in the same operating region.

• The transistors operate in subthreshold region by connecting the gate of the transistors to half of the VDD.

The device width of the second double-MOS structure is larger than that of the first double-MOS structure by factor of N. Since both of the double-MOS structures have the same drain and source voltage, thus the output current which flows in second double-MOS structure is amplified by factor of N as well. The drain current across the device can be expressed in the equation 3.1 by recalling the drain current in subthreshold region.

$$i_{D(subthreshold)} = \frac{W}{L} \mu_e C_{ox} \left(\frac{kT}{q}\right) (n-1) e^{\frac{V_{GS} - V_T}{nkT}} (1 - e^{\frac{-qV_{DS}}{kT}})$$
(3.1)

By operating in the subthreshold region, the double-MOS contributes a very small shot noise and flicker noise that scale accordingly with the input current. The total power consumption is also very low as low current is drawn.



Figure 3.1 Proposed scheme of current preamplifier. Reprinted from [15].



Figure 3.2 Bidirectional input current flow into or out of the current amplifier. The direction of the input and output currents are opposite.

#### 3.1.1 Small-Signal Analysis

The current preamplifier is modelled in a small-signal model as shown in Fig. 3.3. Small-signal analysis was carried out to verify the relationship between the output current  $I_{OUT}$  and the input current  $I_{IN}$ .  $R_s$  represents the sensor resistance where the input current flows.



Figure 3.3 Small-signal model of the current preamplifier from the blue box of Fig. 3.1

$$I_{in} = gm_{n1}V_{out} + gm_{p1}V_{out} + \frac{V_{in} - V_{out}}{r_{on1}||r_{op1}}$$
(3.2)

$$I_{in} = \frac{V_{in}}{R_s} \tag{3.3}$$

Equate (3.1) and (3.2) yield:

$$A_{V} = \frac{V_{out}}{V_{in}} = \frac{\frac{1}{R_{s}} - \frac{1}{r_{on1}||r_{op1}}}{gm_{n1} + gm_{p1} - \frac{1}{r_{on1}||r_{op1}}}$$
(3.4)

Output current is given by:

$$I_{out} = GmV_{in} - gm_{n2}V_{out} - gm_{p2}V_{out} - \frac{V_{out}}{r_{on2}||r_{op2}||R_o}$$
(3.5)

$$I_{out} = GmI_{in}R_s - gm_{n2}I_{in}R_sA_v - gm_{p2}I_{in}R_sA_v - \frac{I_{in}R_sA_v}{r_{on2}||r_{op2}||R_o}$$
(3.6)

$$\frac{I_{out}}{I_{in}} = GmR_i - R_s \left(\frac{\frac{1}{R_s} - \frac{1}{r_{on1}||r_{op1}}}{gm_{n1} + gm_{p1} - \frac{1}{r_{on1}||r_{op1}}}\right) \left(gm_{n2} + gm_{p2} + \frac{1}{r_{on2}||r_{op2}||R_o}\right)$$
(3.7)

Let  $gm_1 = gm_{n1} + gm_{p1}$ ,  $gm_2 = gm_{n2} + gm_{p2}$ ,  $r_{o1} = r_{on1} ||r_{op1}$  and  $r_{o2} = r_{on2} ||r_{op2}||$ 

Since N2 and P2 consist of N replicas of N1 and P1,  $gm_2 = Ngm_1$  and  $r_{o2} = \frac{r_{o1}}{N}$ . Equation (3.7) is simplified to:

$$\frac{I_{out}}{I_{in}} = GmR_s - R_s \left(\frac{\frac{1}{R_s} - \frac{1}{r_{o1}}}{gm_1 - \frac{1}{r_{o1}}}\right) \left(Ngm_1 + \frac{1}{\frac{r_{o1}}{N}}\right)$$
(3.8)

$$\frac{I_{out}}{I_{in}} = GmR_s - \left(\frac{r_{o1} - R_s}{gm_1r_{o1} - 1}\right) \left(\frac{N(1 + gm_1r_{o1})}{r_{o1}}\right)$$
(3.9)

Assuming  $gm_1r_{o1} >> 1$ , this gives the relationship between  $I_{in}$  and  $I_{out}$  as:

$$\frac{I_{out}}{I_{in}} = -N + R_s \left( Gm + \frac{N}{r_{o1}} \right)$$
(3.10)

Referring to equation 3.10, the first term represents the desired relationship where output current is amplified by a factor of N. However, the second term is undesirable since it adds an offset which is based on the sensor resistance of the working electrode. Simulation is carried out to determine its effects on the linearity between the input and output current.

#### 3.1.2 Transconductance Amplifier

Folded cascode topology has been chosen as the operational amplifier in the current preamplifier because it provides high gain and stability for big load. It is also able to achieve a good tradeoff between noise, output range, and power performance. The input stage consists of PMOS with large area to reduce the flicker noise. The characteristics of the folded cascode amplifier are shown in Table 3.2.

| Parameter              | Values |
|------------------------|--------|
| Gain (dB)              | 78     |
| -3db Bandwidth (kHz)   | 6.5    |
| Phase Margin (°)       | 42.8   |
| Power Consumption (mW) | 1.58   |
| CMRR (dB)              | 106.3  |
| PSRR (dB)              | 45.2   |

Table 3.2 Folded cascode amplifier characterisation

#### 3.1.3 Circuit Level Simulation

A simulation is carried out where the sensor resistance,  $R_s$  at the inverting input of the operational amplifier is swept to generate an input current ranging from 1pA to 1  $\mu$ A to represent the current flows in the WE. The simulation setup is shown in Fig. 3.5. The amplification factor, N is fixed at 10.



Figure 3.4 Schematics of folded cascode OTA

 $I_{out}/I_{in}$  is plotted against sensor resistance in Fig. 3.6 to verify equation 3.10 derived in the previous section. Values obtained from equation 3.10 is plotted in the same graph by using typical values of the parameters as shown in Table 3.3 to allow for comparison. Based on the results in Fig. 3.6, for very large  $R_s$  (> 10<sup>8</sup> $\Omega$ ) or very small input currents, the second term in Eq. 3.10 becomes significant and hence create an upward slope which affects the gain factor.



Figure 3.5 Simulation setup for current preamplifier.

The maximum and minimum input current are determined by a 1 % deviation from N, which is 10 in this case. For current flowing away from the WE, the input current range is between 47.2 pA and 1.2  $\mu$ A whereas for current flowing into WE, the input current range is between 47.2 pA to 1.85  $\mu$ A as illustrated in Fig. 3.7. The maximum input current is limited by the maximum output current of the amplifier while the minimum input current is limited by the undesirable sensor resistance effect.



Figure 3.6 The simulation result (blue) shows  $I_{OUT}/I_{IN}$  increases as the sensor resistance increases. In other words, the output current is no longer linear at low input current. The result is corresponding to line plotted using Equation 3.1 (orange).



Figure 3.7 Graph of  $I_{OUT}$  against  $I_{IN}$  from the simulation results (blue). The maximum and minimum input current range is determined by 1 % deviation from the calculated value (orange).

The output current exhibits a linear relationship with the input current. However, there are distortions at both high and low input current. The non-linearity of the relationship is quantised using the Third-order intercept (IP3 or TOI)[16] as shown in Fig. 3.8. The IP3 points are the same regardless of the direction of current flow. The current preamplifier has an IP3 rating of -1 dBm with reference to the output axis and rating of -23 dBm. It indicates a fairly good linearity since the preamplifier can process 23 dBm of input signal before reaching the intermodulation distortion.



(b) Input current flows into the WE

Figure 3.8 Third-order intercept for quantising the non-linearity of the current preamplifier.

The output current from the current preamplifier is converted into voltage by adding a transimpedance amplifier at the output stage and then converted to a digital output using ADC. In order to produce a detectable output voltage, small current should be amplified for a few times to generate a larger current. Hence, the current preamplifiers are then cascoded together to create gain settings in multiples of 10 as shown in Fig. 3.9. Based on the simulation result in Fig. 3.10, the current preamplifier stages only able to amplify the bidirectional input current ranges between **62.3 pA and 1**  $\mu$ A with less than 1% error. The lower limit of the dynamic range of the input current is worse compared to the single stage current preamplifier due to the cumulative effect of the cascode. Other possible sources of non-idealities such as offset voltage of the folded cascode OTA that introduces different operating points to the first and second double-MOS structure need to be investigated and rectified to ensure the current preamplifier exhibits high linearity across the dynamic range and down to 1 pA.



Figure 3.9 Simulation setup for cascoded current preamplifier for different gain settings.



Figure 3.10 Output current against input current for different gain settings where the dashed lines represent the ideal values of  $I_{OUT}$ . There are large deviation for  $I_{IN}$  less than 62.3 pA.



Figure 3.11 Output voltage against input current for different gain settings.

### 3.2 Switched-Capacitor Integrator

As mentioned in the previous section, there were gain error and offset in amplifying the current especially at extremely low current which affect the linearity. Hence, it limits the dynamic current range of the readout circuit. The switched-capacitor topology is then investigated. To make a fair comparison with the current preamplifier, the switched-capacitor integrator is implemented using the same folded cascode amplifier used in the current preamplifier with the same power consumption, transconductance and output current. A simple switched-capacitor integrator is designed and shown as Fig. 2.6(b). It consists of a folded cascode amplifier, a reset switch and an integrating capacitor.

#### **3.2.1** Circuit-Level Simulation

A similar transient simulation is carried out where a resistor,  $R_s$  is placed at the inverting input of the folded cascode amplifier to generate an input current which represents the current flows in the WE. The switched-capacitor integrator converts the input current directly into voltage. The relationship between output voltage and input current is given by:

$$V_{out} = \frac{1}{C_{int}} \int_0^{\frac{T_{clk}}{2}} I_{in} dt + V_{cm}$$
(3.11)

$$V_{out} = \frac{T_{clk}I_{in}}{2C_{int}} \tag{3.12}$$

where  $T_{clk}$  is the period of the reset clock with 50% duty cycle,  $C_{int}$  is the integrating capacitance and  $V_{cm}$  is the common mode voltage which is 900 mV in this case.

However, there are also two main sources of error [14] in switched-capacitor which are

- 1. the **finite transconductance**,  $G_m$  of the folded cascode transconductance amplifier which causes the input differential voltage of opamp increases when the input current to increase. This effect needs to be eliminated to keep the output voltage as accurate as possible.
- 2. the **on-resistance**,  $r_{on}$  of the low leakage switch which prevents the full discharge of the capacitor during reset.

The relationship of  $V_{out}$  and  $I_{in}$  is shown in equation 3.13 by considering the effects of the two error terms that are previously mentioned.

$$\frac{V_{out}}{I_{in}} = \frac{T_{clk}}{2C_{int}} + r_{on} - \frac{1}{G_m}$$
(3.13)

The maximum input current of the switched-capacitor integrator is only 1.75  $\mu$ A it is limited by the high on-resistance of the switch which creates large voltage drop across it. When input current of 1  $\mu$ A is fed into the circuit, an output voltage is exactly the same as the expected value. However, for an input current less than 10 pA, the output voltage begins to deviate more than 1%. Based on the transient simulation in Fig. 3.13, the output voltage gives a deviation of 1.25 % which is due to

the presence of leakage current in the switch. Nevertheless, this topology still gives a wider dynamic range compared to that of the current preamplifier. The dynamic range can be expanded further by increasing the output voltage of the opamp and replacing the switch with a low-leakage switch.



Figure 3.12 Output voltage of the switched-capacitor for an input current of 1  $\mu$ A integrated at 10 pF capacitor for 5  $\mu$ s. The output voltage is 1.40 which is same as the calculated value.



Figure 3.13 Output voltage of the switched-capacitor for an input current of 10 pA integrated at 50 fF capacitor for 5 ms. The output voltage is 1.7775 V and the deviation is 1.25% from the calculated value.

# 3.3 Comparison

Finally, a comparison between the current preamplifier and switch-capacitor integrator is made and illustrated in Table 3.4. The latter is chosen as the topology for the readout circuit as it is able to offer a wider dynamic input current range. It is also more immune to noise and has a smaller area.

| Topology      | Current Preamplifier                                                                                                                                                                 | Switched-Capacitor Integrator                                                                                                                        |  |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Operation     | Input current is amplified by<br>the current preamplifier and<br>then converted into voltage by a<br>transimpedance amplifier                                                        | Input current is converted directly into current at the capacitor                                                                                    |  |
| Mode settings | Requires stages of current preamplifiers                                                                                                                                             | Onlyrequiresdifferentcombinationsofintegratingfrequenciesand capacitance                                                                             |  |
| Area          | Larger due to multiple opamps for different mode settings                                                                                                                            | Smaller because only one opamp is required for mode settings                                                                                         |  |
| Dynamic Range | 62.3 pA - 1.18 $\mu$ A<br>Lower limit is limited by offset<br>caused by sensor resistance as<br>expressed in (3.10)<br>Upper limit is limited by finite<br>transconductance of opamp | 10 pA - 1.75 $\mu$ A<br>Lower limit is limited by leakage<br>current in the reset switch<br>Upper limit is limited by<br>on-resistance of the switch |  |

Table 3.4 Comparison between current preamplifier and switched-capacitor integrator

## 3.4 Chapter Summary

The current preamplifier is designed and its performance is simulated. It gives a fairly good performance in amplifying the current. However, it suffers from non-linear distortion at very low input current less than 47 pA. Based on the small-signal analysis and the simulation result, an offset is contributed by the sensor resistance from the working electrode which affects the linearity between the input and output current. This is a undesirable characteristic for a analogue sensing circuit. The limitations of the current preamplifier lead to the implementation of a switched-capacitor architecture. A simple switched-capacitor is implemented and designed using the same opamp as the current preamplifier. It shows a significant improvement in the permissible dynamic range. Thus, it is chosen as the analogue part of the readout circuit. However, there is still room of improvement for this topology; for example, replacing the switch with a low-leakage switch. Its implementation process is explained in detail in the next chapter.

# Chapter 4

# **Analogue Circuit**

As described in the previous chapter, the current preamplifier suffers from non-linear distortion at low input current. Its dependence on the sensor resistance is also undesirable. Therefore, the employment of a switched-capacitor architecture will be the main focus in this chapter. Its implementations along with design justifications will be described in the following sections.

The target design specifications of the analogue circuit are listed below:

- 1. Wide dynamic range of input current preferably from 1 pA to 1  $\mu$ A or even beyond the limits. This characteristic can ensure that the readout circuit is able to measure different ranges of current from different metabolites (such as glucose and lactate).
- 2. **High linearity**. The current integrated at the capacitor should increase linearly with integration time, so that the output voltage is very close to the ideal value obtained from the formula V = It/C.
- 3. Low noise. Thus, the readout circuit can have low minimum detectable current and higher accuracy especially in capturing very low input current.
- 4. Low power consumption for power-savings. Static power consumption which typically comes from leakage current, and dynamic power consumption from charging and discharging of capacitive node should be optimised.

In this chapter, the implementations and simulations were carried out in AMS 350nm technology instead of GPDK 180 nm in the previous chapter to allow more voltage headroom during the implementation process.

### 4.1 Switched-Capacitor Integrator

The switched-capacitor integrator as shown in Fig. 4.1a consists of a differential folded cascode amplifier, integrating capacitors and switches. As mentioned in previous chapter, a folded cascode topology is chosen because it provides high gain and stability for a big load. As shown in Fig. 4.2,
large transistors are used for the input differential pair to limit noises such as flicker noise and mismatch which could affect the linearity of the integrating current. The dimensions of the transistors are chosen carefully to ensure they are deep in saturation operating region and work properly under different modes and input current range. The maximum output current of the transconductance amplifier is set close to the maximum input current from the WE to reduce the power consumption. The characteristics of the amplifier is presented in Table 4.1. A reset switch is also added in parallel to the capacitor so that the integration time can be defined. When the switched is opened, the current flows through the capacitor and generate an output voltage,  $V_{int}$ . When the switch is closed, the current flows through the switch and thus the current is no longer integrated at the capacitor.



(a) Switched capacitor integrator. The blue dashed block is the capacitor array.

Figure 4.1 Switched capacitor integrator

(b) Capacitor Array

| Parameter                      | Values  |
|--------------------------------|---------|
| Gain (dB)                      | 92      |
| -3db Bandwidth (kHz)           | 7.5     |
| Phase Margin ( $^{\circ}$ )    | 44.8    |
| Power Consumption (mW)         | 2.39    |
| Max. Output Current ( $\mu$ A) | 14      |
| CMRR (dB)                      | 130.4.3 |
| PSRR (dB)                      | 82.2    |

Table 4.1 Folded Cascode amplifier characterisation



Figure 4.2 Schematic of folded cascode amplifier

The capacitor array consists of 3 capacitors with their corresponding switches, together with different integration times, thus enabling different operating modes to measure the input current with a wide dynamic range. Based on Fig. 4.1b, the smallest capacitor in the array is 625 fF and it is always conducting at all operating modes. Larger capacitors, 3.375 pF and 35 pF only conduct at modes which integrate higher current. For example, all three capacitors are only conducted and connected in parallel to produce a resultant capacitor of 40 pF to integrate input current above 1  $\mu$ A. The advantages of this arrangement of the capacitor array with switches are area savings and high accuracy. The total silicon area occupied by this arrangement is less compared to that of arrangement with 3 capacitors of 40 pF, 5 pF and 625 fF with their respective switches. In addition, there is no switch across the smallest capacitor which would otherwise cause potential distortion at the integrating capacitor at a very low current.

# 4.2 Low-Leakage Switch

The switches of the switched-capacitor have to be designed carefully as they need to limit voltage drop and charge injection. The complementary switch [17] as illustrated in Fig. 4.3 has been chosen because it can offer many advantages; firstly, with proper sizing, it can operate as a small resistor when it is turned off. The equivalent resistance of the switch is given by:

$$R_{eq} = \frac{1}{m_n C_{ox}(\frac{W}{L})_N (V_{DD} - V_{THN}) [m_n C_{ox}(\frac{W}{L})_N - m_p C_{ox}(\frac{W}{L})_P] V_{in} - m_p C_{ox}(\frac{W}{L})_P}$$
(4.1)

Referring to equation 4.1, if the condition in 4.2 is satisfied, then the on-resistance of the switch is independent of the input voltage level. Thus, there is much lesser variation contributed by each switch alone.

$$m_n C_{ox} \left(\frac{W}{L}\right)_N = m_p C_{ox} \left(\frac{W}{L}\right)_P \tag{4.2}$$

Secondly, the charge injection from the switch is also limited. This is because the complementary switch consists of both the PMOS and NMOS, thus they are able to inject opposite charges which cancel out each other when the switch is turned off. Lastly, it only consists of two transistors, thus it can effectively reduce the area. To further improve the performance of the switch in term of speed, delay elements in Fig. 4.3b are added to synchronise the clocks, so that both MOSFET can be turned off simultaneously. However, when the switched-capacitor integrator is at low current mode, the integrated voltage is less than that of the ideal voltage. This is due to the presence of small leakage current that flows through the off-switch. Although the effect of the leakage current is only noticeable when integrating very low current, modifications should be made on the switch to rectify this problem since the readout circuit is expected to operate below 1 pA.



Figure 4.3 Complementary switch. Adapted from [17]

A reset switch is also required to reset the capacitor of the integrator after the sample period and define the integration time. Thus, a low-leakage switch [18] is introduced for both reset switch and switches in capacitor array. The switch is extremely important to limit the voltage drop rate in the switched capacitor integrator and hence, improving the accuracy of the integrated input current. The low-leakage switch structure is implemented based on the floating-body techniques in which an extra lateral transistor, M3 was employed to reduce the leakage as shown in Fig. 4.4. The leakage current is compensated by transistor M3. When transistors M1 and M2 are turned off, their drain leakage current flows in the current path introduced by M3. At the same time, node B of the low leakage switch in Fig. 4.4, hence current flow is limited.



Figure 4.4 Low Leakage Switch

# 4.3 Sample and Hold Circuit

The input current is converted into voltage by the integrator at the first stage and this voltage should be sampled and its value should be stored for a period of time until the next sample stage. A simple switched-capacitor sample and hold circuit as depicted in Fig.4.5 is first implemented. Correlated double sampling [19] technique is introduced to produce output with reduced noise and offset from the signal. However, this topology resets to the common mode voltage at each clock period and thus requires an opamp with high slew rate. There is also a voltage drop across long hold time for this topology.



Figure 4.5 Initial sample and hold circuit. Reprinted from [19]

A wide-band offset compensated sample and hold circuit [19] is then implemented as shown in Fig. 4.6. Anticipatory compensation is introduced in this topology by pre-charging the capacitor, C3 with voltage which is expected during the next stage. Hence, slew rate and settling time can be relaxed. The frequency dependence of the voltage gain of the compensated amplifier can be reduced, and thus

the operation of the circuit can be stable at high frequency.



Figure 4.6 Sample and hold circuit. Reprinted from [19]



Figure 4.7 The operation of sample and hold circuit

At high current, there is a small offset at the inverting input of the opamp in the switched-capacitor integrator. To compensate this effect, the offset is sampled and deducted from the output voltage from the integrator. Hence, the output voltage from the sample and hold circuit is free from the offset.

# 4.4 Comparator

Comparators are used to compare the output voltage from the sample and hold circuit with the reference voltage, so that the digital circuit can change the operating mode of the readout circuit based on

the magnitude of input current. Since comparator is only needed after the integration, a clocked comparator [20] in Fig. 4.8 can be used to reduce the power consumption. The clocked comparator consists of the sense amplifier at the left hand side and NAND gate latch at the right hand side.

The sense amplifier [20] consists of latch formed by transistors M1 - M4. When the clock is low, all the nodes in the circuit are either pulled to VDD or ground due to the latch. This action therefore erases all the previous memory of each nodes of the comparator which is a good characteristics for a comparator. When clock goes high, the two inputs are compared causing the output of the circuit to register which one is higher.



Figure 4.8 Clocked comparator. Reprinted from [20]

### 4.5 Analogue-To-Digital Converter

An analogue-to-digital converter is required at the output of the sample and hold stage to provide a digital output which is proportional to the measured current. A 10 bit-SAR ADC from the AMS Analogue standard cell library is used since it is able to provide up to 10-bits resolution and only occupy a small area.

The conversion range of the ADC can be specified to produce a low LSB, so the resolution of the readout circuit can be increased. This can be achieved by setting the positive reference voltage, VRP and negative reference voltage, VRN of the ADC into both upper and lower limit of the output range which are presented in Table 4.2. The LSB of the ADC can be obtained by

$$LSB = \frac{VRP - VRN}{1024} = \frac{2.65 - 1.525}{1024} = 0.8584mV$$
(4.3)

33



| <b>Current Direction</b> | VRP  | VRN   |
|--------------------------|------|-------|
| Into WE                  | 2.65 | 1.775 |
| Out from WE              | 0.65 | 1.525 |

Table 4.2 Reference voltage setup in ADC for bidirectional current

The input current can thus be determined from the decimated output of the ADC.

# 4.6 **Operation Mode Settings**

As mentioned in section 4.1, the wide dynamic range of the input current is achieved by varying the integration frequency and capacitance. Firstly, the highest integration frequency should be determined. Based on the datasheet of the ADC, the clock frequency of the ADC is 1.1 MHz and it takes 11 clock cycles to complete a single conversion. Thus, the maximum integration frequency that can be used is 100 kHz. The frequency is divided by 8 in the subsequent mode to ease the implementation of the digital part of the circuit at the later stage. Different capacitor is also used to further expand the dynamic range of the input current. The capacitor values are chosen carefully to avoid a large die size. The different mode settings with their respective integration frequency and capacitor are presented in Table 4.3. The lower mode is limited by the minimum capacitance of the AMS410 c35b4 technology which is 89.44 fF and long integration time. The higher mode could be implemented by increasing capacitor size. However, it is not done in this project since the input current from the working electrode is usually less than 20  $\mu$ A and other challenges like power consumption due to high output current, and large die size due to large capacitor size might arise as well.

The input current range presented in Table 4.3 is only the current which gives less than 1% deviation. The current range is actually wider than that. However, the circuit can measure current within  $\pm$  13  $\mu$ A with the minimum input-referred noise of 44 fF. The methods of calculation for minimum



Figure 4.10 Analogue block diagram of the readout circuit where the black box represents the digital circuit for autonomous gain control which will be explained in the next chapter

| Mode | Input Current     | Integration Time | Capacitor |
|------|-------------------|------------------|-----------|
| 0    | 1 - 8 µA          | 5 µs             | 40 pF     |
| 1    | 0.125 - 1 μA      | $5 \ \mu s$      | 5 pF      |
| 2    | 15.63 - 125 nA    | $40 \ \mu s$     | 5 pF      |
| 3    | 1.95 - 15.63 nA   | $320 \ \mu s$    | 5 pF      |
| 4    | 0.24 - 1.95 nA    | 2.56 ms          | 5 pF      |
| 5    | 30.52 - 244.14 pA | 20.48 ms         | 5 pF      |
| 6    | 3.82 - 30.52 pA   | 20.48 ms         | 625 fF    |
| 7    | 0.47 - 3.82 pA    | 163.84 ms        | 625 fF    |

Table 4.3 Different mode settings

input-referred noise will be explained later.

# 4.7 Circuit Level Simulation

The analogue circuit is tested by using parametric simulation in which the working electrode is modelled using a resistor. Different modes are tested to determine its dynamic range and noise.

#### 4.7.1 Dynamic Range

As mentioned in the previous chapter, the two main sources of the error for the switched-capacitor integrator [14] are

- 1. the finite transconductance,  $G_m$  of the folded cascode transconductance amplifier
- 2. the **on-resistance**,  $r_{on}$  of the low leakage switch

Referring back to equation 4.4, to keep the error as low as possible, both  $r_{on}$  and  $G_m$  values need to be adjusted carefully in order to cancel out each other and thus minimise the total offset.

$$\frac{V_{out}}{I_{in}} = \frac{1}{2f_{clk}C_{int}} + r_{on} - \frac{1}{G_m}$$
(4.4)

For this switched-capacitor topology, the dynamic range of the input current with less than 1 % deviation is from 0.47 pA to 8  $\mu$ A. This parameter has improved significantly compared to the switched-capacitor integrator designed in Chapter 3. A graph of output voltage against input current for different mode settings is presented in Fig. 4.11.



Figure 4.11 Output voltage against input current for different mode settings

#### 4.7.2 Noise

The total input-referred current noise  $I_{in}^{2}$  is the minimum detectable current of the switched-capacitor integrator [21]. It needs to be determined for each operating mode. To compute  $I_{in}^{2}$ , the total output voltage noise,  $V_{out}^{2}$  at the sample and hold node is required. This can be done by running periodic steady state analysis (PSS). PSS analysis is carried out to compute the periodic operating point when the circuits are linearised around a periodic steady state operating point. Then, the operating point will be used in subsequent phase noise (Pnoise) analysis. The settings for both analysis is displayed in Table 4.4. Shooting method is chosen for PSS analysis since it can reduce the computational time significantly. The maximum sideband parameter is used in pnoise analysis to determine how much of aliasing should be considered. The default value of 7 is chosen. This is because the simulations will run unnecessarily long if the value is too large or the noise will be underestimated if the value is too small.

| Parameter                | Setting               |
|--------------------------|-----------------------|
| Beat Frequency<br>Engine | $f_{clk}$<br>Shooting |
| Maximum sideband         | 7                     |

Table 4.4 PSS and Pnoise analysis settings

The total output noise is then calculated by integrating the phase noise graph over the -10 dB bandwidth,  $f_{-10dB}$ , which is the noise bandwidth. Next, the relationship between  $I_{in}^2$  and  $V_{out}^2$  is drawn to work out  $I_{in}^2$ .

$$V_{out} = \frac{1}{C_{int}} \int_{0}^{\frac{T_{clk}}{2}} I_{in} dt$$
 (4.5)

$$V_{out} = \frac{T_{clk}I_{in}}{2C_{int}} \tag{4.6}$$

$$I_{in}^{2} = (2C_{int}f_{clk})^{2}V_{out}^{2}$$
(4.7)

The input-referred noise for each mode is presented in Table 4.5. The circuit has a minimum input-referred noise as low as 44 fA at the highest mode.

| Mode | Input Current     | <b>Output Noise</b> $(V^2/Hz)$ | $f_{-10dB}$ | Input-Referred Noise, $I_{in}^2$ |
|------|-------------------|--------------------------------|-------------|----------------------------------|
| 0    | 1 - 8 µA          | 63.1 n                         | 68 k        | 524.3 nA                         |
| 1    | 0.125 - 1 μA      | 68.6 n                         | 76 k        | 72.2 nA                          |
| 2    | 15.625 - 125 nA   | 37.6 n                         | 9.25 k      | 2.3 nA                           |
| 3    | 1.953 - 15.625 nA | 8.4 n                          | 3.17 k      | 802 pA                           |
| 4    | 0.244 - 1.953 nA  | 2.1 n                          | 2.09 k      | 32 pA                            |
| 5    | 30.52 - 244.14 pA | 0.46 n                         | 138.74      | 6.2 pA                           |
| 6    | 3.815 - 30.52 pA  | 0.92 n                         | 160.43      | 117 fA                           |
| 7    | 0.477 - 3.815 pA  | 0.59 n                         | 22.49       | 44 fA                            |

Table 4.5 Output noise and input-referred current noise for different mode settings

# 4.8 Chapter Summary

In this chapter, each part of the switched-capacitor readout circuit is explained in detail. The readout circuit operation is broken down into different operating mode, each for different ranges of input current, thus expanding the input dynamic range of the readout circuit. Different mode settings are achieved by manipulating the integration frequency and capacitance. The switched-capacitor topology shows a significant improvement in terms of dynamic range compared to the circuit designed in Chapter 3. Hence, the switched-capacitor topology is chosen as the analogue readout circuit. Lastly, different operating modes with their respective input-referred noise are presented. However, the readout circuit still requires manual tuning of the frequency and activation of the switches for the capacitors. This leads to the implementation of the digital circuit for autonomous gain control in the next chapter.

# Chapter 5 Digital Circuit

The circuit described in Chapter 4 is able to detect a wide dynamic range of input current. However, the frequency and capacitance need to be changed accordingly to provide a linear measurement. To ease the tuning process, an autonomous gain control algorithm is implemented to vary the mode of the switched-capacitor based on the input current. A mealy state diagram for the autonomous gain control algorithm is presented in Fig. 5.1 and its operation is explained in detail in the following sections. Each arrow represents the conditions that have to be satisfied in order to transition to the other state.



Figure 5.1 Mealy state diagram for AGC

# 5.1 Clock Generator

As mentioned in the previous chapter, different integration frequencies are required for different mode operations. Hence, a clock generator which is capable of generating all the local clocks with the required frequencies from the 100 kHz system clock is needed. Since each local clock frequency is a multiple of 1/8 of the system clock frequency, the design process is very simple and straightforward as shown in Listing 5.1.

```
with i_select select
                                        when "000", ---Mode 0: f = 100kHz, Tint = 5us
    o_c lk_d iv \ll i_c lk
2
                                        when "001", —Mode 1: f = 100 \text{ kHz}, Tint = 5 us
                    i_c1k
                                        when "010", —Mode 2: f = 12.5 \text{ kHz}, Tint = 40 us
                    clk_divider(2)
                                        when "011", --Mode 3: f = 1562Hz, Tint = 320us
                    clk_divider(5)
                                        when "100", ---Mode 4: f = 195Hz, Tint = 2.56ms
                    clk_divider (8)
                                        when "101", --Mode 5: f = 24Hz, Tint = 20.48ms
                    clk_divider(11)
                    clk_divider(11)
                                        when "110", --Mode \ 6: \ f = 24Hz, Tint = 20.48ms
                                        when "111", ---Mode 7: f = 3Hz, Tint= 163.84ms
                    clk_divider(14)
                    i_c1k
                                        when others; --- To initialise the clock
10
```

Listing 5.1 Code snippet of clock generator

clk\_divider is a counter which is added by 1 at each rising edge of the system clock. The LSB of the clk\_divider then has a frequency which is half of the frequency of the system clock. Bit 2 of clk\_divider is thus corresponds to a clock signal with 1/8 of the system clock. The rest of the frequencies correspond to higher bits of clk\_divider. To reduce power consumption, when statements are used so the clock generator only outputs the required frequency based on the bit pattern of i\_select.

# 5.1.1 Clock Optimisation

Although the operation of the clock generator seems fine, the following problems are noticed after a few simulations are carried out.

- 1. The system clock frequency is set at 100 kHz initially to account for 5  $\mu$ s integration time. However, this system clock cannot be used to drive the ADC as it will slow down the conversion as the maximum clock frequency of the ADC is 1 MHz.
- 2. Data acquisition time is long due to long hold time especially in higher mode. This is because the duty cycle of each clock frequency is set at 50 %, long integration time implies long hold time as well.

Long hold time is pointless since the comparator can compare the output voltage with the reference voltage directly after integration. Thus, the hold time can be reduced but the integration time is kept the same as the previous design. Hence, the speed of the readout circuit can be improved significantly. The time for a single conversion in ADC needs to be taken into consideration in deciding the hold time as well. Based on the datasheet of the ADC, the ADC conversion is completed after 11 clock cycles,

thus 12  $\mu$ s is set to be the hold time. The system clock frequency is changed to **1 MHz** to drive both the clock generator and ADC at the same time.

The clock generator now uses a counter, called counthigh, which counts up by one at each rising clock edge of the system clock. For the highest frequency mode, the output clock, o\_clk\_div, stays high for 5 clock cycle to set 5  $\mu$ s of integration time, followed by another counter, called countlow which set the hold time by staying low for another 12  $\mu$ s to allow ADC conversion. Similarly, for the lowest frequency mode, the output clock stays high for 163840 clock cycles and then low for 12 clock cycles. The improvement is obvious especially in low frequency mode since the hold time is 12 clock cycles instead of 163840.

```
case current_state is
       when statehigh =>
         if (counthigh < cycle_no - 1) then
            o_{-}clk_{-}out <= '1';
         else
            o_clk_out <= '1';
6
            current_state <= statelow;
           countlow \leq 0;
         end if;
9
         counthigh <= counthigh + 1;</pre>
10
11
       when statelow =>
         if (countlow < 11) then
13
            o_{c1k_{out}} <= '0';
14
            countlow \ll countlow + 1;
15
         else
16
            o_{-}clk_{-}out <= '0';
            current_state <= statehigh;</pre>
18
            counthigh \leq 0;
19
         end if;
20
       end case;
22
```

Listing 5.2 Code snippet of improved clock generator

# 5.2 Autonomous Gain Control Algorithm

Since each mode yields an output voltage range with respect to their input current range, thus the upper and lower limit of the voltage can be used as a threshold to determine if the circuit should operate at higher or lower mode, or stay at the same current mode. The algorithm of the autonomous gain is explained in detail in the following subsections.

### 5.2.1 Mode Specification Stage

Firstly, the output voltage from the sample and hold,  $V_{out}$  is transferred to the two clocked comparators designed in Chapter 4. The comparators are named **comp\_max** and **comp\_min** respectively. The comp\_max comparator compares the output voltage with a reference voltage which is the upper limit of the voltage range, while the comp\_min comparator compares the output voltage with a reference voltage with a referen



Figure 5.2 The comparator pair setup for bidirectional current

When both comparators go low, it indicates the voltage is well within the output range, thus it should stay in the current mode. If comp\_max goes high while the comp\_min goes low, this indicates the output voltage is higher than the upper limit. In other words, the current is too large. Hence, the integrator needs to shift to a lower state which is capable of measuring larger current. If the comp\_max goes low while the comp\_min goes high, this indicates the output voltage is lower than the lower limit and the input current is too small. Hence, the integrator needs to shift to a higher state to measure small currents. The operation is summarised in Table 5.1.

| comp_max | comp_min | Operation            |  |
|----------|----------|----------------------|--|
| Low      | Low      | Stay at current mode |  |
| High     | Low      | Shift to lower mode  |  |
| Low      | High     | Shift to higher mode |  |

Table 5.1 The operation of the comparator pairs

# 5.2.2 Mode Specification Optimisation

Although the algorithm for mode specification seems sufficient, it is yet to be true; the reason being that it does not consider variations at the input current that are likely to happen. For example, if the measurement takes place when there is a momentary variation at the input current, then the measured current could be big enough to provide a high comp\_max output at the digital block. This is undesirable

as it will lead to a shift to lower mode.

In order to compensate the momentary variation of the input current, the operation of the digital block is expanded. The circuit only changes its mode (i) after N measurements are taken and (ii) if the results from N measurements exceed the threshold values,  $\alpha$  and  $\beta$ . The relationship between N,  $\alpha$  and  $\beta$  are given by:

$$N = \alpha + \beta \tag{5.1}$$

where N is the number of measurements taken,  $\alpha$  is the threshold for readout stage and  $\beta$  is the threshold for changing mode. N is set at 10 to take 10 measurements for decision-making of the next stage. 10 is a fairly good sample size assuming the momentary variations of the current is less than five clock cycles during the mode specification stage.  $\alpha$  and  $\beta$  are set to 5 which is half of the sample size, N.

More specifically, the digital block needs to receive 10 comparator pair outputs measured at the same mode. The mode will only change if more than **five** of them indicate that the mode needs to be changed. Three counters, **count\_readout**, **count\_highstate** and **count\_lowstate** are declared to store the results of each comparator pair output from each rising clock edge. For example, if 6 out of the 10 comparator outputs indicate the current is at the correct operating mode, count\_readout will count up to 6 and the circuit will shift to readout mode with the same mode settings at the next clock phase since **count\_readout** >  $\alpha$ . If 6 of the 10 comparator outputs indicates change to lower mode is required, count\_lowstate will count up to 6 and the circuit will shift to a lower operating mode in the next clock phase since **count\_lowstate** >  $\beta$ . The same goes to count\_highstate. If none of the conditions are satisfied, the circuit will stay in the same mode in the next clock phase. An example of the operation of the counters is summarised in Table 5.2. The code snippet of this operation is shown in Listing 5.3.

| $\texttt{count}_{\texttt{readout}}$ | count_highsate | count_lowstate | Result                 |
|-------------------------------------|----------------|----------------|------------------------|
| $6 (> \alpha)$                      | 2              | 2              | Shift to readout stage |
| 1                                   | 7 (> $\beta$ ) | 2              | Shift to higher mode   |
| 1                                   | 1              | 8 (> $\beta$ ) | Shift to lower mode    |
| 5                                   | 3              | 2              | Stay at current mode   |

#### **Remark:**

count\_readout indicates the output is within the range count\_highsate indicates the output is lower than the range count\_lowstate indicates the output is higher than the range Table 5.2 An example of the operation of counters

```
when s1 =>
      sw1 <= '1';
                        ---switch setting for Mode 1
      sw2 <= '0';
3
      frequency <= "000"; ---frequency setting for Mode 1
      if (count_check = 10) then -- check the counter after getting 10 comp outputs
          if (count_readout > 6) then
            current_s <= readout; ---chenge to readout stage
          elsif (count_highstate > 6) then
9
            current_s <= s2; ---change to higher mode
10
          elsif (count_lowstate > 6) then
            current_s <= s0; ---change to lower mode
                   else
13
                     current_s <= s1; --- stay at current mode
14
          end if;
15
```

Listing 5.3 Code snippet of the counter operation at Mode 1

In extreme cases where the input current is beyond the limit of the measurement of the switched-capacitor integrator, the limit\_ind signal of the digital block will be high to indicate the readout circuit has reached its limit and unable to measure the current. For example, if the input current is very large, the circuit will stay at the lowest operating mode and limit\_ind will be high.

# 5.2.3 Readout Stage

After mode specification stage where the circuit has changed to the correct operating mode with respect to the input current, the circuit will shift to the readout stage where the output voltage is passed to ADC. After taking 10 data, the circuit should shift back to previous mode of the mode specification stage since the input current will most likely at the same decade. Based the description of the algorithm, it can be seen that the ADC is not used at the mode specification stage. Turning on the ADC only at the readout stage will lead to a significant reduction in power consumption of system. The reason for that is that the ADC is a power intensive block which consumes significant amount of power if operates continuously. In order to turn on the ADC, an extra **start** signal which is usually low is declared in the digital block. The signal is only high at the readout stage to start the ADC.

```
when readout =>
if (count_data < 10) then ---check if 10 data are collected
start <= '1'; ---start the ADC
count_data <= count_data + 1;
current_s <= readout; ---collect next data
else
current_s <= previous_s; ---return to the previous stage
count_data <= 0; ---reset the counter
end if;</pre>
```

#### Listing 5.4 Code snippet of the readout stage

### 5.2.4 Hysteresis Operation

To further improve the stability of the readout circuit, hysteresis operation is added into the digital block operation. This modification can ensure the circuit does not oscillate between different states without entering the readout stage. The hysteresis operation can be done by altering both threshold values,  $\alpha$  and  $\beta$ . For example, if the previous state is readout stage, then current mode is most likely the correct mode for the input current assuming there is no significant changes in decades in the input current.  $\alpha$  is then changed to 3 while  $\beta$  is changed to 7. The value of 3 is chosen to make the circuit more difficult to change its mode. Hence, the circuit will tend to stay in the same mode and then shift to readout state to read the data unless the change in input current is large and long enough to trigger changes in mode.  $\alpha$  and  $\beta$  values will reset to 5 if the previous stage is not readout. Table 5.3 summarises the threshold values for hysteresis operation.

| Parameter | Without Hysteresis | With Hysteresis |
|-----------|--------------------|-----------------|
| $\alpha$  | 5                  | 3               |
| eta       | 5                  | 7               |
| N         | 10                 | 10              |

Table 5.3 The threshold values for different conditions

```
if (previous_s = current_s) then
        threshold := 3; ---change the threshold if previous stage is readout
      else
        threshold := 5; -- typical threshold
      end if:
      case current_s is
      when s0 =>
        sw1 <= '1';
10
        sw2 <= '1';
11
        frequency \leq "000";
12
13
        if(count_check = 10) then
14
          if (count_readout > threshold) then -- threshold for readout
15
             current_s <= readout;
16
          elsif (count_highstate > 10-threshold) then -- threshold for mode change
17
             current_s <= s1;
18
          elsif (count_lowstate > 10-threshold) then
19
             limit_ind <= '1'; -- limit indicator</pre>
20
             current_s \ll s0;
          end if;
```

#### Listing 5.5 Code snippet of the hysteresis operation

In a nutshell, the addition of hysteresis operation makes the overall system more stable and tends to stay at the current mode for readout. Thus more data can be collected during readout instead out keep on changing mode due to the effects of noise. The values of N,  $\alpha$  and  $\beta$  could be designed in such a way that they can be varied based on the nature of the analytes and the sensing environment to further improve the hysteresis.

# 5.3 RTL Simulation

The description language chosen for the design of the digital block is VHDL. The VHDL is chosen because it can be used across all programmable logic and ASIC technologies and thus allow design migration path. It is also a standard and supported by all major tools vendor. Most importantly, VHDL is a strongly-typed language. As a result, designs written in VHDL are considered self-documenting and ease the debugging process [22]. The complete codes were developed and shown in the Appendix.

# 5.3.1 Clock Generator

The VHDL code for the clock generator called **freq\_select** is imported and its symbol is generated as shown in Fig. 5.3. It consists of three inputs and an output clock. RTL simulation is then carried out using ModelSim simulator to test the behaviour of the digital block. The result of the simulation for the clock generator is shown in Fig. 5.4. Based on the result, the frequency generator operates as expected and generates clock signal with the correct frequency based on the bits of the i\_select. For example, when i\_select is 000, the generator outputs a clock signal which stays high for 5 system clock cycles and low for 12 system clock cycles. When i\_select is 010, the clock signal stays high for 40 cycles.



Figure 5.3 Symbol of clock generator.



i\_select to define output clock

Figure 5.4 RTL simulation for clock generator.

#### 5.3.2 Autonomous Gain Control

The autonomous gain control algorithm is also tested using ModelSim simulator. The VHDL code for the autonomous gain control is imported and the symbol generated is shown in 5.5. The state for the operation begins at Mode 0 and then transitions to other states depending on the number of each counter after ten clock cycles. Fig. 5.6 shows the state changes from S0 to readout stage. After 10 counts by count\_check, count\_readout has exceeded the threshold which is 5 in this case, then the state changes to readout. During readout stage, start signal stays high to initiate the ADC and count\_data begins to count the data collected. After 10 data have collected, the state returns to S0 again.



Figure 5.5 Symbol of autonomous gain control circuit



Figure 5.6 RTL simulation shows the transition to the readout stage by following steps 1 to 9

The hysteresis operation can be observed when the state is returned from the readout stage where the threshold has changed to 3. Thus the digital circuit will transition to readout stage as long as count\_readout is more than 3 as shown in Fig. 5.7.



Figure 5.7 RTL simulation continued from Fig. 5.6. The hysteresis operation is shown by following steps 1 to 4.

# 5.4 Chapter Summary

Chapter 5 describes two main blocks of the digital circuits, the clock generator and autonomous gain control circuit. The operation principles and the algorithm of the VHDL codes are explained in detail. The additional features such as hysteresis and power saving modifications were made to improve its performance. A mealy state diagram is also drawn to summarise the operation of the autonomous gain control algorithm. RTL simulations for each digital block are carried out and presented at the end of the chapter. The whole system which consists of both analogue and digital circuits are simulated in the next chapter.

# Chapter 6

# **System Level Simulation**

The overall system block diagram combining both analogue and digital blocks is presented in Fig. 6.1. System level simulations are carried out to verify the overall performance of the readout circuit. The simulation results are presented in the following sections. The two stages of the system is also illustrated in Fig. 6.2.



Figure 6.1 Readout circuit system block diagram

| Mode Specification Stage           | Readout Stage                                  |       | Mode Specification Stage           | Readout Stage                               |
|------------------------------------|------------------------------------------------|-------|------------------------------------|---------------------------------------------|
| Determination of the suitable mode | 10 measurements at the<br>correct mode setting | ••••• | Determination of the suitable mode | 10 measurements at the correct mode setting |

Figure 6.2 The two stages of the digital block

# 6.1 Transient Simulation

In transient simulation, different input currents are applied to the readout circuit to model the behavior and test the performance of the readout circuit. Due to the extremely long simulation time of AMS simulation, most of the transient simulations in this section are performed at lower modes.

#### 6.1.1 Constant Input Current

The system is first tested with a constant input current to observe the mode specification stage and readout stage. In this simulation, an input current of 62.5 nA is transferred into the system. As seen in Fig. 6.3, the readout circuit begins to integrate the input current at Mode 0 settings. However, the integrated voltage is not large enough to provide detectable a measurement. The circuit then changes to Mode 1 where a smaller integration capacitor is used but the integrated voltage is still small. At Mode 2, the integration time is then increased. Hence, the output voltage is now within the voltage range, thus the digital circuit generates a high start signal to initiate the readout stage. The output voltage is converted into 10-bits digital output and 10 data are collected during readout stage. As shown in Fig. 6.3, all the ADC outputs are 0110110111 in hex, or 439 in decimal.

To determine the input current from the ADC output, the integrated voltage needs to be determined first. This can be done by reverse calculation:

$$V_{out} = VRN + 439 \times 1LSB \tag{6.1}$$

$$V_{out} = 1.775 + 439(0.8545m) \tag{6.2}$$

$$V_{out} = 2.15$$
 (6.3)

Given the integrating capacitor and time for Mode 1 is 5 pF and 40  $\mu$ s respectively, the input current can therefore be determined. The calculated input current is corresponding to the input current applied at the readout circuit.

$$I_{in} = \frac{C_{int}(V_{out} - V_{cm})}{t_{int}} \tag{6.4}$$

$$I_{in} = \frac{5 \times 10^{-12} \times (2.15 - 1.65)}{40 \times 10^{-6}} \tag{6.5}$$

$$I_{in} = 62.5nA \tag{6.6}$$



Figure 6.3 Readout circuit operation for a constant input current. At Mode 0, both switches are closed. However, the current is too small to generate a significant output voltage. The circuit then changes its operating mode at Mode 1 where SW1 is opened but the output voltage is still small. At Mode 2 where the integration time has increased, the output voltage is well-within the range. Lastly, the circuits begin to start ADC to take measurements in readout stage and return to Mode 2 again.

### 6.1.2 Noisy Input Current

Although the readout circuit is able to generate an accurate output based on the simulation and calculation in the previous section, however this is not a good justification on the performance of the readout circuit. In the real sensing environment, there will be a lot of noise in the sensor current from the working electrode due to the electrode-analyte interface, concentration of analyte [23], electrode asymmetry [24] or interferences from other electro-active molecules in the solution or the presene of nano-structures [25].

To model such signal, current with momentary spikes and variations is generated using vpwl. The simulation setup is shown in Fig. 6.4. The spikes generated are large and span across wide range in short time. This signal is then transferred to the readout circuit to determine if the system is capable of detecting the current accurately.



**Readout Circuit** 

Figure 6.4 Simulation setup for noisy input current simulation.

Owing to the 10 measurements taken during the mode specification stage, the system managed to transition to an appropriate mode. However, the noise in the input signal does affect some of the ADC outputs collected during the readout stage. This is because the momentary current spikes are integrated at the capacitor as well. By taking the average of the 10 ADC outputs, the input current obtained is **61.3 nA**. There is an offset in voltage source due to the spike. This offset is calculated and gives an average of 3.3374 V. Thus, the average input current generated due to the noisy source is approximately **61.1 nA** which is very close to the current calculated from ADC output.

To rectify the noise problem, differential sensing by using a second WE [26, 27] to sense the background current and then subtract it from the main WE to obtain a noiseless differential input. This technique is suitable for glucose and lactate with gradually changing concentration. For metabolites like dopamine with rapid changing, technique like sensing the background current in the absence of the biomolecules and then performing subtraction from the sensor current [28] can be adopted.



Figure 6.5 Readout circuit operation for an input current with noise. In the presence of noise, the readout circuit still managed to transition to a suitable mode. However, the ADC output is affected.

### 6.1.3 Varying Input Current

In the real sensing environment, the current from the WE is always changing due to the changes in concentration of analytes in biochemical events. To characterise how fast the system responds to a change in current, an input current with sudden change is applied to the system. Fig. 6.6 illustrates how the system responds to an input current with sudden changes from **250 nA to 45.54 nA**. The changes span over a decade and thus a change in mode is expected.

At the beginning, a current of 250 nA flows into the WE and causes the discharge of the integrating capacitor. This current is too small for Mode 0 to produce detectable output voltage changes. Hence, the circuit transitions to Mode 1 where the integrating capacitor becomes smaller. Initially, during the first three clock cycles, the current is sufficient to produce an output voltage which is within the range but there is a sudden change of current to 45.54 nA. Hence, Mode 1 is now not suitable for measuring this current. Owing to the threshold value set, the circuit then changes to Mode 2 despite there are 3 values which indicate the system should stay in Mode 1. At Mode 2, the circuit then performs readout by starting the ADC conversion. The output of the ADC is -278 in decimal. Since the VRN for current flowing into WE is 1.525V, the current can be determined by:

$$V_{out} = 1.525 - 278(0.8545m) = 1.287V$$
(6.7)

$$I_{in} = \frac{5 \times 10^{-12} \times (1.65 - 1.287)}{40 \times 10^{-6}} \tag{6.8}$$

$$I_{in} = 45.4nA \tag{6.9}$$

After the readout stage at Mode 2, the current changes back to 250 nA. The integrating capacitor now discharges rapidly and output voltage is below the lower limit of the voltage range. After mode specification stage, the system transitions back to Mode 1 and then begins the readout stage. The output of the ADC is -144 which corresponds to 250 nA of input current.

$$V_{out} = 1.525 - 144(0.8545m) = 1.4V \tag{6.10}$$

$$I_{in} = \frac{5 \times 10^{-12} \times (1.65 - 1.4)}{5 \times 10^{-6}} \tag{6.11}$$

$$I_{in} = 250nA \tag{6.12}$$



Figure 6.6 Readout circuit operation for a varying input current. The readout circuit transitions to a suitable mode based on the input current and performs ADC conversion during readout stage.

To express the relationship of the mode transition time with respects to the changes in current. A timing diagram in Fig. 6.7 is drawn.



Figure 6.7 Mode transition timing diagram.

The mode transition time is the time taken where for the system to transition to the next mode given the current has reached the current limit of a particular mode. In Fig. 6.7,  $\Delta I$  is the change in current to the mode limit and  $\Delta t$  is the time taken to the next rising clock edge from the time where current has reached the limit of a mode. Thus, the **single mode transition time**,  $t_m$  is given by:

$$t_m = \Delta t + t_{total} \tag{6.13}$$

Since  $\Delta t$  is negligible, thus

$$t_m = t_{total} = (10 - n)T_m \tag{6.14}$$

where n is the n-th rising clock edge and  $T_m$  is the period of mode clock cycle.  $T_m$  for each mode is given in Table 6.1.

| Mode $(i)$               | 0  | 1  | 2  | 3   | 4    | 5     | 6     | 7      |
|--------------------------|----|----|----|-----|------|-------|-------|--------|
| $m{T}_{m(i)}$ ( $\mu$ s) | 17 | 17 | 52 | 332 | 2572 | 20492 | 20492 | 163852 |
|                          |    |    |    |     |      |       |       |        |

Table 6.1 Period of clock cycle for each mode

A general equation for mode transition timing from Mode i to Mode j is given by equation 6.15.

$$t_{m(i-j)} = (10-n)T_{m(i)} + 10T_{m(i+1)} + \dots + 10T_{m(j)}$$
(6.15)

A ramp input current is also applied to the system as shown in Fig. 6.8. When the input current is ranging from 1  $\mu$ A to 8  $\mu$ A, the system operates in Mode 0. For current lower than 1  $\mu$ A, the system begins to transition to lower mode. As the input current rises again, the system transitions backward to Mode 0.



Figure 6.8 Mode transition for ramp input current

# 6.2 Parametric Simulation

Parametric simulation is performed by varying the input current and plot its operating mode. However, due to extremely long simulation time, the parametric simulation is only carried out up to input current range of Mode 4. The result of the simulation in Fig. 6.9 gives a staircase plot where the operating mode is higher for lower current as expected.



Figure 6.9 Mode versus input current

# 6.3 Chapter Summary

In this chapter, an overview of the system block diagram is presented. The operation of the readout circuit is demonstrated via transient simulations under different conditions, for example constant, noisy and varying input current. The mode specification stage and readout stage are performed by the readout circuit and a correct ADC output is generated. The mode transition timing equation is also derived and explained to determine the time taken to transition from one mode to the next mode with respect to the changes in input current. Lastly, parametric simulation is performed to show the relationship of mode with input current in which the circuit operates at lower mode for higher current and higher mode for lower current. In a nutshell, the performance of the readout circuit is able to perform autonomous gain control to measure a wide dynamic range of input current and has fulfilled the project goal.

# **Chapter 7**

# Layout

In this chapter, the layouts of the analogue and digital part are presented, and the techniques used are described in detail.

# 7.1 Analogue Layout

The input differential pair of the folded cascode amplifier are split into smaller transistors and then interdigitated in a common-centroid configuration [29], where the PMOS transistors are laid symmetrically about a common center in the layout. This can be seen in the layout of both the switched-capacitor integrator and the sample and hold circuit as illustrated in Fig. 7.1 and Fig. 7.2 respectively. This technique allows the two transistors to cancel process gradient in both the x and y directions and expose both devices to heat source(s) in an identical manner. Thus, the sensitivity due to process variation and mismatch can be reduced. They are also stacked together at their common drain and source to reduce total width of the device. Dummies are also placed at both sides of the differential amplifier. Furthermore, a localised guard rings are used to surround each transistor pair to reduce the substrate noise [30]. All the analogue circuits passed the DRC and LVS rules.

# 7.2 Digital Layout

The digital circuit layout is carried out using Cadence Genus and Innovus. However, the digital layout is yet to be completed at this stage due to time constraint and lack of technical supports. In addition, this is the first time for the author to do digital layout using Genus and Innovus since previous digital layout is done in Cadence RC complier and Encounter. Nevertheless, the design flow charts of digital synthesis and Place & Route (P&R) are presented in Fig. 7.4 as a reference for future work.



Figure 7.1 Layout for switched capacitor integrator



Figure 7.2 Layout of sample and hold circuit



Figure 7.3 Layout of clocked comparator



Figure 7.4 Digital synthesis and P&R flow using Genus and Innovus
# **Chapter 8**

# Conclusion

#### 8.1 Conclusion

In hindsight, this project was an ambitious undertaking, which required not only a huge number of implementations and modifications of the analogue part, but also the employment of the novel digital circuit which is able to perform autonomous gain control. In addition, there were many challenges faced in this project, for example, improving the accuracy of the analogue part, designing the digital circuit for AGC for the first time, handling Cadence tools for analysis and simulations etc. Ultimately all of them were done successfully, given that individual part of the readout circuit has been shown to operate successfully, and can fulfill all the target specifications. A comparison of the designed readout circuit with the state-of-the-art readout circuits is presented in Table 8.1.

|              | Circuit Structure                 | Current Range |                          | Dynamic | Autonomous |
|--------------|-----------------------------------|---------------|--------------------------|---------|------------|
|              |                                   | Min           | Max                      | Range   | Gain       |
| TCAS'07[5]   | Current to Time                   | 1 pA          | 1 nA                     | 60 dB   | No         |
| TBCAS'13[13] | Current to Frequency              | 24 pA         | $0.35 \ \mu A$           | 83 dB   | No         |
| TBCAS'07[7]  | Feedback modulated $\Sigma\Delta$ | 0.1 pA        | $\pm 0.5 \ \mu \text{A}$ | 134 dB  | No         |
| TBCAS'16[8]  | Input modulated $\Sigma\Delta$    | 0.1 pA        | $16 \ \mu A$             | 164 dB  | No         |
| TBCAS'17[14] | Switched-Capacitor                | 0.47 pA       | $\pm 20~\mu { m A}$      | 153 dB  | No         |
| TCAS'13[9]   | Current Conveyor                  | 8.6 pA        | $\pm 350 \text{ nA}$     | 92 dB   | No         |
| JCCS'09[15]  | <b>Current Preamplifier</b>       | 1 fA          | $\pm 1 \mu A$            | 180 dB  | No         |
| This work    |                                   | 44 fA         | $\pm$ 13 $\mu A$         | 169 dB  | Yes        |

Table 8.1 Comparison between state-of-the-art of the amperometric current readout circuits

The readout circuit introduced in this report can measure currents within  $\pm 13 \ \mu$ A with a minimum input-referred noise of 44 fA. The dynamic range of the designed readout circuit is 169 dB. The autonomous gain control system with hysteresis operation was implemented and demonstrated for the first time using simple state machine. The autonomous gain control readout circuit functions well

as a whole, and can potentially expand the market of biosensors significantly. Since biosensor plays a crucial role in personalised health care, the introduction of autonomous gain control can encourage people to use biosensors for their personal healthcare, thus improving their health care quality. It is believed that this project has created the basis of autonomous operation for readout circuits which pushes the boundary of the development of point-of-care diagnostics and the quality of clinical or non-clinical analyses.

## 8.2 Achievements

At the end of the project, the following tasks were completed:

- Investigate the current preamplifier topology for readout circuits and derive the small-signal relationship of the circuit.
- Implement a readout circuit which is capable of measuring input current with a wide dynamic range.
- Implement a digital circuit to perform autonomous gain control using hardware descriptive language.
- Analyse and simulate the operations of the readout circuit system under different conditions.

### 8.3 Future Work

While the project mostly focused on the implementations and analysis towards the goals of the project, and has achieved most of the target specifications, there are still a lot of future works that could be done to improve the circuit. Since the project has a deadline, there is a need to definitively decide to stay with the design in order to complete the remaining work in time. Hence, this section will highlight a few possibles further works and suggestions which would be worth investigating.

- Implement an internal system clock generator. Due to time constraint, the internal clock generator is not implemented. This could be done easily by designing an oscillator using a series of inverter. However, more effort should be put to ensure the error in clock is as low as possible since the precision of the switched-capacitor readout circuit is highly dependent on the integration time.
- Implement a system to change the reference voltages for comparator and ADC with respects to the direction of current flows. This can be achieved easily by using another comparator.
- Implement a circuit which gives an accurate reference circuit. Currently, the readout circuit depends on the external reference voltages for the comparator. A voltage regulator could be used to generate the voltage references from VDD or VCM.

- Run simulation using the actual current data points collected from a sensor. Although the readout circuit is tested with different input currents, however it is not sufficient. By running simulation using current generated from sensor can give a more reliable indication of the readout circuit performance.
- Improve the layout of the readout circuit. Although the layout shown in Chapter 7 adapts most of the proper techniques in designing the layout, however, there are still room for improvements For example, split the capacitor into unit capacitance and arrange them in common centroid configuration to reduce mismatch, noise and hence, improve the linearity. Dummy switches and capacitors can be added as well. Extra silicon area can be filled by decoupling capacitor to avoid waste of silicon area and also suppress high frequency noise at the same time. More efforts should be put on the components which will give more parasitic capacitance.

# **Appendix A**

## **VHDL Code**

### A.1 Clock Generator

```
1 library ieee;
 use ieee.std_logic_1164.all;
 use ieee.numeric_std.all;
3
  entity freq_select is
5
  port (
6
   i_clk
                  : in
                          std_logic;
7
    i_rst
                  : in
                          std_logic;
8
                          std_logic_vector(2 downto 0);
    i_select
                  : in
9
    i_select : in std_log1c_v
o_clk_div : out std_logic);
10
11 end freq_select;
12
13 architecture rtl of freq_select is
14
  signal clk_divider : unsigned(14 downto 0):= "00000000000000";
16
17
  begin
18
19
  p_clk_divider: process(i_rst,i_clk)
20
21 begin
    if (i_rst = '1') then
22
      clk_divider \ll (others = >'0');
23
    elsif(rising_edge(i_clk)) then
24
      clk_divider <= clk_divider + 1;
25
    end if;
26
27 end process p_clk_divider;
28
29 with i_select select
  o_clk_div \ll i_clk
                            when "000",
30
           clk_divider(2) when "001",
31
            clk_divider(5) when "010",
32
```

```
      33
      clk_divider(8)
      when "011",

      34
      clk_divider(11)
      when "100",

      35
      clk_divider(14)
      when "101",

      36
      '0'
      when others;

      37
      end rtl;
```

### A.2 Improved Clock Generator

```
architecture rtl of freq_select is
2 type state_type is (statehigh, statelow);
3 signal current_state: state_type;
4 signal counthigh : integer range 0 to 163841 :=0;
  signal countlow : integer range 0 to 11 := 0;
  signal cycle_no : integer range 0 to 163841 :=0;
  begin
  process(i_rst,i_clk, i_select)
10
11
12
 begin
    if(i_rst = '1') then
13
      o_{-}clk_{-}out <= '0';
14
15
    elsif(rising_edge(i_clk)) then
16
         if (i_select <= "000") then
17
           cycle_no <= 5;
18
         elsif(i_select <= "001") then
19
           cycle_no <= 5;
20
         elsif (i_select <= "010") then
           cycle_no <= 40;
         elsif (i_select <= "011") then
23
           cycle_no \ll 320;
24
         elsif (i_select <= "100") then
25
          cycle_no <= 2560;
26
         elsif (i_select \leq "101") then
27
           cycle_no <= 20480;
         elsif (i_select <= "110") then
29
          cycle_no <= 20480;
30
         elsif (i_select <= "111") then
31
           cycle_no <= 163840;
32
        else
33
           cycle_no <= 1;
34
        end if;
35
36
      case current_state is
37
      when statehigh =>
38
```

```
if (counthigh < cycle_no - 1) then
39
            o_clk_out <= '1';
40
         else
41
            o_clk_out <= '1';
42
            current_state <= statelow;
43
            countlow \leq 0;
44
         end if;
45
         counthigh <= counthigh + 1;</pre>
46
47
       when statelow =>
48
         if (countlow < 11) then
49
            o_{c1k_{out}} <= '0';
50
            countlow \leq countlow + 1;
51
         else
52
            o_{c1k_{out}} <= '0';
53
            current_state <= statehigh;
54
            counthigh \leq 0;
55
         end if;
56
57
       end case;
58
    end if;
59
60 end process;
61 end rtl
```

### A.3 Autonomous Gain Control

```
library ieee;
  use ieee.std_logic_1164.all;
2
  use ieee.numeric_std.all;
  entity agc_algorithm is
  port (
6
    clk : in std_logic;
7
    reset : in std_logic;
8
   comp_max : in std_logic;
9
    comp_min : in std_logic;
10
    start : out std_logic;
11
   sw1 : out std_logic;
    sw2 : out std_logic;
13
    frequency: out std_logic_vector(2 downto 0);
14
    limit_ind : out std_logic);
15
 end entity agc_algorithm;
16
17
18 architecture structural of agc_algorithm is
    type state_type is (s0, s1, s2, s3, s4, s5, s6, s7, readout); --- state declaration
19
    signal current_s , previous_s: state_type;
20
```

```
signal count_check: integer range 0 to 10 :=0;
    signal count_highstate: integer range 0 to 10 :=0;
22
    signal count_lowstate: integer range 0 to 10 :=0;
23
    signal count_readout: integer range 0 to 10 :=0;
24
25
    signal count_data: integer range 0 to 11 :=0;
26
27 begin
  ---clocked part
28
29 process (clk, reset, comp_max, comp_min)
    variable threshold : natural range 0 to 10 := 5;
30
31
32 begin
    if (reset = '1') then
       current_s <= s4; ---default state on reset</pre>
34
35
    elsif (rising_edge(clk)) then
36
       limit_ind <= '0';</pre>
37
       if (previous_s = current_s) then
38
         threshold := 3;
39
       else
40
         threshold := 5;
41
      end if;
42
43
       case current_s is
44
45
                        ----Mode 0: Period: 10us Capactior: 40pF---
46
      when s0 =>
47
48
         sw1 <= '1';
49
         sw2 <= '1';
50
         frequency <= "000";
51
52
         if(count_check = 10) then
53
           if (count_readout > threshold) then
54
             current_s <= readout;
55
           elsif (count_highstate > 10-threshold) then
56
             current_s \ll s1;
57
           elsif (count_lowstate > 10-threshold) then
58
             limit_ind <= '1';
59
             current_s <= s0;
60
           end if;
61
           count_readout <= 0;
62
           count_highstate <= 0;</pre>
63
           count_low state <= 0;
64
           count_check \ll 0;
65
           previous_s <= current_s;</pre>
66
67
68
         else
           if ((comp_max = '0') AND (comp_min = '0')) then
69
             count_readout <= count_readout + 1;</pre>
70
```

```
elsif (comp_max = '0' AND comp_min = '1') then
71
              count_highstate <= count_highstate + 1;</pre>
            elsif (comp_max = '1' AND comp_min = '0') then
73
              count_lowstate <= count_lowstate + 1;</pre>
74
            end if:
75
            count_check \ll count_check + 1;
76
          end if;
77
          start <= '0';
78
79
                            -Mode 1: Period: 10us Capactior: 5pF-
80
        when s1 =>
81
         sw1 <= '1';
82
         sw2 <= '0';
83
         frequency <= "000";</pre>
84
85
          if(count_check = 10) then
86
            if (count_readout > threshold) then
87
              current_s <= readout;
88
            elsif (count_highstate > 10-threshold) then
89
              current_s \ll s2;
90
            elsif (count_lowstate > 10-threshold) then
91
              current_s <= s0;
92
            end if;
93
            count_readout <= 0;
94
            count_highstate <= 0;
95
            count_low state <= 0;
96
            count_check <= 0;</pre>
97
            previous_s <= current_s;</pre>
98
99
          else.
100
            count_check <= count_check + 1;</pre>
101
            if (comp_max = '0' AND comp_min = '0') then
102
              count_readout <= count_readout + 1;</pre>
103
            elsif (comp_max = '0' AND comp_min = '1') then
104
              count_highstate <= count_highstate + 1;</pre>
105
            elsif (comp_max = '1' AND comp_min = '0') then
106
              count_lowstate <= count_lowstate + 1;
107
            end if;
108
          end if;
109
          start <= '0';
                           -Mode 2: Period: 80us Capactior: 5pF-
        when s2 =>
113
         sw1 <= '1';
114
         sw2 <= '0';
115
         frequency <= "001";
116
117
          if(count_check = 10) then
118
            if (count_readout > 5) then
119
              current_s <= readout;
120
```

```
elsif (count_highstate > 5) then
              current_s <= s3;
122
            elsif (count_lowstate > 5) then
123
              current_s <= s1;
124
            end if:
125
            count_readout <= 0;
126
            count_highstate <= 0;
127
            count_low state <= 0;
128
            count_check \ll 0;
129
            previous_s <= current_s;</pre>
130
         else
            if (comp_max = '0' AND comp_min = '0') then
133
              count_readout <= count_readout + 1;</pre>
134
            elsif (comp_max = '0' AND comp_min = '1') then
135
              count_highstate <= count_highstate + 1;
136
            elsif (comp_max = '1' AND comp_min = '0') then
137
              count_lowstate <= count_lowstate + 1;
138
            end if;
139
            count_check <= count_check + 1;</pre>
         end if:
141
         start <= '0';
142
                            -Mode 3: Period: 640us Capactior: 5pF-
144
        when s3 =>
145
         sw1 <= '1';
         sw2 <= '0';
147
         frequency \leq "010";
148
         if(count_check = 10) then
150
            if (count_readout > 5) then
              current_s <= readout;
            elsif (count_highstate > 5) then
153
              current_s <= s4;
154
            elsif (count_lowstate > 5) then
              current_s <= s2;
            end if:
            count_readout <= 0;
158
            count_highstate <= 0;
159
            count_low state <= 0;
160
            count_check \ll 0;
            previous_s <= current_s;</pre>
162
         else
164
            if (comp_max = '0' AND comp_min = '0') then
165
              count_readout <= count_readout + 1;</pre>
            elsif (comp_max = '0' AND comp_min = '1') then
167
              count_highstate <= count_highstate + 1;</pre>
168
            elsif (comp_max = '1' AND comp_min = '0') then
              count_lowstate <= count_lowstate + 1:
170
```

140

143

146

149

155

156

157

161

163

166

169

```
end if;
171
            count_check <= count_check + 1;</pre>
          end if;
173
          start <= '0';
174
175
                          -Mode 4: Period: 5.12ms Capactior: 5pF-
176
        when s4 =>
         sw1 <= '1':
178
         sw2 <= '0';
179
         frequency \leq "011";
180
181
          if(count_check = 10) then
182
            if (count_readout > 5) then
183
              current_s <= readout;
184
            elsif (count_highstate > 5) then
185
              current_s <= s5;
186
            elsif (count_lowstate > 5) then
187
              current_s <= s3;
188
            end if;
189
            count_readout <= 0;
190
            count_highstate <= 0;
191
            count_low state <= 0;
192
            count_check \ll 0;
193
            previous_s <= current_s;</pre>
194
          else
195
            if (comp_max = '0' AND comp_min = '0') then
196
              count_readout <= count_readout + 1;</pre>
197
            elsif (comp_max = '0' AND comp_min = '1') then
198
              count_highstate <= count_highstate + 1;
199
            elsif (comp_max = '1' AND comp_min = '0') then
200
              count_lowstate <= count_lowstate + 1;
201
202
            end if;
            count_check <= count_check + 1;</pre>
203
          end if;
204
          start <= '0';
205
206
                            -Mode 5: Period: 40.96ms Capactior: 5pF-
207
        when s5 =>
208
         sw1 <= '1';
209
         sw2 <= '0';
          frequency <= "100";
          if(count_check = 10) then
213
            if (count_readout > 5) then
214
              current_s <= readout;
215
            elsif (count_highstate > 5) then
216
              current_s <= s6;
218
            elsif (count_lowstate > 5) then
              current_s <= s4;
219
            end if;
220
```

```
count_readout <= 0;
   count_highstate <= 0;
   count_low state <= 0;
   count_check \ll 0;
   previous_s <= current_s;
 else
   if (comp_max = '0' AND comp_min = '0') then
     count_readout <= count_readout + 1;</pre>
   elsif (comp_max = '0' AND comp_min = '1') then
     count_highstate <= count_highstate + 1;</pre>
   elsif (comp_max = '1' AND comp_min = '0') then
     count_lowstate <= count_lowstate + 1;</pre>
   end if;
   count_check <= count_check + 1;</pre>
 end if:
 start <= '0';
                -Mode 6: Period: 40.96ms Capactior: 625fF-
when s6 =>
 sw1 <= '0';
 sw2 <= '0';
 frequency <= "100";</pre>
 if(count_check = 10) then
   if (count_readout > 5) then
     current_s <= readout;
   elsif (count_highstate > 5) then
     current_s <= s7;
   elsif (count_lowstate > 5) then
     current_s <= s5;
   end if:
   count_readout <= 0;
   count_highstate <= 0;
   count_lowstate <= 0;
   count_check \ll 0;
   previous_s <= current_s;
 else
   if (comp_max = '0' AND comp_min = '0') then
     count_readout <= count_readout + 1;</pre>
   elsif (comp_max = '0' AND comp_min = '1') then
     count_highstate <= count_highstate + 1;</pre>
   elsif (comp_max = '1' AND comp_min = '0') then
     count_lowstate <= count_lowstate + 1;
   end if:
   count_check <= count_check + 1;</pre>
 end if;
 start <= '0';
                 -Mode 7: Period: 327.68ms Capactior: 625fF-
when s7 =>
```

```
260
261
262
263
264
265
266
267
268
269
270
```

221

222

223

224

225

226

228

229

230

234

235

236

238

239

240

241

242 243

244

245

246

247

248

249

250

251

252

253

254

255

256

257

258

259

```
sw1 <= '0';
271
         sw2 <= '0';
          frequency <= "100";
273
274
          if(count_check = 10) then
275
            if (count_readout > 5) then
276
               current_s <= readout;
            elsif (count_highstate > 5) then
278
               current_s <= s7;
279
            elsif (count_lowstate > 5) then
280
               current_s <= s6;
281
            end if;
282
            count_readout <= 0;
283
            count_highstate <= 0;
284
            count_low state <= 0;
285
            count_check \ll 0;
286
            previous_s <= current_s;
287
          else
288
            if (comp_max = '0' AND comp_min = '0') then
289
              count_readout <= count_readout + 1;</pre>
290
            elsif (comp_max = '0' AND comp_min = '1') then
291
              count_highstate <= count_highstate + 1;</pre>
292
            elsif (comp_max = '1' AND comp_min = '0') then
293
              count_lowstate <= count_lowstate + 1;</pre>
294
            end if:
295
            count_check <= count_check + 1;</pre>
296
          end if;
297
          start <= '0';
298
299
                           -Readout Stage-
300
       when readout =>
301
          if (count_data < 10) then
302
            start <= '1';
303
            count_data <= count_data + 1;</pre>
304
            current_s <= readout;
305
          else
306
            current_s <= previous_s;
307
            count_data <= 0;
308
         end if;
309
       end case;
310
311
     end if;
312
313 end process;
  end;
314
```

Listing A.1 VHDL code for Gain Control Algorithm

# **Bibliography**

- [1] National Research Council (US) Committee on the Role of Human Factors in Home Health Care. The role of human factors in home health care: Workshop summary. https://www.ncbi.nlm. nih.gov/books/NBK210047/, 2010. [Online] Accessed 17 Jan 2018.
- [2] Market Research Future. Biosensors development and demand market research report- global forecast to 2023. 2017.
- [3] S. P. Mohanty and E. Kougianos. Biosensors: A tutorial review. *IEEE Potentials*, 25(2):35–40, March 2006.
- [4] Corrosionpedia. Ir drop. https://www.corrosionpedia.com/definition/2203/ir-drop, 2010. [Online] Accessed 19 July 2008.
- [5] H. S. Narula and J. G. Harris. A time-based vlsi potentiostat for ion current measurements. *IEEE Sensors Journal*, 6(2):239–247, April 2006.
- [6] M. M. Ahmadi and G. A. Jullien. Current-mirror-based potentiostats for three-electrode amperometric electrochemical sensors. *IEEE Transactions on Circuits and Systems I: Regular Papers*, 56(7):1339–1348, July 2009.
- [7] M. Stanacevic, K. Murari, A. Rege, G. Cauwenberghs, and N. V. Thakor. Vlsi potentiostat array with oversampling gain modulation for wide-range neurotransmitter sensing. *IEEE Transactions on Biomedical Circuits and Systems*, 1(1):63–72, March 2007.
- [8] H. Li, C. S. Boling, and A. J. Mason. Cmos amperometric adc with high sensitivity, dynamic range and power efficiency for air quality monitoring. *IEEE Transactions on Biomedical Circuits* and Systems, 10(4):817–827, Aug 2016.
- [9] H. M. Jafari and R. Genov. Chopper-stabilized bidirectional current acquisition circuits for electrochemical amperometric biosensors. *IEEE Transactions on Circuits and Systems I: Regular Papers*, 60(5):1149–1157, May 2013.
- [10] L. Li, X. Liu, W. A. Qureshi, and A. J. Mason. Cmos amperometric instrumentation and packaging for biosensor array applications. *IEEE Transactions on Biomedical Circuits and Systems*, 5(5):439–448, Oct 2011.

- [11] C. Yang, Y. Huang, B. L. Hassler, R. M. Worden, and A. J. Mason. Amperometric electrochemical microsystem for a miniaturized protein biosensor array. *IEEE Transactions on Biomedical Circuits and Systems*, 3(3):160–168, June 2009.
- [12] Marco Carminati, Giorgio Ferrari, Davide Bianchi, and Marco Sampietro. Femtoampere integrated current preamplifier for low noise and wide bandwidth electrochemistry with nanoelectrodes. *Electrochimica Acta*, 112:950 956, 2013.
- [13] M. H. Nazari, H. Mazhab-Jafari, L. Leng, A. Guenther, and R. Genov. Cmos neurotransmitter microarray: 96-channel integrated potentiostat with on-die microsensors. *IEEE Transactions on Biomedical Circuits and Systems*, 7(3):338–348, June 2013.
- [14] S. S. Ghoreishizadeh, I. Taurino, G. De Micheli, S. Carrara, and P. Georgiou. A differential electrochemical readout asic with heterogeneous integration of bio-nano sensors for amperometric sensing. *IEEE Transactions on Biomedical Circuits and Systems*, 11(5):1148–1159, Oct 2017.
- [15] G. Ferrari, M. Farina, F. Guagliardo, M. Carminati, and M. Sampietro. Ultra-low-noise cmos current preamplifier from dc to 1 mhz. *Electronics Letters*, 45(25):1278–1280, December 2009.
- [16] Lou Frenzel. What's the difference between the third-order intercept and the 1-db compression points? http://www.electronicdesign.com/what-s-difference-between/ what-s-difference-between-third-order-intercept-and-1-db-compression-point, 2013. [Online] Accessed 15 Dec 2017.
- [17] Razavi. Design of analog cmos integrated circuits. pages 415–417, 422–425, 2001.
- [18] M. A. Abhari and A. Abrishamifar. A novel ultra low-leakage switch for switched capacitor circuits. pages 1–4, March 2009.
- [19] Christian Enz and G.C. Temes. Circuit techniques for reducing the effects of op-amp imperfections: Autozeroing, correlated double sampling, and chopper stabilization. 84:1584 – 1614, 12 1996.
- [20] R. Jacob Baker. Cmos circuit design, layout, and simulation. 2010.
- [21] J. H. Fischer. Noise sources and calculation techniques for switched capacitor filters. *IEEE Journal of Solid-State Circuits*, 17(4):742–752, Aug 1982.
- [22] Lou Frenzel. What's the difference between the third-order intercept and the 1-db compression points? http://www.electronicdesign.com/what-s-difference-between/ what-s-difference-between-vhdl-verilog-and-systemverilog, 2014. [Online] Accessed 15 April 2018.
- [23] S. S. Ghoreishizadeh, G. Nanda, S. Carrara, and G. De Micheli. Empirical study of noise dependence in electrochemical sensors. In 5th IEEE International Workshop on Advances in Sensors and Interfaces IWASI, pages 36–39, June 2013.

- [24] A. Lowe, H. Eren, and Chun Che Fung. Detection of electrode asymmetry in electrochemical noise analysis. In *Proceedings of IEEE Region 10 International Conference on Electrical and Electronic Technology. TENCON 2001 (Cat. No.01CH37239)*, volume 2, pages 748–751 vol.2, 2001.
- [25] J.Lim J. Wang, J.Polleux and B.Dunn. Pseudocapacitive contributions to electrochemical energy storage in tio\_2 (anatase nanoparticles). In J. Physical Chem. C, volume 111, pages 14925–14931, 2007.
- [26] M. Augustyniak, C. Paulus, R. Brederlow, N. Persike, G. Hartwich, D. Schmitt-Landsiedel, and R. Thewes. A 24x16 cmos-based chronocoulometric dna microarray. In 2006 IEEE International Solid State Circuits Conference - Digest of Technical Papers, pages 59–68, Feb 2006.
- [27] S. S. Ghoreishizadeh, P. Georgiou, S. Carrara, and G. De Micheli. An integrated platform for differential electrochemical and isfet sensing. In 2016 IEEE International Symposium on Circuits and Systems (ISCAS), pages 2875–2878, May 2016.
- [28] B. Bozorgzadeh and P. Mohseni. Integrated systems for high-fidelity sensing and manipulation of brain neurochemistry. In 2016 IEEE International Symposium on Circuits and Systems (ISCAS), pages 1830–1833, May 2016.
- [29] Di Long, Xianlong Hong, and Sheqin Dong. Optimal two-dimension common centroid layout generation for mos transistors unit-circuit. In *Proceedings - IEEE International Symposium on Circuits and Systems*, pages 2999 – 3002 Vol. 3, 06 2005.
- [30] Emre Salman and E.G. Friedman. Methodology for placing localized guard rings to reduce substrate noise in mixed-signal circuits. In 2008 Ph.D. Research in Microelectronics and Electronics, pages 85 – 88, 06 2008.