Development of a low-frequency cell stimulator for regeneration/apoptosis experiments by Fernández-Castro, Adolfo
Instituto Tecnológico de Costa Rica
Electronics Engineering Department
Development of a low-frequency cell stimulator for regeneration/apoptosis
experiments
A report submitted in partial fulfillment of the requirements for the Licentiate
Degree in Electronics Engineering
Submitted by
Adolfo Fernández Castro
Cartago, Costa Rica
November 17, 2016
Scanned by CamScanner
i
ii
iii
Abstract
Cellular stimulation by exposition to variable frequency electric fields constitutes a method for
modifying cellular characteristics such as metabolism, orientation, migration and biological
function. For this type of study and behavior, high-cost and complex commercial equipment is often
used, which shows in general low bandwidth that limits the scope of the experiments.
This work presents the design and implementation of a prototype for electric stimulation and
impedance measurement of cell samples characterized by low-cost, portability, and easy
reconfigurability of frequency and voltage, which makes it suitable for stimulation studies and
research purposes. Also, it constitutes a preliminary study for systems with higher bandwidth, higher
impedance range, and more input channels. The device is designed and implemented in order to
carry out experiments of regeneration and apoptosis. It can generate electric signals up to 40 kHz at
voltages in the range from 0 V to 100 mV, and it is capable of measuring impedance up to 1 MΩ.
Experiments of cellular stimulation and impedance measurement were carried out over yeast
cultures, and the results are compared with the ones obtained by the Agilent 4284A LCR meter.
Keywords: Cellular stimulation, impedance measurement, impedance spectroscopy, signal
generation, ABBM.
iv
Resumen
La estimulación celular por medio de la aplicación de campos eléctricos de frecuencia variable
constituye un método para modificar características celulares como metabolismo, orientación,
migración y función biológica. Para este tipo de estudios y comportamiento, equipo comercial
complejo y de alto costo es usualmente utilizado, este generalmente presenta bajo ancho de banda
limitando el alcance de los experimentos.
Este trabajo muestra el diseño e implementación de un prototipo para la estimulación eléctrica y
medición de impedancia de muestras celulares, caracterizado por su bajo costo, portabilidad y fácil
ajuste de frecuencia y tensión eléctrica, lo cual lo hace adecuado para estudios de estimulación e
investigación. Además, el trabajo constituye un estudio preliminar para sistemas con mayor ancho de
banda, mayor rango de impedancia y más canales de entrada. El dispositivo es diseñado e
implementado con el fin de llevar a cabo experimentos de regeneración y apoptosis. Puede generar
señales eléctricas de hasta 40 kHz con tensiones entre 0 V y 100 mV, y es capaz de medir
impedancias de hasta 1 MΩ. Experimentos de estimulación celular y de medición de impedancia han
sido efectuados sobre muestras de levadura, estos resultados son comparados con los obtenidos
utilizando el medidor LCR Agilent 4284A.
Palabras clave: Estimulación celular, medición de impedancia, espectroscopia de impedancia,
generación de señales, ABBM.
vTo my dear mother . . .
vi
Acknowledgement
This work was partially supported by the Costa Rica Institute of Technology (ITCR) and Hamburg
University of Technology (TUHH). It represents the culmination of 5 years of study to become a
Electronic Engineer with Licienciate’s Degree. In all this time many people have contributed in
different ways to achieve this goal.
I wish to express my sincere thanks to Prof. Dr.-Ing. Wolfgang Krautschneider, Principal of the
Institute of Nano- and Medical Electronics, for giving me the opportunity to perform my Bachelor
Thesis in this Institution, for providing me with advice and all the materials and resources to carry
out this project.
I also would like to express my gratitude to my advisors M.Sc. Juan José Montero Rodríguez and
Dr.-Ing. Renato Rímolo Donadio for the continuous support in my Bachelor Thesis, for his guidance
and immense knowledge. This work would not have been possible without their assistance every step
throughout the process. I also show my gratitude to M.Sc. Pablo Mendoza Ponce for his advice
during the course of this project.
Thanks to Costa Rica Institute of Technology, especially to the teachers and personal of the
Department of Electronics Engineering for sharing their knowledge and giving me support in this 5
years.
Most importantly, I would like to express my gratitude to God for being the light that has
illuminated my path, for all his support and blessings. I want to thank my family and friends for their
motivation and support, special thanks to my mother which unconditional love and support have
encouraged me during all this time.
vii
Table of Contents
List of Figures viii
List of Tables ix
1 Introduction 1
1.1 Electric stimulator for impedance spectroscopy . . . . . . . . . . . . . . . . . . . . 2
1.1.1 General Objective . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3
1.1.2 Specific Objectives . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3
1.2 Document structure . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3
2 Impedance spectroscopy and applications 5
2.1 Impedance measurement methods . . . . . . . . . . . . . . . . . . . . . . . . . . . 6
3 Waveform generation and data acquisition 10
3.1 Direct Digital Synthesis . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
3.2 Current-to-Voltage converter . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
3.3 Analog-to-Digital converter . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
4 Design of a low-frequency cell stimulator 14
4.1 Design options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
4.2 Impedance spectroscopy device based on SoC . . . . . . . . . . . . . . . . . . . . . 15
4.2.1 Waveform generator . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
4.2.2 Conditioning & filtering . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
4.2.3 Impedance measurement . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
4.2.4 Control, processing & storage . . . . . . . . . . . . . . . . . . . . . . . . . 18
4.3 Analog frontend . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
4.3.1 Waveform generation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
4.3.2 Voltage regulator . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
4.3.3 Attenuator . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19
4.3.4 Low-pass filter . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
4.3.5 Current-to-Voltage converter . . . . . . . . . . . . . . . . . . . . . . . . . . 20
4.3.6 Coupling capacitor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
4.3.7 Complete analog circuit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
viii
4.4 Digital design . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
4.4.1 Waveform generator controller . . . . . . . . . . . . . . . . . . . . . . . . . 22
4.5 Impedance calculation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24
5 Low-frequency cell stimulator response 25
5.1 Waveform generation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
5.2 Signal acquisition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
5.2.1 Low-pass filter . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
5.3 Impedance measurement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
5.3.1 Correction factor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
5.3.2 Stimulation with a single frequency . . . . . . . . . . . . . . . . . . . . . . 30
5.3.3 Stimulating with a frequency sweep . . . . . . . . . . . . . . . . . . . . . . 32
6 Conclusions 34
References 36
Appendix A Generated signals for electric stimulation 39
Appendix B Designed software 41
B.1 Python script . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
B.2 Verilog code for serial protocol . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46
Appendix C PCB design 49
C.1 First prototype . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49
C.2 Second prototype . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52
Appendix D Cost and size characteristics 55
ix
List of Figures
1.1 Stimulation and impedance measurement system. . . . . . . . . . . . . . . . . . . . 2
2.1 Impedance representation in the complex plane. . . . . . . . . . . . . . . . . . . . . 6
2.2 Impedance measurement using bridge method [9]. . . . . . . . . . . . . . . . . . . . 7
2.3 Impedance measurement using resonant method [9]. . . . . . . . . . . . . . . . . . . 7
2.4 Impedance measurement using I-V method [9]. . . . . . . . . . . . . . . . . . . . . 8
2.5 Impedance measurement using network analysis method [9]. . . . . . . . . . . . . . 8
2.6 Impedance measurement using ABBM [9]. . . . . . . . . . . . . . . . . . . . . . . . 9
3.1 Basic architecture of a Direct Digital Syntehesis. . . . . . . . . . . . . . . . . . . . . 10
3.2 Direct Digital Synthesis architecture. . . . . . . . . . . . . . . . . . . . . . . . . . . 11
3.3 Current-to-Voltage Converter. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
3.4 Transfer funcion for an ideal unipolar 3-bit ADC [14]. . . . . . . . . . . . . . . . . . 12
4.1 Functional block diagram of the low-frequency cell stimulator. . . . . . . . . . . . . 16
4.2 Electric diagram of the Programmable Waveform Generator. . . . . . . . . . . . . . 18
4.3 Electric diagram of the Voltage Regulator . . . . . . . . . . . . . . . . . . . . . . . 19
4.4 Electric diagram of the Attenuator . . . . . . . . . . . . . . . . . . . . . . . . . . . 19
4.5 Electric diagram of the Low-Pass Filter . . . . . . . . . . . . . . . . . . . . . . . . . 20
4.6 Functional block diagram of the low-frequency cell stimulator. . . . . . . . . . . . . 21
4.7 Communication between FPGA and HPS. . . . . . . . . . . . . . . . . . . . . . . . 22
4.8 Time diagram for serial protocol [12]. . . . . . . . . . . . . . . . . . . . . . . . . . 23
5.1 Serial Protocol Verification. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
5.2 Frequency spectrum at the output of the Programmable Waveform Generator . . . . . 27
5.3 Electric schematic from TINA simulation tool. . . . . . . . . . . . . . . . . . . . . . 27
5.4 Simulated frequency response of the circuit. . . . . . . . . . . . . . . . . . . . . . . 28
5.5 Frequency spectrum for ADC_0 filter. . . . . . . . . . . . . . . . . . . . . . . . . . 28
5.6 Frequency spectrum for ADC_1 filter. . . . . . . . . . . . . . . . . . . . . . . . . . 29
5.7 Correction factor for phase adjustment. . . . . . . . . . . . . . . . . . . . . . . . . . 30
5.8 Stimulation and impedance measurement of yeast cultures. . . . . . . . . . . . . . . 31
5.9 Stimulation of yeast cultures at 40 kHz. . . . . . . . . . . . . . . . . . . . . . . . . 32
5.10 Stimulation of known impedance by frequency sweep. . . . . . . . . . . . . . . . . . 33
xA.1 Sine waveform generation at (a) 10 kHz, (b) 100 kHz and (c) 1 MHz. . . . . . . . . . 39
A.2 Triangular waveform generation at (a) 10 kHz, (b) 100 kHz and (c) 1 MHz. . . . . . . 40
A.3 Square waveform generation at (a) 10 kHz, (b) 100 kHz and (c) 1 MHz. . . . . . . . 40
C.1 Electric diagram of the first prototype. . . . . . . . . . . . . . . . . . . . . . . . . . 50
C.2 PCB design of the first prototype. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51
C.3 Electric diagram of the ADC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52
C.4 Electric diagram of the second prototype. . . . . . . . . . . . . . . . . . . . . . . . 53
C.5 PCB design of the second prototype. . . . . . . . . . . . . . . . . . . . . . . . . . . 54
xi
List of Tables
2.1 Some impedance measurement methods. Adapted from [9]. . . . . . . . . . . . . . . 9
4.1 DDS options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
4.2 OA options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
4.3 Waveform configuration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23
4.4 Serial protocol timing characteristics [12]. . . . . . . . . . . . . . . . . . . . . . . . 24
5.1 Timing measurements of serial protocol. . . . . . . . . . . . . . . . . . . . . . . . . 26
5.2 Stimulation of known impedance by applying a signal of 40 kHz. . . . . . . . . . . . 30
5.3 Stimulation of known impedance by applying a signal of 100 kHz. . . . . . . . . . . 31
5.4 Calculations of resistance over a frequency range. . . . . . . . . . . . . . . . . . . . 33
D.1 Manufacturing cost. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55
1Chapter 1
Introduction
Impedance spectroscopy (IS) is a technique used to determine the electrical resistance of a sample as
a function of the frequency. An alternating voltage is applied to the sample, and the current flow is
measured simultaneously. The impedance is calculated by means of the Ohm’s Law and then stored
as a frequency response plot, with magnitude and phase, or as a Nyquist plot, with a real vs an
imaginary part. The dielectric properties of a sample can be extracted from the impedance, since the
electrical conductivity is proportional to the real part of the impedance (resistance, R) and the
electrical permittivity is obtained from the imaginary part of the impedance (reactance, X).
The Institute of Nano- and Medicine Electronics of the Hamburg University of Technology
(TUHH), and the Department of Electronic Engineering of the Costa Rica Institute of Technology
(ITCR) work together in a project aimed to the development of an electronic system that has tree
main functions: electronic stimulation, electronic characterization, and simultaneously
characterization and stimulation of biological samples [1]. The system will enable characterization
of cells through electrical impedance spectroscopy methods in a broad frequency range.
Researchers at the TUHH have been using commercial equipment for impedance spectroscopy of
biological samples. The Agilent 4284A LCR meter is controlled from a PC using a GPIB cable and a
MATLAB interface, and can produce frequency sweeps from 1 Hz up to 1 MHz. The Gamry
Interface 1000E is also controlled from a PC using special software from Gamry Instruments, and the
frequency range extends from 0.1 Hz up to 1 MHz. These tools have industrial accuracy and are used
for validation of results in cellular growth experiments. However they are expensive, require extra
equipment and licenses, and they are not easy to transport, limiting the possible fields of application.
The device presented in this thesis has been designed as a first prototype to address the cost,
portability, and complexity issues presented in the above tools. It is a device capable to cause
stimulation by the application of waveforms with programmable amplitude and frequency, allowing
single frequency experiments and also accurate frequency sweeps, necessary for impedance
spectroscopy of biological samples. The proposed device constitutes the basis for developing
1 Introduction 2
impedance spectroscopy tools with higher bandwidth, higher impedance range and experiment
parallelization since the critical parts of the system can be replaced with high-performance devices to
expand the range of measurements.
1.1 Electric stimulator for impedance spectroscopy
The concerned device consists in an electric cell stimulator which works at frequencies up to 40 kHz
at voltages from 0 V to 100 mV for impedances up to 1 MΩ. This system will be used to study the
growth of cell cultures stimulated with electric fields of adjustable amplitude and frequency. Cells
under the influence of electromagnetic fields grow in a different way. Some cell cultures exhibit
accelerated reproduction, while other cells can be killed by a specific electric field that induces
apoptosis.
The general diagram of the desired system is shown in Figure 1.1. The Signal generation block is
intended to generate sinusoidal, triangular and square waveforms at frequencies up to 40 kHz. Then
the signal goes trough the Signal conditioning stage to be filtered and adjusted in amplitude, from 0
V to 100 mV. These low voltage, variable electric fields are applied to the Device Under Test (DUT),
in this case biological samples, to cause stimulation. Once the sample is stimulated, the Signal
acquisition block takes electric measurements of the sample to compute the impedance in the next
stage, Signal processing. Finally, the impedance is stored in a memory and can be further analyzed to
obtain the relevant biological information.
Figure 1.1: Stimulation and impedance measurement system.
The digital processing of the signals is accomplished by DE0-Nano-SoC development board, a
System on Chip which integrates a FPGA and a Hard Processor System (HPS). Supplementary
circuits for analog processing of the signals are designed and implemented using discrete elements
and Integrated Circuits (IC).
1 Introduction 3
1.1.1 General Objective
Design an electronic prototype for cell stimulation in the frequency range up to 40 KHz in order to
carry out experiments for monitoring cell cultures growth.
1.1.2 Specific Objectives
• Develop an electronic interface to link up signals between the DE0-Nano-SoC development
board, amplifying and filtering tools, and DUT.
• Implement high-level computational algorithms to enable impedance calculation as well as
processing of the measured data.
• Carry out experiments using the developed device in order to observe changes in the grow rate
of cell samples.
1.2 Document structure
The main content of this thesis is presented in the next five chapters as follows.
Chapter 2 presents the basic theory for understanding the context of the project, as well as its
design and implementation. This chapter includes a literature review of the cell response before the
application of electric fields, the concept of impedance spectroscopy and some of its applications in
the area of biology and medicine. Also, it presents methods for impedance measurement focusing on
ABBM.
Chapter 3 presents electric circuits and systems for waveform generation and data acquisition. It
includes a short description of the DDS architecture, characteristics of the I2V based on inverting
OA, and an overview of the ADC operation, the quantization error, and sampling criteria.
Chapter 4 begins with the design proposals referred to the solution of the concerned problem,
then the selected solution is explained in detail by stages. First, the analog implementation is
described showing the functions of each block, its operation, and components. Then, the digital
implementation explains the designed algorithms for system configuration, communication between
DE0-Nano-SoC development board and analog implementation, impedance computation and data
1 Introduction 4
storage.
Chapter 5 shows the experimental results using the physical prototype. It shows the operation of
the serial communication algorithm, the frequency response of the filters, results of electric
stimulation and impedance measurement of known loads and yeast samples by the application of
fixed frequencies and frequency sweeps.
Chapter 6 presents the conclusions of the project. Here is given a brief analysis of the system
capabilities and limitations. This chapter also includes some recommendations for further work.
5Chapter 2
Impedance spectroscopy and applications
Cells are the basic structural and functional unit of every living organism. Their biological
composition is linked to an electric response, changes in their composition leads to changes in
electric characteristics like conductivity and permittivity [2]. Reciprocally, modifications in their
electric characteristics cause alterations in their metabolism and function. These characteristics
become really important in areas like medicine to make electrical differentiation between healthy and
unhealthy cells. For example, the membrane fluidity in cancer cells is higher [3].
Impedance spectroscopy is a technique used to determine the electrical impedance of a sample as
function of the frequency. The sample is stimulated by application of variable frequency electric
fields and the current is measured to obtain the impedance spectrum. This technique is used in
biology to carry out toxicological tests, medical diagnosis, cell concentration and stem cell
research [1].
The impedance of a sample and its dielectric properties are relevant for a wide range of
applications. In biology, a common experiment is the growth of cell cultures under different
environmental conditions. The concentration of cells present at a specific point of time can be
determined by optical means, by observing the sample under a microscope and staining the cells with
a fluorescent marker. However, these markers are often toxic and alter the growth of the cells. By
constantly monitoring the impedance of the cells, a researcher can measure the approximate number
of cells present in the sample in real time, without damaging the cells in the process.
Another application is the study of the inner part of the cells as a function of the frequency. In
literature it is established that most of the animal cells exhibit three dispersion regions, known as the
alpha, beta and gamma regions [4]. The alpha region describes the low frequency response of the cell
culture, involving the electrode and cellular membrane polarization effects. The beta region is related
to the cellular and nuclear membranes, and the internal organelles. The gamma region, observable at
frequencies above 10 GHz, describes the water relaxation effect. These three dispersion regions are
different between distinct types of cells and can be determined by impedance spectroscopy.
2 Impedance spectroscopy and applications 6
In medicine, Tumor Treating Fields (TTFields) therapy is used to stunt the growth of cancer cells
by tuning intensity and frequency of electric fields, exposure of TTFields may stop cell proliferation
and causes apoptosis [5]. This method has comparable efficiency with chemotherapy, minimizes
toxicity and enables a better quality of life [6]. Others examples related with the regeneration and
cell growth consist in applying electrical stimulation to enhance osteogenesis processes [7], and to
accelerate nerve and cell regeneration in cell cultures and injury muscles [8].
2.1 Impedance measurement methods
Impedance is the opposition that presents a material to the flow of an alternating current. It is
represented by a vector, Z, in polar form with magnitude and phase, as shown in Equation 2.1, or in
rectangular form as a complex quantity with real and imaginary part, as shown in Equation 2.2.
Z = |Z| ∗ Z (2.1)
Z = R + jX (2.2)
Figure 2.1 shows the representation of the impedance in the complex plane.
Figure 2.1: Impedance representation in the complex plane.
The imaginary part of the impedance represents the reactance, X , of the material. There are two
kinds of reactances, Equation 2.3 shows the expression to compute the inductive reactance, XL, and
Equation 2.4 the one for a capacitive reactance, both as a function of frequency, f .
2 Impedance spectroscopy and applications 7
XL = 2ΠfL (2.3)
XC =
1
2ΠfC
(2.4)
Where L constitutes the inductance of the material and C the capacitance.
There are many impedance measurement methods, each one presents different advantages and
disadvantages in frequency scoped, measurement range, and accuracy.
Bridge method Figure 2.2 shows the circuit for measuring impedance using bridge method. When
there is not current flowing in the detector, D, the unknown impedance is obtain from Equation 2.5.
Zx =
Z1
Z2
Z3 (2.5)
Figure 2.2: Impedance measurement using bridge method [9].
Resonant method In Figure 2.3 the diagram for measuring impedance based on bridged method is
shown. The capacitance C is adjusted until get resonance at a known frequency. The frequency, C and
Q are used to compute the impedance form by Lx and Rx. Q, the quality factor, is define as the ratio
between the energy dissipated and stored, it can be measured in the circuit using a voltmeter.
Figure 2.3: Impedance measurement using resonant method [9].
2 Impedance spectroscopy and applications 8
I-V method Figure 2.4 shows the circuit for I-V method. The voltage and current are measured to
compute the impedance Zx. The current is computed by Ohm’s Law from the voltage in a known
low-value resistor R. Equation 2.6 describes this relation.
Zx =
V1
I
=
V1
V2
R (2.6)
Figure 2.4: Impedance measurement using I-V method [9].
Network analysis method In this method the impedance is obtained from the reflection coefficient.
It is computed as the ratio between the incident and reflected signal, these aremeasured using a network
analizer. Figure 2.5 present the diagram for this method.
Figure 2.5: Impedance measurement using network analysis method [9].
Auto balancing bridge method (ABBM) Figure 2.6 shows the circuit for this method. It is based
on a current-to-voltage converter (I2V), implemented by an operational amplifier (OA) in inverting
configuration. The input voltage (Vi) is applied to the Device-Under-Test (DUT), and the generated
current is converted into an output voltage (Vo). The gain depends on the feedback resistance (Rr)
and on the DUT itself. The impedance is calculated using Equation 2.7
ZDUT = −Rr ∗ Vi
Vo
(2.7)
2 Impedance spectroscopy and applications 9
Figure 2.6: Impedance measurement using ABBM [9].
In the current design, the input and output voltages are sampled by ADCs and processed using
the Fast Fourier Transform (FFT). The peak voltages at the fundamental frequency are used to
calculate the magnitude of the impedance, according to Equation 2.7. The phase difference at the
fundamental frequency is equivalent to the phase of the impedance. The processing tasks are
accomplished by a DE0-nano-SoC board, a System on Chip which integrates a FPGA and a Hard
Processor System (HPS).
Table 2.1 presents the relevant advantages and disadvantages of the reviewed methods.
Table 2.1: Some impedance measurement methods. Adapted from [9].
Method Advantages Disadvantages Aplicable frequency
range
Bridge method
-High accurrency.
-Wide frequency coverage by using
different types of bridges.
-Low cost.
-Needs to be manually balanced.
-Narrow frequency coverage
with a single instrument.
DC to 300 MHz
Resonant method -Good Q accuracy up to high Q.
-Needs to be tuned to resonance.
-Low impedance measurement accuracy.
10 kHz to 70 MHz
I-V method -Grounded device measurement.
-Suitable to probe-type test needs.
-Operating frequency range is
limited by transformer used in
probe.
10 kHz to 100 MHz
Network analysis
method
-Wide frequency coverage from LF
to RF.
-Good accuracy when the unknown
impedance is close to characterisitic
impedence.
-Recalibration required when the
measurement frequency is
changed.
-Narrow impedance measurement
range.
5 Hz and above
Auto balancing
bridge method
-Wide frequency coverage from LF
to HF.
-High accuracy over a wide
impedance measurement range.
-Grounded device measurement.
High frequency range not available. 20 Hz to 120 MHz
Since ABBM presents high accuracy in a wide impedance range, operates in a frequency range
that suits the requirements of the design, and constitutes a simple method, it represents the best
option for impedance measurement in this project.
10
Chapter 3
Waveform generation and data acquisition
Reliable stimulation of cells for their characterization requires to apply low-voltage,
variable-frequency electric fields as a method to avoid cell degradation [10]. The applied electric
fields as well as the generated current must be conditioned before being interpreted by the digital
system. This chapter shows a review of DDS method for waveform generation, presents the operation
principles of the Current-to-Voltage Converter and explains important terminology of the ADC.
3.1 Direct Digital Synthesis
Direct Digital Synthesis (DDS) is a digital method that consist in generating multiple frequency
signal from a single frequency source. The basic architecture of a DDS is shown in Figure 3.1. The
frequency source acts as a clock for driving the address counter; a Programmable Read Only
Memory (PROM) stores the waveform conversion data, every count addresses a digital amplitude
value of the waveform. Finally, the digital signal is converted into analog using a Digital to Analog
converter (DAC).
Figure 3.1: Basic architecture of a Direct Digital Syntehesis.
This architecture does not allow changes in the output frequency except when the clock
frequency is changed or the PROM is reprogrammed. A more complex architectures is shown in
Figure 3.2. It integrates a Numerically Controlled Oscillator (NCO) as a flexible method to generate
variable frequency output signals [11].
3 Waveform generation and data acquisition 11
Figure 3.2: Direct Digital Synthesis architecture.
The NCO incorporates a phase accumulator. This sub-system stores the value of phase in a range
from 0 to 2 pi. Every clock cycle the value in ∆ phase register is added to the phase register, and the
waveform phase changes accordingly. The value stored in the ∆ phase register controls the speed in
which the phase of the signal changes. If it decreases the frequency of the output signal also
decreases, and if it increases the frequency of the output signal increases too [12].
For a n-bit phase register, 2n represents the number of points to complete a whole signal cycle.
The Equation 3.1 is used to determine the output frequency of the signal base on the value of the ∆
phase register. This equation is known as the ’tuning equation’.
fout =
M ∗ fMCLK
2n
(3.1)
With fMCLK as the clock of the system.
3.2 Current-to-Voltage converter
A Current-to-Voltage Converter (I2V) is a device that converts an input current into a proportional
output voltage. This behavior can be achieved using a Operational Amplifier (OA) in inverting
configuration. The OA configuration is showed in Figure 3.3.
There are two important characteristics of the OA that allows its behaviour as a I2V. Since its
input terminals act as an open circuit for current and as a short circuit for voltage, practically all the
input current flows trough the feedback resistor (Rf) which causes the generation of a proportional
voltage, and since the non-inverter input of the OA is fixed to ground, a virtual ground appears in the
inverter terminal, causing the voltage dropped in Rf to be the output voltage (Vo) [13].
Equation 3.2 shows the relationship between the input current and the output voltage.
3 Waveform generation and data acquisition 12
Figure 3.3: Current-to-Voltage Converter.
Vo = Ii ∗Rf (3.2)
3.3 Analog-to-Digital converter
An Analog-to-Digital Converter (ADC) is a device that assigns a digital code at the output according
with an analog level at the input. Each analog level is attached with a unique code, this is known as
quantization and is showed in Figure 3.4. For an N-bit code is possible to get a maximum of 2N states
at the output. The resolution of the ADC indicates how much must change the analog input in order
to produce a change of one state in the output, it can be seen as the weight of the Least Significant Bit
(LSB).
Figure 3.4: Transfer funcion for an ideal unipolar 3-bit ADC [14].
3 Waveform generation and data acquisition 13
The analog input of the ADC can take any value, however the digital output can not since it is
quantized. it a difference of up to 1/2 LSB between the input and the output, this is called quantization
error [14].
The time between each input reading is commonly describe using the sampling frequency, fs. The
Nyquist Criteria establishes that the sampling rate must be at least twice the higher frequency of the
input signal. If this criteria is not reached, aliasing errors appear.
In real-time systems, the data processing must be done in an interval of 1/fs. In Fourier Fast
Transform (FFT) applications a package of data is read and stored in memory. When the package is
full the FFT is calculated and at the same time a new package is loaded to memory. The FFT must be
calculated before the next package be loaded to the memory.
In systems when the input signal change more than one LSB during the data conversion large errors
can be got. It happens in signals that change in time, like in AC signals. Most modern ADCs have a
sample-and-hold amplifier (SHA) in order to process AC signals, these are known as sampling ADC.
The SHA samples the input during sampling mode and hold its value during hold mode [15].
14
Chapter 4
Design of a low-frequency cell stimulator
The first section of this chapter presents different options for the implementation of the impedance
spectroscopy device: One based on a NI sbRIO-9651 system on module, the second based on
Peripheral Component Interconnect eXtension for Instrumentation (PXI) of National Instruments,
and an implementation using DE0-Nano-SoC development board. The second part describes the
selected architecture, it shows the block diagram of the system and gives a detailed explanation of
each functional blocks: waveform generation, signal conditioning, impedance measurement circuit
and low-pass filters. Finally, the third part includes the digital logic and programming required for
calculating the impedance from the voltage measurements.
4.1 Design options
The concerned device is designed to cause cellular stimulation and measure the resultant impedance.
The cellular stimulation is achieved by the appliance of sine, triangular and square waveforms with
amplitudes up to 100 mV and frequencies up to 40 kHz. Impedance calculation requires to measure
the input and output voltage of the DUT based on the ABBM method. Three design proposals had
been consider in order to achieve this behaviour.
The first approach consist in using a NI sbRIO-9651 System on Module (SOM) board, a specially
designed platform for control and monitoring applications. It integrates a real-time processor, a
reconfigurable FPGA, and analog and digital input/outputs. This device is used for FFT algorithm
implementation, impedance computation and storage. It requires an analog system for data
conditioning and acquisition.
A second approach consist in a system based on Peripheral Component Interconnect eXtension
for Instrumentation (PXI). This is a PC-based platform for developing test, measuring and control
systems [16]. It consists of a chassis with integrated timing and synchronization, input/outputs PXI
4 Design of a low-frequency cell stimulator 15
modules, and an in-chassis embedded computer. The PXI modules required for this application are: a
Sampling System for Data Acquisition (DAQ) and a Waveform Generator System. The whole system
is controlled by NI LabView, a software development environment for measurement and automation.
The third option consist in using DE0-Nano-SoC development board which incorporates a
FPGA, a HPS, General Purpose Input/Outputs, memory devices, a 8-channel ADC, among others.
This device is used for configuring the stimulation, taking the digitized samples for FFT
computation, computing the magnitude and phase of the impedance and storing the data. As in the
first case, it requires an analog system for data conditioning and acquisition.
All options have the proper hardware to achieve the electric requirements. However, in terms of
cost second option is discarded due to it constitutes the most expensive system, the total cost can be
up to some thousand euros, on the other hand, the third option is the cheaper, the cost of a
DE0-Nano-SoC development board is not higher than e100. In terms of size, the first and third
options have the smallest dimensions, making them suitable for being easily transport. Therefore, the
third option is the one that best meets the design requirements: low-cost, portability and easy
reconfigurability of frequency and voltage. It is important to mention that the Institute already have
one available for the project.
4.2 Impedance spectroscopy device based on SoC
Figure 4.6 shows the functional block diagram of the proposed system. It consists of an analog
implementation for data conditioning and acquisition, and a digital implementation intended to
configure the stimulation parameters, take packages of samples and apply them the FFT for
calculation of the impedance spectrum.
4.2.1 Waveform generator
The waveform generator block is intended to generate sinusoidal, triangular and square waveforms at
frequencies up to 40 KHz with magnitudes between 0 V and 100 mV. The waveform, frequency and
phase shift are configured by the DE0-Nano-SoC board allowing sample stimulation by a fixed
frequency signal or frequency sweeps. There have been considered three different options to perform
this task.
The first option is to use the FPGA contained in the DE0 Nano SoC to generate all this signals
digitally, and then use a DAC to get analog signals with the required specifications. Using the FPGA,
digital signals with different waveform, amplitude and frequency can be generated. These signals
4 Design of a low-frequency cell stimulator 16
Figure 4.1: Functional block diagram of the low-frequency cell stimulator.
have low voltage boundary of 0 V and a high voltage boundary of 3.3 V. The sinusoidal waveform is
commonly stored in a ROM inside the FPGA, and would be transmitted to the DAC either by parallel
or serial communication.
The second option implies to use a Voltage-Controlled Oscillator (VCO), it is a device capable to
generate output signals according to the input voltage applied. MAX038 is a high-frequency VCO
that generates triangle, sawtooth, sine, square and pulse waveforms with frequencies from 0.1 Hz to
20 MHz. However, it is necessary to use a simple DAC to control the VCO using the DE0-Nano-SoC
development board.
The third approach consists in using a Direct Digital Synthesis (DDS). Basically, it is a device
that produces analog waveforms through the conversion of time-varying digital signals into analog
using an integrated DAC [19] (for more information see chapter 3). As in above options,
DE0-Nano-SoC board is programmed to adjust the waveform and frequency of the signal.
The characteristics of the third implementation make him the best option to generate analog signals
with variable output frequencies due to:
• Flexible tuning, just requires to write some internal registers by serial protocol for waveform,
frequency and phase adjustment.
• Eliminates the need of extra algorithms for signal construction, its architecture is optimized to
build sine, triangular and square signals.
• Al thought it require an extra element for adjusting the amplitude, it can be achieved with simple
4 Design of a low-frequency cell stimulator 17
components.
Table 4.1 presents a list of DDS ICs and a brief description of their relevant characteristics.
Table 4.1: DDS options
Chip Freq Range Freq Resolution Waveforms IC Pins
AD5932 Up to 25 MHz 24 bits Sine, triangular, square 16
AD9833 0.1 Hz - 12.5 MHz 28 bits Sine, triangular, square 8
AD9838 0.06 Hz - 8 MHz 28 bits Sine, triangular 20
AD9850 Up to 62.5 MHz 32 bits Sine, square 28
Due to size, resolution, and waveform characteristics the AD9833 is chosen to be implemented in
the target application.
4.2.2 Conditioning & filtering
The conditioning & filtering block adjusts the amplitude of the signal in a range from 0 V to 100 mV,
it also incorporates a LPF in order to decrease the effects of noise and spurious signals.
Amplitude and filter conditioning architectures require the use of OA. Table 4.2 presents a list of
OA and a brief description of their relevant characteristics.
Table 4.2: OA options
Chip Supply range (V) GBP (MHz) Slew Rate (V/us)
OP284 2 - 36 4.25MHz 4
AD820 5 - 30 1.9MHz 3
OP213 4 - 36 3.4MHz 1.2
OPA2365 2.2 - 5.5 50 MHz 25
OPA2836 2.5 - 5.5 205 MHz 560
Gain Bandwidth Product (GBP) and slew rate characteristics make the OPA2836 the best option
for the current design.
4.2.3 Impedance measurement
The impedance measurement block contains the hardware required for the impedance measurement
method. For ABBM, this block consists of a current-to-voltage converter. The OA used to implement
the I2V is the same as the one described for the low-pass filters.
4 Design of a low-frequency cell stimulator 18
4.2.4 Control, processing & storage
Control, processing & storage block is intended to carry on the waveform, frequency and phase shift
signal configuration, as well as execute the stimulation process by a single frequency or frequency
sweep. It also samples the DUT input and output voltages and computes the FFT. It extracts the
magnitude information from the fundamental frequency of the signals and calculates the impedance.
Finally, it stores the impedance data in a text file for further analysis.
The entire block is implemented in the DE0-Nano-SoC development board. This device is
programmed using Quartus Prime Software, a design environment that allows to program the FPGA
using a Hardware Description Language (HDL), and interconnect internal elements such as GIOP,
ADC, and HPS by the system integrator tool, Qsys.
4.3 Analog frontend
4.3.1 Waveform generation
The AD9833 is a DDS optimized to act as a programmable waveform generator that can produce
sine, triangular and square wave outputs with output frequencies up to 12.5 MHz. It has a 0.1 Hz
resolution and is programmed using 3-wire serial interface. The disadvantage of this chip is that has
an output amplitude of around 650 mV for sine and triangular waves and 3.3 V for square waves,
what makes necessary to use an attenuator at the output to get a variable amplitude between 0 and
100 mVpp.
Figure 4.2 shows the electric diagram for the Programmable Waveform Generator. MCLK,
SDATA, SCLK and FSYNC are serial protocol terminals use to stablish communication between
AD9833 and DE0-Nano-SoC development board.
Figure 4.2: Electric diagram of the Programmable Waveform Generator.
4.3.2 Voltage regulator
Initially, the design was supposed to work with positive voltages due to DE0-Nano-SoC board
limitations. However, this implementation increase noise, biasing and distortion issues [21]. Thus, a
4 Design of a low-frequency cell stimulator 19
double-supply system is implemented making necessary to use a method for get a negative supply.
The TL7660 is a Voltage Converter IC that uses two external capacitor for charge pump and charge
reservoir functions, this allows conversion of positive voltages into negatives. Figure 4.3 shows the
electric diagram for the Voltage Regulator.
Figure 4.3: Electric diagram of the Voltage Regulator
When this IC is powered with +3.3 V, theoretically, the output is a DC signal of -3.3 V.
4.3.3 Attenuator
The attenuator is intended to decrease the signal amplitude in the range of 0 V to 100 mV. Using an
Operational Amplifer in inverting configuration is a simple form to get an attenuator, Figure 4.4
shows the electric diagram for this implementation.
Figure 4.4: Electric diagram of the Attenuator
This circuit allows a minimum attenuation factor of 0.3.
4 Design of a low-frequency cell stimulator 20
4.3.4 Low-pass filter
The presence of noise and spurious signals in digital systems is inevitable. The repetition rate, rise
and fall times, amplitude and waveform of the signals in the system cause the increase of energy in
many points of the frequency spectrum [22]. This makes necessary to add a Low-Pass Filter (LPF) to
attenuate the unwanted signals.
Figure 4.5 shows aMultiple-Feedback architecture for a second order LPF with a cut-off frequency
fc = 16MHz.
Figure 4.5: Electric diagram of the Low-Pass Filter
4.3.5 Current-to-Voltage converter
The current at the input of the I2V converter can be estimated using Ohm´s Law. With the stimulation
voltage as Vi and DUT as the impedance at the input, equation 3.2 turns into 4.1.
Vo
Vi
= − Rf
DUT
(4.1)
Equation 4.1 is the same equation use for compute gain in an inverter amplifier. In order two keep
attenuation no grater than 10, the feedback resistor must be kept in the same order of magnitude as
the DUT, otherwise the attenuation could cause inaccurate calculations. The value of the feedback
resistor must be enter during the stimulation configuration in the user interface.
4.3.6 Coupling capacitor
A coupling capacitor is introduced at the output of the attenuator and I2V converter in order to
eliminate DC offset voltages. The coupling capacitor in series with the circuit resistance acts as a
High-Pass Filter (HPF).
4 Design of a low-frequency cell stimulator 21
4.3.7 Complete analog circuit
Figure 4.6 shows a general view of the system. The Programmable Waveform Generator is
configured by the DE0-Nano-SoC development board using serial protocol. This configuration
process establish the waveform, frequency and phase shift of the signal generated by the waveform
generator. Then, the signal is attenuated and filtered before being applied to the DUT, this voltage is
sampled by the ADC 0. The current flowing through the DUT is converted into voltage using the
I2V. This voltage is filtered again for being sampled by the ADC 1. Finally, the DE0-Nano-SoC
apply the FFT to the samples and computes the impedance.
Figure 4.6: Functional block diagram of the low-frequency cell stimulator.
The detailed electric diagram, as well as the PCB layout of this implementation is shown in
Appendix C. This appendix also includes a description, the electric diagram and PCB layout of a
second prototype. This second device was design with almost the same architecture used in the first
prototype. The only difference is that it includes external ADCs with higher sample rate in order to
increase the bandwidth of the system. However, due to time restrictions the implementation with this
design has not been incorporated in this work.
4 Design of a low-frequency cell stimulator 22
4.4 Digital design
4.4.1 Waveform generator controller
The HPS of the DE0-Nano-SoC development board include a Dual-core ARM Cortex-A9 processor
which has been preconfigured to run Linux. A python script is executed on this image in order to
generate a user interface and configure the stimulation process according to the user preferences,
feedback resistor, operation mode, frequency, phase shift and waveform. This task requires to
interconnect the HPS and the FPGA using internal HPS peripheral bridges. However, the program
running on Linux do not have a direct link to the peripheral address, therefore it is necessary to map
the physical address to a user space and access the internal registers of FPGA [20]. The Figure 4.7
shows this relationship.
Figure 4.7: Communication between FPGA and HPS.
Once the user introduces and selects the stimulation parameters, the software computes the
register values for tuning the waveform generator. There are five 16-bit required transmissions and
three configuration registers.
Control register: This register is used to configure the operation of the AD9833. In the first
transmission a 16-bit word [0010 0001 00X0 X0X0b] is loaded to the control register in order to:
indicate to the AD9833 that control register is going to be written (bits 15 and 14), two consecutive
write operations for load the frequency register are required (bit 13), FREQ0 is the register used to
write the value of frequency (bit 11), PHASE0 is the register used to write the value of phase shift
(bit 10), reset the internal registers before writing them (bit 8), and select the waveform (bits 5, 3 and
1). Table 4.3 shows the state of bits 5, 3 and 1 for configuring the signal waveform.
At the fifth transmission, this register is written again with a 16 bit exit word. The word is the same
as the first one except by the reset bit which is set to 0.
4 Design of a low-frequency cell stimulator 23
Table 4.3: Waveform configuration
BIT 5 BIT 3 BIT 1 Waveform
0 X 0 Sinusoid
0 X 1 Triangule
1 1 0 Square
Frequency register FREQ0: This register stores the data for frequency adjustment. It needs two
write operations for load a 28-bit frequency resolution word.
From equation 3.1, the word loaded to the FREQ0 register is calculated as shown in 4.2.
FREQ0 =
fout ∗ 228
fMCLK
(4.2)
The first write operation is used to load the 14 LSB and the second is used to load the 14 MSB.
Bit 15 and 14 of each write operation are set in [01b] to indicate that FREQ0 is been written.
Phase register PHASE0: It stores the desired phase shift, its content is load to the phase
accumulator. The word load to this register is computed using equation 4.3.
PHASE0 =
PhaseShift ∗ 212
2pi
(4.3)
The 4 MSB indicates that PHASE0 register is selected. The remaining 12 bits carry the value
computed in 4.3.
The transmissions are accomplish serial protocol. The time diagram of this protocol is shown in
figure 4.8. SCLK is used to introduce the serial clock that controls the data load, FSYNC enables the
read of data, SDATA contains the data transmitted, and MCLK is the AD9833 internal clock, output
frequency is expressed as a fraction of this clock. MCLK and SCLK are connected to a 25 MHz clock
generated by the DE0-Nano-SoC board.
Figure 4.8: Time diagram for serial protocol [12].
4 Design of a low-frequency cell stimulator 24
Each parameter of the serial protocol has time restrictions, in figure 4.8 they are referred as ts.
Table 4.4 shows these timing characteristics.
Table 4.4: Serial protocol timing characteristics [12].
Parameter Limit Unit Description
t1 40 ns min MCLK period
t2 16 ns min MCLK high duration
t3 16 ns min MCLK low duration
t4 25 ns min SCLK period
t5 10 ns min SCLK high duration
t6 10 ns min SCLK low duration
t7 5 ns min FSYNC to SCLK falling edge setup time
t8 min 10 ns min FSYNC to SCLK hold time
t8 max t4 - 5 ns max
t9 5 ns min Data setup time
t10 3 ns min Data hold time
t11 5 ns min SCLK high to FSYNC falling edge setup time
A module for data transmission is programmed and executed by the FPGA using Verilog (this
module is presented on Appendix B). It send the content of the internal registers to the
Programmable Waveform Generator IC using the serial protocol described in figure 4.8. The LSB of
Configuration Register is used to restart the module and begin a new transmission.
4.5 Impedance calculation
In chapter 2, some methods of impedance measurement were reviewed. ABMM was selected for this
application due to its accuracy and frequency response. Using this method implies to sample the
voltage applied to the DUT, as well as its resultant current. The resultant current is converted into
voltage using a I2V converter, then both voltages are digitized using the ADCs integrated on
DE0-Nano-SoC development board.
The software running on the HPS reads packages of 1024 samples and computes the FFT using
the NumPy library of Python, this code is showed in Appendix B. When the FFT is computed, the
software extracts the DC levels and look for the fundamental frequency component, then calculates
the impedance. The computed impedance is stored in a file for further analysis.
25
Chapter 5
Low-frequency cell stimulator response
This chapter shows the experimental results obtained from the low-frequency cell stimulator device.
The operation of the serial protocol as well as the data acquisition elements is showed. Also, it presents
experiments carried out on known impedances and yeast cultures.
5.1 Waveform generation
Figure 5.1 shows readings of the MCLK, SCLK, SDATA and FSYNC control signals produced by the
FPGA. The process shows a transmission of a 210 kHz triangular signal as follows:
• WORD 1: [0010 0001 0000 0010]b→ Configure a triangular signal.
• WORD 2: [0100 0001 1000 1001]b→ LSB of a 210 kHz signal.
• WORD 3: [0101 0101 1000 0001]b→MSB of a 210 kHz signal.
• WORD 4: [1100 1010 1010 1011]b→ Phase shift of 240◦.
• WORD 5: [0010 0000 0000 0010]b→ End configuration.
Figure 5.1: Serial Protocol Verification.
The timing characteristics had been measured for the signals in Figure 5.1. This information is
shown in Table 5.1.
5 Low-frequency cell stimulator response 26
Table 5.1: Timing measurements of serial protocol.
Parameter Measurement
t1 40 ns
t2 20 ns
t3 20 ns
t4 40 ns
t5 20 ns
t6 20 ns
t7 12.5 ns
t8 27.5 ns
t9 12.5 ns
t10 27.5 ns
t11 7.5 ns
The verification shows that the four variables of control in the serial protocol meet the
requirements on time and the transmission is done properly.
Tests on the Programmable Waveform Generator show that the system interacts properly with the
DE0-Nano-SoC development board. Also, the experimental results reveal that the device is capable
to produce sine, triangular and square signals with frequencies beyond 1 MHz, which exceeds the 40
kHz target. Oscilloscope captures that shows this feature are presented in Appendix A.
5.2 Signal acquisition
5.2.1 Low-pass filter
Using a Spectrum Analizer, the frequency spectrum of the system is observe in order to locate high
energized spurs and harmonics. Figure 5.2 shows the frequency spectrum at the output of the
Programmable Waveform Generator. The characteristics of the applied signal are:
• Waveform = sine.
• Frequency = 12 MHz.
• First energized spur ≈ 38.19 MHz
The results of this analysis exhibit the presence of noise in the spectrum. This indicates the need
of a LPF in order to attenuate this signals, a cut-off frequency of 16 MHz must be enough to deal
with the noise. The electric diagram of a LPF with fc = 16MHz was showed in chapter 5, however,
5 Low-frequency cell stimulator response 27
Figure 5.2: Frequency spectrum at the output of the Programmable Waveform Generator
the calculations in this section were theoretical and did not include variations caused by other stages.
Running simulations of the design on TINA-TI, a simulation tool from Texas Instruments, the
components were adjusted to get a cut-off frequency as close as possible to 16 MHz. Nevertheless it
was not possible to achieve such frequency due to limitations in the components of the circuit. The
electric schematic of the simulated circuit is shown in Figure 5.3.
Figure 5.3: Electric schematic from TINA simulation tool.
5 Low-frequency cell stimulator response 28
The simulated frequency response for the circuit of Figure 5.3 is shown in Figure 5.4. The filter
response is affected by the impedance used as feedback resistor in the attenuator and I2V, the
presented results contemplate a critical operation. Notice that for this case the attenuator is
introducing a gain of around -10 dB.
Figure 5.4: Simulated frequency response of the circuit.
The real response of the assembled filters is shown in the next diagrams. For ADC_0 filter the
cut-off frequency is 5 MHz and for ADC_1 filter it drops to 57 kHz.
103 104 105 106 107
−8
−6
−4
−2
0
Frequency (Hz)
M
ag
ni
tu
de
(d
B)
Figure 5.5: Frequency spectrum for ADC_0 filter.
5 Low-frequency cell stimulator response 29
103 104 105 106 107
−15
−10
−5
0
Frequency (Hz)
M
ag
ni
tu
de
(d
B)
Figure 5.6: Frequency spectrum for ADC_1 filter.
5.3 Impedance measurement
This section presents the results obtained from experiments using known impedances values and yeast
cell cultures. Single frequency and frequency sweeps were applied to known impedance loads in
order to determine the accuracy of the device. Besides, yeast samples were stimulated using a single
frequency in order to observe the growth of the cultures over time, this data is compare with obtained
results using the Agilent 4284A LCR meter.
5.3.1 Correction factor
In order to obtain more accurate results it is necessary to add a correction factor to the phase data.
This correction factor depends on the frequency and is cause by the fact that the measurements are
carried out by one ADC.
The ADC integrated on the DE0-Nano-SoC development board has 12-bit resolution, 500 ksps
sample rate and 8-channel analog input. For the concerned application, two of the channels are
required, one for measuring the voltage applied to the DUT and other for measuring the output
voltage. Due to one ADC must sample two channels, it is impossible to sample them at the same
time which cause a delay in the sampling. This delay causes a phase shift between the signals, and it
is seen like a reactance by the software that computes the impedance.
Using the linear response of resistors it is possible to estimate the correction factor by applying a
frequency sweep to a resistor and obtaining the phase in each frequency. Nine phase data packages
were obtain from stimulating three different resistors at frequencies from 100 Hz to 125 kHz with
5 Low-frequency cell stimulator response 30
increments of 100 Hz. The data were average and a third-order median filter were apply to remove
peaks and noise. This process were carried out using Matlab software, Figure 5.7 shows the
correction factor plot.
Figure 5.7: Correction factor for phase adjustment.
5.3.2 Stimulation with a single frequency
In order to determine the accuracy of the device, known impedances were stimulated by a single
frequency. These impedances were composed by a 10 kΩ resistor in series with a capacitor. Table
5.2 presents the error percentages for phase and magnitude by stimulating impedances with a
sine-wave at 40 kHz and 100 mV.
Table 5.2: Stimulation of known impedance by applying a signal of 40 kHz.
C (pf) Xc (Ω) Theor.
Magnit.
Theor.
Phase
Meas.
Magnit.
Meas.
Phase
% Error
Magnit.
% Error
Phase
10 397887.36 398013.00 -88.56 387550.95 -84.47 2.63 4.62
47 84656.88 85245.46 -83.26 85452.26 -82.67 0.24 0.71
100 39788.74 41026.13 -75.89 39623.77 -74.67 3.42 1.61
220 18085.79 20666.30 -61.06 21542.85 -60.11 4.24 1.55
470 8465.69 13102.21 -40.25 12987.48 -38.93 0.88 3.27
2100 1894.70 10177.91 -10.73 10250.31 -10.66 0.71 0.67
The data in Table 5.2 shows that the device is capable to compute impedance magnitude and
phase at frequencies up to 40 kHz with error percentages lower than 10%.
The previous experiment were repeated using the same values of impedance as DUT but with the
stimulation frequency set to 100 kHz. The results are showed in Table 5.3.
5 Low-frequency cell stimulator response 31
Table 5.3: Stimulation of known impedance by applying a signal of 100 kHz.
C (pf) Xc (Ω) Theor.
Magnit.
Theor.
Phase
Meas.
Magnit.
Meas.
Phase
% Error
Magnit.
% Error
Phase
10 159154.94 159468.79 -86.40 172322.4 -78.59 8.06 9.05
47 33862.75 35308.44 -73.55 38894.9 -73.52 10.16 0.03
100 15915.49 18796.35 -57.86 20216.37 -56.98 7.55 1.52
220 7234.32 12342.42 -35.88 14063.8 -36.49 13.95 1.68
470 3386.28 10557.79 -18.71 11702.32 -18.12 10.84 3.15
2100 757.88 10028.68 -4.33 11034.7 -4.39 10.03 1.29
As can be observed in Table 5.3, the device can operate in frequencies up to 100 kHz but with a
slightly increment of error that exceeds the goal of 10%.
Next experiment consisted in stimulating yeast cultures by the appliance of a sine-wave. Figure
5.8 shows a picture of the setup of the experiment.
Figure 5.8: Stimulation and impedance measurement of yeast cultures.
The yeast culture were deposit in a silicon chamber with two steel electrodes separated by a
distance of 1 cm, it was used 50 g of yeast mixed with 0.5 ml of water. The applied voltage had a
magnitude of 100 mVpp at 40 kHz, this signal were applied over 30 minutes, and each sample was
taken every second. The results obtained with cell stimulator prototype are compared with the ones
obtained using the Agilent 4284A LCR meter. Figure 5.9 shows the changes of magnitude and phase
5 Low-frequency cell stimulator response 32
of the yeast culture over time. The results obtained using the cell stimulator were processed using a
third-order median filter for removing peaks and decreasing noise.
Figure 5.9: Stimulation of yeast cultures at 40 kHz.
The label LCR identify the red and magenta results, these were obtained using the Agilent 4284A
LCR meter, and the label CellStim identify the blue and cyan, the ones obtained with the cell
stimulator prototype. It can be observed that the impedance magnitude differs from one experiment
to another. Even when the same device is used, differences up to 5 kΩ appear. This issue is caused
mainly for three reasons: The cell cultures are very sensitive to changes in the environment, and it is
not possible to have the exactly same conditions in each experiment. The mixture of yeast and water
was not equivalent, shaking a sample in different proportions in each experiment can generates
different growth rates. Even most important, the deposition of water in the yeast produces bubbles
inside the chamber, causing changes in the electrical permittivity and therefore in the impedance.
Additional error sources affects the results obtained with the cell stimulator due to the circuit is
not optimized for noise reduction. Electromagnetic signals in the environment captured by the test
pins and jumpers of the PCB, biasing issues from the OA, and quantization error are some of the
error sources that introduce noise to the signal.
5.3.3 Stimulating with a frequency sweep
For determining the operation of the device over the bandwidth, frequency sweeps were applied to
three different metal film resistors, 3 kΩ, 27 kΩ, and 680 kΩ. The signal applied were a sine-wave
with magnitude of 100 mVpp at frequencies up to 125 kHz. The data were processed using a
third-order median filter in Matlab software, and the results are showed in Figure 5.10. The red line
represents the theoretical value given by the manufacturer, and the blue line represents the results
obtained using the cell stimulator prototype.
5 Low-frequency cell stimulator response 33
Figure 5.10: Stimulation of known impedance by frequency sweep.
Although the original data were filtered, some peaks remain in the curves since the filter order is
not enough to remove them. Tests over the ADC were carried out in order to determine its accuracy,
known voltages were applied at the input of the ADC and the digital values were read to estimate the
error, variation up to 4 mV were noticed in the conversion. This mean that a critical case in which
both, input and output voltages, are affected by this phenomenon there is a difference of 8 mV
between signals, this can lead to an error of up to 8.3% in the calculations. Also, it is possible to
observe that the system has more difficulty calculating the impedance at high frequencies, especially
at high impedances. When high impedance is measured, it is necessary to use high feedback resistors
in the I2V, this resistor modify the filter response, the cut-off frequency decreases as the feedback
resistors increments. It cause the attenuation of the signals at high frequencies. Table 5.4 shows the
average resistance computed using measures up to 40 kHz and 125 kHz.
Table 5.4: Calculations of resistance over a frequency range.
Up to 40 kHz Up to 125 kHz
Theoretical
Resistance (Ω)
Measured
Resistance (Ω) % Error
Measured
Resistance (Ω) % Error
3000.00 2983.20 0.56 3076.67 2.56
27000.00 27003.18 0.01 28603.59 5.94
680000.00 678967.19 0.15 744839.05 9.54
The error percentages presented in table 5.4 shows that the average error remains under 1% for
frequency sweeps up to 40 kHz, but for higher frequencies it increases. However it remains below
10%.
34
Chapter 6
Conclusions
This thesis has presented the design and implementation of a prototype for stimulation and
impedance measurement of cell samples. The device had an implementation cost of €160, which is
30 times less than a commercial LCR meter, its dimensions are 75x100x50 mm, which make it
suitable for portability (this characteristics are explained with more detail in Appendix D). Also, it
establishes the basis for developing others devices with improvements in bandwidth, impedance
range and number of channels. In the next paragraphs, the achievements and limitations of this work
are presented.
It was shown that the stimulation is achieve by generating sine, triangular and square signals at
frequencies up to 1 MHz and magnitudes up to 100 mVpp. The applied signal can be configured as
single frequency or as a frequency sweep. Tests carried out with the device showed that magnitudes
up to 1 MΩ can be measured with error percentages below 10% for frequencies up to 40 kHz, and
below 15% for frequencies up to 100 kHz. Also, impedance phase can be measured with error
percentages below 10% for frequencies up to 100 kHz.
The experiments carried out on yeast cell cultures showed large differences between the
measurements even when the same device were used, the impedance changed from one experiment
to another. Differences in the environmental conditions and the formation of bubbles inside the
chamber were random issues that made difficult to reproduce the results.
Finally, for future work, some recommendations can be followed in order to improve the range of
measurements as well as the quality of the results. One comprises the use of external ADCs for
reducing the phase shift error, since the voltages are sampled at the same time, and improving
resolution and bandwidth, it can be achieved if the ADC is selected with more bits and a higher
sample ratio. It is important to consider that for incrementing the bandwidth, it can be necessary to
implement the FFT inside the FPGA instead of implementing it by software. This would increase the
system speed allowing to operate the system at higher frequencies.
6 Conclusions 35
Improvements on the analog frontend imply to incorporate voltage followers at the input of the
filters for preventing changes in the filter response, it will allow to increase the impedance range. In
general, the bandwidth can be improved with faster devices for wave generation, filtering and
conditioning. The detectable impedance range can also be expanded by increasing the number of bits
of the sampling devices. Finally, the input channels can be multiplexed in a future design for parallel
experiments.
A last recommendation is to implement a systematize methodology for validation of the system.
It must consider the changes in the impedance even when the preparation of the cultures is similar. It
can be achieved by alternately measuring the same sample with the LCR meter and the cell
stimulator prototype in short time periods.
36
References
[1] P. Vega-Castillo and R. Rimolo-Donadio. "Propuesta de Investigación: Circuito Integrado
para la Espectroscopia de Células Humanas - I Fase,” Vicerrectoría de Investigación y Extensión,
Instituto Tecnológico de Costa Rica, Cartago, Cosa Rica, 2015-2016.
[2] S. Meng, M. Rouabhia and Z. Zhang (2011). "Electrical Stimulation in Tissue Regeneration,"
Applied Biomedical Engineering, Dr. Gaetano Gargiulo (Ed.) [Online], ISBN: 978-
953-307-256-2, InTech. Available: http://www.intechopen.com/books/applied-biomedical-
engineering/electrical-stimulation-in-tissueregeneration
[3] E. Hondroulis, S. Melnick, X. Zhang, W. Ze-Zhi and L. Chen-Zhong. "Electrical field
manipulation of cancer cell behavior monitored by whole cell biosensing device," Springer
Science+Business Media, vol. 15, pp 657–663, 2013.
[4] H. P. Schwan (1994). "Electrical properties of tissues and cell suspensions: mechanisms
and models," in Proc. 16th Annual International Conference of the IEEE. [Online], ISBN:
0-7803-2050-6, Engineering Advances: New Opportunities for Biomedical Engineers. Available:
http://ieeexplore.ieee.org/document/412155/
[5] K. Kirson, Z. Gurvich, R. Schneiderman, E. Dekel, A. Itzhaki, Y. Wasserman, R.
Schatzberger and Y. Palti. "Disruption of Cancer Cell Replication by Alternating Electric
Fields," CANCER RESEARCH, vol. 64, pp: 3288–3295, 2004.
[6] A. Davies, U. Weinberg and Y. Palti. "Tumor treating fields: A new frontier in cancer therapy,"
Novocure. ISSN 0077-8923, 2013.
[7] K. Yonemori, S. Matsunaga, Y. Ishidou, S. Maeda and H. Yoshida. "Early Effects of
Electrical Stimulation on Osteogenesis," Bone, vol. 19, pp: 173-180, 1996.
REFERENCES 37
[8] E. Paredes, L. Niño, A. Raya-Rivera, D. Robles and R. Vargas. "An Adaptive System to
Stimulate Culture Cells," IEEE, 2009.
[9] Keysight Technologies, "Impedance Measurement Handbook: A guide to measurement
technology and techniques," Handbook, 5ed, 2015.
[10] J. Montero-Rodríguez, E. Salazar-Flórez, P. Vega-Castillo, J. Tomasik, W. Galjan, K.
Hafkemeyer and Krautschneider. "An Impedance Spectroscopy ASIC for Low-Frequency
Characterization of Biological Samples," in Proc. 9th International Joint Conference on
Biomedical Engineering Systems and Technologies (BIOSTEC 2016), 2016, pages 222-228.
[11] Analog Devices, "Fundamentals of Direct Digital Synthesis (DDS)," Rep. no. MT-
085, Tutorial, 2008. [Online] Available: http://www.analog.com/media/en/training-
seminars/tutorials/MT-085.pdf
[12] Analog Devices, "Programmable Waveform Generator," Rep. no. AD9833, Datasheet,
2016. [Online] Available: http://www.analog.com/media/en/technical-documentation/data-
sheets/AD9833.pdf
[13] T. L. Floyd, "Electronic devices: conventional current version," 9th ed., Pearson, New Jersey,
2012.
[14] W. Kester, D. Sheingold and J. Bryant, "Coding and Quantizing,"
in Fundamentals of Sampled Data Systems, Analog Devices. [Online].
Available: http://www.analog.com/library/analogDialogue/archives/39-
06/Chapter%202%20Sampled%20Data%20Systems%20F.pdf
[15] W. Kester, "Sampling Theory," in Fundamentals of Sampled Data Systems, Analog
Devices. [Online]. Available: http://www.analog.com/library/analogDialogue/archives/39-
06/Chapter%202%20Sampled%20Data%20Systems%20F.pdf
[16] National Instruments, 2016. "What Is PXI?", 2016. [Online]. Available:
http://www.ni.com/pxi/whatis/
REFERENCES 38
[17] P. A. Moya, "Señales y Sistemas: Fundmentos Matemáticos," 1st ed., CDMB, Cartago, Costa
Rica, 2008.
[18] J. Tsui and C.-H. Cheng, "Digital Techniques for Wideband Receivers," 3rd ed., Institution of
Engineering and Technology, 2015.
[19] E. Murphy and C. Slattery, "All About Direct Digital Synthesis," Analog
Dialog, Rep. no. 33, Ask The Application Engineer, 2004. [Online] Available:
http://www.analog.com/library/analogDialogue/archives/38-08/dds.pdf
[20] Terasic Inc, "DE0-NANO-SoC: User Manual," 2015.
[21] Maxim Integrated Products, "Design Trade-Offs for Single-Supply Op Amps," Rep. no.
656, Application note, 2000. [Online] Available: https://www.maximintegrated.com/en/app-
notes/index.mvp/id/656
[22] G. Breed. "Noise and Spurious in Digital Systems and Digitized Signals," High Frequency
Electronics, pp 50–52, 2006.
39
Appendix A
Generated signals for electric stimulation
Figure A.1 is an example of a sine signal in three different frequency levels, Figure A.2 shows the
results for a triangular signal, and Figure A.3 for a square signal.
(a) (b)
(c)
Figure A.1: Sine waveform generation at (a) 10 kHz, (b) 100 kHz and (c) 1 MHz.
A Generated signals for electric stimulation 40
(a) (b)
(c)
Figure A.2: Triangular waveform generation at (a) 10 kHz, (b) 100 kHz and (c) 1 MHz.
(a) (b)
(c)
Figure A.3: Square waveform generation at (a) 10 kHz, (b) 100 kHz and (c) 1 MHz.
41
Appendix B
Designed software
This appendix shows the code programmed in Python to execute the user interface, impedance
calculation and storage, as well as the code used to program the FPGA using Verilog language.
B.1 Python script
This code is executed on the Linux image loaded to the HPS of the DE0-Nano-SoC development
board. It is intended to map the registers addresses to a user space in order to establish
communication between the HPS and the FPGA, display the user interface, configure the stimulation
parameters, perform the FFT, calculate the impedance, and store the data.
impo r t os
impo r t mmap
impo r t t ime
from s t r u c t impo r t unpack
impo r t numpy as np
impo r t m a t p l o t l i b . p y p l o t a s p l t
p r i n t ( ’ ∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗ \ n ’ )
p r i n t ( ’∗ Low−f r e qu en cy c e l l s t i m u l a t o r ∗ \ n ’ )
p r i n t ( ’ ∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗ \ n \ n ’ )
p r i n t ( ’ E x i t w i th c o n t r o l +C ’ )
# Run by w r i t t i n g i n t h e c on s o l e t h e f o l l ow i n g command :
# ap t−g e t i n s t a l l python−numpy python−ma t p l o t l i b
# py thon2 . 7 Ce l l _S t im . py
# D e f i n i t i o n s from hps . h
ALT_STM_OFST = np . u i n t 3 2 (0 xfc000000 )
ALT_LWFPGASLVS_OFST = np . u i n t 3 2 (0 x f f200000 )
# D e f i n i t i o n s from Qsys from hps_0 . h
AVALON_INTERFACE_MEMR_0_BASE = np . u i n t 3 2 (0 x00 )
AVALON_INTERFACE_MEMR_0_SPAN = 32
AVALON_INTERFACE_MEMR_0_END = np . u i n t 3 2 (0 x0f )
ADC_0_BASE = np . u i n t 3 2 (0 x20 )
ADC_0_SPAN = 32
ADC_0_END = np . u i n t 3 2 (0 x3f )
B Designed software 42
# D e f i n i t i o n s f o r t h i s f i l e
HW_REGS_BASE = ALT_STM_OFST
HW_REGS_SPAN = np . u i n t 3 2 (0 x04000000 )
HW_REGS_MASK = np . u i n t 3 2 (HW_REGS_SPAN−1)
# / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / /
# / / Map Adress
# / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / /
# Map t h e a d d r e s s space f o r t h e r e g i s t e r s i n t o u s e r space , so we can i n t e r a c t w i th them .
# Open t h e memory space (mmap)
fd = os . open ( " / dev /mem" , os .O_RDWR | os .O_SYNC)
vbase = mmap .mmap( fd , HW_REGS_SPAN, mmap .MAP_SHARED, (mmap . PROT_WRITE | mmap .PROT_READ) , a c c e s s =mmap
.ACCESS_WRITE , o f f s e t =HW_REGS_BASE) #Device base add r e s s , g i v en by Qsys
# C a l c u l a t e p h y s i c a l a d d r e s s e s f o r p e r i p h e r a l s
r e g_ add r = ( np . u i n t 3 2 (ALT_LWFPGASLVS_OFST + AVALON_INTERFACE_MEMR_0_BASE) & np . u i n t 3 2 (HW_REGS_MASK) )
ADC_addr = ( np . u i n t 3 2 (ALT_LWFPGASLVS_OFST + ADC_0_BASE) & np . u i n t 3 2 (HW_REGS_MASK) )
# / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / /
# / / De f ined Fun c t i o n s
# / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / /
# De f ine DDS w r i t e f u n t i o n
de f d d s _w r i t e ( pwf , pfq , p p s h i f t , p r eg_add r ) :
# Se t c o n f i g u r e r e g i s t e r h igh t o p r e p a r e s e r i a l communica t ion wi th DDS
vbase . s eek ( p r eg_add r +10) # P l a c e t h e c u r s o r a t c o n f i g u r a t i o n r e g i s t e r p o s i t i o n
vbase . w r i t e ( np . u i n t 1 6 (0 xFFFF ) ) # Wr i t e c o n f i g u r a t i o n r e g i s t e r
t ime . s l e e p ( 0 . 0 0 1 )
# S e l e c t t h e v a l u e s o f t h e Con t r o l and Ex i t R e g i s t e r a c c o r d i n g wi th t h e waveform s e l e c t e d
i f ( pwf == 1) :
p c t r l = 0x2100
pex t = 0x2000
i f ( pwf == 2) :
p c t r l = 0x2102
pex t = 0x2002
i f ( pwf == 3) :
p c t r l = 0x2128
pex t = 0x2028
f r e q = np . u i n t 3 2 ( ( p fq ∗268 .435456) / 2 5 )
p l s b = ( np . u i n t 3 2 (0 x3FFF ) & f r e q ) | 0x4000 #LSB Frequency R e g i s t e r
pmsb = ( f r e q >> 14) | 0x4000 #MSB Frequency R e g i s t e r
p p s h i f t = ( p p s h i f t ∗4096) /360
ppreg = 0xC000 | p p s h i f t # Phase R e g i s t e r
vbase . s eek ( p r eg_add r ) # P l a c e t h e c u r s o r a t c o n t r o l r e g i s t e r p o s i t i o n
vbase . w r i t e ( np . u i n t 1 6 ( p c t r l ) ) # Wr i t e c o n t r o l r e g i s t e r
vbase . s eek ( p r eg_add r +2) # P l a c e t h e c u r s o r a t LSB r e g i s t e r p o s i t i o n
vbase . w r i t e ( np . u i n t 1 6 ( p l s b ) ) # Wr i t e LSB r e g i s t e r
vbase . s eek ( p r eg_add r +4) # P l a c e t h e c u r s o r a t MSB r e g i s t e r p o s i t i o n
vbase . w r i t e ( np . u i n t 1 6 ( pmsb ) ) # Wr i t e MSB r e g i s t e r
B Designed software 43
vbase . s eek ( p r eg_add r +6) # P l a c e t h e c u r s o r a t phase r e g i s t e r p o s i t i o n
vbase . w r i t e ( np . u i n t 1 6 ( ppreg ) ) # Wr i t e phase r e g i s t e r
vbase . s eek ( p r eg_add r +8) # P l a c e t h e c u r s o r a t e x i t r e g i s t e r p o s i t i o n
vbase . w r i t e ( np . u i n t 1 6 ( p ex t ) ) # Wr i t e e x i t r e g i s t e r
vbase . s eek ( p r eg_add r +10) # P l a c e t h e c u r s o r a t c o n f i g u r e r e g i s t e r p o s i t i o n
vbase . w r i t e ( np . u i n t 1 6 (0 x0000 ) ) # Wr i t e c o n f i g u r e r e g i s t e r
#End f u n c t i o n
# Def ine FFT f u n t i o n
de f f a s t f t ( p s t a r t _ t im e , pADC_addr , p f bk r ) :
# Read 1024 samples and s t o r e them in memory
N = 1024 # number o f samples
ADC1 = [ None ]∗N # P r e a l l o c a t e l i s t s w i th 1024 "None "
ADC0 = [ None ]∗N
index = [ None ]∗N
f o r c i n r ange ( 0 ,N) :
vbase . s eek ( pADC_addr ) # p l a c e t h e c u r s o r a t CH0 p o s i t i o n
vbase . w r i t e ( ch r (0 x0000 ) ) # s t a r t ADC conv e r s i o n
vbase . s eek ( pADC_addr ) # look CH0
ADC0[ c ] = l i s t ( unpack ( ’ I ’ , vbase . r e ad ( 4 ) ) ) [ 0 ] # Read channe l 0
vbase . s eek ( pADC_addr + 4) # look CH1 ( ch 1 x 4 = 4)
ADC1[ c ] = l i s t ( unpack ( ’ I ’ , vbase . r e ad ( 4 ) ) ) [ 0 ] # Read channe l 1
# p r i n t ( ’ADC0: ’ ,ADC0[ c ] , ’ADC1: ’ , ADC1[ c ] )
# C a l c u l a t e t h e FFT and c o n v e r t a r r a y t o l i s t
ftADC0 = l i s t ( np . f f t . f f t (ADC0) ) # pe r f o rms FFT wi th numpy l i b r a r y
ftADC1 = l i s t ( np . f f t . f f t (ADC1) )
# Sc a l e t h e FFT by d i v i d i n g by N
f o r c i n r ange ( 0 ,N) :
ftADC0 [ c ] = ftADC0 [ c ] /N
ftADC1 [ c ] = ftADC1 [ c ] /N
# De t e c t i n g peaks o f t h e FFT
dcv a l u e s = [ ftADC0 [ 0 ] , ftADC1 [ 0 ] ] # S t o r e t h e DC va l u e s
p r i n t ( ’ d c v a l u e s : ’ , ftADC0 [ 0 ] , ftADC1 [ 0 ] )
d e l ftADC0 [ 0 ] # Remove t h e DC va l u e
d e l ftADC1 [ 0 ] # Remove t h e DC va l u e
# Find max va l u e and index f o r ADC0 ( v i )
maxv0 = ftADC0 [ 0 ]
maxix = 1 # i n i t i a l v a l u e i n c a s e t h e r e i s no max
f o r i i n r ange ( 0 ,N−1) : # (1024 v a l u e s (0 t o 1023) )
i f ( ftADC0 [ i ] > maxv0 ) :
maxv0 = ftADC0 [ i ]
maxix = i
# Ev a l u a t e ADC1 ( vo ) i n t h i s i ndex
maxv1 = ftADC1 [ maxix ] ;
# C a l c u l a t i n g t h e impedance
imp = p fbk r ∗ maxv0 / maxv1
magn = abs ( imp )
ph = phase ( imp )
exec t ime = ( t ime . t ime ( )−s t a r t _ t i m e )
p r i n t ( ’ Magni tude : ’ ,magn , ’ Phase : ’ , ph , ’ Time : ’ , e xec t ime )
p r i n t ( ’max0 ’ , abs ( maxv0 ) , ’max1 ’ , abs ( maxv1 ) , ’ Rfbk ’ , p f bk r )
# Save impedance t o a f i l e
myFi le = open ( ’ impedance . t x t ’ , ’ a ’ ) # open a f i l e f o r append ing
myFi le . w r i t e ( s t r ( exec t ime ) + ’ ’+ s t r ( imp ) + ’ \ n ’ )
B Designed software 44
myFi le . c l o s e ( )
# Save magn i tude t o a f i l e
myFi le = open ( ’ magn i tude . t x t ’ , ’ a ’ ) # open a f i l e f o r append ing
myFi le . w r i t e ( s t r ( exec t ime ) + ’ ’+ s t r ( magn ) + ’ \ n ’ )
myFi le . c l o s e ( )
# Save phase t o a f i l e
myFi le = open ( ’ phase . t x t ’ , ’ a ’ ) # open a f i l e f o r append ing
myFi le . w r i t e ( s t r ( exec t ime ) + ’ ’+ s t r ( ph ) + ’ \ n ’ )
myFi le . c l o s e ( )
r e t u r n ( exec t ime , imp )
#End f u n c t i o n
# / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / /
# / / Programming DDS R e g i s t e r s
# / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / /
p r i n t ( ’ ∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗ \ n \ n ’ )
p r i n t ( ’ En t e r t h e v a l u e i n Ohm of t h e f e edback r e s i s t o r : \ n ’ )
t r y :
f b k r = i n t ( r aw_ inpu t ( ’ R e s i s t o r : ’ ) )
e x c e p t Va l u eE r r o r :
p r i n t ( ’ Not a number ’ )
p r i n t ( ’ ∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗ \ n \ n ’ )
p r i n t ( ’ S e l e c t an o p e r a t i o n mode : \ n ’ )
p r i n t ( ’ 1 . S i n g l e f r e qu en cy \ n ’ )
p r i n t ( ’ 2 . F requency sweep \ n ’ )
t r y :
mod= i n t ( r aw_ inpu t ( ’Mode : ’ ) )
e x c e p t Va l u eE r r o r :
p r i n t ( ’ Not a number ’ )
p r i n t ( ’ ∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗ \ n \ n ’ )
p r i n t ( ’ S e l e c t t h e waveform : \ n ’ )
p r i n t ( ’ 1 . S i n u s o i d a l \ n ’ )
p r i n t ( ’ 2 . T r i a n g u l a r \ n ’ )
p r i n t ( ’ 3 . Square \ n \ n ’ )
t r y :
wf= i n t ( r aw_ inpu t ( ’Wafeform : ’ ) )
e x c e p t Va l u eE r r o r :
p r i n t ( ’ Not a number ’ )
i f (mod == 1) :
p r i n t ( ’ ∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗ \ n \ n ’ )
p r i n t ( ’ En t e r t h e v a l u e o f f r e qu en cy i n Hz : \ n \ n ’ )
t r y :
fq= i n t ( r aw_ inpu t ( ’ F requency : ’ ) )
e x c e p t Va l u eE r r o r :
p r i n t ( ’ Not a number ’ )
p r i n t ( ’ ∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗∗ \ n \ n ’ )
p r i n t ( ’ En t e r t h e phase s h i f t i n d e g r e e s ( from 0 t o 359 d eg r e e s ) : \ n \ n ’ )
t r y :
p s h i f t = i n t ( r aw_ inpu t ( ’ Phase s h i f t : ’ ) )
B Designed software 45
ex c ep t Va l u eE r r o r :
p r i n t ( ’ Not a number ’ )
d d s _w r i t e ( wf , fq , p s h i f t , r e g_ add r )
# Se t a t ime r f o r program ex e c u t i o n
s t a r t _ t i m e = t ime . t ime ( )
wh i l e 1 :
( exctmp , mimp ) = f a s t f t ( s t a r t _ t i m e , ADC_addr , f b k r )
e l s e :
p s h i f t = 0
B = 1250 #125
FQ = [ None ]∗B
Tmp = [ None ]∗B
Imp = [ None ]∗B
#Beging a new r e a d i n g
myFi le = open ( ’ impedance . t x t ’ , ’ a ’ ) # open a f i l e f o r append ing
myFi le . w r i t e ( ’ Feedback R e s i s t o r : ’+ s t r ( f b k r ) + ’ \ n ’ )
myFi le . c l o s e ( )
myFi le = open ( ’ magn i tude . t x t ’ , ’ a ’ ) # open a f i l e f o r append ing
myFi le . w r i t e ( ’ Feedback R e s i s t o r : ’+ s t r ( f b k r ) + ’ \ n ’ )
myFi le . c l o s e ( )
myFi le = open ( ’ phase . t x t ’ , ’ a ’ ) # open a f i l e f o r append ing
myFi le . w r i t e ( ’ Feedback R e s i s t o r : ’+ s t r ( f b k r ) + ’ \ n ’ )
myFi le . c l o s e ( )
# Se t a t ime r f o r program ex e c u t i o n
s t a r t _ t i m e = t ime . t ime ( )
f o r j i n r ange ( 1 ,B) :
fq = 100∗ j
d d s _w r i t e ( wf , fq , p s h i f t , r e g_ add r )
( exctmp , mimp ) = f a s t f t ( s t a r t _ t i m e , ADC_addr , f b k r )
FQ[ j ] = fq
Tmp[ j ] = exctmp
Imp [ j ] = abs (mimp )
p r i n t ( ’ Impedance : ’ , Imp [ j ] , ’ Freq : ’ , f q )
# P l o t t h e magn i tude
p l t . f i g u r e ( 1 , f i g s i z e = ( 4 , 3 ) , dp i =90) # f i g u r e o f 4x3 i n c h e s a t 90 dp i
p l t . p l o t (FQ , abs ( Imp ) )
p l t . x l a b e l ( ’ F requency ’ , f o n t s i z e =14)
p l t . y l a b e l ( ’ Magni tude ’ , f o n t s i z e =14)
p l t . g r i d ( True )
p l t . l e g end ( )
p l t . show ( )
# P l o t t h e phase
p l t . f i g u r e ( 2 , f i g s i z e = ( 4 , 3 ) , dp i =90) # f i g u r e o f 4x3 i n c h e s a t 90 dp i
p l t . p l o t (FQ , phase ( Imp ) )
p l t . x l a b e l ( ’ F requency ’ , f o n t s i z e =14)
p l t . y l a b e l ( ’ Phase ’ , f o n t s i z e =14)
p l t . g r i d ( True )
p l t . l e g end ( )
p l t . show ( )
B Designed software 46
B.2 Verilog code for serial protocol
This code is intended to take the stimulation parameters generated by the preview Python code, and
write the internal registers of the Programable Waveform Generator, AD9833, by serial protocol.
module s e r d d s ( c lk50 , c lk25 , s t a r t , c o n t r o l , l s b f r e q , msbfreq , phase , ex t , s d a t a , f sync , s c l k ) ;
i n p u t c l k50 ;
i n p u t c l k25 ;
i n p u t s t a r t ;
i n p u t [ 1 5 : 0 ] c o n t r o l ; / / Con t r o l R e g i s t e r
i n p u t [ 1 5 : 0 ] l s b f r e q ; / / LSB Frequency R e g i s t e r
i n p u t [ 1 5 : 0 ] msbf req ; / /MSB Frequency R e g i s t e r
i n p u t [ 1 5 : 0 ] phase ; / / Phase R e g i s t e r
i n p u t [ 1 5 : 0 ] e x t ; / / E x i t R e g i s t e r
o u t p u t s d a t a ; / / Data t o be t r a n sm i t e d
o u t p u t f s yn c ; / / Enab l e s o r d e s a b l e s t h e t r a n sm i t i o n
o u t p u t s c l k ; / / P r o t o c o l Clock
r eg coun t2 ; / / Keeps t h e s d a t a b i t s f o r two p e r i o d s o f c l o ck
r eg [ 2 : 0 ] coun t4 ; / / Time beetwen t r a n sm i t i o n s
r eg [ 2 : 0 ] coun t5 ; / / S t o r e s t h e coun t o f sended r e g i s t e r s
r eg [ 3 : 0 ] coun t15 ; / / S t o r e s t h e coun t o f sended s d a t a b i t s
r eg [ 7 9 : 0 ] e n ab l e ; / / Enab l e s t h e SCLK du r i n g t r a n sm i t i o n s
r eg [ 1 5 : 0 ] t empda t a ; / / Data t o be t r a n sm i t t e d
r eg temsync ; / / ~Fsync
always@ ( negedge c lk50 )
beg in
i f ( s t a r t )
b eg in
coun t2 <= 1 ’ b0 ;
coun t4 <= 3 ’ b000 ;
coun t5 <= 3 ’ b000 ;
coun t15 <= 4 ’ b0000 ;
t empda t a <= 16 ’ h0000 ;
temsync <= 1 ’ b0 ;
e n ab l e <= 80 ’ hFFFFFFFFFFFFFFFFFFFF ; / / Wr i t e 80 ’ b i n 1 as e n ab l e r e g i s t e r
end
e l s e
beg in
i f ( coun t5 < 3 ’ b101 )
beg in
i f ( c l k25 && enab l e [ 7 9 ] && coun t15 ==4 ’ b0000 && coun t2 ==1 ’ b0 )
beg in
temsync <= 1 ;
B Designed software 47
c a s e ( coun t5 )
3 ’ b000 : / / Con t r o l R e g i s t e r
t empda t a <= c o n t r o l ;
3 ’ b001 : / / LSB Frequency R e g i s t e r
t empda t a <= l s b f r e q ;
3 ’ b010 : / / MSB Frequency R e g i s t e r
t empda t a <= msbf req ;
3 ’ b011 : / / Phase R e g i s t e r
t empda t a <= phase ;
3 ’ b100 : / / E x i t R e g i s t e r
t empda t a <= ex t ;
endca se
end
e l s e
beg in
i f ( coun t15 == 4 ’ b1111 && coun t2 == 1 ’ b1 )
beg in
temsync <= 0 ;
i f ( coun t4 == 3 ’ b100 )
beg in
coun t5 <= coun t5 + 3 ’ b001 ;
coun t2 <= 1 ’ b0 ;
coun t4 <= 3 ’ b000 ;
coun t15 <= 4 ’ b000 ;
end
e l s e
beg in
coun t4 <= coun t4 + 3 ’ b001 ;
end
end
e l s e
beg in
i f ( temsync == 1)
beg in
i f ( coun t2 == 1 ’ b1 )
beg in
t empda t a <= tempda t a << 1 ;
e n ab l e <= en ab l e << 1 ;
coun t15 <= coun t15 + 16 ’ h0001 ;
coun t2 <= 1 ’ b0 ;
end
e l s e
beg in
t empda t a <= tempda t a ;
coun t2 <= coun t2 + 1 ’ b1 ;
end
B Designed software 48
end
e l s e
beg in
temsync <= temsync ;
end
end
end
end
e l s e
beg in
temsync <= 1 ’ b0 ;
e n ab l e <= 80 ’ h00000000000000000000 ; / / Desab le SCLK
end
end
end
a s s i g n s c l k = c lk25 && enab l e [ 7 9 ] ;
a s s i g n f s yn c = ~ temsync ;
a s s i g n s d a t a = t empda t a [ 1 5 ] ;
endmodule
49
Appendix C
PCB design
C.1 First prototype
Figure C.1 shows the schematic for the first design. This design include many test pins and stage
jumpers for internal analysis of the device.
C PCB design 50
Figure C.1: Electric diagram of the first prototype.
C PCB design 51
Figure C.2 shows the PCB layout for the first implementation.
Figure C.2: PCB design of the first prototype.
C PCB design 52
C.2 Second prototype
A second device was design to incorporate external ADCs with faster sampling rates for achieving a
higher bandwidth, this design eliminates the test pins and stage jumpers included in the first device.
However, due to time constraints and delays in the fabrication of the PCB the system was not tested.
The AD9225 is an ADC that accomplish the circuit requirements, it has 12 bits of resolution,
sample ratio of 25 MSPS and SHA at the input, allowing voltage resolution below 1 mV and input
signal frequencies above 125 kHz. Figure C.3 shows its electric diagram, the external circuitry
configures the IC for accept signals with ground reference in a range of 2 Vpp.
Figure C.3: Electric diagram of the ADC
Sub-systems for signal generation and data acquisition are the same as the designed in the first
prototype. Figure C.4 shows the schematic for the second design.
C PCB design 53
Figure C.4: Electric diagram of the second prototype.
C PCB design 54
Figure C.5 shows the PCB layout for the second implementation.
Figure C.5: PCB design of the second prototype.
55
Appendix D
Cost and size characteristics
The cost by components, as well as the total cost of the designed device is showed in Table D.1.
Table D.1: Manufacturing cost.
Component Quantity Price (e)
DE0-Nano-Soc 1 91
OPA2836 2 7.12
TL7660 1 1.19
AD9833 1 8.34
Capacitors 19 0.2882
Resistor 11 0.1669
Variable
resistor
1 2.28
PCB 1 50
Total 160.38
Finally the device dimensions are: 10x7x5 cm.
