nanoFramework.Iot.Device.Ads1115 1.0.288-preview.86

Prefix Reserved
This is a prerelease version of nanoFramework.Iot.Device.Ads1115.
There is a newer version of this package available.
See the version list below for details.
dotnet add package nanoFramework.Iot.Device.Ads1115 --version 1.0.288-preview.86                
NuGet\Install-Package nanoFramework.Iot.Device.Ads1115 -Version 1.0.288-preview.86                
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.Ads1115" Version="1.0.288-preview.86" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add nanoFramework.Iot.Device.Ads1115 --version 1.0.288-preview.86                
#r "nuget: nanoFramework.Iot.Device.Ads1115, 1.0.288-preview.86"                
#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.Ads1115 as a Cake Addin
#addin nuget:?package=nanoFramework.Iot.Device.Ads1115&version=1.0.288-preview.86&prerelease

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

ADS1115 - Analog to Digital Converter

ADS1115 is an Analog-to-Digital converter (ADC) with 16 bits of resolution.

Documentation

Prodcut datasheet can be found here

Sensor Image

ADS1115

Usage

Important: make sure you properly setup the I2C pins especially for ESP32 before creating the I2cDevice, make sure you install the nanoFramework.Hardware.ESP32 nuget:

//////////////////////////////////////////////////////////////////////
// when connecting to an ESP32 device, need to configure the I2C GPIOs
// used for the bus
Configuration.SetPinFunction(21, DeviceFunction.I2C1_DATA);
Configuration.SetPinFunction(22, DeviceFunction.I2C1_CLOCK);

For other devices like STM32, please make sure you're using the preset pins for the I2C bus you want to use.

// set I2C bus ID: 1
// ADS1115 Addr Pin connect to GND
I2cConnectionSettings settings = new I2cConnectionSettings(1, (int)I2cAddress.GND);
I2cDevice device = I2cDevice.Create(settings);

// pass in I2cDevice
// measure the voltage AIN0
// set the maximum range to 6.144V
using (Ads1115 adc = new Ads1115(device, InputMultiplexer.AIN0, MeasuringRange.FS6144))
{
    // read raw data form the sensor
    short raw = adc.ReadRaw();
    // raw data convert to voltage
    double voltage = adc.RawToVoltage(raw);
}

See the samples project for more examples and usage for different applications.

If you want to use the interrupt pin, the pulses generated by the ADS1115 might be to short to be properly recognized in the software, i.e. on a MCU. The schematic below shows a way of increasing the pulse length so that it is properly recognized (from about 10us to 150us). This uses discrete electronics, but an implementation with an NE555 or equivalent would likely work as well (Just note that you need a type that works at 3.3V).

Pulse_lengthener_schema

Example

Hardware Required

  • ADS1115
  • Rotary Potentiometer
  • Male/Female Jumper Wires

Circuit

circuit

ADS1115

  • ADDR - GND
  • SCL - SCL
  • SDA - SDA
  • VCC - 5V
  • GND - GND
  • A0 - Rotary Potentiometer Pin 2

Rotary Potentiometer

  • Pin 1 - 5V
  • Pin 2 - ADS1115 Pin A0
  • Pin 3 - GND

Code

// set I2C bus ID: 1
// ADS1115 Addr Pin connect to GND
I2cConnectionSettings settings = new I2cConnectionSettings(1, (int)I2cAddress.GND);
I2cDevice device = I2cDevice.Create(settings);

// pass in I2cDevice
// measure the voltage AIN0
// set the maximum range to 6.144V
using (Ads1115 adc = new Ads1115(device, InputMultiplexer.AIN0, MeasuringRange.FS6144))
{
    // loop
    while (true)
    {
        // read raw data form the sensor
        short raw = adc.ReadRaw();
        // raw data convert to voltage
        double voltage = adc.RawToVoltage(raw);

        Debug.WriteLine($"ADS1115 Raw Data: {raw}");
        Debug.WriteLine($"Voltage: {voltage}");
        Debug.WriteLine();

        // wait for 2s
        Thread.Sleep(2000);
    }
}

Results

run results interupt result

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.737 31 1/13/2025
1.2.718 83 12/30/2024
1.2.704 93 12/18/2024
1.2.696 100 12/16/2024
1.2.673 112 10/23/2024
1.2.662 99 10/11/2024
1.2.656 98 10/3/2024
1.2.639 116 9/6/2024
1.2.631 96 8/28/2024
1.2.613 128 8/9/2024
1.2.601 79 7/26/2024
1.2.590 94 7/17/2024
1.2.573 124 6/19/2024
1.2.570 118 6/14/2024
1.2.560 122 5/29/2024
1.2.548 119 5/15/2024
1.2.536 135 4/15/2024
1.2.514 130 3/22/2024
1.2.494 116 2/28/2024
1.2.474 146 1/24/2024
1.2.462 164 1/5/2024
1.2.458 135 12/20/2023
1.2.436 178 11/10/2023
1.2.416 125 11/8/2023
1.2.403 149 10/6/2023
1.2.396 140 9/27/2023
1.2.384 154 9/6/2023
1.2.378 154 8/16/2023
1.2.369 163 8/2/2023
1.2.363 157 7/28/2023
1.2.357 156 7/19/2023
1.2.354 149 7/14/2023
1.2.345 149 6/21/2023
1.2.341 146 6/14/2023
1.2.337 152 6/7/2023
1.2.335 126 6/2/2023
1.2.329 140 5/26/2023
1.2.313 147 5/12/2023
1.2.302 176 5/10/2023
1.2.297 176 5/3/2023
1.2.273 235 3/17/2023
1.2.267 228 3/10/2023
1.2.263 239 3/8/2023
1.2.259 247 2/27/2023
1.2.256 242 2/24/2023
1.2.253 251 2/22/2023
1.2.222 326 1/9/2023
1.2.212 314 1/5/2023
1.2.208 314 1/3/2023
1.2.203 295 12/28/2022
1.2.159 374 11/14/2022
1.2.153 386 11/5/2022
1.2.141 405 10/25/2022
1.2.128 390 10/22/2022
1.2.122 445 10/12/2022
1.2.114 404 10/8/2022
1.2.95 461 9/22/2022
1.2.87 490 9/15/2022
1.2.73 417 9/8/2022
1.2.63 424 9/3/2022
1.2.47 443 8/15/2022
1.2.40 450 8/6/2022
1.2.38 442 8/5/2022
1.2.28 427 8/1/2022
1.2.13 458 7/24/2022
1.2.10 440 7/23/2022
1.1.145.58726 469 7/7/2022
1.1.133.52556 457 6/30/2022
1.1.121.35854 464 6/26/2022
1.1.116.8772 457 6/24/2022
1.1.113.2032 456 6/23/2022
1.1.102.51394 440 6/15/2022
1.1.99.36719 439 6/14/2022
1.1.97.17326 464 6/13/2022
1.1.92.53000 459 6/8/2022
1.1.72.29765 469 5/31/2022
1.1.64.21380 453 5/26/2022
1.1.58.10097 459 5/23/2022
1.1.54.28879 458 5/23/2022
1.1.40 461 5/5/2022
1.1.3 497 4/15/2022
1.1.1 480 4/14/2022
1.0.300 472 3/31/2022
1.0.288-preview.114 135 3/25/2022
1.0.288-preview.113 123 3/25/2022
1.0.288-preview.104 123 3/22/2022
1.0.288-preview.103 117 3/21/2022
1.0.288-preview.100 134 3/19/2022
1.0.288-preview.99 138 3/18/2022
1.0.288-preview.98 126 3/18/2022
1.0.288-preview.93 136 3/15/2022
1.0.288-preview.87 127 3/10/2022
1.0.288-preview.86 133 3/8/2022
1.0.288-preview.77 133 2/27/2022
1.0.288-preview.75 125 2/26/2022
1.0.288-preview.65 131 2/18/2022
1.0.288-preview.63 129 2/16/2022
1.0.288-preview.61 135 2/12/2022
1.0.288-preview.58 127 2/10/2022
1.0.288-preview.53 127 2/9/2022
1.0.288-preview.48 146 2/4/2022
1.0.288-preview.41 142 1/31/2022
1.0.288-preview.29 144 1/28/2022
1.0.288-preview.20 144 1/27/2022
1.0.288-preview.19 150 1/27/2022
1.0.288-preview.18 144 1/27/2022
1.0.288-preview.5 144 1/24/2022
1.0.288-preview.1 137 1/21/2022
1.0.272 175 1/10/2022
1.0.259 343 12/9/2021
1.0.258 336 12/7/2021
1.0.218 212 10/18/2021
1.0.209 370 10/12/2021
1.0.157 355 9/4/2021
1.0.155 351 8/31/2021
1.0.153 180 8/14/2021
1.0.151 192 8/6/2021
1.0.146 179 7/22/2021
1.0.136 249 7/17/2021
1.0.135 179 7/16/2021
1.0.134 184 7/15/2021
1.0.133 196 7/14/2021
1.0.130 172 7/6/2021
1.0.127 188 7/5/2021
1.0.125 210 7/5/2021
1.0.122 232 6/30/2021
1.0.121 213 6/29/2021
1.0.119 235 6/28/2021
1.0.111 199 6/14/2021
1.0.105 297 5/29/2021
1.0.104 257 5/29/2021
1.0.97 193 5/28/2021
1.0.63 193 5/26/2021
1.0.20 234 5/21/2021