# A Standalone Capacitively Coupled Occupancy Sensor 

by<br>William H. Thompson<br>S.B., Massachusetts Institute of Technology (2010)<br>Submitted to the Department of Electrical Engineering and Computer Science<br>in partial fulfillment of the requirements for the degree of<br>Master of Engineering in Electrical Engineering and Computer Science at the<br>MASSACHUSETTS INSTITUTE OF TECHNOLOGY<br>\section*{}<br><br>(c) Massachusetts Institute of Technology 2012. All rights reserved.

Author

$$
\begin{array}{r}
\text { Department of El ctrical Engineering and Computer Science } \\
\text { September } 30,2012
\end{array}
$$

Certified by


Dr. Steven B. Leeb
Professor of E.E.C.S. \& M.E., MacVicar Faculty Fellow

$$
\cap \cap \cap \text { Thesis Supervisor }
$$

Certified by


Al-Thaddeus Avestruz
Doctoral Candidate
Thesis Supervisor

Accepted by $\qquad$

# A Standalone Capacitively Coupled Occupancy Sensor 

by
William H. Thompson

Submitted to the Department of Electrical Engineering and Computer Science on September 30, 2012, in partial fulfillment of the requirements for the degree of Master of Engineering in Electrical Engineering and Computer Science


#### Abstract

This thesis presents the design and implementation of a standalone, capacitively coupled, occupancy sensor. Unlike previous iterations, the new sensor is decoupled from the fluorescent lamp. A well controlled, high voltage amplifier and autotransformer are designed as a replacement source and operate over a wide range of output frequencies and amplitudes. The sensor electronics are implemented with active sensing electrodes and resistive and capacitive feedback modes are evaluated for performance. Optimal front end feedback, electrode spacing, and signal source amplitude are explored. The sensor achieves a detection range of 11 feet for occupancy detection, with capacitive measurements down to the attofarad level. The application of the sensor as a material detector, using a linear mixing algorithm, is also found to be feasible.


Thesis Supervisor: Dr. Steven B. Leeb
Title: Professor of E.E.C.S. \& M.E., MacVicar Faculty Fellow

Thesis Supervisor: Al-Thaddeus Avestruz
Title: Doctoral Candidate

## Acknowledgements

I would like to thank everyone that made this thesis possible. I am extremely grateful to my thesis supervisors, Steve Leeb and Al-Thaddeus Avestruz, for their constant guidance and support.

My friends and colleagues in the lab and at MIT have also provided incredible support, encouragement, and distraction. They include, but are not limited to, John Cooley, Steven Herbst, Shahriar Khushrushahi, Jim Paris, John Donnal, Arthur Chang, Lizi George, and Amanda Levesque. I am especially thankful to Tina Drake for her endless support.

Lastly, I like to thank my parents for pushing me, believing in me, and always supporting me.

## Contents

1 Introduction ..... 15
1.1 Motivation and Prior Work ..... 15
1.2 Applications ..... 16
1.2.1 Occupancy Detection ..... 16
1.2.2 Object Detection ..... 16
1.3 Thesis Overview ..... 16
2 System Overview ..... 19
2.1 System Requirements ..... 21
2.2 Fundamental Limits of Detection ..... 22
2.2.1 Occupancy Detection ..... 22
2.2.2 Object Detection ..... 23
2.3 System Dynamics ..... 23
2.4 System Partitioning ..... 25
3 High Voltage Signal Source ..... 27
3.1 Circuit Design ..... 28
3.1.1 Digital to Analog Synthesis ..... 30
3.1.2 Pre-Gain and PI Controller ..... 33
3.1.3 Wide Rail Power Operational Amplifier ..... 36
3.1.4 Autotransformer ..... 39
3.1.5 High Voltage Feedback and Control ..... 43
3.2 Summary of Tradeoffs ..... 46
4 Sensing Circuitry Design ..... 47
4.1 Front End Amplifier ..... 47
4.1.1 Active Receive Electrodes ..... 50
4.1.2 Common Mode Feedback ..... 55
4.2 Signal Conditioning ..... 58
4.2.1 Gain Stages ..... 59
4.2.2 Synchronous Detector and Filters ..... 60
4.2.3 Instrumentation Amplifier and ADC ..... 64
4.3 Noise, Drift, and Offset Analysis ..... 65
4.3.1 Sensor Front End ..... 66
4.3.2 Analog Switches and Filters ..... 69
4.3.3 Instrumentation Amplifier and ADC, ..... 70
4.4 Implementation and Performance ..... 70
4.4.1 Component Selection ..... 70
4.4.2 Noise and Drift ..... 71
4.5 Summary of System Tradeoffs ..... 72
5 Occupancy Detection Demonstration and Performance ..... 73
5.1 System Configuration ..... 73
5.1.1 Experimental Setups ..... 74
5.2 Occupancy Detection ..... 75
5.2.1 Range Tests ..... 75
6 Object Detection ..... 89
6.1 Linear Mixing Detection Algorithm ..... 91
6.2 Multifrequency Tests ..... 92
6.3 Object Detection Implementation ..... 93
7 Conclusions and Future Work ..... 95
7.1 Summary ..... 95
7.2 System Improvements and Alternatives ..... 96
7.2.1 Digital Synthesis ..... 96
7.2.2 Wide Rail Power Op-Amp ..... 96
7.2.3 Upstream ADC ..... 96
7.3 Future Work ..... 97
7.3.1 Differential Signal Source ..... 97
7.3.2 Multiple Sensor Applications ..... 97
7.3.3 Large Scale Implementation ..... 97
A Code ..... 99
A. 1 Sensor Interfacing Software in Matlab ${ }^{(0)}$ ..... 99
A.1.1 readADC.m ..... 99
A.1.2 recorder.m ..... 100
A.1.3 liveGraph.m ..... 101
A.1.4 rangeExpt.m ..... 103
A.1. 5 gridExpt.m ..... 105
A. 2 Sensor Board Software ..... 107
A.2.1 makefile ..... 108
A.2.2 FullyDiff.c ..... 124
B Schematics and Boards ..... 141
B. 1 High Voltage Signal Source ..... 142
B.1.1 Full Schematic ..... 142
B.1.2 PCB Layout ..... 143
B.1.3 Bill of Materials ..... 144
B. 2 Standalone Sensor Electrodes ..... 145
B.2.1 Capacitive Mode Electrodes ..... 145
B.2.2 Resistive Mode Electrodes ..... 149
B. 3 Standalone Sensor Signal Conditioning ..... 153
B.3.1 Full Schematic ..... 153
B.3.2 PCB Layout ..... 163
B.3.3 Bill of Materials ..... 164
B. 4 Atmega32U4 Breakout Board ..... 166
B.4.1 Full Schematic ..... 166
B.4.2 PCB Layout ..... 167
B.4.3 Bill of Materials ..... 168

## List of Figures

2-1 The lumped element model for the capacitively coupled occupency sensor. ..... 19
2-2 Modeled sensed current, $I_{d}$, as a function of $Z_{d}$. $\mathrm{V}_{\mathrm{s}}=200 \mathrm{~V}, \mathrm{Z}_{\mathrm{cm}}=1 \mathrm{~m} \Omega, \mathrm{f}=10 \mathrm{kHz}$ ..... 20
2-3 Diagram of the generalized standalone occupancy sensor. ..... 21
2-4 Bode plot of a model low pass filter. ..... 24
3-1 The block diagram of the high voltage signal source. Two DDS sine sources are summed and their offsets nulled. Gain is applied on the sensor board, $\mathrm{G}_{0}$, then sent via coax cable to the HV board. A pre-gain stage, $\mathrm{G}_{1}$, follows and then a proportional- integral controller for the power op-amp and autotransformer. ..... 29
3-2 The circuit diagram of the summed, synthesized analog sinusoids. The offset subtrac- tion is set by making $v_{d c}$ negative. It is scaled by $R_{d c}$, whose value is chosen based on whether one or two DDS chips are on. ..... 31
3-3 The circuit model for the first two op-amp stages: a pre-gain stage followed by a proportional-integral controller. Here, $R_{f 2}$ is the parallel combination of the high voltage divider at the output of the signal source, given by $R_{d 1} \| R_{d 2}$. ..... 34
3-4 The circuit diagram of the wide swing op-amp and output autotransformer. ..... 37
3-5 OPA452 Peak Output Voltage vs. Frequency ..... 38
3-6 Two circuit models for the autotransformer. ..... 40
3-7 The circuit model for the third gain stage op-amp and reflected load with out-of-loop compensation resistor $R_{c}$ ..... 43
3-8 The circuit model for the PI controller and plant. ..... 44
3-9 Block diagram for the proportional-integral controller. ..... 44
3-10 The block diagram of the plant at the high voltage source output. ..... 45
3-11 Plots of the dynamics for the PI controller implemented in the high voltage amplifier ..... 46
4-1 The full and simplified circuit diagrams for the front end amplifier. ..... 48
4-2 The generalized block diagram for the front end amplifier. ..... 49
4-3 Front end amplifier with the modeled lumped cable and parasitic capacitance, inside the dashed box. The configuration of the front end amplifier used in the standalone sensor removes this capacitance. ..... 50
4-4 Loop transfer functions as affected by stray capacitance. ..... 51
4-5 The bode plots for the front end amplifiers implemented, with finite open loop gain. ..... 53
4-6 The frequency of the pole as a function of capacitance, plotted for the four resistor values implemented. ..... 54
4-7 Schematic for the half circuit common mode feedback of the front end amplifier. Feedback capacitances represent lumped T-networks. Electrode circuitry is left of the cable and sensor board circuitry to the right. ..... 56
4-8 Block diagram for the common mode feedback of the front end amplifier. ..... 56
4-9 The bode plot of the closed loop transfer function for interference at the front end amplifier to the output. The largest expected interference contributors, at 60 Hz and 52 kHz , are noted by the dashed lines. ..... 58
4-10 The generalized block diagram for the signal conditioning circuitry. The first gain stage is singled ended and located on each respective electrode. The following stages are all fully differential and reside on the sensor board. The dashed box is replicated four times. ..... 59
4-11 A singled ended input to differential output op-amp configuration. ..... 60
4-12 Block diagram of the synchronous detector and low pass filters. ..... 61
4-13 Circuit implementation of the synchronous detector and low pass filters. ..... 63
4-14 Circuit implementation of the clock signal synthesis. The flips flop depicted here are implemented with the 74HVC74 ..... 63
4-15 Circuit diagram of the instrumentation amp., with gain and level shifting, followed by the ADC. ..... 64
4-16 An op-amp with voltage and current noise sources included. ..... 66
4-17 Schematic of the front end amplifier noise model. ..... 68
5-1 Front left view of the standalone sensor setup. The source electrode is located on the highest platform and protected by electrical tape. The receive electrodes are on either side of the source electrode and the sensor board sits between them. ..... 74
5-2 Representative in phase and quadrature contributions to the total magnitude mea- sured from the sensor board. ..... 75
5-3 A top down illustration of the front to back and left to right testing paths. ..... 76
5-4 Measured responses and their derivatives for front to back range tests with varied front end compensation. ..... 77
5-5 Measured responses and their derivatives for left to right range tests with varied front end compensation. ..... 78
5-6 Measured responses and their derivatives for front to back range tests with varied source amplitudes. ..... 80
5-7 Measured responses and their derivatives for left to right range tests with varied source amplitudes. ..... 81
5-8 The system detection radius, based on front to back range tests, as a function of the system signal source amplitude. ..... 82
5-9 Front to back range test linear fit and modeled response. ..... 84
5-10 Measured responses and their derivatives for front to back range tests with varied electrode spacing. ..... 86
5-11 Measured responses and their derivatives for left to right range tests with varied electrode spacing. ..... 87
6-1 The conductivity and permittivity of human muscle as a function of frequency. ..... 90
6-2 The conductivity of aluminum as a function of frequency. ..... 90
6-3 Example in phase and quadrature response curves and the measurements of interest. ..... 92
6-4 Mismatch between zero crossings of the derivative response curves. ..... 93

## List of Tables

3.1 Sine Synthesis and Conditioning Components ..... 33
3.2 High Voltage Pre-Gain and PI Controller Components ..... 36
3.3 High Voltage Wide Rail Gain Stage Components ..... 39
3.4 P42/29-3B9 Core and Material Specifications ..... 42
3.5 Autotransformer Design Corners ..... 42
3.6 Autotransformer Parameters ..... 43
4.1 Front End Amplifier Combinations ..... 71
4.2 Measured Noise Referred to Input ..... 72
4.3 Measured System Drift ..... 72
5.1 Front End Amplifier Combinations ..... 79
5.2 Varied Source Voltage Test Parameters ..... 79
5.3 Linear Fit Parameters ..... 83
5.4 Varied Geometry Parameters ..... 85
6.1 Object Detection Results ..... 93

## Chapter 1

## Introduction

### 1.1 Motivation and Prior Work

The standalone occupancy sensor aims to challenge existing motion and occupancy detection technology and present a superior alternative. Passive infrared (PIR) sensors are commonplace devices and have achieved widespread use in various settings, e.g. offices, laboratories, and even restrooms. This is largely due to their simplicity, which allows for low cost and high volume access to the sensors. However, a byproduct of the PIR sensor's simplicity is its limits of use. As described in reference [5], a PIR sensor is effectively limited to motion detection, as opposed to pure occupancy detection, by low frequency noise and drift due to electronics and changes in the background infrared radiation.

One of the goals of the capacitively coupled occupancy sensor is to detect true occupancy, and remove any dependency on movement. Implementing large scale capacitive sensing in this fashion has been proven feasible in previous work $[1,5]$. Therefore, pushing the limits of effective occupancy detection is the next step in the development of the standalone sensor. Doing so is heavily reliant on mitigating the same noise and drift problems that plague existing sensors.

Previous applications of the capacitively coupled occupancy sensor relied on fluorescent lamps as a signal source. The primary motivation for this thesis is to eliminate the need for a fluorescent bulb and to create an independent, standalone sensor. Despite the prevalence of fluorescent lamps, their utility as a signal source for the occupancy sensor is limited. As a preinstalled system, parameters of the signal source and sensor configuration that are useful to the application of the occupancy detector, as a retrofit implementation, are not necessarily controlled. This limits some applications of the sensor by reducing the degrees of freedom in the system.

An advantage of the standalone system is the freedom to engineer the system with full control over the operating parameters. Without a fixed and given signal source, like the fluorescent lamp, the standalone system has the freedom to operate over a range of source frequencies and amplitudes.

Furthermore, by removing the requirement for the fluorescent lamp as an installation framework also removes the limits of the sensor electrode configuration. Thus, the standalone sensor is better suited to be adapted for use in a wider variety of applications.

### 1.2 Applications

### 1.2.1 Occupancy Detection

As with previous designs, one of the primary applications of the standalone sensor is occupancy detection based purely on presence. The benefits of eliminating dependencies on motion are numerous and impact the possible applications of the device. The simplest application is a basic replacement of the PIR sensor. In an office or laboratory setting, where motion sensors commonly control lighting, the benefit of pure presence detection is the reduction of false negatives, where the building lights may turn off while occupants are still present. Breaking this paradigm is the advantage of pure occupancy detection.

The standalone sensor can also be used to detect motion and occupancy in high security areas. By not having a lamp as a signal source, the sensor can operate in an ad hoc manner. The standalone sensor may be used in a conventional high security, limited access area. Along with fixed or permanent installations, the sensor may also be set up in the field or on the go, as necessary, because no lamp infrastructure is required.

### 1.2.2 Object Detection

An alternative and innovative application of the standalone sensor is object detection and differentiation. One method of differentiating between materials is based on the principle that the frequency response of the permittivity and conductivity of a particular material is different. The design for the standalone sensor allows for this because the signal source allows for simultaneous multi-frequency operation.

Once again, this application may be employed in security applications. In a high security settings such as airports, weapons detection and threat assessment, among other preventative measures are of high priority. The ability to sense a potentially harmful materials is invaluable in many situations.

### 1.3 Thesis Overview

This thesis discusses the design and implementation of a standalone occupancy sensor. Emphasis is placed on increasing the range and sensitivity over previous implementations of the occupancy sensor. In doing so, a new approach to the front end sensing circuitry is evaluated and sources of noise and error are minimized.

The design and implementation of the high voltage signal source, that replaces the fluorescent, is discussed in Chapter 3. Analysis and design of the front end sensing amplifier and signal conditioning circuitry is presented in Chapter 4 . The overall system performance and results of the system tests performed are discussed in Chapter 5 . Finally, the thesis is concluded in Chapter 7 with a discussion of the results, system limitations, and future work. Appendices follow with relevant schematics, board layouts, and code.

## Chapter 2

## System Overview

A lumped element system model for the standalone sensor system, shown in Figure 2-1, may be applied to simplify and visualize the measurements of interest. Furthermore, the model provides useful insight into the system to aid and drive design.


Figure 2-1: The lumped element model for the capacitively coupled occupency sensor.

The model depicts the dominant lumped capacitances of the system, comprised by the source to receive electrode capacitance, $C_{s e}$, in parallel with the variable capacitance from the source to the electrodes, $+\Delta C$ and $-\Delta C$, which are dependent on the presence of an occupant. These variable capacitances sensed by the system are significantly smaller than the fixed source to receive electrode capacitance. Previous work modeling the system provides approximate capacitances for the model which are used in the design of the standalone sensor [1].

The measurement of interest is the current into each of the front end op-amps, whose inputs are modeled by a small impedance, $Z_{d}$. The impedances through the front end amplifier are small
because in feedback they appear as nearly a short circuit. A common-mode feedback path drives each amplifier to a known potential, which has some impedance path to the source ground through $Z_{c m}$. Because the common mode feedback drives the amplifiers and attempts to attenuate the common mode signal, its path to the source ground is small.


Figure 2-2: Modeled sensed current, $I_{d}$, as a function of $Z_{d} . \mathrm{V}_{\mathrm{s}}=200 \mathrm{~V}, \mathrm{Z}_{\mathrm{cm}}=1 \mathrm{~m} \Omega, \mathrm{f}=10 \mathrm{kHz}$

As shown in Figure 2-2, for a fixed $\Delta C$, the sensed current increases for smaller $Z_{d}$ and $Z_{c m}$. This suggests that large common mode rejection is desirable in order to maximize the sensed current. As $Z_{d}$ and $Z_{c m}$ go to zero and the loop gain of the front end becomes large, the sensed current to one electrode is

$$
\begin{equation*}
i_{\text {sense }}=v_{s} \omega_{c}\left(\frac{C_{s e} \Delta C}{C_{s e}+\Delta C}\right) \tag{2.1}
\end{equation*}
$$

This holds for all cases where the occupant is relatively far from the sensor, and $\Delta C \ll C_{\text {se }}$. In the end, this model allows for a calculation of the minimum detectable change in capacitance for the standalone system

$$
\begin{align*}
\Delta C_{\min } & =\frac{i_{\text {sense }}}{\omega_{c} v_{s}}  \tag{2.2}\\
& =\frac{1}{\omega_{c} v_{s}} \cdot \frac{v_{\min }}{\mathrm{G}_{\mathrm{sys}} Z_{f}}
\end{align*}
$$

where $i_{\text {sense }}=i_{d}, v_{\min }$ is the minimum detectable voltage at the input to the analog to digital converter, $\mathrm{G}_{\text {sys }}$ is the overall system gain, and $Z_{f}$ is the front end transimpedance gain.

A block diagram depicting a standalone system is shown in Figure 2-3. The full system consists of the following elements:

- A high voltage signal source to drive the source electrodes
- A front end amplifier on the receive electrodes
- A signal conditioning chain and microcontroller interface on the sensor board

The high voltage source drives an electric field. The targets present in the sensing space perturb


Figure 2-3: Diagram of the generalized standalone occupancy sensor.
the field and affect the coupling to the receive electrodes. The front end amplifiers, located on the receive electrodes, transduce the currents at their inputs, according to the local feedback network. Additional gain is applied and the sensed signal is transmitted via a coaxial cable to the signal conditioning electronics on the sensor board. The received signal is further amplified as necessary and then synchronously detected using a full bridge. A set of RC low pass filters remove the ac component and pass it to an instrumentation amplifier, which level shifts the signal to the midscale value of the supply range of the ADC. Lastly, the digital representation of the sensed capacitance change is passed to a computer for data collection and analysis.

### 2.1 System Requirements

The primary goal for the standalone sensor is to lower the minimum detectable capacitance change. Previous sensors achieved capacitance measurements as low as 10 fF [5]. Pushing the minimum detectable capacitance even lower is desirable in order to increase the sensitivity of the system. As noted from Equation (2.2), this can be done in a number of ways, including increasing the source amplitude and operating frequency. A conservative calculation places the minimum capacitance detectable by the standalone sensor at

$$
\begin{equation*}
\Delta C_{\min }=\frac{100 \mu \mathrm{~V}}{(2 \pi 10 \mathrm{kHz})(200 \mathrm{~V})(10)(10 \mathrm{k} \Omega)}=80 \mathrm{aF} \tag{2.3}
\end{equation*}
$$

Though exceptionally small, it is not uncommon for capacitance measurements to be of such a small resolution. Impedance spectroscopy, electrochemical impedance measurements, and ac current sensing atomic force microscopy are just a few applications in which attofarad measurements have been performed $\{7,8,9,10,11\}$. An important difference is the physical scale of the measurement space. The standalone system aims to make these measurements over a large volume in comparison to those described in the references.

In order to measure such small capacitance changes, the sensor must maintain a suitably low noise floor and be able to reject unwanted, erroneous signals. Furthermore, errors, in the form of offset and drift, introduced by the sensor electronics must also be kept as low as possible. One
method of doing so is to null the differential measurement made by the electrodes. This means that the receive electrodes couple to the source equally; thus, in the absence of an occupant, and any detection, the differential output of the sensor is zeroed.

### 2.2 Fundamental Limits of Detection

### 2.2.1 Occupancy Detection

Occupancy detection refers to the sensing of an object purely based on proximity, with no dependence on motion, heat, or sound. For detecting an average person, about 5 feet 10 inches tall and 180 pounds, the detection range of the system is defined to be the farthest distance away from the sensor that yields a correct positive result, i.e. detecting an occupant when an occupant is actually present. Naturally, the larger the detection range, the larger the volume over which an object may be sensed.

There are two paradigms: near and far detection. Near detection, or detection localized about the sensor when distance is not the goal, does not suffer from low sensed signal amplitudes. Rather the more important factor, when purposefully within the detection radius, is the system sensitivity and minimizing the smallest detectable occupant. Far detection, as noted, attempts to push the range of the system. In either case, the signal to noise ratio (SNR) is the key metric to be maximized. Near the sensor, the dynamic range of the system must be sufficient to handle a wide swing response. Far from the sensor, the noise floor of the system must be kept low in order to decrease the minimum detectable signal.

The proximity sensing, described further in Chapter 4, method uses the magnitude of the measured in phase and quadrature signals from the synchronous detector. For this application, magnitude errors are the greatest concern and limit the resolution.

## Noise, Drift, Offset and Dynamic Range

As an object moves farther and farther away from the sensor, the point to point change in capacitance decreases along with the sensed input current. When the input current drops below the noise floor of the system, the object is no longer detectable. This noise floor is defined as the root mean square (RMS) noise of the entire system. The system noise is assumed to be represented by a Gaussian distribution. This means that the three sigma rule may be applied to detection decisions. The rule states that $99.7 \%$ of the values of a distribution are within three standard deviations, or sigmas, of the mean. In the context of the sensor, this suggests that the level of confidence with which a measurement may be considered a true positive detection can be determined by its value above the noise floor. Thus, lowering the noise contributions of the electronics and mitigating noise contributions from the environment are a must in order to increase the detection range.

Furthermore, the negligible drift enables presence based detection. System drift, regardless of the source, hinders the detection capabilities of the system by corrupting the relationship between past and current measured values. For instance, a static object within range of the sensor should result in a constant measured response. This may not always be the case with drift present and the system may begin to break down.

Measurement offsets may also negatively affect system performance by reducing dynamic range. This is primarily a concern when close to the sensor, where the signal amplitude is largest. A reduction in the dynamic range translates into a reduction of sensitivity because the sensed signals may be clipped by the limited range.

## Electric Field Drop Off

Physical limits also apply to the capacitively coupled occupancy sensor. The farther away an object is from the signal source, the smaller the disturbance in the electric field measured by the system. Occupancy detection is limited by strength of the electric field and the rate at which it weakens as a function of distance.

The drop off of the electric field for different electrode configurations is currently an active area of research. The parameters that affect the field include, but are not limited to, the signal source amplitude, the electrode configuration, and the size of the electrodes. The effects of these parameters for some example configurations are investigated in Chapter 5.

### 2.2.2 Object Detection

Object detection has similar concerns to occupancy detection. It differs slightly because it aims to differentiate between materials. However, this sensing application is less concerned with the distance of the detection field. Material differentiation is to be performed well within the range of the system, since the granularity and sensitivity of the sensor is much more important.

Another major concern for this application is reproducibility. Based on the method to be explained in Chapter 6, the object detection algorithm uses the amplitudes of the in phase and quadrature measurements at two different frequencies. The algorithm uses calibration trials as references for object detection.

### 2.3 System Dynamics

Another consideration in the design of the source and sensor electronics is the placement of the closed loop poles and zeros. Close proximity between the operating frequency and the poles and zeros leads to undesired errors in amplitude and phase. In general, poles and zeros are not well
controlled both initially, as well as over time and temperature. Placing these singularities away from signal frequencies minimizes their time-varying effects.

The dynamic characteristics of each stage are specified, in large part, by passive components. These resistors and capacitors are prone to drift and mismatch; this, in turn, translates to shifts in the pole and zero frequencies. Errors arise in both magnitude and phase and their severity depends on the proximity of the system poles and zeros and operating frequency. A simple RC low pass filter, such as those found in the signal conditioning circuitry, illustrates the potential effects of these errors well. The passive components define the passband and stopband regions, denoted in the bode plot in Figure 2-4.


Figure 2-4: Bode plot of a model low pass filter.

A change in resistance or capacitance moves the cutoff frequency. As a result, the operating frequency may be pushed into the stopband or, conversely, the passband may be extended and erroneous inputs attenuated less. The phase incurred at the output is also affected, more so than the magnitude. This can be observed qualitatively from the bode plot. Operating in the passband a decade away from the cutoff frequency offers no significant attenuation in magnitude, but the phase incurred from the filter is already significant.

Analysis along these lines can be extrapolated for the operation of the system as a whole. Operating near the poles and zeros at any stage makes the entire system susceptible to magnitude and phase errors. Magnitude errors primarily result in signal attenuation through the signal conditioning. Phase errors indirectly affect the amplitude of the sensed signal by altering the phase of the signal at the synchronous detector. As will be described in Chapter 4, phase offset between the input signal and multiplied signal at the synchronous detector results in attenuation at the output. This
matters less for proximity detection since the magnitude of the in phase and quadrature amplitudes is found. However, these errors pose a larger problem for object detection where both individual amplitudes are needed.

### 2.4 System Partitioning

The gain in the system is distributed to provide a tradeoff between bandwidth and signal-to-noise ratio (SNR). The general principle for distributing the gain is conflicting. Gain should be applied as early as possible to maximize SNR. However, it should also be cascaded over several stages to maximize the gain bandwidth product.

Figure 2-3 presents a reference for the input referred noise of the standalone system. The noise at the input to the sense electrodes, $n_{i}^{2}$, is the combination of the noise contributed by the source, $n_{s r c}^{2}$ and the noise contributed by the sensor electronics, $n_{o, s e n s o r}^{2}$, given by

$$
\begin{equation*}
n_{i}^{2}=\mathrm{A} n_{s r c}^{2}+\frac{1}{\mathrm{G}_{\mathrm{sys}}}-n_{o, s e n s o r}^{2}, \tag{2.4}
\end{equation*}
$$

where $A$ is the attenuation ratio of the source signal to the input of the sensor and $G_{\text {sys }}$ is the overall system gain. Because A is so small, the noise contribution of the signal source is minimal compared to that of the sensor electronics. This implies that the bulk of the noise in the system is from the sensing electronics.

## Chapter 3

## High Voltage Signal Source

The fluorescent lamp as an electric field source is inconsistent, non-uniform, and prone to drift, largely because of the properties of the plasma inside the bulb. As one of the goals of the standalone sensor is to improve upon the fluorescent lamp, a new signal source is needed to drive the electric field to sense changes in capacitance.

The benefit of the standalone source is that the idiosyncrasies of the fluorescent lamp, with its alternating linear voltage profile and lumped node model, no longer need to be addressed [1]. The electric field source consists of a plate driven by a high voltage amplifier with a sinusoidal reference. The operating range is chosen to be between 10 kHz and 100 kHz , and the output signal amplitude can be as large as 500 V from an input reference of less than 1 V . Furthermore, for sensor applications that require multiple simultaneous operating frequencies, the reference source is capable of outputting summed sinusoids.

The performance of the high voltage source determines the performance of the entire system. The most important consideration is the drift at the output of the source. Maintaining a steady output ensures that all sensing is possible and reliable.

To provide better performance than the fluorescent lamp, the signal source needs:

- Variable amplitude
- Wide operating frequency range
- Low noise floor
- Small short and long term drift

In this chapter, a general analysis for the design is discussed first. Specific implementations are detailed when necessary to illustrate design decisions.

### 3.1 Circuit Design

The general approach to designing the high voltage signal source is to amplify the input signal as much as possible, through op-amp stages, then rely on a transformer to further increase the output signal amplitude. The gain is broken up into multiple stages to maximize the system bandwidth. Noise performance is traded off, but as illustrated in Chapter 4, the attenuated source noise is negligible in comparison to the input referred noise at the sensing input. A block diagram of the full circuit, shown in Figure 3-1, outlines the stages of the signal source.

The circuit consists of a digital to analog converter synthesizing the input sine wave, which is fed into a preamplifier and then a closed loop power amplifier stage with an autotransformer.


Figure 3-1: The block diagram of the high voltage signal source. Two DDS sine sources are summed and their offsets nulled. Gain is applied on the sensor board, $\mathrm{G}_{o}$, then sent via coax cable to the HV board. A pre-gain stage, $\mathrm{G}_{1}$, follows and then a proportionalintegral controller for the power op-amp and autotransformer.

### 3.1.1 Digital to Analog Synthesis

The input sine wave is synthesized by a direct digital synthesis (DDS) chip, the AD9837, which is controlled via the serial peripheral interface (SPI) from a microcontroller. The AD9837 contains a digital to analog converter (DAC) along with other circuitry such as memory and logic, to generate a programmable sine wave at its output. Both frequency and phase offsets are controllable via the SPI bus.

The AD9837 output is constructed by clocking through a read only memory (ROM) that contains a lookup table. This table is used to convert the programmed input to the appropriate analog output. This output is created by an internal 10-bit DAC which makes the output voltage quantization 4 mV . The output frequency is given by

$$
\begin{equation*}
f_{o u t}=\frac{f_{m c l k}}{2^{28}} \cdot \text { FREQREG } \tag{3.1}
\end{equation*}
$$

where $f_{m c l k}$ is the master clock frequency and FREQREG is the value programmed into the frequency control register. This constrains the output frequency to a resolution of 0.01 Hz .

The output signal spectrum is comprised of the output frequency with harmonics at multiples of the master clock frequency $[2]$. The magnitude of the harmonics falls off according to $\frac{\sin x}{x}$, where $x=\frac{\pi \cdot f}{f_{\mathrm{mclk}}}$. If the output frequency is close to the master clock frequency, it is possible for the higher frequency harmonics to contribute significantly to the output. The highest operating frequency of the standalone sensor is 100 kHz . The master clock is maintained at 2.67 MHz , which makes the largest harmonic a small fraction of the fundamental

$$
\begin{equation*}
\mathrm{A}_{1 \mathrm{st}}=\frac{\sin \pi \frac{(2.67 \mathrm{MHz}-100 \mathrm{kHz})}{2.67 \mathrm{MHz}}}{\pi \frac{(2.67 \mathrm{MHz}-100 \mathrm{kHz})}{2.67 \mathrm{MHz}}} \cdot \mathrm{~A}_{\text {fundamental }}=.0388 \cdot \mathrm{~A}_{\text {fundamental }} . \tag{3.2}
\end{equation*}
$$

This implies that the harmonic content of the AD9837 is small.
Due to the capabilities of the DDS and its unipolar supply, the output is limited in amplitude and contains a dc offset. While neither are prohibitive, both must be addressed to best drive the high voltage amplifier. In order to accommodate simultaneous multiple frequency output, two waveforms are generated by two separate, selectable, DDS chips and subsequently summed.

A summing amplifier, pictured in Figure 3-2, is used to add and scale the outputs of the waveform generators, according to:

$$
\begin{equation*}
v_{o u t}=-R_{f}\left(\frac{v_{d d s 1}+v_{o s}}{R_{d d s}}+\frac{v_{d d s 2}+v_{o s}}{R_{d d s}}+\frac{v_{d c}}{R_{d c}}\right) \tag{3.3}
\end{equation*}
$$

where each voltage input is scaled by the ratio of the feedback resistor, $R_{f}$, and the scaling resistors, $R_{d d s}$ and $R_{d c}$. The ac and dc components of each signal are explicitly written to illustrate the
additional undesired dc voltages. The applied gain at this stage is controlled by the ratio of the feedback resistance to the scaling resistances. The gain increases the signal amplitude, thereby resolving the low output amplitude of the DDS chips. However, the dc offsets are amplified at the same time.


Figure 3-2: The circuit diagram of the summed, synthesized analog sinusoids. The offset subtraction is set by making $v_{d c}$ negative. It is scaled by $R_{d c}$, whose value is chosen based on whether one or two DDS chips are on.

Two approaches are taken to handle the offsets of the synthesized waveforms. The first method consists of subtracting as much of the offset as possible. Doing so enables as large a gain as possible to be applied at the summing amplifier. The amount of de subtraction required is dictated by the system configuration. Single frequency operation requires only one DDS chip and disables the other, leaving only one dc offset to negate, while multifrequency mode requires twice as much subtraction. By making $v_{d c}$ negative, the approximately 300 mV offset applied by each DDS chip can be negated. The amount of subtraction is controlled by $R_{d c}$ as noted in equation (3.3). With $v_{d c}$ fixed at -5 V , $R_{d c}$ is halved when both DDS chips are active, or kept at its nominal value with only one active DDS.

It is vital to subtract the offset as entirely as possible in order to maximize the gain applied during this stage. Any remaining offset will be amplified and lower the maximum voltage swing at the output. Thus, the largest gain that may be applied is

$$
\begin{equation*}
\mathrm{G}<\frac{V_{p e a k}}{V_{O F F}+v_{a m p}} \tag{3.4}
\end{equation*}
$$

where $V_{\text {peak }}$ is the peak output voltage of the summing op-amp, $V_{O F F}$ is the sum of the dc offset voltages, and $v_{a m p}$ is the sum of the ac amplitudes.

The remaining offset is removed by a high pass filter placed at the output of the summing
amplifier. It is important to keep the cutoff frequency of the filter

$$
\begin{equation*}
f_{c u t o f f}=\frac{1}{2 \pi R_{h p} C_{h p}}, \tag{3.5}
\end{equation*}
$$

far from the operating frequency in order to avoid attenuating the signal and to limit any phase offset. Pushing the cutoff lower in frequency requires increasing the resistance and capacitance accordingly. However, a larger capacitor leads to larger settling times, which affects how the filter reacts to drifts in the offset.

The last piece of the high voltage signal source on the sensor board is the cable driver. The output of the summing amplifier is sent to the high voltage board via coaxial cable. An op-amp is used with proper impedance matching to drive the cable and avoid corrupting the signal.

## Implementation

The implementation uses the components from Table 3.1. The inputs to the summing op-amp are scaled equally. The offset subtraction is varied by changing $R_{d c}$, in order to cancel the offset imparted by the DDS chips. With the summing op-amp powered by $\pm 5 \mathrm{~V}$ supplies, a gain of 10 was chosen such that, with one DDS active, the total offset at the summing op-amp input may be

$$
\begin{align*}
V_{O F F} & <\frac{1}{10} \cdot(5 \mathrm{~V}-10 \cdot 0.3 \mathrm{~V})  \tag{3.6}\\
& <0.2 \mathrm{~V} \tag{3.7}
\end{align*}
$$

This is much larger than any expected offset and should be more than sufficient.
The cutoff of the high pass filter is set to 160 Hz , which is far from the lowest operating frequency of 10 kHz . At two decades above cutoff, the output is well within the passband. Thus, the magnitude error at the output is insignificant and the added phase at the output is much smaller than one degree. This also ensures that drift, in either direction, of the pole frequency has little effect on the output. Lastly, the filter settles within 6 ms , which is a tenth of the duration of the sampling window.

Table 3.1: Sine Synthesis and Conditioning Components

| Component | Value |
| :---: | :---: |
| Summing Amp | LT1806 |
| Cable Driver | LT1806 |
| Gain | 10 |
| HPF Cutoff | 160 Hz |
| $R_{d d s}$ | $1 \mathrm{k} \Omega$ |
| $R_{d c}$ | $9 \mathrm{k} \Omega, 17 \mathrm{k} \Omega$ |
| $R_{f}$ | $10 \mathrm{k} \Omega$ |
| $R_{h p}$ | $1 \mathrm{k} \Omega$ |
| $C_{h p}$ | $1 \mathrm{\mu F}$, film |

### 3.1.2 Pre-Gain and PI Controller

Operating at high gains over the nominal frequency range places strict demands on the op-amps used in the signal source chain. These components must operate with sufficient bandwidth and slew rate. Furthermore, the inputs to each stage must be kept within the acceptable limits for the op-amps used. If these criteria are not met, the output of each stage may be distorted. Figure 3-3 presents the first two op-amp stages on the high voltage board. These first two stages are designed with the AD8620 and powered from $\pm 12 \mathrm{~V}$ supplies. Despite these supplies, the inputs of the AD8620 are limited to $\pm 10.5 \mathrm{~V}$, while the outputs reach $\pm 11.84 \mathrm{~V}$. These specifications set the limits of the operating voltages for these op-amp stages.

The pre-gain stage is configured as a non-inverting amplifier with adjustable gain set by a potentiometer in the feedback path. The adjustable gain at this stage determines the final output amplitude of the signal source. This potentiometer must have a small temperature coefficient in order to lessen the amount of drift in the source. The second op-amp is configured as a proportional-integral (PI) controller with proper compensation in its feedback path. The control characteristics will be discussed in more detail in Section 3.1.5. The bottom half of its feedback network, $R_{f 2}$, is comprised of the parallel combination of the resistors in the voltage divider feeding back a fraction of the high voltage output.

## Slew Rate Limitations

The slew rate dictates the highest acceptable operating frequency and largest acceptable voltage amplitude for each stage. The slew rate of an op-amp is related to the peak voltage at the output by:

$$
\begin{equation*}
\mathrm{SR}=\frac{d V_{o u t}}{d t} \tag{3.8}
\end{equation*}
$$



Figure 3-3: The circuit model for the first two op-amp stages: a pre-gain stage followed by a proportional-integral controller. Here, $R_{f 2}$ is the parallel combination of the high voltage divider at the output of the signal source, given by $R_{d 1} \| R_{d 2}$.
and is determined by the internal topology and biasing. The slew rate, as a function of the input frequency, $f$, and amplitude ceiling, $V_{p k}$, is given by

$$
\begin{equation*}
\mathrm{SR} \geq 2 \pi f \cdot V_{p k} \tag{3.9}
\end{equation*}
$$

This relation sets the minimum slew rate necessary for the op-amp to produce an undistorted output for a given frequency and peak voltage.

For the purposes of the pre-gain op-amp and PI controller, the minimum slew rates necessary at the extreme ends of the desired operating region and for ideal operation are

$$
\begin{align*}
& \mathrm{SR}_{\min }=2 \pi \cdot 10 \mathrm{kHz} \cdot 12 \mathrm{~V}=0.75 \mathrm{~V} / \mu \mathrm{s}  \tag{3.10a}\\
& \mathrm{SR}_{\min }=2 \pi \cdot 100 \mathrm{kHz} \cdot 12 \mathrm{~V}=7.5 \mathrm{~V} / \mu \mathrm{s} \tag{3.10b}
\end{align*}
$$

which fall well below the specified $60 \mathrm{~V} / \mathrm{us}$ slew rate of the AD8620 [3].
Failing to reach the minimum slew rate does not necessarily prohibit all functionality. Instead it lessens the output capabilities of the system, in one of two ways. If a stage can not meet the minimum slew rate specification, the op-amp may be driven at a lower frequency or signal amplitude to reduce the minimum slew rate. Conversely, if the slew rate criteria is disregarded the output signal will appear distorted.

## Per Stage Bandwidth Requirements

Another characteristic vital to the performance of the high voltage signal source is the bandwidth of each stage. The op-amps used in each stage must be capable of running at the highest operating frequency of the system. Furthermore, the product of the applied gain, G, and operating frequency,
$f$, must remain constant, as dictated by the op-amp's specified gain bandwidth product (GBW):

$$
\begin{equation*}
\mathrm{GBW}=\mathrm{G} \cdot f . \tag{3.11}
\end{equation*}
$$

The GBW is also based on the internal topology and technology of an op-amp and guides the design decisions regarding the maximum gain that may be applied for a given frequency. The larger the gain applied the lower the bandwidth. Thus, in applications requiring high gain, the op-amps used must have sufficiently large bandwidth in order to accommodate the large gain. The GBW of the AD8620 [3], at 25 MHz , is much larger than the highest operating frequency.

## Offset Considerations

Because the eventual output of the signal source is a transformer, offsets propagated through the signal chain are of particular concern. Offsets at the input of the transformer can result in increased losses and possible saturation. Sources of additional offset may include op-amp input offset voltage and input bias current. The input offset voltage is the voltage necessary to force the op-amp output voltage to zero with no inputs present. However, when inputs and feedback are present this offset voltage will be amplified alongside the signal:

$$
\begin{equation*}
v_{o u t}=\mathrm{G}\left(v_{i n}+V_{o s}\right) \tag{3.12}
\end{equation*}
$$

Input bias current are a fundamental property of an op-amp. Ideally, no current flows into or out of the input of the op-amp, but in reality some current is required to bias the input transistors. For the case of the signal source gain stages, a worst case offset contribution from the input bias current of the op-amp can be expressed as:

$$
\begin{equation*}
v_{\text {offset }}=I_{B}\left(R_{f} \| R_{g}\right), \tag{3.13}
\end{equation*}
$$

where $I_{B}$ is the input bias current and both $R_{f}$ and $R_{g}$ are the resistances in the non-inverting op-amp feedback network. This applies to both stages. The pre-gain stage input sees the resistance of the potentiometer. At dc, the feedback capacitor of the PI controller is effectively open and the input sees the voltage divider resistance. Therefore, if both stages use the AD8620, the total expected offset at the output can be given by the sum of the gain offset product and the offsets due to the input bias currents:

$$
\begin{equation*}
v_{o f f s e t}=\left(G_{1}+G_{2}\right) V_{o s}+\left(R_{f 1}+R_{f 2}\right) I_{B} \tag{3.14}
\end{equation*}
$$

$R_{f b x}$ denotes the lumped feedback resistances of each stage. Mitigating the offsets at these later
stages is an important consideration for the signal source.

## Implementation

The components implemented in these op-amp stages are listed in Table 3.2. The input bias current of the AD8620 is a mere 10 pA and even with extremely large feedback resistances may be safely ignored. However, the input offset is listed at $250 \mu \mathrm{~V}$, which means that large gains can potentially result in millivolt level offsets at the outputs of these stages. Since a $10 \mathrm{k} \Omega$ potentiometer is used in the feedback of the pre-gain stage, the maximum gain and bandwidth are

$$
\begin{align*}
\mathrm{G}_{\max } & =1+\frac{9 \mathrm{k} \Omega}{100 \Omega}=91  \tag{3.15a}\\
\mathrm{BW}_{\max } & =\frac{\mathrm{GBW}}{\mathrm{G}_{\max }}=275 \mathrm{kHz} \tag{3.15b}
\end{align*}
$$

Gain errors in the system may arise if the potentiometer is particularly sensitive to temperature. The error itself is less of a concern than the potential gain drift. A $5 \%$ error in the overall gain will lower the overall output voltage, but may be accounted for by simply increasing the gain. However, temperature related drift, which translates to a temperature dependent gain, produces long term effects that hinder the performance of the sensor. The Vishay Accutrim 1260 W series $10 \mathrm{k} \Omega$ potentiometer used has a low temperature coefficient of $\pm 10 \mathrm{ppm} /{ }^{\circ} \mathrm{C}$, but because the potentiometer is used radiometrically, the actual gain temperature coefficient is much lower.

Table 3.2: High Voltage Pre-Gain and PI Controller Components

| Component | Value |
| :---: | :---: |
| Op-Amps | AD8620 |
| $R_{f 1}$ | $10 \mathrm{k} \Omega$ pot, Accutrim 1260 W |
| $R_{f 2}$ | $10 \mathrm{k} \Omega \\| 1 \mathrm{M} \Omega$ |
| $C_{c}$ | 330 pF |

### 3.1.3 Wide Rail Power Operational Amplifier

The third stage is designed to use the OPA452 power op-amp, which has a much wider supply range compared to the previous stages. This voltage translation allows for another stage of closed loop amplification. Increasing the supply range enables the stage to further amplify the signal and increase the potential output voltage swing. The third stage amplifier and the output transformer, with its compensation, are shown in Figure 3-4.


Figure 3-4: The circuit diagram of the wide swing op-amp and output autotransformer.

## Gain Limitations

This stage is configured as another non-inverting amplifier with a fixed gain of two. The reason for such a conservative gain can again be explained by the slew rate and gain bandwidth product limitations. Similar to equation (3.10), the minimum slew rate necessary to utilize as much of the wider rails as possible is

$$
\begin{align*}
& \mathrm{SR}_{\text {min }}=2 \pi \cdot 10 \mathrm{kHz} \cdot 40 \mathrm{~V}=2.5 \mathrm{~V} / \mathrm{\mu s}  \tag{3.16a}\\
& \mathrm{SR}_{\text {min }}=2 \pi \cdot 100 \mathrm{kHz} \cdot 40 \mathrm{~V}=25 \mathrm{~V} / \mathrm{\mu s} \tag{3.16b}
\end{align*}
$$

The specified slew rate for the OPA452 is $7.2 \mathrm{~V} / \mathrm{\mu s}$ [4]. This means that the low end of the operating frequency range is within bounds, but the high end far exceeds the capabilities of this op-amp. While this again does not prohibit all functionality at higher frequencies, it does require a lower peak voltage at 100 kHz to remain operable. The potential output voltage from this stage is capped at $\pm 39 \mathrm{~V}$ from the supplies, but decreases as frequency increases based on the slew rate and operating frequency. The relationship between the peak output voltage and frequency is shown in Figure 3-5 and given by

$$
\begin{equation*}
v_{\text {out }}=\frac{\mathrm{SR}}{2 \pi f}=\frac{7.2 \mathrm{~V} / \mu \mathrm{s}}{2 \pi f} \tag{3.17}
\end{equation*}
$$

A large gain not only pushes the voltage output limit of the op-amp by forcing it to operate near its rails, but also affects the stability of the entire system. As discussed in Section 3.1.2, large gains lower the stage crossover frequency. The gain bandwidth product of the OPA452, which is specified to be 1.8 MHz , limits the amount of gain applied at this stage. Such a low GBW, only about one decade away from the highest operating frequency, places further emphasis on remaining conservative with the gain applied at the third stage to operate the stage below crossover.


Figure 3-5: OPA452 Peak Output Voltage vs. Frequency

## Output Resistance

The internal output resistance of an op-amp can cause stability issues when driving a capacitive load. Due to its configuration as a non-inverting amplifier, the apparent output resistance of the component is scaled by the ratio of the open and closed loop gains, given by

$$
\begin{equation*}
R_{\text {out }}=r_{o} \cdot \frac{A_{C L}}{A_{o}} . \tag{3.18}
\end{equation*}
$$

As a result, small gains result in exceedingly small output resistances. This allows an op-amp to appear as a better voltage source. However, the op-amp output resistance, $r_{o}$, along with any load capacitance will create an extra pole in the loop transmission. The location of this pole may potentially cause the op-amp to become unstable. The lower the output resistance, the lower the frequency of the additional pole, which further reduces the crossover frequency of the stage. Further feedback analysis is discussed in Section 3.1.5.

## Implementation

In line with the the design parameters, the third stage was set to a gain of 2 , which means that the bandwidth of the stage is limited to 900 kHz . In order to accommodate the high end of the operating frequency range, the stage is driven such that the largest output voltage is not greater than

$$
\begin{equation*}
v_{o}=\frac{7.2 \mathrm{~V} \mathrm{\mu s}}{2 \pi 100 \mathrm{kHz}}=11.4 \mathrm{~V} . \tag{3.19}
\end{equation*}
$$

This lowers the maximum possible output voltage, but is necessary to meet the slew rate requirements for the OPA452. The rails of the op-amp were then reduced to $\pm 25 \mathrm{~V}$ since the extra headroom was unnecessary. Table 3.3 lists the implemented parameters for the wide rail gain stage.

Table 3.3: High Voltage Wide Rail Gain Stage Components

| Component | Value |
| :---: | :---: |
| Op-Amp | OPA452 |
| $R_{1}$ | $50 \mathrm{k} \Omega$ |
| $R_{2}$ | $50 \mathrm{k} \Omega$ |
| $R_{c 1}$ | $10 \Omega$ |
| $R_{c 2}$ | $1 \mathrm{k} \Omega$ |
| $C_{c 1}$ | $2.2 \mathrm{\mu F}$, metal film |

### 3.1.4 Autotransformer

The final stage of the high voltage signal source is the output transformer. The transformer design for a single ended source is a single winding autotransformer, as depicted in Figure 3-4. This type of transformer consists of one winding with at least one center tap. By using an autotransformer less copper is needed and leakage inductances are smaller in comparison to an isolated transformer. Given a current density, $J$, and a cross sectional area, $A$, the current, $I$, through a conductor is given by:

$$
\begin{equation*}
I=J \cdot A \tag{3.20}
\end{equation*}
$$

Furthermore, for a transformer, with N turns on the primary or secondary, the total effective cross sectional area, and in a sense the amount of material used, is:

$$
\begin{equation*}
A_{t o t a l}=\frac{I \cdot N}{J} \tag{3.21}
\end{equation*}
$$

Given equal current densities and areas, the ratio between an autotransformer and two winding transformer is related by:

$$
\begin{equation*}
\frac{\text { autotransformer material }}{\text { two winding material }}=\frac{\left(N_{t}-N_{s}\right) I_{p}+N_{s}\left(I_{s}-I_{p}\right)}{N_{t} I_{p}+N_{s} I_{s}} \tag{3.22}
\end{equation*}
$$

where $N_{t}$ is the total number of turns of the autotransformer, which is equivalent to $N_{p}$, the number of turns on the primary of the two winding transformer. Simplifying and recognizing that $N_{t} I_{p}=N_{s} I_{s}$ from fundamental transformer properties, results in:

$$
\begin{equation*}
\frac{\text { autotransformer material }}{\text { two winding material }}=1-\frac{N_{s}}{N_{t}} \tag{3.23}
\end{equation*}
$$

confirming that the autotransformer makes more efficient use of its material. This makes for a physically smaller and lighter component.

The autotransformer is also more efficient electrically. Compared to a two winding transformer, it experiences lower losses through the secondary leakage impedances. This is detailed by examining

(b) Equivalent circuit model for the autotransformer.

Figure 3-6: Two circuit models for the autotransformer.
the voltage loops of the circuit model of the autotransformer, shown in Figure 3-6. Using Kirchhoff's voltage laws, these loops can be expressed as:

$$
\begin{gather*}
V_{p}=E_{p}+I_{p}\left(R_{p}+j X_{p}\right)-\left(I_{s}-I_{p}\right)\left(R_{s}+j X_{s}\right)  \tag{3.24a}\\
E_{s}=V_{s}+\left(I_{s}-I_{p}\right)\left(R_{s}+j X_{s}\right) \tag{3.24b}
\end{gather*}
$$

The losses seen at the primary due to series resistances and leakage inductances can be found by the conversion $E_{p}=N E_{s}$. Substituting this back into equation (3.24a), and simplifying results in:

$$
\begin{align*}
V_{p} & =N V_{s}+N\left(I_{s}-I_{p}\right)\left(R_{s}+j X_{p}\right)+I_{1}\left(R_{p}+j X_{p}\right)-\left(I_{s}-I_{p}\right)\left(R_{s}+j X_{s}\right)  \tag{3.25}\\
& =N V_{s}+I_{p}\left[\left(R_{p}+j X_{p}\right)+(N-1)^{2}\left(R_{s}+j X_{s}\right)\right]
\end{align*}
$$

where the losses are:

$$
\begin{align*}
& R_{l}=R_{p}+R_{s}(N-1)^{2}  \tag{3.26a}\\
& X_{l}=X_{p}+X_{s}(N-1)^{2} \tag{3.26b}
\end{align*}
$$

The ratio between the autotransformer secondary losses and those of a transformer with isolated windings is given by:

$$
\begin{equation*}
\frac{(N-1)^{2}}{N^{2}} \tag{3.27}
\end{equation*}
$$

again confirming the higher efficiency of the autotransformer due to its lower losses.
The autotransformer is not without its disadvantages. For example, there is no isolation. While this may be problematic for other applications, the standalone signal source does not demand it. In fact, the opposite is the case; the non-isolated output of the autotransformer allows for a feedback path to be wrapped around the transformer to the PI controller.

The lower leakage inductance of the autotransformer is advantageous for the sensor signal source. Since the output of the transformer drives a coaxial cable, the cable capacitance may resonate with the leakage inductance. The frequency of this resonance is

$$
\begin{equation*}
f_{\text {resonance }}=\frac{1}{2 \pi \sqrt{L_{\ell} C_{c a b l e}}}, \tag{3.28}
\end{equation*}
$$

where $L_{\ell}$ is the leakage inductance of the transformer and $C_{c a b l e}$ is the cable capacitance. The cable capacitance is a fixed parameter of the coaxial cable that increases with every additional segment. Thus, reducing the leakage inductance as much as possible forces the resonant frequency higher and farther away from the operating region. For damping, a resistor, $R_{c}$, may be placed in series with the input of the autotransformer. It may be chosen so that

$$
\begin{equation*}
R_{c}=\sqrt{\frac{L_{\ell}}{C_{c a b l e}}} \tag{3.29}
\end{equation*}
$$

but too large of an $R_{c}$ reduces damping of the parallel resonance with the magnetizing inductance. This implies that small leakage inductance is preferable.

## Inductance, Core, and Turns Design

The design of the primary of the autotransformer is not unlike that of the two winding version. Based on the core parameters, required peak voltage, and operating frequency, the magnetizing inductance and required turns may be designed. The magnetizing inductance may be determined by

$$
\begin{equation*}
L_{m, \min }=A_{L} \cdot\left(\frac{V_{p k}}{\omega B_{s a t} A}\right)^{2} \tag{3.30}
\end{equation*}
$$

where $A_{L}$, the effective inductance per winding, $B_{s a t}$, the maximum peak flux density before reaching core saturation, and $A$, the effective area, are parameters specified for a given core. The peak expected voltage at the output of the transformer is $V_{p k}$. The minimum magnetizing inductance is
primarily dictated by the maximum output current of the amplifier, $I_{\text {max }, a m p}$, driving the coil

$$
\begin{equation*}
L_{m, \text { min }}=\frac{V_{\text {primary }}}{\omega I_{\text {max }, a m p}} . \tag{3.31}
\end{equation*}
$$

With this in mind, the minimum required turns can be found by

$$
\begin{equation*}
N_{p, \min }=\sqrt{\frac{L_{m, \text { min }}}{A_{L}}} . \tag{3.32}
\end{equation*}
$$

The core used in the design is the Ferroxcube P42/29-3B9 and its specifications are listed in Table 3.4. The corner cases for the minimum magnetizing inductance and primary turns of the design are printed in Table 3.5.

Table 3.4: P42/29-3B9 Core and Material Specifications

| Parameter |  | Value |
| :---: | :---: | :---: |
| Effective Area | $A_{e}$ | $265 \mathrm{~mm}^{2}$ |
| Maximum Flux Density | $B_{\text {sat }}$ | 470 mT |
| Inductance per Turn | $A_{L}$ | $11500 \mathrm{nH} / \mathrm{N}^{2}$ |

Table 3.5: Autotransformer Design Corners

| $V_{p k}$ | $f$ | $L_{m}$ | $N_{p}$ |
| :---: | :---: | :---: | :---: |
| 200 V | 10 kHz | 7.5 mH | 26 |
| 200 V | 100 kHz | $75 \mu \mathrm{H}$ | 3 |
| 500 V | 10 kHz | 46.9 mH | 64 |
| 500 V | 100 kHz | $469.5 \mu \mathrm{H}$ | 7 |

## Implementation

The autotransformer was wound according to the 10 kHz and 200 V design, but operates up to 100 kHz and 500 V . The magnetizing inductance was doubled for margin, and other parameters are listed in Table 3.6. A threaded nylon rod and a pair of nylon nuts are used to clamp down the two halves of the core. Before clamping, it is imperative to remove any debris that may prevent a flush mating of the core halves. Even the slightest air gap between the halves is detrimental to its performance by decreasing the magnetizing inductance of the transformer, which increases the magnetizing current.

Table 3.6: Autotransformer Parameters

| Winding | Turns | Gauge | $L_{m}$ | $L_{l}$ | $R_{L}$ | $C_{\text {interwinding }}$ | $f_{\text {resonance }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Primary | 38 | 32 AWG | 14.57 mH | $12.5 \mu \mathrm{H}$ | $16 \Omega$ | 400 pF | 25 kHz |
| Secondary | 380 | 32 AWG | 1.76 H | $12.5 \mu \mathrm{H}$ | $1.7 \mathrm{k} \Omega$ | 400 pF | 25 kHz |

### 3.1.5 High Voltage Feedback and Control

## Driving Cable Capacitance

As depicted in Figure 3-7, the output of the third stage of the signal source is loaded by the parallel capacitance combination, $C_{L, p}$, of the transformer interwinding capacitance and the reflected capacitance at the primary due to the coaxial cable at the output of the secondary.


Figure 3-7: The circuit model for the third gain stage op-amp and reflected load with out-of-loop compensation resistor $R_{c}$.

The reflected load capacitance seen at the output of the third stage is found by

$$
\begin{equation*}
C_{L, p}=\left(\frac{N_{p}}{N_{s}}\right)^{2} \cdot C_{L, s} \tag{3.33}
\end{equation*}
$$

which shows that $C_{L, p}$ can present a large capacitive load. Furthermore, since the load capacitance is dominated by the cable capacitance, the longer the cable, the larger the load capacitance. This load, in combination with the output resistance of the op-amp, adds a complex pole if the inductance is include. When overdamped, the pole that matter is

$$
\begin{equation*}
f_{p}=\frac{1}{2 \pi r_{o} C_{L}} \tag{3.34}
\end{equation*}
$$

As the load capacitance increases, the frequency of the pole is lowered. If this pole is lower than the unity gain frequency of the op-amp, the phase and gain margins will suffer and consequently the op-amp may become unstable.

A zero can be added in order to mitigate the effects of the pole. This can be done by placing a resistor at the output of the op-amp, $R_{c}$ in Figure 3-7, which interacts with the load capacitance creating a zero at a frequency of

$$
\begin{equation*}
f_{z}=\frac{1}{2 \pi R_{c} C_{L}} \tag{3.35}
\end{equation*}
$$

## Proportional-Integral Controller

The output of the transformer is passed through a voltage divider and fed back to a proportionalintegral (PI) controller. The feedback network is designed to operate with unity gain at dc, while ac


Figure 3-8: The circuit model for the PI controller and plant.
signals are fed back with a return ratio so there is amplification. The capacitor $C_{f b}$ at the bottom of the divider is an open at dc so feedback is unity. At signal frequencies, the feedback ratio is

$$
\begin{equation*}
\frac{R_{d 2}}{R_{d 1}+R_{d 2}} \tag{3.36}
\end{equation*}
$$

The general block diagram for the ac control is shown in Figure 3-9.


Figure 3-9: Block diagram for the proportional-integral controller.

The plant in this system, as shown in Figure 3-8, is the combination of the OPA452 power amplifier and the autotransformer dynamics. As specified in the OPA452 datasheet, the component
exhibits a two pole roll off [4]. The power amp is configured as a non-inverting amplifier, in Figure 310 , with a gain of two, hence the return ratio. Its output however is loaded by the transformer and reflected cable capacitance. This affects the closed loop response of the power amp. The load at


Figure 3-10: The block diagram of the plant at the high voltage source output.
the output is the series RLC circuit formed by the resistor at the output of the power amp, $R$, the transformer leakage inductance, $L_{\ell}$, and the reflected cable capacitance, $C_{c a b l e}$. The output is taken after the resistor and inductor, at the top of capacitor, which forms an ac voltage divider given by

$$
\begin{align*}
\frac{v_{p, o u t}}{v_{p, l}} & =\frac{\frac{1}{s C_{c a b l e}}}{R+s L_{\ell}+\frac{1}{s C_{c a b l e}}}  \tag{3.37}\\
& =\frac{1}{s^{2} L_{\ell} C_{c a b l e}+s R C_{c a b l e}+1}
\end{align*}
$$

This is the load of the system, whose output is then divided and fed back to the controller. Finally, the full plant is the product of the closed loop response of the OPA452 and the autotransformer load.

The proportional and integral gains of the PI controller are the main parameters that control the performance of the system. These parameters manage the overshoot and settling time of the system. The proportional gain is set to about 2 and the integral gain to $3 \times 10^{-6}$. As illustrated in Figure 3-11a, the system is stable with a phase margin of $60.4^{\circ}$. The step response exhibits some ringing but settles in approximately 30 ms because the resonance is not well damped.


Figure 3-11: Plots of the dynamics for the PI controller implemented in the high voltage amplifier.

## Driven DC Offset

Lastly, as seen in Figure 3-4, an RC network is placed at the base of the primary of the transformer. The resistor prevents the transformer from appearing as a short at dc. The capacitor shorts the resistor at signal frequencies.

### 3.2 Summary of Tradeoffs

Since the signal source is the drive behind the capacitive sensing, limiting the amount of offset and amplitude and phase drift of the source is important. However, drift in the source is not so well negated. The problem with short and long term drifts appears when defining a detection boundary.

The most significant of considerations in the high voltage signal source are the tradeoffs between gain and offset, and gain and bandwidth. Though offset voltages are accounted for in the overall system, any lingering offset present at the input of a stage becomes significant because of the large gains applied stage by stage, and to the overall signal.

## Chapter 4

## Sensing Circuitry Design

This chapter will discuss the design and implementation of the sensing electronics. This includes the front end amplifiers on each receive electrode and the signal conditioning circuitry on the sensor board. The sensing circuitry is designed with many of the same considerations as the high voltage board. Low noise and small drift are still the main concerns and drive the design of the circuitry presented in this chapter.

### 4.1 Front End Amplifier

The goal of the front end amplifier is to measure the slight changes in the amplitude and phase of the input signal. Unlike previous iterations of the sensing circuitry, the standalone sensor uses two single ended front end amplifiers followed by a differential amplifier at the sensing plates with common-mode feedback. The two front end amplifiers form an output measurement

$$
\begin{equation*}
v_{o u t}=A_{d}\left(v_{1}-v_{2}\right)+A_{c m}\left(\frac{v_{1}+v_{2}}{2}\right), \tag{4.1}
\end{equation*}
$$

where $v_{1}$ and $v_{2}$ are the sensed signals into each amplifier, $A_{d}$ is the differential gain, and $A_{c m}$ is the common mode gain. The differential output signals are the source of the small sensed amplitude and phase changes, which correspond to a detection, and thus must be preserved as much as possible. On the other hand, the common mode signals are undesired and rejecting them is important. The method of common mode rejection is one of the most significant differences in the standalone sensor and will be detailed in Section 4.1.2.

The front end amplifier used in the standalone sensing system is physically located on the receive electrodes. Previous versions of the sensor treated the receive electrodes as simple plates separated from the electronics. This method reduces the complexity of the system, but lengthens the sensing node making it more susceptible to parasitic capacitances from the undriven cable and the
environment. Thus, the aim of mating the front end amplifier with the receive electrode is to:

- control the extent of the sensing node
- reduce the effects of cable capacitance and interference from inductive coupling

Addressing these issues is vital to improving the performance of the entire system.

(a) Full schematic of the front end amplifier. The capacitive T-network in the feedback path is modeled by the lumped capacitance $C_{f}$.

(b) Simplified schematic of the front end amplifier.

Figure 4-1: The full and simplified circuit diagrams for the front end amplifier.

A simplified version of the front end amplifier used in the standalone sensor is shown in Figure 41 b , where the feedback network is lumped and generalized as $Z_{f}$. For simplicity, the capacitive T-network is replaced with an equivalent effective capacitance; analysis of the T-network is discussed later in this section and in Section 4.3.1. Based on the amplifier configuration, it will convert an input current to an output voltage. Since the inverting node is a virtual ground, by applying Kirchhoff's
current law the output can be found to be

$$
\begin{align*}
v_{\text {out }} & =-i_{i n} Z_{f} \\
& =-i_{i n}\left(R_{f} \| \frac{1}{s C_{f}}\right) \tag{4.2}
\end{align*}
$$

The input current is provided by the signal source, $v_{i n}$, and the sensed capacitance to the receive electrode, $Z_{\text {in }}$, by

$$
\begin{equation*}
i_{i n}=\frac{v_{i n}}{Z_{i n}}=v_{i n} \cdot s C_{s e n} . \tag{4.3}
\end{equation*}
$$

Substituting equation (4.3) into equation (4.2) and simplifying, the transfer function of the front end amplifier in the ideal case can be shown to be

$$
\begin{equation*}
\frac{v_{o u t}}{v_{i n}}=\frac{s R_{f} C_{s e n}}{1+s R_{f} C_{f}} \tag{4.4}
\end{equation*}
$$



Figure 4-2: The generalized block diagram for the front end amplifier.

Figure 4-2 illustrates the block diagram of the front end amplifier and helps find several important system parameters. The loop transmission, $L(s)$, is the product of the forward path, $A(s)$, and the feedback path, $H(s)$,

$$
\begin{equation*}
L(s)=A(s) H(s)=A(s) \cdot \frac{Z_{i n}}{Z_{i n}+Z_{f}} \tag{4.5}
\end{equation*}
$$

The forward path consists of the open loop gain of the op-amp, as defined by the gain bandwidth product and unity gain frequency of a given component. Lastly, the closed loop transfer function of the system can be derived using Black's formula and shown to be

$$
\begin{equation*}
\frac{v_{o}}{v_{i n}}=\frac{Z_{f}}{Z_{i n}+Z_{f}} \cdot \frac{A(s)}{1+A(s) \frac{Z_{i n}}{Z_{i n}+Z_{f}}} \tag{4.6}
\end{equation*}
$$

When $\mathrm{A}(\mathrm{s})$ is sufficiently large, the transfer function can be confirmed with equation (4.4)

$$
\begin{equation*}
A(s) \rightarrow \infty: \frac{v_{o}}{v_{i n}}=\frac{Z_{f}}{Z_{i n}}=\frac{s R_{f} C_{s e n}}{1+s R_{f} C_{f}} \tag{4.7}
\end{equation*}
$$

### 4.1.1 Active Receive Electrodes

## On-Plate Implementation

The sensing node is one of the most sensitive points in the system. Constraining the sensing node to the receive electrode helps to avoid parasitic capacitances, reduces the potential to pick up extraneous signals from noise sources, and limits interference from the environment. These parasitic capacitances can be modeled by a lumped capacitor to ground at the input of the amplifier.


Figure 4-3: Front end amplifier with the modeled lumped cable and parasitic capacitance, inside the dashed box. The configuration of the front end amplifier used in the standalone sensor removes this capacitance.

In previous electrode configurations, the dominant stray capacitance was contributed by the coaxial cable connecting the electrode to the front end amplifier, as shown in Figure 4-3. To account for this in the dynamic response of the amplifier, the sensed input capacitance may be lumped together with any other stray input capacitances present in the environment

$$
\begin{align*}
Z_{i n} & =Z_{\text {sen }} \| Z_{\text {stray }} \\
& =\frac{1}{s C_{s e n}} \| \frac{1}{s C_{s t r a y}} . \tag{4.8}
\end{align*}
$$

The effect of the added capacitance is observed in the new closed loop and loop transfer functions for the system, for a real $A(s)$, which become

$$
\begin{align*}
{\frac{v_{o}}{}}_{v_{i n}}^{\prime} & =\frac{A(s) \cdot s R_{f}\left(C_{\text {sen }}+C_{\text {stray }}\right)}{s R_{f}\left(C_{i n}+C_{\text {stray }}\right)+(A(s)+1)\left(1+s R_{f} C_{f}\right)}  \tag{4.9}\\
L(s)^{\prime} & =A(s) \frac{1+s R_{f} C_{f}}{1+s R_{f}\left(C_{\text {sen }}+C_{f}+C_{\text {stray }}\right)} \tag{4.10}
\end{align*}
$$

The stray capacitance lowers the loop gain and shifts the pole lower in frequency. While the closed
loop pole is shifted lower in frequency, the zero remains at the origin. The bode plots in Figure 4-4 demonstrate these effects for one set of parameters, $R_{f}, C_{f}, C_{\text {sen }}$, with and without $C_{\text {stray }}$. For the purposes of this bode plot $R_{f}=10 \mathrm{M} \Omega, C_{f}=180 \mathrm{pF}, C_{\text {sen }}=10 \mathrm{pF}$, and $C_{\text {stray }}=100 \mathrm{pF}$.


Figure 4-4: Loop transfer functions as affected by stray capacitance.

Because the front end amplifier is located on the receive electrode, there is no cable connected to the sensing node. As a result, the cable capacitance no longer effects the input of the front end amplifier. This drastically reduces the stray capacitances at the sensing node. A typical RG-178 coaxial cable has approximately 30 pF per foot of cable and thus may easily dominate the stray capacitances present [22]. The cable interaction at the input node of the front end amplifier is removed entirely, and instead the output of the front end amplifier is buffered and sent to the signal conditioning via a properly driven cable.

## Resistive vs. Capacitive Dominated Feedback

Two feedback modes can be used in the front end amplifier: resistor dominated and capacitor dominated. The feedback network for the front end amplifier is a parallel combination of the feedback resistance and capacitance as given by

$$
\begin{equation*}
Z_{f}=\left(Z_{R_{f}} \| Z_{C_{f}}\right) \tag{4.11}
\end{equation*}
$$

These modes correspond to the dominant impedance in the parallel configuration. Dominance in this sense refers to the impedance through which the most current flows. In other words, capacitive mode feedback refers to the case where $Z_{C_{f}}$ is much smaller than $Z_{R_{f}}$, the reverse is true for resistive mode feedback. The different dynamic characteristics that each path exhibits will be discussed here, along with the tradeoffs of each mode.

As a first approximation, when $Z_{R_{f}} \ll Z_{C_{f}}$, the impedance of the feedback capacitor may be ignored and the transfer function of the front end amplifier simplifies to

$$
\begin{equation*}
\frac{v_{o}}{v_{i n}}=-\frac{R_{f}}{1 / s C_{s e n}}=-s R_{f} C_{s e n} \tag{4.12}
\end{equation*}
$$

which is the same as the transfer function for an inverting differentiator. On the other hand, when $Z_{C_{f}} \ll Z_{R_{f}}$, the feedback resistance is insignificant and thus the transfer function of the front end amplifier becomes

$$
\begin{equation*}
\frac{v_{o}}{v_{i n}}=-\frac{1 / s C_{f}}{1 / s C_{s e n}}=-\frac{C_{s e n}}{C_{f}} \tag{4.13}
\end{equation*}
$$

and the op-amp appears most similar to an inverting amplifier. The first major difference is the frequency dependence of the resistive mode feedback at signal frequencies. This frequency dependence must be accounted for when operating over a range of frequencies, as measurements at different frequencies will be scaled differently. The capacitive mode feedback does not suffer from this drawback; since the gain is the ratio of the capacitances, their frequency components are negated. The disadvantage to capacitive dominated feedback is that typically temperature coefficients and initial tolerances are much poorer for practical capacitors.

As shown in the discussion of the closed loop response of the front end amplifier, and equations (4.4) and (4.9), the former reprinted here

$$
\frac{v_{o}}{v_{i n}}=\frac{s R_{f} C_{s e n}}{1+s R_{f} C_{f}}
$$

the product $R_{f} C_{f}$ is responsible for the location of the system pole. It is important to keep the operating frequency in mind when considering the placement of this closed loop pole. The bode plot in Figure 4-5 illustrates the shape of the magnitude and phase plots for a general front end amplifier. At low frequencies the system is similar to the response of a differentiator. As the frequency increases and reaches the lower frequency knee of the magnitude plot, the response takes on the shape of the inverting op-amp. Realistically, because of the finite open loop gain, the magnitude rolls off due to the internal compensation of the op-amp. Operating at or around the pole is undesirable because of the dynamics of the region, i.e. the large frequency dependence of both gain and phase. Thus, for each feedback mode the operating frequency range should be well away from the pole contributed by the feedback network. There is also added benefit for placing the pole away from the very low


Figure 4-5: The bode plots for the front end amplifiers implemented, with finite open loop gain.
frequency range. The farther away the pole, the better the attenuation of 60 Hz pickup and other low frequency interference at the input.

The $R_{f} C_{f}$ time constants required to remain in one region of dominance straddle the pole. In other words, for resistive mode feedback the operating frequency region should be well before the pole and for the capacitive mode well after the pole. These operating regions are dictated by the requirements of the feedback mode to maintain impedance dominance. Figure 4-6 illustrates the required pole frequency for the implemented values of $R_{f}$ as a function of $C_{f}$ with horizontal lines marking the operating frequencies of the system. For the given resistances acceptable feedback capacitances for resistive dominated feedback lie above the operating frequencies; for the capacitive dominated feedback the opposite is true. This can also be inferred from the fact that capacitance is inversely proportional to impedance, i.e. smaller capacitances yield larger impedances which lead to resistor dominance in the feedback network.

The feedback network in the resistive mode demands small capacitances. In order to more accurately and precisely present small capacitances in the feedback path of the resistive mode a T-network is used, as previously depicted in Figure 4-1a. The effective capacitance seen wrapped


Figure 4-6: The frequency of the pole as a function of capacitance, plotted for the four resistor values implemented.
around the op-amp can be approximated by

$$
\begin{equation*}
C_{e f f}=\frac{C_{1} C_{2}}{\left(C_{1}+C_{2}+C_{3}\right)}, \tag{4.14}
\end{equation*}
$$

by assuming the inverting input of the op-amp is a virtual ground. This result is confirmed by noting that without $C_{3}$, the expression results in the expected series combination of $C_{1}$ and $C_{2}$.

## Tradeoffs

The relative merits of either feedback mode, and their respective operating regions, are largely influenced by the passive component properties, such as temperature coefficients, precision, and matching. More specifically, the effects these parameters have on the gain and phase responses of the front end amplifier determine the strengths and weaknesses of each feedback mode. Furthermore, the operating regions themselves respond differently to changes in these parameters.

The magnitude of the front end gain is affected by both the operating frequency and, more importantly, the ratio of the sensed capacitance and feedback capacitance. Gain errors in the resistive dominated feedback are primarily due to frequency instability of the signal source. This is because the mode operates on the ramp of the frequency response, before the $R_{f} C_{f}$ pole. This also means that since the operating frequency range is a decade wide, there will be a 20 dB difference between the gains at the low and high ends of the range. Moreover, the resistive mode does not operate at the largest gain possible because its operating point comes before the pole.

On the other hand, since the capacitive mode operates after the pole, the frequency response is essentially flat and thus not affected by a change in frequency. However, because the gain in this region is set by the feedback capacitor, any fluctuations in its capacitance are detrimental to the gain stability of the system. If the feedback capacitor is susceptible to thermal effects, then the gain
of the system will change as the feedback capacitance changes. By operating below the pole, the resistive mode avoids drastic gain changes due to capacitance fluctuation. A wandering capacitance can be translated into a wandering pole. If the pole is placed one decade away from one end of the operating frequency range, then a frequency shift toward the operating region will alter the gain and phase of the response.

In the end, the resistive mode feedback does not suffer greatly from gain errors due to capacitance fluctuations, but is more susceptible to gain errors due to inaccurate signal frequency. Conversely, the capacitive mode is less vulnerable to frequency dependent errors and rather is more likely to be affected by the feedback capacitor inaccuracies. Lastly, the capacitive mode has a larger gain than the resistive mode. In both modes however, the small feedback capacitances must be accurate and reliable.

### 4.1.2 Common Mode Feedback

As discussed earlier, moving the front end amplifiers onto the receive electrodes and off the sensor board itself, is desirable in order to limit stray capacitances, at the sensing node, and avoid erroneous pick up from the environment. The main sources of interference are 60 Hz pick up and noise from surrounding fluorescent lamp ballasts, which typically switch around 50 kHz . However, this is not possible without splitting up the fully differential front end amplifier, as used by previous sensor implementations.

The benefit of the fully differential front end is the common mode rejection, which attenuates common mode signals introduced by the environment. The effect of the common mode signals on the differential mode output of the front end, and throughout the signal chain, is what must be limited. Common mode output signals are less of a concern because the signal chain is fully differential all the way until the ADC.

A consequence of using active receive electrodes is the need to recover the common mode rejection performance at the front end. The answer to this issue is to include a common mode feedback path designed to drive the non-inverting inputs of the two front end amplifiers and null any common mode signals. A circuit diagram is presented in Figure 4-7 and the corresponding block diagram in Figure 4-8. For the purposes of this analysis, the sensed capacitance, $C_{s}$, is fixed and at a virtual ground.

The output of the electrodes is sent, via coaxial cable, to the sensor board where the common mode signal is taken from the midpoint of two resistors, shown here as $R$. The common mode signal is then passed through an op-amp with a topology similar to the front end. The output of this op-amp then drives the non-inverting input of the front end amplifier. Furthermore, as discussed in Section 4.1.1, the capacitance in the feedback network for the common mode amplifier is implemented with a T-network. For simplicity, the effective capacitance of the T-network, according


Figure 4-7: Schematic for the half circuit common mode feedback of the front end amplifier. Feedback capacitances represent lumped T-networks. Electrode circuitry is left of the cable and sensor board circuitry to the right.
to equation (4.14) is used here. Here, G is the transfer function of the common mode amplifier given by

$$
\begin{equation*}
\mathrm{G}(s)=\frac{v_{c m}(s)}{v_{i n}(s)}=\frac{R_{c}}{\frac{R}{2}\left(s R_{c} C_{c}+1\right)} \tag{4.15}
\end{equation*}
$$

and H is the transfer function of the front end amplifier previously discussed in Section 4.1.1. Sources of interference, such as 60 Hz pick up and pick up from surrounding fluorescent lamp ballasts, are included at the input to the front end amplifier.


Figure 4-8: Block diagram for the common mode feedback of the front end amplifier.
There are two features of the common mode feedback that are important to its performance. First, since the front end amplifier is driven with the feedback, it is important that the feedback amplifier not distort the sensed signal. Second, any external interference injected into the system must be well attenuated. The compensation capacitance, $C_{c}$, is selected for a given feedback network of the front end amplifier in order to maintain stability and good attenuation of common mode signals.

To illustrate the performance of the common mode feedback the front end amplifier is modeled
with a $10 \mathrm{M} \Omega$ resistor and 180 pF capacitor. Furthermore, the compensation feedback is modeled with a $1 \mathrm{M} \Omega$ resistor. Three values for the effective compensation capacitance are shown: 2 pF , 20 pF , and 200 pF . The compensation impedance, $Z_{c}=R_{c} \| C_{c}$, sets the dominant pole. Thus, as $Z_{c}$ increases the pole frequency decreases, which forces the common mode amplifier to cross over sooner. The loop transmission of the common mode feedback is shown in Figure 4-9a. It is evident from this plot that the system is stable with a phase margin of $90^{\circ}$ even as the compensation capacitance increases. Though the stability is unaffected by increasing $Z_{c}$, the pole in the closed loop response begins to encroach on the range of operating frequencies. If the pole and operating frequency are too close, then the sensed signal may be attenuated and it may also incur some phase offset. As shown in Figure 4-9b, the phase contribution is more significant as the pole approaches the operating frequency range.


The common mode rejection performance, shown via the closed loop response from $v_{c m}^{\prime}$ to $v_{o u t}$, is presented in Figure 4-9. Again, the plot depicts the responses for the same increasing values of $Z_{c}$. The most notable features here are the attenuations of 60 Hz pick up and 50 kHz pick up from fluorescent lamp ballasts. As the compensation capacitance decreases, the respective frequencies of the system poles and zeros increases. In turn as these frequencies increase, the frequency range of attenuated signals expands and so does the attentuation. This is particularly apparent at 50 kHz , where the smallest compensation capacitor yields the largest attenuation. A large common mode rejection is desirable for limiting the effect of common mode signals on the differential mode output of the front end amplifier.


Figure 4-9: The bode plot of the closed loop transfer function for interference at the front end amplifier to the output. The largest expected interference contributors, at 60 Hz and 52 kHz , are noted by the dashed lines.

### 4.2 Signal Conditioning

The purpose of the signal conditioning circuitry is to optimally manage the sensed response from the output of the front end amplifier. The circuit consists of the following three blocks:

- Gain stages
- Synchronous detector and filters
- Instrumentation amplifier and ADC

The primary function of each stage and its adaptations are discussed in the following sections. A full system block diagram is depicted in Figure 4-10. The sensed signal is amplified as early as possible and then passed to the synchronous detector. This demodulates the signal, which is then low pass filtered. An instrumentation amplifier is then used to amplify and level shift the signal. The signal is again filtered and sent to an analog to digital converter (ADC) which is finally read by the microcontroller unit (MCU).

There are four identical copies of the signal conditioning circuitry beginning from the last gain stage and ending with the ADC. The purpose of this is primarily to allow for flexibility at the demodulation stage. Multiple independent channels allows for different simultaneous chopping frequencies and in phase and quadrature measurements of the same input signal. A final two copies of the signal chain are used for measuring the high voltage signal source for the purposes of normalizing the measurements by any drift present in the signal source.


Figure 4-10: The generalized block diagram for the signal conditioning circuitry. The first gain stage is singled ended and located on each respective electrode. The following stages are all fully differential and reside on the sensor board. The dashed box is replicated four times.

Much of the general topology and design is adapted from previous implementations of the occupancy sensor [1]. The components used in the realization of the circuitry and measured performance characteristics are listed after each section.

### 4.2.1 Gain Stages

Three separate gain stages amplify and buffer the sensed signal from the output of the sensor front end. The first gain stage is located immediately after the front end amplifier on the receive electrodes. The op-amp is configured as a non-inverting amplifier. In addition to the gain, this stage is employed as a cable driver sending the sensed signal from the receive electrodes to the next stage of the signal conditioning electronics on the sensor board. The additional stage on the electrode helps isolate the sensing components from the rest of the circuit. A coaxial cable at the output of an op-amp appears as a capacitive load, as previously discussed in Section 3.1.5, and can add a pole to the transfer function of the amplifier. In order to maintain stability, this pole must be kept far from the unity gain frequency of the amplifier

$$
\begin{equation*}
f_{p}=\frac{1}{2 \pi R_{o} C_{L}} \ll \frac{\mathrm{GBW}}{A_{C L}} \tag{4.16}
\end{equation*}
$$

where GBW is the gain bandwidth product of the amplifier, $A_{C L}$ is the closed loop gain, $R_{o}$ is the output resistance of the amplifier, and $C_{L}$ is the capacitive load at the output.

The next two gain stages are placed on the sensor board with the rest of the downstream signal conditioning electronics. Unlike the stage on the electrodes, these two stages are fully differential gain stages. The incoming signals from each electrode comprise the positive and negative inputs to the second stage. The third gain stage marks the beginning of the replicated chain. Without a third
op-amp at the beginning of each replicated channel, the inputs to the four multipliers may present possibly interacting loads to the previous single op-amp second stage.

The pair of signal chains used to measure the high voltage source are structured slightly differently. The measurement of the signal source is singled ended as opposed to differential and is measured directly from a voltage divider at the output. This means there is no electrode necessary, and thus no first stage. Furthermore, in order to utilize the same path the fully differential second gain stage is configured according to Figure $4-11$, which is adapted from the component application note [23].


Figure 4-11: A singled ended input to differential output op-amp configuration.

### 4.2.2 Synchronous Detector and Filters

The synchronous detection used in the standalone sensor is carried over from previous implementations of the sensing circuitry. Explicit details regarding the principles involved have been thoroughly discussed as it pertains to the signal conditioning circuitry in this type of system, but will be reviewed more generally here [1, 6]. The multiplier and filter topology are presented in Figure 4-12.

The basic concept involves a high frequency carrier signal modulated by a low frequency signal of interest. The demodulation is then performed at the carrier frequency via a signal derived from the initial synthesized carrier signal. The result can then be filtered to recover the signal of interest. The implementation for the standalone sensor diverges from previous versions by measuring both the in phase and quadrature components of the modulated signal. To do so, the input signal is


Figure 4-12: Block diagram of the synchronous detector and low pass filters.
multiplied separately by a signal in phase and a signal $90^{\circ}$ out of phase. This reduces the impact of any phase error between the input signal and the demodulating signals. Furthermore, this method provides more, useful information about the environment. The signal conditioning circuitry is split into pairs of channels, the first channel of the pair performs in phase demodulation and the second channel performs the quadrature demodulation.

## Synchronous Detection Analysis

A more in depth analysis begins by expressing the input to the multiplier as:

$$
\begin{equation*}
w(t)=A m(t) \cos \left(\omega_{c} t+\varphi\right) \tag{4.17}
\end{equation*}
$$

or the time domain product of the carrier signal, $A \cos \left(\omega_{c} t+\varphi\right)$, and the modulation function, $m(t)$, where $\varphi$ is the phase of the signal at the input of the synchronous detector. The modulation function is what is to be recovered from the input and represents the sensed fluctuations in capacitance, and thus target movement and presence. In order to do so, the input is then multiplied by a signal at the carrier frequency. The in phase and quadrature signals can then be represented by

$$
\begin{align*}
& q_{I}(t)=w(t) \cdot \cos \left(\omega_{c} t+\varphi_{1}\right)=A m(t) \cos \left(\omega_{c} t+\varphi\right) \cdot \cos \left(\omega_{c} t+\varphi_{1}\right)  \tag{4.18a}\\
& q_{Q}(t)=w(t) \cdot \sin \left(\omega_{c} t+\varphi_{2}\right)=A m(t) \cos \left(\omega_{c} t+\varphi\right) \cdot \sin \left(\omega_{c} t+\varphi_{2}\right) \tag{4.18b}
\end{align*}
$$

where $\varphi_{x}$, the phase of the derived carrier signal, may not necessarily be equal to the phase $\varphi$ of the input signal. The next step in the process requires two product-to-sum identities:

$$
\begin{align*}
\cos \theta \cdot \cos \varphi & =\frac{1}{2}[\cos (\theta-\varphi)+\cos (\theta+\varphi)]  \tag{4.19a}\\
\cos \theta \cdot \sin \varphi & =\frac{1}{2}[\sin (\theta+\varphi)-\cos (\theta-\varphi)] \tag{4.19b}
\end{align*}
$$

in order to reduce (4.18) into the following forms:

$$
\begin{align*}
& q_{I}(t)=\frac{A m(t)}{2}\left[\cos \left(\varphi-\varphi_{1}\right)+\cos \left(2 \omega_{c} t+\varphi+\varphi_{1}\right)\right]  \tag{4.20a}\\
& q_{Q}(t)=\frac{A m(t)}{2}\left[\sin \left(2 \omega_{c} t+\varphi+\varphi_{2}\right)-\cos \left(\varphi-\varphi_{2}\right)\right] . \tag{4.20~b}
\end{align*}
$$

Previous implementations, that do not obtain $q_{Q}(t)$, stop at this point and pass $q_{I}(t)$ down the signal chain where the higher frequency copy of the signal, at $2 \omega_{c} t$, is filtered out. The standalone sensor circuitry follows suit, but sends both $q_{I}(t)$ and $q_{Q}(t)$ through the low pass filters. The filtered signals from (4.20) may be combined by finding the magnitude of the two signals:

$$
\begin{equation*}
r_{I Q}(t)=\sqrt{r_{I}(t)^{2}+r_{Q}(t)^{2}}=\sqrt{\left[\frac{A m(t)}{2} \cos \left(\varphi-\varphi_{1}\right)\right]^{2}+\left[-\frac{A m(t)}{2} \sin \left(\varphi-\varphi_{2}\right)\right]^{2}} \tag{4.21}
\end{equation*}
$$

Using another trigonometric identity:

$$
\begin{equation*}
\sin ^{2} \theta+\cos ^{2} \theta=1 \tag{4.22}
\end{equation*}
$$

the result can be further simplified:

$$
\begin{align*}
r_{I Q}(t) & =\sqrt{\left(\frac{A m(t)}{2}\right)^{2}\left(\cos ^{2}\left(\varphi-\varphi_{1}\right)+\sin ^{2}\left(\varphi-\varphi_{2}\right)\right)}  \tag{4.23}\\
& =\frac{A m(t)}{2} \sqrt{\sin ^{2}\left(\varphi-\varphi_{2}\right)+\cos ^{2}\left(\varphi-\varphi_{1}\right)}
\end{align*}
$$

The eventual output of the multiplier and filters is the recovered sensed signal, $m(t)$, multiplied by a scaling factor dependent on any potential phase errors.

## Implementation

The synchronous detector is realized with a set of four analog switches, shown in Figure 4-13, configured in a full bridge topology and driven by the in phase, $s$, and quadrature, $\bar{s}$, clock signals to form a square wave multiplier.

Square wave multiplication also necessitates the use of low pass filtering. Since a square wave can be defined as the infinite series of its Fourier series terms:

$$
\begin{equation*}
\frac{4}{\pi} \sum_{n=1,3,5, \ldots}^{\infty} \frac{1}{n} \sin \left(n \omega_{c} t\right) \tag{4.24}
\end{equation*}
$$

harmonics of the square wave create higher frequency replicas of the modulated signal. These


Figure 4-13: Circuit implementation of the synchronous detector and low pass filters.
replicas, along with the replicas at $2 \omega_{c}$, will be removed by the low pass filters.
The passive low pass filters implemented after the analog switches contain two fully differential stages followed by two singled ended stages. This topology comprises a four pole RC ladder with two repeated poles. The goal is to attenuate all signals outside of the low frequency window where the signal of interest is located. The filter poles must be placed far from the operating frequency in order to limit any unwanted attenuation and phase offset.


Figure 4-14: Circuit implementation of the clock signal synthesis. The flips flop depicted here are implemented with the $74 \mathrm{HVC74}$.

The clock signal generation is presented in Figure 4-14. The pair of clock signals for one pair of channels are generated from the same pulse width modulation (PWM) pin on the system MCU at a frequency $4 \omega_{c}$ and a $50 \%$ duty cycle. The clock signals are then sent through three D flip flops configured as divide by two counters; thus, the outputs are brought back down to the appropriate carrier frequency $\omega_{c}$. The $Q$ and $\bar{Q}$ of the first flip flop each feed the clock inputs of two separate flip flops. Since the outputs are triggered on rising edges, this configuration provides the required
$90^{\circ}$ phase shift for the multiplier and reduces the reliance on a precise $50 \%$ duty cycle input.

### 4.2.3 Instrumentation Amplifier and ADC

An instrumentation amplifier follows the low pass filters. Its purpose is to convert the differential signal to a single ended signal and level shift the output. The benefit of using an instrumentation amplifier is primarily for its low noise and low offset voltage characteristics. In this case, an autozeroing amplifier, the AD8230, is utilized for its very low offset voltage performance. This topology consists of a two stage, fully differential design with sample and hold circuitry for both stages. Figure 4-15 depicts the method used for level shifting the output as outlined in the component datasheet [19].


Figure 4-15: Circuit diagram of the instrumentation amp., with gain and level shifting, followed by the ADC .

The offset voltage of the amplifier is of particular concern because of its effect on the maximum voltage swing of the output signal:

$$
\begin{equation*}
v_{s w i n g}=2\left(v_{f s}-\left|v_{o f f s e t}\right|\right) \tag{4.25}
\end{equation*}
$$

where $v_{f s}$ is the full scale voltage of the system and $v_{o f f s e t}$ is the output offset of the amplifier. Given a rail to rail amplifier, such as the AD8230, ideally the output voltage swing makes the most of the amplifier capabilities and truly spans from rail to rail. With some voltage offset on top of the output signal, the output voltage swing will never reach its full potential. As a result, the dynamic range of the system can suffer as well. The dynamic range of the system can be defined as:

$$
\begin{equation*}
\mathrm{DR}=\frac{v_{f s}}{v_{\text {noise }}} \tag{4.26}
\end{equation*}
$$

or the ratio of the full scale range and the noise floor of the system. Optimally, the gain of the instrumentation amplifier is set such that the noise floor at the input of the ADC is no larger than the least significant bit (LSB) of the ADC. The LSB is the result of dividing the full scale voltage
by the most significant bit (MSB)

$$
\begin{equation*}
\left.v_{n o i s e}\right|_{G_{o p t}}=\frac{v_{f s}}{\mathrm{MSB}} \tag{4.27}
\end{equation*}
$$

In combining these results, the dynamic range of the system becomes:

$$
\begin{align*}
\mathrm{DR} & =\frac{v_{\text {swing }} / 2}{v_{\text {noise }}} \\
& =\frac{v_{f s}-\left|v_{\text {offset }}\right|}{v_{\text {noise }}}  \tag{4.28}\\
& =\operatorname{MSB} \cdot\left(\frac{v_{f s}-\left|v_{\text {offset }}\right|}{v_{f s}}\right) .
\end{align*}
$$

The amount of offset voltage at the output of the amplifier must be limited in order to achieve the largest dynamic range possible. It also goes without saying that limiting the noise in the system is also beneficial to not only preserving dynamic range, but to improving the overall performance. Large gains on the instrumentation amplifier may ncedlcssly amplify the noise along with the signal itself.

The final stage of the signal conditioning chain is the analog to digital converter. The LTC2484 24 bit sigma-delta ADC is used to convert the analog sensed signal at the output of the signal conditioning chain. Level shifting the output of the instrumentation amplifier is a necessary step in order to use as much of the system full scale range. Interfacing with a unipolar ADC requires that some DC offset be applied to the AC signal, such that the input to the ADC is non-negative. The logical level is the midscale value of the full operating range of the ADC ; this level maximizes the possible voltage swing and allows for equal positive and negative swings.

### 4.3 Noise, Drift, and Offset Analysis

Errors in the form of noise, drift, and offset will be analyzed for each stage of the standalone sensor circuitry. Noise is represented by probability density functions, most often of a Gaussian distribution. This means that $99.7 \%$ of the instantaneous noise in a system will be contained within $3 \sigma$ of the mean value of the noise floor of the system. The noise floor is defined as the root mean square (RMS) noise with no inputs present. With this in mind, the contributions to the cumulative noise present in the entire system can be analyzed. Accounting for noise is not so simple as summing the incurred noise from stage to stage. Rather, the square root of the sum of the squares of all of the independent noise sources must be found.

The RMS voltage noise for a resistor is

$$
\begin{equation*}
v_{n}=\sqrt{4 k_{B} T R \Delta f} \quad \mathrm{~V} / \sqrt{\mathrm{Hz}} \tag{4.29}
\end{equation*}
$$

and the RMS current noise can be found by dividing through by the resistance $R$

$$
\begin{equation*}
i_{n}=\sqrt{\frac{4 k_{B} T \Delta f}{R}} \quad \mathrm{~A} / \sqrt{\mathrm{Hz}} \tag{4.30}
\end{equation*}
$$

Here $k_{B}$ is Boltzmann's constant and $T$ is the circuit temperature measured in Kelvin. These definitions are useful when analyzing the noise performance of the circuitry for the sensor, specifically the contributions from resistors in feedback paths, filters, and other settings. Typical op-amp noise sources are twofold. They can be represented as the combination of an input voltage noise in series with one input and input current noise sources from both inputs to ground, as depicted in Figure 416.


Figure 4-16: An op-amp with voltage and current noise sources included.

Characteristics of conventional voltage and current sources, i.e. linearity and independence, apply when analyzing the contributions of each noise source. Thus superposition can be used to simplify noise analyses by opening or shorting appropriate sources, investigating the contributions of each source one at a time, and finally finding the square root of the sum of the squares of each individual noise source to find the total circuit noise.

### 4.3.1 Sensor Front End

## Gain and Phase Errors

The feedback network is affected most by the uncertainties and inaccuracies of the capacitor. Resistors are generally more precise and available with lower temperature coefficients. Recall that the closed loop transfer function of the front end is

$$
\begin{equation*}
\frac{v_{\text {out }}}{v_{\text {in }}}=\frac{s R_{f} C_{\text {sen }}}{1+s R_{f} C_{f}} \tag{4.31}
\end{equation*}
$$

The frequency of the pole in the front end transfer function can be shown to be dominated by capacitance error, given by

$$
\begin{equation*}
\frac{\delta \tau}{\tau}=\sqrt{\left(\frac{\delta R_{f}}{R_{f}}\right)^{2}+\left(\frac{\delta C_{f}}{C_{f}}\right)^{2}} \tag{4.32}
\end{equation*}
$$

where $\tau$ is the time constant of the $R_{f} C_{f}$ pole and the delta, $\delta$, of the values is the precision or error. Assuming, $1 \%$ precision resistors and $5 \%$ precision capacitors, the frequency error becomes

$$
\begin{equation*}
\frac{\delta \tau}{\tau}=\sqrt{(.01)^{2}+(.05)^{2}}=5.099 \% \tag{4.33}
\end{equation*}
$$

Therefore, the precision of the resistor is dwarfed by that of the capacitor and may be ignored. Based on the closed loop transfer function of the front end, and by taking the derivative of the gain and phase and multiplying by the error in the time constant of the feedback impedance, the gain error can be found to be

$$
\begin{align*}
\delta \mathrm{G} & =\left|\frac{d \mathrm{G}}{d \tau}\right| \cdot \delta \tau \\
& =\frac{\omega^{2} R_{f} C_{s e n} \tau}{\left[(\omega \tau)^{2}+1\right]^{3 / 2}} \cdot \delta \tau \tag{4.34}
\end{align*}
$$

and the phase error to be

$$
\begin{align*}
\delta \mathrm{P} & =\left|\frac{d \mathrm{P}}{d \tau}\right| \cdot \delta \tau  \tag{4.35}\\
& =\frac{\delta \tau}{(\omega \tau)^{2}+1}
\end{align*}
$$

## Front End Amplifier Noise

The noise model for the front end amplifier is shown in Figure 4-17. Superposition of the noise sources may be used to analyze each individual contribution to the total output noise. This total is the sum of the squared magnitude of each transfer function for a particular noise source:

$$
\begin{equation*}
\overline{v_{n o}^{2}}=\sum_{i}\left|a_{i}(s)\right|^{2} \overline{v_{n i}^{2}} \tag{4.36}
\end{equation*}
$$

Due to the synchronous detection employed in the system, the bandwidth of the circuit is narrow. Thus, the transfer functions can be assumed to be constant over the bandwidth and any frequency dependency ignored. This also means that the total mean squared noise at the output is just multiplied by the circuit bandwidth.

From the model, it can be shown that the input voltage noise is amplified by the gain of the


Figure 4-17: Schematic of the front end amplifier noise model.
front end and hence the transfer function becomes

$$
\begin{equation*}
\alpha_{e_{n}}=\frac{Z_{f}}{Z_{i n}} \tag{4.37}
\end{equation*}
$$

Next, the input current noise at the inverting terminal of the front end amplifier is converted to a voltage by the feedback impedance

$$
\begin{equation*}
\alpha_{i_{-}}=Z_{f} \tag{4.38}
\end{equation*}
$$

Since the non-inverting terminal of the op-amp is driven to the common mode of the measured signal, it will see some impedance due to the terminating resistors and cable impedance. For the operating frequency range of the standalone system, and the expected cable capacitance, $R_{t} \ll 1 / s C_{\text {cable }}$, the impedance seen at the non-inverting input becomes

$$
\begin{equation*}
Z_{+}=\frac{1}{s C_{c a b l e}} \| R_{t} \approx R_{t}, \tag{4.39}
\end{equation*}
$$

which is then amplified by the gain of the front end amplifier

$$
\begin{equation*}
\alpha_{i_{+}}=Z_{+} \cdot\left(1+\frac{Z_{f}}{Z_{i n}}\right) . \tag{4.40}
\end{equation*}
$$

The termination resistor will also add its own noise, given by

$$
\begin{equation*}
\alpha_{R_{i}}=\left(1+\frac{Z_{f}}{Z_{i n}}\right) \tag{4.41}
\end{equation*}
$$

Lastly, the voltage noise of the feedback network is the product of the current noise of the feedback resistor and the feedback impedance and is seen in its entirety at the output

$$
\begin{equation*}
\alpha_{f b}=1 \tag{4.42}
\end{equation*}
$$

The combined mean squared output voltage noise density is then

$$
\begin{align*}
\overline{v_{n o}^{2}} & =\alpha_{e_{n}}^{2} e_{n}^{2}+\alpha_{i_{-}}^{2} i_{n-}^{2}+\alpha_{i_{+}}^{2} i_{n+}^{2}+\alpha_{R_{t}} v_{n, R_{t}}^{2}+\alpha_{f b} i_{n, f b}^{2} \\
& =e_{n}^{2}\left(\frac{Z_{f}}{Z_{i n}}\right)^{2}+i_{n-}^{2} Z_{f}^{2}+i_{n+}^{2} R_{t}^{2}\left(1+\frac{Z_{f}}{Z_{i n}}\right)^{2}+\left(4 k T R_{t}\right)^{2}\left(1+\frac{Z_{f}}{Z_{i n}}\right)^{2}+\left(\frac{4 k T}{R_{f}}\right)^{2} Z_{f}^{2} \quad \mathrm{~V}^{2} / \mathrm{Hz} \tag{4.43}
\end{align*}
$$

Equation (4.43) may be referred to the input (RTI) by dividing through by the front end gain, $Z_{f} / Z_{i n}$. Evaluating the RTI noise shows that the front end attenuates all signals for which $Z_{i n}>Z_{f}$, i.e. signals lower in frequency than the $R_{f} C_{f}$ pole. This suggests that the op-amp used to implement the front end amplifier must have suitably low current noise, as it is not mitigated by the front end configuration and is instead a function of the input impedance. Furthermore, the output noise can be lowered by increasing the resistance in the feedback network.

### 4.3.2 Analog Switches and Filters

Recall that $\varphi_{1}$ and $\varphi_{2}$ are the phase errors between the input signal and the in phase and quadrature clock signals. Given the result in (4.23), the error can be observed from:

$$
\begin{equation*}
r_{I Q}(t)=\frac{A m(t)}{2} \sqrt{\sin ^{2}(\varphi)+\cos ^{2}\left(\varphi-\varphi_{e r r}\right)} \tag{4.44}
\end{equation*}
$$

where $\varphi_{e r r}=\varphi_{1}-\varphi_{2}$. There is no $\varphi_{e r r}$ for which the root of the sum of the squares is less than 1 . Therefore, any phase error incurred between the input and clock signals does not attenuate the recoverable signal. Though there is still potential for some phase error, the total possible error is reduced by more than half compared to the in phase demodulation only method where the output is:

$$
\begin{equation*}
V_{o u t}=\cos \left(\omega_{c} t\right) \cos \left(\omega_{c} t+\varphi_{e r r}\right) \tag{4.45}
\end{equation*}
$$

When including both in phase and quadrature signals, the output response never drops below one as $\varphi_{e r r}$ increases. Though phase errors may still affect the output response, their significance is
diminished.
Another consideration is the possibility that the analog switches incur a voltage offset due to charge injection. Charge injection is a result of mismatched parasitic capacitances inside an op-amp. The effects of charge injection typically show up as glitches at the output. The faster the switching or smaller the load capacitance the worse these glitches will be.

The low pass filters may also exhibit what is known as $k T C$ noise. The voltage noise contribution of a single low pass $R C$ filter is

$$
\begin{equation*}
\overline{v_{n}^{2}}=\frac{k T}{C} \tag{4.46}
\end{equation*}
$$

This means that the resistance in the filter does not contribute to the noise profile of the stage. This does not absolve the filter resistors from all responsibility. If the resistors are not matched on either side of the fully differential filter, then offsets may be applied to the output of the filter. As with any other stage, additional offsets reduce the dynamic range of the system.

### 4.3.3 Instrumentation Amplifier and ADC

The instrumentation amplifier acts as a gain stage and a level shifting stage. As such it is prone to errors from both applications. The AD8138 has a particularly difficult time applying large gains with accuracy and precision because of a large gain drift. The datasheet for the LTC2484 analog to digital converter specify a 600 nV RMS output noise [16]. Given a 5 V rail, this specification is below 22 bits of accuracy and is considered insignificant.

### 4.4 Implementation and Performance

The design criteria discussed previously were used as a basis for selecting the components used in the actualized system.

### 4.4.1 Component Selection

## On Plate Electronics

Some experiments required different pairs of receive electrodes with differing impedances in the feedback path of the front end amplifiers. The aim of these experiments was to empirically evaluate the tradeoffs between gain and noise in the first stage. The pairs of components used for each set of plates is listed in Table 5.1. The capacitances listed for the resistive modes are the lumped, effective feedback capacitances. Per the previous discussion, the pole of each pair is placed on the appropriate side of the system operating frequencies.

The required $\pm 5 \mathrm{~V}$ rails are supplied to the active receive electrodes via twisted 30 AWG wire. All signal connections, to and from the electrodes, are made over RG-178 via MMCX style connectors.

Table 4.1: Front End Amplifier Combinations

| Plates | Mode | $R_{f}$ | $C_{f}$ | Pole |
| :---: | :---: | :---: | :---: | :---: |
| Pair 1 | Capacitive | $10 \mathrm{M} \Omega$ | 180 pF | 88.4 Hz |
| Pair 2 | Capacitive | $1 \mathrm{M} \Omega$ | 2 nF | 79.6 Hz |
| Pair 3 | Resistive | $10 \mathrm{k} \Omega$ | 4.7 pF | 3.39 MHz |
| Pair 4 | Resistive | $1 \mathrm{k} \Omega$ | 40 pF | 3.98 MHz |

An LT1806 amplifies the sensed signal and drives the cable out of the receive electrodes to the sensor board and signal conditioning circuitry. The gain of this amplifier is set by the feedback network to be 10. With a gain bandwidth product of 325 MHz , the LT1806 is more than capable of driving the cable at the operating frequencies used in the system.

## Signal Conditioning Electronics

The signal conditioning circuitry is implemented based on the design in Section 4.2 and the schematics for the gain stages, multiplier and filter chain, instrumentation amplifier, and ADC are presented again here. Values of the gain setting resistors were minimized in order to reduce additional noise. The two gain stages at the beginning of the signal path are unity gain, set by $R_{f x}=R_{g x}$, in order to avoid saturating the op-amp output. The following filters have cutoffs, 160 Hz and 1.6 kHz , chosen to appropriately filter two decades below both 10 kHz and 100 kHz operating signal frequencies. The AD8230 instrumentation amplifier follows and its gain is set to 2 to minimize the effects of gain drift inherent to the component. The analog to digital convert used is the LTC2484 part, which is designed to not require additional drivers. Another set of low pass filters are connected to the inputs of the ADC per the recommendations in the component datasheet [16].

### 4.4.2 Noise and Drift

The cumulative measured noise of the system, as previously analyzed in Section 4.3, are presented in Table 4.2. These measurements profile the total measured noise at the ADC. The experiments were performed with the entire system functioning and thus are an accurate representation of the total noise expected at the input to the ADC. These tests were used as controls for the system experiments, described in Chapter 5, and thus were performed for each front end amplifier configuration. The RMS voltage noise was taken from an approximately 10 second window. Table 4.2 presents the input referred current noise.

Based on the same long term data collection used to gather the system noise profile, the drift of the entire system was also characterized. The results of the tests presented in Table 4.3 are difference between the initial and final measured value over a 10 minute test period.

Table 4.2: Measured Noise Referred to Input

| Front End Pair | RTI Noise at 10 kHz | RTI Noise at 100 kHz |
| :---: | :---: | :---: |
| $10 \mathrm{M} \Omega, 180 \mathrm{pF}$ | $0.14 \mathrm{nA}_{\mathrm{RMS}}$ | $1.02 \mathrm{nA}_{\mathrm{RMS}}$ |
| $1 \mathrm{M} \Omega, 2 \mathrm{nF}$ | $0.88 \mathrm{nA}_{\mathrm{RMS}}$ | $3.75 \mathrm{nA}_{\mathrm{RMS}}$ |
| $10 \mathrm{k} \Omega, 4.7 \mathrm{pF}$ | $0.81 \mathrm{nA}_{\mathrm{RMS}}$ | $0.93 \mathrm{nA}_{\mathrm{RMS}}$ |
| $1 \mathrm{k} \Omega, 40 \mathrm{pF}$ | $6.01 \mathrm{nA}_{\mathrm{RMS}}$ | $3.07 \mathrm{nA}_{\mathrm{RMS}}$ |

Table 4.3: Measured System Drift

| Front End Pair | Drift at 10 kHz | Drift at 100 kHz |
| :---: | :---: | :---: |
| $10 \mathrm{M} \Omega, 180 \mathrm{pF}$ | $347 \mu \mathrm{~V}$ | $-3 \mu \mathrm{~V}$ |
| $1 \mathrm{M} \Omega, 2 \mathrm{nF}$ | $27 \mu \mathrm{~V}$ | $-106 \mu \mathrm{~V}$ |
| $10 \mathrm{k} \Omega, 4.7 \mathrm{pF}$ | $-5 \mu \mathrm{~V}$ | $-25 \mu \mathrm{~V}$ |
| $1 \mathrm{k} \Omega, 40 \mathrm{pF}$ | $16 \mu \mathrm{~V}$ | $4 \mu \mathrm{~V}$ |

### 4.5 Summary of System Tradeoffs

The two feedback modes that can be implemented at the front end amplifier each have their strengths and weaknesses. The resistive mode sacrifices gain for a lesser dependence on the accuracy of the feedback capacitor by operating before the closed loop pole. The capacitive mode uses the maximum gain set by the feedback capacitor. Furthermore, the feedback resistance is the dominant factor in the noise considerations of the front end amplifier. The resistive mode will contribute more noise content than the capacitive mode because it demands a lower resistance to dominate the feedback current path.

Next, gain distribution and application balances the signal to noise ratio of the the measured signal. Early stage gain is helps to amplify the signal as much as possible before additional noise is accrued. Doing so limits the gain applied to noise accumulated in later stages.

The instrumentation amplifier is valuable for providing a low offset output. Generally however, the characteristics of available instrumentation amplifiers emphasizing select qualities over others. In this sense, low output offset may come at the expense of higher gain error or output noise. The AD8230 is an example of one such instrumentation amp.

## Chapter 5

## Occupancy Detection

## Demonstration and Performance

This chapter will present and discuss the performance of the standalone sensor system as an occupancy sensor. The following sections cover the setups, conditions, and the results of each test. These tests show that an optimal system has a maximum range of 11 feet and can sense capacitance changes down to the attofarad level. Furthermore, the tests show that the system is not limited by noise or signal integrity, but rather by physical constraints.

### 5.1 System Configuration

The standalone sensor system configuration is largely similar to previous sensor implementations integrated into fluorescent lamps. Depending on the configuration, there may be three or four electrodes of interest: one or two source electrodes and two active receive electrodes. Thus, the system may be driven single ended or differentially, but sensing is always done differentially. There are three parameters of interest regarding the placement of the electrodes:

- Distance apart (separation)
- Coplanarity
- Height off of ground

The impact of the geometry of the electrodes, specifically that of these three characteristics, is explored in this chapter.

The source signal can be derived from any source of periodic waveforms and can be single ended or differential. A system configured with the singled ended driver will rely on stray capacitive coupling, while a differentially driven system naturally presents an explicit return path.

The functional performance of the system is highly dependent on the performance of the high voltage amplifier driving the source electrodes. The signal source has a practical operating range of tens to hundreds of volts and tens of hundreds of kilohertz. The system is capable of being pushed even further, to a thousand or more volts in amplitude and a signal frequency up to megahertz, but the utility and benefit of these extremes is not investigated here.

### 5.1.1 Experimental Setups

A photograph of the experimental setup used to explore the capabilities of the single ended system is shown in Figure 5-1.


Figure 5-1: Front left view of the standalone sensor setup. The source electrode is located on the highest platform and protected by electrical tape. The receive electrodes are on either side of the source electrode and the sensor board sits between them.

The setup consists of arrangeable platforms, for easy reconfiguration of the source and measurement electrodes, to satisfy the placement requirements for different system configurations. The signal source is the high voltage amplifier described in Chapter 3. The frequency response of the transformers used in the high voltage amplifiers and the noise performance of the amplifier is also discussed in Chapter 3. Data from the sensor board was taken using a combination of MatLAB ${ }^{\left({ }^{(1)}\right.}$ Scripts and C code running on an Atmel ATmega32U4. The full code used for the experiments can be found in Appendix A.

Two power supplies are used to power the whole system, one for the high voltage amplifier and another for the active electrodes and signal conditioning board. Limiting the number of independent power supplies reduces the possibility of independent noise sources in the system. With as much
circuitry as possible on the same power supply, any ripple or noise on the rails of the system is seen equally by each device. The high voltage amplifier requires its own power supply due to its higher voltage demands. Bypass capacitors are used generously and every chip is bypassed on both rails.

### 5.2 Occupancy Detection

### 5.2.1 Range Tests

A variety of range tests were performed to measure the detection radius of the standalone sensor. The responses presented here are the magnitude of the signals measured. An example of the individual in phase and quadrature measurements is shown in Figure 5-2. The limit of the detection radius is defined by the measured noise floor of the system. One, two, and three sigmas are presented on the relevant plots to determine the edge of detection.


Figure 5-2: Representative in phase and quadrature contributions to the total magnitude measured from the sensor board.

Two types of range tests were performed. The first range test, the front to back test, begins with the subject standing 0.25 m away from the sensor setup, then taking successive 0.25 m steps away
from the sensor. This test comprises 20 datapoints, for a total distance of 5 m . For consistency, the backward steps are performed in a line at the same position for each test, typically the right most receive electrode when facing the setup. This position is away from the center line of the differential measurement and is a peak in the left to right response. The goal of this test is to determine the maximum detection radius for a given setup.

The second test, the left to right test, is a similarly stepped process. The difference for this test is that the subject steps across the face of the sensor at a fixed distance. The step size is about equal to the front to back test, but since the experiment area is rectangular there are fewer data points. Left to right tests typically span the full range of the testing area. When performed within a the detection radius of a given configuration, this test is useful for comparing relative signal to noise ratios.


Figure 5-3: A top down illustration of the front to back and left to right testing paths.

## Front End Feedback vs. Range

Sensing tests were performed with several different combinations of impedances in the front end amplifier feedback path. The front end feedback pairs evaluated are listed in Table 5.1. The goal of these tests was to determine which feedback pair provided the best sensing results. It is abundantly clear that the capacitive dominated feedback configuration is best suited for the standalone sensor. It yields the largest signals, due in part to the large gain of the capacitive mode feedback, which correspond to a larger detection range and increased sensitivity within range of the system.

Front to Back Range for Various Front End Feedback

(a) Measured responses for front to back range tests with different front end compensation.

Derivative of Front to Back Range for Various Front End Feedback

(b) Derivatives of the measured responses for front to back range tests with varied front end compensation.

Figure 5-4: Measured responses and their derivatives for front to back range tests with varied front end compensation.

(a) Measured responses for left to right range tests with different front end compensation.

Derivative of Left to Right Sensitivity for Various Front End Feedback

(b) Derivatives of the measured responses for left to right range tests with varied front end compensation.

Figure 5-5: Measured responses and their derivatives for left to right range tests with varied front end compensation.

Table 5.1: Front End Amplifier Combinations

| Plates | Mode | $R_{f}$ | $C_{f}$ | Pole |
| :---: | :---: | :---: | :---: | :---: |
| Pair 1 | Capacitive | $10 \mathrm{M} \Omega$ | 180 pF | 88.4 Hz |
| Pair 2 | Capacitive | $1 \mathrm{M} \Omega$ | 2 nF | 79.6 Hz |
| Pair 3 | Resistive | $10 \mathrm{k} \Omega$ | 4.7 pF | 3.39 MHz |
| Pair 4 | Resistive | $1 \mathrm{k} \Omega$ | 40 pF | 3.98 MHz |

## Source Voltage vs. Range

In order to explore the relationship between the source voltage and the range, tests were performed at varying source voltages. For each source voltage tested, the electrode configuration remained the same. The parameters for this set of tests is listed in Table 5.2. These tests were performed using the $10 \mathrm{M} \Omega$ and 180 pF front end feedback pair and with 6 feet of separation between receive electrodos.

Table 5.2: Varied Source Voltage Test Parameters

| Parameter | Value |
| :---: | :---: |
| Source Voltage Amplitude | $110 \mathrm{~V}, 200 \mathrm{~V}, 300 \mathrm{~V}, 400 \mathrm{~V}, 500 \mathrm{~V}$, |
| Electrode Separation | 6 ft. |
| Operating Frequency | 100 kHz |
| $R_{f}$ | $10 \mathrm{M} \Omega$ |
| $C_{f}$ | 180 pF |

As expected, larger source voltages yield larger voltage responses. Both the front to back and left to right range tests display this characteristic. This suggests that larger source voltages are beneficial for increasing the sensitivity of the system, as illustrated by Figure 5-6a. On the other hand, it is clear from the front to back derivative plot that the increased source voltage is not strongly connected to the detection range of the system. As illustrated by Figure 5-8, doubling or tripling the signal source voltage adds only a marginal increase in detection range. It can then be inferred that physical constraints limit the detection range of the capacitively coupled occupancy sensor.

Front to Back Range for Various Source Amplitudes

(a) Measured responses for front to back range tests with varied source amplitudes.

Derivative of Front to Back Range Test for Various Source Amplitudes

(b) Derivatives of the measured responses for front to back range tests with varied source amplitudes.

Figure 5-6: Measured responses and their derivatives for front to back range tests with varied source amplitudes.

(b) Derivatives of the measured responses for left to right range tests with varied source amplitudes.

Figure 5-7: Measured responses and their derivatives for left to right range tests with varied source amplitudes.


Figure 5-8: The system detection radius, based on front to back range tests, as a function of the system signal source amplitude.

The derivative of the front to back response, seen in Figure 5-6b, highlights another feature of the standalone sensor. The graph shows three distinct regions of operation, labeled as the near field region, the linear far field region, and the end of the detection range where the system noise is dominant. The noise boundary is approximate since each configuration has a varying noise profile. The near field region is located in the area where the occupant is close enough to the electrodes to act as a conduit. In such close proximity, the electric fields cannot be shunted to ground without interfering with the occupant.

The most important detail to note in far field region is its linearity. This implies that the environment is not a significant source of interference. Furthermore, to approximate the drop off of the electric field, this region may be fit and the non-linear roll off of the field modeled. For the far field region, the derivative of the response is approximately linear and thus can be modeled

$$
\begin{equation*}
y^{\prime}=\frac{k}{r^{n}} \tag{5.1}
\end{equation*}
$$

where $y$ is the measured response, $r$ the distance from the sensor, $k$ a constant scaling factor, and $n$ the dropoff of the response. By fitting this linear region, $k$ and $n$ can be approximated. The approximated values may then be evaluated with the integral of equation (5.1)

$$
\begin{equation*}
y=\frac{k}{1-n} \cdot \frac{1}{r^{n-1}} . \tag{5.2}
\end{equation*}
$$

Figure 5-9 presents the linear fit of the derivative and the modeled sensor response, each with their respective data for the $10 \mathrm{M} \Omega, 180 \mathrm{pF}$ plate. Table 5.3 present the constants and exponents for each signal source amplitude. The results of the fit show that the system response will, on average, drop off according to $\frac{1}{r^{3.6}}$.

Table 5.3: Linear Fit Parameters

| $V_{s}$ | \# of Points | Fit Distance | $k$ | $n$ | $\mathrm{R}^{2}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 110 V | 8 | 6 ft. | 3.2 | 4.66 | .9787 |
| 200 V | 8 | 6 ft. | 4.23 | 4.48 | .9766 |
| 300 V | 8 | 6 ft. | 7.65 | 4.62 | .9834 |
| 400 V | 8 | 6 ft. | 9.06 | 4.55 | .9837 |
| 500 V | 8 | 6 ft. | 13.16 | 4.68 | .9640 |


(a) Linear fit of the derivative of the front to back range test response with measured data.

(b) Modeled response of front to back range test with measured data.

Figure 5-9: Front to back range test linear fit and modeled response.

## Electrode Geometry vs. Range

The geometry of the electrodes is also tied to the performance of the sensor. Two different separations are of particular interest: the spacing between receive electrodes and the spacing between the receive electrode plane and the source electrode plane. The interest again is the effect of the geometry on the range of the system. The parameters for the tests performed are listed in Table 5.4.

Table 5.4: Varied Geometry Parameters

| Parameter | Value |
| :---: | :---: |
| Source Voltage Amplitude | 300 V |
| Receive Electrode Separation | $4 \mathrm{ft}, 6 \mathrm{ft}, 8 \mathrm{ft}$ |
| Operating Frequency | 100 kHz |

The same three operating regions can be seen, albeit to a lesser degree, in the derivative of the front to back range test. The first important feature is the near field sensitivity. As the separation decreases, the sensitivity close to the sensor increases. However, as the distance from the sensor increases, there is a crossover point at which the larger separation configuration becomes more sensitive. This implies that the sensor configuration may be tailored for a specific application. Bringing the plates closer together may be most beneficial for uses that do no require a large detection range and instead prioritize local sensitivity.

Front to Back Range Test for Various Electrode Spacings

(a) Measured responses for front to back range tests with varied electrode spacing.

Derivative of Front to Back Range Test for Various Electrode Spacings

(b) Derivatives of the measured responses for front to back range tests with varied electrode spacing.

Figure 5-10: Measured responses and their derivatives for front to back range tests with varied electrode spacing.

(b) Derivatives of the measured responses for left to right range tests with varied electrode spacing.

Figure 5-11: Measured responses and their derivatives for left to right range tests with varied electrode spacing.

## Chapter 6

## Object Detection

Based on the discussion in Chapter 5, an occupant, $p$, within the detection range of the sensor may be mapped to some response, $a_{p}$, by a function $f$,

$$
\begin{equation*}
p \xrightarrow{f} a_{p} . \tag{6.1}
\end{equation*}
$$

This concept is not restricted to people and in fact may be applied to other objects in the detection range, such as a metal object, by a second mapping

$$
\begin{equation*}
m \xrightarrow{g} a_{m} . \tag{6.2}
\end{equation*}
$$

Both $m$ and $p$ represent electric field profiles, which are based on properties, such as volume, permittivity, conductivity, shape, and orientation, among others. Independent information through $f$ and $g$ allows an occupant with an object to be resolved. This is shown experimentally in Figure 6-1, which details the frequency response of the conductivity and permittivity of human muscle. For comparison, the frequency response of aluminum is shown in Figure 6-2. The relative permittivity of metals is just 1 .


Figure 6-1: The conductivity and permittivity of human muscle as a function of frequency.


Figure 6-2: The conductivity of aluminum as a function of frequency.

### 6.1 Linear Mixing Detection Algorithm

In order to explore this, a linear mixing assumption is made, which provides

$$
\begin{equation*}
c p+d m \xrightarrow{f, g} c a_{m}+d a_{m} . \tag{6.3}
\end{equation*}
$$

The current system allows for four signals to be measured. These signals correspond to the in phase and quadrature measurements at two separate frequencies, 10 kHz and 100 kHz . Arranged in a matrix, they are

$$
\begin{align*}
\mathbf{a} & =\mathbf{K}\binom{\mathrm{P}}{\mathrm{M}} \\
\left(\begin{array}{c}
a_{I, 10} \\
a_{Q, 10} \\
a_{I, 100} \\
a_{Q, 100}
\end{array}\right) & =\left(\begin{array}{ll}
k_{1} & k_{2} \\
k_{3} & k_{4} \\
k_{5} & k_{6} \\
k_{7} & k_{8}
\end{array}\right)\binom{\mathrm{P}}{\mathrm{M}}, \tag{6.4}
\end{align*}
$$

where $\mathbf{a}_{i, j}$ is the measured response, P and M are scalar electric field cross-sections, and $k_{i}$ are the gains mapping the cross-sections to the data. Equation (6.4) can be rewritten as

$$
\begin{equation*}
\mathrm{a}_{\mathrm{pm}}=\mathrm{k}_{\text {even }} \mathrm{M}+\mathbf{k}_{o d d} \mathrm{P} . \tag{6.5}
\end{equation*}
$$

In the context of a detection algorithm, an object factor, $\rho$, is defined as the ratio of metal to person cross-sections

$$
\begin{equation*}
\rho=\frac{\mathrm{M}}{\mathrm{P}} . \tag{6.6}
\end{equation*}
$$

The object factor is the metric by which person and object detection will be based. By normalizing so that $\mathrm{P}=1$, equation (6.5) becomes

$$
\begin{equation*}
\mathbf{a}_{\mathrm{pm}}=\mathbf{k}_{\text {even }} \rho_{o}+\mathbf{k}_{\text {odd }}(1) \tag{6.7}
\end{equation*}
$$

where $\rho_{o}$ is the calibration factor. Subtracting the person response, $\left.\mathrm{P}\right|_{\mathrm{P}=1}$, from the measured response removes the influence of the person on the measurement. To best approximate the true metal gains, $\rho_{o}$ can be found by

$$
\begin{equation*}
\rho_{o}=\frac{\mathbf{k}_{\text {even }}^{T}\left(\mathbf{a}_{\mathrm{pm}}-\mathbf{k}_{\text {odd }}(1)\right)}{\mathbf{k}_{\text {even }}^{T} \mathbf{k}_{\text {even }}} \tag{6.8}
\end{equation*}
$$

and subsequently multiplied with the original $\mathbf{k}_{\text {even }}$ such that

$$
\begin{equation*}
\mathbf{k}_{\text {even }, o}=\rho_{o} \cdot \mathbf{k}_{\text {even }} \tag{6.9}
\end{equation*}
$$

and the new metal gains are compensated. Finally, with all of the gains known, the object factor for a given experiment may be determined. Using least squares, the electric field cross-sections are found by

$$
\begin{equation*}
\binom{\mathrm{P}}{\mathrm{M}}=\left(\mathbf{K}^{T} \mathbf{K}\right)^{-1} \mathbf{K}^{T} \hat{\mathbf{a}}_{\mathrm{pm}} \tag{6.10}
\end{equation*}
$$

where $\mathbf{K}$ is now comprised of $\mathbf{k}_{\text {odd }}$ and $\mathbf{k}_{\text {even,o }}$. The detection metric is then

$$
\begin{equation*}
\hat{\rho}=\frac{\mathrm{M}}{\mathrm{P}} . \tag{6.11}
\end{equation*}
$$

### 6.2 Multifrequency Tests

In practice, this algorithm is first implemented with three calibration stages in order to obtain the components necessary to determine $\mathbf{K}$. The vector $\mathbf{a}$ is the response measured from each test. All tests performed were similar to the left to right range tests. The elements that comprise a are defined as the peak to peak deltas of the in phase and quadrature response curves, as shown in Figure 6-3. This places emphasis on the sensed changes during a test. Any long term effects due to offsets present in the response are ignored. This removes any potential error in the data caused by drift in the system.

Example In Phase and Quadrature Responses


Figure 6-3: Example in phase and quadrature response curves and the measurements of interest.

This method presumes that the deltas measured for every experiment are equivalent measurements, which means that the peaks of the responses occur at the same point for each test. Figure 6-4
shows the derivatives of two pairs of in phase and quadrature curves from two different tests. The zero crossing then, corresponds to the peak of the measured response. This illustrates that while the peaks of the same test are perfectly matched, the peak position from test to test varies. However, as noted by the scale, the change in peak position is small and thus may be ignored.


Figure 6-4: Mismatch between zero crossings of the derivative response curves.

The calibration tests include a person-only run to find $\mathbf{k}_{\text {odd }}$, a metal-only test for the initial $\mathbf{k}_{\text {even }}$, and finally a test with both person and metal. The final calibration run yields the set of measured $\mathbf{a}_{\mathrm{pm}}$ needed to find the true $\mathbf{k}_{\text {even,o }}$. With the three calibration tests complete, $\rho$ may be found from equation (6.8) and finally the adjusted $\mathbf{k}_{\text {even }}$ from equation (6.9).

### 6.3 Object Detection Implementation

Preliminary data collected using the detection algorithm outlined here is shown in Table 6.1. For these tests, the system was driven with a summed 10 kHz and 100 kHz sinusoid with an amplitude of 300 V . The left to right tests were performed 1 m away from the sensor over a span of 10 ft . The metal-only calibration was performed with the aluminum cylinder, while the person-metal calibration done with an aluminum toolbox.

Table 6.1: Object Detection Results

| Object | $\frac{\mathrm{M}}{\mathrm{P}}$ |
| :---: | :---: |
| Stool | 1.97 |
| Aluminum Cylinder | 0.26 |
| Aluminum Bracket | 0.81 |

The three objects held during the tests were, from largest to smallest, a metal stool, an aluminum
cylinder, and an aluminum bracket. The results of applying the algorithm suggest that the stool had the largest cross-section of the three, followed by the bracket, and lastly the cylinder. Furthermore, though the bracket was physically smaller, other properties of its electric field cross-section are such that it has a larger effect than the cylinder.

While these are preliminary results, they suggest that linear mixing may provide a good approximation. Further testing must be done in order to confirm statistical significance.

## Chapter 7

## Conclusions and Future Work

### 7.1 Summary

Chapter 2 laid out the design parameters and requirements for the standalone capacitively coupled occupancy sensor.

Chapter 3 discussed the high voltage signal source designed to replace the fluorescent lamp. Removing the dependency on the fluorescent lamp as the signal source required the standalone system to provide an alternative. The fluorescent lamp was used as a guideline for the minimum operating requirements. The design expands on these requirements to increase the breadth of possible operating configurations. The input to the signal source is digitally synthesized and amplified as much as possible before finally driving a step-up autotransformer. The final implementation is capable of generating a single, or summed, sinusoid with an amplitude of up to 500 V over a wide frequency range from tens to hundreds of kilohertz.

Chapter 4 described the design of the standalone sensor front end amplifier and signal conditioning circuitry. A new approach was taken to design and implement the receive electrode. The front end amplifier was placed on the electrodes themselves and the sensed signal then sent on a driven cable to the signal conditioning electronics. This method is in contrast to previous iterations, where undriven cables were used to connect the inputs of the front end amplifier to passive electrodes. The new method confines the sensing node to a well controlled area and limits pickup of extraneous signals and noise. The signal conditioning circuitry synchronously detects the in phase and quadrature components of the sensed signal, which is then read by an ADC. Finally, the on board microcontroller sends the data to a computer for analysis.

Chapter 5 presented the results of the system performance tests. The detection radius was tested for various system configurations, including front end amplifier compensation, electrode spacing, and signal source amplitude. The detection range of the system experienced diminishing returns for
increases in the signal source amplitude and receive electrode spacing. Ultimately, 11 ft . was found to be the maximum detection range of the system. Sensitivity was found to scale with the signal source amplitude in the short range. Furthermore, the spacing between receive electrodes gives an indication of the tradeoffs between sensitivity and range. Overall the sensor was found to be capable of attofarad measurements.

Lastly, in Chapter 6 material detection was shown to at least be a feasible application via the linear mixing detection algorithm, though further testing is necessary for statistical value.

### 7.2 System Improvements and Alternatives

Though functional, the implementation of the standalone sensor system revealed limitations of the design. Improvements to these concerns are outlined here.

### 7.2.1 Digital Synthesis

The AD9837 direct digital synthesis chip, used to generate the input sine wave to the high voltage signal source, is not designed for use in precision systems. The output voltage temperature coefficient is the largest in the high voltage signal chain. Thus it is the weakest link regarding signal source drift. The alternative to using an all-in-one solution is to break out the individual components and reimplement them individually more accurately.

### 7.2.2 Wide Rail Power Op-Amp

While the op-amp used in the last stage of the high voltage signal source is designed for wide rail operation, its gain bandwidth product and slew rate leave a little to be desired. As such, the OPA452 cannot meet all of the demands of the standalone sensor. It is not able to be driven as hard as the rest of the high voltage circuitry. Instead a push pull output stage specifically can be designed to handle the wide rails at the operating frequencies of the sensor. This would allow the system to operate at even higher source amplitudes. Though it was showed that increases in the amplitude of the signal source have diminishing returns for the detection range, the system sensitivity would benefit greatly.

### 7.2.3 Upstream ADC

An alternative to the existing signal conditioning circuitry is to recreate it digitally. Moving the ADC upstream in the chain would allow for multiplier and filters to be completely digital. Concerns regarding impedance mismatches, precision, and noise may be ignored. Instead the difficulty involves
driving the upstream ADC without degrading the sensed signal. The ADC chosen must have a sufficient sample rate and resolution in order to accurately measure the incoming sensed signals.

### 7.3 Future Work

### 7.3.1 Differential Signal Source

One key aspect that the standalone sensor does not exactly replicate from the fluorescent lamp versions is the fully differential signal source. Instead it relies on stray coupling to provide a return path to the signal source reference. The two bulbs of the fluorescent lamp, with which previous sensors were integrated, served as a differential drive with an explicit return path. The subtleties between the two drivers and their tradeoffs will be explored in the future.

### 7.3.2 Multiple Sensor Applications

Implementing multiple sets of receive electrodes opens the possibility of imaging a space. A version of the standalone sensor, capable of multiplexing several inputs, may be employed as a form of an electrical impedance tomographer. By relying on the differing frequency responses of various materials, in a similar fashion to Chapter 6 , an object may be imaged.

### 7.3.3 Large Scale Implementation

Because the sensor is not tied to a lamp or any other type of infrastructure, it may be scaled freely. A logical next step would be to drastically increase the area of the electrodes. This may provide a method of combating the dropoff of the electric field. If such large electrodes, like a room sized installation, are indeed able to do so, then the door to large scale occupancy detection will be opened. Alternatively, the geometry of the electrodes may be configured in such a way as to aim the electric field and tune the detection range to a specific area.

## Appendix A

## Code

## A. 1 Sensor Interfacing Software in Matlab ${ }^{\circledR}$

## A.1.1 readADC.m

```
function val = readADC(s, chan)
%% Send the command to the sensor if necessary
fprintf(s,'%s',strcat('A',chan));
%% Read from the board
% matrix = fscanf(s,'%s');
raw = fscanf(s,'%02x');
matrix = rot90(raw);
%% Print channel and received data
fprintf('%c:_',chan);
for k=1:4
    fprintf('%02X_',matrix(k));
end
%% Interpret data received from the board and print and return read value
if bitget(matrix(1),6)
    result = matrix(1)*2^24+matrix(2)*2^16+matrix(3)*2^8+matrix(4);
    result = bitshift(result,-5);
    result = bitand(result,16777215);
    val = result*5/(2^24-1);
    fprintf(',,%f\n', val);
elseif bitget(matrix (1),6)== 0
```


## A.1.2 recorder.m

```
function recorder(port,pts,ADC,file)
%% Open Data Link to Board
s = open_ser(port);
%% Initialization
% port: port to collect data from
% pts: number of points to record
% ADC: array argument to select ADCs to read
% should be in the form: ['0','1']
% file: target file to save data to
% Set drive frequencies
% - x1: 10.416 kHz
% - x2: 83.333 kHz
% fprintf(s,'%s ',' p2'); % PWM frequency for demodulation
% fprintf(s,'%s ','d1'); % DDS source drive frequency
%% Open Target Save File
fid = fopen(file,'w'); % Open file with write access
fprintf (fid,'%s\r\n',datestr(now)); % Record starting time and date
% Write column headers
for k = 1:2:length(ADC)
    fprintf (fid,'%c,',ADC(k));
    fprintf (fid,'%c,', ADC(k+1));
    fprintf (fid,'iq%d,',k);
end
fprintf (fid,'\r\n'); % New line for the recorded data
%% Main plot loop
for l = 1:pts
    % Print current point to screen
    fprintf('%d:\lrcorner\r\n',l)
```

    5
    ```
    % Read one channel from board
    for k = 1:2:length(ADC)
    % Read a pair of ADCs and find sqrt of the sum of the squares
    sample_i = readADC(s,ADC(k));
    sample_q = readADC(s,ADC(k+1));
    sample = sqrt(sample_i^2 + sample_q^2);
    % Print results to screen and write to file
    fprintf ('%2.6f,_%2.6f,_%2.6f\r\n',sample_i,sample_q,sample);
        fprintf (fid,'%10.18f,%10.18f,%10.18f,',sample_i,sample_q,sample);
    end
    % Create new line for after each datapoint
    fprintf (fid,}\mp@subsup{}{}{\prime}\r\\\`)
    % Wait sufficient time to resample
    pause(1/6.7);
end
fprintf(fid,'%s',datestr(now)); % Record time and date at the end of recording
% Close file and serial port upon termination
fclose (fid);
stopasync(s);
fclose (s);
end
```


## A.1.3 liveGraph.m

```
function liveGraph(port,pts,avgs,ADC)
%% Open Data Link to Board
s = open_ser(port);
%% Initialization
% port: port to collect data from
% pts: number of points in plot buffer
% avgs: number of points to average over
% ADC array to choose which ADCs to read from
% Set drive frequencies
% - x1: 10.416 kHz
% - x2: 83.333 kHz
fprintf (s,'%s','p3'); % PWM frequency for demodulation
fprintf(s,'%s','d3'); % DDS source drive frequency
```

```
    % Initialize sample and plotting arrays
    samples_iq = zeros(length(ADC),pts);
samples_iq_avg = ones(length(ADC),1);
samples = zeros(length(ADC)/2,pts);
samples_avg = ones(length(ADC)/2,1);
% fig = figure(1);
%% Main plot loop
while(1)
    % Shift sample arrays left and append placeholder 0
    samples_iq = [samples_iq(:,2:length(samples_iq)) zeros(length(ADC),1)];
    samples = [samples(:,2:length(samples)) zeros(length(ADC)/2,1)];
    % Read one channel from board
    for k = 1:2:length(ADC)
    % Read a pair of ADCs and find sqrt of the sum of the squares
    sample_i = readADC(s,ADC(k));
    sample_q = readADC(s,ADC(k+1));
    sample = sqrt(sample_i^2 + sample_q^2);
    % Place results in appropriate row in the last column of each array
    % (this should be in place of the placeholder 0)
    samples_iq(k:k+1, length(samples_iq)) = [sample_i; sample_q];
    samples(ceil(k/2), length(samples)) = sample;
    % Print results
        fprintf('%2.6f,_%2.6f,^%2.6f\r\n',sample_i,sample_q,sample);
    end
```

    \% Get the average value of each raw channel for the last "avgs" samples
    for \(\mathrm{k}=1\) :length(ADC)
        samples_iq_avg(k,1) = mean(samples_iq(k,length(samples_iq)-avgs:end));
    end
    for \(\mathrm{k}=1\) : length(ADC)/2
        samples_avg(k,1) = mean(samples(k,length(samples)-avgs:end));
    end
    \% Populate plotting and average buffers
    plotbuf = samples;
    avgbuf \(=\) samples \(-(\) samples_avg*ones(1,length(samples)));
    \% Plot the sampled data from each ADC
ylabel ('Volts') ; title ([' Chan ' int2str(k)]) ;
axis ([1 pts $-.002+.002])$; axis ([1 pts $0 \quad .05])$

## A.1.4 rangeExpt.m

```
function response = rangeExpt(port,pts,avgpts,ADC,file)
```

\% port: port to collect data from
\% pts: number of range points to record
\% avgpts: number of samples to average at each point
$\% \quad$ should be in the form $\left[{ }^{\prime} 0, ', 1 '\right]$
\% file: target file to save data to
\%\% Open Data Link to Board
$\mathrm{s}=$ open_ser(port);

```
%% Initialize
    % Preallocate space for result
    response = zeros(length(ADC),pts);
    % Set drive frequencies
% - x1: 10.416 kHz
% - x2: 83.333 kHz
%fprintf(s,'%s ',' p1'); % PWM frequency for demodulation
fprintf (s,'%s','d3'); % DDS source drive frequency
%% Open Target Save File
fid = fopen(file,'w'); % Open file with write access
fprintf (fid,'%s\r\n',datestr(now)); %Record starting time and date
% Write column headers
for }\textrm{k}=1:2:length(ADC
    fprintf (fid,'%c,',ADC(k));
    fprintf (fid,'%c,', ADC(k+1));
    fprintf (fid,'iq%c,', ADC(k));
end
fprintf (fid,'\r\n'); % New line for the recorded data
%% Record from board
waitforbuttonpress; % Press button to start recording
for k = 1:pts
    % Press button before each point
    waitforbuttonpress;
    fprintf('%s',repmat(sprintf('\n') ,1,10) );
% pause(8);
    % (Re)-Initialize sample array
    pt_vals = zeros(length(ADC),avgpts);
    % Poll ADCs and discard result to flush
    % each ADC before recording.
    for l = 1:length(ADC)
        readADC(s,ADC(1));
    end
    % Pause sufficient time before beginning to sample
    pause(1/6.7);
    for l = 1:avgpts
        % Sample each ADC once
        for n = 1:length(ADC)
            pt_vals(n,l)=readADC(s,ADC(n));
        end
```


## A.1.5 gridExpt.m

```
function response = gridExpt(port,xpts,ypts,avgpts,ADC,file)
% Inputs:
% port: port to collect data from
% xpts: number of x points to record
5 % ypts: number of y points to record
% avgpts: number of samples to average at each point
% ADC: array argument to select ADCs to read
```

\% should be in the form ['0,,$\left.^{\prime} 1^{\prime}\right]$
\% Set drive and chop frequencies
\% - x1: 10.416 kHz
\% - x2: 83.333 kHz
\% - x3: $10.416 \& 83.333 \mathrm{kHz}$ Drive
\% Ch1: 10.416 kHz, Ch2: 83.333 kHz Chop
\% fprintf(s,'\%s ',' p1'); \% PWM Chop
$\% \operatorname{fprintf}\left(\mathrm{~s}, \% \mathrm{~s},{ }^{\prime}, \mathrm{d} 1\right.$ ') ; \% DDS
\% \% Open Target Save File
fid $=$ fopen(file,'w'); \% Open file with write acces
fprintf (fid,' $\% \mathrm{~s} \backslash \mathrm{r} \backslash \mathrm{n}^{\prime}$, datestr(now)); \% Record starting time and date
fprintf (fid, ${ }^{\prime} \% \mathrm{~s} \backslash \mathrm{r} \backslash \mathrm{n}^{\prime}, \mathrm{ADC}$ ); \% Record ADC
fprintf (fid, 'Grid: $\lrcorner \% \mathrm{~d}_{\lrcorner} \mathrm{x}_{\lrcorner} \% \mathrm{~d} \backslash \mathrm{r} \backslash \mathrm{n}^{\prime}$, xpts,ypts); \% Record grid size
\%\% Record Data from Board
waitforbuttonpress; \% Press button to start experiment
\% Iterate through each column of every row in grid
for $\mathrm{k}=1$ :ypts
for $1=1$ :xpts
\% Press button before each point waitforbuttonpress;
\% ( Re )-Initialize sample array pt_vals $=$ zeros(length(ADC), avgpts);
\% Flush ADCs before each point for $m=1$ :length(ADC)
readADC(s,ADC(m));
end
pause(1/6.7)
\% Sample each ADC at each point for $m=1$ :avgpts
for $\mathrm{n}=1$ :length(ADC)

```
                pt_vals(n,m)=readADC(s,ADC(n));
            end
            pause(1/6.7);
        end
        for m = 1:length(ADC)
            % Average the sampled values for each point
            response(l,k,m) = mean(pt_vals(m,:));
            % Write each sampled value to file
            % This will write length(ADC) rows per point.
            % There will be xpts*ypts*length(ADC) rows total,
            % as there will be a new row for each point.
            fprintf (fid,'%c,', ADC(m));
            fprintf(fid,'%10.18f,',pt_vals(m,:));
            fprintf (fid,'\r\n');
        end
    end
end
%% Write final (averaged) respones to file
    fprintf (fid,'%s\r\n','Response');
    for k = 1:ypts
    for l = 1:length(ADC)
        fprintf (fid,'%10.18f,',response(k,:,m));
        fprintf (fid,'\r\n');
    end
end
%% Close file and serial port
fclose (fid);
stopasync(s);
fclose (s);
delete(s);
clear s;
% close all ;
end
```


## A. 2 Sensor Board Software

The software below can be compiled from a fresh installation of Ubuntu with the following commands.

```
sudo apt-get install build-essential subversion git gcc-avr avr-libc dfu-programmer
cd $HOME
svn checkout https://bucket.mit.edu/svn/Standalone_Sensor/
mkdir $HOME/atmega32u4/
```

5 cd \$HOME/atmega32u4/

```
git clone https://github.com/abcminiuser/lufa-lib.git
```

cd lufa-lib/
git checkout acd92983
cd \$HOME/Standalone_Sensor/Sensor $\backslash$ and $\backslash$ Code/code/Fully_Diff/

The command
make
will compile the software. The command
make dfu
will program the ATmega32U4 microcontroller breakout board with the makefile included here. The breakout board must be reset with the HWB button held down, in order to enter the bootloader, and program the microcontroller.

## A.2.1 makefile

```
# Hey Emacs, this is a -*- makefile -*-
# Fully Differential Standalone Sensor
# MIT 04/2012
#
#
# Makefile edited for use with Atmega32U4 and
# Fully Differential Standalone Sensor by:
# BJ Thompson
#
#
# NOTE: LUFA path must be edited if not built on <sensor>
#
# Adapted from (below):
# WinAVR Makefile Template written by Eric B. Weddington, Jrg Wunsch, et al.
# >> Modified for use with the LUFA project. <<
#
# Released to the Public Domain
#
# Additional material for this makefile was written by:
# Peter Fleury
# Tim Henigan
# Colin O'Flynn
# Reiner Patommel
# Markus Pfaff
# Sander Pool
```

```
# Frederik Rouleau
# Carlos Lamas
# Dean Camera
# Opendous Inc.
# Denver Gingerich
#
# On command line:
#
# make all = Make software.
#
# make clean = Clean out built project files .
4 0
4 5
```

MCU = atmega32u4
\# Target architecture (see library "Board Types" documentation).
ARCH = AVR8

# Target board (see library "Board Types" documentation, NONE for projects not requiring

# LUFA board drivers). If USER is selected, put custom board drivers in a directory called

# Processor frequency.

# This will define a symbol, F_CPU, in all source code files equal to the

# processor frequency in Hz. You can then use this symbol in your source code to

# calculate timings. Do NOT tack on a 'UL' at the end, this will be done

# automatically to create a 32-bit value in your source code.

# This will be an integer division of F_USB below, as it is sourced by

# F_USB after it has run through any CPU prescalers. Note that this value

# does not *change* the processor frequency - it should merely be updated to

# reflect the processor speed set externally so that the code can use accurate

# software delays.

F_CPU = 16000000

# Input clock frequency.

# This will define a symbol, F_USB, in all source code files equal to the

# input clock frequency (before any prescaling is performed) in Hz. This value may

# differ from F_CPU if prescaling is used on the latter, and is required as the

# raw input clock is fed directly to the PLL sections of the AVR for high speed

# clock generation for the USB and other AVR subsections. Do NOT tack on a 'UL'

# at the end, this will be done automatically to create a 32-bit value in your

    source code.
    
# 

# If no clock division is performed on the input clock inside the AVR (via the

# CPU clock adjust registers or the clock division fuses), this will be equal to F_CPU.

F_USB = \$(F_CPU)

# Output format. (can be srec, ihex, binary)

FORMAT = ihex
1 2 0

# Target file name (without extension).

TARGET = FullyDiff

```
\# Object files directory
    \# To put object files in current directory, use a dot (.), do NOT make
    \# this an empty or blank macro!
    OBJDIR \(=\).
    \# Path to the LUFA library
LUFA_PATH \(=\)../../../../ atmega32u4/lufa-lib/trunk
\# LUFA library compile-time options and predefined tokens
LUFA_OPTS \(=-\) D USB_DEVICE_ONLY
LUFA_OPTS \(+=-\) D FIXED_CONTROL_ENDPOINT_SIZE \(=8\)
LUFA_OPTS \(+=-\) D FIXED_NUM_CONFIGURATIONS \(=1\)
LUFA_OPTS \(+=\)-D USE_FLASH_DESCRIPTORS
LUFA_OPTS \(+=-\) D USE_STATIC_OPTIONS \(=\backslash\)
"(USB_DEVICE_OPT_FULLSPEED_|_USB_OPT_REG_ENABLED_|_USB_OPT_AUTO_PLL)"
\# Create the LUFA source path variables by including the LUFA root makefile
include \$(LUFA_PATH)/LUFA/makefile
\# List C source files here. (C dependencies are automatically generated.)
SRC \(=\$(\) TARGET \() . c\)
    Descriptors.c
    \$(LUFA_SRC_USB)
    \$(LUFA_SRC_USBCLASS)
\# List C++ source files here. (C dependencies are automatically generated.)
CPPSRC \(=\)
\# List Assembler source files here.
\# Make them always end in a capital .S. Files ending in a lowercase .s
\# will not be considered source files but generated files (assembler
\# output from the compiler), and will be deleted upon "make clean"!
\# Even though the DOS/Win* filesystem matches both .s and .S the same,
\# it will preserve the spelling of the filenames, and gcc itself does
\# care about how the name is spelled on its command-line.
ASRC \(=\)
\# Optimization level, can be \([0,1,2,3, \mathrm{~s}]\).
\# \(\quad 0=\) turn off optimization. \(\mathrm{s}=\) optimize for size .
\# (Note: 3 is not always the best optimization level. See avr-libc FAQ.)
```

OPT = s

# Debugging format.

# Native formats for AVR-GCC's - g are dwarf-2 [default] or stabs.

# AVR Studio 4.10 requires dwarf-2.

# AVR [Extended] COFF format requires stabs, plus an avr-objcopy run.

DEBUG = dwarf -2

# List any extra directories to look for include files here.

# Each directory must be seperated by a space.

# Use forward slashes for directory separators.

# For a directory that has spaces, enclose it in quotes.

EXTRAINCDIRS = \$(LUFA_PATH)/

# Compiler flag to set the C Standard level.

# c89 = "ANSI" C

# gnu89 = c89 plus GCC extensions

# c99 = ISO C99 standard (not yet fully implemented)

# gnu99 = c99 plus GCC extensions

CSTANDARD = -std=c99

# Place -D or - U options here for C sources

CDEFS = -DF_CPU=$(F_CPU)UL
CDEFS += -DF_USB=$(F_USB)UL
CDEFS += -DBOARD=BOARD_$(BOARD) -DARCH=ARCH_$(ARCH)
CDEFS += \$(LUFA_OPTS)

# Place -D or -U options here for ASM sources

ADEFS = -DF_CPU=$(F_CPU)
ADEFS += -DF_USB=$(F_USB)UL
ADEFS += -DBOARD=BOARD_\$(BOARD)
ADEFS += \$(LUFA_OPTS)

# Place -D or -U options here for C++ sources

CPPDEFS = -DF_CPU=$(F_CPU)UL
CPPDEFS += -DF_USB=$(F_USB)UL
CPPDEFS += -DBOARD=BOARD_\$(BOARD)
CPPDEFS += \$(LUFA_OPTS)
\#CPPDEFS += -D__STDC_LIMIT_MACROS
\#CPPDEFS += -D__STDC_CONSTANT_MACROS

```
\(\#-\) g*: \(\quad\) generate debugging information
\(\#-\) g*: \(\quad\) generate debugging information
\# - O*: optimization level
\# - O*: optimization level
\# -f ...: tuning, see GCC manual and avr-libc documentation
\# -f ...: tuning, see GCC manual and avr-libc documentation
\# -Wall...: warning level
\# -Wall...: warning level
\# - Wa,...: tell GCC to pass this to the assembler.
\# - Wa,...: tell GCC to pass this to the assembler.
\# -adhlns...: create assembler listing
\# -adhlns...: create assembler listing
CFLAGS \(=-\mathrm{g} \$(\) DEBUG \()\)
CFLAGS \(=-\mathrm{g} \$(\) DEBUG \()\)
CFLAGS \(+=\$\) (CDEFS)
CFLAGS \(+=\$\) (CDEFS)
CFLAGS \(+=-0 \$\) (OPT)
CFLAGS \(+=-0 \$\) (OPT)
CFLAGS \(+=-\) funsigned-char
CFLAGS \(+=-\) funsigned-char
CFLAGS \(+=-\) funsigned-bitfields
CFLAGS \(+=-\) funsigned-bitfields
CFLAGS \(+=-\mathrm{ffunction}-\) sections
CFLAGS \(+=-\mathrm{ffunction}-\) sections
CFLAGS \(+=-\) fno-inline-small-functions
CFLAGS \(+=-\) fno-inline-small-functions
CFLAGS \(+=-\) fpack-struct
CFLAGS \(+=-\) fpack-struct
CFLAGS \(+=-\) fshort-enums
CFLAGS \(+=-\) fshort-enums
CFLAGS \(+=-\) fno-strict-aliasing
CFLAGS \(+=-\) fno-strict-aliasing
CFLAGS \(+=-\) Wall
CFLAGS \(+=-\) Wall
CFLAGS \(+=\)-Wstrict-prototypes
CFLAGS \(+=\)-Wstrict-prototypes
\#CFLAGS \(+=-\) mshort-calls
\#CFLAGS \(+=-\) mshort-calls
\#CFLAGS \(+=-\) fno-unit-at-a-time
\#CFLAGS \(+=-\) fno-unit-at-a-time
\#CFLAGS \(+=-\) Wundef
\#CFLAGS \(+=-\) Wundef
\#CFLAGS \(+=\) - Wunreachable-code
\#CFLAGS \(+=\) - Wunreachable-code
\#CFLAGS \(+=-\) Wsign-compare
\#CFLAGS \(+=-\) Wsign-compare
CFLAGS \(+=-\) Wa,- adhlns \(=\$(<: \% . c=\$(\) OBJDIR \() / \% .1 \mathrm{st})\)
CFLAGS \(+=-\) Wa,- adhlns \(=\$(<: \% . c=\$(\) OBJDIR \() / \% .1 \mathrm{st})\)
CFLAGS \(+=\$(\) patsubst \(\%,-\mathrm{I} \%, \$(\) EXTRAINCDIRS) \()\)
CFLAGS \(+=\$(\) patsubst \(\%,-\mathrm{I} \%, \$(\) EXTRAINCDIRS) \()\)
CFLAGS \(+=\$(\) CSTANDARD \()\)
CFLAGS \(+=\$(\) CSTANDARD \()\)
\#---------------- Compiler Options C++ ----------------------------
\#---------------- Compiler Options C++ ----------------------------
\# \(-\mathrm{g} *\) : generate debugging information
\# \(-\mathrm{g} *\) : generate debugging information
\# -O*: optimization level
\# -O*: optimization level
\# \(-\mathrm{f} \ldots\) : tuning, see GCC manual and avr-libc documentation
\# \(-\mathrm{f} \ldots\) : tuning, see GCC manual and avr-libc documentation
\# -Wall...: warning level
\# -Wall...: warning level
\# - Wa,...: tell GCC to pass this to the assembler.
\# - Wa,...: tell GCC to pass this to the assembler.
\# -adhlns...: create assembler listing
\# -adhlns...: create assembler listing
CPPFLAGS \(=-\mathrm{g} \$(\) DEBUG \()\)
CPPFLAGS \(=-\mathrm{g} \$(\) DEBUG \()\)
CPPFLAGS \(+=\$\) (CPPDEFS)
CPPFLAGS \(+=\$\) (CPPDEFS)
CPPFLAGS \(+=-0 \$\) (OPT)
CPPFLAGS \(+=-0 \$\) (OPT)
CPPFLAGS \(+=-\) funsigned-char
CPPFLAGS \(+=-\) funsigned-char
CPPFLAGS \(+=-\) funsigned-bitfields
CPPFLAGS \(+=-\) funsigned-bitfields
CPPFLAGS \(+=-\mathrm{fpack}\)-struct
CPPFLAGS \(+=-\mathrm{fpack}\)-struct
CPPFLAGS \(+=-\mathrm{fshort}-\) enums
CPPFLAGS \(+=-\mathrm{fshort}-\) enums
CPPFLAGS \(+=-\) fno-exceptions
CPPFLAGS \(+=-\) fno-exceptions
CPPFLAGS \(+=\)-Wall
CPPFLAGS \(+=\)-Wall
CPPFLAGS \(+=\)-Wundef
CPPFLAGS \(+=\)-Wundef
\#CPPFLAGS \(+=-\) mshort - calls
\#CPPFLAGS \(+=-\) mshort - calls
\#CPPFLAGS \(+=\)-fno-unit-at-a-time
\#CPPFLAGS \(+=\)-fno-unit-at-a-time
```

\#CPPFLAGS $+=-$ Wstrict-prototypes
\#CPPFLAGS $+=-$ Wunreachable-code
\#CPPFLAGS $+=-$ Wsign-compare
CPPFLAGS $+=-$ Wa, - adhlns $=\$(<: \% . c p p=\$($ OBJDIR $) / \% .1$ st $)$
CPPFLAGS $+=\$($ patsubst $\%,-I \%, \$($ EXTRAINCDIRS $))$
\#CPPFLAGS $+=\$($ CSTANDARD $)$

```
\#---------------- Assembler Options
\# - Wa,...: tell GCC to pass this to the assembler.
\# -adhlns: create listing
\# -gstabs: have the assembler create line number information; note that
\# for use in COFF files, additional information about filenames
\# and function names needs to be present in the assembler source
\# files - - see avr-libc docs [FIXME: not yet described there]
\# - listing - cont-lines: Sets the maximum number of continuation lines of hex
\# dump that will be displayed for a given single line of source input.
ASFLAGS \(=\$(\) ADEFS \()-\) Wa,- adhlns \(=\$(<: \% . S=\$(\) OBJDIR \() / \% .1 s t),-\) gstabs,-- listing - cont -
    lines \(=100\)
\#----------------- Library Options
\# Minimalistic printf version
PRINTF_LIB_MIN \(=-\) Wl,-u,vfprintf \(-l\) printf_min
\# Floating point printf version (requires MATH_LIB \(=-\operatorname{lm}\) below)
PRINTF_LIB_FLOAT \(=-\) Wl, \(-u\), vfprintf \(-l\) printf_flt
\# If this is left blank, then it will use the Standard printf version.
PRINTF_LIB \(=\)
\#PRINTF_LIB \(=\$(\) PRINTF_LIB_MIN \()\)
\(\#\) PRINTF_LIB \(=\$(\) PRINTF_LIB_FLOAT \()\)
\# Minimalistic scanf version
SCANF_LIB_MIN \(=-W 1,-u, v f s c a n f-l s c a n f \_m i n ~\)
\# Floating point \(+\%[\) scanf version (requires MATH_LIB \(=-\operatorname{lm}\) below)
SCANF_LIB_FLOAT \(=-W l,-u, v f s c a n f-l s c a n f \_f l t\)
\# If this is left blank, then it will use the Standard scanf version.
SCANF_LIB \(=\)
\(\#\) SCANF_LIB \(=\$(\) SCANF_LIB_MIN \()\)
\(\#\) SCANF_LIB \(=\$(\) SCANF_LIB_FLOAT \()\)
MATH_LIB \(=-1 \mathrm{~m}\)
    \# List any extra directories to look for libraries here.
    \# Each directory must be seperated by a space.
    \# Use forward slashes for directory separators.
    \# For a directory that has spaces, enclose it in quotes.
EXTRALIBDIRS \(=\)
\#---------------- External Memory Options
\# 64 KB of external RAM, starting after internal RAM (ATmega128!),
\# used for variables (.data/.bss) and heap (malloc()).
\#EXTMEMOPTS \(=-\) Wl,- Tdata \(=0 \times 801100,--\) defsym \(=\) _heap_end \(=0 \times 80 \mathrm{ffff}\)
\# 64 KB of external RAM, starting after internal RAM (ATmega128!),
\# only used for heap (malloc()).
\#EXTMEMOPTS \(=-\) Wl, -- section - start,. data \(=0 \times 801100,--\) defsym \(=\) _heap_end \(=0 \times 80 \mathrm{ffff}\)
EXTMEMOPTS \(=\)
\#---------------- Linker Options ----------------
\# -Wl,...: tell GCC to pass this to linker.
\# -Map: create map file
\# --cref: add cross reference to map file
LDFLAGS \(=-\) Wl,- Map \(=\$(\) TARGET \() \cdot\) map,-- cref
LDFLAGS \(+=-\) Wl,-- relax
LDFLAGS \(+=-\) Wl,-- gc - sections
LDFLAGS \(+=\$\) (EXTMEMOPTS)
LDFLAGS \(+=\$\) (patsubst \(\%,-\mathrm{L} \%, \$(\) EXTRALIBDIRS) \()\)
LDFLAGS \(+=\$\) (PRINTF_LIB) \(\$(\) SCANF_LIB) \(\$(\) MATH_LIB \()\)
\#LDFLAGS \(+=-\mathrm{T}\) linker_script.x
\#---------------- Programming Options (avrdude) ---------------
\# Programming hardware
\# Type: avrdude -c ?
\# to get a full listing .
\#
AVRDUDE_PROGRAMMER \(=j\) tagmkII
\# com1 \(=\) serial port. Use lpt1 to connect to parallel port.
AVRDUDE_PORT = usb
```

AVRDUDE_WRITE_FLASH = -U flash:w:$(TARGET).hex
#AVRDUDE_WRITE_EEPROM = -U eeprom:w:$(TARGET).eep

# Uncomment the following if you want avrdude's erase cycle counter.

# Note that this counter needs to be initialized first using - Yn,

# see avrdude manual.

\#AVRDUDE_ERASE_COUNTER = - y

# Uncomment the following if you do /not/ wish a verification to be

# performed after programming the device.

\#AVRDUDE_NO_VERIFY = - V

# Increase verbosity level. Please use this when submitting bug

# reports about avrdude. See [http://savannah.nongnu.org/projects/avrdude](http://savannah.nongnu.org/projects/avrdude)

# to submit bug reports

\#AVRDUDE_VERBOSE = -v -v
AVRDUDE_FLAGS = -p \$(MCU) -P \$(AVRDUDE_PORT) -c \$(AVRDUDE_PROGRAMMER)
AVRDUDE_FLAGS += \$(AVRDUDE_NO_VERIFY)
AVRDUDE_FLAGS += \$(AVRDUDE_VERBOSE)
AVRDUDE_FLAGS += \$(AVRDUDE_ERASE_COUNTER)
\#---------------- Debugging Options

# For simulavr only - target MCU frequency

DEBUG_MFREQ = \$(F_CPU)

# Set the DEBUG_UI to either gdb or insight.

# DEBUG_UI = gdb

DEBUG_UI = insight

# Set the debugging back-end to either avarice, simulavr.

DEBUG_BACKEND = avarice
\#DEBUG_BACKEND = simulavr

# GDB Init Filename.

GDBINIT_FILE = __avr_gdbinit

# When using avarice settings for the JTAG

JTAG_DEV = /dev/com1

# Debugging port used to communicate between GDB / avarice / simulavr.

DEBUG_PORT = 4242

```
```

    # just set to localhost unless doing some sort of crazy debugging when
    # avarice is running on a different computer.
    DEBUG_HOST = localhost

```
```


# Define programs and commands.

SHELL = sh
CC = avr-gcc
OBJCOPY = avr-objcopy
OBJDUMP = avr-objdump
SIZE = avr-size
AR = avr-ar rcs
NM = avr -nm
AVRDUDE = avrdude
REMOVE = rm -f
REMOVEDIR = rm -rf
COPY = cp
WINSHELL = cmd

# Define Messages

# English

MSG_ERRORS_NONE = Errors: none
MSG_BEGIN = -------- begin --------
MSG_END = -------- end --------
MSG_SIZE_BEFORE = Size before:
MSG_SIZE_AFTER = Size after:
MSG_COFF = Converting to AVR COFF:
MSG_EXTENDED_COFF = Converting to AVR Extended COFF:
MSG_FLASH = Creating load file for Flash:
MSG_EEPROM = Creating load file for EEPROM:
MSG_EXTENDED_LISTING = Creating Extended Listing:
MSG_SYMBOL_TABLE = Creating Symbol Table:
MSG_LINKING = Linking:
MSG_COMPILING = Compiling C:
MSG_COMPILING_CPP = Compiling C++:
MSG_ASSEMBLING = Assembling:
MSG_CLEANING = Cleaning project:
MSG_CREATING_LIBRARY = Creating library:

# Define all object files .

```

```

    @echo
    
# Display size of file.

HEXSIZE = $(SIZE) --target=$(FORMAT) \$(TARGET).hex
ELFSIZE = \$(SIZE) \$(MCU_FLAG) \$(FORMAT_FLAG) \$(TARGET).elf
MCU_FLAG = \$(shell $(SIZE) --help | grep -- --mcu > /dev/null && echo --mcu=$(MCU)
)
FORMAT_FLAG = \$(shell \$(SIZE) --help | grep -- --format=.*avr > /dev/null \&\& echo
--format=avr )
sizebefore:
@if test -f \$(TARGET).elf; then echo; echo \$(MSG_SIZE_BEFORE); \$(ELFSIZE); \
2>/dev/null; echo; fi
sizeafter:
@if test -f \$(TARGET).elf; then echo; echo \$(MSG_SIZE_AFTER); \$(ELFSIZE); \
2>/dev/null; echo; fi

# Display compiler version information.

gccversion:
@\$(CC) --version

# Program the device.

program: \$(TARGET).hex \$(TARGET).eep
\$(AVRDUDE) \$(AVRDUDE_FLAGS) \$(AVRDUDE_WRITE_FLASH) \$(AVRDUDE_WRITE_EEPROM)
flip: \$(TARGET).hex
batchisp -hardware usb -device \$(MCU) -operation erase f
batchisp - hardware usb -device \$(MCU) -operation loadbuffer \$(TARGET).hex
program
batchisp -hardware usb -device \$(MCU) -operation start reset 0
dfu: \$(TARGET).hex
-dfu-programmer \$(MCU) erase
dfu-programmer \$(MCU) flash \$(TARGET).hex
dfu-programmer \$(MCU) reset
-dfu-programmer \$(MCU) reset
flip-ee: \$(TARGET).hex \$(TARGET).eep
\$(COPY) \$(TARGET).eep \$(TARGET)eep.hex
batchisp - hardware usb - device \$(MCU) -operation memory EEPROM erase
batchisp -hardware usb - device \$(MCU) -operation memory EEPROM loadbuffer \$(
TARGET)eep.hex program

```
batchisp -hardware usb - device \(\$(\mathrm{MCU})\) - operation start reset 0
\$(REMOVE) \$(TARGET)eep.hex
dfu-ee: \$(TARGET).hex \$(TARGET).eep
dfu-programmer \$(MCU) eeprom-flash \$(TARGET).eep
dfu-programmer \(\$(\mathrm{MCU})\) reset
\# Generate avr-gdb config/init file which does the following:
\# define the reset signal, load the target file, connect to target, and set
\# a breakpoint at main().
gdb-config:
@ (REMOVE) \$(GDBINIT_FILE)
@echo define reset \(\gg\) (GDBINIT_FILE)
@echo SIGNAL SIGHUP >> (GDBINIT_FILE)
@echo end >> \$(GDBINIT_FILE)
@echo file \$(TARGET).elf >> \$(GDBINIT_FILE)
@echo target remote \(\$(\) DEBUG_HOST): \(\$(\) DEBUG_PORT) \(\gg\) (GDBINIT_FILE)
ifeq (\$(DEBUG_BACKEND),simulavr)
@echo load >> \$(GDBINIT_FILE)
endif
@echo break main >> (GDBINIT_FILE)
debug: gdb-config \$(TARGET).elf
ifeq (\$(DEBUG_BACKEND), avarice)
@echo Starting AVaRICE - Press enter when "waiting_to connect" message displays.
@ (WINSHELL) /c start avarice --jtag \$(JTAG_DEV) --erase --program --file \}
\$(TARGET).elf \$(DEBUG_HOST):\$(DEBUG_PORT)
@\$(WINSHELL) / c pause
else
@ (WINSHELL) /c start simulavr -- gdbserver --device \(\$(\mathrm{MCU})--\mathrm{clock}-\mathrm{freq} \backslash\)
\$(DEBUG_MFREQ) --port \$(DEBUG_PORT)
endif
@ (WINSHELL) /c start avr-\$(DEBUG_UI) --command=\$(GDBINIT_FILE)
\# Convert ELF to COFF for use in debugging / simulating in AVR Studio or VMLAB.
COFFCONVERT \(=\) (OBJCOPY) -- debugging
COFFCONVERT \(+=-\)-change-section-address .data-0x800000
COFFCONVERT \(+=--\) change-section-address .bss-0x800000
COFFCONVERT \(+=-\)-change-section-address .noinit-0x800000
COFFCONVERT \(+=-\)-change-section-address .eeprom-0x810000
```

coff: \$(TARGET).elf
@echo
@echo \$(MSG_COFF) \$(TARGET).cof
\$(COFFCONVERT) - 0 coff-avr \$< \$(TARGET).cof
extcoff: \$(TARGET).elf
@echo
@echo \$(MSG_EXTENDED_COFF) \$(TARGET).cof
\$(COFFCONVERT) -0 coff-ext-avr \$< \$(TARGET).cof

# Create final output files (.hex, .eep) from ELF output file.

%.hex: %.elf
@echo
@echo $(MSG_FLASH)$@
\$(OBJCOPY) - O \$(FORMAT) - R .eeprom - R .fuse -R .lock $<$@
%.eep: %.elf
@echo
@echo \$(MSG_EEPROM) $@
    -$(OBJCOPY) -j .eeprom --set-section-flags=.eeprom="alloc,load"\
--change-section-lma .eeprom=0 --no-change-warnings -0 \$(FORMAT) $<$@ |
exit 0

# Create extended listing file from ELF output file.

%.1ss: %.elf
@echo
@echo \$(MSG_EXTENDED_LISTING) \$@
\$(OBJDUMP) - - -S -z $<>$@

# Create a symbol table from ELF output file.

%.sym: %.elf
@echo
@echo \$(MSG_SYMBOL_TABLE) \$@
\$(NM) -n $<>$@

# Create library from object files .

.SECONDARY : \$(TARGET).a
.PRECIOUS : \$(OBJ)
6 4 0
%.a: \$(OBJ)
@echo
@echo \$(MSG_CREATING_LIBRARY) \$@
\$(AR) \$@ \$(OBJ)

```

645

690
    \# Link: create ELF output file from object files .
    .SECONDARY : \$(TARGET).elf
    .PRECIOUS : \$(OBJ)
    \%.elf: \$(OBJ)
        @echo
        @echo \$(MSG_LINKING) \$@
        \$(CC) \$(ALL_CFLAGS) \(\$^{\wedge}\)--output \(\$\) @ (LDFLAGS)
    \# Compile: create object files from C source files .
    \$(OBJDIR) \(/ \% .0: \%\).c
    @echo
    @echo \$(MSG_COMPILING) \$<
    \(\$(\mathrm{CC})-\mathrm{c} \$(\) ALL_CFLAGS \() \$<-\mathrm{o}\) @
    \# Compile: create object files from \(\mathrm{C}++\) source files.
    \$(OBJDIR)/\%.o: \%.cpp
    @echo
    @echo \(\$\) (MSG_COMPILING_CPP) \(\$<\)
    \$(CC) - c \$(ALL_CPPFLAGS) \$< - \(\$\) @
\# Compile: create assembler files from C source files .
\%.s : \%.c
    \$(CC) -S \$(ALL_CFLAGS) \(\$<-0 \$ @\)
    \# Compile: create assembler files from \(\mathrm{C}++\) source files.
\%.s : \%.cpp
        \$(CC) -S \$(ALL_CPPFLAGS) \$<-o \$@
    \# Assemble: create object files from assembler source files .
\$(OBJDIR)/\%.o: \%.S
    @echo
    @echo \$(MSG_ASSEMBLING) \$<
    \$(CC) - c \$(ALL_ASFLAGS) \(\$<-0 \$ @\)
    \# Create preprocessed source for use in sending a bug report.
    \%.i : \%.c
\[
\$(\mathrm{CC})-\mathrm{E}-\mathrm{mmcu}=\$(\mathrm{MCU})-\mathrm{I} . \$(\mathrm{CFLAGS}) \$<-\mathrm{o} \$ @
\]
\# Target: clean project.
clean: begin clean_list end
```

clean_list:
@echo \$(MSG_CLEANING)
\$(REMOVE) \$(TARGET).hex
\$(REMOVE) \$(TARGET).eep
\$(REMOVE) \$(TARGET).cof
\$(REMOVE) \$(TARGET).elf
\$(REMOVE) \$(TARGET).map
\$(REMOVE) \$(TARGET).sym
\$(REMOVE) \$(TARGET).lss
\$(REMOVE) $(SRC:%.c=$(OBJDIR)/%.o) $(CPPSRC:%.cpp=$(OBJDIR)/%.o) $(ASRC:%.S=$(
OBJDIR)/%.o)
\$(REMOVE) $(SRC:%.c=$(OBJDIR)/%.1st) $(CPPSRC:%.cpp=$(OBJDIR)/%.1st) $(ASRC:%.S
        =$(OBJDIR)}/%.1st
\$(REMOVE) \$(SRC:.c=.s)
\$(REMOVE) \$(SRC:.c=.d)
\$(REMOVE) \$(SRC:.c=.i)
\$(REMOVEDIR).dep
checksource:
@for f in \$(SRC) \$(CPPSRC) \$(ASRC); do \

        if [ -f $$f ]; then \
                    echo "Found_Source_File:_$$f" ; \
        else\
            echo "Source_File_Not_Found:\lrcorner$$f" ; \
        fi; done
    # Create object files directory
    $(shell mkdir $(OBJDIR) 2>/dev/null)
    # Include the dependency files.
    -include \$(shell mkdir .dep 2>/dev/null) \$(wildcard .dep/*)

# Listing of phony targets.

```
710
715
720
```

.PHONY : all begin finish end sizebefore sizeafter gccversion \
build elf hex eep lss sym coff extcoff doxygen clean
clean_list clean_doxygen program dfu flip flip-ee dfu-ee \}
debug gdb-config checksource

```

\section*{A.2. 2 FullyDiff.c}
```

/*
Fully Differential Standalone Sensor Code
MIT 04/2012
BJ Thompson
Rev. 1
*/
/*
Adapted from:
LUFA Library
Copyright (C) Dean Camera, 2012.
dean [at] fourwalledcubicle [dot] com
www.lufa-lib.org
*/
/*
Copyright 2012 Dean Camera (dean [at] fourwalledcubicle [dot] com)

```
        Permission to use, copy, modify, distribute, and sell this
    software and its documentation for any purpose is hereby granted
    without fee, provided that the above copyright notice appear in
    all copies and that both that the copyright notice and this
    permission notice and warranty disclaimer appear in supporting
    documentation, and that the name of the author not be used in
    advertising or publicity pertaining to distribution of the
    software without specific, written prior permission.

The author disclaim all warranties with regard to this software, including all implied warranties of merchantability and fitness. In no event shall the author be liable for any special, indirect or consequential damages or any damages whatsoever resulting from loss of use, data or profits, whether in an action of contract, negligence or other tortious action, arising out of or in connection with the use or performance of this software.
```

    * Main source file for the Fully Differential Standalone Sensor board.
    * This file contains the main resources for using the board:
    * - hardware configuration and initialization
    * - USB and virtual serial communication
    * 

*/
\#include "FullyDiff.h"
\#include <stdlib.h>
/** LUFA CDC Class driver interface configuration and state information. This structure is
* passed to all CDC Class driver functions, so that multiple instances of the same class
* within a device can be differentiated from one another.
*/
USB_ClassInfo_CDC_Device_t FullyDiff_CDC_Interface =
{
.Config =
{
.ControlInterfaceNumber =0,
.DataINEndpointNumber = CDC_TX_EPNUM,
.DataINEndpointSize = CDC_TXRX_EPSIZE,
.DataINEndpointDoubleBank = false,
.DataOUTEndpointNumber = CDC_RX_EPNUM,
.DataOUTEndpointSize = CDC_TXRX_EPSIZE,
.DataOUTEndpointDoubleBank = false,
.NotificationEndpointNumber = CDC_NOTIFICATION_EPNUM,
.NotificationEndpointSize = CDC_NOTIFICATION_EPSIZE,
.NotificationEndpointDoubleBank = false,
},
};
/** Standard file stream for the CDC interface when set up, so that the virtual CDC COM port
can be
* used like any regular character stream in the C APIs
*/
static FILE USBSerialStream;
/* Global Variables */
char ADC_buf[5]; // Array to consolidate ADC conversions
char lastPress = 0;
bool debugFlag = true;

```
// Generic bad input message
char \(*\) ErrStr \(=\) "Bad Input. \(\backslash r \backslash n " ;\)
/** Main program entry point. This routine contains the overall program flow, including initial
    * setup of all components and the main program loop.
    **/
    int main(void)
\{
    SetupHardware();
    /* Create a regular character stream for the interface so that it can be used with the stdio.h
        functions */
    CDC_Device_CreateStream(\&FullyDiff_CDC_Interface, \&USBSerialStream);
    //LEDs_SetAllLEDs(LEDMASK_USB_NOTREADY);
    sei();
    for (;;)
        \{
        CheckPE2();
        /* Must throw away unused bytes from the host, or it will lock up while waiting for
            the device */
        uint16_t BytesReceived = CDC_Device_BytesReceived(\&FullyDiff_CDC_Interface
        );
        if (BytesReceived)
        \{
            int16_t recByte = CDC_Device_ReceiveByte(\&FullyDiff_CDC_Interface);
        switch (recByte)
            \{
        case 'A': // ADC Command
            \{
            int16_t ADC_rec \(=0\);
            if (debugFlag)
            \{
            // Echo received command byte
                CDC_Device_SendByte(\&FullyDiff_CDC_Interface,recByte);
                CDC_Device_SendString(\&FullyDiff_CDC_Interface," :u\r \(\backslash \mathrm{n} ")\);
            \}
            // Receive channel byte and check if valid
        ADC_rec \(=\) waitforByte();
        // Select a single ADC
```

    if (ADC_rec > = '0' && ADC_rec < = '6')
    {
        uint8_t chan = ADC_rec-'0';
        ADC_flush();
        ADC_read(chan);
        ADC_response(); // Responds with 4 bytes
    }
    // Select all ADCs
    else if (ADC_rec == 'a'| ADC_rec == 'A')
    {
        for (int i = 0; i < 6; i++)
            {
            ADC_flush();
            ADC_read(i);
            ADC_response(); // Responds with 4*6=24 bytes
                }
    }
    // (Re)Configure ADCn
else if (ADC_rec == 'w')
{
// placeholder for writing to ADC
}
// Invalid input
else
reportError();
}
break;
case 'd':
{
int16_t DDS_rec = 0;
DDS_rec = waitforByte();
if (checkHex(DDS_rec))
{
if (DDS_rec == '1')
{
DDS_Config(6,0x00100000);
DDS_Config(7,0x00100000);
}
else if (DDS_rec == '2')
{
DDS_Config(6,0x00800000);
DDS_Config(7,0x00800000);

```
```

                        }
            else if (DDS_rec == '3')
                        {
            DDS_Config(6,0x00100000);
            DDS_Config(7,0x00800000);
                    }
            else if (DDS_rec == '0')
                        {
            DDS_Config(6,0);
            DDS_Config(7,0);
                        }
    }
    else
    {
            reportError();
            break;
    }
    /*
CDC_Device_SendByte(\&FullyDiff_CDC_Interface,DDS_rec);
CDC_Device_SendString(\&FullyDiff_CDC_Interface,"\r\n");
*/
}
break;
case 'D': // DDS Command
{
// Initialize DDS byte buffer
// 1 Byte channel, 4 Byte data = 5 bytes + NULL
char DDS_bytes[6];
int16_t DDS_rec = 0;
uint8_t DDS_chan = 0;
uint16_t DDS_com = 0;
// Wait for 4 incoming bytes and check if input is valid
for (int i = 0; i < 5; i++)
{
DDS_rec = waitforByte();
if (checkHex(DDS_rec))
{
// Save input if valid
DDS_bytes[i] = DDS_rec;
}
else
{
// Terminate buffer and exit if not valid
DDS_bytes[i] = '\0';
reportError();

```
```

            break;
    ```
            break;
                        }
                        }
    }
    }
// Terminate buffer
// Terminate buffer
DDS_bytes[5] = '\0';
DDS_bytes[5] = '\0';
// Extract, convert, and write DDS channel and command from input
// Extract, convert, and write DDS channel and command from input
DDS_chan = (uint8_t) (DDS_bytes[0] & 0x0F);
DDS_chan = (uint8_t) (DDS_bytes[0] & 0x0F);
DDS_com = (uint16_t) strtoul(&DDS_bytes[1],NULL,16);
DDS_com = (uint16_t) strtoul(&DDS_bytes[1],NULL,16);
DDS_Set(DDS_chan,DDS_com);
DDS_Set(DDS_chan,DDS_com);
// Echo received DDS instruction
// Echo received DDS instruction
if (debugFlag)
if (debugFlag)
    {
    {
        fprintf(&USBSerialStream,"DDS:\lrcornerChan:%X_Command:%X\r\n",
        fprintf(&USBSerialStream,"DDS:\lrcornerChan:%X_Command:%X\r\n",
            DDS_chan,DDS_com);
            DDS_chan,DDS_com);
    }
    }
    }
    }
    break;
    break;
case 'p':
case 'p':
    {
    {
int16_t pwm_rec = 0;
int16_t pwm_rec = 0;
pwm_rec = waitforByte();
pwm_rec = waitforByte();
if (checkHex(pwm_rec))
if (checkHex(pwm_rec))
    {
    {
            if (pwm_rec == '1') // Set PWM chans to 41.6kHz
            if (pwm_rec == '1') // Set PWM chans to 41.6kHz
                    {
                    {
            OCROA = 0x17;
            OCROA = 0x17;
            OCR1A = 0x0060;
            OCR1A = 0x0060;
            OCR4C = 0xC0;
            OCR4C = 0xC0;
            OCR4B = OCR4C/2;
            OCR4B = OCR4C/2;
            }
            }
            else if (pwm_rec == '2') // Set PWM chans to 333kHz
            else if (pwm_rec == '2') // Set PWM chans to 333kHz
                {
                {
            OCROA = 0x02;
            OCROA = 0x02;
            OCR1A = 0x000C;
            OCR1A = 0x000C;
            OCR4C = 0x18;
            OCR4C = 0x18;
            OCR4B = OCR4C/2;
            OCR4B = OCR4C/2;
            }
            }
            else if (pwm_rec == '3') // PWM1: 41.6kHz, PWM2: 333kHz
            else if (pwm_rec == '3') // PWM1: 41.6kHz, PWM2: 333kHz
                    {
                    {
            OCROA = 0x02;
            OCROA = 0x02;
            OCR1A = 0x0060;
            OCR1A = 0x0060;
            OCR4C = 0x18;
            OCR4C = 0x18;
            OCR4B = OCR4C / 2;
            OCR4B = OCR4C / 2;
                }
```

                }
    ```
```

    }
    ```
    }
    else
    else
    {
    {
                reportError();
                reportError();
                break;
                break;
    }
    }
    }
    }
    break;
    break;
case 'P': // PWM Command
case 'P': // PWM Command
    {
    {
CDC_Device_SendByte(&FullyDiff_CDC_Interface,recByte);
CDC_Device_SendByte(&FullyDiff_CDC_Interface,recByte);
CDC_Device_SendString(&FullyDiff_CDC_Interface,"\r\n");
CDC_Device_SendString(&FullyDiff_CDC_Interface,"\r\n");
char PWM_bytes[4];
char PWM_bytes[4];
int16_t PWM_rec = 0;
int16_t PWM_rec = 0;
for (int i = 0; i < 3; i++)
for (int i = 0; i < 3; i++)
    {
    {
        PWM_rec = waitforByte();
        PWM_rec = waitforByte();
        if (checkHex(PWM_rec))
        if (checkHex(PWM_rec))
            {
            {
            PWM_bytes[i] = PWM_rec;
            PWM_bytes[i] = PWM_rec;
                }
                }
                else
                else
                {
                {
            reportError();
            reportError();
                break;
                break;
                    }
                    }
    }
    }
PWM_bytes[3] = '\0';
PWM_bytes[3] = '\0';
    if (PWM_bytes[0] == '1')
    if (PWM_bytes[0] == '1')
    {
    {
        OCROA = (uint8_t) strtoul(&PWM_bytes[1],NULL,16);
        OCROA = (uint8_t) strtoul(&PWM_bytes[1],NULL,16);
        fprintf(&USBSerialStream,"%d\r\n",(uint8_t) strtoul(&PWM_bytes
        fprintf(&USBSerialStream,"%d\r\n",(uint8_t) strtoul(&PWM_bytes
            [1],NULL,16));
            [1],NULL,16));
    }
    }
else if (PWM_bytes[0] == '2')
else if (PWM_bytes[0] == '2')
    {
    {
        OCR1A = (uint8_t) strtoul(&PWM_bytes[1],NULL,16);
        OCR1A = (uint8_t) strtoul(&PWM_bytes[1],NULL,16);
        fprintf(&USBSerialStream,"%d\r\n",(uint8_t) strtoul(&PWM_bytes
        fprintf(&USBSerialStream,"%d\r\n",(uint8_t) strtoul(&PWM_bytes
            [1],NULL,16));
            [1],NULL,16));
    }
    }
else if (PWM_bytes[0] == '3')
else if (PWM_bytes[0] == '3')
    {
    {
        OCR4C = (uint8_t) strtoul(&PWM_bytes[1],NULL,16);
        OCR4C = (uint8_t) strtoul(&PWM_bytes[1],NULL,16);
        OCR4B = OCR4C/2;
```

        OCR4B = OCR4C/2;
    ```
```

                return true;
                }
    else
            return false;
    }
void reportError(void)
{
debugCheck();
//Clear CDC buffer and exit if input not valid
CDC_Device_Flush(\&FullyDiff_CDC_Interface);
CDC_Device_SendString(\&FullyDiff_CDC_Interface,ErrStr);
}
int16_t waitforByte(void)
{
// Wait for an incoming byte
while (!(CDC_Device_BytesReceived(\&FullyDiff_CDC_Interface))) {continue;}
// Receive incoming byte
return CDC_Device_ReceiveByte(\&FullyDiff_CDC_Interface);
}
/* Configures the board hardware and chip peripherals */
void SetupHardware(void)
{
/* Disable watchdog if enabled by bootloader/fuses */
MCUSR \&= ~ (1 << WDRF);
wdt_disable();
MCUCR = (1<< JTD);
MCUCR = (1<< JTD );
/* Disable clock division */
clock_prescale_set(clock_div_1);
/* Hardware Initialization */
//LEDs_Init();
USB_Init();
SPI_Init();
/* Set up pin direction for button */
DDRE \& = ~
PORTE | = (1<< PE2);
/* Set up pin directions for CS and disable all chips */
DDRD = 0xFF;

```
4 3 0
4 3 5
```

```
    PORTD = 0xFF;
```

```
    PORTD = 0xFF;
    /* Set up PWM for chopper channels */
    /* Set up PWM for chopper channels */
    PWM_Init();
    PWM_Init();
    /* Set up PWM on Status LEDs */
    /* Set up PWM on Status LEDs */
    LEDs_PWMInit();
    LEDs_PWMInit();
    /* Set up Debug Mode */
    /* Set up Debug Mode */
    DDRF & = ~ (1 << PF7);
    DDRF & = ~ (1 << PF7);
    PORTF |= (1<< PF7);
    PORTF |= (1<< PF7);
    debugCheck();
    debugCheck();
    DDS_Init();
    DDS_Init();
```

4 2 0
{
{
/* Set up directions for PWM pins */
/* Set up directions for PWM pins */
DDRB |=(1<< PB5) |(1<< PB6)|(1<< PB7);
DDRB |=(1<< PB5) |(1<< PB6)|(1<< PB7);
DDRC |= (1<< PC6);
DDRC |= (1<< PC6);
/* Set up PWM for 8-bit TC0
OC0A on PB7 connected, toggle on compare match
WGM = 1 (0b010), TOP =OCRA0
Prescaler: CLK/8
TCCR0A = 0b01000010;
TCCR0B = 0b00000010; */
/* No prescaler: 0x00 = 8MHz,0xFF = 31.2kHz
* CLK/8: 0x00 = 1MHz,0xFF = 3.94kHz
* CLK/8: 0x02 = 333kHz, 0x18 = 40kHz
* CLK/8: 0x17 = 41.6kHz
*/
TCCROA = 0;
TCCROA | = (1<<WGM01);
TCCROB | = (1<<CSO1);
OCROA = 0x02;
TCCROA | = ( }1<<\mathrm{ COMOAO);
/* Set up PWM for 16-bit TC1, OC1A on PB5
Use frequency and phase correct mode:
- Mode: Toggle OC1A on compare match (OC1x disconnected)
- WGM: Mode }9\mathrm{ (1001)
- Prescaler: CLK/1 (none)
- TCCR1A = 0b01000001;
- TCCR1B = 0b00010001; */

```
/* Set up SPI Data Directions:
- !SS (PB0): output
- MOSI (PB1): output
- SCK (PB2): output
- MISO (PB3): input
explicitly set ! SS as output to ensure SPI configuration */
\(/ /\) DDR_SPI \(=(1 \ll\) DD_MOSI \() \mid(1 \ll\) DD_SCK \()\);
```

    DDRB \(=((1 \ll\) PBO \() \mid(1 \ll\) PB1 \() \mid(1 \ll\) PB2 \())\);
    PORTB \(\mid=(1 \ll\) PBO \()\);
    ```
    /* Enable SPI as Master with clock rate fck/16
        Transmit MSB first (DORD=0), SCK low when idle \((\mathrm{CPOL}=0)\)
        Sample data on trailing (falling ) edge (CPHA=1) */
    \(/ / \mathrm{SPCR}=(1 \ll \mathrm{SPE})|(1 \ll \mathrm{MSRT})|(1 \ll \mathrm{CPHA}) \mid(1 \ll\) SPR 0\()\);
    \(\mathrm{SPCR}=0 \mathrm{~b} 01010101\);
\}
uint8_t SPI_transmit(uint8_t data)
\{
    /* Send data */
    SPDR = data;
    /* Wait for transmission complete */
    while (!(SPSR \& \((1 \ll\) SPIF \())\) );
    /* Return received byte */
    return SPDR;
\}
void ADC_read(uint8_t chan)
\{
    /* Sample data on trailing edge \((\mathrm{CPHA}=1)\)
        May need to reconfigure sample edge depending on how MOSI data works */
    //SPCR = 0b01010101;
    \(\mathrm{SPCR}=0 \mathrm{~b} 01011101\);
    /* Chip Select Enable */
    PORTD \& \(={ }^{\sim}(1 \ll\) chan \()\);
    /* Send dummy bytes over SPI and read back 4 byte conversion */
    for (int \(\mathbf{i}=0 ; \mathbf{i}<4 ; i++\) )
        \{
            ADC_buf \([\mathrm{i}]=\) SPI_transmit(0x00);
        \}
    /* Chip Select Disable */
    PORTD \(\mid=(1 \ll\) chan \()\);
\}
void ADC_flush(void)
\{
    /* Clear ADC temp bytes and buffer*/
    for (int \(\mathbf{i}=0 ; \mathbf{i}<4 ; i++\) )
        \{
        ADC_buf \([\mathrm{i}]=0\);
```

560
}
void DDS_Set(uint8_t chan, uint16_t data)
{
/* Ensure that only DDS can be selected */
if ((chan == PD6)| (chan == PD7))
{
unsigned char dataH = (data >> 8);
unsigned char dataL = (data \& 0xFF);
/* Shift data on FALLING edge of SCK
SCK idles HIGH when FSYNC/CS goes low (mode 3) */
SPCR = 0b01011001;
/* Chip Select Enable */
PORTD \& = ~ (1<< chan);
/* Send DDS setup data (no data to read back) */
SPI_transmit(dataH);
SPI_transmit(dataL);
/* Chip Select Disable */
PORTD | = (1<< chan );
}
}
/* Configures DDS with a 10kHz and 100kHz sine wave on Ch. A and B */
void DDS_Init(void)
{
/* Reset and Initialize */
DDS_Set(PD6, 0x2100);
//DDS_Set(PD7, 0x2100);
/* Write to frequency register (Fout,Fin):
* Fmclk = 320kHz:
* 10kHz = 0x00800000,
*
* Fmclk = 2.67MHz:
* 10.416kHz = 0x00100000,
6 0 0
6 0 5
* 83.3kHz = 0x00800000,
* 125kHz = 0x00C00000,
*
* (~10khz, 4MHz) = 0x000A3D70, ( }\mp@subsup{}{}{~}100\textrm{kHz},4\textrm{MHz})=0x0066666
* (~ }\mp@subsup{}{}{~}10\textrm{kHz},5\textrm{MHz})=0x00083126,(~100\textrm{kHz},5\textrm{MHz})=0x0051\textrm{EB}8
*/
DDS_Freq(PD6,0,0x00800000);

```
```

    /* Write PHASE0 Reg */
    DDS_Phase(PD6,0,0);
    6 1 0
6 2 0
/*
* The phase registers are written to with a 16-bit word.
* D15 and D14 are always 1, D13 selects PHASE0 or PHASE1
* registers . D12 doesn't matter. The remaining 12 bits
* are preg.
*
* preg is the 12 bit result of the following:
* preg = (phase_shift*2^12)/(2*pi)
*/

```
```

    reg = (reg & 0x01) << 13;
    preg = (3<< 14) | reg | (0x0FFF & preg);
    DDS_Set(en,preg);
    }
void debugCheck(void)
{
uint8_t PF7Stat = (PINF \& (1<< PF7));
if (!PF7Stat)
{
debugFlag = true;
}
else
debugFlag = false;
}
void CheckPE2(void)
{
uint8_t PE2Stat = (PINE \& (1 << PE2));
char* ReportString = NULL;
static bool ActionSent = false;
if (!PE2Stat)
{
ADC_flush();
ADC_read(1);
ReportString = "Button}\lrcornerDown\r\n";
}
else
ActionSent = false;
if ((ReportString != NULL) \&\& (ActionSent == false))
{
ActionSent = true;
CDC_Device_SendString(\&FullyDiff_CDC_Interface, ReportString);
ADC_response();
}
}
void ADC_response(void)
{
char ADC_chars[5];

```
```

    // There are two methods for sending data over serial:
    // Method 1: Using the CDC_Interface
    for (int i = 0; i < 4; i++)
        {
        sprintf(ADC_chars,"%02X",ADC_buf[i]);
        CDC_Device_SendString(&FullyDiff_CDC_Interface, ADC_chars);
    }
    CDC_Device_SendString(&FullyDiff_CDC_Interface,"\r\n");
    // Method 2: Using the USBSerialStream
    /*for (int i = 0; i < 4; i++)
    {
    fprintf(&USBSerialStream,"%XX",ADC_buf[i]);
    }
    CDC_Device_SendString(&FullyDiff_CDC_Interface,"\r\n");*/
    }
/** Event handler for the library USB Connection event. */
void EVENT_USB_Device_Connect(void)
{
//LEDs_SetAllLEDs(LEDMASK_USB_ENUMERATING);
LEDs_SetBrightness(LEDS_BLU,LOW);
}
/** Event handler for the library USB Disconnection event. */
void EVENT_USB_Device_Disconnect(void)
{
//LEDs_SetAllLEDs(LEDMASK_USB_NOTREADY);
LEDs_SetBrightness(LEDS_BLU,HALF);
}
/** Event handler for the library USB Configuration Changed event. */
void EVENT_USB_Device_ConfigurationChanged(void)
{
bool ConfigSuccess = true;
ConfigSuccess \&= CDC_Device_ConfigureEndpoints(\&FullyDiff_CDC_Interface);
//LEDs_SetAllLEDs(ConfigSuccess ? LEDMASK_USB_READY : LEDMASK_USB_ERROR);
LEDs_SetBrightness(LEDS_BLU,ConfigSuccess ? LOW : HIGH);
}
/** Event handler for the library USB Control Request reception event. */
void EVENT_USB_Device_ControlRequest(void)
{
CDC_Device_ProcessControlRequest(\&FullyDiff_CDC_Interface);
}

```

\section*{Appendix B}

\section*{Schematics and Boards}

\section*{B. 1 High Voltage Signal Source}

\section*{B.1.1 Full Schematic}


9/3/12 11:32 PM f=0.92 /home/bjthom28/Projects/Standalone_Sensor/Sensor and Code/pcb_and_schematic/HVrev2/HVrev2.:

\section*{B.1.2 PCB Layout}


9/3/12 11:33 PM f=1.54 /home/bjthom28/Projects/Standalone_Sensor/Sensor and Code/pcb_and_schematic/HVrev1/HVrev1.I

\section*{B.1.3 Bill of Materials}
\begin{tabular}{|c|c|c|}
\hline Qty & Value & Parts \\
\hline 1 & 15 mH & L1 \\
\hline 8 & DIODE-DO-214AC & D1, D2, D3, D4, D5, D6, D7, D8 \\
\hline 1 & 10 & ROPT1 \\
\hline 1 & Jumper & SJ2 \\
\hline 1 & Terminal & PWR \\
\hline 13 & . 1 u & \[
\begin{aligned}
& \text { CB1, CB2, CB3, CB4, CB5, CB6, CB7, CB8, CB9, CB10, CB11, } \\
& \text { CB12, CB13 }
\end{aligned}
\] \\
\hline 2 & .1uF & CT3, CT5 \\
\hline 2 & 1M & R1, R16 \\
\hline 1 & 1k & R14 \\
\hline 6 & 1 u & C3, C7, C10, C13, CB14, CB15 \\
\hline 2 & 1 uF & CT2, CT6 \\
\hline 1 & 2.2 uF & CT4 \\
\hline 1 & 10 & R5 \\
\hline 1 & 10k & RP1 \\
\hline 2 & 10k & R2, R17 \\
\hline 8 & 10u & C2, C4, C5, C6, C8, C9, C11, C12 \\
\hline 1 & 22 uF & CT1 \\
\hline 1 & 50 & R15 \\
\hline 2 & 50 k & R3, R4 \\
\hline 2 & 317 T & IC4, IC6 \\
\hline 2 & 330 pF & CC1, CC2 \\
\hline 2 & 337T & IC5, IC7 \\
\hline 4 & OP27P & IC1, IC2, IC8, IC9 \\
\hline 1 & OPA452/3S & IC3 \\
\hline 4 & R1 & R7, R9, R10, R12 \\
\hline 4 & R2 & R6, R8, R11, R13 \\
\hline 2 & BNC & CON1, CON2 \\
\hline 6 & TPT-SMD & GAIN2, GAIN3, HVDIV, IN1, IN2, OP2 \\
\hline
\end{tabular}

\section*{B. 2 Standalone Sensor Electrodes}

\section*{B.2.1 Capacitive Mode Electrodes}

Full Schematic


9/3/12 10:56 PM f=0.92 /home/bjthom28/Projects/Standalone_Sensor/Sensor and Code/pcb_and_schematic/diff_al/diff_plate_

\section*{PCB Layout}


9/3/12 10:57 PM f=1.04 /home/bjthom28/Projects/Standalone_Sensor/Sensor and Code/pcb_and_schematic/diff_al/diff_plate_


9/3/12 11:05 PM f=3.51 /home/bjthom28/Projects/Standalone_Sensor/Sensor and Code/pcb_and_schematic/diff_al/diff_plate_

\section*{Bill of Materials}
\begin{tabular}{|c|c|c|}
\hline Qty & Value & Parts \\
\hline 5 & .1 u & CB3, CB4, CB6, CB7, CB9 9 \\
\hline 2 & .01 u & CB5, CB8 \\
\hline 2 & 1 u & CB1, CB2 \\
\hline 1 & \(10,1 \%\) & R5 \\
\hline 1 & \(10 \mathrm{k}, .01 \%\) & R1 \\
\hline 1 & \(22-23-2031\) & PWR \\
\hline 3 & \(51, .05 \%\) & R3, R4, R6 \\
\hline 1 & \(500, .05 \%\) & R 2 \\
\hline 1 & ADA4817-1 & IC1 \\
\hline 1 & LT1806 & IC2 \\
\hline 1 & MICA & C1 \\
\hline 2 & MMXC-CUT & CON1, CON2 \\
\hline 1 & SMA-ONLY & DRIVE \\
\hline
\end{tabular}


\section*{PCB Layout}


9/3/12 10:58 PM \(f=1.04\) /home/bjthom28/Projects/Standalone_Sensor/Sensor and Code/pcb_and_schematic/diff_al/diff_plate.I


9/3/12 11:04 PM f=4.22 /home/bjthom28/Projects/Standalone_Sensor/Sensor and Code/pcb_and_schematic/diff_al/diff_plate.l

\section*{Bill of Materials}
\begin{tabular}{|c|c|c|}
\hline Qty & Value & Parts \\
\hline 5 & .1 u & \(\mathrm{CB} 3, \mathrm{CB} 4, \mathrm{CB} 6, \mathrm{CB} 7, \mathrm{CB} 9\) \\
\hline 2 & .01 u & \(\mathrm{CB} 5, \mathrm{CB} 8\) \\
\hline 1 & \(.01 \mathrm{u}, 1 \%\) & C 3 \\
\hline 2 & 1 u & \(\mathrm{CB}, \mathrm{CB} 2\) \\
\hline 1 & \(10,1 \%\) & R 5 \\
\hline 1 & \(10 \mathrm{k}, .01 \%\) & R1 \\
\hline 1 & \(22-23-2031\) & PWR \\
\hline 3 & \(51, .05 \%\) & \(\mathrm{R} 3, \mathrm{R} 4, \mathrm{R} 6\) \\
\hline 2 & \(220 \mathrm{p}, 1 \%\) & \(\mathrm{C} 1, \mathrm{C} 2\) \\
\hline 1 & \(500, .05 \%\) & R 2 \\
\hline 1 & ADA4817-1 & IC1 \\
\hline 1 & LT1806 & IC2 \\
\hline 2 & MMXC-CUT & CON1, CON2 \\
\hline 1 & SMA-ONLY & DRIVE \\
\hline
\end{tabular}

B.3.1 Full Schematic
B. 3 Standalone Sensor Signal Conditioning











\section*{B.3.3 Bill of Materials}
\begin{tabular}{|c|c|c|}
\hline Qty & Value & Parts \\
\hline 6 & 10k Pot & RP1, RP2, RP3, RP4, RP6, RP7 \\
\hline 18 & Gain Adj. & R22, R23, R36, R37, R50, R51, R64, R65, R74, R75, R94, R95, R108, R109, R114, R115, R116, R117 \\
\hline 1 & 5 MHz & X1 \\
\hline 6 & Jumpers & SJ1, SJ2, SJ3, SJ4, SJ5, SJ6 \\
\hline 63 & .1u & C76, C78, C80, CB1, CB2, CB4, CB5, CB7, CB8, CB10, CB11, CB13, CB14, CB16, CB17, CB18, CB19, CB20, CB21, CB23, CB24, CB25, CB26, CB27, CB28, CB30, CB31, CB32, CB33, CB34, CB35, CB37, CB38, CB39, CB40, CB45, CB46, CB47, CB58, CB59, CB60, CB61, CB63, CB64, CB65, CB66, CB67, CB68, CB70, CB71, CB72, CB73, CB76, CB77, CB78, CB79, CB80, CB81, CB87, CB89, CB90, CB92, CB93 \\
\hline 8 & .1u & CB48, CB50, CB51, CB52, CB53, CB55, CB56, CB84 \\
\hline 24 & .1u, PPS & \(\mathrm{C} 4, \mathrm{C} 5, \mathrm{C} 10, \mathrm{C} 11, \mathrm{C} 16, \mathrm{C} 17, \mathrm{C} 22, \mathrm{C} 23, \mathrm{C} 29, \mathrm{C} 31, \mathrm{C} 34, \mathrm{C} 36, \mathrm{C} 39, \mathrm{C} 41, \mathrm{C} 44\), C46, C52, C53, C58, C59, C65, C67, C70, C72 \\
\hline 14 & .01u & C77, C79, CB3, CB6, CB9, CB12, CB15, CB22, CB29, CB36, CB62, CB69, CB88, CB91 \\
\hline 24 & .01u, 1\% & \(\mathrm{C} 6, \mathrm{C} 7, \mathrm{C} 8, \mathrm{C} 9, \mathrm{C} 12, \mathrm{C} 13, \mathrm{C} 14, \mathrm{C} 15, \mathrm{C} 18, \mathrm{C} 19, \mathrm{C} 20, \mathrm{C} 21, \mathrm{C} 24, \mathrm{C} 25, \mathrm{C} 26, \mathrm{C} 27\), C54, C55, C56, C57, C60, C61, C62, C63 \\
\hline 12 & .01u, \(2 \%\) & C28, C30, C33, C35, C38, C40, C43, C45, C64, C66, C69, C71 \\
\hline 1 & 1M & R7 \\
\hline 2 & 1N4148S & D3, D4 \\
\hline 4 & 1 k & R76, R77, R78, R79 \\
\hline 21 & 11 & \(\mathrm{C} 32, \mathrm{C} 37, \mathrm{C} 42, \mathrm{C} 47, \mathrm{C} 48, \mathrm{C} 49, \mathrm{C} 50, \mathrm{C} 51, \mathrm{C} 68, \mathrm{C} 73, \mathrm{C} 74, \mathrm{C} 75, \mathrm{CB} 41, \mathrm{CB} 42\), CB43, CB44, CB49, CB74, CB75, CB82, CB85 \\
\hline 2 & 10k, .01\% & R1, R2 \\
\hline 60 & 10k, 1\% & \(\mathrm{R} 14, \mathrm{R} 15, \mathrm{R} 16, \mathrm{R} 17, \mathrm{R} 18, \mathrm{R} 19, \mathrm{R} 20, \mathrm{R} 21, \mathrm{R} 28, \mathrm{R} 29, \mathrm{R} 30, \mathrm{R} 31, \mathrm{R} 32, \mathrm{R} 33, \mathrm{R} 34\), R35, R42, R43, R44, R45, R46, R47, R48, R49, R56, R57, R58, R59, R60, R61, R62, R63, R66, R67, R68, R69, R70, R71, R72, R73, R86, R87, R88, R89, R90, R91, R92, R93, R100, R101, R102, R103, R104, R105, R106, R107, R110, R111, R112, R113 \\
\hline 1 & \(10 \mathrm{n}, 1 \%\) & C3 \\
\hline 1 & 22-23-2031 & PWR \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|}
\hline 4 & 30, .1\% & R83, R85, R97, R99 \\
\hline 2 & 33 u & CB54, CB57 \\
\hline 2 & 33 u & CB83, CB86 \\
\hline 2 & 34, .1\% & R81, R119 \\
\hline 14 & 50, .1\% & R3, R5, R10, R12, R24, R26, R38, R40, R52, R54, R82, R84, R96, R98 \\
\hline 2 & 51, .05\% & R8, R9 \\
\hline 6 & 74VHC74 & \(\mathrm{IC} 22, \mathrm{IC} 23, \mathrm{IC} 37, \mathrm{IC} 38, \mathrm{IC} 40, \mathrm{IC} 41\) \\
\hline 1 & 100p, 1\% & C2 \\
\hline 2 & 110, .1\% & R80, R118 \\
\hline 1 & 180p, 1\% & C1 \\
\hline 3 & 250 k & RP5, RP8, RP9 \\
\hline 10 & 500, .05\% & R4, R6, R11, R13, R25, R27, R39, R41, R53, R55 \\
\hline 1 & 7805 & IC26 \\
\hline 1 & 7905 & IC27 \\
\hline 7 & AD8138 & IC1, IC5, IC8, IC11, IC14, IC29, IC32 \\
\hline 6 & AD8230 & IC7, IC10, IC13, IC16, IC30, IC33 \\
\hline 2 & AD9837-10 & IC42, IC43 \\
\hline 1 & ADR441 & IC25 \\
\hline 1 & ATM32U4 & ATMEGA32U4-BREAKOUT \\
\hline 5 & LT1806 & IC2, IC3, IC4, IC44, IC45 \\
\hline 6 & LTC2484 & IC17, IC18, IC19, IC20, IC34, IC35 \\
\hline 3 & LTC6994-2 & IC21, IC36, IC39 \\
\hline 6 & MAX4523 & IC6, IC9, IC12, IC15, IC28, IC31 \\
\hline 4 & MMXC & CON1, CON2, CON3, CON4 \\
\hline 5 & SMA & CLK_IN_40K, CLK_IN_400K, CLK_IN_VAR, DDS_OUT, HV_DIV \\
\hline 7 & TPT & AGND1, AGND2, AGND3, AGND4, AGND5, GND1, GND2 \\
\hline
\end{tabular}

B.4.1 Full Schematic



\section*{B.4.3 Bill of Materials}
\begin{tabular}{|c|c|c|}
\hline Qty & Value & Parts \\
\hline 1 & .1 u & C 2 \\
\hline 1 & 0 & R 1 \\
\hline 1 & 1 k & R 4 \\
\hline 3 & 1 u & \(\mathrm{C} 1, \mathrm{C} 5, \mathrm{CB} 1\) \\
\hline 2 & 10 p & \(\mathrm{C} 3, \mathrm{C} 4\) \\
\hline 1 & 16 MHz & X 1 \\
\hline 2 & 22 & \(\mathrm{R} 2, \mathrm{R} 3\) \\
\hline 2 & 100 & \(\mathrm{R} 6, \mathrm{R} 7\) \\
\hline 1 & ATMEGA32U4-AU & IC 1 \\
\hline 1 & LDO3.3 & LDO \\
\hline 2 & LED & \(\mathrm{D} 1, \mathrm{D} 2\) \\
\hline 1 & MICRO-USB-ZX62-B-5PA & USB 1 \\
\hline 2 & SW-C\&K-KSC-JWING & \(\mathrm{HWB}, \mathrm{RST}\) \\
\hline 1 & TC2050-IDC-NL & ISP \\
\hline
\end{tabular}

\section*{Bibliography}
[1] J.J. Cooley. Capacitive Sensing with a Fluorescent Lamp. M.eng. thesis, Massachusetts Institute of Technology, Cambridge, Massachusetts, February 2007.
[2] Analog Devices. AD9837 Low Power, \(8.5 \mathrm{~mW}, 2.3 \mathrm{~V}\) to 5.5 V , Programmable Waveform Generator, 2011. Rev. 0.
[3] Analog Devices. AD8620 Precision, Very Low Noise, Low Input Bias Current, Wide Bandwidth JFET Operational Amplifiers, 2008. Rev. F.
[4] Texas Instruments. OPA452,OPA452: \(80 \mathrm{~V}, 50 \mathrm{~mA}\) Operational Amplifiers, 2003. Rev. C.
[5] J.J. Cooley. Analysis, Modeling and Design of Energy Management and Multisource Power Systems. Ph.d. thesis, Massachusetts Institude of Technology, Cambridge, Massachusetts, June 2011.
[6] D. Vickery. A Retrofit Current Sensor for Non-Intrusive Power Monitoring at the Circuit Breaker. M.eng. thesis, Massachusetts Institute of Technology, Cambridge, Massachusetts, September 2011.
[7] M. Carminati, M. Sampietro, G. Ferrari, and F. Gozzini. Instrumentation with attofarad resolution for electrochemical impedance measurements on molecular biosensors. In Research in Microelectronics and Electronics, 2009. PRIME 2009. Ph.D., pages 316-319, July 2009.
[8] G. Ferrari, F. Gozzini, A. Molari, and M. Sampietro. Transimpedance amplifier for high sensitivity current measurements on nanodevices. Solid-State Circuits, IEEE Journal of, 44(5):16091616, May 2009.
[9] L Fumagalli, G Ferrari, M Sampietro, I Casuso, E Martnez, J Samitier, and G Gomila. Nanoscale capacitance imaging with attofarad resolution using ac current sensing atomic force microscopy. Nanotechnology, 17(18):4581, 2006.
[10] A Heidary, R Taherkhani, and G.C.M. Meijer. A capacitance measurement system with milliwatt power and attofarad resolution. In 20th Iranian Conference on Electrical Engineering, May 2012.
[11] S Wu and J Yu. Attofarad capacitance measurement with scanning microwave microscopy, April 2012. Agilent Technologies.
[12] Daniele Andreuccetti, Roberto Fossi, and Caterina Petrucci. Dielectric Properites of Body Tissues, 2010. http://niremf.ifac.cnr.it/tissprop/.
[13] Camelia Gabriel and Sami Gabriel. Compilation of the Dielectric Properties of Body Tissues at RF and Microwave Frequencies, 1997. mirrored at: http://niremf.ifac.cnr.it/docs/DIELECTRIC/home.html.
[14] Ferroxcube. 3C81 Material specification, 2008. Datasheet.
[15] Ferroxcube. P42/29 P cores and accessories, 2008. Datasheet.
[16] Linear Technology. LTC2484 24-Bit \(\Delta \Sigma \mathrm{ADC}\) with Easy Drive Input Current Cancellation, 2005. Rev. D.
[17] Analog Devices. AD8230 16V Rail-to-Rail, Zero-Drift, Precision Instrumentation Amplifier, 2007. Rev. B.
[18] Analog Devices. ADA4817-1/ADA4817-2 Low Noise, 1 GHz FastFET Op Amps, 2008. Rev. 0.
[19] Analog Devices. AD8131 Low Distortion Differential ADC Driver, 2006. Rev. F.
[20] Maxim. MAX4521/MAX4522/MAX4523 Quad, Low-Voltage. SPST Analog Switches, July 2007. Rev. 6.
[21] Linear Technology. LT1806/LT1807 325MHz, Single/Dual, Rail-to-Rail Input and Output, Low Distortion, Low Noise Precision Op Amps, 2010. Rev. C.
[22] KSM. RG178 Coaxial Cable to Mil-C-17 Specification, 2011.
[23] John Ardizzoni and Jonathon Pearson. AN-0990 Terminating a Differential Amplifier in SingleEnded Input Applications. Analog Devices, 2009. Rev. 0.```

