nanoFramework.Iot.Device.Mcp960x 1.0.4-preview.24

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

// Install nanoFramework.Iot.Device.Mcp960x as a Cake Tool
#tool nuget:?package=nanoFramework.Iot.Device.Mcp960x&version=1.0.4-preview.24&prerelease                

MCP960X - device family of cold-junction compensated thermocouple to digital converter

The MCP960X device family is an I2C interface cold-junction compensated thermocouple to digital converter. Supported thermocouple types (designated by NIST ITS-90) are: K, J, T, N, S, E, B and R. The MCP9600/01 converts the thermocouple EMF to degree Celsius with integrated cold-junction compensation.

Note: Default thermocouple type is K

Sensor Image

Illustration of wiring from a Raspberry Pi device

Documentation

MCP960X datasheet

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. The sample reads two temperatures. One is a connected thermocouple reading which can be read using the GetTemperature command and the other is the temperature of the device itself which can be read using the GetColdJunctionTemperature command. The Cold Junction Temperature is used internally to increase the accuracy of the thermocouple.

using Iot.Device.Mcp960x;
using nanoFramework.Hardware.Esp32;
using System.Device.I2c;
using System.Diagnostics;
using System.Threading;

Debug.WriteLine("Write I2C MCP960X - ADR 0x67 - Read ambient and hot junction temperature every 1 sec");

// redefine I2C pins to match your ESP32 DevKit
// Configuration.SetPinFunction(21, DeviceFunction.I2C1_DATA);
// Configuration.SetPinFunction(22, DeviceFunction.I2C1_CLOCK);

// set I2C bus ID: 1
// 0x67 is the device address
I2cConnectionSettings settings = new I2cConnectionSettings(1, 0x67);
I2cDevice i2cDevice = I2cDevice.Create(settings);
Mcp960x mcp960x = new Mcp960x(i2cDevice, coldJunctionResolutionType: ColdJunctionResolutionType.N_0_25);

DeviceIDType deviceIDType;
byte major;
byte minor;
mcp960x.ReadDeviceID(out deviceIDType, out major, out minor);
Debug.WriteLine($"device id: {(byte)deviceIDType} - major: {major} - minor: {minor}");

while (true)
{
    Debug.WriteLine($"ambient temperture: {mcp960x.GetColdJunctionTemperature()}");
    Debug.WriteLine($"hot junction temperture: {mcp960x.GetTemperature()}");

    Thread.Sleep(1000);
}
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.673 81 10/23/2024
1.2.656 74 10/3/2024
1.2.639 96 9/6/2024
1.2.631 83 8/28/2024
1.2.613 99 8/9/2024
1.2.601 68 7/26/2024
1.2.590 84 7/17/2024
1.2.573 85 6/19/2024
1.2.570 83 6/14/2024
1.2.536 113 4/15/2024
1.2.514 107 3/22/2024
1.2.494 100 2/28/2024
1.2.462 163 1/5/2024
1.2.458 137 12/20/2023
1.2.436 167 11/10/2023
1.2.403 124 10/6/2023
1.2.396 136 9/27/2023
1.2.384 149 9/6/2023
1.2.378 129 8/16/2023
1.2.369 153 8/2/2023
1.2.363 143 7/28/2023
1.2.357 159 7/19/2023
1.2.354 153 7/14/2023
1.2.345 167 6/21/2023
1.2.341 142 6/14/2023
1.2.337 174 6/7/2023
1.2.335 142 6/2/2023
1.2.329 159 5/26/2023
1.2.316 146 5/16/2023
1.2.313 147 5/12/2023
1.2.302 165 5/10/2023
1.2.297 148 5/3/2023
1.2.273 231 3/17/2023
1.2.267 248 3/10/2023
1.2.263 245 3/8/2023
1.2.259 251 2/27/2023
1.2.256 252 2/24/2023
1.2.253 271 2/22/2023
1.2.222 313 1/9/2023
1.2.208 323 1/3/2023
1.2.203 306 12/28/2022
1.2.153 391 11/5/2022
1.2.141 384 10/25/2022
1.2.63 401 9/3/2022
1.2.47 405 8/15/2022
1.2.40 410 8/6/2022
1.2.38 400 8/5/2022
1.2.28 391 8/1/2022
1.2.13 398 7/24/2022
1.2.10 386 7/23/2022
1.1.142.3202 419 7/7/2022
1.1.133.52556 419 6/30/2022
1.1.121.35854 451 6/26/2022
1.1.113.2032 401 6/23/2022
1.1.102.51394 407 6/15/2022
1.1.99.36719 398 6/14/2022
1.1.72.29765 400 5/31/2022
1.1.64.21380 407 5/26/2022
1.1.58.10097 404 5/23/2022
1.1.54.28879 416 5/23/2022
1.1.40 428 5/5/2022
1.1.1 438 4/14/2022
1.0.300 430 3/31/2022
1.0.4-preview.44 124 3/25/2022
1.0.4-preview.34 109 3/21/2022
1.0.4-preview.29 120 3/18/2022
1.0.4-preview.24 120 3/15/2022
1.0.4-preview.17 121 3/8/2022
1.0.4-preview.8 132 2/27/2022
1.0.4-preview.6 116 2/26/2022
1.0.4-preview.1 118 2/19/2022
1.0.1 151 2/18/2022