nanoFramework.Iot.Device.Mcp3428 1.0.288-preview.29

The ID prefix of this package has been reserved for one of the owners of this package by NuGet.org. Prefix Reserved
This is a prerelease version of nanoFramework.Iot.Device.Mcp3428.
There is a newer version of this package available.
See the version list below for details.
dotnet add package nanoFramework.Iot.Device.Mcp3428 --version 1.0.288-preview.29
NuGet\Install-Package nanoFramework.Iot.Device.Mcp3428 -Version 1.0.288-preview.29
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="nanoFramework.Iot.Device.Mcp3428" Version="1.0.288-preview.29" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add nanoFramework.Iot.Device.Mcp3428 --version 1.0.288-preview.29
#r "nuget: nanoFramework.Iot.Device.Mcp3428, 1.0.288-preview.29"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install nanoFramework.Iot.Device.Mcp3428 as a Cake Addin
#addin nuget:?package=nanoFramework.Iot.Device.Mcp3428&version=1.0.288-preview.29&prerelease

// Install nanoFramework.Iot.Device.Mcp3428 as a Cake Tool
#tool nuget:?package=nanoFramework.Iot.Device.Mcp3428&version=1.0.288-preview.29&prerelease

Mcp3428 - Analog to Digital Converter (I2C)

The library implements the Microchip MCP3428 16 bit A/D converter with I2C interface. It has hardware configurable I2C address and software configurable resolution and gain. Can work in continuous and on-demand conversion modes.

Documentation

"The MCP3426, MCP3427 and MCP3428 devices (MCP3426/7/8) are the low noise and high accuracy 16 Bit Delta-Sigma Analog-to-Digital (ΔΣ A/D) Converter family members of the MCP342X series from Microchip Technology Inc. These devices can convert analog inputs to digital codes with up to 16 bits of resolution." - Datasheet

The 3 devices differ only in addressing capability and channel number. The library implements all of them.

Board

MCU Breadboard diagram

Usage

Simple example for measuring LED forward voltage using the MCP3428 ADC and a MCU.

// I2C addres based on pin configuration
var addr = Mcp3428.AddressFromPins(PinState.Low, PinState.Low);
var options = new I2cConnectionSettings(1, addr);

using (var dev = new UnixI2cDevice(options))
using (var adc = new Mcp3428(dev, ModeEnum.OneShot, ResolutionEnum.Bit16, GainEnum.X1))
{
    var ch1 = adc.ReadChannel(0);

    Debug.WriteLine($"LED forward voltage value: {ch1} V");
}

On the MCP3428 you can select 8 different I2C addresses that the device answers on. It's done by connecting two pins, Adr0 and Adr1 to supply voltage or ground or leaving then floating. The library has a helper method to choose the address based on pin states.

With this instantiating the device and reading the first channel is done like this:

var options = new I2cConnectionSettings(1,
    Mcp3428.AddressFromPins(PinState.Low, PinState.Floating));
using (var dev = new UnixI2cDevice(options))
using (var adc = new Mcp3428(dev)) // Default settings
{
    var ch1 = adc.ReadChannel(0);

    Debug.WriteLine($"ADC Channel value: {ch1} V");
}

The library provides an async API as reading with 16 bit resolution can take up to 60-80ms. It's in a separate class called Mcp3428Async.

Product Compatible and additional computed target framework versions.
.NET Framework net is compatible. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.2.436 216 11/10/2023
1.2.416 92 11/8/2023
1.2.329 159 5/26/2023
1.2.313 128 5/12/2023
1.2.297 131 5/3/2023
1.2.212 284 1/5/2023
1.2.203 280 12/28/2022
1.2.159 351 11/14/2022
1.2.153 364 11/5/2022
1.2.141 377 10/25/2022
1.2.95 415 9/22/2022
1.2.87 483 9/15/2022
1.2.82 470 9/14/2022
1.1.116.8772 435 6/24/2022
1.1.113.2032 419 6/23/2022
1.1.97.17326 453 6/13/2022
1.1.92.53000 420 6/8/2022
1.1.58.10097 427 5/23/2022
1.1.3 436 4/15/2022
1.1.1 438 4/14/2022
1.0.300 460 3/31/2022
1.0.288-preview.114 116 3/25/2022
1.0.288-preview.113 105 3/25/2022
1.0.288-preview.104 99 3/22/2022
1.0.288-preview.100 107 3/19/2022
1.0.288-preview.98 104 3/18/2022
1.0.288-preview.93 107 3/15/2022
1.0.288-preview.65 109 2/18/2022
1.0.288-preview.48 128 2/4/2022
1.0.288-preview.42 124 1/31/2022
1.0.288-preview.29 123 1/28/2022
1.0.288-preview.22 123 1/27/2022
1.0.288-preview.20 129 1/27/2022
1.0.288-preview.18 128 1/27/2022
1.0.288-preview.1 124 1/21/2022
1.0.260 293 12/10/2021
1.0.259 292 12/9/2021
1.0.258 282 12/8/2021
1.0.189 402 9/25/2021
1.0.155 317 8/31/2021
1.0.138 352 7/18/2021
1.0.136 395 7/17/2021
1.0.135 155 7/16/2021
1.0.134 170 7/15/2021
1.0.133 191 7/14/2021
1.0.130 153 7/6/2021
1.0.125 194 7/5/2021
1.0.121 198 6/29/2021
1.0.119 216 6/28/2021
1.0.112 202 6/16/2021
1.0.105 273 5/29/2021
1.0.55 204 5/25/2021