AN85951 PSoC™ 4 and PSoC™ 6 MCU CAPSENSE™ design guide
About this document
Scope and purpose
The CAPSENSE™ design guide explains how to design capacitive touch sensing applications with the CAPSENSE™ feature in PSoC™ 4 and PSoC™ 6 MCU device families. The CAPSENSE™ feature offers unprecedented signal-to-noise ratio (SNR), best-in-class liquid tolerance, and a wide variety of sensors such as buttons, sliders, touchpads, and proximity sensors. This design guide explains the CAPSENSE™ operation, CAPSENSE™ design tools, performance tuning of the PSoC™ Creator and ModusToolbox™ CAPSENSE™ component and design considerations. This guide also introduces Fifth Generation CAPSENSE™ technology which has several advantages over the previous generation devices.
Different device families are available with CAPSENSE™ feature. If you have not chosen a particular device, or are new to capacitive sensing, see the Getting started with CAPSENSE™ design guide. It helps you understand the advantages of CAPSENSE™ over mechanical buttons, CAPSENSE™ technology fundamentals, and to select the right device for your application. It also directs you to the right documentation, kits, or tools to help with your design.
Intended audience
This document is primarily intended for engineers who need to become familiar with the CAPSENSE™ design principles of PSoC™ 4 and PSoC™ 6 MCU devices.
Introduction
Overview
Capacitive touch sensors are user interface devices that use human body capacitance to detect the presence of a finger on or near a sensor.CAPSENSE™ solutions bring elegant, reliable, and easy-to-use capacitive touch sensing functionality to your product.
This design guide focuses on the CAPSENSE™ feature in the PSoC™ 4 and PSoC™ 6 MCU families of devices. These are true programmable embedded system-on-chip, integrating configurable analog and digital peripheral functions, memory, radio, and a microcontroller on a single chip. These devices are highly flexible and can implement many functions such as ADC, DAC, and Bluetooth® LE in addition to CAPSENSE™, which accelerates time-to-market, integrates critical system functions, and reduces overall system cost.
This guide assumes that you are familiar with developing applications for PSoC™ 4 and PSoC™ 6 MCU using the PSoC™ Creator integrated design environment (IDE). If you are new to PSoC™ 4, see AN79953 - Getting started with PSoC™ 4 or AN91267 - Getting started with PSoC™ 4 Bluetooth® LE. If you are new to PSoC™ 6 MCU, see AN221774 – Getting started with PSoC™ 6 MCU and AN210781 - Getting started with PSoC™ 6 MCU with Bluetooth® LE connectivity. If you are new to PSoC™ Creator, see the PSoC™ Creator home page.
If you are new to ModusToolbox™, see ModusToolbox™ IDE quick start guide.
This design guide helps you understand:
-
CAPSENSE™ technology in PSoC™ 4 and PSoC™ 6 MCU
-
Design and development tools available for PSoC™ 4 and PSoC™ 6 MCU PSoC™ 6 MCU CAPSENSE™
-
PSoC™ 6 MCU CAPSENSE™ PCB layout guidelines for PSoC™ 4 and PSoC™ 6 MCU
-
Performance tuning of PSoC™ 4 and PSoC™ 6 MCU CAPSENSE™ component
-
Applications using CAPSENSE™ Plus features such as motor control systems and induction cookers
CAPSENSE features
CAPSENSE™ in PSoC™ 4 and PSoC™ 6 MCU has the following features:
-
Supports self-capacitance (CSD) and mutual-capacitance (CSX) based touch sensing on all CAPSENSE™-capable GPIO pins1
-
Provides the best-in-class signal-to-noise ratio (SNR), allowing high sensitivity that provides high-range proximity sensing (up to a 30-cm proximity-sensing distance) and liquid-tolerant operation (see Liquid tolerance)
-
High-performance sensing across a variety of overlay materials and varied thickness (see CAPSENSE™ fundamentals, Overlay material, and Overlay thickness)
-
SmartSense auto-tuning technology
-
Pseudo random sequence (PRS) clock source, supports spread spectrum and programmable resistance switches for lower electromagnetic interference (EMI)
-
Low power consumption with as low as 1.71-V operation and as low as 150-nA current consumption in Hibernate mode
The PSoC™ 4100S Max device introduces the fifth-generation CAPSENSE™ technology (Ratiometric sensing technology) and has the following additional features when compared to older generations:
-
Improved SNR: Fifth-generation CAPSENSE™ technology (Ratiometric sensing technology) significantly improves noise performance compared to previous generation devices
-
Improved refresh rate: The better sensitivity of multi sense converter (MSC) requires less time to get a similar signal as in previous generations; therefore, it is able to achieve a higher refresh rate. The two independent MSC blocks, which can scan the sensors in parallel improve the refresh rate further especially in use cases where large numbers of sensors need to be scanned
-
Improved CPU bandwidth: Scan supported in both CPU mode and DMA mode. The CPU mode is a conventional interrupt-driven mode, while the DMA mode is capable of autonomous scanning which reduces the CPU bandwidth requirement to 18% compared to previous generations
-
Improved noise immunity: Rail-to-rail swing is used as sense voltage, which provides maximum sense voltage and better immunity. In the fifth-generation CAPSENSE™ technology, full-wave differential sensing is used for self-capacitance sensing and this cancels out noise induced from the external environment to the sensor routings. This sensing technology is also better immune to power supply (Vdd) noise
The PSoC™ 4000T device is a member of the PSoC™ 4 MCU family with fifth-generation CAPSENSE™ and multi-sense technology. It offers an ultra-low power touch HMI solution, based on an integrated “Always-On” sensing technology, improved performance to enable modern sleek user interface solutions with superior liquid tolerance, and robust and reliable touch HMI solutions for harsh environments.
PSoC 4 and PSoC 6 MCU CAPSENSE Plus features
You can create PSoC™ 4 CAPSENSE™ Plus applications that feature capacitive touch sensing and additional system functionality. The key features of these devices, in addition to CAPSENSE™ are:
-
Arm®Cortex®-M0/M0+ CPU with single cycle multiply delivering up to 43 DMIPS at 48 MHz
-
1.71 V – 5.5 V operation over –40 to 85°C ambient
-
Up to 128 KB of flash (CM0+ has > 2X code density over 8-bit solutions)
-
Up to 16 KB of SRAM
-
Up to 94 programmable GPIOs
-
Independent center-aligned PWMs with complementary dead-band programmable outputs, synchronized ADC operation (ability to trigger the ADC at a customer-specifiable time in the PWM cycle), and synchronous refresh (ability to synchronize PWM duty cycle changes across all PWMs to avoid anomalous waveforms)
-
Comparator-based triggering of PWM Kill signals (to terminate motor-driving when an over-current condition is detected)
-
12-bit 1 Msps ADC including sample-and-hold (S&H) capability with zero-overhead sequencing allowing the entire ADC bandwidth to be used for signal conversion and none used for sequencer overhead
-
Opamps with comparator mode and SAR input buffering capability
-
Segment LCD direct drive that supports up to four commons
-
SPI/UART/I2C serial communication channels
-
Bluetooth® LE communication compliant with version 4.0 and multiple features of version 4.1
-
Programmable logic blocks, each having eight macrocells and a cascadable data path, called universal digital blocks (UDBs) for efficient implementation of programmable peripherals (such as I2S)
-
Controller area network (CAN)
-
Fully-supported PSoC™ Creator design entry, development, and debug environment providing:
- Design entry and build (comprehending analog routing)
- Components for all fixed-function peripherals and common programmable peripherals
- Documentation and training modules
-
Support for porting builds to MDK Arm® environment (previously known as RealView) and others
-
Support for Eclipse integrated development environment (IDE) for ModusToolbox™
The main features of PSoC™ 6 MCU device, in addition to CAPSENSE™ are:
-
Single CPU devices (Arm® Cortex® -M4), dual CPU devices (Arm® Cortex®-M4 and Cortex®-M0+). Support for inter-processor communication in hardware
-
1.71 V - 3.6 V device operating voltage with user selectable core logic operation at either 1.1 V or 0.9 V
-
Up to 2 MB of flash memory and up to 1 MB of SRAM
-
Up to 78 GPIOs that can be used for analog, digital, CAPSENSE™, or segment LCD functions
-
Programmable analog blocks: Two opamps, configurable PGAs, comparators, 12-bit 1 Msps SAR ADC, 12 -bit voltage mode DAC
-
Programmable digital blocks, communication interfaces
-
12 UDBs, 32 TCPWMs configurable as 16-bit/32-bit timer, counter, PWM, or quadrature decoder
-
Up to 13 serial communication block (SCB) configurable as I2C, SPI, or UART interfaces. See the Device datasheet for more details
-
Audio subsystem with one I2S interface and two PDM channels
-
SMIF interface with support for execute-in-place from external quad SPI flash memory and on-the-fly encryption and decryption
-
Bluetooth® Smart connectivity with Bluetooth® LE 5.0 (applicable only to PSoC™ 6 MCU with Bluetooth® LE family of devices)
See AN64846 - Getting started with CAPSENSE™ to select an appropriate CAPSENSE™ device based on your requirements.
CAPSENSE design flow
Figure 1 illustrates the product design cycle with capacitive sensing; the information in this guide is highlighted in green. provides links to the supporting documents for each of the numbered tasks in Figure 1.
Steps in flowchart | Supporting documentation | |
---|---|---|
Name | Chapter | |
| CAPSENSE™ design guide (This document) Getting started with CAPSENSE™ | CAPSENSE™ technology and PSoC™ 4 and PSoC™ 6 MCU CAPSENSE™ – |
| Getting started with CAPSENSE™ | – |
| PSoC™ 4 datasheet PSoC™ 4 Bluetooth® LE datasheet PSoC™ 6 MCU datasheet | – |
AN64846 – Getting started with CAPSENSE™ design guide AN79953 – Getting started with PSoC™ 4 AN91267 – Getting started with PSoC™ 4 Bluetooth® LE AN221774 – Getting started with PSoC™ 6 MCU | – | |
| CAPSENSE™ design guide (This document) | Design considerations |
| CAPSENSE™ design guide (This document) | Design considerations |
| PSoc™ CAPSENSE™ Component datasheet/middleware document | – |
CAPSENSE™ design guide (This document) | CAPSENSE™ performance tuning | |
| PSoc™ CAPSENSE™ design guide (This document) | CAPSENSE™ performance tuning |
| PSoC™ Component datasheet/middleware document | – |
PSoC™ Creator Example projects Download ModusToolbox™ here. See the ModusToolbox™ related documents: ModusToolbox™ release notes ModusToolbox™ user guide ModusToolbox™ quick start guide ModusToolbox™ CAPSENSE™ configurator guide ModusToolbox™ CAPSENSE™ tuner guide PSoC™ Creator to ModusToolbox™ porting guide | – | |
| PSoC™ Creator user guide for in-IDE programming PSoC™ Programmer home page and MiniProg3 user guide for standalone programming | – |
| – | – |
| CAPSENSE™ design guide (This document) | CAPSENSE™ performance tuning |
| – | – |
CAPSENSE technology
Capacitive touch sensing technology measures changes in capacitance between a plate (the sensor) and its environment to detect the presence of a finger on or near a touch surface.
CAPSENSE fundamentals
A typical CAPSENSE™ sensor consists of a copper pad of proper shape and size etched on the surface of a PCB. A non-conductive overlay serves as the touch surface for the button, as Figure 2 shows.
CAPSENSE™ also requires external capacitor CMOD or CINT for self-capacitance sensing and mutual-capacitance sensing. For third- and fourth-generation CAPSENSE™ architecture, a single CMOD capacitor is required for self-capacitance sensing and CINTA and CINTB capacitors for mutual-capacitance sensing. If shield electrode is implemented for liquid tolerance, or for large proximity sensing distance, an additional CTANK capacitor may be required. For Fifth-Generation CAPSENSE™ architecture, two CMOD capacitors are required for both self-capacitance and mutual-capacitance sensing for each channel. These external capacitors are connected between a dedicated GPIO pin and ground. Table 38 list the recommended values of the external capacitors.
The capacitance of the sensor in the absence of a touch is called the parasitic capacitance, CP. CP results from the electric field between the sensor (including the sensor pad, traces, and vias) and other conductors in the system such as the ground planes, traces, and any metal in the product’s chassis or enclosure. The GPIO and internal capacitances of PSoC™ also contribute to the parasitic capacitance. However, these internal capacitances are typically very small compared to the sensor capacitance.
Self-capacitance sensing
Figure 4 shows how a GPIO pin is connected to a sensor pad by traces and vias for self-capacitance sensing. Typically, a ground (GND) hatch surrounds the sensor pad to isolate it from other sensors and traces. Although Figure 4 shows some field lines around the sensor pad, the actual electric field distribution is very complex.
When a finger is present on the overlay, the conductive nature and large mass of the human body forms a grounded, conductive plane parallel to the sensor pad, as Figure 5 shows.
This arrangement forms a parallel plate capacitor. The capacitance between the sensor pad and the finger is shown in Equation 1.
Where:
ε0 = Free space permittivity
εr = Relative permittivity of overlay
A = Area of finger and sensor pad overlap
d = Thickness of the overlay
CF = Finger capacitance.
CP and CF are parallel to each other because both represent the capacitance between the sensor pin and ground. Therefore, the total capacitance CS of the sensor, when the finger is present on the sensor, is the sum of CP and CF.
In the absence of touch, CS is equal to CP.
PSoC™ converts the capacitance CS into equivalent digital counts called raw counts. Because a finger touch increases the total capacitance of the sensor pin, an increase in the raw counts indicates a finger touch. Refer to the CSD specification in Device datasheet/Component datasheet/middleware document document to learn about the supported CP range for a given device with which the recommended SNR can be achieved.
Mutual-capacitance sensing
Figure 8 shows the button sensor layout for mutual-capacitance sensing. Mutual-capacitance sensing measures the capacitance between two electrodes, transmit (Tx) electrode and receive (Rx) electrode.
In a mutual-capacitance sensing system, a digital voltage signal switching between VDDIO 2 or VDDD3 (if VDDIO is not supported by the device) and GND is applied to the Tx pin and the amount of charge received on the Rx pin is measured. The amount of charge received on the Rx electrode is directly proportional to the mutual-capacitance (CM) between the two electrodes.
When a finger is placed between the Tx and Rx electrodes, the mutual-capacitance decreases to C1 M , as shown in Figure 9. Because of the reduction in the mutual-capacitance, the charge received on the Rx electrode also decreases. The CAPSENSE™ system measures the amount of charge received on the Rx electrode to detect a touch/no touch condition.
Capacitive touch sensing method
PSoC™ uses patented capacitive touch-sensing method CAPSENSE™ sigma delta (CSD) for self-capacitance sensing and CAPSENSE™ crosspoint (CSX) for mutual-capacitance scanning. The CSD and CSX touch sensing methods provide the industry’s best-in-class Signal-to-noise ratio (SNR). These sensing methods are a combination of hardware and firmware techniques.
CAPSENSE sigma delta (CSD)
Figure 11 shows a simplified block diagram of the CSD method.
In CSD, each GPIO has a switched-capacitance circuit that converts Cs into an equivalent current. An analog MUX (AMUX) selects one of the sensor currents and feeds it into the current to digital converter. The current to digital converter is similar to a delta sigma ADC. The output count of the current to digital converter, known as raw count, is a digital value that is proportional to the self-capacitance between the electrodes.
Where,
GCSD = Capacitance to digital conversion gain of CSD
CS = Self-capacitance of the electrode
Figure 14 illustrates a plot of raw count over time. When a finger touches the sensor, the CS increases from CP to CP + CF, and the raw count increases. By comparing the change in raw count to a predetermined threshold, logic in firmware decides whether the sensor is active (finger is present).
CAPSENSE crosspoint (CSX)
Figure 12 shows the simplified block diagram of the CSX method.
With CSX, a voltage on the Tx electrode couples charge on to the RX electrode. This charge is proportional to the mutual capacitance between the Tx and Rx electrodes. An analog MUX then selects one of the Rx electrodes and feeds it into the current to digital converter.
The output count of the current to digital converter,
, is a digital value that is proportional to the mutual-capacitance between the Rx and Tx electrodes as shown in
Figure 13
.
Where,
GC SX = Capacitance to digital conversion gain of mutual capacitance method
CM = Mutual-capacitance between two electrodes
Figure 14 illustrates a plot of raw count over time. When a finger touches the sensor, CM decreases from CM to C1 M (see Figure 9) hence the counter output decreases. The firmware normalizes the raw count such that the raw counts go high when CM decreases. This maintains the same visual representation of raw count between CSD and CSX methods. By comparing the change in raw count to a predetermined threshold, logic in firmware decides whether the sensor is active (finger is present). The normalized inverted raw count is computed using Figure 58.
Signal-to-noise ratio (SNR)
In practice, the raw counts vary due to inherent noise in the system.CAPSENSE™ noise is the peak-to-peak variation in raw counts in the absence of a touch, as Figure 15 shows.
A well-tuned CAPSENSE™ system reliably discriminates between the ON and OFF states of the sensors. To achieve good performance, the CAPSENSE™ signal must be significantly larger than the CAPSENSE™ noise. SNR is defined as the ratio of CAPSENSE™ signal to CAPSENSE™ noise is the most important performance parameter of a CAPSENSE™ sensor.
In this example, the average level of raw count in the absence of a touch is 5925 counts. When a finger is placed on the sensor, the average raw count increases to 6060 counts, which means the signal is 6060– 5925 = 135 counts. The minimum value of the raw count in the OFF state is 5912 and the maximum value is 5938 counts. Therefore, the CAPSENSE™ noise is 5938 – 5912 = 26 counts. This results in an SNR of 135/26 = 5.2.
The minimum SNR recommended for a CAPSENSE™ sensor is 5. This 5:1 ratio comes from best practice threshold settings, which enable enough margin between signal and noise in order to provide reliable ON/OFF operation.
CAPSENSE widgets
CAPSENSE™ widgets consist of one or more CAPSENSE™ sensors, which as a unit represent a certain type of user interface. CAPSENSE™ widgets are broadly classified into four categories – buttons (zero-dimensional), sliders (one-dimensional), touchpads/trackpads (two-dimensional), and proximity sensors (three-dimensional). Figure 16 shows button, slider, and proximity sensor widgets. This section explains the basic concepts of different CAPSENSE™ widgets. For a detailed explanation of sensor construction, see Sensor construction.
Buttons (zero-dimensional)
CAPSENSE™ buttons replace mechanical buttons in a wide variety of applications such as home appliances, medical devices, white goods, lighting controls, and many other products. It is the simplest type of CAPSENSE™ widget, consisting of a single sensor. A CAPSENSE™ button gives one of two possible output states: active (finger is present) or inactive (finger is not present). These two states are also called ON and OFF states, respectively.
For the self-capacitance (CSD) sensing method, a simple CAPSENSE™ button consists of a circular copper pad connected to a PSoC™ GPIO with a PCB trace. The CAPSENSE™ button is surrounded by grounded copper hatch that isolates it from other buttons and traces. A circular gap separates the button pad and the ground hatch. Each button requires one PSoC™ GPIO. These buttons can be constructed using any conductive material on a non-conductive substrate; for example, indium tin oxide on a glass substrate, or silver ink on a non-conductive film. Even metallic springs can be used as button sensors; see Sensor construction for more details.
For the mutual-capacitance (CSX) sensing method, each button requires one GPIO pin configured as Tx electrode and one GPIO pin configured as Rx electrode.The Tx pin and Rx pins can be shared across multiple buttons, with each button being a unique intersection of Rx and Tx like in Figure 18.However, it is recommended to minimize the Rx trace length and shield the Rx trace with ground on both sides, to minimize noise coupling into the Rx.
If the application requires many buttons (for example in a calculator keypad or a QWERTY keyboard), you can arrange the CAPSENSE™ buttons in a matrix, as Figure 19 shows. This allows a design to have multiple buttons per GPIO. For example, the 16-button design in Figure 19 requires only eight GPIOs.
A matrix button design has two groups of capacitive sensors: row sensors and column sensors. The matrix button architecture can be used for both self-capacitance (CSD) and mutual-capacitance (CSX) methods.
In CSD mode, each button consists of a row sensor and a column sensor, as Figure 19 shows. When a button is touched, both row and column sensors of that button become active. The CSD-based matrix button should be used only if the user is expected to touch one button at a time. If the user touches more than one diagonally opposite buttons, the finger location cannot be resolved as Figure 20 shows. This effect is called as ghost effect, which is considered an invalid condition.
Mutual-capacitance is the recommended sensing method for matrix buttons because this method is not affected from the ghost touch phenomena and provides better SNR for high Cp sensors. This is because it senses mutual-capacitance formed at each intersection rather than sensing rows and columns as shown in Figure 21. Applications that require simultaneous sensing of multiple buttons, such as a keyboard with Shift, Ctrl, and Alt keys can use CSX sensing method or you should design the Shift, Ctrl, and Alt keys as individual CSD buttons.
Sliders (one-dimensional)
Sliders are used when the required input is in the form of a gradual increment or decrement. Examples include lighting control (dimmer), volume control, graphic equalizer, and speed control. Currently, the CAPSENSE™ Component in PSoC™ Creator and ModusToolbox™ supports only self-capacitance-based sliders. Mutual capacitance-based sliders will be supported in future version of component.
A slider consists of a one-dimensional array of capacitive sensors called segments, which are placed adjacent to one another. Touching one segment also results in partial activation of adjacent segments. The firmware processes the raw counts from the touched segment and the nearby segments to calculate the position of the geometric center of the finger touch, which is known as the centroid position.
The actual resolution of the calculated centroid position is much higher than the number of segments in a slider. For example, a slider with five segments can resolve at least 100 physical finger positions. This high resolution gives smooth transitions of the centroid position as the finger glides across a slider.
In a linear slider, the segments are arranged inline, as Figure 22 shows. Each slider segment connects to a PSoC™ GPIO. A zigzag pattern (double chevron) is recommended for slider segments. This layout ensures that when a segment is touched, the adjacent segments are also partially touched, which aids estimation of the centroid position.
Radial sliders are similar to linear sliders except that radial sliders are continuous. Figure 23 shows a typical radial slider.
Touchpads/Trackpads (two-dimensional)
A touchpad (also known as trackpad) has two linear sliders arranged in an X and Y pattern, enabling it to locate a finger’s position in both X and Y dimensions. Figure 24 shows a typical arrangement of a touchpad sensor. Similar to the matrix buttons, touchpads can also be sensed using either CSD or CSX sensing method.
CSD-based touchpads suffer from ghost touches, so it supports only single-point touch applications.
CSX touchpads can support multi-point touch applications, but these may need more scanning time compared to CSD touchpad because this method scans each intersection rather than rows and columns.
See AN234185 PSoC™ 4 CAPSENSE™ Touchpad design guide to learn more.
Proximity (three-dimensional)
Proximity sensors detect the presence of a hand in the three-dimensional space around the sensor. However, the actual output of the proximity sensor is an ON/OFF state similar to a CAPSENSE™ button. Proximity sensing can detect a hand at a distance of several centimeters to tens of centimeters depending on the sensor construction. Self capacitance is the recommended method of sensing for a proximity application.
Proximity sensing requires electric fields that are projected to much larger distances than buttons and sliders. This demands a large sensor area. However, a large sensor area also results in a large parasitic capacitance CP, and detection becomes more difficult. This requires a sensor with high electric field strength at large distances while also having a small area. Figure 25 shows a proximity sensor using a trace with a thickness of 2-3 mm surrounding the other sensors.
You can also implement a proximity sensor by ganging other sensors together. This is accomplished by combining multiple sensor pads into one large sensor using firmware. The disadvantage of this method is high parasitic capacitance. See the Component datasheet/middleware document for details on maximum parasitic capacitance supported by a given device.
See AN92239 proximity sensing with CAPSENSE™ and the proximity sensing section in Getting started with CAPSENSE™ design guide to learn more about proximity sensors.
Liquid tolerance
Capacitive sensing is used in a variety of applications such as home appliances, automotive, and industrial applications. These applications require robust capacitive-sensing operation even in the presence of mist, moisture, water, ice, humidity, or other liquids. In a capacitive-sensing application design, false sensing of touch or proximity detection may happen due to the presence of a film of liquid or liquid droplets on the sensor surface, due to the conductive nature of some liquids. CSD sensing method can compensate for variation in raw count due to these causes and provide a robust, reliable, capacitive sensing application operation.
-
To compensate for changes in raw count due to mist, moisture, and humidity changes, the CAPSENSE™ sensing method continuously adjusts the baseline of the sensor to prevent false triggers
-
To prevent sensor false triggers due to a liquid flow, you should implement a Guard sensor as Figure 27 shows. The Driven shield signal and shield electrode can be used to detect the presence of a streaming liquid and ignore the status or stop the sensing from rest of the sensors as long as the liquid flow is present
-
Note: the guard sensor itself is just another self-capacitance sensor; even though you could implement it around mutual-capacitance sensors also for liquid flow tolerance. PSoC™ devices allow implementation of such self-capacitance sensors and mutual-capacitance sensors together in the same design
-
To compensate for changes in raw count due to liquid droplets for self-capacitance sensing, you can implement a Driven shield signal and shield electrode as Figure 27 shows. When a shield electrode is implemented, CAPSENSE™ reliably works and reports the sensor ON/OFF status correctly, even when liquid droplets are present on the sensor surface. To prevent sensor false triggers due to liquid droplets for mutual-capacitance sensing, you can use both the sensing methods that is, mutual capacitance and self-capacitance with Driven shield signal and shield electrode on the same set of sensors as Using self-capacitance sensing for liquid tolerance of mutual-capacitance sensors explains
In summary, if your application requires tolerance to liquid droplets, implement a Driven shield signal and shield electrode. If your application requires tolerance to streaming liquids along with liquid droplets, implement a Driven shield signal and shield electrode and a Guard sensor as shown in Figure 27. Follow the schematic and layout guidelines explained in the Layout guidelines for liquid tolerance section to construct the shield electrode and guard sensor respectively.
Liquid tolerance for self capacitance sensing
Effect of liquid droplets and liquid stream on a self-capacitance sensor
To understand the effect of liquids on a CAPSENSE™ sensor, consider a CAPSENSE™ system in which the hatch fill around the sensor is connected to ground, as Figure 28(a) shows. The hatch fill when connected to a GND improves the noise immunity of the sensor. Parasitic capacitance of the sensor is denoted as CP in Figure 28(b).
As shown in Figure 29, when a liquid droplet falls on the sensor surface, due to its conductive nature it provides a strong coupling path for the electric field lines to return to ground; this adds a capacitance CLD in parallel to CP. This added capacitance draws an additional charge from the AMUX bus as explained in GPIO cell capacitance to current converter resulting in an increase in the sensor raw count. In some cases (such as salty water or water containing minerals), the increase in raw count when a liquid droplet falls on the sensor surface may be equal to the increase in raw count due to a finger touch, as Figure 29 shows. In such a situation, sensor false triggers might occur.
CP = Sensor parasitic capacitance
CLD = Capacitance added by the liquid droplet
To nullify the effect of capacitance added by the liquid droplet to the CAPSENSE™ circuitry, you should drive the hatch fill around the sensor with the driven-shield signal.
As Figure 31 shows, when the hatch fill around the sensor is connected to the driven-shield signal and when a liquid droplet falls on the touch interface, the voltage on both sides of the liquid droplet remains at the same potential. Because of this, the capacitance, CLD, added by the liquid droplet does not draw any additional charge from the AMUX bus and hence the effect of capacitance CLD is nullified. Therefore, the increase in raw count when a water droplet falls on the sensor will be very small, as Figure 32 shows.
CS = Sensor parasitic capacitance
CSH = Capacitance between the sensor and the hatch fill
CHG = Capacitance between the hatch fill and ground
CLD = Capacitance added by the liquid droplet
Figure 30 shows how a sensor may false trigger in presence of a liquid, if hatch fill is connected to ground. Note however, that the same is not true for all cases. For example, spring sensors, which are inherently more liquid tolerant than sensors etched on PCB surface. As Figure 33 shows, due to the large airgap between the liquid drop and the hatch fill, the capacitance CLD between the liquid drop and grounded hatch pattern on the PCB would be very low so as not to cause any false triggers. If required, the hatched pattern on the PCB can still be connected to a driven shield electrode to further nullify the effect of CLD and have an improved liquid tolerance.
Driven shield signal and shield electrode
The driven-shield signal is a buffered version of the sensor-switching signal, as Figure 34 shows. The driven-shield signal has the same amplitude, frequency, and phase as that of sensor switching signal. When the hatch fill around the sensor is connected to the driven shield signal, it is referred as shield electrode.
-
To implement liquid-tolerant CAPSENSE™ designs: Shield electrode helps in making CAPSENSE™ designs liquid-tolerant as explained above
-
To improve proximity sensing distance in presence of floating or grounded conductive objects: A shield electrode, when placed between the proximity sensor and a floating or a grounded conductive object, reduces the effect of these objects on the proximity-sensing distance and helps in achieving large proximity-sensing distance. See the “Proximity Sensing” section in the Getting started with CAPSENSE™ design guide for more details
-
To reduce the parasitic capacitance of the sensor: When a CAPSENSE™ sensor has a long trace, the CP of the sensor will be very high because of the increased coupling of sensor electric field lines from the sensor trace to the surrounding ground. By implementing a shield electrode, the coupling of electric field lines to ground is reduced, which results in reducing the CP of the sensor
See Layout guidelines for shield electrode for layout guidelines of shield electrode.
Guard sensor
When a continuous liquid stream is present on the sensor surface, the liquid stream adds a large capacitance (CST) to the CAPSENSE™ sensor. This capacitance may be several times larger than CLD. Because of this, the effect of the shield electrode is completely masked, and the sensor raw counts will be same as or even higher than a finger touch. In such situations, a guard sensor is useful to prevent sensor false triggers.
A guard sensor is a copper trace that surrounds all the sensors on the PCB, as Figure 35 shows. A guard sensor is similar to a button sensor and is used to detect the presence of streaming liquids. When a guard sensor is triggered, the firmware should disable the scanning of all other sensors except the guard sensor to prevent sensor false triggers.
See Layout guidelines for guard sensor for PCB layout guidelines for implementing a guard sensor.
If there is no space on the PCB for implementing a guard sensor, the guard sensor functionality can be implemented in the firmware. For example, you can use the ON/OFF status of different sensors to detect a liquid stream depending on the use case, such as follows:
-
When there is a liquid stream, more than one button sensor will be active at a time. If your design does not require multi-touch sensing, you can detect this and ignore the sensor status of all the button sensors to prevent false triggering
-
In a slider, if the slider segments which are turned ON are not adjacent segments, you can reset the slider segments status or ignore the slider centroid value that is calculated
-
Likewise, you could create your own custom algorithm to detect the presence of streaming liquids and ignore the sensor status during the time a liquid is present on the touch surface
Liquid tolerance for mutual-capacitance sensing
Effect of liquid droplets and liquid stream on a mutual-capacitance sensor
However, mutual-capacitance increases if the liquid droplet covers just the Tx and Rx electrode and does not spread over the grounded hatch. This causes a decrease in raw count as shown in Figure 36. This decrease in raw count may cause the baseline reset due to Low baseline reset. Once the liquid drop is removed, the raw count would rise while the baseline may remain at the lower value, resulting in a difference signal which may cause the sensor to false trigger.
Using self-capacitance sensing for liquid tolerance of mutual-capacitance sensors
CAPSENSE™ senses the self-capacitance of Tx and Rx nodes of a mutual-capacitance sensor. This ability of scanning the sensor using both CSD and CSX modes could be used to avoid false triggers due to the presence of liquid drops on a mutual capacitance sensor. See the code example PSoC™ 4 hybrid sensing using CAPSENSE™ to understand how to sense a mutual-capacitance button with both CSD as well as CSX sensing method.
To achieve liquid tolerance, you need to scan the Rx electrode of the sensor
with the CSD sense method. While scanning the Rx electrode as a CSD sensor, ensure that
you enable the shield electrode, and connect the Tx pin of the mutual-capacitance sensor
to the driven shield signal. You can use the low-level API function
CapSense_SetPinState()
to connect the Tx pin of the
mutual-capacitance sensor to the shield electrode before calling the
CapSense_ScanAllWidgets()
API function that scans the
Rx electrode as a CSD sensor as shown
below:
CapSense_SetPinState(CapSense_BUTTON1_WDGT_ID,CapSense_BUTTON1_TX0_ID,CapSense_SHIELD);
CapSense_ScanAllWidgets();
From sections 2.5.1 and 2.5.2 you understood the effect of liquid drop on the CSD and CSX button respectively. By utilizing the difference in their response to the liquid drop, you can create a firmware logic to achieve a liquid-tolerant mutual-capacitance sensor. The effect of presence of the liquid drop on the CSD and CSX scan results is summarized in Figure 37.
Where Figure 37 shows the effect of the water drop on the CSX sensor pattern surrounded by hatch fill when scanned using this method. The regions in Figure 37 represent the following:
-
Finger touch
-
Liquid droplet on the Tx line and grounded shield hatch
-
Liquid drop present on the Tx and Rx electrodes only
-
Finger touch when a liquid drop is on the Tx and Rx electrodes only
-
Liquid drop removed from the Tx and Rx electrodes
The changes in raw count as shown in Figure 37 can be used in the firmware to reset the baseline of the CSX sensor to nullify the effect of liquid drops. The button status should be ON state for Region 1, 4, and OFF state in other regions; additionally, the baseline of the CSX button must be re-initialized in Region 3 and Region 5. The baseline of the sensor could be reset by using the CapSense_InitializeWidgetBaseline() API function as shown below:
CapSense_InitializeWidgetBaseline(CapSense_CSX_BUTTON_WDGT_ID);
Effect of liquid properties on liquid-tolerance performance
In certain applications, the CAPSENSE™ system has to work in the presence of a variety of liquids such as soap water, sea water, and mineral water. In such applications, it is always recommended to tune the CAPSENSE™ parameters for sensors by considering the worst-case signal due to liquid droplets. To simulate the worst-case conditions, it is recommended that you test the liquid-tolerance performance of the sensors with salty water by dissolving 40 grams of cooking salt (NaCl) in one liter of water. Tests were done using soapy water; the results show that the effect of soapy water is similar to the effect of salty water. Therefore, if the tuning is done to reject salty water, the CAPSENSE™ system will work even in the presence of soapy water.
In applications such as induction cooktops, there are chances of hot water spilling on to the CAPSENSE™ touch surface. To determine the impact of the temperature of a liquid droplet on CAPSENSE™ performance, droplets of water at different temperatures were poured on a sensor and the corresponding change in raw counts was monitored. Experiment shows that the effect of hot liquid droplets is same as that of the liquid at room temperature as Figure 38 shows. This is because the hot liquid droplet cools down immediately to room temperature when it falls on the touch surface. If hot water continuously falls on the sensor and the temperature of the overlay rises because of the hot water, the increase in raw count due to the increase in temperature is compensated by the Baseline update algorithm, thereby preventing any false triggering of the sensors.
PSoC 4 and PSoC 6 MCU CAPSENSE
This chapter explains how CAPSENSE™ CSD and CSX (third, fourth, and fifth generations) are implemented in the PSoC™ 4 and PSoC™ 6 MCUs. See Capacitive touch sensing method to understand the basic principles of CAPSENSE™. A basic knowledge of the PSoC™ device architecture is a prerequisite for this chapter. If you are new to PSoC™ 4, see AN79953 - Getting started with PSoC™ 4 or AN91267 - Getting started with PSoC™ 4 Bluetooth® LE; for PSoC™ 6 MCU, see AN221774 - Getting started with PSoC™ 6 MCU.
The PSoC™ 4 family of devices has three different CAPSENSE™ architectures. Table 2 explains the differences between the third and fifth-generation CAPSENSE™ architecture.
CAPSENSE generations in PSoC 4 and PSoC 6
Table 2 lists the main differences in the CAPSENSE™ architecture for CSD and CSX.
Feature | Third-generation CAPSENSE™ | Fourth-generation CAPSENSE™ | Fifth-generation CAPSENSE™ | Improvement impact | Conditions | |
---|---|---|---|---|---|---|
SNR | 5:1 | 6.5:1 | 48:1 | Higher SNR implies better sensitivity, that is, ability to sense smaller signals. | VDD = 5 V; No firmware filter; Cp ~= 33 pF; Cf = 0.1 pF | |
Sensing mode | Self-cap and mutual-cap modes | Self-cap, mutual-cap, and ADC modes | Self-cap and mutual-cap modes | – | – | |
Sensor capacitance parasitic range | 5 pF – 45 pF | 5 pF – 200 pF | 2 pF – 200 pF | Greater Cp range implies higher flexibility in PCB layout routing and ability to sense with very short/long sensor traces, and for different PCB materials (for example, FFC and so on). | – | |
Typical sense signal needed | 100 fF | 100 fF | 15 fF for CSD-RM 10 fF for CSX-RM | Smaller sense signal required, implying support for thicker overlays, higher proximity range, smaller sensor size, and so on. | VDD = 5 V; No firmware filter; Cp ~= 33 pF; SNR = 5:1; | |
Noise floor (rms) | – | – | 500 aF for CSD-RM 100 aF for CSX-RM | Higher SNR or lower noise floor implies ability to sense smaller signals. | VDD - 5 V; Cp ~= 33 pF; CM = 5 pF | |
Overlay thickness supported | Up to 5 mm | Up to 5 mm | Up to 18 mm | Supports designs with thicker overlay. | 10 mm CSD button; Acrylic overlay; SNR = 5:1; Cp ~= 22 pF; | |
Refresh rate | – | 22 Hz | 242 Hz | Faster refresh rate enables fast gestures and taps detections on applications such as large trackpad and long sliders or large number of button sensors with single device, and so on. | 7x5 CSX touchpad; Acrylic overlay 3 mm thickness; SNR = 10:1; Finger Size = 8 mm; | |
CPU bandwidth requirement | Completely CPU driven. CPU is required for initialization and sequencing the sensors. | 40% sequencer 4 It takes care of initialization, configuration, and scanning of sensors. CPU is needed for sequencing through each sensor. | 7% Completely autonomous. | Reduced CPU usage for sensing frees the CPU to perform other peripheral operations, and act as a central controller in an application. | 10x8 CSX touchpad; Scan clock = 1 MHz; No of sub-conversions = 70; Refresh rate = 100 Hz; | |
Emission control options. | PRS | PRS, SSC | PRS, SSC | – | – | |
Noise immunity | Sense Voltage (Vref) | 1.2 V | 1.2 V-2.8 V. | Rail to Rail | Higher the sense voltage, higher the noise immunity. | – |
Differential Sensing | Mutual-cap sensing | Mutual-cap sensing | Mutual-cap and self-cap sensing | Differential sensing cancels out noise induced from external environment through CMOD. | ||
VDD noise impact | Yes | Yes | No | VDD noise has minimal affect on fifth generation CAPSENSE™ operation. | ||
Sense clock frequency | Self-Cap | 45 kHz – 6 MHz | 45 kHz – 6 MHz | 45 kHz – 6 MHz | Higher sense clock frequency means faster scan for low Cp sensors. This provides ability to support faster taps or gestures, or for a given refresh rate, ability to implement multiple firmware filters for better immunity. | – |
Mutual-Cap | 45 kHz - 300 kHz | 45 kHz - 3 MHz | 45 kHz – 6 MHz | |||
Multi-channel support | No | No | Yes | Provides ‘n’ times increased speed of scanning for the same number of sensors, if ‘n’channels are used. | – | |
Shield Cp | -- | -- | 1.2 nF | – | – | |
Device family | PSoC™ 4100/4200 PSoC™ 4100 M/4200 M PSoC™ 4100 L/4200 L PSoC™ 4100 BL/4200 BL | PSoC™ 4000 PSoC™ 4000S PSoC™ 4100S PSoC™ 4100S Plus PSoC™ 6 | PSoC™ 4100S Max PSoC™ 4000T(fifth-generation low-power) | – | – |
Capacitive Sigma-Delta (CSD) sensing method (third and fourth
generation)
Figure 39 illustrates the CAPSENSE™ block that scans CAPSENSE™ sensors in the CSD sensing mode.
As explained in Capacitive touch sensing method, this block works by first converting the sensor capacitance into an equivalent current. An analog multiplexer then selects one of the currents and feeds it into the current-to-digital converter. This current-to-digital converter consists of a sigma-delta converter, which controls the modulation IDAC for a specific period, the total current sourced or sinked by the IDACs is the same as the total current sinked or sourced by the sensor capacitance. The digital count output of the sigma-delta converter is an indicator of the sensor capacitance and is called a raw count. This block can be configured in either IDAC Sourcing mode or IDAC Sinking mode. In the IDAC Sourcing mode, the IDACs source current to AMUXBUS while the GPIO cells sink current from AMUXBUS. In the IDAC Sinking mode, the IDACs sink current from AMUXBUS while the GPIO cells source current to AMUXBUS.
GPIO cell capacitance to current converter
In the CAPSENSE™ CSD system, the GPIO cells are configured as switched-capacitance circuits that convert sensor capacitances into equivalent currents. Figure 40 shows a simplified diagram of the GPIO cell structure.
IDAC sourcing mode
In the IDAC Sourcing mode, the GPIO cell sinks current from the AMUXBUS A through a switched capacitor circuit as Figure 41 shows.
Two non-overlapping, out-of-phase clocks of frequency FSW control the switches SW1 and SW3 as Figure 42 shows. The continuous switching of SW1 and SW3 forms an equivalent resistance RS, as Figure 41 shows.
If the switches operate at a sufficiently low frequency FSW, such that time TSW/2 is sufficient to fully charge the sensor to VREF and fully discharge it to ground, as Figure 42 shows, the value of the equivalent resistance RS is given by Figure 43.
Where,
CS = Sensor capacitance
FSW = Frequency of the sense clock
The sigma-delta converter maintains the voltage of AMUXBUS A at a constant VREF (this process is explained in Sigma-delta converter. Figure 44 shows the resulting voltage waveform across CS.
Figure 45 gives the value of average current taken from AMUXBUS A.
IDAC sinking mode
In the IDAC sinking mode, the GPIO cell sources current to the AMUXBUS A through a switched capacitor circuit as Figure 46 shows. Figure 47 shows the voltage waveform across the sensor capacitance.
Because this mode charges the AMUXBUS A directly through VDDD, it is more susceptible to power supply noise compared to the IDAC sourcing mode. Hence, it is recommended to use this mode with an LDO or a very stable and quiet VDDD.
Figure 48 provides the value of average current supplied to AMUXBUS A.
CAPSENSE clock generator
The CAPSENSE™ clock generator block generates the sense clock FSW, and the modulation clock FMOD, from the high-frequency system resource clock (HFCLK) or peripheral clock (PERI) depending on the PSoC™ device family as shown in Figure 39.
Sense Clock
The sense clock, also referred to as the switching clock, drives the non-overlapping clocks to the GPIO cell switched capacitor circuits for the GPIO cell capacitance to charge converter.
Sense clock can be sourced from three options: direct, 8-bit PRS, and 12-bit PRS. Some PSoC™ 4 and PSoC™ 6 MCU parts also support additional spread spectrum clock (SSCx) modes. For more details on the supported modes for PSoC™ device, see the Component datasheet/middleware document.
Direct clock is a constant frequency sense clock source. When you chose this option, the sensor pin switches with a constant frequency clock with frequency as specified in the CAPSENSE™ component configuration window.
PRS clock implies that the sense clock is driven from a PRS block, which can generate either 8-bit or 12-bit PRS. Use of the PRS clock spreads the sense clock frequency over a wide frequency range by dividing the input clock using a PRS.
SSCx also spreads the sense clock frequency. It provides better noise immunity and reduces radiated electromagnetic emissions.
See Manually tuning hardware parameters for details on the clock source and frequency selection guidelines.
Modulator clock
The modulation clock is used by the Sigma-delta converter. This clock determines the sensor scan time based on Equation 8 and Equation 9.
Where,
Resolution = Scan resolution
Sensor Initialization time = Time taken by the sensor to write to the internal registers and initiate a scan.
Sigma-delta converter
The sigma-delta converter converts the input current to a corresponding digital count. It consists of a sigma-delta converter and two current sourcing/sinking digital-to-analog converters (IDACs) called modulation IDAC and compensation IDAC as Figure 39 shows.
The sigma-delta converter uses an external integrating capacitor, called modulator capacitor CMOD, as Figure 39 shows. Sigma-delta converter controls the modulation IDAC current by switching it ON or OFF corresponding to the small voltage variations across CMOD to maintain the CMOD voltage at VREF. The recommended value of CMOD is listed in Table 38.
The sigma-delta converter can operate in either IDAC sourcing mode or IDAC sinking mode.
-
IDAC sourcing mode: In this mode, the GPIO cell capacitance to charge converter sinks current from CMOD through AMUXBUS A, and the IDACs then source current to AMUXBUS A to balance its voltage
-
IDAC sinking mode: In this mode,the GPIO cell capacitance to charge converter sources current from CMOD to AMUXBUS A and the IDACs sink current through AMUXBUS A to balance its voltage
In both the above-mentioned modes, the sigma delta converter can operate in either single IDAC mode or dual IDAC mode:
-
In the single IDAC mode, the modulation IDAC is controlled by the sigma-delta converter; the compensation IDAC is always OFF
-
In the dual IDAC mode, the modulation IDAC is controlled by the sigma-delta converter; the compensation IDAC is always ON
In the single IDAC mode, if ‘N’ is the resolution of the sigma-delta converter and IMOD is the value of the modulation IDAC current, the approximate value of raw count in the IDAC Sourcing mode is given by Equation 10.
Similarly, the approximate value of raw count in the IDAC sinking mode is given by Equation 11.
In the dual IDAC mode, the compensation IDAC is always ON. If ICOMP is the compensation IDAC current, the equation for the raw count in the IDAC sourcing mode is given by Equation 12.
Raw count in the IDAC sinking mode is given by Equation 13.
The relation between the parameters shown in the above equation to the CAPSENSE™ Component parameters is listed in Table 3.
Sl. No. | Parameter | Description | Comments |
---|---|---|---|
1 | N | Scan resolution | Scan resolution is configurable from 6-bit to 16-bit. See Component datasheet/middleware document for details. |
2 | VREF | N/A | The VREF value is 1.2 V or configurable between 0.6 V to VDDA - 0.6 V depending on the PSoC™ device family. See Component datasheet/middleware document for details. |
3 | FSW | Sense clock frequency | Sense clock frequency and sense clock source decide the frequency at which the sensor is switching. See Sense Clock for details. |
Sense clock source | |||
4 | IMOD | Modulator IDAC | IMOD = Modulation IDAC current |
5 | ICOMP | Compensation IDAC | ICOMP = Compensation IDAC current |
6 | VDD | N/A | This parameter is the device supply voltage. |
7 | CS | N/A | This parameter is the sensor parasitic capacitance. |
8 | N/A | Modulator clock frequency | Modulator clock divider does not impact raw count. See the Modulator clock section for more details. |
Analog multiplexer (AMUX)
The sigma delta converter scans one sensor at a time. An analog multiplexer selects one of the GPIO cells and connects it to the input of the sigma delta converter, as Figure 39 shows. The AMUXBUS A and the GPIO cell switches (see SW3 in Figure 46) forms this analog multiplexer. AMUXBUS A connects to all GPIOs that support CAPSENSE™. See the corresponding Device datasheet for a list of port pins that support CAPSENSE™. AMUXBUS A also connects the integrating capacitor CMOD to the sigma-delta converter circuit. AMUXBUS B is used for shielding and is kept at VREF when shield is enabled.
CAPSENSE CSD shielding
PSoC™ 4 and PSoC™ 6 MCU CAPSENSE™ supports shield electrodes for liquid tolerance and proximity sensing. CAPSENSE™ has a shielding circuit that drives the shield electrode with a replica of the sensor switching signal to nullify the potential difference between sensors and shield electrode. See Driven-shield signal and shield electrode Driven-shield signal and shield and Effect of liquid droplets and liquid stream on a self-capacitance sensor for details on how this is useful for liquid tolerance.
In the sensing circuit, the sigma delta converter keeps the AMUXBUS A at VREF (see Sigma-delta converter). The GPIO cells generate the sensor waveforms by switching the sensor between AMUXBUS A and a supply rail (either VDD or ground, depending on the configuration). The shielding circuit works in a similar way; AMUXBUS B is always kept at VREF. The GPIO cell switches the shield between AMUXBUS B and a supply rail (either VDDD or ground, the same configuration as the sensor). This process generates a replica of the sensor switching waveform on the shield electrode.
For a large shield layer with high parasitic capacitance, an external capacitor (Csh tank capacitor) is used to enhance the drive capacity of the shield electrode driver.
CAPSENSE CSX sensing method (third- and fourth- generation)
Figure 55 illustrates the CSX sensing circuit. The implementation uses the following hardware sub-blocks from CSD HW.
-
An 8-bit IDAC and the sigma delta converter
-
AMUXBUS A
-
CAPSENSE™ clock generator for Tx clock and modulator clock
-
VREF and port pins for Tx and Rx electrodes and external caps
-
Two external capacitors (CINTA and CINTB) (see Table 38 for recommended value of these capacitors)
The CSX sensing method measures the mutual-capacitance between the Tx electrode and Rx electrode, as shown in Figure 55. The Tx electrode is excited by a digital waveform (Tx clock), which switches between VDDIO (or VDDD if VDDIO is not available in the given part number) and ground. The Rx electrode is statically connected to AMUXBUS A. The CSX method requires two external integration capacitors, CINTA and CINTB. The value of these capacitors is listed in Table 38.
Figure 56 shows the voltage waveforms on the Tx electrode and CINTA and CINTB capacitors. The sampling – a process of producing a “sample” – is started by the firmware by initializing the voltage on both external capacitors to VREF and performing a series of sub-conversions. A sub-conversion is a capacitance to count conversions performed within a Tx clock cycle. The sum of results of all sub-conversions in a sample is referred to as “raw count”.
During a sub-conversion, both SW1 and SW2 switches are operated in phase with the Tx clock. On the rising edge of the Tx clock, SW1 is closed (SW2 is open during this time) and charge flows from the Tx electrode to the Rx electrode. This charge is integrated onto the CINTA capacitor, which increases the voltage on CINTA. The IDAC is configured in sink mode to discharge the CINTA capacitor back to voltage VREF. On the falling edge of the Tx clock, SW2 is closed (SW1 is open during this time) and the charge flows from the Rx electrode to the Tx electrode. This causes the voltage on CINTB to go below VREF. The IDAC is configured in source mode to bring the voltage on CINTB back to VREF.
The charge transferred between Tx and Rx electrodes in both the cycles is proportional to mutual-capacitance, CM, between the electrodes. The sigma delta converter controls IDAC for charging or discharging the external capacitors and also it measures the charging and discharging time in terms of modulator clock cycles for a sub-conversion. Multiple sub-conversions are performed during the CSX scanning and the result of each sub-conversion is accumulated to produce “raw count” for a sensor.
The modulator clock is used to measure the time taken to charge/discharge external capacitors within a Tx clock cycle. For this reason, modulator clock frequency must be always greater than Tx clock frequency; higher modulator clock frequency leads to better accuracy. For proper operation, the IDAC current should be set such that the CINTA and CINTB capacitors are charged/discharged within one Tx clock cycle. The CAPSENSE™ Component/middleware provides an option to automatically calibrate the IDAC. It is recommended to enable this option.
Where,
IDAC = IDAC current
CM = Mutual-capacitance between Tx and Rx electrodes
VTX = Amplitude of the Tx signal
FTX = Tx clock frequency
FMod = Modulator clock frequency
NSub = Number of sub-conversions
When you place a finger on the CSX button, the mutual-capacitance between Rx and Tx electrodes decreases, which decreases the raw count. This decrease in raw count from the hardware is inverted by the CAPSENSE™ Component to make it similar to the raw count change in CSD for a finger touch. The final resulting inverted raw count is given by Figure 58.
See CSX sensing method (third- and fourth-generation) for more details of CSX hardware parameters.
CAPSENSE CSD-RM sensing method
(fifth-generation and fifth-generation low-power)
This section provides an overview of the CSD-RM architecture implemented in the fifth-generation CAPSENSE™ device (known as multi sense converter (MSC)). The main features include ratiometric sensing, differential mode of operation without the need of reference voltage, use of capacitor DACs (CDAC) instead of current DACs (IDAC), which improves noise performance.
The fifth-generation low power (known as multi-sense low-power or MSCLP) technology has an internal clock removing the dependency on the system resource. Autonomous scanning is now enabled even without the CTRLMUX and DMA. All AMUXBUS CAPSENSE™ pins support autonomous scanning.
GPIO cell capacitance to charge converter
GPIO cell capacitance to current converter explains the GPIO cell configuration. In the fifth-generation architecture, the sensor is either interfaced to the AMUX (as before) or a new control MUX matrix, which supports autonomous scanning (limited number of pins supported). The GPIO cells are configured as switched-capacitance circuits that convert sensor capacitance into equivalent charge transfer. Figure 61 shows the GPIO cell structure.
In the fifth-generation low-power architecture, the sensor is only interfaced to the AMUX, which now supports autonomous scanning (supports more number of pins than CTRLMUX).
Four non-overlapping, out-of-phase clocks of frequency FSW control the switches (SW1, SW2, SW3 and SW4) as Figure 63 shows.
Capacitor DACs (CDACs)
IDACs are replaced by CDACs in the fifth-generation CAPSENSE™ architecture. It consists of two CDACs, a reference capacitor DAC, and a compensation capacitor DAC. In each sense clock period, the sensor capacitance, as mentioned in GPIO cell capacitance to charge converter, transfers charge to both CMODs in such a way that it affects the voltage balance between the CMODs. Both capacitor DACs are switched on to CMOD multiple times during a sense clock period to restore the voltage balance between the CMODs. The number of cycles required by the reference capacitor DAC to balance the voltage is proportional to the self-capacitance of the sensors.
The fifth-generation low-power CAPSENSE™ consists of Fine CDAC and Dither CDAC. The Fine Reference CDAC (Cfine) is a programmable CDAC, which is used to achieve finer resolution for the Reference CDAC. The CDAC dither is used to reduce Flat-spots (or dead zones).
CAPSENSE clock generator
This block generates the sense clock FSW, and the modulation clock FMOD, from the high-frequency system resource clock (HFCLK) or peripheral clock (PERI) depending on the PSoC™ device family.
Sense clock
CAPSENSE™ clock generation is similar to that in the older generation as explained in Sense Clock.
Modulator clock
The modulation clock is used by the Ratiometric sensing technology. This clock determines the sensor scan time based on Equation 16 and Equation 17.
Where,
Number of subconversions = Total number or sub-conversions in single scan
Subconversion = Capacitance to count conversions performed within a sense clock cycle
Sensor initialization time = Time taken by the sensor to write to the internal registers and initiate a scan
Ratiometric sensing technology
It consists of a ratiometric converter and two CDACs, a reference capacitor DAC, and a compensation capacitor DAC. In each sense clock period, the sensor capacitance, as mentioned in GPIO cell capacitance to charge converter, transfers charge to both CMODs in such a way that it affects the voltage balance between the CMODs. The ratiometric converter controls the reference CDAC by switching it ON or OFF corresponding to the small voltage variations across two CMODs to maintain the CMOD voltage at the same level. The number of cycles required by the reference capacitor DAC to balance the voltage between the CMODs is proportional to the self-capacitance of the sensors.
The compensation capacitor is used to compensate excess mutual-capacitance from the sensor to increase the sensitivity. The number of times it is switched depends on the amount of charge the user application is trying to compensate (remove) from the sensor mutual capacitance.
The ratiometric converter can operate in either the single CDAC mode or dual CDAC mode.
-
In the single CDAC mode, the reference CDAC is controlled by the ratiometric converter; the compensation CDAC is always OFF
-
In the dual CDAC mode, the reference CDAC is controlled by the ratiometric converter; the compensation CDAC is always ON. The reference CDAC is capable of compensating up to 95%, results in the increased signal as explained in Conversion gain and CAPSENSE™ signal
In the single CDAC mode, if CREF is the value of the reference CDAC, the approximate raw count value is given by Equation 18.
In the dual CDAC mode, the compensation CDAC is always ON. If CCOMP is the compensation CDAC, the raw count equation is given by Equation 19.
Where,
MaxCount = NSub.SnsClkDiv
NSub = Number of sub-conversions
SnsClkDiv = Sense clock divider
CompClkDiv = Compensation CDAC divider
CS = Sensor capacitance
Cref = Reference capacitance
Ccomp = Compensation capacitance
With CIC2 enabled,
Where,
It is recommended to choose the number of CIC2 samples in such a way that "K" can be set to “1” to get the highest possible raw count.
Number of CIC2 samples | Recommended CIC2 shift for divider | CIC2 hardware divider |
---|---|---|
2 | 1 | 2 |
3-4 | 2 | 4 |
5-8 | 3 | 8 |
9-16 | 4 | 16 |
17-32 | 5 | 32 |
33-64 | 6 | 64 |
65-128 | 7 | 128 |
129-256 | 8 | 256 |
Selecting the auto option for CIC2 shift in the CAPSENSE™ configurator selects hardware shift (hardware divider) as per Table 4.
The decimation rate is the down sampling rate, and when it reaches its maximum of 255, the following condition needs to be ensured to avoid CIC2 accumulator (25-bit) overflow.
Where,
CIC2_Acc_SizeMax - Maximum CIC2 accumulator size
The maximum CIC2 accumulator size for a direct clock is (225 - 1), and for a PRS clock is (225 - 1)/2.
As per Equation 18, the output raw count is proportional to the ratio of sensor capacitance to the reference capacitance, and hence the name Ratiometric Sensing.
Noise improvement is one of the main advantages of the fifth-generation over previous generations of CAPSENSE™ technology. The dominant noise sources in the fourth-generation are current (IMOD), reference voltage (VREF), and clock jitter (FSW) (see Figure 53). These noise sources have been removed in the fifth-generation (see Equation 19). The IDAC has been replaced with CDAC. Since the system is now fully differential, it does not need VREF. The CAPSENSE™ architecture is no longer affected by jitter as the scan result is now based on the edges of the clock rather than the duration of the clock. Because of differential architecture, the drift of raw count for a given power-supply ripple is significantly less in the fifth-gen and fifth-gen low-power CAPSENSE™. The user may not need any LDO to design with fifth-gen and fifth-gen low-power CAPSENSE™ technology if power supply ripple is within the limits mentioned in the datasheet.
Analog multiplexer (AMUX) and control matrix (CTRLMUX)
Another feature introduced in the Fifth-Generation is the control matrix (CTRLMUX) as shown in Figure 59. The CTRLMUX enables autonomous scanning and provides immunity to on-chip IO noise. The CTRLMUX allows the CAPSENSE™ IP to directly handle the sensor inputs5 (in addition to the traditional GPIO mode), and hence supports autonomous scanning of the sensors without the CPU.
For fifth-generation low-power, as shown in the image Figure 60, the CTRLMUX has been removed. The AMUXBUS is enabled to handle autonomous scanning on all the CAPSENSE™ pins.
CAPSENSE CSDRM shielding
PSoC™ 4 CAPSENSE™ supports shield electrodes for liquid tolerance and proximity sensing. The purpose of the shielding is to remove the parasitic capacitance between the sensor and shield electrodes. See Driven-shield signal and shield electrode and Effect of liquid droplets and liquid stream on a self-capacitance sensor for details on how this is useful for liquid tolerance. The fifth-generation CAPSENSE™ architecture supports two shield modes – active and passive shielding.
Active shielding
In active shielding mode, the shield circuit drives the shield electrode with a replica of the sensor signal using a buffer as shown in Figure 71. This nullifies the potential difference between sensors and the shield electrode.
Passive shielding
In the passive shielding mode, there is no buffer used; instead, the shield is switched between VDDA and GND as shown in Figure 72. The switching is controlled in such a way that the net charge between the sensor and the shield is nullified every two sense clocks.
Table 5 provides the comparison of the active shielding features versus the passive shielding features.
Feature | Active shielding | Passive shielding | Effect |
---|---|---|---|
Performance | Higher | Lower | Active shielding is preferred for high-performance applications. |
Power impact | Higher | Lower | Passive shielding is preferred for low-power applications. |
CAPSENSE CSX-RM sensing method
(fifth-generation and fifth-generation low-power)
Figure 73 illustrates the CSX-RM sensing circuit. The implementation uses the following hardware subblocks:
-
Two 8-bit capacitor DACs and ratiometric converter
-
AMUXBUS and CTRLMUX
-
CAPSENSE™ clock generator for Tx clock and modulator clock
-
Port pins for Tx and Rx electrodes and external caps
-
Two external capacitors (CMOD1 and C MOD2)
The CSX-RM sensing method measures the mutual-capacitance between the Tx electrode and Rx electrode, as shown in Figure 73. The Tx electrode is activated by a digital waveform (Tx clock), which switches between VDDA and ground. The Rx electrode is statically connected to AMUXBUS A or CTRLMUX, as applicable. The CSX-RM method requires two external integration capacitors, CMOD1 and CMOD2.
The sampling – a process of producing a “sample” – is started by the firmware by initializing the voltage on both external capacitors (CMOD) to VDDA/2 and performing a series of sub-conversions. A sub-conversion is a capacitance to count conversions performed within a Tx clock cycle. The sum of results of all sub-conversions in a sample is referred to as “raw count”.
On the rising and falling edge of the Tx clock, charge flows from the Tx electrode to the Rx electrode. In such a way that it unbalances the voltage between the external CMOD capacitors. Both capacitor DACs (reference and compensation capacitor DACs) are switched onto CMOD multiple times during a sense clock period to balance the CMOD’s back to their original voltage. Number of cycles required by the reference capacitor DAC to balance is proportional to the mutual-capacitance, Cm, between the electrodes.
The number of times the reference capacitor is switched with respect to the modulator clock is denoted by the Tx clock divider value according to Figure 75.
Where,
TxClkDiv = Tx clock divider
FMod = Modulator frequency
FTx = Tx clock frequency
The compensation capacitor is used to compensate excess mutual-capacitance from the sensor to increase the sensitivity. The number of times it is switched depends on the amount of charge the user application is trying to compensate (remove) from the sensor mutual-capacitance. The number of times the compensation capacitor is switched with respect to the modulator clock is denoted by the value of the compensation CDAC divider according to the Equation 21. The CDAC compensation clock divider must be less than or equal to the Tx clock divider.
Where,
CompClkDiv = Compensation CDAC divider
FM MOD = Modulator frequency
Fcomp = Compensation CDAC clock frequency
Ratiometric sensing technology
The ratiometric converter gives an equivalent raw count which is proportional to the sensor mutual-capacitance after each scan. The ratiometric converter can operate in either single CDAC mode or dual CDAC mode.
-
In the single CDAC mode, the reference CDAC is controlled by the ratiometric converter; the compensation CDAC is always OFF
-
In the dual CDAC mode, the reference CDAC is controlled by the ratiometric converter; the compensation CDAC is always ON. Compensation CDAC is capable of compensating up to 95%, results in increased signal as explained in Conversion gain and CAPSENSE™ signal
In the single CDAC mode, if Cref is the value of the reference CDAC, the approximate value of raw count is given by Figure 77.
In the dual CDAC mode, the compensation CDAC is always ON. If Ccomp is the compensation CDAC, the equation for the raw count is given by Figure 78.
Where,
MaxCount = NSub.TxClkDiv
NSub = Number of sub-conversions
SnsClkDiv = Sense clock divider
CompClkDiv = Compensation CDAC divider
CS = Sensor capacitance
Cref = Reference capacitance
Ccomp = Compensation capacitance
With CIC2 enabled,
Where,
It is recommended to choose the number of CIC2 samples in such a way that "K" can be set to “1” to get the highest possible raw count.
Number of CIC2 samples | Recommended CIC2 shift for divider | CIC2 hardware divider |
---|---|---|
2 | 1 | 2 |
3-4 | 2 | 4 |
5-8 | 3 | 8 |
9-16 | 4 | 16 |
17-32 | 5 | 32 |
33-64 | 6 | 64 |
65-128 | 7 | 128 |
129-256 | 8 | 256 |
Selecting the auto option for CIC2 shift in the CAPSENSE™ configurator selects hardware shift (hardware divider) as per Table 4
The decimation rate is the down sampling rate, and when it reaches its maximum of 255, the following condition needs to be ensured to avoid CIC2 accumulator (25-bit) overflow.
Where,
CIC2_Acc_SizeMax - Maximum CIC2 accumulator size
The maximum CIC2 accumulator size for a direct clock is (225 - 1), and for a PRS clock is (225 - 1)/2.
According to Figure 78, the output raw count is proportional to the ratio of the mutual capacitance of the sensor to the reference capacitance, hence the name ratiometric sensing.
Advantages of fifth generation and fifth generation low-power
See AN234231 - Achieving lowest-power capacitive sensing with PSoC™ 4000T for detailed information on autonomous scanning and the CIC2 filter.
Autonomous scanning
In previous generation CAPSENSE™ technology, after each scan, CPU is interrupted to configure the next sensor. Autonomous scanning mode in the fifth-generation CAPSENSE™ technology avoids the CPU intervention for scanning every subsequent sensor. This significantly reduces the CPU bandwidth required for scanning widgets with large number of sensors. Autonomous scanning requires features such as CTRLMUX and DMA. Since the number of pins supported with CTRLMUX is limited, the number of pins supporting autonomous scanning is also limited. See the Configuring autonomous scan section for more details.
In fifth-generation low-power CAPSENSE™, autonomous scanning is supported inherently, and requires neither CPU intervention nor CTRLMUX and DMA. All CAPSENSE™ pins support this scanning mode, via the AMUXBUS, compared to the limited number of pins, which were supported by the CTRLMUX in the fifth-generation CAPSENSE™ technology.
Usage of multiple channels
See Multi-channel scanning section for more details.
CIC2
The multi-sense low-power (MSCLP) CAPSENSE™ device has a built-in cascaded integrator-comb 2 (CIC2) digital filter, which improves the effective resolution, and thereby the SNR, for a given scan period. The CIC2 filter is a 2nd order digital low-pass (decimation) filter used to filter delta-sigma converters. Figure 82 shows the representation of a CIC2 filter made up of a cascade of two integrators and two comb filters.
The CIC2 filter receives the output of the MSCLP analog front end, which is a delta-sigma converter. This converter generates a bitstream of 1s and 0s representing its input, and moves the quantization noise to high frequencies. This high-frequency noise is filtered out by a digital low-pass filter; the downsampler converts the input to a single digital word representing the measured signal. This combination of a low-pass filter (A0, A1) and a downsampler (D0, D1) is known as a decimator (CIC2 filter) as shown in Figure 82.
The raw count gets accumulated at the end of each valid sample.
A minimum of two valid CIC2 samples are required for proper CIC2 filtering. Considering two valid samples, calculate the decimation (down sampling) rate using the following equation:
Configure the CIC2 Shift parameter as "Auto" in the CAPSENSE™ configurator. This automatically selects the appropriate hardware shift (hardware divider).
Calculate the max raw count, when CIC2 is enabled, using the following equation:
6
When the decimation rate reaches its maximum of 255, the user needs
to ensure that the below conditions are met to avoid the CIC2 accumulator (25-bit)
overflow.
For Direct clock: (225-1) >= TRUNC((Nsub*Sns_Clk_Div)/Decimation-1)*Decimation2
For PRS clock: (225-1)/2 >= TRUNC((Nsub*Sns_Clk_Div)/Decimation-1)*Decimation2
6 When the decimation rate reaches its maximum of 255, the user needs to ensure that the below conditions are met to avoid the CIC2 accumulator (25-bit) overflow.
For Direct clock: (225-1) >= TRUNC((Nsub*Sns_Clk_Div)/Decimation-1)*Decimation2
For PRS clock: (225-1)/2 >= TRUNC((Nsub*Sns_Clk_Div)/Decimation-1)*Decimation2
6 When the decimation rate reaches its maximum of 255, the user needs to ensure that the below conditions are met to avoid the CIC2 accumulator (25-bit) overflow.
For Direct clock: (225-1) >= TRUNC((Nsub*Sns_Clk_Div)/Decimation-1)*Decimation2
For PRS clock: (225-1)/2 >= TRUNC((Nsub*Sns_Clk_Div)/Decimation-1)*Decimation2
CAPSENSE design and development tools
This section introduces the available software tools, such as PSoC™ Creator and ModusToolbox™, to develop your CAPSENSE™ application. For more details, see the user manual of the respective IDE. Table 7 shows the supported devices and the CAPSENSE™ component/middleware version in PSoC™ Creator and ModusToolbox™.
Devices | Software tool | CAPSENSE™ library |
---|---|---|
PSoC™ 4000S, PSoC™ 4100S, PSoC™ 4100S Plus, PSoC™ 4100S Plus 256K, PSoC™ 4500S | ModusToolbox™, PSoC™ Creator | CAPSENSE™ middleware, CAPSENSE™ component |
PSoC™ 4000T, PSoC™ 4100S Max, All PSoC™ 6 devices | ModusToolbox™ | CAPSENSE™ middleware |
All other PSoC™ 4 devices | PSoC™ Creator | CAPSENSE™ component |
PSoC Creator
PSoC™ Creator is a state-of-the-art, easy-to-use IDE. It offers a unique combination of hardware configuration and software development based on classical schematic entry. You can develop applications in a drag-and-drop design environment using a library of Components. For details, see the PSoC™ Creator home page.
CAPSENSE component
PSoC™ Creator provides a CAPSENSE™ component, which is used to create a capacitive touch system in PSoC™ by simply configuring this Component. The CAPSENSE™ component also provides an application programming interface (API) to simplify firmware development. Some PSoC™ 4 Bluetooth® LE and PSoC™ 6 MCU devices also support a CAPSENSE™ Gesture Component (see the corresponding Device datasheet to see if your device supports this Component).
Each CAPSENSE™ component has an associated datasheet that explains details about the Component. To open the Component datasheet, right-click the Component and select Open Datasheet.
The CAPSENSE™ component also has a Tuner GUI, called the Tuner GUI, to help with the tuning process.
CapSense_ADC component
The CapSense_ADC7 component is only applicable for the PSoC™ 4S-Series, PSoC™ 4100S Plus, PSoC™ 4100PS, and PSoC™ 6 MCU devices. This component should be used when both CAPSENSE™ and ADC operations are required. This component allows using the CAPSENSE™ block for ADC operation and touch functionality in a time-multiplexed manner.
Tuner GUI
Tuner helper is included with the CAPSENSE™ component and assists in tuning CAPSENSE™ parameters and monitoring sensor data such as raw count, baseline, and difference count. Refer the Component datasheet/middleware document for the detailed procedure on how to use Tuner GUI.
Example projects
You can use the CAPSENSE™ example projects provided in PSoC™ Creator to learn schematic entry and firmware development. To find a CAPSENSE™ example project, go to the PSoC™ Creator home page, click Find Code Example …, and select the appropriate architecture, as Figure 86 shows. You can also filter for a project by writing partial or complete project name in the Filter by field.
ModusToolbox
ModusToolbox™ software suite is used for the development of PSoC™ 6 and PSoC™ 48 based CAPSENSE™ applications. You can download ModusToolbox™ from here. Before you start working with this software, it is recommended that you go through the Quick start guide and user guide. ModusToolbox™ software trainings can be found here. If you have ModusToolbox™ IDE installed in your system, you can create a CAPSENSE™ application for the devices supported in ModusToolbox™.
CAPSENSE middleware
ModusToolbox™ provides a CAPSENSE™ middleware, which can be used to create a capacitive touch system in PSoC™ by simply configuring parameters in the CAPSENSE™ configuration tool. The middleware also provides an application programming interface (APIs) to simplify firmware development. See the CAPSENSE™ middleware library for more details.
CAPSENSE configurator
The CAPSENSE™ configurator tool in ModusToolbox™ is similar to that in PSoC™ Creator, which is used to configure the CAPSENSE™ hardware and software parameters. For more details on configuring CAPSENSE™ in ModusToolbox ™, see the ModusToolbox™ CAPSENSE™ configurator guide and CAPSENSE™ middleware library. Figure 87 shows how to open the CAPSENSE™ configuration tool in ModusToolbox™. Alternatively, it can also be opened from the Quick panel in the ModusToolbox™. For simplicity of documentation, this design guide shows selecting the CAPSENSE™ parameter in PSoC™ Creator CAPSENSE™ component.
CSDADC middleware
This CSDADC middleware9 should be used when both the CAPSENSE™ and ADC operations are required. This middleware allows using the CAPSENSE™ hardware block for ADC operation and touch functionality in a time-multiplexed manner. It could be used for all three sensing modes that is, CSD, ADC, and CSX. See the CSDADC middleware library documentation for more details.
CSDIDAC middleware
The CSDIDAC middleware allows you to use the CAPSENSE™ IDAC in a standalone mode. You can use this middleware if you are not using CAPSENSE™ middleware or if you are using only one IDAC for CAPSENSE™. See the CSDADC middleware library documentation.
CAPSENSE Tuner
ModusToolbox™ also supports a GUI tool that can be used for tuning CAPSENSE™ parameters. This tool can be opened from the Device configurator by selecting Launch CAPSENSE™ Tuner as shown in Figure 87. See the CAPSENSE™ tuner guide documentation.
Example projects
To quickly start the CAPSENSE™ system design, start with the example projects provided in ModusToolbox™. You can find a CAPSENSE™ example project by navigating to File > New > ModusToolbox Application. Choose the appropriate Board Support Package with a device. Figure 88 shows creating a CAPSENSE™ CSD Button example starter code in ModusToolbox™ from the list of available code examples.
Hardware kits
Table 8 lists the development kits that support evaluation of PSoC™ 4 and PSoC™ 6 CAPSENSE™.
Development kit | Supported CAPSENSE™ features |
---|---|
PSoC™ 4000 pioneer kit (CY8CKIT-040) | A 5x6 CAPSENSE™ touchpad and a wire proximity sensor |
PSoC™ 4 S-series pioneer kit (CY8CKIT-041) | Two self- or mutual-capacitive sensing buttons A 7×7 self- or mutual-capacitive sensing touchpad |
PSoC™ 4 S-series prototyping kit (CY8CKIT-145) | Three self- or mutual-capacitive sensing buttons A five-segment self- or mutual-capacitive sensing linear slider |
PSoC™ 4100S Plus prototyping kit (CY8CKIT-149) | Three self- or mutual-capacitive sensing buttons A six-segment self- or mutual-capacitive sensing linear slider |
PSoC™ 4100S Max pioneer kit (CY8CKIT041S-Max) | Two self- or mutual-capacitive sensing buttons An eight-segment self- or mutual-capacitive sensing linear slider A 10x16 self- or mutual-capacitive sensing touchpad A proximity sensor loop |
PSoC™ 4000T kit (CY8CKIT-040T) | One CAPSENSE™ button A 4x5 self- or mutual-capacitive sensing touchpad A proximity sensor loop |
PSoC™ 4000T prototyping kit (CY8CPROTO-040T) | One self-capacitive sensing button One mutual-capacitive sensing button A proximity sensor loop A five-segment self- or mutual-capacitive sensing linear slider |
PSoC™ 4 pioneer kit (CY8CKIT042) | A five-segment linear slider |
PSoC™ 4 Bluetooth® LE pioneer Kit (CY8CKIT-042-BLE) | A five-segment linear slider and a wire proximity sensor |
PSoC™ 4200-M pioneer kit (CY8CKIT-044) | A five-element gesture detection and two proximity wire sensors |
PSoC™ 4200-L pioneer kit (CY8CKIT-046) | A five-element gesture detection, two proximity wire sensors, and an eight-element radial slider |
PSoC™ 4100PS prototyping kit (CY8CKIT-147) | No onboard CAPSENSE™ sensors. The kit can be used to connect external sensors to any I/O pin. |
CAPSENSE™ proximity shield (CY8CKIT-024) | A four-element gesture detection and one proximity loop sensor |
CAPSENSE™ liquid level sensing shield (CY8CKIT-022) | A two-element flexible PCB and 12-element flexible PCB |
PSoC™ 4 processor module (CY8CKIT038), with PSoC™ development kit (CY8CKIT001) | A five-segment linear slider and two buttons |
CAPSENSE™ expansion board kit (CY8CKIT-031), to be used with CY8CKIT038 and CY8CKIT-001 | A 10-segment slider, five buttons and a 4 x 4 matrix button with LED indication. |
MiniProg3 program and debug kit (CY8CKIT-002) | CAPSENSE™ performance tuning in CY8CKIT-038 |
PSoC™ 6 Wi-Fi BT pioneer kit (CY8CKIT-062-WiFi-BT pioneer kit) and PSoC™ 6 Bluetooth® LE pioneer kit (CY8CKIT062-BLE pioneer kit) | A 5-segment CAPSENSE™ slider, two CAPSENSE™ buttons, one CAPSENSE™ proximity sensing header, a proximity sensor. |
PSoC™ 6 Wi-Fi BT prototyping kit (CY8CPROTO-063-4343W) | A 5-segment CAPSENSE™ slider and two mutual-cap CAPSENSE™ buttons |
CAPSENSE performance tuning
After you have completed the sensor layout (see PCB layout guidelines), the next step is to implement the firmware and tune the CAPSENSE™ parameters for the sensor to achieve optimum performance. The CAPSENSE™ sensing method is a combination of hardware and firmware techniques. Therefore, it has several hardware and firmware parameters required for proper operation. These parameters should be tuned to optimum values for reliable touch detection and fast response. Most of the capacitive touch solutions in the market must be manually tuned. A unique feature called SmartSense (also known as Auto-tuning) is available for PSoC™ 4 and PSoC™ 6 CAPSENSE™. SmartSense is a firmware algorithm that automatically sets all parameters to optimum values.
Selecting between SmartSense and manual tuning
SmartSense auto-tuning reduces design cycle time and provides stable performance across PCB variations, but requires additional RAM and CPU resources, as indicated in the Component datasheet/middleware document or ModusToolbox™ CAPSENSE™ configurator guide, to allow runtime tuning of CAPSENSE™ parameters. SmartSense is recommended mainly for conventional CAPSENSE™ applications involving simple button and slider widgets, and is currently supported only for Self-capacitance sensing and not Mutual-capacitance sensing.
On the other hand, manual tuning requires effort to tune optimum CAPSENSE™ parameters, but allows strict control over characteristics of capacitive sensing system, such as response time and power consumption. It also allows use of CAPSENSE™ beyond the conventional button and slider applications such as proximity and liquid-level-sensing.
SmartSense is the recommended tuning method for all the conventional CAPSENSE™ applications. You should use SmartSense auto-tuning if your design meets the following requirements:
-
The design is for conventional user-interface application like buttons, sliders, and touchpad
-
The parasitic capacitance (CP) of the sensors is within SmartSense-supported range as mentioned in the “SmartSense operating conditions” section in Component datasheet/middleware document or ModusToolbox™ CAPSENSE™ configurator guide
-
The sensor scan time chosen by SmartSense meets the response time/power requirements of the end system
-
SmartSense auto-tuning meets the RAM/flash requirements of the design
For all other applications, use Manual tuning. In such cases, you can also use SmartSense as an initial step to find the optimum hardware parameters such as Sense Clock frequency, and then change the tuning mode to manual tuning for further tuning of the CAPSENSE™ parameters. See Using SmartSense to determine hardware parameters.
SmartSense
Overview
The CAPSENSE™ algorithm is a combination of hardware and firmware blocks inside PSoC™. Therefore, it has several hardware and firmware parameters required for proper operation. These parameters need to be tuned to optimum values for reliable touch detection and fast response.
SmartSense is a CAPSENSE™ tuning method that automatically sets sensing parameters for optimal performance, based on user-specified finger capacitance values, and continuously compensates for system, manufacturing, and environmental changes.
Some advantages of SmartSense, as opposed to manual tuning are:
- Reduced design cycle time: The design flow for capacitive touch applications involves tuning all of the sensors. This step can be time consuming if there are many sensors in your design. In addition, you must repeat the tuning when there is a change in the design, PCB layout, or mechanical design. Auto-tuning solves these problems by setting all of the parameters automatically. Figure 89 shows the design flow for a typical CAPSENSE™ application with and without SmartSense
-
Performance is independent of PCB variations: The parasitic capacitance, CP, of individual sensors can vary due to process variations in PCB manufacturing, or vendor-to-vendor variation in a multi-sourced supply chain. If there is significant variation in CP across product batches, the CAPSENSE™ parameters must be re-tuned for each batch. SmartSense sets parameters for each device automatically, hence taking care of variations in CP
-
Ease of use: SmartSense is faster and easier to use because only a basic knowledge of CAPSENSE™is needed
Note that SmartSense can be used in multiple ways:
-
SmartSense (Full auto-tune) – This is the quickest way to tune. This method calibrates CAPSENSE™ hardware and software parameters automatically at runtime. This is the recommended method for most designs
-
SmartSense (Hardware parameters only) – This method auto-tunes all hardware parameters of CAPSENSE™, but allows to set user-defined threshold values (see Table 14). This method consumes less flash/RAM resources than SmartSense (Full Auto-Tune). Also, this method avoids the extra processing needed for automatic threshold calculation and hence allows lower power consumption for a given scan rate. Use this method for low-power or noisy designs or in cases with constrained memory requirements
-
SmartSense for initial tuning – You may also use SmartSense for initial tuning, to quickly find the best settings for a CAPSENSE™ board and then change to manual tuning. This method is useful for cases with strict requirements on response time or power consumption. This is a quick method to find the best settings, instead of starting manual tuning from scratch. Refer to the section Using SmartSense to determine hardware parameters for more details
-
Table 9. CAPSENSE™ parameters auto-tuned in SmartSense
Parameter Full auto-tune mode Hardware parameters only mode
Scan resolution
Calculated once on CAPSENSE™ initialization.
Compensation IDAC
Modulator IDAC
Sense clock frequency
Modulator clock frequency
Finger threshold
Calculated once on CAPSENSE™ initialization based on the selected finger capacitance and updated after each sensor scan.
Manual selection (see Table 14).
Noise threshold
Hysteresis
Negative noise threshold
Low baseline reset
SmartSense full auto-tune
In SmartSense Full Auto-tune mode, the only parameter that needs to be tuned by the user is the Finger Capacitance parameter. The Finger Capacitance parameter (CF) indicates the minimum value of finger capacitance that should be detected as a valid touch by the CAPSENSE™ Component. Whenever the actual CF that is added when the finger touches the button sensor is greater than the value specified for the Finger Capacitance parameter in the Component configuration window, the sensor status will change to ‘1’; however, if the actual CF added by the finger touch is less than the value specified in the Component configuration window, the sensor status will remain ‘0’. The way of tuning the finger capacitance is different for button and slider widgets.
Tuning button widgets
This section explains how to choose the finger capacitance value for the button widget. You may perform only a coarse tuning of the Finger capacitance parameter for a working design, or you may choose to fine-tune the Finger capacitance value. Coarse-tuning will satisfy the requirements of most designs, but fine-tuning will allow you to choose the most efficient CAPSENSE™ parameters (that is, minimum sensor scan time) using SmartSense.
If you do not know the value of CF (CF can be estimated based on Figure 6), set the Finger capacitance as follows:
-
Start by specifying the highest value for finger capacitance (from the available options in the list) and check the SNR and button status when the button is touched. Use the Tuner GUI to find the SNR
-
Decrease the finger capacitance parameter value until the button status changes to ‘1’ on touch and SNR>5. Figure 90 shows the detailed steps to find the right value for the Finger capacitance parameter in your design
Enable filters if the SNR of one or more sensors is less than 5:1 when the set finger capacitance is already at the least finger capacitance supported in the Component. You can also enable filters if externally induced noise is causing a decrease in SNR. See Table 10 to choose the right filter in this case. There are various types of filters available in the CAPSENSE™ Component such as Median Filter, IIR filter, and Average Filter; you can enable more than one filter to reduce the noise in the raw count according to the requirement.
If you choose to use an IIR filter, begin by selecting a filter with a higher value of the filter coefficient and keep decreasing it until you achieve an SNR greater than or equal to 5:1. Using filters will affect the response time. You must properly select the filter coefficient such that the response time and SNR requirement are satisfied.
If the SNR is still less than 5:1 even when the smallest allowed value of finger capacitance and proper filter is chosen, see PCB layout , Manual tuning, or Tuning debug FAQs for more details on debugging the issue.
Filter | Description | Mathematical description | Application |
---|---|---|---|
Median | Nonlinear filter that takes the three most recent samples and computes the median value. | y [ i ]median ( x [ i ] , x [ i − 1 ] , x [ i − 2 ] ) | Eliminates noise spikes from motors and switching power supplies |
Average | Finite impulse response filter (no feedback) with equally weighted coefficients. It takes the four most recent samples and computes their average. | y [ i ]1 4 × ( x [ i ] + x [ i − 1 ] + x [ i − 2 ] + x [ i − 3 ] ) | Eliminates periodic noise (for example, from power supplies) |
First Order IIR | Infinite impulse response filter (feedback) with a step response similar to an RC low pass filter, thereby passing the low-frequency signals (finger touch responses). K value is fixed to 256. N is the IIR filter raw count coefficient. A lower N value results in lower noise, but slows down the response. | y [ i ]
1 K × ( N × x [ i ] + ( K − N ) × y [ i − 1 ] ) | Eliminates high frequency noise. |
Hardware IIR | Enables the hardware IIR filter (see the equation on the right) for regular widgets (except Proximity and Low Power). iirRCcoef – IIR filter raw count coefficient; valid range: 0 to 8. A low coefficient means lower filtering, while a higher coefficient means a higher response time. Note: There is no filtering for coefficient value “0”. | R a w C o u n t
1 2 i i r R C c o e f R a w C o u n t N e w ( 1
1 2 i i r R C c o e f ) R a w C o u n t P r e v i o u s | Eliminates high-frequency noise. |
Tuning slider widgets
For sliders, set finger capacitance to the highest value initially. Slide your finger on the slider. If at any position on the slider, at least one slider segment status is ON and has an SNR >5:1, and at least two slider segments report a “difference count” that is, a “sensor signal” value greater than 0, use this finger capacitance value. Otherwise, decrease the finger capacitance value until the above condition holds true. Figure 91 shows how to tune the finger capacitance for slider widget.
If these conditions are not met even after setting minimum allowed Finger Capacitance, use Manual tuning or revise the hardware according to Slider design considerations or see Tuning debug FAQs. Figure 91 explains the process of setting finger capacitance value for sliders.
- To review slider design, see the Slider design section in the Design considerations chapter.
Tuning proximity widgets
See AN92239 Proximity sensing with CAPSENSE™ and the “Proximity sensing” section in Getting started with CAPSENSE™ design guide.
SmartSense hardware parameters-only mode
See Table 14 for the recommended values for thresholds when the CSD tuning method is SmartSense (Hardware parameters only).
SmartSense for initial tuning
See Using SmartSense to determine hardware parameters for more details.
Manual tuning
Overview
SmartSense technology allows a device to calibrate itself for optimal performance and complete the entire tuning process automatically. This technology will meet the needs of most designs, but in cases where SmartSense does not work or there are specific SNR or power requirements, the CAPSENSE™ parameters can be adjusted to meet system requirements. This can be achieved by manual tuning.
Some advantages of manual tuning, as opposed to SmartSense auto-tuning are:
-
Strict control over parameter settings: SmartSense sets all the parameters automatically. However, there may be situations where you need to have strict control over the parameters. For example, use manual tuning if you need to strictly control the time PSoC™ takes to scan a group of sensors or strictly control the sense clock frequency of each sensor (this can be done to reduce EMI in systems)
-
Supports higher parasitic capacitances: If the parasitic capacitance is higher than the value supported by SmartSense, you should use manual tuning. See the Component datasheet/middleware document for more details on the supported range of parasitic capacitance by SmartSense
The manual tuning process can be summarized in the following three steps and is shown in Figure 92.
Tune CAPSENSE™ component hardware parameters to ensure that Signal-to-noise is greater than 5:1 with a signal of at least 50 counts while meeting the system timing requirements.
Depending upon the sensing method selected, the manual tuning procedure will differ. See CSD sensing method (third- and fourth-generation), CSX sensing method (third- and fourth-generation) chapter for their respective manual tuning procedures. You can skip these sections if you are not planning to use manual tuning in your design. Figure 92 shows a general manual tuning procedure.
- To review the hardware design, see the Sensor construction and PCB layout guidelines sections in the Design considerations chapter.
CSD sensing method (third- and fourth-generation)
This section explains the basics of manual tuning using CSD sensing method. It also explains the hardware and software parameters that influence CSD sensing method and procedure of manual tuning for button, slider, touchpad and proximity widgets.
Basics
Conversion gain and CAPSENSE signal
Conversion gain will influence how much signal the system sees for a finger touch on the sensor. If there is more gain, the signal is higher, and a higher signal means a higher achievable Signal-to-noise ratio (SNR).
Conversion gain in single IDAC mode
In the single IDAC mode, the raw count is directly proportional to the sensor capacitance.
Where,
CS = sensor capacitance
CS = CP if there is no finger present on sensor
CS = (CP + CF) when there is a finger present on the sensor
GCSD = Capacitance to digital conversion gain of CAPSENSE™ CSD
The approximate value of this conversion gain using the IDAC sourcing mode, according to Figure 51 and Figure 93 is:
Where,
VREF = Comparator reference voltage. Refer Table 2.
FSW = Sense clock frequency
IMOD = Modulator IDAC current
N = Resolution of the sigma to delta converter.
The tunable parameters of the conversion gain are VREF, FSW, IMOD, and N. Figure 96 illustrates a plot of raw count versus sensor capacitance.
The change in raw counts when a finger is placed on the sensor is called CAPSENSE™ signal. Figure 97 shows how the value of the signal changes with respect to the conversion gain.
Figure 97 shows three plots corresponding to three conversion gain values GCSD3 ,GCSD2 ,and GCSD1 . An increase in the conversion gain results in higher signal value. However, this increase in the conversion gain also moves the raw count corresponding to CP (that is, Baseline) towards the maximum value of raw count (2N-1). For very high gain values, the raw count saturates as the plot of GCSD3 shows. Therefore, you should tune the conversion gain to get a good signal value while avoiding saturation of raw count. Tune the CSD parameters such that when there is no finger on the sensor, that is when CS = CP, the raw count = 85% of (2N-1) as Figure 98 shows. This ensures maximum gain, with enough margin for the raw count to grow because of environmental changes, and not saturate on finger touches.
Conversion gain in dual IDAC mode
The equation for raw count in the dual IDAC mode, according to Figure 93 and Figure 53 is:
Where,
ICOMP = Compensation IDAC current
GCSD is given by Figure 50 for sourcing IDAC mode and Figure 95 for sinking IDAC mode.
In both single IDAC and dual IDAC mode, tune the CSD parameters, so that when there is no finger on the sensor,that is when CS = , CP the raw count = 85% of (2N-1), as Figure 100 shows, to ensure high conversion gain, to avoid Flat-spots, and to avoid raw count saturation due to environmental changes.
As Figure 100 shows, the 85% requirement restricts to a fixed gain in single-IDAC mode, while in dual-IDAC mode, gain can be increased by moving the CS axis intercept to the right (by increasing ICOMP) and correspondingly decreasing the modulator IDAC (IMOD) to still achieve raw count = 85% of (2N-1) for CS = CP. Using dual IDAC mode this way brings the following changes to the Raw Count versus CP graph:
- Use of compensation IDAC introduces a non-zero intercept on the CS axis as given in .Figure 101. CS axis intercept with regards to ICOMP
CS axis intercept = (I COMP V REF F SW )
The value of IMOD in the dual IDAC mode is half compared to the value of IMOD in the single IDAC mode (all other parameters remaining the same), so the gain GCSD in the dual IDAC mode is double the gain in the single IDAC mode according to dual IDAC mode. Thus, the signal in the dual IDAC mode is double the signal in the single IDAC mode for a given resolution N.
While manually tuning a sensor, keep dual IDAC mode and Figure 77 as well as the following points in mind:
-
Higher gain leads to increased sensitivity and better overall system performance. However, do not set the gain such that raw counts saturate, as the plot of gain GCSD3 shows in Figure 97. It is recommended to set the gain in such a way that the raw count corresponding to CP is 85 percent of the maximum raw count for both the single IDAC and dual IDAC mode. The sense clock frequency (FSW) should be set carefully; higher the frequency, higher the gain, but the frequency needs to be low enough to fully charge and discharge the sensor as Figure 77 indicates
-
Enabling the Compensation IDAC plays a huge role in increasing the gain; it will double the gain if set as recommended above. Always enable the Compensation IDAC when it is not being used for general-purpose applications
-
Lower the modulation IDAC current, higher the gain. Adjust your IDAC to achieve the highest gain, but make sure that the raw counts corresponding to CP have enough margin for environmental changes such as temperature shifts, as indicated in Figure 98 and Figure 100
-
Increasing the number of bits of resolution used for scanning increases gain. An increase in resolution by one bit will double the gain of the system, but also double the scan time according to Figure 49. A balance of scan time and gain needs to be achieved using resolution
Flat-spots
Ideally, raw counts should have a linear relationship with sensor capacitance as Figure 96 and Figure 100 show. However, in practice, sigma delta modulators have non-sensitivity zones, also called flat-spots or dead-zones – for a range of sensor capacitance values, the sigma delta modulator may produce the same raw count value as Figure 102 shows. This range is known as a dead-zone or a flat-spot.
In the case of CAPSENSE™ CSD, these flat spots occur near 25, 50, and 75 percent of the maximum raw count value (that is, near 25%, 50%, and 75% of 2N-1, where N = Scan resolution). These flat spots are prominent when direct clock is used as Sense Clock source. Flat-spots do not occur if PRS is used as the Sense Clock source (see also section Using SmartSense to determine hardware parameters.
For almost all systems, we recommend using PRS as the Sense Clock source because it limits the impact of flat spots and also provides EMI/EMC benefits as indicated in Sense Clock. If your system requires a direct clock, ensure that you use auto-calibration or avoid this raw count range when using manual calibration.
Flat-spots reduction techniques
-
Calibrate rawcount to 85% In the case of CAPSENSE™ CSD, these flat-spots occur near 25, 50, and 75 percent of the maximum raw count value (that is, near 25%, 50%, and 75% of 2N-1, where ‘N’ is the scan resolution). Setting calibration to 85% decreases the width of flat-spots significantly.
-
Use PRS clock These flat-spots are prominent when direct clock is used as the Sense Clock source. Flat-spots do not occur if PRS is used as the Sense Clock source (refer to the Using SmartSense to determine hardware parameters section). For almost all systems, we recommend using PRS as the Sense Clock source because it limits the impact of flat-spots and also provides EMI/EMC benefits as indicated in Sense clock source. If your system requires a direct clock, ensure that you use auto-calibration or avoid this raw count range when using manual calibration.
Selecting CAPSENSE hardware parameters
CAPSENSE™ hardware parameters govern the conversion gain and CAPSENSE™ signal. Table 11 lists the CAPSENSE™ hardware parameters that apply to CSD sensing method. The following subsection gives guidance on how to adjust these parameters to achieve optimal performance for CAPSENSE™ CSD system.
For simplicity of documentation, this design guide shows selecting the CAPSENSE™ parameters in PSoC™ Creator. You can use the same procedure to set the parameters in ModusToolbox™. However, in ModusToolbox™, you set the Sense clock and Modulator clock using divider values while in the PSoC™ Creator you specify the frequency value directly in the configurator. For more details on configuring CAPSENSE™, see the Component datasheet/middleware document.
Sl. No. | CAPSENSE™ parameter in PSoC™ Creator | CAPSENSE™ parameter in ModusToolbox™ |
---|---|---|
1 | Sense cock frequency | Sense clock divider |
2 | Sense clock source | Sense clock source |
3 | Modulator clock frequency | Modulator clock divider |
4 | Modulator IDAC | Modulator IDAC |
5 | Compensation IDAC | Compensation IDAC |
6 | Scan resolution | Scan resolution |
Using SmartSense to determine hardware parameters
Parameters listed in Table 11 are CAPSENSE™ hardware parameters. Tuning these parameters manually for optimal value is a time-consuming task. You can use SmartSense to determine these hardware parameters and take it as an initial value for manual tuning. You can fine-tune these values to further optimize the scan time, SNR, power consumption, or improving EMI/EMC capability of the CAPSENSE™ system.
Set the tuning mode to SmartSense and configure default values for parameters other than finger capacitance. See the SmartSense section for the tuning procedure and use the Tuner GUI to read back all the hardware parameters set by SmartSense. See the Component datasheet/middleware document for more details on how to use the Tuner GUI.
Figure 103 shows the best hardware parameter values in the Tuner GUI that are tuned by SmartSense for a specific hardware to sense a minimum finger capacitance of 0.1 pF.
Manually tuning hardware parameters
Sense clock parameters
There are two parameters that are related to Sense clock: Sense clock source and Sense clock frequency.
Sense clock source
Select “Auto” to let the Component automatically choose the best sense clock source from Direct, PRSx, and SSCx for each widget. If not selecting Auto, then select the clock source based on the following:
-
Use pseudo random sequence (PRSx) modes to remove flat-spots
-
Use spread spectrum clock (SSCx) modes for reducing EMI/EMC noise at a particular frequency. This feature is available in the PSoC™ 4 S-Series, PSoC™ 4100S Plus, PSoC™ 4100PS, and PSoC™ 6 family of devices. In this case, the frequency of the sense clock is spread over a predetermined range
-
Use the direct clock for absolute capacitance measurement
When selecting PRSx as the sense clock source, ensure that the sequence completes within one conversion cycle; not letting the sequence complete may cause high noise in raw count, that is, TPRS<<TSCAN.
For PRS clock, use the following equations to calculate one PRS sequence completion cycle and scan time.
See the Component datasheet/middleware document for more details on the rules and recommendations for SSCx selection.
Sense clock frequency
The sense clock frequency should be selected so that the sensor will charge and discharge completely in each sense clock period as Figure 44 shows.
This requires that the maximum sense clock frequency be chosen per Figure 106.
Here, CP is the sensor parasitic capacitance, and RSeriesTotal is the total series-resistance, including the 500 Ω resistance of the internal switches, the recommended external series resistance of 560 Ω (connected on PCB trace connecting sensor pad to the device pin), and trace resistance if using highly resistive materials (example ITO or conductive ink);that is, a total of 1.06 kΩ plus the trace resistance.
The value for CP can be estimated using the CSD Built-in-Self-test API; GetSensorCapacitance(). See the Component datasheet/middleware document for details.
Figure 94 shows that it is best to use the maximum clock frequency to have a good gain; however, you should ensure that the sensor capacitor fully charges and discharges as shown in Figure 44.
Generally, the CP of the shield electrode will be higher compared to sensor CP. For good liquid tolerance, the shield signal should satisfy the condition mentioned in Shield electrode tuning theory. If it is not satisfied, reduce the sense clock frequency further to satisfy the condition.
Modulator clock frequency
The modulator clock governs the conversion time for capacitance-to-digital conversion, also called the “sensor scan time” (see Figure 49).
A lower modulator clock frequency implies the following:
Longer conversion time (see Figure 77 and Figure 75)
-
Lower peak-to-peak noise on raw count because of longer integration time of the sigma-delta converter
-
Wider Flat-spots
Select the highest frequency for the shortest conversion time and narrower flat spots for most cases. Use slower modulator clock to reduce peak-to-peak noise in raw counts if required.
Modulation and compensation IDACs
CSD supports two IDACs: Modulation IDAC and Compensation IDAC that charge CMOD as Figure 39 shows. These govern the Conversion gain in dual IDAC mode for capacitance-to-digital conversion. The CapSense Component allows the following configurations of the IDACs:
-
Enabling or disabling of Compensation IDAC
-
Enabling or disabling of Auto-calibration for the IDACs
-
DAC code selection for Modulator and Compensation IDACs if auto-calibration is disabled
Compensation IDAC
Enabling the compensation IDAC is called “dual IDAC” mode, and results in increased signal as explained in Conversion gain in dual IDAC mode. Enable the compensation IDAC for most cases. Disable the compensation IDAC only if you want to free the IDAC for other general-purpose analog functions.
Auto-calibration
This feature enables the firmware to automatically calibrate the IDAC to achieve the required calibration target of 85%. It is recommended to enable auto-calibration for most cases. Enabling this feature will result in the following:
-
Fixed raw count calibration to 85% of maximum raw count even with part-to-part CP variation
-
Avoids Flat-spots
-
Automatically selects the optimum gain
If your design environment includes large temperature variation, you may find that the 85% IDAC calibration level is too high, and that the raw counts saturate easily over large changes in temperature, leading to lower SNR. If this is the case, you can adjust the calibration level lower by using CapSense_CSDCalibrateWidget() in your firmware.
For proper functioning of CAPSENSE™ under diverse environmental conditions, it is recommended to avoid very low or high IDAC codes. For a 7-bit IDAC, it is recommended to use IDAC codes between 18-110 from the possible 0 to 127 range. You can use CAPSENSE™ tuner to confirm that the auto-calibrated IDAC values fall in this recommended range. If the IDAC values are out of the recommended range, based on Figure 93, Figure 94 and Figure 99, you may change the VRef or FSW to get the IDAC code in proper range.
Disable IDAC auto-calibration if a change in CP needs to be detected by measuring the raw count level at reset, for example:
-
Detecting large variations in sensor CP across boards or layout problems
-
Detecting finger touch at reset
-
Advanced CAPSENSE™ methods like liquid-level sensing, for example, to have different raw count level for different liquid levels at reset
Selecting DAC codes
This is not the recommended approach. However, this could be used only If you want to disable auto-calibration for any reason. To get the IDAC code, you may first configure CAPSENSE™ Component with auto-calibration enabled and all other hardware parameters the same as required for final tuning and read back the calibrated IDAC values using Tuner GUI. Then, re-configure the CAPSENSE™ Component to disable auto-calibration and use the obtained IDAC codes as fixed DAC codes read-back from the Tuner GUI.
Scan resolution
It governs the sensor scan time per Figure 104 and the conversion gain per Figure 93, Figure 94, and Figure 99. Scan resolution needs to be selected to maintain a balance between the signal and scan time.
Higher scan resolution implies the following:
-
Longer scan time per Figure 104
-
Higher SNR on raw counts (increase in resolution increases the signal at a disproportionate rate to noise)
In general, it is recommended to tune the resolution to achieve as high SNR as possible; however if the system is constrained on power consumption and/or response time, set the lowest resolution to achieve at-least 5:1 SNR in the end system.
Tuning shield electrode
The shield related parameters need to be additionally configured or tuned differently when you enable the Shield electrode in the CSD sensing method for liquid tolerance or reducing the Cp of the sensor.
Shield electrode tuning theory
Ideally, the shield waveform should be exactly the same as that of the sensor as explained in Driven shield signal and shield electrode. However, in practical applications, the shield waveform may have a higher settling time and an overshoot error. Observe the sensor and shield waveform in the oscilloscope; an example waveform is shown in Driven shield signal and shield electrode. The shield waveform should settle to the sensor voltage within 90% of ON time of the sense clock waveform and the overshoot error of the shield signal with respect to VREF should be less than 10%.
If these conditions are not satisfied, you will observe a change in raw count of the sensors when touching the shield hatch; in addition, if inactive sensors are connected to shield as mentioned in Inactive sensor connection, touching one sensor can cause change in raw count on other sensors, which indicates that there is cross talk if the shield electrode is not tuned properly.
In SmartSense, the sense clock frequency is automatically set. Check if these conditions are satisfied. If not satisfied, switch to Manual tuning and set the Sense clock frequency manually so that these conditions are satisfied. You can also tune the Shield SW resistance parameter to reduce the overshoot error.
Tuning shield-related parameters
Enable shield tank capacitor
Enabling a shield tank capacitor increases the drive strength of the shield thus allowing the shield signal to settle to the sensor voltage faster as required. It is recommended to use the shield tank capacitor for PSoC™ 4A-S and PSoC™ 6 MCU family of devices. For PSoC™ 4A, PSoC™ 4A-L, and PSoC™ 4A-M family of devices, the shield tank capacitor does not prove very advantageous because it doubles the shield series resistance. It is recommended to keep this option disabled for these device families.
Shield electrode delay
For proper operation of the shield electrode, the shield signal should match the sensor signal in phase. Due to the difference in trace lengths of the sensor and shield electrodes, the shield waveform may arrive earlier to the sensor waveform. You can use an oscilloscope to view both sensor and shield signals to verify this condition. If they are not aligned, use this option to add delay to the shield signal to align the two signals. Available delays vary depending on the device selected.
Shield SW resistance
This parameter controls the shield signal rise and fall times to reduce EMI. This parameter is valid only for PSoC™ 4 S-Series, PSoC™ 4100S Plus, PSoC™ 4100PS, and PSoC™ 6 MCU family of devices. The default value of shield switch resistance is Medium. Table 12 shows the effect of the Shield SW resistance value. You should select this value based on the application requirement; in addition, ensure that it satisfies the conditions in Shield electrode tuning theory.
Lower switch resistance | Higher switch resistance |
---|---|
Large overshoot error Higher electromagnetic emission Faster settling time that is, higher maximum sense clock frequency | Smaller overshoot error Lower electromagnetic emission Slower settling time that is, lower maximum sense clock frequency |
Number of shield electrodes
This parameter specifies the number of shield electrodes required in the design. Most designs work with one dedicated shield electrode; however, some designs require multiple dedicated shield electrodes for ease of PCB layout routing or to minimize the PCB real estate used for the shield layer. See Layout guidelines for shield electrode.
Inactive sensor connection
When the shield electrode is enabled for liquid-tolerant designs, or if you want to use shield to reduce the sensor parasitic capacitance, this option should be specified as “Shield”; otherwise, select “Ground”.
However, there is a risk of higher radiated emission due to inactive sensors getting connected to Shield. In such situations, use the CAPSENSE™ API to manually control inactive sensor connections. Instead of connecting all unused sensors to the shield, connect only the opposing inactive sensors or inactive sensors closer to the sensor being scanned to shield for reducing the radiated emission.
Selecting CAPSENSE software parameters
CAPSENSE™ software parameters govern the sensor status based on the raw count of a sensor. Table 13 provides a list of CAPSENSE™ software parameters. These parameters apply to both CSD and CSX sensing methods. This section defines these parameters with the help of Baseline, and provides guidance on how to adjust these parameters for optimal performance of your design. Table 14 shows the recommended values for the software threshold parameter and they are applicable for most of the designs. However, if there are any external noise present in the end system, you must modify these thresholds accordingly to avoid any sensor false trigger.
Sl. No. | CAPSENSE™ component parameter name in PSoC™ Creator/ModusToolbox™ |
---|---|
Finger threshold | |
Noise threshold | |
Hysteresis | |
ON debounce | |
Sensor auto-reset | |
Low baseline reset | |
Negative noise threshold |
Sl. No. | CAPSENSE™ threshold parameter | Recommended value |
---|---|---|
Finger threshold | 80 percent of signal | |
Noise threshold | 40 percent of signal | |
Hysteresis | 10 percent of signal | |
ON debounce | 3 | |
Low baseline reset | 30 | |
Negative noise threshold | 40 percent of signal |
Baseline
After tuning the CAPSENSE™ Component for a given CP, the raw count value of a sensor may vary gradually due to changes in the environment such as temperature and humidity. Therefore, the CAPSENSE™ Component creates a new count value known as baseline by low-pass filtering the raw counts. Baseline keeps track of, and compensates for, the gradual changes in raw count. The baseline is less sensitive to sudden changes in the raw count caused by a touch. Therefore, the baseline value provides a reference level for computing signal.
Figure 109 shows the concept of raw count, baseline, and signal.
Baseline update algorithm
To properly tune the CAPSENSE™ software, that is, the threshold parameters, it is important to understand how baseline is calculated and how the threshold parameters affect the baseline update.
Baseline is a low-pass-filtered version of raw counts. As Figure 110 shows, baseline is updated by low-pass-filtering raw counts if the current raw count is within a range of (Baseline – Negative noise threshold) to (Baseline + Noise threshold). If the current raw count is higher than baseline by a value greater than noise threshold, baseline remains at a constant value equal to prior baseline value.
If the current raw count is below baseline minus negative noise threshold, baseline again remains constant at a value equal to prior baseline value for Low baseline reset number of sensor scans. If the raw count continuously remains lower than baseline minus noise threshold for low baseline reset number of scans, the baseline is reset to the current raw count value and starts getting updated again, as Figure 111 shows.
Finger threshold
The finger threshold parameter is used along with the hysteresis parameter to determine the sensor state, as Figure 112 shows.
It is recommended to set finger threshold to 80 percent of the signal. This setting allows enough margin to reliably detect sensor ON/OFF status over signal variations across multiple PCBs.
Hysteresis
The hysteresis parameter is used along with the finger threshold parameter to determine the sensor state, as Figure 112 and Figure 113 show. Hysteresis provides immunity against noisy transitions of sensor state. The hysteresis parameter setting must be lower than the finger threshold parameter setting. It is recommended to set hysteresis to 10 percent of the signal.
Noise threshold
For single-sensor widgets, such as buttons and proximity sensors, the noise threshold parameter sets the raw count limit above which the baseline is not updated, as Figure 110 shows. In other words, the baseline remains constant as long as the raw count is above baseline + noise threshold. This prevents the baseline from following raw counts during a finger touch.
The noise threshold value should always be lower than the finger threshold – hysteresis. It is recommended to set noise threshold to 40 percent of the signal.
If the noise threshold is set to a low value, the baseline will remain constant if raw counts suddenly increase by a small amount, say because of small shifts in power supply or shifts in ground voltage because of high GPIO sink current and so on.
On the other hand, if the noise threshold is set to a value close to finger threshold – hysteresis, the baseline may keep updating even when the sensor is touched. This will lead to reduced signal
Negative noise threshold
The negative noise threshold parameter sets the raw count limit below which the baseline is not updated for the number of samples specified by the low baseline reset parameter as Figure 111 shows.
Negative noise threshold ensures that the baseline does not fall low because of any high amplitude repeated negative noise spikes on raw count caused by different noise sources such as electrostatic discharge (ESD) events.
It is recommended to set the negative noise threshold parameter value to be equal to the noise threshold parameter value.
Low baseline reset
This parameter is used along with the negative noise threshold parameter. It counts the number of abnormally low raw counts required to reset the baseline as Figure 111 shows.
If a finger is placed on the sensor during device startup, the baseline is initialized to the high raw count value at startup. When the finger is removed, raw counts fall to a lower value. In this case, the baseline should track the low raw counts. The Low Baseline Reset parameter helps to handle this event. It resets the baseline to the low raw count value when the number of low samples reaches the low baseline reset number.
The low baseline reset parameter should be set to meet following conditions:
-
Low baseline reset time is greater than the time for which negative noise (due to noise sources such as ESD events) is expected to last
-
Low baseline reset time is lower than the time in which a sensor is expected to start responding again after the finger kept on sensor during device startup is removed from the sensor
The low baseline reset parameter is generally set to a value of 30.
Debounce
This parameter selects the number of consecutive CAPSENSE™ scans during which a sensor must be active to generate an ON state from the component. Debounce ensures that high-frequency, high-amplitude noise does not cause false detection.
The Debounce parameter impacts the response time of a CAPSENSE™ system. The time it takes for a sensor to report ON after the raw counts value have increased above finger threshold + hysteresis because of finger presence, is given by Figure 116.
The Debounce parameter is generally set to a value of ‘3’ for reliable sensor status detection. It can be raised or lowered based on the noise aspects of the end user system.
Sensor auto reset
Enabling the Sensor Auto Reset parameter causes the baseline to always update regardless of whether the signal is above or below the noise threshold.
When auto reset is disabled, the baseline only updates if the current raw count is within a range of (Baseline – Negative Noise Threshold) to (Baseline + Noise Threshold) as Figure 110 shows and the Baseline update algorithm describes. However, when Auto Reset is enabled, baseline is always updated if the current raw count is higher than (Baseline – Negative Noise Threshold) as Figure 117 shows.
Because the baseline is always updated when sensor auto reset is enabled, this setting limits the maximum time duration for which the sensor will be reported as pressed. However, enabling this parameter prevents the sensors from permanently turning on if the raw count suddenly rises without anything touching the sensor. This sudden rise can be caused by a large power supply voltage fluctuation, a high-energy RF noise source, or a very quick temperature change.
Enable this option if you have a problem with sensors permanently turning on when the raw count suddenly rises without anything touching the sensor.
Multi-frequency scan
Enabling multi-frequency scan, the CAPSENSE™ component performs a sensor scan with three different sense clock frequencies and obtains corresponding difference count. The median of the sensor difference-count is selected for further processing. Use this feature for robust operation in the presence of external noise at a certain sensor scan frequency. This option is not available in SmartSense Full Autotune mode. See the code example CE227719 CAPSENSE™ with multi-frequency scan.
Button widget tuning
Figure 118 illustrates an overview of the CSD button tuning procedure.
To review the hardware design, see the Sensor construction and PCB layout guidelines sections in the Design considerations chapter. Also, see the Tuning debug FAQs section for guidelines on advanced debug.
As explained in Selecting between SmartSense and manual tuning, Manual tuning requires effort to tune optimum CAPSENSE™ parameters, but allows strict control over characteristics of capacitive sensing system, such as response time and power consumption. The button is tuned for reliable touch detection to avoid false triggers in noisy environment.
The CE230926 PSoC™ 4: CAPSENSE™ CSD button tuning explains tuning of self-capacitance based button widgets in the Eclipse IDE for ModusToolbox™ using the CAPSENSE™ Tuner GUI. For details on the Component and all related parameters, see the Component datasheet.
Slider widget tuning
A slider has many segments, each of which is connected to the CAPSENSE™ input pins of the PSoC™ device. Unlike the simple on/off operation of a button widget sensor, slider widget sensors work together to track the location of a finger or other conductive object. Because of this, the slider layout design should ensure that the CP of all the segments in a slider remain as close as possible. Keeping similar CP values between sensors will help minimize the tuning effort and ensure an even response across the entire slider. See Slider design for details on slider layout design guidelines to avoid nonlinearity in the centroid, ensure that the signal from all the slider segments is equal, as Figure 119 shows, when a finger is placed at the center of the slider segment. If the signal of the slider segments is different, then the centroid will be nonlinear, as Figure 120 shows.
A linear response for the reported finger position (that is, the Centroid position) versus the actual finger position on a slider requires that the slider design is such that whenever a finger is placed anywhere between the middle of the segment SLDn and middle of segment SLDn-1, other than the exact middle of slider segments, exactly two sensors report a valid signal 10. If a finger is placed at the exact middle of any slider segment, the adjacent sensors should report a difference count = noise threshold. These conditions are required since the centroid position calculation is based on the closest segment to the finger and two neighboring segments as shown in Figure 121.
Where,
Resolution = API resolution set in the CAPSENSE™ Component Customizer
n = Number of sensor elements in the CAPSENSE™ Component Customizer
x = Index of element which gives maximum signal
si = Different counts (with subtracted noise threshold value) of the slider segment
Figure 122 shows an overview of the CSD slider tuning procedure.
The upper crossover point (UCP) and lower crossover point (LCP) are obtained as shown inFigure 123. Refer to CE229521 – PSoC™ 4 CAPSENSE™ CSD Slider tuning which demonstrates how to manually tune a self-capacitance based Slider widget on PSoC™ Creator and CE230493 – PSoC™ 4: CAPSENSE™ CSD Slider tuning on Eclipse IDE for ModusToolbox™.
Touchpad widget tuning
Please refer to AN234185 PSoC™ 4 CAPSENSE™ Touchpad design guide for touchpad tuning guidelines.
Proximity widget tuning
For tuning a proximity sensor, see AN92239 - Proximity sensing with CAPSENSE™.
CSX sensing method (third- and fourth-generation)
This chapter explains the basics of manual tuning using the CSX sensing method. It also explains the hardware parameters that influence a manual tuning procedure.
Basics
Conversion gain and CAPSENSE signal
In a mutual-capacitance sensing system, the Rawcountcounter is directly proportional to the mutual-capacitance between the Tx and Rx electrodes, as Figure 124 shows.
Where,
GCSX = Capacitance to digital conversion gain of CAPSENSE™ CSX
CM = Mutual-capacitance between the Tx and Rx electrodes.
Figure 129 shows the relationship between raw count and mutual capacitance of the CSX sensor. The tunable parameters of the conversion gain in Figure 125 are FTX , NMOD , FMOD and IDAC.
The approximate value of this conversion gain is:
Where,
VTX = Voltage at the Tx node of the sensor as shown in Figure 127
The value of VTX is always VDDIO or VDDD (if VDDIO is not available) if the Tx clock frequency can completely charge and discharge the Tx electrode. FTX is the Tx clock frequency, IDAC is the current drawn for charging and discharging the CINT capacitors, and Nsub is the number of sub-conversions.
Selecting CAPSENSE hardware parameters
CAPSENSE™ hardware parameters govern the conversion gain and. Table 15 lists the CAPSENSE™ hardware parameters that apply to the CSX sensing method. Table 15 also shows the mapping of each parameter in the PSoC™Creator CAPSENSE™ component to the one in the ModusToolbox™ middleware. For simplicity of documentation, this design guide shows selecting the CAPSENSE™ parameter using the CAPSENSE™ configurator in PSoC™ Creator. The same procedure could be followed in configuring CAPSENSE™ in ModusToolbox™. However, in ModusToolbox™, you set the Tx clock and Modulator clock using divider values. On the other hand, in PSoC™ Creator, you specify the frequency value directly in the configurator. See Component datasheet/middleware document.
Sl # | CAPSENSE™ parameter in PSoC™ Creator | CAPSENSE™ parameter in ModusToolbox™ |
---|---|---|
1 | Modulator clock frequency | Modulator clock divider |
2 | Tx clock source | Tx clock source |
3 | Tx clock frequency | Tx clock divider |
4 | IDAC | IDAC |
5 | Number of sub-conversions | Number of sub-conversions |
Tx clock parameters
There are two parameters that are related to the Tx clock: Sense clock source and Sense clock frequency.
Tx clock source
Select “Auto” to let the Component automatically choose the best Tx clock source between Direct and Spread spectrum clock (SSCx) for each widget. If not selecting Auto, select the clock source based on the following:
-
Direct – Clock signal with a fixed clock frequency. Use this option for most cases
-
Spread spectrum clock (SSCx) – If you chose this option, the Tx clock signal frequency is dynamically spread over a predetermined range. Use this option for reduced EMI interference and avoiding Flat-spots
However, when selecting SSCx clock, you need to select the Tx clock frequency, Modulator clock frequency, and number of sub conversion such that the conditions mentioned in Component datasheet/ModusToolbox™ CAPSENSE™ configurator guide for SSCx clock source selection are satisfied.
Tx clock frequency
To minimize the scan time, as Figure 131 shows, it is recommended to use the maximum Tx clock frequency available in the component drop-down list that satisfies the criteria.
Where, NSub = Number of sub-conversions.
Additionally, if you are using the SSCx clock source, ensure that you select the Tx clock frequency that meets the conditions mentioned in Component datasheet/middleware document/ModusToolbox™ CAPSENSE™ configurator guide in addition to these conditions.
The maximum value of FTX depends on the selected device. For the PSoC™ 4 S-Series, PSoC™ 4100S Plus, PSoC™ 4100PS, and PSoC™ 6 MCU family of devices, the maximum FTX is 3000 kHz and for other devices it is 300 kHz.
Modulator clock frequency
It is best to choose the highest allowed clock frequency for the given device because a higher modulator clock frequency leads to a higher sensitivity/signal, increased accuracy, and lower noise for a given CM to digital count conversion as Figure 105 and Figure 106 indicate. Also, a higher value of Fmod/Ftx ensures lower width of Flat-spots in CM to raw count conversion.
IDAC
It is recommended to enable IDAC auto-calibration. It is best to avoid very high and very low IDAC codes. The recommended IDAC code range is between 30-90. If the IDAC values are away from the recommended range, tune the Tx clock frequency to adjust the IDAC level. If the IDAC is failing to calibrate properly, it may be due to low CM in the design. Refer to the section I am observing a low CM for my CSX button for mitigating impact of low CM in the design.
Number of sub-conversions
The number of sub-conversions decides the sensitivity of the sensor and sensor scan time. From Figure 57 for a fixed modulator clock and Tx clock, increasing the number of sub-conversions (NSub) increases the signal and SNR. However, increasing the number of sub-conversions also increases the scan time of the sensor per Figure 132.
Initially, set the value to a low number (for example, 20), and use the Tuner GUI to find the SNR of the sensor. If the SNR is not > 5:1 with the selected NSub, try to increase the NSub in steps such that the SNR requirement is met.
Selecting CAPSENSE software parameters
Button widget tuning
Figure 133 illustrates an overview of the CSX button tuning procedure.
- To review the hardware design, see the Sensor construction and PCB layout guidelines sections in the Design considerations chapter. Also, see the Tuning debug FAQs section for guidelines on advanced debug
The CE230660 PSoC™ 4: CAPSENSE™ CSX button tuning explains tuning of mutual-capacitance based button widgets in the Eclipse IDE for ModusToolbox™ and CE228931 – PSoC™ 4 CAPSENSE™ CSX button tuning in PSoC™ Creator using the CAPSENSE™ tuner. For details on the Component and all related parameters, see the Component datasheet.
Touchpad widget tuning
Please refer to AN234185 PSoC™ 4 CAPSENSE™ Touchpad design guide for touchpad tuning guidelines.
CSD-RM sensing method (fifth-generation and fifth-generation low-power)
This chapter explains the basics of manual tuning using CSD-RM sensing method (Fifth-Generation and Fifth-Generation Low-Power). It also explains the hardware and software parameters that influence the CSD-RM sensing method and the procedure of manual tuning for button, slider, touchpad and proximity widgets.
Basics
Conversion gain and CAPSENSE signal
Conversion gain will influence how much signal the system sees for a finger touch on the sensor. If there is more gain, the signal is higher, and a higher signal means a higher achievable Signal-to-noise ratio (SNR).
Conversion gain in single CDAC
In the single CDAC mode, the raw count is directly proportional to the sensor capacitance.
Where,
CS = Sensor capacitance
CS = CP if there is no finger present on sensor
CS = (CP
- CF) when there is a finger present on the sensor
GCSD = Capacitance to digital conversion gain of CAPSENSE™ CSD. The approximate value of this conversion gain according to Figure 66 and Figure 134 is shown using Figure 135.
Where,
The equation for raw count in the single CDAC mode, according to Figure 135 and Figure 134 is shown in Figure 136.
Where,
NSub = Number of sub-conversions
SnsClkDiv = sense clock divider
CS = Sensor capacitance
Cref = Reference capacitance
RefCDACCode = Reference CDAC value
The tunable parameters of the conversion gain are Cref, SnsClkDiv, and NSub. Figure 137 shows a plot of raw count versus sensor capacitance.
The change in raw counts when a finger is placed on the sensor is called CAPSENSE™ signal. Figure 138 shows how the value of the signal changes with respect to the conversion gain.
Figure 138 shows three plots corresponding to three conversion gain values GCSD3, GCSD2, and GCSD1. An increase in the conversion gain results in higher signal value. However, this increase in the conversion gain also moves the raw count corresponding to CP (that is, Baseline) towards the maximum value of raw count (Maxcount). For very high gain values, the raw count saturates as the plot of GCSD3 shows. Therefore, tune the conversion gain to get a good signal value while avoiding saturation of raw count. Tune the CSD-RM parameters such that when there is no finger on the sensor, that is when CS = CP, the raw count = 85% of Maxcount as Figure 139 shows. This ensures maximum gain, with enough margin for the raw count to grow because of environmental changes, and not saturate on finger touches.
Conversion gain in dual CDAC mode
The equation for raw count in the dual CDAC mode, according to Figure 67 and Figure 134 is shown in Figure 140.
Where,
Maxcount = NSub
- SnsClkDiv
SnsClkDiv = Sense clock divider
NSub = Number of sub-conversions
Cref = Reference capacitance
Ccomp = Compensation capacitance
CompCLKDiv = CDAC compensation divider
CS = Sensor capacitance
Cref = RefCDACCode * Clsb
Ccomp=CompCDACCode * Clsb
RefCDACCode = Reference CDAC value
CompCDACCode = Compensation CDAC value
Clsb = 8.86fF
GCSD is given by Figure 135.
In both single CDAC and dual CDAC mode, tune the CSD-RM parameters, so that when there is no finger on the sensor, that is when CS = CP, the raw count = 85% of Maxcount, as Figure 141 shows, to ensure high conversion gain, to avoid Flat-spots, and to avoid raw count saturation due to environmental changes.
As Figure 141 shows, the 85% requirement restricts to a fixed gain in single-CDAC mode, while in dual-CDAC mode, gain can be increased by moving the CS axis intercept to the right (by increasing CompClkDIV) and correspondingly decreasing the modulator CDAC switching (SnsClkDIV) to still achieve raw count = 85% of Maxcount for CS = CP. Using dual CDAC mode this way brings the following changes to the Raw Count versus CP graph:
Use of compensation CDAC introduces a non-zero intercept on the CS axis as shown in Figure 142Figure 142. CS axis intercept with regards to Ccomp
C
S
axis intercept
(
2 ×
C
c o m p
S n s C l k
D i v
C o m p C l k
D i v
)
The value of Cref in the dual CDAC mode is half compared to the value of Cref in the single CDAC mode (all other parameters remaining the same), so the gain GCSD in the dual CDAC mode is double the gain in the single CDAC mode according to Figure 94. Thus, the signal in the dual CDAC mode is double the signal in the single CDAC mode for a given number of sub-conversions (Nsub).
While manually tuning a sensor, refer Figure 94, Figure 99 and the following points:
-
Higher gain leads to increased sensitivity and better overall system performance. However, do not set the gain such that raw counts saturate, as the plot of gain GCSD3 shows in Figure 97. It is recommended to set the gain in such a way that the raw count corresponding to CP is 85 percent of the maximum raw count for both the single CDAC and dual CDAC mode
-
The sense clock frequency (FSW) should be set carefully; higher the frequency, higher the CS sampling rate which allows for more FSW periods and better noise averaging, but the frequency needs to be low enough to fully charge and discharge the sensor as Figure 106 indicates
-
Enabling the compensation CDAC (baseline compensation) plays a huge role In increasing the gain; it will double the gain if set as recommended in Conversion gain in dual CDAC mode. Always enable Compensation CDAC, make sure the calibrated Cref is in valid range when enabling Compensation CDAC
-
Lower the reference CDAC, higher the gain. Adjust your CDAC to achieve the highest gain, but make sure that the raw counts corresponding to CP have enough margin for environmental changes such as temperature shifts, as indicated in Figure 98 and Figure 100
-
Increasing the number of sub-conversions used for scanning increases gain. An increase in number of sub-conversions also increases the scan time according to Figure 49. A balance of scan time and gain need to be achieved using number of sub-conversions (Nsub)
Flat-spots
Ideally, raw counts should have a linear relationship with sensor capacitance as Figure 96 and Figure 100 show. However, in practice, RM converter has non-sensitivity zones, also called flat-spots or dead-zones – for a range of sensor capacitance values, the RM converter may produce the same raw count value as Figure 144 shows. This range is known as a dead-zone or a flat-spot.
Figure 143 shows the flat-spots relation to different CAPSENSE™ hardware parameters.
Where,
CS = Sensor capacitance
CMOD = Modulator capacitor
FSW = Frequency of the sense clock
FMOD = Modulator clock frequency
Bal% = Rawcount calibration percentage
Flat-spots reduction techniques
-
Set rawcount calibration to 85% As per Figure 143, flat-spots width is inversely proportional to calibration level. Setting calibration to 85% decrease the width of flat-spots significantly.
-
Enable dithering An additional Dither CDAC is available in Fifth-Generation CAPSENSE™ architecture, which adds white noise that moves the conversion point around the flat-spots region.
-
Enable PRS clock These flat-spots are prominent when direct clock is used as Sense Clock source. Flat-spots are reduced if PRS is used as the sense clock source (see also section Using SmartSense to determine hardware parameters). PRS clock can results in a slight reduction of signal or sensitivity at higher rawcount calibration. Recommended to set the rawcount calibration to 65% when PRS is used as clock source.
-
Use larger CMOD The flat-spots width is inversely proportional to the CMOD used. Fifth-Generation architecture supports CMOD upto 10 nF and typical value is 2.2 nF. And increasing CMOD have the adverse effect of increasing the noise, initialization time and minimum signal required to detect.
-
Increase sense clock divider Increasing sense clock divider decreases flat-spots width but increases the scan time. If the flat-spot is detected, increase the Sense clock divider such that the scan time requirement is met.
Table 16 lists different the flat-spots reduction techniques in recommended priority and other considerations.
S. No | Flat-spots reduction techniques | Recommendation | Additional benefits | Disadvantage |
---|---|---|---|---|
1 | Set rawcount calibration to 85%. | High | Improves sensitivity | |
2 | Enable dithering | High | ||
3 | Enable PRS clock | Low | Improves EMI/EMC radiation | Needs to set rawcount calibration to 65%. Decreases sensitivity. |
4 | Increase CMOD | Low | Increases noise | |
5 | Increase sense clock divider | Low | Increases scan time and power consumption |
Selecting CAPSENSE hardware parameters
CAPSENSE™ hardware parameters govern the conversion gain and CAPSENSE™ signal. Table 17 lists the CAPSENSE™ hardware parameters that apply to CSD-RM sensing method. The following subsections provide guidance on how to adjust these parameters to achieve optimal performance for CAPSENSE™ CSD-RM system.
S. No | CAPSENSE™ parameter in ModusToolBox™ |
---|---|
1 | Scan mode |
2 | Scan connection method |
3 | Number of Init sub-conversions |
4 | Sense clock divider |
5 | Sense clock source |
6 | Modulator clock divider |
7 | Reference CDAC value |
8 | CDAC compensation divider |
9 | Compensation CDAC value |
10 | Fine CDAC value |
11 | Number of sub-conversions |
12 | Enable CDAC dither |
5.3.4.2.1 and 5.3.4.2.2 show selecting the CAPSENSE™ parameters in Eclipse IDE for ModusToolbox™. For more details on configuring CAPSENSE™, see the Component datasheet/middleware document.
Using SmartSense to determine hardware parameters
Table 17 lists the CAPSENSE™ hardware parameters. Tuning these parameters manually for optimal value is a time-consuming task. Use SmartSense to determine these hardware parameters and take these as initial values for manual tuning. You can fine-tune these values to further optimize the scan time, SNR, power consumption, or improving EMI/EMC capability of the CAPSENSE™ system. Set the tuning mode to SmartSense and configure default values for the parameters other than finger capacitance, Sense clock source and CDAC dither. Set these per the application requirement.
See the SmartSense section for the tuning procedure and use the Tuner GUI to read back all the hardware parameters set by SmartSense. See the CAPSENSE™ tuner guide for more details on how to use the Tuner GUI.
Figure 145 shows the best hardware parameter values in the Tuner GUI that are tuned by SmartSense for a specific hardware to sense a minimum finger capacitance of 0.1 pF.
Manually tuning hardware parameters
Scan mode
Scan mode can be set as CS-DMA or Interrupt Driven mode. For autonomous scanning select DMA mode and for legacy interrupt based scanning select Interrupt Driven mode.
In Fifth-Generation Low-Power CAPSENSE™, autonomous scanning is supported inherently and does not need CPU intervention, and does not require CTRLMUX and DMA.
Sensor connection method
Autonomous scanning is only available in CTRLMUX method, but the numbers of supported pins are limited in this method (see the Device datasheet for supported pins). Additionally provides better immunity to on-chip IO noise. Choose AMUXBUS method to support more number of pins in Interrupt Driven mode.
In Fifth-Generation Low-Power CAPSENSE™, all CAPSENSE™ pins support autonomous scanning mode, via the AMUXBUS, compared to the limited number of pins which were supported by the CTRLMUX in the Fifth-Generation CAPSENSE™ technology.
Modulator clock frequency
The modulator clock governs the conversion time for capacitance-to-digital conversion, also called the “sensor scan time” (see Figure 49).
A lower modulator clock frequency implies the following:
Longer conversion time
-
Lower peak-to-peak noise on raw count because of longer integration time of the ratiometric converter
-
Wider Flat-spots
Select the highest frequency for the shortest conversion time and narrower flat-spots for most cases. Use slower modulator clock to reduce peak-to-peak noise in raw counts if required.
Based on the required Modulator clock frequency (FMOD), calculate the modulator clock divider using Figure 146.
Where,
FClock = Clock frequency connected to CAPSENSE™ block
Initialization sub-conversions
As part of initialization, CMOD1 and CMOD2 need to be charged to the required voltage (VDDA/2). There are three phases in initialization – CMOD initialization, CMOD short and initialization sub-conversions. During CMOD initialization phase, CMOD1 is pulled to GND and CMOD2 is pulled to VDDA. During CMOD short phase both capacitors are tied together so the charge is shared to produce a voltage close to VDDA/2 on both. After these two phases the scanning is started, but rawcount is discarded for the configured number of init sub-conversions.
The number of init sub-conversions should be selected based on Figure 147.
Where,
CMOD = Modulator capacitor
VOS = Comparator offset voltage (3 mV)
CS = Sensor capacitance
Base% = Baseline compensation percentage
Bal% = Rawcount calibration percentage
SnsClkDiv = sense clock divider
Cref = Reference capacitance
Cref = RefCDACCode * Clsb
RefCDACCode = Reference CDAC value
Clsb = 8.86 fF
Sense clock parameters
There are two parameters that are related to Sense clock: Sense clock source and Sense clock divider.
Sense clock source
Select “Auto” to let the Component automatically choose the best Sense clock source from Direct, PRSx, and SSCx for each widget. If not selecting Auto, select the clock source based on the following:
-
Use SSCx (spread spectrum clock) modes for reducing EMI/EMC noise at a particular frequency. This feature is available in PSoC™ 4S-Series, PSoC™ 4100S Plus, PSoC™ 4100PS, PSoC™ 4100S Max, PSoC™ 4000T and PSoC™ 6 family of devices. In this case, the frequency of the sense clock is spread over a predetermined range
-
Use Direct clock for absolute capacitance measurement
-
Use PRSx (pseudo random sequence) modes to remove flat-spots and improve EMI/EMC radiation. In 5th Generation CAPSENSE™, PRS clock results in a slight reduction in signal/sensitivity at higher rawcount calibration percent, hence 65% rawcount calibration is recommended when PRS clock is used
When selecting SSCx, you need to select the Sense clock frequency, Modulator clock frequency, and number of sub-conversion such that the conditions mentioned in ModusToolbox™ CAPSENSE™ configurator guide for SSCx clock source selection are satisfied.
PRS/SSC can be used to reduce the emissions, but it will increase power consumption as it needs high Nsubs. It is recommended to set Nsubs as 1024(or multiples of 1024) to obtain the maximum spread. If Nsubs are lesser than 1024 or non-multiples of 1024, the performance will be non-optimal.
Sense clock divider
The sense clock divider should be selected so that the sensor will charge and discharge completely in each sense clock period.
This is verified by observing the charging and discharging waveforms of the sensor using an oscilloscope and an active probe. The sensors should be probed close to the electrode and not at the sense pins or the series resistor.
Refer to Figure 148 and Figure 149 for waveforms observed on the sensor/shield. Figure 148 shows proper charging when the sense clock frequency is correctly tuned. The pulse width is at least 5Tau, that is, the voltage is reaching at least 99.3% of the required voltage at the end of each phase. Figure 149 shows incomplete settling (charging/discharging). If the charging is incomplete, increase the sense clock divider.
Repeat this process for all the sensors and the shield. Each sensor may require a different sense clock divider value to charge/discharge completely. But all the sensors that are in the same scan slot need to have the same sense clock source, sense clock divider, and number of sub-conversions. Therefore, take the largest sense clock divider in a given scan slot and apply it to all the other sensors that share that slot. Take this into consideration that a higher sense clock divider increases current consumption as there are longer charging and discharging cycles. Generally, the CP of the shield electrode will be higher compared to the sensor CP.
For good liquid tolerance, the shield signal should satisfy the condition mentioned in the Tuning shield electrode chapter. If it is not satisfied, reduce the sense clock frequency further to satisfy the condition.
Figure 135 shows that it is best to use the maximum clock frequency to achieve higher gain; however, you should ensure that the sensor capacitor fully charges and discharges as shown in Figure 63.
Number of sub-conversions
The number of sub-conversions decides the sensitivity of the sensor and sensor scan time. From Figure 67 for a fixed modulator clock and Sense clock, increasing the number of sub-conversions (NSub) increases the signal and SNR. However, increasing the number of sub-conversions also increases the scan time of the sensor per Figure 151.
Initially, set the value to a low number, and use the Tuner GUI to find the SNR of the sensor. If the SNR is not > 5:1 with the selected, try to increase the in steps such that the SNR requirement is met.
Capacitive DACs
-
Enabling or disabling of Compensation CDACs
-
Enabling or disabling of Auto-calibration for the CDACs
-
Compensation CDAC divider and DAC codes for Reference and Compensation CDACs can be set manually if auto-calibration is disabled
Table 18 showcases different numbers of valid CDAC combinations that can be set in the CAPSENSE™ configurator.
Sr. no. | Cref | Cfine | Ccomp |
---|---|---|---|
1 | Auto | Auto | Auto |
2 | Auto | Auto | Disabled |
3 | Auto | Disabled | Auto |
4 | Auto | Disabled | Disabled |
5 | Value | Value | Auto |
6 | Value | Value | Value |
7 | Value | Value | Disabled |
8 | Value | Disabled | Auto |
9 | Value | Disabled | Value |
10 | Value | Disabled | Disabled |
11 | Disabled | Auto | Auto |
12 | Disabled | Auto | Disabled |
13 | Disabled | Value | Auto |
14 | Disabled | Value | Value |
15 | Disabled | Value | Disabled |
Cref boost parameter can be used to adjust the sensitivity of reference CAPDAC, which can be used only with combinations 1 and 3, where Compensation CDAC (Ccomp) and reference CAPDAC are set to "Auto".
Reference CDAC (Cref)
The reference CDAC is used to compensate for the charge transferred by the sensor self-capacitance (CS) from the CMOD. The number of times it is switched depends on the self-capacitance of the sensor. In the case of a finger placed over the sensor, additional reference CDAC switching is required to compensate.
Cref is calculated using the following equation:
Where,
RefCDACCode = Reference CDAC value
Clsb = 8.86 fF
Cref should satisfy the below criteria:
If the auto-calibrated RefCDACCode is less than 6, then enable fine CDAC.
The following options can be used to increase the RefCDACCode,
-
Decrease the sense clock divider. Note that the pulse width of the sense clock should be long enough to allow the sensor capacitance to charge and discharge completely. This decreased sense clock can be accommodated by decreasing series resistance or decreasing shield Cp
-
Disable compensation
Fine Reference CDAC (Cfine)
The fifth-generation low-power CAPSENSE™ consists of a Fine CDAC, which is a programmable CDAC used to achieve a finer resolution for the Reference CDAC. Hence, enabling Cfine along with Cref increases the accuracy. It is recommended to always enable auto-calibration for Fine CDAC to ensure optimal performance.
Cfine = Fine Reference CDAC = FineCDACCode * Clsb
FineCDACCode = Fine CDAC value
Clsb = 2.2 nF
Compensation CDAC (Ccomp)
The compensation capacitor is used to compensate excess self-capacitance from the sensor to increase the sensitivity. The number of times it is switched depends on the amount of charge the user application is trying to compensate (remove) from the sensor self-capacitance.
Compensation CDAC divider
The number of times the compensation capacitor is switched in a single sense clock is denoted by Kcomp. Select CDAC compensation divider based on Figure 152 such that below criteria is satisfied.
- CDAC compensation divider >= 4
Kcomp should be a whole numberFigure 152. CDAC compensation divider
CDAC compensation divider
S e n s e c l o c k d i v i d e r
K
c o m p
Auto-calibration
The auto-calibration feature enables the firmware to automatically calibrate the CDAC to achieve the required calibration target of 85%. It is recommended to enable auto-calibration for most cases. Enabling this feature will result in the following:
-
Default calibration is set to 85% of maximum raw count even with part-to-part CP variationNote: If the raw counts are saturating at 85%, the calibration percentage can be reduced further to avoid saturation.
-
Decrease the effect of Flat-spots
If your design environment includes large temperature variation, you may find that the 85% CDAC calibration level is too high, and that the raw counts saturate easily over large changes in temperature, leading to lower SNR. In this case, adjust the calibration level lower by using Cy_CapSense_CalibrateAllSlots() in your firmware.
For proper functioning of CAPSENSE™ under diverse environmental conditions, it is recommended to avoid very low or high CDAC codes. For an 8-bit CDAC, it is recommended to use CDAC codes between 6-200 from the possible 0 to 255 range. You can use CAPSENSE™ tuner to confirm that the auto-calibrated CDAC values fall in this recommended range. If the CDAC values are out of the recommended range, based on Figure 134, Figure 135, and Figure 140, you may change the Calibration level or Fmod or FSW to get the CDAC code in proper range.
Selecting CDAC codes
This is not the recommended approach. However, this approach could be used only if you want to disable auto-calibration for any reason. To get the CDAC code, you may first configure CAPSENSE™ Component with auto-calibration enabled and all other hardware parameters the same as required for final tuning and read back the calibrated CDAC values using Tuner GUI. Then, re-configure the CAPSENSE™ Component to disable auto-calibration and use the obtained CDAC codes as fixed DAC codes read-back from the Tuner GUI.
CDAC dither
As the input capacitance is swept, the raw count should increase linearly with capacitance. There are regions where the raw count does not change linearly with input capacitance, and these are called flat-spots. See section Flat-spots for more details. Dithering helps to reduce flat-spots. This is done using a dither CDAC. The dither CDAC adds white noise that moves the conversion point around the flat region.
It is recommended to always enable CDAC dither scale in auto-calibrated mode to ensure optimal performance. In case it is required to set the CDAC dither scale manually, see the following table for general recommended values.
Parasitic Capacitance (Cp) | Scale |
---|---|
2 pF <= Cp < 3 pF | 3 |
3 pF <= Cp < 5 pF | 2 |
5 pF <= Cp < 10 pF | 1 |
Cp >= 10 pF | 0 |
For details on setting dither related parameters, refer to the Readme of code example PSoC™ 4: MSCLP CAPSENSE™ low power (section 'Stage 2: Measure sensor capacitance to set CDAC Dither parameter')
Tuning shield electrode
The shield related parameters need to be additionally configured or tuned differently when you enable the Shield electrode in the CSD-RM sensing method for liquid tolerance or reducing the Cp of the sensor.
Shield electrode tuning theory
If these conditions are not satisfied, you will observe a change in raw count of the sensors when touching the shield hatch; in addition, if inactive sensors are connected to shield as mentioned in Inactive sensor connection, touching one sensor can cause change in raw count on other sensors, which indicates that there is cross talk if the shield electrode is not tuned properly.
Keep in mind that the higher sense clock divider increases current consumption as there is longer charging and discharging cycles. Generally, the CP of the shield electrode will be higher compared to the sensor CP. For good liquid tolerance, approximate maximum shield frequency (FShield) ensures correct charging and discharging of the shield waveform. If it is not satisfied, reduce the sense clock frequency further to satisfy the condition.
In SmartSense, the sense clock frequency is automatically set. Check if these conditions are satisfied. If not satisfied, switch to Manual tuning and set the sense clock frequency manually so that these conditions are satisfied.
Tuning shield-related parameters
Inactive sensor connection
When the shield electrode is enabled for liquid-tolerant designs, or if you want to use shield to reduce the sensor parasitic capacitance, this option should be specified as “Shield”; otherwise, select “Ground”.
However, there is a risk of higher radiated emission due to inactive sensors getting connected to Shield. In such situations, use the CAPSENSE™ API to manually control inactive sensor connections. Instead of connecting all unused sensors to the shield, connect only the opposing inactive sensors or inactive sensors closer to the sensor being scanned to shield for reducing the radiated emission.
Number of shield electrodes (total shield count)
This parameter specifies the number of shield electrodes required in the design. Most designs work with one dedicated shield electrode; however, some designs require multiple dedicated shield electrodes for ease of PCB layout routing or to minimize the PCB real estate used for the shield layer. See Layout guidelines for shield electrode Layout guidelines for shield.
Shield mode
Selecting CAPSENSE software parameters
Configuring autonomous scan
Autonomous scanning improves CPU offloading by removing the requirement of CPU intervention in between sensor scans. Figure 155 shows the waveform of scanning all slots, which shows the CAPSENSE™ CPU bandwidth requirement for autonomous scanning and interrupt driven scanning. In autonomous scan once the CPU initiates a command to scan all slots, there is no CPU interrupt raised by CAPSENSE™ until all the slots are scanned. But in interrupt driven scan, after each slot scan, a CPU interrupt is raised to configure the next slot sensors.
In fifth-generation CAPSENSE™, autonomous scanning is only available when Scan mode is set as Chained Scanning – DMA (CS-DMA) in the CAPSENSE™ configurator as shown in Figure 156. And sensor connection method is only available as CTRLMUX. This limits the number of available CAPSENSE™ sensors. In Interrupt driven mode, sensor connection can be configured as either AMUXBUS or CTRLMUX. Through AMUXBUS any GPIO pin can be configured as a CAPSENSE™ sensor,but CPU interrupts need to be serviced to read the scan result and configure the next sensor.
In fifth-generation low-power CAPSENSE™ regular widgets are scanned autonomously by default. CPU can remain in deep sleep mode while the scanning happens. An interrupt can wake the CPU to process the data, after all the slots are scanned Low power widgets are scanned using the low-power always-on-sense (LP-AoS) mode as explained in LP-AoS mode.
Autonomous scanning
Autonomous scanning mode in Fifth-Generation CAPSENSE™ technology avoids the CPU intervention for scanning every next sensor. This significantly reduces the CPU bandwidth required for scanning widgets withlarge number of sensors. Based on the CAPSENSE™ generation there are the following methods of autonomous scanning - Chained scanning – DMA mode and LP-AoS mode.
Chained scanning – DMA mode
In the chained scanning - DMA mode, DMA handles the configuration of each sensor, thereby avoiding the requirement of CPU intervention after each sensor scan completion. Each channel of MSC block requires four channels of DMA to be configured in the device configurator as shown in Figure 157.
Figure 158 illustrates the flow of CS-DMA based scanning mode.
-
Write DMA channel Write DMA is configured to transfer scan configuration of a sensor to MSC block. Source address to the corresponding sensor’s scan configuration is received from Chain Write DMA channel
-
Chain Write DMA channel When the MSC block completes scanning of current sensor, it will trigger the DMA to transfer the source address of next sensor’s or first sensor’s (if it is a new scan) scan configuration to the Write DMA channel
-
Read DMA channel Read DMA channel transfer the scan result (rawcount) to destination location of corresponding sensor
-
Chain Read DMA channel Once the current sensor scan is completed by MSC block, Chain Read DMA is triggered to transfer the destination location (address) of current sensor scan result (rawcount) to the Read DMA channel
LP-AoS mode
The fifth-generation CAPSENSE™ (MSCLP) performs autonomous sensing using the LP-AoS hardware mode. Using this mode, multiple sensors (a frame) can be scanned without the intervention of the CPU. To enable this, the MSCLP block has an internal 1-KB SRAM. The middleware writes the configuration of multiple sensors to be scanned to the internal SRAM. Then, the MSCLP autonomously reads each sensor configuration, initiates scanning, and saves the result to the SRAM for the middleware to read and process after full-frame scanning is completed.
The device can be kept in any device power modes such as active, sleep, or deep sleep while MSCLP is scanning multiple sensors. MSCLP has all the system resources such as high-frequency clock and reference generator internal to the MSCLP hardware to enable scanning in device low-power state (i.e., deep sleep).
Wake-on-Touch (WoT)
LP-AoS has the additional capability of scanning the same frame periodically and processing the result to detect touch. Therefore, the CPU is not required to process or initiate scanning; this allows the PSoC™ device to be kept in deep sleep for a longer time and to have the sensor touch detection as a wakeup interrupt. This is known as Wake-on-Touch. With this approach, the application can get the lowest power consumption with touch-sensing capability. Note that WoT is only supported for Low-Power Widgets. See section Low-power widget tuning for details on Low-Power Widgets.
Multi-channel scanning
Multi-channel design uses both the instances of CAPSENSE™ MSC0 and MSC1, leading to simultaneous operation and reduction in scan time. Multi-channel scanning is in lock step thereby avoiding any cross-channel noise coupling. Scan synchronization is required to have the scanning in lock step. Fifth-Generation CAPSENSE™ technology has built in ability for multi-channel synchronization and CPU is not required for this.
Multi-channel operation is an added advantage to support applications such as large touchpad, which require many sensor pins for interfacing. For example, a 6x8 touchpad can be configured as shown in Figure 160. In this figure, the sensors shown in blue color is scanned by channel 0 (MSC0) and green color is scanned by channel 1 (MSC1).
In this case, channel 0 and channel 1 can scan one of its sensors at the same time. To avoid any cross-talk noise, sensors to be scanned together should be selected such that the physical distance between the two sensor is as maximum as possible, and should avoid combining row and column sensors.
In the above example, the recommended scan configuration is as shown in Table 20. All the sensors that belong to same slot is scanned together.
Slot # | Channel 0 sensor | Channel 1 sensor |
---|---|---|
Slot 0 | Col 0 | Col 4s |
Slot 1 | Col 1 | Col 5 |
Slot 2 | Col 2 | Col 6 |
Slot 3 | Col 3 | Col 7 |
Slot 4 | Row 0 | Row 3 |
Slot 5 | Row 1 | Row 4 |
Slot 6 | Row 2 | Row 5 |
Button widget tuning
Button widget tuning section provides high-level steps for tuning CSD button. The CE231078 PSoC™ 4: MSC CAPSENSE™ CSD Button Tuning explains tuning of self capacitance-based button widgets in the Eclipse IDE for ModusToolbox™. For details on the Component and all related parameters, see the Component datasheet.
Slider widget tuning
Slider widget tuning section provides high-level steps for tuning CSD slider. The CE232776 PSoC™ 4: MSC CAPSENSE™ CSD slider tuning explains tuning of self-capacitance-based slider widgets in the Eclipse IDE for ModusToolbox™. For details on the Component and all related parameters, see the Component datasheet.
Touchpad widget tuning
Refer to the AN234185 PSoC™ 4 CAPSENSE™ Touchpad design guide for touchpad hardware and firmware design guidelines, along with tuning guidelines. The CE235338 PSoC™ 4: MSCLP self-capacitance touchpad tuning code example explains the tuning of self-capacitance-based touchpad widgets in the Eclipse IDE for ModusToolbox™.
For details on the PSoC™ Creator based CAPSENSE™ Component and all related parameters, see the Component datasheet.
Proximity widget example
For tuning a proximity sensor, see AN92239 - Proximity sensing with CAPSENSE™.
Low-power widget tuning
The CE235111 – PSoC™ 4: MSCLP CAPSENSE™ low power CSD Button Tuning explains the tuning of a low-power widget in the Eclipse IDE for ModusToolbox™.
CSX-RM sensing method (fifth-generation and fifth-generation low-power)
This section explains the basics of manual tuning using the CSX-RM sensing method for the fifth-generation and fifth-generation low-power devices. It also explains the hardware parameters that influence the manual tuning procedure.
Basics
Conversion gain and CAPSENSE signal
Conversion gain influences how much signal count the system observes for a finger touch on the sensor. If there is more gain, the signal is higher, and a higher signal means a higher achievable Signal-to-noise ratio (SNR). Note that an increased gain may result in an increase in both signal and noise. However, if required, you can use firmware filters to decrease noise. For details on available firmware filters, see Table 10.
Conversion gain in single CDAC In a mutual-capacitance sensing system, the rawcount counter is directly proportional to the mutual-capacitance between the Tx and Rx electrodes, as Figure 161 shows. Figure 161. Raw count relationship to sensor capacitance
R a w c o u n t
c o u n t e r
=
G
C S X
C
M
Where,
GCSX = Capacitance to digital conversion gain of CAPSENSE™ CSX
CM = Mutual-capacitance between the Tx and Rx electrodes
Figure 101 shows the relationship between raw count and mutual-capacitance of the CSX sensor. The tunable parameters of the conversion gain in Figure 162 are Cref, TxClkDiv and NSub.
The approximate value of this conversion gain is: Figure 162. Capacitance to digital converter gain
G
C S X
= M a x C o u n t
2
C
r e f
T x C l k
D i v
Where, MaxCount = NSub
- TxClkDiv
The equation for raw count in the single CDAC mode, according to Figure 161 and Figure 162 is shown in Figure 163. Figure 163. Single CDAC mode raw counts
R a w c o u n t
C o u n t e r
=
N
S u b
2 ×
C
M
C
r e f
Where,
NSub = Number of sub-conversions
TxClkDiv = Tx clock divider
CM = Sensor mutual-capacitance
RefCDACCode = Reference CDAC value
Clsb = 8.86 fF
The tunable parameters of the conversion gain are Cref, TxClkDiv, and NSub. Figure 164. Voltage at Tx node of the CSX sensor
Note: The raw count observed from the Component is given by Figure 165. See CAPSENSE™ CSX-RM sensing method (fifth-generation and fifth-generation low-power) for more details on Rawcountcomponent.Figure 165. Rawcountcomponent
R a w c o u n t
C o m p o n e n t
M a x C o u n t −
R a w c o u n t
C o u n t e r
Figure 166. Raw count vs sensor mutual-capacitance
Conversion gain in dual CDAC mode The equation for raw count in the dual CDAC mode, according to Figure 78 and Figure 161 is shown in Figure 167. Figure 167. Dual CDAC mode raw counts
rawcount
G
C S X
C
M
− M a x c o u n t
2 ×
C
c o m p
C
r e f
C o m p C L K
d i v
Where,
Maxcount = NSub *SnsClkDiv
SnsClkDiv = Sense clock divider
NSub = Number of sub-conversions
Cref = Reference capacitance = RefCDACCode*Clsb
Ccomp = Compensation capacitance = CompCDACCode*Clsb
CompCLKDiv = CDAC compensation divider
CM = Sensor mutual-capacitance
RefCDACCode = Reference CDAC value
CompCDACCode = Compensation CDAC value
Clsb = 8.86 fF
GCSX is given by Figure 162
Selecting CAPSENSE hardware parameters
CAPSENSE™ hardware parameters govern the conversion gain and CAPSENSE™ signal. Table 21 lists the CAPSENSE™ hardware parameters that apply to the CSX-RM sensing method for the fifth-generation devices.
S. No | CAPSENSE™ parameter in ModusToolBox™ |
---|---|
1 | Tx clock divider |
2 | Tx clock source |
3 | Modulator clock divider |
4 | Reference CDAC value |
5 | CDAC compensation divider |
6 | Compensation CDAC value |
7 | Fine CDAC value |
8 | Number of sub-conversions |
9 | Enable CDAC dither |
Scan mode
Scan mode can be set as CS-DMA or Interrupt Driven mode. For autonomous scanning select DMA mode and for legacy interrupt based scanning select Interrupt Driven mode.
In fifth-generation low-power CAPSENSE™, autonomous scanning is supported inherently and does not need CPU intervention, and does not require CTRLMUX and DMA.
Sensor connection method
Autonomous scanning is only available in the CTRLMUX method, but the number of supported pins are limited in this method (see the Device datasheet for supported pins). Additionally, this method provides better immunity to on-chip I/O noise. Choose the AMUXBUS method to support more number of pins in the Interrupt Driven mode.
In the CTRLMUX connection method for CSX sensors, choose the inactive sensor connection as VDDA/2 and ensure to add empty scan slots before the first sensor scan for initializing the voltages on Rx lines to VDDA/2.
In fifth-generation low-power CAPSENSE™, all CAPSENSE™ pins support the autonomous scanning mode, via the AMUXBUS, compared to the limited number of pins, which were supported by the CTRLMUX in the fifth-generation CAPSENSE™ technology.
Modulator clock frequency
It is best to choose the highest allowed clock frequency for the given device because a higher modulator clock frequency leads to a higher sensitivity/signal, increased accuracy, and lower noise for a given CM to digital count conversion as Figure 161 and Figure 162 indicates. Also, a higher value of FMOD/FTX ensures lower width of Flat-spots in CM to raw count conversion.
Initialization sub-conversions
As part of initialization, CMODs need to be charged at the required voltage (VDDA/2). There are three phases in initialization – CMOD initialization, CMOD short, and initialization sub-conversions. During the CMOD initialization phase, CMOD1 is pulled to GND and CMOD2 is pulled to VDDA. During the CMOD short phase, both capacitors are tied together so the charge is shared to produce a voltage close to VDDA/2 on both. After the two phases, the scanning is started but rawcount is discarded for a specific number of init sub-conversions.
Select the number of init sub-conversions based on Figure 168.
Where,
CMOD = Modulator capacitor
VOS = Comparator offset voltage (3mV of PSoC™ 4100S Max device)
CM = Sensor mutual-capacitance
Base% = Baseline compensation percentage
Bal% = Rawcount calibration percentage
Cref = Reference capacitance = RefCDACCode * Clsb
RefCDACCode = Reference CDAC value
Clsb = 8.86 fF
Tx clock parameters
There are two parameters that are related to the Tx clock: Sense clock source and Sense clock frequency.
Tx clock source
Select “Auto” as the clock source for the Component to automatically select the best Tx clock source between Direct and Spread Spectrum Clock (SSCx) for each widget. If the “Auto” option is not selected, then choose the clock source based on the following:
-
Direct – Clock signal with a fixed-clock frequency. Use this option for most cases
-
Spread spectrum clock (SSCx) – If you choose this option, the Tx clock signal frequency is dynamically spread over a predetermined range. Use this option for reduced EMI interference and avoiding flat-spots. However, when selecting the SSCx clock, ensure to select the Tx clock frequency, modulator clock frequency, and number of sub-conversions such that the conditions mentioned in Component datasheet/ModusToolbox™ CAPSENSE™ configurator guide for the SSCx clock source selection are satisfied
-
Pseudo Random Sequence (PRSx) – Use PRSx (pseudo random sequence) modes to remove flat-spots and improve EMI/EMC radiation and susceptibility. In 5th Generation CAPSENSE™, PRS clock introduces signal/sensitivity loss at higher rawcount calibration percent, hence 65% rawcount calibration is recommended when PRS clock is used
When selecting SSCx, you need to select the Sense clock frequency, Modulator clock frequency, and number of sub-conversions such that the conditions mentioned in the ModusToolbox™ CAPSENSE™ configurator guide for SSCx clock source selection are satisfied.
PRS/SSC can be used to reduce the emissions, but it increases power consumption as it needs high Nsubs. It is recommended to set Nsubs as 1024 (or multiples of 1024) to obtain the maximum spread. If Nsubs are lesser than 1024 or non-multiples of 1024, the performance will be non-optimal.
Tx clock frequency
The Tx clock frequency determines the duration of each sub-conversion, as explained in the CAPSENSE™ CSX-RM sensing method (fifth-generation) section. The Tx clock divider should be configured such that the pulse width of the Tx clock is long enough to allow the sensor capacitance to charge and discharge completely. This is verified by observing the charging and discharging waveforms of the sensor using an oscilloscope and an active probe. The sensors should be probed close to the electrode and not at the sense pins or the series resistor.
Refer to Figure 169 and Figure 170 for waveforms observed on the sensor/shield. Figure 169 shows proper charging when the sense clock frequency is correctly tuned. The pulse width is at least 5Tau, that is, the voltage is reaching at least 99.3% of the required voltage at the end of each phase. Figure 170 shows incomplete settling (charging/discharging). If the charging is incomplete, increase the Tx clock divider.
Repeat this process for all the sensors and the shield. Each sensor may require a different Tx clock divider value to charge/discharge completely. But all the sensors that are in the same scan slot need to have the same Tx clock source, Tx clock divider, and number of sub-conversions. Therefore, take the largest Tx clock divider in a given scan slot and apply it to all the other sensors that share the slot.
Additionally, if you are using the SSCx clock source, ensure that you select the Tx clock frequency that meets the conditions mentioned in the Component datasheet/middleware document/ModusToolbox™ CAPSENSE™ Configurator user guide in addition to these conditions.
Number of sub-conversions
The number of sub-conversions decides the sensitivity of the sensor and sensor scan time. From Figure 78 for a fixed modulator clock and Tx clock, increasing the number of sub-conversions (NSub) increases the signal and SNR. However, increasing the number of sub-conversions also increases the scan time of the sensor.
Initially, set the value to a low number (for example, 20), and use the Tuner GUI to find the SNR of the sensor. If the SNR is not > 5:1 with the selected NSub, increase then NSub in steps such that the SNR requirement is met.
Capacitive DACs
-
Enabling or disabling of Compensation CDACs
-
Enabling or disabling of Auto-calibration for the CDACs
-
Compensation CDAC divider, DAC code selection for Reference and Compensation CDACs if auto-calibration is disabled
Table 22 shows the different numbers of valid CDAC combinations that can be set in the CAPSENSE™ Configurator.
Sr. no. | Cref | Cfine | Ccomp |
---|---|---|---|
1 | Auto | Auto | Auto |
2 | Auto | Auto | Disabled |
3 | Auto | Disabled | Auto |
4 | Auto | Disabled | Disabled |
5 | Value | Value | Auto |
6 | Value | Value | Value |
7 | Value | Value | Disabled |
8 | Value | Disabled | Auto |
9 | Value | Disabled | Value |
10 | Value | Disabled | Disabled |
11 | Disabled | Auto | Auto |
12 | Disabled | Auto | Disabled |
13 | Disabled | Value | Auto |
14 | Disabled | Value | Value |
15 | Disabled | Value | Disabled |
Reference CDAC (Cref)
The reference CDAC is used to compensate the charge transferred by the sensor mutual-capacitance (CM) from CMOD. The number of times it is switched depends on the mutual-capacitance of the sensor.
Cref is calculated using the following equation:
C
r e f
= R e f e r e n c e c a p a c i tan c e
R e f C D A C C o d e *
C
l s b
Where,
RefCDACCode = Reference CDAC value
Clsb = 8.86fF
Cref should satisfy below criteria:
RefCDACCode > 6
If the auto-calibrated RefCDACCode is less than 6, then enable fine CDAC.
The following options can be used to increase the RefCDACCode, Decrease the Tx clock divider. Note that the pulse width of the Tx clock should be long enough to allow the sensor capacitance to charge and discharge completely. This decreased Tx clock can be accommodated by decreasing series resistance or decreasing shield Cp Disable compensation
Fine Reference CDAC (Cfine)
The fifth-generation low-power CAPSENSE™ consists of Fine CDAC, which is a programmable CDAC used to achieve finer resolution for the Reference CDAC. Hence, enabling Cfine along with Cref increases the accuracy. It is recommended to always enable auto-calibration for Fine CDAC, to ensure optimal performance.
Cfine = Fine Reference CDAC = FineCDACCode
- Clsb
FineCDACCode = Fine CDAC value
Clsb = 2.2 nF
Compensation CDAC (Ccomp) Enabling the compensation CDAC is called “dual CDAC” mode, and results in increased signal as explained in Conversion gain and CAPSENSE™ signal. Enable the compensation CDAC for most cases.
The compensation capacitor is used to compensate excess mutual-capacitance from the sensor to increase the sensitivity. The number of times it is switched depends on the amount of charge the user application is trying to compensate from the sensor mutual-capacitance.
Compensation CDAC divider
The number of times the compensation capacitor is switched in a single sense clock is denoted by Kcomp. Select CDAC compensation divider based on below Figure 171 such that below criteria is satisfied:
-
CDAC compensation divider >= 4
-
Kcomp should be a whole number
Auto-calibration
This feature enables the firmware to automatically calibrate the CDAC to achieve the required calibration target of 40%. It is recommended to enable auto-calibration for most cases. Enabling this feature will result in the following:
Fixed raw count calibration to 40% of max raw count even with part-to-part CM variation
Decrease the effect of Flat-spots
Automatically selects the optimum gain
For proper functioning of CAPSENSE™ under diverse environmental conditions, it is recommended to avoid very low or high CDAC codes. You can use CAPSENSE™ tuner to confirm that the auto-calibrated CDAC values fall in this recommended range. If the CDAC values are out of the recommended range, based on Figure 161, Figure 162, and Figure 165, you may change the Calibration level or Fmod or FSW to get the CDAC code in proper range.
Selecting CDAC codes
This is not the recommended approach. However, this could be used only if you want to disable auto-calibration for any reason. To get the CDAC code, you may first configure CAPSENSE™ Component with auto-calibration enabled and all other hardware parameters the same as required for final tuning and read back the calibrated CDAC values using Tuner GUI. Then, re-configure the CAPSENSE™ Component to disable auto-calibration and use the obtained CDAC codes as fixed DAC codes read-back from the Tuner GUI.
CDAC dither
As the input capacitance is swept, the raw count should increase linearly with capacitance. However, there are regions called flat-spots where the raw count does not change linearly with input capacitance (refer to section Flat-spots for more details). Dithering, with the help of a dither CDAC, helps to reduce flat-spots. The dither CDAC adds white noise that moves the conversion point around the flat region.
It is recommended to always enable CDAC dither scale in auto-calibrated mode to ensure optimal performance. In case it is required to set the CDAC dither scale manually, see the following table for general recommended values.
Mutual Capacitance (Cm) | Scale |
---|---|
300 fF <= Cm < 500 fF | 5 |
500 fF <= Cm < 1000 fF | 4 |
1000 fF <= Cm < 2000 fF | 3 |
Cm >= 2 pF | Follow Table 19 |
For details on setting dither related parameters, refer to the PSoC™ 4: MSCLP CAPSENSE™ low power (section 'Stage 2: Measure sensor capacitance to set CDAC Dither parameter') code example.
Selecting CAPSENSE software parameters
Configuring autonomous scan
Configuring autonomous scan in CSX-RM sensing is the same as that for CSD-RM sensing; therefore, configure autonomous scan as mentioned in the Configuring autonomous scan section.
Multi-channel scanning
Multi-channel scanning in CSX-RM sensing is the same as that for CSD-RM sensing; therefore, refer to the Multi-channel scanning section for more details.
Button widget tuning
Button widget tuning section provides high-level steps for tuning CSX button. The CE231079 PSoC™ 4: MSC CAPSENSE™ CSX button tuning explains tuning of mutual-capacitance based button widgets in the Eclipse IDE for ModusToolbox™. For details on the Component and all related parameters, see the Component datasheet.
Touchpad widget tuning
Please refer to AN234185 PSoC™ 4 CAPSENSE™ Touchpad design guide for touchpad tuning guidelines.
Manual tuning trade-offs
When manually tuning a design, it is important to understand how the settings impact the characteristics of the capacitive sensing system. Any CAPSENSE™ design has three major performance characteristics: reliability, power consumption, and response time.
- Reliability defines how CAPSENSE™ systems behave in adverse conditions such as a noisy environment or in the presence of water. High-reliability designs will avoid triggering false touches, and ensure that all intended touches are registered in these adverse conditions
Power consumption is defined as the average power drawn by the device, which includes, scanning, processing, and low-power mode transitions as explained in Low-power design. Quicker scanning and processing of the sensors ensures that the device spends less time in a higher power state and maximizes the time it can spend in a lower power sleep state.
- Response time defines how much time it takes from the moment a finger touches the sensor until there is a response from the system. Because the lowest response time is limited by the scan and processing time of the sensors, it is important to properly define and follow a timing budget. A good target for total response time is below 100 ms
These performance characteristics depend on each other. The purpose of the tuning process is to find an optimal ratio that satisfies the project’s specific requirements. When planning a design, it is important to note that these characteristics usually have an inverse relationship. If you take action to improve one characteristic, the others will degrade.
For example, if you want to use CAPSENSE™ in a toy, it is more important to have a quick response time and low power consumption. In a different example, such as a “Start/Stop” button for an oven, reliability is the most important characteristic and the response time and power consumption are secondary.
Now let us consider the factors that affect reliability, power consumption, and response time. Figure 172 shows dependencies between CAPSENSE™ characteristics, measurable parameters, and actual CAPSENSE™configurable parameters.
Reliability
The following factors affect reliability:
-
Signal-to-noise ratio (SNR): SNR gives a measure of confidence in a valid touch signal. For reliable CAPSENSE™ operation, it should be greater than 5. Manual tuning can ensure optimal SNR in specific designs
-
Noise immunity: It is the ability of the system to resist external or internal noise. Typical examples of external noise are ESD events, RF transmitters such as Bluetooth® LE, switching relays, power supply, and so on. The internal noise source could be an LED driven by PWM, or I2C, or SPI communications for example. Even designs with good SNR may suffer from poor performance because of poor noise immunity. Manual tuning allows to tune frequencies and parameters to help avoid noise interference by allowing more control over selection of different parameters
Power consumption and response time
The following factors affect the power consumption and response time:
-
Scan rate: Scan rate can be defined as the frequency at which you scan the sensor. Scan rate decides the minimal possible time from the finger touch until it is reported. The maximum scan rate will be limited by the Sensor scan
-
Scan time: It is the time taken to scan and process a particular sensor. It affects power consumption as indicated in Low-power design and scan rate as indicated above. Manual tuning can achieve specific scan durations while maintaining a minimum SNR
-
Firmware touch delay: This can be caused by the Debounce procedure or use of Raw Data Noise Filters depending on the CAPSENSE™ component version you are using). Both affect scan time by adding to the processing time of a sensor and delay the touch reporting until a certain number of samples in a row show the touch signal. In both cases response rate is reduced, but reliability is usually improved
Tuning debug FAQs
This section lists the general debugging questions on CAPSENSE™ Component tuning. Jump to the question you have, for quick information on possible causes and solutions for your debugging topic.
The tuner does not communicate with the device
Cause 1: Your device is not programmed.
Solution 1: Make sure to Program your device with your latest project updates before launching the tuner.
Cause 2: The tuner configuration setting does not match the SCB Component setting.
Solution 2: Open the EzI2C slave component configuration window, that is, the Configure ‘SCB_P4’ dialog and verify that the settings match the configuration of the Tuner Communication Setup dialog. See the CAPSENSE™ Component datasheet for details on tuner usage.
Cause 3: Your I2C pins are not configured correctly.
Solution 3: Open the .cydwr file in Workspace Explorer and ensure the pin assignment matches what is physically connected on the board.
Cause 4: You did not include the CAPSENSE™ TunerStart API or another required tuner code.
Solution 4: Add the tuner code listed in CAPSENSE™ Component datasheet to your main.c and reprogram the device.
I am unable to update parameters on my device through the tuner
Cause 1: Your communications settings on the device are incorrect.
Solution 1: Review and make sure the settings in the UART/EZI2C configurator dialog and Tuner Communication Setup dialog match. Make sure that the sub-address size is equal.
I can connect to the device but I do not see any raw counts
Cause 1: You did not add the tuner code to your project.
Solution 1: Review the Tuner GUI section and add the tuner code to your main.c and reprogram the device.
Difference counts only change slightly (10 to 20 counts) when a finger is placed on the sensor
Cause 1: The gain of your system is too low.
Solution 1: Review the Tuner GUI section of this document.
Cause 2: Your sensor parasitic capacitance is very high.
Solution 2: To confirm this issue, use the Built-in Self-Test (BIST) APIs documented in the Component datasheet. These functions allow you to read out an estimate of the sensor parasitic capacitance. You can also confirm this reading independently with an LCR meter.
If your hardware has an option to enable Driven shield signal and shield electrode, use this option in the advanced settings of the CAPSENSE™ Component configuration window. A driven shield around the sensors helps reduces the parasitic capacitance. When you enable this option, you may want to enable driving the shield to unused sensors by also changing the “Inactive Sensor connection” setting to “shield” in the advanced settings. If after enabling the shield, your CP remains greater than the supported range of parasitic capacitance by the PSoC™ device, review your board layout to reduce CP further, by following the PCB layout guidelines, and/or contact Technical support to review your layout. See Component datasheet/middleware document for more details on the supported range of CP
Cause 3: Your overlay may be too thick.
Solution 3: Review your Overlay thickness with respect to your Overlay thickness.
Cause 4: Raw counts may be too close to saturation and hence, saturating when sensor is touched.
Solution 4: Tune IDAC to ensure that raw counts are tuned to ~85 percent of the max raw count for a given sensor according to the Modulation and compensation IDACs section.
After tuning the system, I see large amount of radiated noise during testing
Cause 1: The sense clock frequency is causing radiated noise in your system.
Solution 1: Reduce the sense clock frequency or enable PRS for your sensor based on Electromagnetic compatibility (EMC) considerations section. If it is already enabled, see theElectromagnetic compatibility (EMC) considerations section.
Cause 2: Large shield electrode may be contributing to a large radiated noise.
Solution 2: Reduce the size of shield electrode based on Layout guidelines for liquid tolerance.
My scan time no longer meets system requirements after manual tuning
Cause: The noise and CP of your system are high, which requires more scan time and filtering to achieve reliable operation.
Solution: CP needs to be reduced. First, enable the Driven shield signal and shield electrode in the advanced settings of the CAPSENSE™ Component configuration window and ensure gain is set as high as possible by reviewing the PCB layout guidelines. If your system still cannot meet final requirements, you may need to change your board layout to reduce CP further, review the PCB layout guidelines for the same.
I am unable to calibrate my system to 85 percent
Cause 1: Your sensor may have a short to ground.
Solution: First, use a multimeter to check if there is a short between your sensor and ground. If it is present, review your schematic and layout for errors.
Cause 2: Your sensor CP may be too high or too low.
Solution: If your hardware has an option to enable Driven shield signal and shield electrode, use this option in the advanced settings of the CAPSENSE™ Component configuration window. A driven shield around the sensors helps reduces the parasitic capacitance. If you do not have a hardware option to use shield or if after enabling the shield, yourCP remains greater than the device supported CP, contact Technical support to review your layout or for further application-specific guidance.
If you suspect the capacitance to be low compared to the minimum supported parasitic capacitance by the device, add a footprint of the capacitor to a pin. In the final design, if the CP is identified to be lower than the supported range, place an additional compensation capacitor to increase the sensor CP to the supported range by dynamically connecting it to the sensor while scanning. See the Component datasheet/middleware document to understand how to gang the sensors to an external compensation capacitor connected to a pin to increase the CP whenever required.
My slider centroid response is non-linear
Cause: Layout may not meet hardware design guidelines to ensure proper linearity.
Solution: Check the CP of the sensors using the built-in self-test option in the General tab of the CAPSENSE™ configuration window and update the layout according to the Slider design section. See the Component datasheet/middleware document section for details on BIST API.
My slider segments have a large variation of CP
Cause: Your layout design caused your sensors to have an unbalanced CP.
Solution: Your layout needs to be updated. Review Slider design and update your layout as required. If this is not immediately possible, you should re-tune every sensor to have a similar response. This will be a long iterative process and the preferred method is to update the hardware, if possible.
Raw counts show a level-shift or increased noise when GPIOs are toggled
Cause 1: The sensor traces are routed parallel to the toggling GPIOs on your PCB.
Solution: Your layout needs to be updated. Review Trace routing and update your layout as required. If the layout cannot be modified at the current stage, you could evaluate the use of firmware filters to reduce the peak-to-peak noise and hence improve SNR.
Cause 2: A large amount of current is being sinked through the GPIOs.
Solution: Limit the amount of DC current sink through the GPIOs when CAPSENSE™ sensors are being scanned. See Schematic rule checklist. If the current sink through GPIOs is firmware-controlled, and the raw count-level-shift caused by current sink has a large difference compared to the touch signal, you could implement firmware techniques like resetting or re-initializing the CAPSENSE™ baseline whenever the current sink is enabled through the GPIOs. The baseline of the CAPSENSE™ sensor could be reset by using the CapSense_InitializeWidgetBaseline() API function as shown below:
CapSense_InitializeWidgetBaseline(CapSense_CSD_BUTTON_WDGT_ID);
Cause 3: You did not follow the guidelines mentioned in Sensor pin selection section.
Solution: Follow the recommendations in Sensor pin selection section. In addition, for PSoC™ 6 family of devices, follow these guidelines on drive mode strength, switching frequency and slew rate selection, and so on:
- Reduce the drive strength of the switching GPIOs. Table 24 lists the available drive strength options for the GPIOs. Figure 175 shows an example on how to select the drive strength of the GPIOs using the Device configurator in the ModusToolbox™ project
Drive strength | Drive current in mA |
---|---|
Full | 8 |
1 2 | 4 |
1 4 | 2 |
1 8 | 1 |
-
Decrease the switching frequency of the GPIO being toggled
-
Use GPIO slew rate as SLOW mode (note that this limits the toggling frequency to 1.5 MHz). See Table 42 for more details
-
Use PRS as the Sense Clock source.
-
If possible, reduce VDDA to lower than 2.7 V
-
Try to restrict GPIO switching to intervals between CAPSENSE™ scans
I am getting a low SNR
Cause 1: Sensor is not tuned properly.
Cause 2: CAPSENSE™ and other peripherals are not properly assigned to the recommended pin.
Solution: See Sensor pin selection and Raw counts show a level-shift or increased noise when GPIOs are toggled for more details.
Cause 3: HFCLK source may be causing higher noise for a PSoC™ 6 device.
Solution: For the best performance of CAPSENSE™ in PSoC™ 6 family of devices, use HFCLK derived from the IMO/ECO+PLL clock source. This clock source provides the best SNR performance. Figure 176 shows how to change the clock settings using the System tab in the Device configurator for a ModusToolbox™ project. See AN221774 - Getting started with PSoC™ 6 MCU for more details on changing the device clock.
I am observing a low CM for my CSX button
Cause: The mutual capacitance between the Tx and Rx electrode should be higher than approximately 750 fF for proper IDAC calibration.
Solution: It is recommended to have two free pins in your device with footprint to add extra Capacitance if CM of the button turn out to be low. We could then increase the sensor CM to the supported range by dynamically connecting external capacitor to the CSX sensor while scanning as shown in the below figure, where Pin1 is ganged to the Tx pin and Pin2 is ganged to the Rx pin of the sensor respectively. This will help in mitigating low CM risk if it is found during testing phase. See Component datasheet/middleware document to understand how to gang the sensor.
Figure 177 shows the addition of the external capacitor as a button widget in the CAPSENSE™ component and assigning dedicated pins to the Tx and Rx electrode. Figure 178 shows the ganging of the sensor to the external capacitor by assigning Selected pins to both sensor pin and external capacitor pin, this must be done for both Rx and Tx electrode. There is no need to scan the external capacitor while scanning of the widgets, thus we can selectively scan widgets using the APIs CapSense_SetupWidget() and CapSense_Scan() provided by the CAPSENSE™ component.
Gesture in CAPSENSE
Touch gesture support
The CAPSENSE™ Component in PSoC™ 4 and PSoC™ 6 MCU supports the gesture detection feature for sliders and touchpad widgets. It allows to identify different predefined gestures based on touch patterns on sliders and touchpad widget.
Gesture groups
Gestures are divided into several groups: Click, one-finger scroll, two-finger scroll, two-finger zoom, one-finger edge swipe, one-finger flick, and one-finger rotate.
Table 25 lists the gestures supported by various widgets. See Component datasheet/middleware document for more details on how these gestures are defined and the parameter that to be configured in the CAPSENSE™ configurator to detect these gestures.
Widget type | Gesture groups | ||||||
---|---|---|---|---|---|---|---|
Click | One-finger scroll | Two-finger scroll | One-finger flick | One-finger edge swipe | Two-finger zoom | One-finger rotate | |
Button | ✓ | – | – | – | – | – | – |
Linear slider | – | ✓ | – | ✓ | – | – | – |
Radial slider | ✓ | – | – | – | – | – | – |
Matrix buttons | – | – | – | – | – | – | |
Touchpad | ✓ | – | – | ✓ | – | – | ✓ |
Proximity | – | – | – | – | – | – |
One-finger gesture implementation
Implementing gesture detection involves following steps:
-
Tuning the widget
-
Selecting predefined gesture
-
Firmware implementation with timestamp
-
uning gesture parameters
Tuning the widget
Tune the CAPSENSE™ hardware and software parameters for the widget. Generally, in a gesture application, because of the speed and orientation of the finger movement changes, the finger may make a very little contact with the widget. This could be confirmed by viewing the centroid data in the Tuner GUI when the gesture is being performed. If the sensitivity is good enough, you will get the data without any break. If you observe any break in the centroid data, increase the sensitivity until the data for the gesture is complete and appear without any break.
Ensure that you get a SNR above 5:1 for the slight finger contact that you may want to detect. Also, ensure that you have a linear centroid response with respect to the finger position on the slider or touchpad. Tune the sensors using guidelines in section Slider widget tuning tuning for achieving the same
Selecting predefined gesture
First, enable Gestures in the Gesture tab in CAPSENSE™ Component. All gesture-related configuration parameters appear after enabling gestures; these parameters are systematically arranged by widgets/gesture groups as Table 25 shows. According to the application requirement, you can enable and disable gestures by selecting the specific checkbox. Do the following to enable gestures and configure the corresponding parameters.
-
Select the widget for which gesture feature must be enabled in the Widget pane. If you have multiple widgets in the project, the PSoC™ Creator allows gesture recognition only one widget. However, in ModusToolbox™, gesture recognition can be enabled on more than one widget
-
Select the desired gestures in Gestures pane. User has an option to select multiple gestures. In PSoC™ Creator, you cannot enable scroll gesture and flick gesture at the same time. This is applicable for both sliders and touchpad. However, in ModusToolbox™, you can enable more than one gesture according to the application requirement
-
Configure all parameters in the Parameter pane. When a gesture is selected, the right pane of the window dispays the parameters of the selected gesture group. See the Component datasheet/middleware document
Firmware implementation with timestamp
See the code example PSoC™ 4 CAPSENSE™ Touchpad Gestures to understand how to implement timestamp for gesture recognition. Because each gesture has a pattern of touch that changes with time, a reference timestamp is needed for properly getting the touch data with respect to time. This time stamp represents the sampling rate for the gesture recognition algorithm. Both the centroid positions and their respective timestamp are used by the gesture decoding API to determine different predefined gesture patterns that are applicable for the widget.
First, tune the widget using the procedure described in Tuning the widget and determine the time interval between two successive CAPSENSE™ scans in the firmware. Update the timestamp exactly with this duration. The way to accurately determine it is to toggle a GPIO in the firmware after the CAPSENSE™ scan is complete and find the time duration using an oscilloscope.
Tuning gesture parameters
This section describes how to set gesture parameters for sliders; the same procedure could be extended to the gesture groups supported by touchpads. CAPSENSE™ sliders support Click, One-finger Scroll, and One-finger flick gesture features. See the Component datasheet/middleware document.
Using tuner GUI for tuning gesture parameters
You can use the Gesture View in Tuner GUI for tuning the gesture parameters and visualize and analyze the performance of the gesture detected in the end system.
Ensure the following while using Tuner GUI for gestures:
-
For tuning gesture parameters in runtime, Tuner GUI must be used with EZI2C. Use Synchronized communication mode for visualizing the detected gestures in runtime. For more details on using the Tuner GUI, see the Component datasheet/middleware document and the PSoC™ 4 CAPSENSE™ touchpad gestures code example. All the parameters for the gestures that are available in the CAPSENSE™ configurator are available in Tuner GUI, where you can directly edit these values for tuning.
-
As Figure 181 shows, the Gesture View tab is organized into different panes as follows: Gesture Event History pane shows detected gestures and their positions on the widget.
-
Detected Gesture pane indicates the detected gesture. If the delay checkbox is enabled, a gesture picture is displayed for the specified time-interval; if delay is disabled, the last reported gesture picture is displayed until a new gesture is reported.
-
Cypress® Icon in the Tuner GUI moves according to the scroll gesture. It indicates how well the parameter of the scroll gesture is tuned. This dynamic feature gives performance feedback for further fine-tuning gesture parameters. Figure 181. Tuner GUI for gestures
-
Determining the event duration using Tuner GUI. A general equation to determine the event duration is given by Figure 182. Figure 182. Gesture duration
-
Event duration = N o . o f s a m p l e s x
T
s a m p l e
Where,
No. of Samples
= Number of samples the gesture event occurred. This data could be obtained from the Graph View in the Tuner GUI.
T
s a m p l e
= Time interval between two samples.
T
s a m p l e
=
1
Re f r e s h r a t e
Figure 183. Determining the Gesture parameters using Tuner GUI
Click
There are two type of click gestures: single-click and double-click. Table 26 lists the parameters to be configured for the Click gesture in both PSoC™ Creator and in ModusToolbox™. See Component datasheet/middleware document. Table 27 provides the recommended values of the gesture parameter for the Click gesture.
Gesture | PSoC™ Creator | ModusToolbox™ |
---|---|---|
Single-click | One finger minimum touch duration | Minimum click timeout |
One finger maximum touch duration | Maximum click timeout | |
Maximum position displacement | Maximum click distance | |
Double-click | Minimum interval between touches | Minimum second click interval |
Maximum interval between touches | Maximum second click interval | |
Maximum displacement for the second click | Maximum second click distance |
Parameters | Typical values |
---|---|
Maximum position displacement | 20% of maximum position of the slider |
Maximum position displacement for the second click | 20% of maximum position of the slider |
Minimum interval between touches (ms) | 60 |
Maximum interval between touches (ms) | 400 |
One finger minimum touch duration (ms) | 20 |
One finger maximum touch duration (ms) | 400 |
Single click
A single click is defined as a touch-down event followed by a lift-off. Figure 184 shows the spatial and timing condition that must be satisfied for a valid single-click event.
From Figure 184, at time T1, the finger touched down on the slider; at time T2, the finger is lifted off from the slider. For a valid single click, the touch-down duration should be between the “One finger minimum touch duration” and “one-finger maximum touch duration” and the relative position of the liftoff from the initial position of touch should be less than the “Maximum position displacement” parameter.
The duration of each single-click event can be determined by using Figure 182 by finding the number of samples for the single click in the Graph view of Tuner GUI and the refresh rate as shown in Figure 183. From the single-click event duration, fix the parameters “One-finger minimum touch duration” and “One-finger maximum touch duration”. The maximum position displacement parameter can be determined by observing the maximum variation in the centroid position using the Tuner GUI as shown in Figure 183. The recommended value is 20 percent of the maximum centroid position of the slider as mentioned in Table 26.
Double click
A double click is two single-clicks event occurring one after another with the second click occurring between the minimum and maximum time interval between the two touches. In addition, the relative position of the second click from the initial position of touchdown event should be less than the maximum position displacement for the second click. Figure 185 shows the spatial and timing conditions that must be satisfied for a valid double-click event.
From Figure 185, at time T1, the finger touched down on the slider for the first click; at time T2, the finger is lifted off from the slider. At T3, the finger touched down on the slider for the second click; at T4, the finger is lifted off from the slider. For a valid double click, each click should satisfy the condition of single click, and the second click should occur between Minimum and Maximum interval between touch parameters.
Using the Graph view in the Tuner GUI, observe the double-click touch data. Determine the parameter of single click as mentioned in the Single click section. Determine the duration between the two touches using the Graph view in the Tuner GUI and set the value of the minimum and maximum intervals between touch parameters. A typical captured data for the double-click event is shown in Figure 183.
Scroll
There are two different scroll gestures that can be detected on sliders: One-finger scroll and One-finger Inertial scroll. See Component datasheet/middleware document. Table 28 shows the parameters to be configured for the scroll gesture.
Gesture | PSoC™ Creator | ModusToolbox™ |
---|---|---|
One-finger scroll | Position threshold N | Minimum scroll distance |
Scroll step | ||
Debounce | Scroll debounce | |
One-finger inertial scroll | Position inertial threshold | NA |
Count level |
One-finger scroll
A One-finger Scroll gesture is a combination of a touchdown followed by a displacement in specific direction. The change in position between two consecutive scans must exceed the Position Threshold value given in the configurator after tuning. See Component datasheet/middleware document.
Follow these steps to set the scroll gesture parameter values as shown in Table 28.
-
Determine the number of samples of the scroll gesture from the Graph view (Centroid position) in Tuner GUI
-
By using Figure 182 determine the duration of the complete scroll
-
Determine the change in centroid position for the complete scroll using the Tuner GUI
-
Determine Position Threshold Figure 186. Each gesture is scanned at a sample rate that is set in the timestamp in the application code. The position threshold is given by the change in the centroid position for the duration that is set in the timestampFigure 186. Equation to determine position threshold
-
Position Threshold = Change in Centroid position Total duration of scroll × Duration of timestamp
-
In PSoC™ Creator, set four different position thresholds and their scroll count values in the configurator, which are determined by varying the speed of the scroll gesture. Now, change the speed of scroll and repeat the steps 1 – 4 and set these position threshold values. In ModusToolbox™ has only one parameter: Minimum Scroll distance; determine its value in the same way you determined the position threshold
-
Read the scroll step from the CAPSENSE™ data structure and use it to control the speed and smoothness of the scroll gesture. The scroll step depends on the position threshold. This scroll step is used in the application code to control the actual variable value to be changed with respect to scroll. Note: The scroll step parameter is not available in ModusToolbox™.
-
Set the maximum slider position as ten times the dimension of the slider as a general rule. If you set scrollDistanceMin=10, everything below a 1-mm movement will not detect the scroll gesture. Everything above this number might detect a gesture
Observe the Cypress® icon in the Tuner GUI (see Figure 181) to get a feedback on how well the tuning has been done for the scroll gesture in the given hardware. You can also print the variable that must be controlled by scroll through UART to visualize how the value is changing with respect to scroll. This could be used as a visual feedback. The position threshold parameters and the corresponding step counts should be tuned until the variation in the variable value with respect to scroll meet the requirement of the end user application.
One-finger inertial scroll
The one-finger Inertial scroll gesture is defined as a touchdown event followed by a minimum displacement in a specific direction, and then a liftoff. The movement of scroll will automatically stop when it reaches the end value of the variable. See Component datasheet/middleware document.
The gesture parameter is provided in Table 28. The position inertial threshold parameter is given by the minimum change in centroid position that is required before a liftoff; its value can also be determined by steps in the One-finger scroll section. The count value parameter defines the momentum of scroll; it can take two possible values: low or high. Choose the count value according to the end application requirement.
One-finger flick
A flick gesture is a touchdown event followed by a high-speed displacement and a liftoff event (see Component datasheet/middleware document). The flick gesture is similar to the One-finger Inertial Scroll; the only difference is that it requires a high-speed displacement followed by a liftoff event within the maximum sample interval defined in the configurator. You can determine the position threshold and the maximum sample interval by following the same procedure in One-finger scroll section and by using Figure 182.
Gesture | PSoC™ Creator | ModusToolbox™ |
---|---|---|
One Finger Flick Gesture | Position threshold | Minimum flick distance |
Maximum sample interval | Maximum flick timeout |
Two-finger gesture implementation
Two-finger gestures such as Two-finger Scroll and Two-finger Zoom are supported in the touchpad widget. You must enable this feature in the Widget Details tab of the Touchpad Widget. The procedure for tuning the parameters is the same as mentioned in the One-finger gesture implementation section (see Component datasheet/middleware document). Figure 187 shows how to enable two-finger touch gestures in the configurator, select the centroid type as 5 x 5 Centroid, and set the two-finger detection as True.
Advanced filters for gestures
Advanced filtering features for gestures such as Ballistic multiplier, Adaptive IIR filter, and the Edge correction feature are available to improve gesture recognition and the user experience.
See Component datasheet/middleware document.
Design considerations
This chapter explains the firmware and hardware design considerations for CAPSENSE™.
Firmware
The CAPSENSE™ scan is non-blocking in nature. The CPU intervention is not required between the start and the end of a CAPSENSE™ scan. Therefore, you can use CPU to perform other tasks while a CAPSENSE™ scan is in progress. However, note that CAPSENSE™ is a high-sensitive analog system. Therefore, sudden changes in the device current may increase the noise present in the raw counts. If you are using widgets that require high sensitivity such as proximity sensors, or buttons with thick overlay, you should use a blocking scan. Example firmware for a non-blocking scan is shown below.
/* Enable global interrupts */
CyGlobalIntEnable;
/* Start EZI2C component */
EZI2C_Start();
/*
* Set up communication data buffer to CapSense data structure to be
* exposed to I2C master at primary slave address request.
*/
EZI2C_EzI2CSetBuffer1(sizeof(CapSense_dsRam),
sizeof(CapSense_dsRam),
(uint8 *)&CapSense_dsRam);
/* Initialize CapSense component */
CapSense_Start();
/* Scan all widgets */
CapSense_ScanAllWidgets();
for(;;)
(
/* Do this only when a scan is done */
if(CapSense_NOT_BUSY == CapSense_IsBusy())
( /* Process all widgets */
CapSense_ProcessAllWidgets();
/* Scan result verification */
if (CapSense_IsAnyWidgetActive())
(
/* Add any required functionality
based on scanning result */
)
/* Include Tuner */
CapSense_RunTuner();
/* Start next scan */
CapSense_ScanAllWidgets();
)
/* CPU Sleep */
CySysPmSleep();
)
)
You should avoid interrupted code, power mode transitions, and switching ON/OFF peripherals while a high-sensitivity CAPSENSE™ scan is in progress. However, if you are not using high-sensitivity widgets, you can use CPU to perform other tasks. You can also use low-power mode of PSoC™ to reduce the average power consumption of the CAPSENSE™ system, as explained in the next section. Monitoring and verifying the raw counts and SNR using the Tuner GUI is recommended if you are using a non-blocking code.
If you want to develop firmware using the ModusToolbox™ software, see the references in the ModusToolbox™ section of this document.
Low-power design
PSoC™ low-power modes allow you to reduce overall power consumption while retaining essential functionality. See AN234231 - Achieving lowest-power capacitive sensing with PSoC™ 4000T and AN86233 - PSoC™ 4 MCU low-power modes and power reduction techniques, for a basic knowledge of PSoC™ 4 low-power modes. See AN219528 - PSoC™ 6 MCU low-power modes and power reduction techniques, for PSoC™ 6’s low-power modes, and AN210998 - PSoC™ 4 low-power CAPSENSE™ design, for designing a low-power CAPSENSE™ application.
The CPU intervention is not required between the start and the end of a CAPSENSE™ scan. If the firmware does not have any additional task other than waiting for the scan to finish, you can put the device to Sleep mode after initiating a scan to save power. When the CSD hardware completes the scan, it generates an interrupt to return the device to the Active mode.
There are different firmware and hardware techniques to reduce the power consumption of the CAPSENSE™ system.
-
If you use APIs that scan multiple widgets together, the device returns to Active mode after finishing the scan of a single widget. Therefore, you should scan each widget individually for reducing the power consumption in the design. See the CAPSENSE™ Component datasheet
-
You can use the Deep-Sleep mode of PSoC™ to considerably reduce the power consumption of a CAPSENSE™ design. However, the CAPSENSE™ hardware is disabled in the Deep-Sleep mode. Therefore, the device must wake up frequently to scan for touches. You can use the watchdog timer (WDT) in PSoC™ to wake up the device from the Deep-Sleep mode at frequent intervals. Increasing the frequency of the scans improves the response of the CAPSENSE™ system, but it also increases the average power consumption
-
As the number of sensors in the design increases, the device has to spend more time in the Active mode to scan all sensors. This, in turn, increases the average power consumption. For saving power in a design with multiple sensors, you should include a separate proximity loop that surrounds all the sensor. When the device wakes up from the Deep-Sleep mode, only scan this proximity sensor. If the proximity sensor is active, the device must stay in the Active mode and scan other sensors. If the proximity sensor is inactive, the device can return to the Deep-Sleep mode. Figure 188 illustrates this process
-
The CAPSENSE™ component can reduce power consumption by reducing the execution time of scanning by ganging sensors together and managing scanning at the application level. In this case, all the sensors in the design are “ganged” that is, simultaneously connected to the AMUX bus to form a virtual sensor. See the code example PSoC™ 4 low power ganged sensor and AN92239 - Proximity sensing with CAPSENSE™ for details on ganged sensor implementation. A ganged sensor has different tuning parameters because its properties are different compared to considering the sensors individually. Therefore, it should be considered as a single CSD button and tuned separately; see Manual tuning. The ganged sensor is periodically scanned by using a watchdog timer (WDT); if the ganged sensor reports a touch event, enable the scanning of the actual widgets that need to be scanned. This is helpful in CAPSENSE™ designs that requires Wake on Touch modes. The procedure is similar to what is explained in Figure 188. You can achieve very low system current while maintaining a good touch response, by properly tuning CAPSENSE™ and the wakeup interval. This technique could also be used with the CSX touchpad widget
-
If high-speed peripherals such as system timers and I2C are required, you can put the CPU to sleep mode instead of going to deep sleep mode
-
You can also add a shield hatch in the design, as explained in Driven shield signal and shield electrode to reduce the parasitic capacitance and therefore, the scan time. The scan time and power consumption is directly related; thus, the power consumption is reduced by lowering the scan time
Synchronized scanning
In Fifth-Generation Low-Power CAPSENSE™ (MSCLP), the sensor scanning can be controlled using the External Frame Start feature. This allows scanning to be triggered by a pulse on the External Frame Start pin (ext_frm_start). This feature is available in PSoC™ 4000T.
This feature can be used to synchronize the scanning of multiple devices with MSCLP on-board or to synchronize with external periodic noise sources, such as LCDs.
External frame start pulse guidelines
Mentioned below are the characteristics of the External Frame Start signal for the proper operation of the external frame start feature.
Scan trigger: A scan will happen only when an external frame start signal is received after a scan_all_slots has been called in the application.Figure 189. Scan trigger
Pulse Type: A clean rectangle wave Pulse Period: The period of pulse that is interval between two subsequent pulses should not be lesser than the frame duration + MSC ISR duration + Processing durationFigure 190. Pulse period
Minimum Pulse Width: The pulse should not be shorter than 2 ILO cyclesFigure 191. Minimum pulse width
Max Pulse Width: Should not be longer than scanning frame durationFigure 192. Max pulse width
Sync interval (interval between the calling scan_all_slots() and the pulse): Should be longer or equal 2 ILO cycles.Figure 193. Sync interval
Conditioning the external frame start pulse
With the help of external frame start feature in MSCLP, scans can be synchronized with an LCD sync signal. If the external frame start signal does not comply with the guidelines mentioned in the External Frame Start Pulse Guidelines section, the signals will need to be conditioned. One way to condition the sync signal is using the TCPWM hardware present in the device. It receives the LCD sync signal (e.g., 60 Hz square wave) and generates the external_frame_start signal, with the appropriate width, as output.
Figure 194. Using TCPWM to generate conditioned pulse
The TCPWM is configured as a single shot timer. The timer gets triggered by an external input pulse. This external input pulse is the LCD sync signal, and the output from the TCPWM is fed to the ext_frm_start pin of the MSCLP.
Three GPIOs and 1 TCPWM are used in this approach,
External Trigger input for the TCPWM TCPWM line output MSCLP ext_frm_strt pin
The output from the TCPWM needs to be wired and connected to the input of the ext_frm_strt pin.
Sensor construction
A capacitive sensor can be constructed using different materials depending on the application requirement. In a typical sensor construction, a conductive pad, or surface that senses a touch is connected to the pin of the PSoC™ using a conductive trace or link. This whole arrangement is placed below a non-conductive overlay material and the user interacts on top of the overlay.
Figure 195 shows the most common CAPSENSE™ sensor construction.
The copper pads etched on the surface of the PCB act as CAPSENSE™ sensors. A nonconductive overlay serves as the touch surface. The overlay also protects the sensor from the environment and prevents direct finger contact. A ground hatch surrounding the sensor pad isolates the sensor from other sensors and PCB traces.
If liquid tolerance is required, you should use a shield hatch instead of the ground hatch. In this case, drive the hatch with a shield signal instead of connecting it to ground. See Liquid tolerance section for details.
The simplest CAPSENSE™ PCB design is a two-layer board with sensor pads and hatched ground plane on the top, and the electrical components on the bottom. Figure 196 shows an exploded view of the CAPSENSE™ hardware.
Sensors may also be constructed by using materials other than copper, such as indium tin oxide (ITO) or printed ink on substrates such as glass or a flex PCB. In some cases, springs can also be used as CAPSENSE™ sensors as Figure 197 shows, to create elevated sensors that allow overlay to be placed at an elevated distance from the PCB. See Getting started with CAPSENSE™ design guide for PCB design considerations specific to spring sensors and other non-copper sensors such as ITO and printed ink.
Overlay selection
Overlay material
The overlay is an important part of CAPSENSE™ hardware as it determines the magnitude of finger capacitance. The finger capacitance is directly proportional to the relative permittivity of the overlay material. See Finger capacitance for details.
Table 30 shows the relative permittivity of some common overlay materials. Materials with relative permittivity between 2.0 and 8.0 are well suited for CAPSENSE™ overlay.
Material | εr |
---|---|
Air | 1.0 |
Formica | 4.6 – 4.9 |
Glass (Standard) | 7.6 – 8.0 |
Glass (Ceramic) | 6.0 |
PET film (Mylar®) | 3.2 |
Polycarbonate (Lexan®) | 2.9 – 3.0 |
Acrylic (Plexiglas®) | 2.8 |
ABS | 2.4 – 4.1 |
Wood table and desktop | 1.2 – 2.5 |
Gypsum (Drywall) | 2.5 – 6.0 |
In capacitive touch sensing, the finger and the sensor behave as the two plates of a capacitance, with the overlay forming the dielectric material. Hence, in case of multiple overlays, it makes two capacitors in series. Thus, the effective dielectric constant is as shown below for two overlays of dielectric constant of ε1 and ε2 and thickness of d1 and d2.
Overlay thickness
Finger capacitance is inversely proportional to the overlay thickness. Therefore, a thin overlay gives more signal than a thick overlay. See Finger capacitance for details.
Table 31 lists the recommended maximum thickness of acrylic overlay for different CAPSENSE™ widgets.
Widget | Maximum thickness (mm) – 4th Generation CAPSENSE™ | Maximum thickness (mm) – 5th Generation CAPSENSE™ |
---|---|---|
Button | 5 | 18 |
Slider | 511 | 18 |
Touchpad | 0.5 | 3 |
Because Finger capacitance also depends on the dielectric constant of the overlay, the dielectric constant also plays a role in the guideline for the maximum thickness of the overlay. Common glass has a dielectric constant of approximately εr = 8, while acrylic has approximately εr = 2.5. The ratio of εr/2.5 is an estimate of the overlay thickness relative to plastic for the same level of sensitivity. Using this rule of thumb, a common glass overlay can be about three times as thick as a plastic overlay while maintaining the same level of sensitivity.
In addition, avoid using very thin or no overlay. It is important to have a minimum overlay thickness in a CAPSENSE™ design for the following reasons:
-
An overlay provides protection from the environmental condition, prevents direct finger contact, and gives ESD protection. The overlay thickness should be small enough to give a good signal, and decided based on the button size and the strength to withstand ESD. See AN64846 - Getting started with the CAPSENSE™
-
For the CSD button, if there is no overlay the buttons will be over sensitive
-
For sliders, if there is no overlay, the raw count may saturate for the slider segments and may cause non-linear centroid response for slider. See Slider design
-
For the CSX sensor, it is recommended to have a minimum overlay thickness of 0.5 mm. If it is violated, sudden decrease in raw count is observed when a finger is placed on a sensor or a water drop falls on the Tx and Rx electrodes. See Effect of grounding
Overlay adhesives
The overlay must have a good mechanical contact with the PCB. You should use a nonconductive adhesive film for bonding the overlay and the PCB. This film increases the sensitivity of the system by eliminating the air gap between the overlay and the sensor pads. 3M™ makes a high-performance acrylic adhesive called 200 MP that is widely used in CAPSENSE™ applications. It is available in the form of adhesive transfer tapes; example product numbers are 467 MP and 468 MP.
PCB layout guidelines
PCB layout guidelines help you to design a CAPSENSE™ system with good sensitivity and high Signal-to-noise ratio (SNR).
Sensor CP
In a CAPSENSE™ system design, the CP of the sensor must be within the supported range of the device. You can find the supported CP range in the Component datasheet/middleware document. The main components of CP are trace capacitance, sensor pad capacitance, and pin capacitance of the device. The pin capacitance is device-dependent (see the Device datasheet), so you can only design your sensor and trace capacitance to be able to meet the CP criteria in the datasheet. The relationship betweenCP and the PCB layout features is not simple. CP increases with an increase in the sensor pad size and trace length and width, and with a decrease in the gap between the sensor pad and the ground hatch.
There are many ways to decrease theCP :
-
Decrease the trace length and width as much as possible. Reducing the trace length increases noise immunity
-
Drive the hatch with a shield signal. See Driven shield signal and shield electrode
Reducing the sensor pad size is not recommended because it also reduces the finger capacitance. In some special cases, such as small sensor pad and very small trace length due to placement of the sensor pad close to the device, there is a possibility of the sensor CP to be lower than the supported minimum CP by the device. In that case, add a footprint of the capacitor across the sensor or any unused pin. If the CP is identified to be lower than the supported range, place a 4.7 pF capacitor across the sensor or on the unused pin and gang the capacitor during the CAPSENSE™ scan, refer to the FAQ I am unable to calibrate my system to 85 percent for more details. This will increase the CP of the sensor to the supported range.
If the sensor CP is very high due to long traces or because of a nearby ground, use the mutual-capacitance sensing method so that the sensitivity is not degraded because of the high CP value. The sensitivity of the CAPSENSE™ sensor in a mutual-capacitance sensing method is independent of the sensor CP.
Board layers
Most applications use a two-layer board with the sensor pads and the hatched ground planes on the top side and all other components on the bottom side. PCBs that are more complex use four layers.
-
FR4-based PCB designs perform well with board thickness ranging from 0.020 inches (0.5 mm) to 0.063 inches (1.6 mm).
-
Flex circuits work well with CAPSENSE™ too. You can use flex circuits for curved surfaces. All PCB guidelines in this document also apply to flex. You should use flex circuits with thickness 0.01 inches (0.25 mm) or higher for CAPSENSE™. The high breakdown voltage of the Kapton® material (290 kV/mm) used in flex circuits provides built in ESD protection for the CAPSENSE™ sensors
Button design
Self-capacitance button design
The self-capacitance button has a single electrode and can have different shapes and size as recommended below.
Shape: You should use circular sensor pads for CAPSENSE™ buttons. Rectangular shapes with rounded corners are also acceptable. However, you should avoid sharp corners (<90º) since they concentrate electric fields. Figure 199 shows recommended button shapes.
Size: Button diameter should be 5 mm to 15 mm, with 10 mm suitable for most applications. A larger diameter is appropriate for thicker overlays.
Spacing: The width of the gap between the sensor pad and the ground hatch should be equal to the overlay thickness, and range from 0.5 mm to 2 mm. For example, if the overlay thickness is 1 mm, you should use a 1 mm gap. However, for a 3 mm overlay, you should use a 2 mm gap.
Select the spacing between two adjacent buttons such that when touching a button, the finger is not near the gap between the other button and the ground hatch, to prevent false touch detection on the adjacent buttons, as Figure 200 shows.
Mutual-capacitance button design
Mutual capacitance sensing measures the change in capacitive coupling between two electrodes. The sensor pattern should be designed in such a way that the finger disturbs the electric field between the Tx and Rx electrodes to a maximum extent. There are standard button patterns that could be used for the mutual capacitance button design and their parameters could be modified based on the application requirement. Fishbone pattern is one of the mutual capacitance patterns which give better performance in terms of SNR.
Fishbone pattern
Prongs or fishbone are standard shapes for mutual-capacitance buttons. The Tx forms a box or ring around the button for shielding Rx from noise. There are interlaced Tx and Rx prongs inside the border to form the electric field. Figure 201 shows an example of a two-prong fishbone sensor structure with top and bottom view with hatched ground. The gap between the outer wall of the Tx electrode and the coplanar hatch ground should be greater than the air-gap of Tx and Rx electrodes. The reference plane (PCB bottom layer) of the Fishbone structure should have void region as shown in Figure 201.
Table 32 lists the suggested fishbone button design parameters for some commonly used sensor sizes and overlay like glass and acrylic. As explained in section Sensor size, the recommended button size is to keep the button X and Y dimension close to the sum of expected user finger size and overlay thickness. However, the table lists multiple button sizes that you can chose from if you have constraints on available space on board or if you would like to have a bigger button for your application for ease of user interaction etc.
Also, note that for a given button size, the achievable SNR decreases with increased overlay thickness. Thus, if you plan to use thick overlays (approx. > 1 mm acrylic or 2 mm glass) ensure to avoid compromising on button size due to board space because that will further limit the button SNR performance. Ensure to use bigger buttons (>= biggest expected finger size) for such thick overlays. And also, for small buttons better to have thin overlays for getting good SNR.
Button size (X-size, Y-size) (mm) | Number of Rx-prongs | Air gap between Tx and Rx in mm | Tx width in mm | Rx width in mm | X-wall wdth in mm | Y-wall width in mm | Y prong in mm |
---|---|---|---|---|---|---|---|
5, 5 | 3 | 0.35 | 0.48 | 0.48 | 0.24 | 0.24 | 0.2 |
10,7 | 3 | 0.75 | 0.92 | 0.92 | 0.46 | 0.46 | 0.2 |
10,5 | 3 | 0.5 | 1.17 | 1.17 | 0.58 | 0.58 | 0.2 |
10,10 | 2 | 0.9 | 1.60 | 1.60 | 0.80 | 0.80 | 0.2 |
12, 12 | 2 | 1.3 | 1.70 | 1.70 | 0.85 | 0.85 | 0.2 |
13, 10 | 2 | 1.1 | 2.15 | 2.15 | 1.08 | 1.08 | 0.2 |
13, 13 | 2 | 1.5 | 1.75 | 1.75 | 0.88 | 0.88 | 0.2 |
15, 15 | 2 | 1.7 | 2.05 | 2.05 | 1.03 | 1.03 | 0.2 |
17, 17 | 2 | 2.3 | 1.95 | 1.95 | 0.98 | 0.98 | 0.2 |
20, 13 | 2 | 1.8 | 3.20 | 3.20 | 1.60 | 1.60 | 0.2 |
25, 13 | 2 | 2 | 4.25 | 4.25 | 2.13 | 2.13 | 0.2 |
The above button design parameters in Table 32 ensure a good SNR performance if you follow the schematics and layout guidelines in this chapter.
Button design for arbitrary shapes and dimensions
Figure 202 shows the different orientation of Rx prongs in the Fish bone pattern, in Button A the Rx prong is perpendicular to the side of the button with larger dimension and in Button B the Rx prongs is parallel to the side of the button with larger dimension. Orientation of Rx prongs like in Button A results in optimized button pattern compared to Button B. Thus, it is always recommended to have Rx prongs perpendicular to the side of the button with larger dimension. Thus if you need a 10x13 mm button, then simply use the 13x10 mm button from Table 31 and rotate it 90º to get 13x10 mm Noise in CAPSENSE™ system button pattern as shown in Figure 202.
There may be some design where you need a different button shape than the recommended rectangular, like an oval or circular shape etc. The below steps explain how to construct the button with nonstandard shape from the standard Fish bone pattern.
-
First select the Fishbone pattern (Rectangular shape for oval shape and Square button for circular shape) from Table 31 to cover the desired button shape
-
Then in the user interface or above the overlay print button shape with required dimension over the fishbone pattern as shown in Figure 204
Mutual capacitance buttons designed using this method have some oversensitive area or less sensitive outside the button shape as shown in the below figures, this could be mitigated by properly tuning the software thresholds of the mutual capacitance button. The below figure shows an example of a circular button made using a square fishbone pattern.
If you want a pattern that is not present in Table 31, you can obtain the button parameters by following few steps. For example, if you want a 19x19 pattern, choose the pattern that is close to the required pattern from Table 31 like 17x17, and scale the air gap between Tx and Rx with respect to the button areas. For example:
Where, ButtonArea=X x Y dimension of the sensor.
Compute the Tx, Rx width and Tx wall based on the assumption below and by considering the Newgap as obtained above. The obtained values of the button design parameters are shown in Table 32. Refer to the Figure 201 to understand the description of the button design parameters.
Button size (X-size, Y-size)(mm) | Number of Rx-prongs | Air gap between Tx and Rx in mm | Tx width in mm | Rx width in mm | X-wall width in mm | Y-wall width in mm | Y prong in mm |
---|---|---|---|---|---|---|---|
17, 17 | 2 | 2.3 | 1.95 | 1.95 | 0.98 | 0.98 | 0.2 |
19,19 | 2 | 2.9 | 1.85 | 1.85 | 0.93 | 0.93 | 0.2 |
General recommendations on Fishbone pattern parameters
Sensor size
The sensor size is the XY dimension of the button, it is selected based on the board space availability, expected user finger size and overlay material and thickness. Sensor size selection also depends upon the number of required buttons on the PCB considering required button-to-button gap and space availability in the PCB. But if the space is not the constrain then choose higher button size which will result in getting a good SNR. Note that increasing the sensor size beyond a point will cause the SNR to saturate, this is because some of the electric field lines from Tx/Rx electrode do not interact with the finger as shown in Figure 205.
The SNR of the button is decreased with usage of thick overlays. Thus, the recommended minimum sensor size is finger size plus overlay thickness to achieve a good SNR even with thick overlays. For example, the minimum sensor size recommended could be 13x10 mm, considering the finger size around 10mm in diameter and 3 mm overlay thickness. As mentioned in the Button design for arbitrary shapes and dimensions Rx prongs should be perpendicular to the side with large dimension.
Button spacing
The button spacing is the gap between the Tx wall of two buttons. It helps to prevent user error by isolating the buttons from each other and reduces the cross talk. It is recommended to keep a minimum of 8 mm spacing between the buttons this will ensure a good single touch and multi touch performance.
Overlay
The overlay thickness and overlay permittivity influences the SNR of the button and immunity towards the external noise such as ESD. Refer to the Overlay selection section for more details. It is recommended to keep the overlay thickness as minimum as possible which will help in getting a higher SNR for the button and it should be high enough to provide immunity towards ESD noise. In some cases, if the overlay thickness is more and you cannot avoid it due to mechanical design consideration. In such a case, for getting a better SNR use a mutual capacitance button with bigger size than the recommended size. Refer to the section Sensor size for selecting the minimum button dimension with respect to the overlay thickness. Using an overlay material with higher dielectric constant will also leads to higher SNR. So always use material with high dielectric constant when we use thick overlay. And also, for smaller buttons better to have thin overlays for getting good SNR.
Air gap between Tx and Rx electrode
The gap between the Tx and Rx electrode influences the mutual capacitance between the Tx and Rx electrode. Increasing the gap reduces the mutual capacitance. It is the most critical parameter in the Fishbone pattern design and the gap between the Tx and Rx electrode such that the mutual capacitance is above 750 fF.
Number of Rx-prongs
The number of Rx prongs influence the mutual capacitance between the Tx and Rx electrode, because increasing the number of Rx prongs decreases the gap between the Tx and Rx electrode for a given button size. Higher mutual capacitance implies higher electric field lines between Tx and Rx electrode. Thus, we get a higher signal when we touch the button, because the finger touch will disturb the electric field to a maximum extent. But higher CM also increases the impact of external noise such as VDDA ripple noise. Thus, there is a tradeoff in selecting the number of Rx prongs to get a higher signal verses getting good noise immunity. The optimal number of Rx prongs is 2 for the Fishbone pattern (that is Fishbone pattern with a single Tx prong and two Rx prongs). The below figure shows the mutual capacitance button with three and one number of Rx prongs.
Tx electrode and Rx electrode width
The Tx electrode and Rx electrode width influences the mutual capacitance between Tx and Rx electrode. Best signal response is achieved when Rx width/area is equal to Tx width/area in the case of less external noise in the system. The below figure shows the electric filed lines from Tx to Rx electrode with equal and unequal widths. Thus, from the below figure it is clear that having equal Tx and Rx width will eventually leads to higher change in CM for a finger touch.
In some cases, it is required to provide liquid tolerance to the mutual capacitance button as mentioned in section Liquid tolerance for mutual-capacitance sensing. To achieve that we have to use a hybrid sensing technique with both CSX and CSD sensing method. In such a case the Tx or Rx electrode whichever is scanned in CSD technique should have a significant width so that it ensures a good signal for a finger touch.
Co planar ground
Presence of coplanar ground decreases the impact of noise in the system and it also provides good ground resulting in decreased signal disparity effect. It is recommended to have as much area surrounding the sensor with hatched pattern and connected it to device ground. Also follow the recommendations as mentioned in the layout and schematics guidelines in this chapter. Ground plane reduces the coupling of electric field lines to the approaching finger, which decreases the change in mutual capacitance caused by a finger touch. It is suggested to avoid having ground plane underneath the sensor unless you expect strong coupling to a noise source present right below the sensor. Figure 201 shows the coplanar ground on the top and bottom layer of the PCB. The gap between the outer wall of the Tx electrode and the coplanar hatch ground should be greater than the air-gap of Tx and Rx electrodes.
Tx wall (X-wall and Y-wall width)
Tx wall act as a shield to the Rx electrode from noise. Wide Tx wall also reduces the effect of cross talk and the impact of Co-planar ground. It is recommended to keep the Tx wall width approximately equal to half of Tx electrode width. The below figure shows the effect of wider Tx wall, it increases the number of electric field lines reaching the finger from the Tx electrode by reducing the impact of Coplanar ground. The width of Tx wall can also be slightly increased in case Tx electrode is scanned as a CSD sensor as mentioned in sectionLiquid tolerance for mutual-capacitance sensing. An example 10x10 pattern with increased Tx wall is given in Table 33.
Button Size (X-Size, Y-Size) (mm) | Number of Rx-Prongs | Air Gap between Tx and Rx in mm | Tx Width in mm | Rx Width in mm | X-Wall Width in mm | Y-Wall Width in mm | Y Prong in mm |
---|---|---|---|---|---|---|---|
10, 10 | 2 | 0.8 | 1.2 | 1.2 | 1.5 | 1.6 | 0.2 |
Slider design
Figure 209 shows the recommended slider pattern for a linear slider and Table 35 shows the recommended values for each of the linear slider dimensions. A detailed explanation on the recommended layout guidelines is provided in the following sections.
Parameter | Acrylic overlay thickness | Minimum | Maximum | Recommended |
---|---|---|---|---|
Width of the segment (W) | 1 mm | 2 mm | 8 mm 12 | |
3 mm | 4 mm | |||
4 mm | 6 mm | |||
Height of the segment (H) | 7 mm 13 | 15 mm | 12 mm | |
Air gap between segments (A) | 0.5 mm | 2 mm | 0.5 mm | |
Air gap between the hatch and the slider (AHS) | 0.5 mm | 2 mm | Equal to overlay thickness |
Slider-segment shape, width, and Air gap
A linear response of the reported finger position (that is, the centroid position) versus the actual finger position on a slider requires that the slider design is such that whenever a finger is placed anywhere between the middle of the segment SLD0 and middle of segment SLDn-1, other than the exact middle of slider segments, exactly two sensors report a valid signal 14. If a finger is placed at the exact middle of any slider segment, the adjacent sensors should report a difference count = noise threshold. Therefore, it is recommended that you use a double-chevron shape as Figure 209 shows. This shape helps in achieving a centroid response close to the ideal response, as Figure 210 and Figure 211 show. For the same reason, the slider-segment width and air gap (dimensions “W” and “A” respectively, as marked in Figure 209) should follow the relationship mentioned in Figure 124.
Typically, an average human finger diameter is approximately 9 mm. Based on this average finger diameter and Figure 212, the recommended slider-segment-width and air-gap is 8 mm and 0.5 mm respectively.
If the sum of slider-segment width and 2 * air-gap is lesser than finger diameter, as required according to Figure 212, the centroid response will be non-linear. This is because, in this case, a finger placed on the slider will add capacitance, and hence valid signal to more than two slider-segments at some given position, as Figure 213 shows. Thus, calculated centroid position in Figure 214 will be non-linear as Figure 215 shows.
Where,
Resolution = API resolution set in the CAPSENSE™ component customizer
n = Number of sensor elements in the CAPSENSE™ component customizer
x = Index of element which gives maximum signal
Si = Different counts (with subtracted noise threshold value) of the slider segment
Note that even though a slider-segment-width value of less than finger diameter – 2 * air-gap provides a non-linear centroid response, as Figure 215 shows; it may still be used in an end application where the linearity of reported centroid versus actual finger position does not play a significant role. However, a minimum value of slider-segment-width must be maintained, based on overlay thickness, such that, at any position on the effective slider length, at least one slider-segment provides a Signal-to-noise ratio (SNR) of ≥ 5:1 (that is signal greater than or equal to the finger threshold parameter) at that position. If the slider-segment width is too low, a finger may not be able to couple enough capacitance, and therefore, none of the slider-segments will have a 5:1 SNR, resulting in a reported centroid value of 0xFFFF 15 in PSoC™ Creator as Figure 216 shows, and 0x0000 16 in ModusToolbox™.
The minimum value of slider-segment width for certain overlay thickness values for an acrylic overlay are provided in Table 35. For thickness values of acrylic overlays, which are not specified in Table 35, Figure 217 may be used to estimate the minimum slider-segment width. Very thin overlay or no overlay may cause a nonlinear centroid response due to saturation of raw count or due to high finger capacitance; centroid position may be detected before touching the slider. In these conditions, the CAPSENSE™ centroid algorithm will not be able to correctly estimate the finger position on the slider using Figure 214. It is recommended to have the overlay thickness for the CSD sensor as mentioned in Table 34.
If the slider-segment-width + 2 * air-gap is higher than the finger diameter value as required in Figure 212, the centroid response will have flat-spots; that is, if the finger is moved towards the middle of any segment, the reported centroid position will remain constant as Figure 218 shows. This is because, as Figure 219 shows, when the finger is placed in the middle of a slider segment, it will add a valid signal only to that segment even if the finger is moved a little towards adjacent segments.
Note that if the value of slider-segment-width + 2 * air-gap is higher than the finger diameter, it may be possible to increase and adjust the sensitivity of all slider segments such that even if the finger is placed in the middle of a slider segment, adjacent sensors report a difference count value equal to the noise threshold value (see Figure 210); however, this will result in the hover effect – the slider may report a centroid position even if the finger is hovering above the slider and not touching the slider.
Dummy segments at the ends of a slider
In a CAPSENSE™ design, when one segment is scanned, adjacent segments are connected to either ground or to the driven- shield signal based on the option specified in the “Inactive sensor connection” parameter in the CAPSENSE™ CSD Component. For a linear centroid response, the slider requires all the segments to have the same sensitivity, that is, the increase in the raw count (signal) when a finger is placed on the slider segment should be the same for all segments. To maintain a uniform signal level from all slider segments, it is recommended that you physically connect the two segments at both ends of a slider to either ground or driven shield signal. The connection to ground or to the driven-shield signal depends on the value specified in the “Inactive sensor connection” parameter. Therefore, if your application requires an ‘n’ segment slider, it is recommended that you create n+2 physical segments, as Figure 209 shows.
If it is not possible to have two segments at both ends of a slider due to space constraints, you can implement these segments in the top hatch fill, as Figure 220 shows. Also, if the total available space is still constrained, the width of these segments may be kept lesser than the width of segments SLD0 through SLDn-1, or these dummy segments may even be removed.
If the two segments at the both ends of a slider are connected to the top hatch fill, you should connect the top hatch fill to the signal specified in the “Inactive sensor connection” parameter. If liquid tolerance is required for the slider, the hatch fill around the slider, the last two segments, and the inactive slider segments should be connected to the driven-shield signal. See the Effect of liquid droplets and liquid stream on a self-capacitance sensor section for more details.
Deciding slider dimensions
Slider dimensions for a given design can be chosen based on following considerations:
-
Decide the required length of the slider (L) based on application requirements. This is same as the “effective slider length” as Figure 209 shows.
-
Decide the height of the segment based on the available space on the board. Use the maximum allowed segment height (15 mm) if the board space permits; if not, use a lesser height but ensure that the height is greater than the minimum specified in Table 35.
-
The slider-segment width and the air gap between slider segments should be as recommended in Table 35. The recommended slider-segment-width and air-gap for an average finger diameter of 9 mm is 8 mm and 0.5 mm respectively.
-
For a given slider length L, calculate the number of segments required by using the following formula:
If the available number of CAPSENSE™ pins is slightly less than the number of segments calculated for a certain application, you may increase the segment width to achieve the required slider length with the available number of pins. For example, a 10.2 cm slider requires 13 segments. However, if only 10 pins are available, the segment width may be increased to 10.6 cm. This will either result in a nonlinear response as Figure 218 shows, or a hover effect; however, this layout may be used if the end application does not need a high linearity.
If the available PCB area is less than that required per this equation, you can remove the dummy segments.
In this case, the minimum PCB length required will be as shown in Figure 223.
Routing slider segment trace
A slider has many segments, each of which is connected separately to the CAPSENSE™ input pin of the device. Each segment is separately scanned and the centroid algorithm is applied finally on the signal values of all the segments to calculate the centroid position. The SmartSense algorithm implements a specific tuning method for sliders to avoid nonlinearity in the centroid that could occur due to the difference of CP in the segments. However, the following layout conditions need to be met for the slider to work:
-
CP of any segment should always be within the supported range of CP as mentioned in the Component datasheet
-
CP of the slider segment should be as close as possible. However, in the practical scenario CP of each slider segment might vary because of differences in trace routing for each segment. The maximum allowed variation in the segment parasitic capacitance is 44% maximum CP of the slider segment for an 85% IDAC calibration level. If the variation in CP is beyond this limit then it may cause a change in the sensitivity among the slider segments leading to a non-linear slider response
Implement the following layout design rules to meet a good slider design with linear response.
-
Design the shape of all segments to be as uniform as possible
-
Ensure that the length and the width of the traces connecting the segments to the device are same for all the segments if possible
-
Maintain the same air gap between the sensors or traces to ground plane or hatch fill
Slider design with LEDs
In some applications, it may be required to display the finger position by driving LEDs. You can either place the LEDs just above the slider segments or drill a hole in the middle of a slider segment for LED backlighting, as Figure 224 shows. When a hole is drilled for placing an LED, the effective area of the slider segment reduces. To achieve an SNR > 5:1, you need to have a slider segment with a width larger than the LED hole size. See Table 35 for the minimum slider width required to achieve an SNR > 5:1 for a given overlay thickness. Follow the guidelines provided in the Crosstalk solutions section to route the LED traces.
Sensor and device placement
Follow these guidelines while placing the sensor and the device in your PCB design:
-
Minimize the trace length from the device pins to the sensor pad
-
Mount series resistors within 10 mm of the device pins to reduce RF interference and provide ESD protection. See Series resistors on CAPSENSE™ pins for details
-
Mount the device and the other components on the bottom layer of the PCB
-
Avoid connectors between the sensor and the device pins because connectors increase CP and noise pickup
-
Button to Button distance (edge to edge) must be greater than 8 mm. If keys have less than 8 mm between them, there will be cross talk between the keys. Also, from a usability standpoint, it increases the risk of the user touching two keys at the same time. Key to key distance must be greater than 8 mm
-
Spacing from a touch line to any metal should be greater than 5 mm. This includes the metal chassis, decorative chrome trim, screws, and so on
-
Isolate or provide physical separation between CAPSENSE™ components and their signals from noisy subsystems such as transformers. A CAPSENSE™ system in general is sensitive to external noise
Trace length and width
Use short and narrow PCB traces to minimize the parasitic capacitance of the sensor. The maximum recommended trace length is 12 inches (300 mm) for a standard PCB and 2 inches (50 mm) for flex circuits. The maximum recommended trace width is 7 mil (0.18 mm). You should surround the CAPSENSE™ traces with a hatched ground or hatched shield with trace-to-hatch clearance of 10 mil to 20 mil (0.25 mm to 0.51 mm).
Trace routing
You should route the sensor traces on the bottom layer of the PCB, so that the finger does not interact with the traces. Do not route traces directly under any sensor pad unless the trace is connected to that sensor.
Do not run capacitive sensing traces closer than 0.25 mm to switching signals or communication lines. Increasing the distance between the sensing traces and other signals increases the noise immunity. If it is necessary to cross communication lines with sensor pins, make sure that the intersection is at right angles, as Figure 225 shows.
If, due to spacing constraints, sensor traces run in parallel with high-speed traces such as I2C communication lines or Bluetooth® LE antenna traces, it is recommended to place a ground trace between the sensor trace and the high-speed trace as shown in Figure 226. This guideline also applies to the cross talk caused by CAPSENSE™ sensor trace with precision analog trace such as traces from temperature sensor to the PSoC™ device. The thickness of the ground trace can be 7 mils and the spacing from sensor trace to ground trace should be equal to minimum of 10 mils to reduce the CP of the CAPSENSE™ sensor.
If a ground trace cannot be placed in between the switching trace and the CAPSENSE™ trace, the 3W rule can be followed to reduce the cross talk between the traces. The 3W rule states that “to reduce cross talk from adjacent traces, a minimum spacing of two trace widths should be maintained from edge to edge” as shown in Figure 227.
-
Do not run Tx and Rx lines parallel to each other. The trace routing should be separated as much as possible
-
If the layout constraints require Tx and Rx run parallel for short distances, the space between Tx and Rx should be greater than the distance between Tx and Rx inside the key (2 times the Tx-Rx key spacing is preferred) or add ground between them
-
Keep as much clearance around Rx as possible to prevent noise on the touch keys. It is critical to follow this guideline for spacing to power traces and LED lines (high speed switching, power). Ground should also follow this rule, but it is less critical. Ground will provide noise protection but will reduce key sensitivity
-
For a given set of sensors, the number of Rx lines must be less than or equal to Tx lines. Rx lines are susceptible to noise, whereas Tx lines are relatively less susceptible
Crosstalk solutions
A common backlighting technique for panels is an LED mounted under the sensor pad so that it is visible through a hole in the middle of the sensor pad. When the LED is switched ON or OFF, voltage transitions on the LED trace can create crosstalk in the capacitive sensor input, creating noisy sensor data. To prevent this crosstalk, isolate CAPSENSE™ and the LED traces from one another as Trace routing section explains.
You can also reduce crosstalk by removing the rapid transitions in the LED drive voltage, by using a filter as Figure 228 shows. Design the filter based on the required LED response speed.
A guard trace is a ground trace running close to or above/below a TX/Rx line of a mutual-capacitance button. Guard traces can be used to protect sensor traces from noise if the layout does not allow for a ground hatch. Similar to ground hatch, guard traces add parasitic capacitance and reduce button sensitivity. Guard traces are usually needed on a case-by-case basis. Typical situations where guard traces have been used in the past include:
-
Reduce cross talk
-
Protect from noise of high-speed lines (I2C, SPI, UART) and toggling LED traces
-
Border around the HMI or around an LCD
Vias
Use the minimum number of vias possible to route CAPSENSE™ signals, to minimize parasitic capacitance. Place the vias on the edge of the sensor pad to reduce trace length, as Figure 229 shows.
Ground plane
When designing the ground plane, follow these guidelines:
-
Ground surrounding the sensors should be in a hatch pattern. If you are using ground or driven-shield planes in both top and bottom layers of the PCB, you should use a 25 percent hatching on the top layer (7-mil line, 45-mil spacing), and 17 percent on the bottom layer (7 mil line, 70 mil spacing)
-
For the other parts of the board not related to CAPSENSE™, solid ground should be present as much as possible
-
The ground planes on different layers should be stitched together as much as possible, depending on the PCB manufacturing costs. Higher amount of stitching results in lower ground inductance, and brings the chip ground closer to the supply ground. This is important especially when there is high current sinking through the ground, such as when the radio is operational
-
Every ground plane used for CAPSENSE™ should be star-connected to a central point, and this central point should be the sole return path to the supply ground. Specifically:
-
The hatch ground for all sensors must terminate at the central point
-
The ground plane for CMOD, CINTX must terminate at the central point
-
The ground plane for CSH_TANK must terminate at the central point
Figure 230 explains the star connection. The central point for different families is mentioned in Table 36.
Family | Central point |
---|---|
PSoC™ 4000 | VSS pin |
PSoC™ 4100/4100M | VSS pin |
PSoC™ 4200/4200M/4200L/PSoC™ 4-S/PSoC™ 4100PS | VSS pin |
PSoC™ 4100-BL | E-pad |
PSoC™ 4200-BL | E-pad |
- All the ground planes for CAPSENSE™ should have an inductance of less than 0.2 nH from the central point. To achieve this, place the CMOD, CINTx, and CSH_TANK capacitor pads close to the chip, and keep their ground planes thick enough
Using packages without E-pad
When not using the E-pad, the VSS pin should be the central point and the sole return path to the supply ground. High-level layout diagrams of the top and bottom layers of a board when using a chip without the E-pad are shown in Figure 231 and Figure 232.
Using packages with E-pad
If you are using packages with E-pad, the following guidelines must be followed:
-
The E-pad must be the central point and the sole return path to the supply ground
-
The E-pad must have vias underneath to connect to the next layers for additional grounding. Generally unfilled vias are used in a design for cost purposes, but silver-epoxy filled vias are recommended for the best performance as they result in the lowest inductance in the ground path
Using PSoC 4 Bluetooth LE devices
In the case of PSoC™ 4 Bluetooth® LE devices in the QFN package (with E-pad):
-
The general guidelines of ground plane (discussed above) apply
-
The E-pad usage guidelines of Using packages with E-pad apply
-
The VSSA pin should be connected to the E-pad below the chip itself
-
The vias underneath the E-pad are recommended to be 5x5 vias of 10-mil size
High-level layout diagrams of the top and bottom layers of a board when using PSoC™ 4 Bluetooth® LE chips are shown in Figure 233 and Figure 234.
Power supply layout recommendations
CAPSENSE™ is a high-sensitivity analog system. Therefore, a poor PCB layout introduces noise in high-sensitivity sensor configurations such as proximity sensors and buttons with thick overlays (>1 mm). To achieve low noise in a high-sensitivity CAPSENSE™ design, the PCB layout should have decoupling capacitors on the power lines, as listed in Table 37.
Power line | Decoupling capacitors | Corresponding ground terminal | Applicable device family |
---|---|---|---|
VDD | 0.1 µF and 1 µF | VSS | PSoC™ 4000 |
VDDIO | 0.1 µF and 1 µF | VSS | PSoC™ 4000, PSoC™ 6 MCU |
VDDD | 0.1 µF and 1 µF | VSS | PSoC™ 4100, PSoC™ 4200, PSoC™ 6 MCU |
0.1 µF and 1 µF | VSSD | PSoC™ 4100-BL, PSoC™ 4200-BL, PSoC™ 4200L, PSoC™ S-series, PSoC™ 4100S Plus, PSoC™ 4100S Max | |
See device datasheet | VSSD | PSoC™ 4000T | |
VDDA17 | 0.1 µF and 1 µF (Battery powered supply) | VSSA | PSoC™ 4100, PSoC™ 4200, PSoC™ 4100-BL, PSoC™ 4200-BL, PSoC™ 4200L, PSoC™ 4S-Series, PSoC™ 4100S Plus, PSoC™ 4100PS, PSoC™ 6 MCU |
0.1 µF and 10 µF (Mains Powered supply) | VSSA | PSoC™ 4S-series, PSoC™ 4100S Plus, PSoC™ 4100PS | |
VDDR | 0.1 µF and 1 µF | VSSD | PSoC™ 4100-BL, PSoC™ 4200-BL, PSoC™ 6 MCU with Bluetooth® LE Connectivity |
VCCD | See device datasheet | VSS (PSoC™ 4000) or VSSD (all others) | All device families |
The decoupling capacitors and CMOD capacitor must be placed as close to the chip as possible to keep ground impedance and supply trace length as low as possible.
For further details on bypass capacitors, see the Power section in the Device datasheet.
Layout guidelines for liquid tolerance
As explained in the Liquid tolerance section, by implementing a shield electrode and a guard sensor, a liquid-tolerant ™ system can be implemented. If there are multiple CSD blocks in the device, each CSD block should have a dedicated shield electrode. This section shows how to implement a shield electrode and a guard sensor.
Layout guidelines for shield electrode
The area of the shield electrode depends on the size of the liquid droplet and the area available on the board for implementing the shield electrode. The shield electrode should surround the sensor pads and traces, and spread no further than 1 cm from these features. Spreading the shield electrode beyond 1 cm has negligible effect on system performance.
Also, having a large shield electrode may increase radiated emissions. If the board area is very large, the area outside the 1-cm shield electrode should be left empty, as Figure 235 shows. The board design should focus on reducing the coupling capacitance between the liquid droplet and ground. Thus, for improved liquid tolerance, there should not be any hatch fill or a trace connected to ground in the top and bottom layers of the PCB.
When there is a grounded hatch fill or a trace then, when a liquid droplet falls on the touch surface, it may cause sensor false triggers. Even if there is a shield electrode between the sensor and ground, the effect of the shield electrode will be totally masked out and sensors may false trigger.
In some applications, there may not be sufficient area available on the PCB for shield electrode implementation. In such cases, the shield electrode can spread less than 1 cm; the minimum area for shield electrode can be the area remaining on the board after implementing the sensor.
In some applications, the capacitance of the shield electrode will be very high; you can reduce it with the following techniques:
-
Using multiple shield electrode instead of single shield electrode: If there is a single hatch pattern with a higher CP, split the hatch pattern into multiple hatch patterns and drive it with the shield signal to decrease the shield CP. This will also allow the use of a higher range of sense clock frequencies for the sensors which will improve the sensitivity of the CAPSENSE™ system. In a complex layout design, this approach will make trace routing simple
-
Connecting multiple shield pins to the same electrode: If splitting the shield electrode in the layout is not feasible, connect multiple shield pins to the same electrode. This will make all the series resistance of the sensor pins in parallel and reduce the effective time constant of the shield electrode, which will allow using a higher range of sense clock frequencies for sensors, which will improve the sensitivity of the CAPSENSE™ system
Follow these guidelines to implement the shield electrode in two-layer and four-layer PCBs:
Two-layer PCB:
-
Top layer: Hatch fill with 7 mil trace and 45 mil grid (25 percent fill). Hatch fill should be connected to the driven-shield signal
-
Bottom layer: Hatch fill with 7 mil trace and 70 mil grid (17 percent fill). Hatch fill should be connected to the driven-shield signal
Four (or more)-layer PCB:
-
Top layer: Hatch fill with 7 mil trace and 45 mil grid (25 percent fill). Hatch fill should be connected to the driven-shield signal
-
Layer-2: Hatch fill with 7 mil trace and 70 mil grid (17 percent fill). Hatch fill should be connected to the driven-shield signal
-
Layer-3: VDD Plane
-
Bottom layer: Hatch fill with 7 mil trace and 70 mil grid (17 percent fill). Hatch fill should be connected to ground
The recommended air gap between the sensor and the shield electrode is 1 mm.
Layout guidelines for guard sensor
As explained in the Guard sensor section, the guard sensor is a copper trace that surrounds all sensors, as Figure 236 shows.
The guard sensor should be triggered only when there is a liquid stream on the touch surface. Ensure that the shield electrode pattern surrounds the guard sensor to prevent it from turning on due to liquid droplets. The guard sensor should be placed such that it meets the following conditions:
-
It should be the first sensor to turn on when there is a liquid stream on the touch surface. To accomplish this, the guard sensor is usually placed such that it surrounds all sensors
-
It should not be accidentally touched while pressing a button or slider sensor. Otherwise, the button sensors and slider sensor scanning will be disabled and the CAPSENSE™ system will become nonoperational until the guard sensor is turned off. To ensure the guard sensor is not accidentally triggered, place the guard sensor at a distance greater than 1 cm from the sensors
Follow these guidelines to implement the guard sensor:
-
The guard sensor should be in the shape of a rectangle with curved edges and should surround all the sensors
-
The recommended thickness for a guard sensor is 2 mm
-
The recommended clearance between the guard sensor and the shield electrode is 1 mm
If there is no space on the PCB for implementing a guard sensor, the guard sensor functionality can be implemented in the firmware. For example, you can use the ON/OFF status of different sensors to detect a liquid stream depending on the use case data.
The following conditions can be used to detect a liquid stream on the touch surface:
-
When there is a liquid stream, more than one button sensor will be active at a time. If your design does not require multi-touch sensing, you can detect this and reject the sensor status of all the button sensors to prevent false triggering
-
In a slider, if the slider segments which are turned ON are not adjacent segments, you can reset the slider segments status or reject the slider centroid value that is calculated
-
A firmware algorithm to detect the false touch due to water drop from the use case data can be made to improve the false touch rejection capability sensors
Liquid tolerance with ground ring
In some applications, it is required to have a ground ring (solid trace or a hatch fill) around the periphery of the board for improved ESD performance, as shown in Figure 237. The ground ring is used to redirect the ESD as explained inRedirect. Having a ground ring around the board may result in sensor false triggers when liquid droplets fall in between the sensor and the ground sensor. Therefore, it is recommended not to have any ground in the top layer. If the design must have a ground ring in the top layer, use a ground ring with the minimum thickness (8 mils).
Schematic rule checklist
Table 38 provides the checklist to verify your CAPSENSE™ schematic.
No. | Category | Recommendations/Remarks |
---|---|---|
1 | CMOD | 2.2 nF. X7R or NP0 capacitors can be used for CMOD. X7R type CMOD will experience very large raw count variation and probably saturation in applications where the temperature range is well above ambient (that is, > 50C). Hence, it is recommended to select the CMOD capacitor type according to the expected operating temperature range. See Table 39 for pin selection. |
2 | CSH_TANK18 | 10 nF if shield electrode is used; NA otherwise. See Driven shield signal and shield electrode and CAPSENSE™ CSD shielding for details on shield electrode and use of CSH_TANK respectively. See Table 39 for pin selection. |
3 | CINTA/CINTB19 | 470 pF. See Table 39 for pin selection. |
4 | Series resistance on input lines | 560 Ω for self-capacitance and 2 kΩ for mutual-capacitance. See Series resistors on CAPSENSE™ pins for details. |
5 | Sensor pin selection | If possible, avoid pins that are close to the GPIOs carrying switching/communication signals. Physically separate DC loads such as LEDs and I2C pins from the CAPSENSE™ pins by a full port wherever possible. See Sensor pin selection section for more details. |
6 | GPIO source/sink current | Ensure that the total sink current through GPIOs is not greater than 40 mA when the CAPSENSE™ block is scanning the sensors. |
7 | Series resistance on shield lines | 560 Ω recommended on shield lines. |
External capacitors pin selection
Device | CMOD (or CMOD1 for fifth-generation CAPSENSE™) | CSH_TANK (or CMOD2 for fifth-generation CAPSENSE™) |
---|---|---|
PSoC™ 4000 | P0[4] | P0[2] |
PSoC™ 4100/PSoC™ 4200 | P4[2] | P4[3] |
PSoC™ 4200M/PSoC™ 4200L | CSD0: P4[2] | CSD0: P4[3] |
CSD1: P5[0] | CSD1: P5[1] | |
PSoC™ 4 Bluetooth® LE | P4[0] | P4[1] |
PSoC™ 6 MCU | P7[1] | P7[2] |
PSoC™ 4S-Series, PSoC™ 4100S Plus | P4[2] | P4[3] |
PSoC™ 4100PS | P5[2] | P5[3] |
PSoC™ 4100S Max | Channel0: P4[0] | Channel0: P4[1] |
Channel1: P7[0] | Channel1: P7[1] | |
PSoC™ 4000T | P4[2] | P4[3] |
Device | CMOD (or CMOD1 for fifth-generation CAPSENSE™) | CSH_TANK (or C MOD2 for fifth-generation CAPSENSE™) | C INTA | C INT B |
---|---|---|---|---|
PSoC™ 4000 | Port0[0:7], Port1 [0:7]P2[0] | Port0 [0:7], Port1 [0:7]P2[0] | P0[4] | P0[2] |
PSoC™ 4100 | Port0 [0:7], Port1 [0:7]Port2 [0:7], Port3 [0:7]P4[2] | Port0 [0:7], Port1 [0:7]Port2 [0:7], Port3 [0:7]P4[3] | Not supported | Not supported |
PSoC™ 4200 | Port0 [0:7], Port1 [0:7]Port2 [0:7], Port3 [0:7]P4[2] | Port0 [0:7], Port1 [0:7], Port2 [0:7], Port3 [0:7]P4[3] | Port0 [0:7], Port1 [0:7]Port2 [0:7], Port3 [0:7] | Port0 [0:7], Port1 [0:7]Port2 [0:7], Port3 [0:7] |
PSoC™ 4200M | CSD0: Port0 [0:7], Port1 [0:7] Port2 [0:7], Port3 [0:7] Port4 [0:6], Port6 [0:5] Port7 [0:1] | CSD0: Port0 [0:7], Port1 [0:7]Port2 [0:7], Port3 [0:7], Port4 [0:6], Port6 [0:5] Port7 [0:1] | CSD0: P4[2] | CSD0: P4[3] |
CSD1: Not supported | CSD1: Not supported | CSD1: Not supported | CSD1: Not supported | |
PSoC™ 4200L | CSD0: Port0 [0:7], Port1 [0:7] Port2 [0:7], Port3 [0:7] Port4 [0:6], Port6 [0:5] Port7 [0:7], Port10 [0:7], Port11 [0:7] | CSD0: Port0 [0:7], Port1 [0:7] Port2 [0:7], Port3 [0:7] Port4 [0:6], Port6 [0:5] Port7 [0:7], Port10 [0:7] Port11 [0:7] | CSD0: P4[2] | CSD0: P4[3] |
CSD1: Port5 [0:7], Port8 [0:7] Port9 [0:7] | CSD1: Port5 [0:7], Port8 [0:7] Port9 [0:7] | CSD1: P5[0] | CSD1: P5[1] | |
PSoC™ 4 Bluetooth® LE | Port0 [0:7], Port1 [0:7]Port2 [0:7], Port3 [0:7]Port4 [0:1], Port5 [0:1]Port6 [0:1] | Port0 [0:7], Port1 [0:7]Port2 [0:7], Port3 [0:7]Port4 [0:1], Port5 [0:1]Port6 [0:1] | P4[0] | P4[1] |
PSoC™ 6 MCU | P7[1] or P7[2] or P7[7] | P7[1] or P7[2] or P7[7] | P7[1] | P7[2] |
PSoC™ 4S-Series, PSoC™ 4100S Plus | P4[2], P4[3], P4[1] | P4[2], P4[3], P4[1] | P4[2] | P4[3] |
PSoC™ 4100PS | P5[0], P5[2], P5[3] | P5[0], P5[2], P5[3] | P5[2] | P5[3] |
PSoC™ 4100S Max20 | Channel0: P4[0], P4[2] | Channel0: P4[1], P4[3] | Not applicable | Not applicable |
Channel1: P7[0], P5[1] | Channel1: P7[1], P5[2] | |||
PSoC™ 4000T | P4[2], | P4[3] | Not applicable | Not applicable |
Sensor pin selection
The selection of the sensor pins should be in a way such that the CAPSENSE™ sensor traces and communication or other toggling GPIO traces are isolated by proper port/pin assignment. The following are some recommended guidelines:
-
Isolate switching signals, such as PWM, I2C communication lines, and LEDs from the sensor and sensor traces. Place them at least 4 mm apart and fill a hatched ground between the CAPSENSE™ traces and the switching signals to avoid crosstalk
-
Distribute the placement of DC loads on different ports to reduce the noise in CAPSENSE™. It is recommended to have digital I/Os spread on different ports rather than concentrating in a single port
-
While the CAPSENSE™ block is scanning the sensor, limit the total source or sink current through GPIOs to less than 40 mA while the CAPSENSE™ block is scanning the sensor. Sinking a current greater than 40 mA while the CAPSENSE™ sensor is scanning may result in excessive noise in the sensor raw count
-
For a PSoC™ 4 device it is recommended to place all the digital DC loads like LEDs, I2C/UART communication pins on the port powered by only VSSD; see the Device datasheet for determining the ports that are powered by VSSD. Placing DC loads on ports powered by VSSA will shift the VSSA up. Since CAPSENSE™ is powered by VSSA, it will affect its performance
-
For PSoC™ 6 family of devices:
-
Table 41 lists the ports that support CAPSENSE™, selecting ports 5, 6, 7, and 8 for CAPSENSE™ ensures lesser noise
-
It is recommended to place all digital switching pins such as LEDs, I2C, UART, SPI, SMIF communication pins on the ports that are powered by a different power supply domain which is not shared with the CAPSENSE™ ports. Table 42 lists the ports, their supply domains, and recommendations for using these ports with CAPSENSE™. For more details, see the Errata section of the Device datasheet. A deviation from these guidelines might cause a noise due to level shift in raw count. For more details, see Raw counts show a level-shift or increased noise when GPIOs are toggled. To isolate the supply domains further, it is better to externally isolate them using ferrite beads as shown in Figure 239
Device | CAPSENSE™ capable ports |
---|---|
CY8C62x6, CY8C62x7 | P0, P1, P2, P4, P5, P6, P7, P8, P9, P10, P11 |
CY8C63x6, CY8C63x7 | P0, P1, P2, P4, P5, P6, P7, P8, P9, P10, P11 |
CY8C62x5 | P7.0 to P7.7, P8.0 to P8.3, P9.0 to P9.3 |
Ports | Supply domain | Recommended for CAPSENSE™ | Recommendations for GPIOs if used for communication, LEDs, and other high frequency functionality with CAPSENSE™ |
---|---|---|---|
P0 | VBACKUP | No* | Switching frequency < 8 MHz |
P1 | VDDD | No* | Switching frequency < 1 MHz, SLOW Slew Rate |
P2, P3, P4 | VDDIO2 | No* | Switching frequency < 25 MHz |
P5, P6, P7, P8 | VDDIO1 | Yes | Not recommended |
P9, P10 | VDDIOA | No* | Switching frequency < 1 MHz, SLOW Slew Rate |
P11, P12, P13 | VDDIO0 | No* | Switching frequency < 80 MHz |
P14 | VDDUSB | No* | NA |
19 These external capacitors are only used in the case of third- and fourth-generation CAPSENSE™
Layout rule checklist
Table 43 provides the checklist to help verify your layout design.
No. | Category | Minimum value | Maximum value | Recommendations/Remarks | |
---|---|---|---|---|---|
1 | Button | Shape | N/A | N/A | Circle or rectangular with curved edges |
Size | 5 mm | 15 mm | 10 mm | ||
Clearance to ground hatch | 0.5 mm | 2 mm | Should be equal to overlay thickness | ||
2 | Slider | Width of segment | 1.5 mm | 8 mm | 8 mm |
Clearance between segments | 0.5 mm | 2 mm | 0.5 mm | ||
Height of segment | 7 mm | 15 mm | 12 mm | ||
3 | Overlay | Type | N/A | N/A | Material with high relative permittivity (except conductors) Remove any air gap between sensor board and overlay/front panel of the casing. |
Thickness for buttons | N/A | 5 mm | |||
Thickness for sliders | N/A | 5 mm | |||
Thickness for touchpads | N/A | 0.5 mm | |||
4 | Sensor traces | Width | N/A | 7 mil | Use the minimum width possible with the PCB technology that you use. |
Length | N/A | 300 mm for a standard (FR4) PCB 50 mm for flex PCB | Keep as low as possible. | ||
Clearance to ground and other traces | 0.25 mm | N/A | Use maximum clearance while keeping the trace length as low as possible. | ||
Routing | N/A | N/A | Route on the opposite side of the sensor layer. Isolate from other traces. If any non-CAPSENSE™ trace crosses the CAPSENSE™ trace, ensure that intersection is orthogonal. Do not use sharp turns. | ||
5 | Via | Number of vias | 1 | 2 | At least one via is required to route the traces on the opposite side of the sensor layer. |
Hole size | N/A | N/A | 10 mil | ||
6 | Ground | Hatch fill percentage | N/A | N/A | Use hatch ground to reduce parasitic capacitance. Typical hatching: 25% on the top layer (7 mil line, 45 mil spacing) 17% on the bottom layer (7 mil line, 70 mil spacing) |
7 | Series resistor | Placement | N/A | N/A | Place the resistor within 10 mm of the PSoC™ pin. See Figure 240 for an example placement of series resistance on board. |
8 | Shield electrode | Spread | N/A | 1 cm | If you have PCB space, use 1-cm spread. |
9 | Guard sensor (for water tolerance) | Shape | N/A | N/A | Rectangle with curved edges |
Thickness | N/A | N/A | Recommended thickness of guard trace is 2 mm and distance of guard trace to shield electrode is 1 mm. | ||
10 | Ground Ring(for ESD protection) | Shape | N/A | N/A | Around the board periphery with curved edges. Can be a solid trace or a hatch fill. |
Thickness | N/A | N/A | Not recommended in top layer as it can cause sensor false triggers with liquid droplets. If design must have a Ground Ring in the top layer, use a minimum thickness ring of 8 mils. | ||
11 | CMOD | Placement | N/A | N/A | Place close to the PSoC™ pin. See Figure 240 for an example placement of CMOD on PCB. |
12 | CSH_TANK | Placement | N/A | N/A | Place close to the PSoC™ pin. See Figure 240 for an example placement of CSH_TANK on board. |
13 | CINTA | Placement | N/A | N/A | Place close to the PSoC™ pin. See Figure 240 for an example placement of CINTA on the PCB. |
14 | CINTB | Placement | N/A | N/A | Place close to the PSoC™ pin. See Figure 240 for an example placement of CINTA on the PCB. |
19 These external capacitors are only used in the case of third- and fourth-generation CAPSENSE™
Noise in CAPSENSE system
Finger injected noise
If the power supply design of the system is poor, the power and ground supplies of a device fluctuates in voltage relative to the finger ground (earth ground) in a common mode fashion. This type of noise is called common mode noise. Figure 241 illustrates the common mode noise, where both the 5 V and the 0 V output leads of the power supply remain 5 V from each other, but they move up and down together, in a “common mode” manner.
This is not a problem, until a finger touch occurs on the button. A finger touch on the button introduces a (capacitive) path to the same earth ground and it will create a path for charge flow, which is equivalent to a noise signal injected exactly at the finger touch location. This injected noise caused by the common mode noise in power supply is called finger injected noise. It is observed only during the finger touch on the button in AC powered application and it doesn’t occur in battery powered application.
Recommendations to reduce the finger injected noise
The finger injected noise could be reduced by properly following the layout and schematics guidelines described in this section. The general recommendations to reduce the finger injected noise is explained below.
- Fill the PCB board around the button with hatched pattern and connected it to device ground. Follow the recommendations as mentioned in the section Ground plane. Figure 242 shows the impact of ground on the finger injected noise for mutual capacitance button and it is also true for CSD sensing technique. In the left figure, the system doesn’t have the hatched ground around the button and most of the injected noise through the finger pass to the Rx pin of the device through the Capacitance formed between the finger and Rx electrode. In the right figure, the system has the hatched ground around the button and thus the finger injected noise is having an alternate path to flow which results in the reduction of the noise reaching to the device Rx pin.
Figure 242. Effect of ground on finger injected noise
-
Better power supply design of the system could easily eliminate the common mode noise, which will in turn reduce the finger injected noise
-
Use software technique that are available in the CAPSENSE™ component to combat the finger injected noise such as selecting optimal sensing clock frequency and Multi frequency scanning, and so on
-
Increase the overlay thickness will reduce the finger injected noise as it will decrease the capacitance formed between the finger and Rx electrode
VDDA noise
The noise in the system due to unwanted voltage ripples in the VDD supply is called VDDA noise.
Recommendations to reduce the VDDA noise
The VDDA noise could be reduced by properly following the layout and schematics guidelines in this chapter. The general recommendations to reduce the VDDA noise as follows:
-
Use clean power supply and have VDD ripples below the limits mentioned in the device datasheet
-
Use filters or an LDO regulator on the VDD power lines. Fifth-gen and fifth-gen low-power CAPSENSE™ devices are more robust towards power supply ripple compared to previous-generation CAPSENSE™ devices. The user may not need any LDO to design with these devices if the power supply ripple is within the limits mentioned in the datasheet. However, the user is advised to validate and ensure that overall system-level performance requirements are met
-
Use decoupling capacitors on the power supply pins to reduce the conducted noise from the power supply
-
To reduce high-frequency noise, place a ferrite bead around power supply or communication lines
-
Selecting the proper supply configuration as mentioned in the Power section in the Device datasheet and using the internal regulator to the device might help in reducing the VDDA noise
External noise
Any noise that is injected into to the system through the routing trace lines like ESD, EMI, conducted noise are coming into the category of external noise. The recommended guidelines for reducing the impact of the external noise are discussed in this section.
ESD protection
The nonconductive overlay material used in CAPSENSE™ provides inherent protection against ESD. Table 44 lists the thickness of various overlay materials, required to protect the CAPSENSE™ sensors from a 12 kV discharge (according to the IEC 61000 4 2 specification).
Material | Breakdown voltage (V/mm) | Minimum overlay thickness for protection against 12 kV ESD (mm) |
---|---|---|
Air | 1200 – 2800 | 10 |
Wood – dry | 3900 | 3 |
Glass – common | 7900 | 1.5 |
Glass – Borosilicate (Pyrex®) | 13,000 | 0.9 |
PMMA Plastic (Plexiglas®) | 13,000 | 0.9 |
ABS | 16,000 | 0.8 |
Polycarbonate (Lexan®) | 16,000 | 0.8 |
Formica | 18,000 | 0.7 |
FR-4 | 28,000 | 0.4 |
PET Film (Mylar®) | 280,000 | 0.04 |
Polyimide Film (Kapton®) | 290,000 | 0.04 |
If the overlay material does not provide sufficient protection (for example, ESD from other directions), you can apply other ESD counter-measures, in the following order: Prevent, Redirect, and ESD protection devices.
Preventing ESD discharge
Preventing the ESD discharge from reaching the PSoC™ is the best countermeasure you can take. Make sure that all paths to PSoC™ have a breakdown voltage greater than the maximum ESD voltage possible at the surface of the equipment. You should also maintain an appropriate distance between the PSoC™ and possible ESD sources. In the example illustrated in Figure 243, if L1 and L2 are greater than 10 mm, the system can withstand a 12 kV ESD.
If it is not possible to maintain adequate distance, place a protective layer of nonconductive material with a high breakdown voltage between the possible ESD source and PSoC™. One layer of 5 mil thick Kapton® tape can withstand 18 kV. See Table 44 for other material dielectric strengths.
Redirect
If your product is densely packed, preventing the discharge event may not be possible. In such cases, you can protect the PSoC™ from ESD by redirecting the ESD. A standard practice is to place a ground ring on the perimeter of the circuit board, as Figure 244 shows. The ground ring should connect to the chassis ground. Using a hatched ground plane around the button or slider sensor can also redirect the ESD event away from the sensor and PSoC™.
ESD protection devices
You can use ESD protection devices on vulnerable traces. Select ESD protection devices with a low input capacitance to avoid reduction in CAPSENSE™ sensitivity. Table 45 lists the recommended ESD protection devices.
ESD protection device | Input capacitance | Leakage current | Contact maximum ESD limit | Air discharge maximum ESD limit | |
---|---|---|---|---|---|
Manufacturer | Part number | ||||
Littelfuse | SP723 | 5 pF | 2 nA | 8 kV | 15 kV |
Vishay | VBUS05L1-DD1 | 0.3 pF | 0.1 µA | ±15 kV | ±16 kV |
NXP | NUP1301 | 0.75 pF | 30 nA | 8 kV | 15 kV |
Electromagnetic compatibility (EMC) considerations
EMC is related to the generation, transmission, and reception of electromagnetic energy that can affect the working of an electronic system. Electronic devices are required to comply with specific limits for emitted energy and susceptibility to external events. Several regulatory bodies worldwide set regional regulations to help ensure that electronic devices do not interfere with each other.
CMOS analog and digital circuits have very high input impedance. As a result, they are sensitive to external electric fields. Therefore, you should take adequate precautions to ensure their proper operation in the presence of radiated and conducted noise.
Computing devices are regulated in the US by the FCC under Part 15, Sub-Part B for unintentional radiators. The standards for Europe and the rest of the world are adapted from CENELEC. These are covered under CISPR standards (dual-labeled as ENxxxx standards) for emissions, and under IEC standards (also dual labeled as ENxxxx standards) for immunity and safety concerns.
The general emission specification is EN55022 for computing devices. This standard cover both radiated and conducted emissions. Medical devices in the US are not regulated by the FCC, but rather are regulated by FDA rules, which include requirements of EN55011, the European norm for medical devices. Devices that include motor controls are covered under EN55014 and lighting devices are covered under EN50015.
These specifications have essentially similar performance limitations for radiated and conducted emissions. Radiated and conducted immunity (susceptibility) performance requirements are specified by several sections of EN61000-4. Line voltage transients, ESD and some safety issues are also covered in this standard.
Radiated interference and emissions
While PSoC™ 4 and PRoC Bluetooth® LE offer a robust CAPSENSE™ performance, radiated electrical energy can influence system measurements and potentially influence the operation of the CAPSENSE™ processor core. Interference enters the CAPSENSE™ device at the PCB level through sensor traces and through other digital and analog inputs. CAPSENSE™ devices can also contribute to electromagnetic compatibility (EMC) issues in the form of radiated emissions.
Use the following techniques to minimize the radiated interference and emissions.
Hardware considerations
Ground Pane
In general, proper ground plane on the PCB reduces both RF emissions and interference. However, solid grounds near CAPSENSE™ sensors or traces connecting these sensors to PSoC™ pins increase the parasitic capacitance of the sensors. It is thus recommended to use hatched ground planes surrounding the sensor and on the bottom layer of the PCBs, below the sensors, as explained in the Ground plane section in PCB layout guidelines. Solid ground may be used below the device and other circuitry on the PCB which is farther from CAPSENSE™ sensors and traces. A solid ground flood is not recommended within 1 cm of CAPSENSE™ sensors or traces.
Series resistors on CAPSENSE pins
Every CAPSENSE™ controller pin has some parasitic capacitance (CP) associated with it. As Figure 245 shows, adding an external resistor forms a low-pass RC filter that attenuates the RF noise amplitude coupled to the pin. This resistance also forms a low-pass filter with the parasitic capacitance of the CAPSENSE™ sensor that significantly reduces the RF emissions.
Series resistors should be placed close to the device pins so that the radiated noise picked by the traces gets filtered at the input of the device. Thus, it is recommended to place series resistors within 10 mm of the pins.
For CAPSENSE™ designs using copper on PCBs, the recommended series resistance for CAPSENSE™ input lines is 560 Ω. Adding resistance increases the time constant of the switched-capacitor circuit that converts CP into an equivalent resistor; see GPIO cell capacitance to current converter. If the series resistance value is larger than 560 Ω, the slower time constant of the switching circuit suppresses the emissions and interference, but limits the amount of charge that can transfer. This lowers the signal level, which in turn lowers the SNR. Smaller values are better in terms of SNR, but are less effective at blocking RF.
Series resistors on digital communication lines
Communication lines, such as I2C and SPI, also benefit from series resistance; 330 Ω is the recommended value for series resistance on communication lines. Communication lines have long traces that act as antennae similar to the CAPSENSE™ traces. The recommended pull-up resistor value for I2C communication lines is 4.7 kΩ. If more than 330 Ω is placed in series on these lines, the VIL and VIH voltage levels may fall out of specifications. 330 Ω will not affect I2C operation as the VIL level still remains within the I2C specification limit of 0.3 VDD when PSoC™ outputs a LOW.
Trace length
Long traces can pick up more noise than short traces. Long traces also add to CP. Minimize the trace length whenever possible.
Current loop area
Another important layout consideration is to minimize the return path for currents. This is important as the current flows in loops. Unless there is a proper return path for high-speed signals, the return current will flow through a longer return path forming a larger loop, thus leading to increased emissions and interference.
If you isolate the CAPSENSE™ ground hatch and the ground fill around the device, the sensor-switching current may take a longer return path, as Figure 247 shows. As the CAPSENSE™ sensors are switched at a high frequency, the return current may cause serious EMC issues. Therefore, you should use a single ground hatch, as Figure 248 shows.
RF source location
If your system has a circuit that generates RF noise, such as a switched-mode power supply (SMPS) or an inverter, you should place these circuits away from the CAPSENSE™ interface. You should also shield such circuits to reduce the emitted RF. Figure 249 shows an example of separating the RF noise source from the CAPSENSE™ interface.
Firmware considerations
The following parameters affect Radiated Emissions (RE) in a CAPSENSE™ system:
-
Device operating voltage
-
Device operation frequency
-
Sensor switching frequency
-
Shield signal
-
Sensor scan time
-
Sense Clock Source Inactive sensor termination
The following sections explain the effect of each parameter.
Device operating voltage
The emission is directly proportional to the voltage levels at which switching happens. Reducing the operating voltage helps to reduce the emissions as the amplitude of the switching signal at any output pin directly depends on the operating voltage of the device.
PSoC™ allows you to operate at lower operating voltages, thereby reducing the emissions. Figure 250 and Figure 251 show the impact of operating voltage on radiated emissions. Because IMO = 24 MHz, there is a spike at 24 MHz and the other spikes are caused by different hardware and firmware operations of the device.
Device operating frequency
Reducing the system clock frequency (IMO frequency) reduces radiated emissions. However, reducing the IMO frequency may not feasible in all applications because the IMO frequency impacts the CPU clock and all other system timings. Choose a suitable IMO frequency based on your application.
Sensor-switching frequency
Reducing the sensor-switching frequency (see Sense Clock) also helps to reduce radiated emissions. See Figure 252 and Figure 253. Because IMO = 24 MHz, there is a spike at 24 MHz and the other spikes are caused by different hardware and firmware operations of the device.
Pseudo random sense clock
The PSoC™ 4 device supports PRS-based sense clock generation. A PRS is used instead of a fixed clock source to attenuate emitted noise on the CAPSENSE™ pins by reducing the amount of EMI created by a fixed-frequency source and to increase EMI immunity from other sources and their harmonics.
Spread spectrum sense clock
In addition to the PRS-based clock generation, the PSoC™ 4 S-Series, PSoC™ 4100S Plus, PSoC™ 4100PS, and PSoC™ 6 MCU family of devices supports a unique feature called spread spectrum sense clock generation, in which the sense clock frequency is spread over a desired range. This method will help to reduce the peaks and spread out the emissions over a range of frequencies. The spread spectrum clock can be enabled by selecting the Sense Clock Source as SSCn. The range of frequency spread is decided by the length of the register. For more details on the spread spectrum clock generation in the PSoC™ 4 S-Series, PSoC™ 4100S Plus, and PSoC™ 4100PS family, see the Spread spectrum clock section in the CAPSENSE™ chapter of the respective device Technical reference manual.
Shield signal
Shield signal
Enabling the shield signal (see Driven shield signal and shield electrode) on the hatch pattern increases the radiated emissions. Enable the driven-shield signal only for liquid-tolerant, proximity-sensing, or high-parasitic-capacitance designs. Also, if the shield must be used, ensure that the shield electrode area is limited to a width of 1 cm from the sensors, as Figure 235 shows.
Figure 255 and Figure 256 show the impact of enabling the driven-shield signal on the hatch pattern surrounding the sensors on radiated emissions.
Sensor scan time
Reducing the sensor scan time reduces the average radiated emissions. The sensor-scan time depends on the scan resolution and modulator clock divider (see Figure 50). Increasing the scan resolution or modulator clock divider increases the scan time.
Figure 257 and Figure 258 show the impact of sensor scan time on radiated emissions. Note that, here, the sensor scan time was varied by changing the scan resolution. Because IMO = 24 MHz, there is a spike at 24 MHz and the other spikes are caused by different hardware and firmware operations of the device.
Parameter | Total scan time for five buttons | |
---|---|---|
0.426 ms | 0.106 ms | |
Modulation clock divider | 2 | 2 |
Scan resolution | 10 bits | 8 bits |
Individual sensor scan time | 0.085 ms | 0.021 ms |
Sense clock source
Using PRS instead of direct clock drive as sense clock source spreads the radiated spectrum and hence reduces the average radiated emissions. See Figure 259 and Figure 260. Because IMO = 24 MHz, there is a spike at 24 MHz and the other spikes are caused by different hardware and firmware operations of the device.
Inactive sensor termination
Connecting inactive sensors to ground reduces the radiated emission by a greater degree than connecting them to the shield. Figure 261 and Figure 262 show the impact of different inactive sensor terminations on radiated emission. Because IMO = 24 MHz, there is a spike at 24 MHz and the other spikes are caused by different hardware and firmware operations of the device.
Conducted RF noise
The noise current that enters the CAPSENSE™ system through the power and communication lines is called conducted noise. You can use the following techniques to reduce the conducted RF noise.
-
Use decoupling capacitors on the power supply pins to reduce the conducted noise from the power supply. See section Power supply layout recommendations and the Device datasheet for details
-
Provide GND and VDD planes on the PCB to reduce current loops
-
If the PSoC™ PCB is connected to the power supply using a cable, minimize the cable length and consider using a shielded cable
To reduce high-frequency noise, place a ferrite bead around power supply or communication lines.
Effect of grounding
CSX method
The equivalent capacitances formed in the CSX method when a finger touches the CSX sensor is shown in Figure 263. From Figure 263, current drawn from the IDAC (IRX) has two components: Imt and Isc. These two components depend on the ratio of CbodyDG/Cfs. Because the raw count depends on the amount of current drawn from IDAC, the increase and decrease of CbodyDG/Cfs will affect the raw count of the sensor and cause a sudden change in the behavior on some conditions. To understand it better, consider two extreme conditions which cause CbodyDG>>Cfs and CbodyDG<<Cfs.
Where,
CM = Mutual capacitance between the Rx and Tx electrode
Cfs = Capacitance formed between the surface of the finger and electrode
Cfm = Virtual capacitance which reduces the mutual-capacitance CM due to placing a finger
CbodyDG = Body capacitance relative to the device ground
Imt is due to the effective mutual-capacitance between the Tx and Rx electrode.
Isc = Parasitic current that flows due to the capacitance formed between the sensor and finger
CbodyDG≫Cfs
Because CbodyDG>>Cfs, you can replace CbodyDG with a ground conductor; the resulting equivalent circuit appears as shown in Figure 265. Whenever there is a finger touch, the current drawn from the IDAC is directly dependent upon the effective mutual-capacitance between the Tx and Rx. This condition is observed in a good board design.
CbodyDG≪Cfs
This condition (CbodyDG<<Cfs) is observed when a finger touches a CSX button with a very thin overlay or no overlay, or a finger touching the Rx and Tx electrodes directly, or a water drop being present on the Rx and Tx electrode only. Because CbodyDG<<Cfs, you can remove CbodyDG; the equivalent circuit for this case is as shown in Figure 266. In this condition, the capacitance introduced by the finger to the electrode Cfs is very high compared to the capacitance of the finger relative to the device ground CbodyDG.
From Figure 266, it forms a balanced bridge circuit. Due to this, no current flows through Cfm, and also due to increase in Cfs, Isc increases and thus additional current is drawn from the IDAC. This causes an unexpected behavior of decrease in the raw count.
For CSX sensors, design should focus on increasing the ratio of CbodyDG/Cfs. Following are the examples for increasing the ratio of CbodyDG/Cfs:
-
CbodyDG/Cfs ratio depends on the thickness of the overlay, size of the sensor, and many other factors. By experimental data, you are recommended not to use overlay thickness below 0.5 mm for CSX sensor. See Overlay thickness
-
If the sensor is surrounded by hatch fill connected to ground, there is a lower chance that CbodyDG<<Cfs. Therefore, ensure good ground in the design. Follow the best practices for the PCB layout guidelines described in this chapter
-
In the design, it is recommended to isolate the trace lines of Rx and Tx electrode, external capacitors, and resistors of the CSX touch sensing system from any conducting surface or a finger touch to avoid direct interaction. Not following this recommendation may cause CbodyDG<<Cfs
CSD method
The equivalent capacitances formed in the CSD method when a finger touches the CSD sensor is shown in Figure 267. It shows that the current drawn from the IDAC directly depends on the capacitance introduced by the finger touch. ICPis a fixed component and ICF depends on CF,CBG,CGE. From Sigma-delta converter, the raw count depends on the amount of current drawn from IDAC. To understand it better, consider two scenarios of an AC/ DC mains-powered application and a battery-powered application.
AC/DC-powered application
In an AC / DC-powered application using the mains supply, device ground is strongly coupled to earth ground. Thus, you can replace CGE with a conductor and CBG is usually 100 pF to 200 pF. Since CBG is large when compared to CF, you can neglect its effect. Finally, the resulting equivalent circuit is shown in Figure 269. The increase in total capacitance draws a higher current from the IDAC achieving a higher change in raw count for a finger touch. Thus, in this condition, you get a higher sensitivity, which means that you will get a higher signal for a finger touch.
Battery-powered application
In battery-powered portable applications, device ground and earth ground are lightly coupled, thus CGE is small. The resulting equivalent circuit is shown in Figure 270. Thus, in this condition, you get a lower sensitivity; that means you will get a lower signal for a finger touch, which is due to a decrease in capacitance seen at the device.
Following are the recommendations for a CSD system design in a portable application powered by a battery:
-
Add a large ground plane to the system. The ground plane should be away from the sensing element such that it does not increase the parasitic capacitance of the sensor. Follow the best practices for the PCB layout guidelines described in this chapter
-
Use a driven shield to improve the sensitivity of portable devices. Refer to the Layout guidelines for shield electrode for more details
-
Reduce the thickness of the overlay material or use an overlay with better dielectric value to improve sensitivity
-
Tune the CAPSENSE™ system with powering it by a battery source
19 These external capacitors are only used in the case of third- and fourth-generation CAPSENSE™
CAPSENSE Plus
PSoC™ 4 can perform many additional functions along with CAPSENSE™. The wide variety of features offered by this device allows you to integrate various system functions in a single chip, as Figure 271 shows. Such applications are known as CAPSENSE™ Plus applications.
The additional features available in a PSoC™ 4 device include:
-
Communication: Bluetooth® LE, I2C, UART, SPI, CAN, and LIN
-
Analog functions: ADC, comparators, and opamps
-
Digital functions: PWMs, counters, timers, and UDBs
-
Segment LCD drive
-
Bootloaders
-
Different power modes: Active, sleep, deep sleep, hibernate, and stop
While using above mentioned additional features, it is recommended to configure it in sinking mode as applicable.
For more information on PSoC™ 4, see AN79953 - Getting started with PSoC™ 4, or AN91267 - Getting started with PSoC™ 4 Bluetooth® LE.
The flexibility of the PSoC™ 4 and the unique PSoC™ Creator IDE allow you to quickly make changes to your design, which accelerates time-to-market. Integrating other system functions significantly reduces overall system cost. Table 47 shows a list of example applications, where using CAPSENSE™ Plus can result in significant cost savings.
Application | CAPSENSE™ | Opamp | ADC | Comp | PWM, Counter, Timer, UDBs | Comm(Bluetooth® LE, I2C, SPI, UART) | LCD drive | GPIOs |
---|---|---|---|---|---|---|---|---|
Heart rate monitor (wrist band) | User interface: buttons, linear sliders | TIA, Buffer | Heart Rate Measurement, Battery voltage measurement | LED Driving | Bluetooth® LE | Segment LCD | LED indication | |
LED bulb | User interface: buttons, radial sliders | Amplifier | LED current measurement | Short circuit protection | LED color control (PrISM*) | Bluetooth® LE | LED indication | |
Washing machine | User interface: buttons, radial sliders | Temperature sensor | Water level monitor | Buzzer, FOC** motor control | I2C LCD display, UART network interface | Segment LCD | LED indication | |
Water heater | User interface: buttons, linear sliders | Temperature sensor, water flux sensor | Water level monitor | Buzzer | I2C LCD display, UART Network Interface | Segment LCD | LED indication | |
IR remote controllers | User interface: buttons, linear and radial sliders, touchpads | Manchester encoder | LED indication | |||||
Induction cookers | User interface: buttons, linear sliders | Temperature sensor | Segment LCD | LED indication | ||||
Motor control systems | User interface: buttons, linear sliders | BLDC*** and FOC motor control | LED indication | |||||
Gaming/simulation controllers | User interface: buttons, touchpads | Reading analog joysticks | I2C/SPI/UART communication interface | Segment LCD | LED indication | |||
Thermal printers | User interface: buttons | Overheat protection, paper sensor | Stepper motor control | SPI communication interface | LED indication |
- PrISM = Precision illumination signal modulation
** FOC = Field oriented control
*** BLDC = Brushless DC motor
Figure 272 shows a general block diagram of a CAPSENSE™ Plus application, such as an induction cooker or a microwave oven.
In this application, the 12-bit 1 Msps SAR ADC in the PSoC™ 4 detects over-current, overvoltage, and high temperature conditions. The PWM output drives the speaker for status and alarm tones. Another PWM controls the heating element in the system. The CAPSENSE™ buttons and slider constitute the user interface. PSoC™ 4 can also drive a segment LCD for visual outputs. PSoC™ 4 has a serial communication block that can connect to the main board of the system.
Figure 273 shows the application-level block diagram of a fitness tracker based on PSoC™ 6 MCU with Bluetooth® LE Connectivity. The device provides a one-chip solution and includes features like activity monitoring, environment monitoring, CAPSENSE™ for user interface, Bluetooth® LE connectivity, and so on. For more information on PSoC™ 6 MCU, see AN210781 – Getting started with PSoC™ 6 MCU with Bluetooth® LE connectivity.
Resources
Website
Visit the Getting started with PSoC™ 4, Getting started with PSoC™ 4 Bluetooth® LE, Getting started with PSoC™ 6 MCU, and Getting started with PSoC™ 6 MCU with Bluetooth® LE connectivity website to understand the PSoC™ 4, PSoC™ 6 MCU with Bluetooth® LE connectivity.
Device datasheet
-
PSoC™ 4 datasheet
-
PSoC™ 4 Bluetooth® LE datasheet
-
PSoC™ 6 MCU devices
Component datasheet/middleware document
-
PSoC™ 4 Capacitive Sensing
-
PSoC™ 6 capacitive sensing
-
CAPSENSE™ middleware library
-
ModusToolbox™ CAPSENSE™ configurator guide
Technical reference manual
The PSoC™ 4 Technical reference manual (TRM) and PSoC™ 6 Technical reference manual (TRM) provide quick and easy access to information on PSoC™ 4 and PSoC™ 6 architecture including top-level architectural diagrams, register summaries, and timing diagrams.
Development kits
Table 8 lists Infineon® development kits that support PSoC™ 4 and PSoC™ 6 CAPSENSE™.
PSoC Creator
PSoC™ Creator is a state-of-the-art, easy-to-use integrated development environment. See the PSoC™ Creator home page.
ModusToolbox
ModusToolbox™ software suite is used for the development of PSoC™ 4 and PSoC™ 6 based CAPSENSE™ applications. You can download the ModusToolbox™ software here. The related documents are as follows:
-
ModusToolbox™ release notes
-
ModusToolbox™ install guide
-
ModusToolbox™ user guide
-
ModusToolbox™ quick start guide
-
ModusToolbox™ software training
-
ModusToolbox™ CAPSENSE™ configurator
-
ModusToolbox™ CAPSENSE™ tuner
-
ModusToolbox™ device configurator
-
ModusToolbox™ SmartIO configurator
-
PSoC™ Creator to ModusToolbox™
-
ModusToolbox™ command line
Application notes and design guides
® A large collection of application notes are available to get your design up and running fast. See PSoC™ 4 application notes, PSoC™ 4 Bluetooth® LE application notes, CAPSENSE™ application notes and design guides.
Following is the list of CAPSENSE™ specific applications notes:
Design guide for PSoC™ 3 and PSoC™ 5LP devices
- PSoC™ 3 and PSoC™ 5LP CAPSENSE™ design guide
Design guides for the CAPSENSE™ Express family
-
CY8CMBR3XXX CAPSENSE™ design guide
-
CY8CMBR2110 CAPSENSE™ design guide
-
CY8CMBR2016 CAPSENSE™ design guide
-
CY8CMBR2010 CAPSENSE™ design guide
-
CY8CMBR2044 CAPSENSE™ design guide
-
CAPSENSE™ Express™: CY8C201XX application notes
Design guides for PSoC™ 1 devices
-
CY8C20XX7/S design guide
-
CY8C20XX6A/H CAPSENSE™ design guide
-
CY8C21X34/B CAPSENSE™ design guide
-
CY8C20X34 CAPSENSE™ design guide
Getting started application note
-
AN79953 - Getting started with PSoC™ 4
-
AN210781 – Getting started with PSoC™ 6 MCU with Bluetooth® LE connectivity
-
AN221774 – Getting started with PSoC™ 6 MCU
Design support
-
Knowledge base articles – Browse technical articles by product family or perform a search on CAPSENSE™ topics
-
White papers – Learn about advanced capacitive-touch interface topics
-
Infineon developer community – Connect with the technical community and exchange information
-
Video library – Quickly get up to speed with tutorial videos
-
Quality and reliability – We are committed to complete customer satisfaction. At our Quality website, you can find reliability and product qualification reports
-
https://www.infineon.com/cms/en/about-infineon/company/contacts/support/– Submit your design for review by creating a support case. You need to register and login at the website to be able to contact technical support. It is recommended to use PDF prints for the schematic and Gerber files with layer information for the layout
AMUXBUS
Analog multiplexer bus available inside PSoC™ that helps to connect I/O pins with multiple internal analog signals.
AMUXBUS
Baseline
A value resulting from a firmware algorithm that estimates a trend in the Raw Count when there is no human finger present on the sensor. The Baseline is less sensitive to sudden changes in the Raw Count and provides a reference point for computing the Difference Count.
Baseline
Button or button widget
A widget with an associated sensor that can report the active or inactive state (that is, only two states) of the sensor. For example, it can detect the touch or no-touch state of a finger on the sensor.
Button or button widget
Difference count
The difference between Raw Count and Baseline. If the difference is negative, or if it is below Noise Threshold, the Difference Count is always set to zero.
Difference count
Capacitive sensor
A conductor and substrate, such as a copper button on a printed circuit board (PCB), which reacts to a touch or an approaching object with a change in capacitance.
Capacitive sensor
CAPSENSE
Infineon® Touch-sensing user interface solution. The industry’s No. 1 solution in sales by 4x over No. 2.
CAPSENSE™
CAPSENSE Mechanical Button Replacement (MBR)
Configurable solution to upgrade mechanical buttons to capacitive buttons, requires minimal engineering effort to configure the sensor parameters and does not require firmware development. These devices include the CY8CMBR3XXX and CY8CMBR2XXX families.
CAPSENSE™ Mechanical Button Replacement (MBR)
Centroid or Centroid Position
A number indicating the finger position on a slider within the range given by the Slider Resolution. This number is calculated by the CAPSENSE™ centroid calculation algorithm.
Centroid or Centroid Position
Compensation IDAC
A programmable constant current source, which is used by CSD to compensate for excess sensor CP. This IDAC is not controlled by the Sigma-Delta Modulator in the CSD block unlike the Modulation IDAC.
Compensation IDAC
CAPSENSE Sigma Delta
CAPSENSE™ Sigma Delta (CSD) is a patented method of performing self-capacitance (also called self-cap) measurements for capacitive sensing applications.
In CSD mode, the sensing system measures the self-capacitance of an electrode, and a change in the self-capacitance is detected to identify the presence or absence of a finger.
CAPSENSE™ Sigma Delta
CSD
Debounce
A parameter that defines the number of consecutive scan samples for which the touch should be present for it to become valid. This parameter helps to reject spurious touch signals.
A finger touch is reported only if the Difference Count is greater than Finger Threshold
- Hysteresis for a consecutive Debounce number of scan samples.
Debounce
Driven-shield
A technique used by CSD for enabling liquid tolerance in which the Shield Electrode is driven by a signal that is equal to the sensor switching signal in phase and amplitude.
Driven-shield
Electrode
A conductive material such as a pad or a layer on PCB, ITO, or FPCB. The electrode is connected to a port pin on a CAPSENSE™ device and is used as a CAPSENSE™ sensor or to drive specific signals associated with CAPSENSE™ functionality.
Electrode
Finger threshold
A parameter used with Hysteresis to determine the state of the sensor. Sensor state is reported ON if the Difference Count is higher than Finger Threshold + Hysteresis, and it is reported OFF if the Difference Count is below Finger Threshold – Hysteresis.
Finger threshold
Ganged sensors
The method of connecting multiple sensors together and scanning them as a single sensor. Used for increasing the sensor area for proximity sensing and to reduce power consumption.
To reduce power when the system is in low-power mode, all the sensors can be ganged together and scanned as a single sensor taking less time instead of scanning all the sensors individually. When you touch any of the sensors, the system can transition into active mode where it scans all the sensors individually to detect which sensor is activated.
PSoC™ supports sensor-ganging in firmware, that is, multiple sensors can be connected simultaneously to AMUXBUS for scanning.
Ganged sensors
Gesture
Gesture is an action, such as swiping and pinch-zoom, performed by the user. CAPSENSE™ has a gesture detection feature that identifies the different gestures based on predefined touch patterns. In the CAPSENSE™ Component, the Gesture feature is supported only by the Touchpad Widget.
Gesture
Guard sensor
Copper trace that surrounds all the sensors on the PCB, similar to a button sensor and is used to detect a liquid stream. When the Guard Sensor is triggered, firmware can disable scanning of all other sensors to prevent false touches.
Guard sensor
Hatch fill or hatch ground or hatched ground
While designing a PCB for capacitive sensing, a grounded copper plane should be placed surrounding the sensors for good noise immunity. But a solid ground increases the parasitic capacitance of the sensor which is not desired. Therefore, the ground should be filled in a special hatch pattern. A hatch pattern has closely-placed, crisscrossed lines looking like a mesh and the line width and the spacing between two lines determine the fill percentage. In case of liquid tolerance, this hatch fill referred as a shield electrode is driven with a shield signal instead of ground.
Hatch fill or hatch ground or hatched ground
Hysteresis
A parameter used to prevent the sensor status output from random toggling due to system noise, used in conjunction with the Finger Threshold to determine the sensor state.
Hysteresis
IDAC
Programmable constant current source available inside PSoC™, used for CAPSENSE™ and ADC operations.
IDAC (current-output digital-to-analog converter)
current-output digital-to-analog converter
Liquid tolerance
The ability of a capacitive sensing system to work reliably in the presence of liquid droplets, streaming liquids or mist.
Liquid tolerance
Linear slider
A widget consisting of more than one sensor arranged in a specific linear fashion to detect the physical position (in single axis) of a finger.
Linear slider
Low baseline reset
A parameter that represents the maximum number of scan samples where the Raw Count is abnormally below the Negative Noise Threshold. If the Low Baseline Reset value is exceeded, the Baseline is reset to the current Raw Count.
Low baseline reset
Manual-tuning
The manual process of setting (or tuning) the CAPSENSE™ parameters.
Manual-tuning
Matrix buttons
A widget consisting of more than two sensors arranged in a matrix fashion, used to detect the presence or absence of a human finger (a touch) on the intersections of vertically and horizontally arranged sensors.
If M is the number of sensors on the horizontal axis and N is the number of sensors on the vertical axis, the Matrix Buttons Widget can monitor a total of M x N intersections using ONLY M + N port pins.
When using the CSD sensing method (self-capacitance), this Widget can detect a valid touch on only one intersection position at a time.
Matrix buttons
Modulation capacitor
An external capacitor required for the operation of a CSD block in Self-Capacitance sensing mode.
Modulation capacitor (CMOD)
CMOD
Modulator clock
A clock source that is used to sample the modulator output from a CSD block during a sensor scan. This clock is also fed to the Raw Count counter. The scan time (excluding pre and post processing times) is given by (2N – 1)/Modulator Clock Frequency, where N is the Scan Resolution.
Modulator clock
Modulation IDAC
Modulation IDAC is a programmable constant current source, whose output is controlled (ON/OFF) by the sigma-delta modulator output in a CSD block to maintain the AMUXBUS voltage at VREF. The average current supplied by this IDAC is equal to the average current drawn out by the sensor capacitor.
Modulation IDAC
Multi sense converter
The multi sense converter is the analog to digital converter used in Fifth-Generation CAPSENSE™ technology also known as Ratiometric sensing technology.
Multi sense converter (MSC)
MSC
Mutual-capacitance
Capacitance associated with an electrode (say Tx) with respect to another electrode (say Rx) is known as mutual-capacitance.
Mutual-capacitance
Negative noise threshold
A threshold used to differentiate usual noise from the spurious signals appearing in negative direction. This parameter is used in conjunction with the Low Baseline Reset parameter.
Baseline is updated to track the change in the Raw Count as long as the Raw Count stays within Negative Noise Threshold, that is, the difference between Baseline and Raw count (Baseline – Raw count) is less than Negative Noise Threshold.
Scenarios that may trigger such spurious signals in a negative direction include: a finger on the sensor on power-up, removal of a metal object placed near the sensor, removing a liquid-tolerant CAPSENSE™-enabled product from the water; and other sudden environmental changes.
Negative noise threshold
CAPSENSE noise
The variation in the Raw Count when a sensor is in the OFF state (no touch), measured as peak-to-peak counts.
CAPSENSE™ noise (Noise)
Noise
Noise threshold
A parameter used to differentiate signal from noise for a sensor. If Raw Count – Baseline is greater than Noise Threshold, it indicates a likely valid signal. If the difference is less than Noise Threshold, Raw Count contains nothing but noise.
Noise threshold
Overlay
A non-conductive material, such as plastic and glass, which covers the capacitive sensors and acts as a touch-surface. The PCB with the sensors is directly placed under the overlay or is connected through springs. The casing for a product often becomes the overlay.
Overlay
Parasitic capacitance
Parasitic capacitance is the intrinsic capacitance of the sensor electrode contributed by PCB trace, sensor pad, vias, and air gap. It is unwanted because it reduces the sensitivity of CSD.
Parasitic capacitance (CP)
CP
Proximity sensor
A sensor that can detect the presence of nearby objects without any physical contact.
Proximity sensor
Radial slider
A widget consisting of more than one sensor arranged in a specific circular fashion to detect the physical position of a finger.
Radial slider
Raw count
The unprocessed digital count output of the CAPSENSE™ hardware block that represents the physical capacitance of the sensor.
Raw count
Refresh interval
The time between two consecutive scans of a sensor.
Refresh interval
Scan resolution
Resolution (in bits) of the Raw Count produced by the CSD block.
Scan resolution
Scan time
Time taken for completing the scan of a sensor.
Scan time
Self-capacitance
The capacitance associated with an electrode with respect to circuit ground.
Self-capacitance
Sensitivity
The change in Raw Count corresponding to the change in sensor capacitance, expressed in counts/pF. Sensitivity of a sensor is dependent on the board layout, overlay properties, sensing method, and tuning parameters.
Sensitivity
Sense clock
A clock source used to implement a switched-capacitor front-end for the CSD sensing method.
Sense clock
Sensor
See Capacitive sensor.
Sensor
Sensor auto reset
A setting to prevent a sensor from reporting false touch status indefinitely due to system failure, or when a metal object is continuously present near the sensor.
When Sensor Auto Reset is enabled, the Baseline is always updated even if the Difference Count is greater than the Noise Threshold. This prevents the sensor from reporting the ON status for an indefinite period of time. When Sensor Auto Reset is disabled, the Baseline is updated only when the Difference Count is less than the Noise Threshold.
Sensor auto reset
Sensor ganging
See Ganged sensors.
Sensor ganging
Shield electrode
Copper fill around sensors to prevent false touches due to the presence of water or other liquids. Shield Electrode is driven by the shield signal output from the CSD block. See Driven-shield.
Shield electrode
Shield tank capacitor
An optional external capacitor (CSH Tank Capacitor) used to enhance the drive capability of the CSD shield, when there is a large shield layer with high parasitic capacitance.
Shield tank capacitor (CSH)
CSH
signal
Difference Count is also called Signal. See Difference Count.
signal (CAPSENSE™ signal)
CAPSENSE™ signal
Signal-to-noise ratio
The ratio of the sensor signal, when touched, to the noise signal of an untouched sensor.
Signal-to-noise ratio
SNR
Slider resolution
A parameter indicating the total number of finger positions to be resolved on a slider.
Slider resolution
SmartSense auto-tuning
A CAPSENSE™ algorithm that automatically sets sensing parameters for optimal performance after the design phase and continuously compensates for system, manufacturing, and environmental changes.
SmartSense™ auto-tuning
Touchpad
A Widget consisting of multiple sensors arranged in a specific horizontal and vertical fashion to detect the X and Y position of a touch.
Touchpad
Trackpad
See Touchpad.
Trackpad
Tuning
The process of finding the optimum values for various hardware and software or threshold parameters required for CAPSENSE™ operation.
Tuning
VREF
Programmable reference voltage block available inside PSoC™ used for CAPSENSE™ and ADC operation.
VREF
Widget
A user-interface element in the CAPSENSE™ Component that consists of one sensor or a group of similar sensors. Button, proximity sensor, linear slider, radial slider, matrix buttons, and touchpad are the supported widgets.
Widget
Revision history
Document version | Date of release | Description of changes |
---|---|---|
2013-04-19 | ** | New Design Guide. |
2013-07-29 | *A | Added dual IDAC support. Updated some schematics in chapter 6. Other minor changes to chapters 3, 5, and 6. |
2013-11-13 | *B | Added support of CY8C4000 devices. Minor fixes throughout the document. |
2014-02-24 | *C | Updated the table of device features. Changed IDAC names to sync with new PSoC™ Creator Component terms. Added a schematic checklist. Changed screenshots to match the new Component version. |
2014-02-27 | *D | Updated Table 1-1 per PSoC™ 4000 datasheet. |
2014-03-20 | *E | Added firmware design considerations to Chapter 6. Added power supply layout and schematic considerations to Chapter 6. Updated the IMO range for PSoC™ 4000 |
2014-04-15 | *F | Updated to support PSoC™ 4000 and PSoC™ Creator 3.0 SP1. |
2014-08-29 | *G | Added Reference to Getting started with CAPSENSE™ in Proximity (three-dimensional) Renamed Liquid tolerance to Liquid tolerance and re-wrote this section. Updated the recommendations for Shield drive that is Csh_tank precharge and CMOD precharge in CAPSENSE™ CSD shielding CAPSENSE™ CSD shielding. Added recommendation for setting “API resolution” in Chapter Added guidelines on how to select value of “Sensitivity” parameter in Chapter Updated recommended values of threshold and hysteresis parameters in Chapter Manual tuning trade-offs Added Section Manual Tuning Slider Example. Updated maximum overlay thickness value for sliders in Table 31. Added guideline on maximum thickness for overlays of materials other than acrylic in Overlay thickness Overlay thickness. Re-wrote Chapter Slider design. Added recommendations on DC loads in Sensor and device placement Renamed and rewrote Layout guidelines for liquid tolerance to Layout guidelines for liquid tolerance. Added External capacitors pin selection External capacitors pin selection. Updated slider related recommendations in Layout rule Updated Electromagnetic compatibility (EMC) considerations , added extensive data on hardware and firmware considerations. |
2014-12-19 | *H | Added information for the PSoC™ 4 Bluetooth® LE family of devices. Added information for the PRoC Bluetooth® LE family of devices. Updated ground and power layout guidelines in Ground plane and Power supply layout recommendations. |
2015-01-21 | *I | Added information for PSoC™ 4200-M family of devices. Added footnote in chapter Slider. Added GPIO source/sink current limit in Table 38. Changed document title to PSoC™ 4 CAPSENSE™ Design Guide – AN85951 |
2015-06-02 | *J | Changed Document Title to “AN85951 – PSoC™ 4 CAPSENSE™ Design Guide” . Updated Design considerations Updated Preventing ESD discharge. Updated Figure 243. Updated Redirect. Replaced "Guard Ring" with "Ground Ring". |
2015-08-20 | *K | Added Table 3-1. Removed chapter 3.2.1 CMOD Precharge. Added chapter CAPSENSE™ in PSoC™ 4xxxM/4xxxL-Series. Updated chapter Trace routing. Added reference of AN2397. Added recommendation for modulator clock divider in chapter Manual tuning trade-offs. Added Figure 240 |
2015-09-16 | *L | Updated Overview. Updated Figure 1 Figure 1. Updated Table 8, Table 36, Table 37, Table 39. |
2016-01-19 | *M | Updated Introduction. Moved Signal-to-noise ratio (SNR) to CAPSENSE™ technology. Updated Chapters PSoC™ 4 and PSoC™ 6 MCU and for CAPSENSE™ performance details. Added section to CAPSENSE™ design and development tools. Added Glossary. |
2016-02-23 | *N | Added information on mutual-capacitance sensing in PSoC™ 4 device series. Added information on CAPSENSE™ 3.0 changes. Added following sections: Mutual-capacitance sensing CAPSENSE™ Architecture in PSoC™ 4 S-series Updated following sections: Introduction CAPSENSE™ CAPSENSE™ design and development tools CAPSENSE™ performance tuning |
2016-03-04 | *O | Added PSoC™ Analog Coprocessor references. Updated External capacitors pin selection. Updated Development kits chapter. Updated document title. Updated Copyright notice. |
2016-06-14 | *P | Updated IDAC sinking mode recommendation. Updated template. |
2016-11-18 | *Q | Updated Recommended pins for external capacitors. |
2017-04-19 | *R | Updated logo and copyright. |
2017-09-22 | *S | Added references to PSoC™ 4100S Plus throughout the document. Updated CAPSENSE™ features CAPSENSE™ features with PSoC™ 4100S Plus features. Updated PSoC™ 4 and PSoC™ 6 CAPSENSE™ development kits with CY8CKIT-149 PSoC™ 4100S Plus prototyping kit. Updated Application notes and design guides Application notes and design guides with specific list of CAPSENSE™ Application Notes |
2018-01-18 | *T | Changed document title Added references to PSoC™ 6 MCU features throughout the document Updated CAPSENSE™ generations in PSoC™ 4 and PSoC™ 6 CAPSENSE™ generations in PSoC™ 4 and PSoC™ 6 with generalized architecture block diagram for CSD sensing. Added Gesture in CAPSENSE™ Gesture in CAPSENSE™. Updated Table 8 and Table 40. |
2018-02-28 | *U | Added references to PSoC™ 4100PS throughout the document. |
2018-11-08 | *V | Updated the entire document with references to CY8C62x8 and CY8C62xA devices. Updated the entire document with references to ModusToolbox™. Updated Table 8 with the information of PSoC™ 6 kits. Updated chapter Mutual-capacitance button design with the information of additional mutual cap key. Removed all references to PRoC Bluetooth® LE devices. |
2019-04-11 | *W | Updated SmartSense and Manual tuning with respect to the latest component. Removed details on different shield drive mode from CAPSENSE™ CSD Updated CAPSENSE™ CSX sensing Updated figures in PSoC™ Creator SmartSense, and Gesture in CAPSENSE™ with respect to the latest component Removed a table in External capacitors pin selection chapter Updated Table 3 |
2020-01-07 | *X | Added Liquid tolerance for Mutual Capacitance Sensing section Removed Mutual Capacitance Button Design section Updated Table 3-2 and Table 3-3 Updated CAPSENSE™ CSX Sensing Method Added ModusToolBox™ section in Chapter 4 Updated SmartSense and Manual Tuning section with respect to the latest component. Updated Slider Tuning Guidelines section Added Tuning Shield Electrode section Updated Gesture chapter with gesture tuning guidelines Updated the Low Power design section Updated Sensor and Device placement section Updated Slider Design section Added Effect of Grounding in CSX method and Effect of Grounding in CSD method section |
2020-03-18 | *Y | Updated Sensor pin selection and chapters. |
2020-10-08 | *Z | Added CAPSENSE™ configurator CAPSENSE™ configurator. Moved Tuning Shield Electrode section under CSD sensing method (third- and fourth-generation) CSD sensing method (third- and fourth-generation). Added I am observing a low CM for my CSX button I am observing a low CM for my CSX button. Added Mutual-capacitance button design Mutual-capacitance button design. Added additional layout guidelines in Sensor and device placement Sensor and device placement. Added additional trace routing guidelines in Trace routing Trace routing. Added additional guard trace guidelines in Crosstalk Crosstalk . Added new Noise in CAPSENSE™ system Noise in CAPSENSE™ system. Added a single line description on self cap buttons in Self-capacitance button Self-capacitance button . Moved ESD and Electromagnetic compatibility (EMC) considerations under External noise External noise. Moved Effect of grounding on CSX method and effect of grounding on CSD method under Effect of grounding. |
2021-10-01 | AA | Updated to IFX template. Updated CAPSENSE™ features with new Fifth-Generation CAPSENSE™ block and PSoC™ 4100S Max features. Update Table 2. Added new section CAPSENSE™ CSD-RM sensing method (fifth-generation) and CAPSENSE™ CSX-RM sensing method (fifth-generation). Added new section for features Autonomous scanning and Usage of multiple channels. Removed “5.3.2.4 Button widget example” and replaced with Button widget tuning. Added new chapter 5.3.2.6 "Touchpad widget tuning". Added new section for Fifth-generation CAPSENSE™ sensing method - CSD-RM sensing method (fifth-generation and fifth-generation low-power) and CSX-RM sensing method (fifth-generation and fifth-generation low-power). Updated Table 31, Table 39, and Table 40. Updated Copyright information. |
2022-07-21 | AB | Template update |
2022-12-20 | AC | In the Table 2, in the Feature column, updated "Noise floor (pk-pk)" to "Noise floor (rms)". |
2023-08-04 | AD | Updated link references Deleted CSD Finger Detection Criteria Deleted CSX Finger Detection Criteria Added Synchronized scanning section Added CIC2 section Added the section title Advantages of fifth generation and fifth generation low-power |
2023-09-27 | AE | Updated CIC2 section Updated Using SmartSense to determine hardware parameters section Updated Table 10 Updated Table 16 Updated Sense clock source |
2024-02-08 | AF | Fixed broken links. Removed "5.3.2.6 Touchpad widget tuning". Removed "5.3.3.5 Touchpad widget tuning". Removed "5.3.5.7 Touchpad widget tuning". |
2024-03-20 | AG | Information about CIC2 is updated in Chapter 3. Updated measuring method for sense clock divider and added information about Cfine and CDAC configuration in Chapter 5. Updated LDO recommendation information in Recommendations to reduce the VDDA noise section. |
Trademarks
The Bluetooth® word mark and logos are registered trademarks owned by Bluetooth SIG, Inc., and any use of such marks by Infineon is under license.
6 When the decimation rate reaches its maximum of 255, the user needs to ensure that the below conditions are met to avoid the CIC2 accumulator (25-bit) overflow.
For Direct clock: (225-1) >= TRUNC((Nsub*Sns_Clk_Div)/Decimation-1)*Decimation2
For PRS clock: (225-1)/2 >= TRUNC((Nsub*Sns_Clk_Div)/Decimation-1)*Decimation2
19 These external capacitors are only used in the case of third- and fourth-generation CAPSENSE™