nanoFramework.Iot.Device.Ads1115 1.2.718

Prefix Reserved
dotnet add package nanoFramework.Iot.Device.Ads1115 --version 1.2.718                
NuGet\Install-Package nanoFramework.Iot.Device.Ads1115 -Version 1.2.718                
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.2.718" />                
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.2.718                
#r "nuget: nanoFramework.Iot.Device.Ads1115, 1.2.718"                
#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.2.718

// Install nanoFramework.Iot.Device.Ads1115 as a Cake Tool
#tool nuget:?package=nanoFramework.Iot.Device.Ads1115&version=1.2.718                

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.718 71 12/30/2024
1.2.704 87 12/18/2024
1.2.696 92 12/16/2024
1.2.673 110 10/23/2024
1.2.662 98 10/11/2024
1.2.656 97 10/3/2024
1.2.639 115 9/6/2024
1.2.631 94 8/28/2024
1.2.613 127 8/9/2024
1.2.601 78 7/26/2024
1.2.590 90 7/17/2024
1.2.573 123 6/19/2024
1.2.570 117 6/14/2024
1.2.560 121 5/29/2024
1.2.548 118 5/15/2024
1.2.536 134 4/15/2024
1.2.514 129 3/22/2024
1.2.494 115 2/28/2024
1.2.474 145 1/24/2024
1.2.462 162 1/5/2024
1.2.458 133 12/20/2023
1.2.436 176 11/10/2023
1.2.416 123 11/8/2023
1.2.403 147 10/6/2023
1.2.396 138 9/27/2023
1.2.384 152 9/6/2023
1.2.378 152 8/16/2023
1.2.369 161 8/2/2023
1.2.363 154 7/28/2023
1.2.357 154 7/19/2023
1.2.354 147 7/14/2023
1.2.345 147 6/21/2023
1.2.341 144 6/14/2023
1.2.337 150 6/7/2023
1.2.335 124 6/2/2023
1.2.329 138 5/26/2023
1.2.313 145 5/12/2023
1.2.302 174 5/10/2023
1.2.297 174 5/3/2023
1.2.273 234 3/17/2023
1.2.267 227 3/10/2023
1.2.263 237 3/8/2023
1.2.259 246 2/27/2023
1.2.256 240 2/24/2023
1.2.253 249 2/22/2023
1.2.222 323 1/9/2023
1.2.212 312 1/5/2023
1.2.208 312 1/3/2023
1.2.203 293 12/28/2022
1.2.159 372 11/14/2022
1.2.153 384 11/5/2022
1.2.141 403 10/25/2022
1.2.128 388 10/22/2022
1.2.122 443 10/12/2022
1.2.114 402 10/8/2022
1.2.95 459 9/22/2022
1.2.87 488 9/15/2022
1.2.73 415 9/8/2022
1.2.63 422 9/3/2022
1.2.47 441 8/15/2022
1.2.40 448 8/6/2022
1.2.38 440 8/5/2022
1.2.28 425 8/1/2022
1.2.13 455 7/24/2022
1.2.10 438 7/23/2022
1.1.145.58726 467 7/7/2022
1.1.133.52556 455 6/30/2022
1.1.121.35854 462 6/26/2022
1.1.116.8772 455 6/24/2022
1.1.113.2032 454 6/23/2022
1.1.102.51394 438 6/15/2022
1.1.99.36719 434 6/14/2022
1.1.97.17326 462 6/13/2022
1.1.92.53000 457 6/8/2022
1.1.72.29765 465 5/31/2022
1.1.64.21380 451 5/26/2022
1.1.58.10097 455 5/23/2022
1.1.54.28879 456 5/23/2022
1.1.40 459 5/5/2022
1.1.3 495 4/15/2022
1.1.1 478 4/14/2022
1.0.300 470 3/31/2022
1.0.288-preview.114 131 3/25/2022
1.0.288-preview.113 121 3/25/2022
1.0.288-preview.104 121 3/22/2022
1.0.288-preview.103 115 3/21/2022
1.0.288-preview.100 132 3/19/2022
1.0.288-preview.99 136 3/18/2022
1.0.288-preview.98 124 3/18/2022
1.0.288-preview.93 134 3/15/2022
1.0.288-preview.87 125 3/10/2022
1.0.288-preview.86 131 3/8/2022
1.0.288-preview.77 130 2/27/2022
1.0.288-preview.75 123 2/26/2022
1.0.288-preview.65 129 2/18/2022
1.0.288-preview.63 127 2/16/2022
1.0.288-preview.61 133 2/12/2022
1.0.288-preview.58 125 2/10/2022
1.0.288-preview.53 125 2/9/2022
1.0.288-preview.48 144 2/4/2022
1.0.288-preview.41 140 1/31/2022
1.0.288-preview.29 142 1/28/2022
1.0.288-preview.20 142 1/27/2022
1.0.288-preview.19 148 1/27/2022
1.0.288-preview.18 142 1/27/2022
1.0.288-preview.5 141 1/24/2022
1.0.288-preview.1 135 1/21/2022
1.0.272 173 1/10/2022
1.0.259 341 12/9/2021
1.0.258 334 12/7/2021
1.0.218 210 10/18/2021
1.0.209 368 10/12/2021
1.0.157 353 9/4/2021
1.0.155 349 8/31/2021
1.0.153 178 8/14/2021
1.0.151 190 8/6/2021
1.0.146 177 7/22/2021
1.0.136 247 7/17/2021
1.0.135 177 7/16/2021
1.0.134 182 7/15/2021
1.0.133 194 7/14/2021
1.0.130 170 7/6/2021
1.0.127 186 7/5/2021
1.0.125 208 7/5/2021
1.0.122 230 6/30/2021
1.0.121 211 6/29/2021
1.0.119 233 6/28/2021
1.0.111 197 6/14/2021
1.0.105 295 5/29/2021
1.0.104 255 5/29/2021
1.0.97 191 5/28/2021
1.0.63 191 5/26/2021
1.0.20 232 5/21/2021