Skip to content

Latest commit

 

History

History
58 lines (38 loc) · 6.58 KB

README.md

File metadata and controls

58 lines (38 loc) · 6.58 KB

MPR121 Advanced Calibration

This is for anyone using Adafruit’s MPR121 Breakout Board and, having gone through Adafruit’s learning guide (which BTW is a very good starting point), has reached the limit of what can be done with the Set Thresholds public method of the MPR121 library.

This program allows for calibration of individual electrode sensitivity using baseline filtering, touch filtering & debounce, and the MPR121's autoconfig feature, all during program execution, thus avoiding the need to recompile & reload with each scenario being tested. Its objective is finding the optimal calibration parameters to be later implemented in the appropriate production program.

A necessary pre-read to understand this guide is NXP’s MPR121 Datasheet, particularly Section 3. Device Operation Overview and Section 5. Register Operations Descriptions. If you don’t know what a register is, go first to SparkFun’s Level Up Your Arduino Code: Registers. And if you’re unfamiliar with binary operations, start with their Digital Logic Tutorial.

You may notice in NXP’s website that the venerable MPR121 is no longer manufactured, but there are plenty pieces in inventory to last us a long time, so there’s nothing to worry about (unless of course, your plan was to create a ground-breaking product to bring riches and glory, in which case, you should consider some other cap sensor).

If you find that I’ve missed on something, then by all means enrich this experience with your dialogue, which can only result in benefits for us all.

Cap Sensor Sensitivity

The MPR121 can measure capacitances ranging from 10 pF to 2000 pF (approx.) by varying the amount of charge current and charge time applied to the sensing inputs. This means that it may not be enough to go through certain materials. (See AN3863 Designing Touch Sensing Electrodes). In any case, charge current and charge time can be modified to reach other capacitance sensitivities.

At the end of the charge time, the electrode voltage is measured with a 10 bit ADC. The highest operating range of the electrode charging source is Vdd - 0.7V, so, it is critical not to charge the electrode beyond this point because it’s a non-linear region, meaning the ADC reading can quickly overflow returning meaningless results. For more information see AN3889 Capacitance Sensing Settings.

This is why the Autoconfig feature is so sweet: it automatically tests various charge times and charge currents to determine the maximum values (within definable limits) that result in controlled output, and it does this for each individual electrode, allowing for differences in capacitance due to conector length, pad characteristics, etc. Details on the input variables for Autoconfig start in Page 7 of AN3889.

MPR121 Library

To use Autoconfig and to change calibration parameters during program execution, some serious modifications to the Adafruit_MPR121 library files are necessary, so I copied and renamed the .cpp and .h files and placed them in the same file directory of the .ino sketch. This way the original MPR121 library remains untouched.

The changes to the library include:

  • Run-time defined parameters for:
    • Baseline Filtering Control
    • Touch/Release Debounce
    • First & Secondary Filtering and Sample Interval
    • Autoconfig Level Limits & Target
  • Binary encoding of Filter and Global CDC CDT Configuration registers
  • Display of resulting Charge Time and Charge Current per electrode defined by Autoconfig
  • Differentiating failure reason when starting the board
  • Clean-up of unused code

Main Program (.ino file)

My use case has three breakout boards with specific I2C addresses, but this can be changed in the variable definition section of the main sketch.

Instead of using the standard MPR121 library methods to acquire status data (touched, filereredData & baselineData), the program executes a multibyte read of all status registers (from 0x00 thru 0x2A) at once, providing a coherent picture (same time stamp) for analysis of touched/released status and its associated filtered and baseline data.

Other options provided by the program for output data (to plot or print) include:

  • Filtered data of a selected board or all of them
  • Baseline data of a selected board or all of them
  • Baseline & Filtered data of a selected board

Blynk as Input Data Interface

Although designed as a platform for IoT software, a free account (two devices max) can be used to create, fast & easy, a user interface to input data. It's well documented and has a Quickstart Guide that will get you running in minutes. I'm using an ESP32 Feather V2 and there is a long list of supported hardware. For ESP32's, use the BlynkSimpleEsp32 library that can be installed via Arduino IDE following these instructions.

Below is a screenshot of what the Web Dasbhboard can look like: adjust any MPR121 parameter and then click on START to issue the cap.begin() method and restart the breakout boards with the new parameters.

Screenshot 2022-07-16 182932

Other Useful Application Notes

Finally, for further understanding of what can be done with the MPR121 cap sensor, consider all the application notes available, particularly: