nanoFramework.Iot.Device.Mcp960x 1.2.869

Prefix Reserved
dotnet add package nanoFramework.Iot.Device.Mcp960x --version 1.2.869
                    
NuGet\Install-Package nanoFramework.Iot.Device.Mcp960x -Version 1.2.869
                    
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.2.869" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="nanoFramework.Iot.Device.Mcp960x" Version="1.2.869" />
                    
Directory.Packages.props
<PackageReference Include="nanoFramework.Iot.Device.Mcp960x" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add nanoFramework.Iot.Device.Mcp960x --version 1.2.869
                    
#r "nuget: nanoFramework.Iot.Device.Mcp960x, 1.2.869"
                    
#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.
#addin nuget:?package=nanoFramework.Iot.Device.Mcp960x&version=1.2.869
                    
Install nanoFramework.Iot.Device.Mcp960x as a Cake Addin
#tool nuget:?package=nanoFramework.Iot.Device.Mcp960x&version=1.2.869
                    
Install nanoFramework.Iot.Device.Mcp960x as a Cake Tool

MCP960X/MCP9600/MCP9601 - 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.869 147 12 days ago
1.2.864 150 12 days ago
1.2.852 156 a month ago
1.2.846 161 a month ago
1.2.822 104 2 months ago
1.2.775 103 2 months ago
1.2.772 103 2 months ago
1.2.755 106 2 months ago
1.2.743 96 3 months ago
1.2.737 79 3 months ago
1.2.718 98 4 months ago
1.2.696 95 4 months ago
1.2.673 118 6 months ago
1.2.656 99 6 months ago
1.2.639 118 7 months ago
1.2.631 103 8 months ago
1.2.613 118 8 months ago
1.2.601 87 9 months ago
1.2.590 105 9 months ago
1.2.573 105 10 months ago
1.2.570 104 10 months ago
1.2.536 131 4/15/2024
1.2.514 123 3/22/2024
1.2.494 115 2/28/2024
1.2.462 180 1/5/2024
1.2.458 153 12/20/2023
1.2.436 179 11/10/2023
1.2.403 137 10/6/2023
1.2.396 148 9/27/2023
1.2.384 157 9/6/2023
1.2.378 138 8/16/2023
1.2.369 164 8/2/2023
1.2.363 152 7/28/2023
1.2.357 171 7/19/2023
1.2.354 161 7/14/2023
1.2.345 179 6/21/2023
1.2.341 153 6/14/2023
1.2.337 186 6/7/2023
1.2.335 154 6/2/2023
1.2.329 171 5/26/2023
1.2.316 160 5/16/2023
1.2.313 163 5/12/2023
1.2.302 178 5/10/2023
1.2.297 162 5/3/2023
1.2.273 244 3/17/2023
1.2.267 261 3/10/2023
1.2.263 260 3/8/2023
1.2.259 264 2/27/2023
1.2.256 267 2/24/2023
1.2.253 286 2/22/2023
1.2.222 330 1/9/2023
1.2.208 339 1/3/2023
1.2.203 323 12/28/2022
1.2.153 409 11/5/2022
1.2.141 404 10/25/2022
1.2.63 424 9/3/2022
1.2.47 426 8/15/2022
1.2.40 432 8/6/2022
1.2.38 420 8/5/2022
1.2.28 412 8/1/2022
1.2.13 418 7/24/2022
1.2.10 406 7/23/2022
1.1.142.3202 441 7/7/2022
1.1.133.52556 440 6/30/2022
1.1.121.35854 471 6/26/2022
1.1.113.2032 421 6/23/2022
1.1.102.51394 429 6/15/2022
1.1.99.36719 418 6/14/2022
1.1.72.29765 422 5/31/2022
1.1.64.21380 428 5/26/2022
1.1.58.10097 426 5/23/2022
1.1.54.28879 437 5/23/2022
1.1.40 451 5/5/2022
1.1.1 461 4/14/2022
1.0.300 452 3/31/2022
1.0.4-preview.44 142 3/25/2022
1.0.4-preview.34 129 3/21/2022
1.0.4-preview.29 139 3/18/2022
1.0.4-preview.24 140 3/15/2022
1.0.4-preview.17 139 3/8/2022
1.0.4-preview.8 151 2/27/2022
1.0.4-preview.6 135 2/26/2022
1.0.4-preview.1 137 2/19/2022
1.0.1 174 2/18/2022