137 lines
5.0 KiB
Markdown
Raw Normal View History

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
2023-01-16 17:33:16 +01:00
The MCP4725 is an I2C single channel 12 bit Digital to Analog Converter (DAC).
2021-12-21 16:28:24 +01:00
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
2023-01-16 17:33:16 +01:00
#### RP2040 specific
There are different RP2040 board files.
This library works with RP2040 pico - https://github.com/earlephilhower/arduino-pico
Will give an error on setSDA() and setSCL() with the "Arduino MBED OS" version.
See remark PR #21.
2022-10-17 10:40:05 +02:00
- **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
2023-01-16 17:33:16 +01:00
#### Must
2021-12-21 16:28:24 +01:00
- update documentation
2023-01-16 17:33:16 +01:00
#### Should
2021-12-21 16:28:24 +01:00
- test the powerDown modes / functions.
2023-01-16 17:33:16 +01:00
#### Could
2021-12-21 16:28:24 +01:00
- extend unit tests