MCP9700シリーズ(MCP9700, MCP9700A)は、Microchip Technology製の温度センサ IC(-40~+125℃)です。MCP9700シリーズのOSS-ECAL(電子部品抽象化レイヤのオープンソースソフトウェア:Open Source Software for Electronic Components Abstraction Layer)を提供致します。
MCUインタフェース:ADC
ご注意:このリソースの元の言語は英語です。 翻訳は概要を便宜的に提供するもので、機械翻訳を使用していることがあり、私たちは翻訳の正確性および妥当性につきましては一切保証いたしません。 また、実際の設計などの前には、必ず最新版Datasheetをご参照くださいますようお願いいたします。
MCP9700シリーズ(MCP9701, MCP9701A)
概要
リニア・アクティブ・サーミスタ集積回路(IC)を搭載したMCP9700/9700AおよびMCP9701/9701Aセンサは、温度をアナログ電圧に変換するアナログ温度センサ・ファミリを構成しています。 低コスト、低消費電力のこのセンサは、0℃~+70℃(MCP9700A/9701A)で±2℃、0℃~+70℃(MCP9700/9701)で±4℃の精度を備え、消費電流は6μA(標準)です。サーミスタなどの抵抗センサとは異なり、リニア・アクティブ・サーミスタICは信号調整回路を追加する必要がありません。そのため、サーミスタ・ソリューションのバイアス回路開発のオーバーヘッドを、この低コスト・デバイスからセンサを実装することで回避することができます。電圧出力ピン(VOUT)は、マイクロコントローラのADC入力に直接接続できます。MCP9700/9700AおよびMCP9701/9701Aの温度係数は、それぞれ2.5Vおよび5Vの基準電圧を持つ8ビットADCに対して1℃/ビットの分解能を提供するようにスケーリングされています。MCP9700/9700A は 4.096V 基準の 12 ビット ADC に対して 0.1℃/ビットを出力します。MCP9700/9700AおよびMCP9701/9701Aは、温度の相対変化の測定が必要なアプリケーションに低コストのソリューションを提供します。25℃からの相対温度変化を測定する場合、0℃から+70℃まで±1℃(代表値)の精度を実現できます。この精度は、+25℃でシステム校正を適用することによっても達成できる。 さらに、このデバイス・ファミリーは寄生容量の影響を受けにくく、大きな容量性負荷を駆動できる。このため、デバイスをマイクロコントローラーから離れた場所に配置することができ、プリント回路基板(PCB)レイアウト設計の柔軟性を提供する。また、出力に容量を追加することで、オーバーシュートやアンダーシュートを低減し、出力の過渡応答に役立ちます。しかし、センサー出力の安定性には容量性負荷は必要ありません。
特徴
- 小型アナログ温度センサー
- 利用可能なパッケージ:SC70-5, SOT-23-3, TO-92-3
- 広い温度測定範囲:
-40℃ ~ +125℃(拡張温度)
-40℃ ~ +150℃(高温)(MCP9700、SOT-23-3およびSC70-5のみ) - 精度:
±2°C (max.), 0°C to +70°C (MCP9700A/9701A)
±4°C (max.), 0°C to +70°C (MCP9700/9701) - アナログ・デジタル・コンバーター(ADC)に最適化:
10.0 mV/°C (typical) (MCP9700/9700A)
19.5 mV/°C (typical) (MCP9701/9701A) - 広い動作電圧範囲:
VDD = 2.3V to 5.5V (MCP9700/9700A)
VDD = 3.1V to 5.5V (MCP9701/9701A) - 低動作電流:6 µA(typical)
- 大容量負荷の駆動に最適化
用途
- ハードディスク・ドライブとその他のPC周辺機器
- エンターテインメント・システム
- 家庭用電化製品
- オフィス機器
- バッテリーパックとポータブル機器
- 汎用温度モニタリング
OSS-ECAL仕様
API関数
etSTS oMCP9700( etCMD cmd, float32* rlt )
oMCP9700関数は、引数のコマンドによってMCP9700シリーズ(MCP9701, MCP9701A)の処理を実行するAPI関数です。
戻り値 | etSTS | OSS-ECALステータスコード | |
eSTS_FIN | 正常終了 | ||
eSTS_ERR_MIN | 最小温度エラー(rltは最小温度) | ||
eSTS_ERR_MAX | 最大温度エラー(rltは最大温度) | ||
eSTS_ERR_HAL_ADC | HAL ADCエラー | ||
eSTS_ERR_COMMAND_CODE | コマンド選択エラー | ||
eSTS_ERR_OTHERS_RUN | 他のコンポーネントが処理実行中 | ||
eSTS_ERR_HAL_OTHERS_RUN | 他のアプリケーションがHAL実行中 | ||
eSTS_ERR_ADC_OBJECT | AD変換オブジェクト選択エラー | ||
引数 IN | etCMD cmd | OSS-ECALコマンドコード | |
eCMD_START | AD変換をスタートするコマンド | ||
eCMD_READ | AD変換値を読込み、AD変換値を温度に変換するコマンド AD変換値から温度変換式 電圧値=(AD変換値×VDD)/(2AD bit) 温度=((電圧値-電圧オフセット値)/ゲイン係数)+温度オフセット値 (Min, Max Limit) | ||
eCMD_START_READ | AD変換をスタートし、AD変換値を読込み、AD変換値を温度に変換するコマンド AD変換値から温度変換式 電圧値=(AD変換値×VDD)/(2AD bit) 温度=((電圧値-電圧オフセット値)/ゲイン係数)+温度オフセット値 (Min, Max Limit) | ||
引数 OUT | float32* rlt | 温度 -40.0 to 125.0 [°C] |
HAL別コマンド対応表
Arduino | eCMD_START_READ |
ARM Mbed | eCMD_START_READ |
Debian(Linux) | eCMD_START_READ |
Infineon ModusToolbox | eCMD_START_READ |
NXP MCUXpresso iMXRT1051B_1052B | eCMD_START eCMD_READ eCMD_START_READ |
Renesas SSP | eCMD_START eCMD_READ eCMD_START_READ |
STM STM32Cube FW_F4 | eCMD_START eCMD_READ eCMD_START_READ |
etSTS oMCP9700_START(void)
oMCP9700_START関数は、MCP9700シリーズ(MCP9701, MCP9701A)のAD変換を開始するAPI関数です。
戻り値 | etSTS | OSS-ECALステータスコード | |
eSTS_FIN | 正常終了 | ||
eSTS_ERR_HAL_ADC | HAL ADCエラー | ||
eSTS_ERR_OTHERS_RUN | 他のコンポーネントが処理実行中 | ||
eSTS_ERR_HAL_OTHERS_RUN | 他のアプリケーションがHAL実行中 | ||
eSTS_ERR_ADC_OBJECT | AD変換オブジェクト選択エラー |
HAL別関数対応表
Arduino | – |
ARM Mbed | – |
Debian(Linux) | – |
Infineon ModusToolbox | – |
NXP MCUXpresso iMXRT1051B_1052B | X |
Renesas SSP | X |
STM STM32Cube FW_F4 | X |
etSTS oMCP9700_READ( float32* rlt )
oMCP9700_READ関数は、MCP9700シリーズ(MCP9701, MCP9701A)のAD変換の終了を確認し、AD変換値を読み込み、そのAD変換値を温度に特性変換して、その温度をrltに保存するAPI関数です。
AD変換値から温度変換式
電圧値=(AD変換値×VDD)/(2AD bit)
温度=((電圧値-電圧オフセット値)/ゲイン係数)+温度オフセット値 (Min, Max Limit)
戻り値 | etSTS | OSS-ECALステータスコード | |
eSTS_FIN | 正常終了 | ||
eSTS_ERR_MIN | 最小温度エラー(rltは最小温度) | ||
eSTS_ERR_MAX | 最大温度エラー(rltは最大温度) | ||
eSTS_ERR_HAL_ADC | HAL ADCエラー | ||
eSTS_ERR_TIMEOUT | ADC Timeoutエラー(AUTOSARのみ) | ||
eSTS_ERR_OTHERS_RUN | 他のコンポーネントが処理実行中 | ||
eSTS_ERR_ADC_OBJECT | AD変換オブジェクト選択エラー | ||
引数 OUT | float32* rlt | 温度 -40.0 to 125.0 [°C] |
HAL別関数対応表
Arduino | – | |
ARM Mbed | – | |
Debian(Linux) | – | |
Infineon ModusToolbox | – | |
NXP MCUXpresso iMXRT1051B_1052B | X | |
Renesas SSP | X | |
STM STM32Cube FW_F4 | X | Time-out時間 HAL_MAX_DELAY |
etSTS oMCP9700_START_READ( float32* rlt )
oMCP9700_START_READ関数は、MCP9700シリーズ(MCP9701, MCP9701A)のAD変換を開始し、AD変換の終了を待ち、AD変換値を読み込み、そのAD変換値を温度に特性変換して、その温度をrltに保存するAPI関数です。
AD変換値から温度変換式
電圧値=(AD変換値×VDD)/(2AD bit)
温度=((電圧値-電圧オフセット値)/ゲイン係数)+温度オフセット値 (Min, Max Limit)
戻り値 | etSTS | OSS-ECALステータスコード | |
eSTS_FIN | 正常終了 | ||
eSTS_ERR_MIN | 最小温度エラー(rltは最小温度) | ||
eSTS_ERR_MAX | 最大温度エラー(rltは最大温度) | ||
eSTS_ERR_HAL_ADC | HAL ADCエラー | ||
eSTS_ERR_OTHERS_RUN | 他のコンポーネントが処理実行中 | ||
eSTS_ERR_HAL_OTHERS_RUN | 他のアプリケーションがHAL実行中 | ||
eSTS_ERR_ADC_OBJECT | AD変換オブジェクト選択エラー | ||
引数 OUT | float32* rlt | 温度 -40.0 to 125.0 [°C] |
HAL別関数対応表
Arduino | X | |
ARM Mbed | X | |
Debian(Linux) | X | |
Infineon ModusToolbox | X | |
NXP MCUXpresso iMXRT1051B_1052B | X | |
Renesas SSP | X | |
STM STM32Cube FW_F4 | X | Time-out時間 HAL_MAX_DELAY |
File構成
フォルダ* | ファイル | 概要 |
---|---|---|
MCP9700_HALNAME_VERSION/sample | sample.c (.cpp) | サンプル・アプリケーション・プログラム |
sample.h | サンプル・アプリケーション・ヘッダ | |
MCP9700_HALNAME_VERSION | oMCP9700.c (.cpp) | MCP9700シリーズ(MCP9701, MCP9701A)用OSS-ECALプログラム |
oMCP9700.h | MCP9700シリーズ(MCP9701, MCP9701A)用OSS-ECALヘッダ | |
MCP9700_ARDUINO.ino | Arduino用サンプル・アプリケーション・プログラム | |
oss_ecal.h | OSS-ECAL 共通ヘッダ (Ver 01.00.00以降) | |
user_setting.c (.cpp) | ユーザ設定定数・テーブル | |
user_setting.h | ユーザ設定ヘッダ | |
readme.md | Readme | |
OSS-ECAL Terms of Use.txt | OSS-ECAL利用条件 |
* HALNAMEはHAL対応表を参照してください。
HAL対応表
HAL | MCU* | 開発環境* | HALNAME |
---|---|---|---|
Arduino 1.8.6 | ATmega2560 ATmega328P | Mega 2560 Rev3 Arduino Pro Mini 3.3V | ARDUINO |
ARM Mbed 6.17.0 | STM32F401RE | STM32 Nucleo-64 boards | MBED |
Infineon ModusToolbox HAL Cat1 2.4.3 | CYBLE-416045-02 | CY8CPROTO-063-BLE PSoC 6 BLE Prototyping Kit | ModusToolbox |
NXP MCUXpresso SDK iMXRT1051B_1052B ksdk2_0 | MIMXRT1052DVL6A | IMXRT1050-EVKB | iMXRT1051B1052B |
Renesas SSP 2.4.0 | R7FS7G27H3A01CFC | S7G2 SK | SSP |
STM STM32Cube FW_F4 V1.27.1 | STM32F401RE | STM32 Nucleo-64 boards | STM32F4 |
Debian(Linux) v2022.04 | TI AM335x | BeagleBone Black – Rev C | Linux |
* 開発時のMCUおよび開発環境。
同じHALであってもMCUや開発環境が異なると動作が合わない場合があります。
OSS-ECAL ダウンロード
ダウンロードは、ログインしてから行ってください。新規のユーザ登録は、こちらから行ってください。
組込み方法
ユーザプログラムに複数のOSS-ECAL(同じMCU機能の電子部品)を組み込む方法
ユーザプログラムに複数のOSS-ECAL(異なるMCU機能の電子部品)を組み込む方法
注意事項
サンプル版OSS-ECALは、優先順位の異なるThread(Task)や割込みで用いることを前提としていません。下記の例のような使い方はしないでください。
例)同じADCグループに各センサーが割り当てられ、優先順位が異なる処理でOSS-ECAL APIを実行すると、正しい値を取得できない場合があります。
ADC Gr0 Ch0 温度センサ AD22100A 100ms周期 Thread(優先順位低)で温度取込み
ADC Gr0 Ch1 圧力センサ MPX5999D イベント割込み(優先順位高)で圧力取込み