2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
[![Arduino CI](https://github.com/RobTillaart/MCP4725/workflows/Arduino%20CI/badge.svg)](https://github.com/marketplace/actions/arduino_ci)
|
2021-12-21 16:28:24 +01:00
|
|
|
[![Arduino-lint](https://github.com/RobTillaart/MCP4725/actions/workflows/arduino-lint.yml/badge.svg)](https://github.com/RobTillaart/MCP4725/actions/workflows/arduino-lint.yml)
|
|
|
|
[![JSON check](https://github.com/RobTillaart/MCP4725/actions/workflows/jsoncheck.yml/badge.svg)](https://github.com/RobTillaart/MCP4725/actions/workflows/jsoncheck.yml)
|
2021-01-29 12:31:58 +01:00
|
|
|
[![License: MIT](https://img.shields.io/badge/license-MIT-green.svg)](https://github.com/RobTillaart/MCP4725/blob/master/LICENSE)
|
|
|
|
[![GitHub release](https://img.shields.io/github/release/RobTillaart/MCP4725.svg?maxAge=3600)](https://github.com/RobTillaart/MCP4725/releases)
|
|
|
|
|
2021-12-21 16:28:24 +01:00
|
|
|
|
2020-11-27 11:20:37 +01:00
|
|
|
# MCP4725
|
|
|
|
|
2021-12-21 16:28:24 +01:00
|
|
|
Arduino library for 12 bit I2C DAC - MCP4725.
|
2020-11-27 11:20:37 +01:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2020-11-27 11:20:37 +01:00
|
|
|
## Description
|
|
|
|
|
2021-12-21 16:28:24 +01:00
|
|
|
The MCP4725 is an I2C 12 bit Digital to Analog Converter (DAC).
|
|
|
|
It is possible to have up to 8 MCP4725 on one I2C bus.
|
|
|
|
The MCP4725 supports 100 KHz 400 KHz and 3.4 MHz bus speeds.
|
2020-11-27 11:20:37 +01:00
|
|
|
|
|
|
|
The output of the MCP4725 depends on the voltage supplied, which is in the range
|
|
|
|
of 2.7V .. 5.5V. Check datasheet for the details.
|
|
|
|
|
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
## Interface
|
|
|
|
|
|
|
|
### Constructor
|
|
|
|
|
2021-12-21 16:28:24 +01:00
|
|
|
- **MCP4725(uint8_t deviceAddress, TwoWire \*wire = &Wire)** Constructor, needs I2C address, optional set Wire bus
|
|
|
|
- **bool begin(uint8_t dataPin, uint8_t clockPin)** for ESP32. Returns true if connected.
|
|
|
|
- **bool begin()** for UNO and other boards with hard wired I2C pins.
|
|
|
|
Returns true if deviceAddress can be found on the I2C bus.
|
|
|
|
- **bool isConnected()** returns true if device (address) can be seen on the I2C bus.
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
|
|
|
|
### base
|
|
|
|
|
2021-12-21 16:28:24 +01:00
|
|
|
- **int setValue(uint16_t value = 0)** value = 0 .. 4095.
|
2020-11-27 11:20:37 +01:00
|
|
|
Uses writeFastMode and does not write to EEPROM.
|
2021-12-21 16:28:24 +01:00
|
|
|
Therefore it does not update the lastWriteEEPROM timestamp.
|
|
|
|
The default value is 0.
|
|
|
|
Returns 0 on success
|
|
|
|
- **uint16_t getValue()** returns last value set from cache, this is much faster than readDAC().
|
|
|
|
This latter gives the real value from the MCP4725.
|
|
|
|
Note: a difference can be caused by power outage a reset etc.
|
|
|
|
- **int setPercentage(float percentage)** percentage = 0..100.0%.
|
|
|
|
Convenience wrapper around setValue().
|
|
|
|
- **float getPercentage()** returns percentage. Wrapper around getValue().
|
|
|
|
- **int writeDAC(value, bool EEPROM = false)** Writes to DAC and conditionally to EEPROM.
|
|
|
|
This latter is for startup / reset behaviour. Check datasheet for the detail behaviour.
|
|
|
|
- **bool ready()** returns true if a new value can be written to the MCP4725.
|
2020-11-27 11:20:37 +01:00
|
|
|
Return false if recently was written to EEPROM.
|
2021-12-21 16:28:24 +01:00
|
|
|
- **uint16_t readDAC()** reads the current value set in the MCP4725.
|
|
|
|
- **uint16_t readEEPROM()** reads the current value in the EEPROM of the MCP4725.
|
|
|
|
- **uint32_t getLastWriteEEPROM()** returns time in millis() when last value was written to EEPROM.
|
|
|
|
|
2020-11-27 11:20:37 +01:00
|
|
|
Page 3 of datasheet states it takes **25 - 50 ms** before values are written to EEPROM.
|
2021-12-21 16:28:24 +01:00
|
|
|
So the exact timing of a sensor can differ quite a lot.
|
2020-11-27 11:20:37 +01:00
|
|
|
When writing to EEPROM with **writeDAC()** one should check it is at least 50 ms ago.
|
|
|
|
If one know the specific timing of a sensor one can tune this or even make it adaptive.
|
|
|
|
|
|
|
|
|
|
|
|
## Experimental
|
|
|
|
|
|
|
|
Check datasheet for these functions, (not tested enough yet).
|
|
|
|
|
2021-12-21 16:28:24 +01:00
|
|
|
- **int writePowerDownMode(uint8_t PDM, bool EEPROM = false)**
|
|
|
|
- **uint8_t readPowerDownModeEEPROM()**
|
|
|
|
- **uint8_t readPowerDownModeDAC()**
|
|
|
|
- **int powerOnReset()**
|
|
|
|
- **int powerOnWakeUp()**
|
2020-11-27 11:20:37 +01:00
|
|
|
|
|
|
|
More investigations needed for:
|
|
|
|
- Writing to EEPROM, **ready()** and **getLastWriteEEPROM()**
|
|
|
|
checking when and how long the sensor blocks needs to be verified in detail in practice.
|
|
|
|
|
|
|
|
|
|
|
|
## Address Notes
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2020-11-27 11:20:37 +01:00
|
|
|
The address of the MCP4725 in the demo sketches is set to 0x62 as that
|
|
|
|
was the address of the sensor I had during writing.
|
|
|
|
According to the datasheet the address has the following bit pattern:
|
|
|
|
|
|
|
|
address 011000FFU (so 0x6?)
|
|
|
|
|
|
|
|
F = Factory set bit
|
|
|
|
U = User configurable bit
|
|
|
|
|
|
|
|
This means you can have at most 8 MCP4725 in one I2C bus (without multiplexing).
|
|
|
|
You have to specify the factory bits in your order, but not all shops might
|
|
|
|
provide all versions of the MCP4725.
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2020-11-27 11:20:37 +01:00
|
|
|
```
|
|
|
|
MCP4725A0T-E/CH: 0110 000U 0x60 - 0x61
|
|
|
|
MCP4725A1T-E/CH: 0110 001U 0x62 - 0x63
|
|
|
|
MCP4725A2T-E/CH: 0110 010U 0x64 - 0x65
|
|
|
|
MCP4725A3T-E/CH: 0110 011U 0x66 - 0x67
|
|
|
|
```
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2020-11-27 11:20:37 +01:00
|
|
|
If one need more DAC's one might have a look at the MCP4728
|
|
|
|
It has 4 channels per chip (no experience /library yet)
|
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2022-10-17 10:40:05 +02:00
|
|
|
### RP2040 specific
|
|
|
|
|
|
|
|
- **bool begin(int sda, int scl)** begin communication with the DAC.
|
|
|
|
It has the parameter for selecting on which pins the communication should happen.
|
|
|
|
Check RP2040 Pinout for compatible pins.
|
|
|
|
When Wire1 is used, it needs to be specified in the constructor with "&Wire1"
|
|
|
|
|
|
|
|
|
2020-11-27 11:20:37 +01:00
|
|
|
## Operation
|
|
|
|
|
|
|
|
See examples
|
2021-12-21 16:28:24 +01:00
|
|
|
|
|
|
|
|
|
|
|
## Future
|
|
|
|
|
|
|
|
- update documentation
|
|
|
|
- test the powerDown modes / functions.
|
|
|
|
- write a sketch to measure the **writeDac()** timing if possible.
|
|
|
|
- extend unit tests
|
|
|
|
-
|
|
|
|
|
|
|
|
|