nanoFramework.Iot.Device.Ads1115 1.2.718

Prefix Reserved
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.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.822 91 4 days ago
1.2.775 116 a month ago
1.2.772 103 a month ago
1.2.759 97 a month ago
1.2.755 97 a month ago
1.2.743 107 a month ago
1.2.737 81 2 months ago
1.2.718 95 2 months ago
1.2.704 101 2 months ago
1.2.696 108 2 months ago
1.2.673 121 4 months ago
1.2.662 106 5 months ago
1.2.656 103 5 months ago
1.2.639 121 6 months ago
1.2.631 101 6 months ago
1.2.613 131 7 months ago
1.2.601 82 7 months ago
1.2.590 96 7 months ago
1.2.573 126 8 months ago
1.2.570 122 9 months ago
1.2.560 124 9 months ago
1.2.548 120 10 months ago
1.2.536 136 4/15/2024
1.2.514 131 3/22/2024
1.2.494 123 2/28/2024
1.2.474 147 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 151 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 158 7/19/2023
1.2.354 149 7/14/2023
1.2.345 149 6/21/2023
1.2.341 148 6/14/2023
1.2.337 155 6/7/2023
1.2.335 129 6/2/2023
1.2.329 143 5/26/2023
1.2.313 151 5/12/2023
1.2.302 180 5/10/2023
1.2.297 180 5/3/2023
1.2.273 240 3/17/2023
1.2.267 233 3/10/2023
1.2.263 243 3/8/2023
1.2.259 251 2/27/2023
1.2.256 247 2/24/2023
1.2.253 256 2/22/2023
1.2.222 332 1/9/2023
1.2.212 319 1/5/2023
1.2.208 319 1/3/2023
1.2.203 300 12/28/2022
1.2.159 379 11/14/2022
1.2.153 391 11/5/2022
1.2.141 410 10/25/2022
1.2.128 395 10/22/2022
1.2.122 450 10/12/2022
1.2.114 415 10/8/2022
1.2.95 466 9/22/2022
1.2.87 495 9/15/2022
1.2.73 422 9/8/2022
1.2.63 429 9/3/2022
1.2.47 448 8/15/2022
1.2.40 455 8/6/2022
1.2.38 447 8/5/2022
1.2.28 432 8/1/2022
1.2.13 463 7/24/2022
1.2.10 445 7/23/2022
1.1.145.58726 474 7/7/2022
1.1.133.52556 462 6/30/2022
1.1.121.35854 471 6/26/2022
1.1.116.8772 464 6/24/2022
1.1.113.2032 461 6/23/2022
1.1.102.51394 445 6/15/2022
1.1.99.36719 446 6/14/2022
1.1.97.17326 471 6/13/2022
1.1.92.53000 464 6/8/2022
1.1.72.29765 474 5/31/2022
1.1.64.21380 458 5/26/2022
1.1.58.10097 464 5/23/2022
1.1.54.28879 463 5/23/2022
1.1.40 468 5/5/2022
1.1.3 502 4/15/2022
1.1.1 485 4/14/2022
1.0.300 479 3/31/2022
1.0.288-preview.114 140 3/25/2022
1.0.288-preview.113 128 3/25/2022
1.0.288-preview.104 128 3/22/2022
1.0.288-preview.103 122 3/21/2022
1.0.288-preview.100 139 3/19/2022
1.0.288-preview.99 143 3/18/2022
1.0.288-preview.98 131 3/18/2022
1.0.288-preview.93 141 3/15/2022
1.0.288-preview.87 135 3/10/2022
1.0.288-preview.86 138 3/8/2022
1.0.288-preview.77 138 2/27/2022
1.0.288-preview.75 130 2/26/2022
1.0.288-preview.65 136 2/18/2022
1.0.288-preview.63 135 2/16/2022
1.0.288-preview.61 140 2/12/2022
1.0.288-preview.58 132 2/10/2022
1.0.288-preview.53 132 2/9/2022
1.0.288-preview.48 155 2/4/2022
1.0.288-preview.41 147 1/31/2022
1.0.288-preview.29 149 1/28/2022
1.0.288-preview.20 149 1/27/2022
1.0.288-preview.19 155 1/27/2022
1.0.288-preview.18 149 1/27/2022
1.0.288-preview.5 149 1/24/2022
1.0.288-preview.1 142 1/21/2022
1.0.272 180 1/10/2022
1.0.259 348 12/9/2021
1.0.258 341 12/7/2021
1.0.218 217 10/18/2021
1.0.209 376 10/12/2021
1.0.157 360 9/4/2021
1.0.155 356 8/31/2021
1.0.153 185 8/14/2021
1.0.151 196 8/6/2021
1.0.146 183 7/22/2021
1.0.136 253 7/17/2021
1.0.135 183 7/16/2021
1.0.134 188 7/15/2021
1.0.133 200 7/14/2021
1.0.130 176 7/6/2021
1.0.127 193 7/5/2021
1.0.125 214 7/5/2021
1.0.122 236 6/30/2021
1.0.121 218 6/29/2021
1.0.119 239 6/28/2021
1.0.111 203 6/14/2021
1.0.105 301 5/29/2021
1.0.104 261 5/29/2021
1.0.97 197 5/28/2021
1.0.63 197 5/26/2021
1.0.20 238 5/21/2021