= MAX6675 K型熱電対温度センサ(SPI接続) = * [wiki:MAX6675Instruction 作り方の説明はこちら。] * [wiki:MAX6675Sketch 使うためのスケッチはこちら。] * [http://www.switch-science.com/products/detail.php?product_id=146 販売を始めました。] K型[http://ja.wikipedia.org/wiki/熱電対 熱電対]を使用した温度計モジュール。SPIでつなぎます。 校正不要。0℃~1023℃、0.25℃刻み。 ライターの火の温度とか測れちゃいます! [[Image(1.JPG, 500px)]] Arduinoなら、そのままデジタル8番~13番の位置に差し込めば動きます。 [[Image(2.JPG, 500px)]] 熱電対は比較的熱容量が小さいので、温度変化の検出が早いです。 常温程度の温度をモニタしていても、案外面白いです。 == 概要 == * K型熱電対を使用(接続はミニチュアコネクタ) * マイコンとはSPI接続(読み出しのみ) * [http://japan.maxim-ic.com/quick_view2.cfm/qv_pk/3149 Maxim社のMAX6675]を使用。 == 特徴 == いい点: * 校正不要 * 0℃~1023℃の広範囲を測定 * Arduinoなら、いきなり差し込んで動く。 悪い点: * 0.25℃刻みなのがちょっと粗い。 * 0℃以下を測定できない。 * 常温付近では相対的に誤差が大きい。 == 用途 == * ハンダごてのコテ先温度計 * なんちゃってリフロー * 恒温槽 * 各種実験 == 回路図 == [[Image(3.png, 500px)]] オープンソースだなんてほどのことはありません。 == キット販売~~検討~~中 == キットとして販売~~することを検討~~中です。 チップ部品が2個あるのがもしかしたら問題。 SOICは1.27mmピッチだからなんとかなるでしょう。 1005のチップコンデンサは、人によってはキツイかもしれません。 虫眼鏡、ピンセット、細いコテ先、細いハンダ、フラックスが必須です。 逆に、熱電対レセプタクルのハンダ付けには、太いコテ先が必須。 内容物: * ボード * Maxim MAX6675(SOIC 8ピン) * チップコンデンサ(1005サイズ) * K型熱電対専用レセプタクル基板直付け用(ミニチュア) * ピンヘッダ6ピン * K型熱電対(安物なので高温だと被覆が燃えます) * K型熱電対専用プラグ(ミニチュア、黄色) ~~3,000円くらいかなあ。~~ [http://www.switch-science.com/products/detail.php?product_id=146 2,980円で販売しています。] 高くてごめんなさい。MAX6675が高いんです。 == 謝辞 == Maxim社の無料サンプル制度を利用させていただきました。 うちみたいな小さな会社に対しても、ちゃーんと対応して下さるのが嬉しいです。 届くの早いし。ちなみに、マキシムジャパンから届きます。 サンプルでいただいたチップは、商売に使っちゃいけないのがルール。 上記のプレゼントで使用しているチップは、別途購入した物です。ご安心下さい。 == MAX6675.pde == {{{ #!c #include "SPI.h" #define VCC 8 #define GND 9 #define SLAVE 10 void setup() { #ifdef GND pinMode(GND, OUTPUT); digitalWrite(GND, LOW); #endif #ifdef VCC pinMode(VCC, OUTPUT); digitalWrite(VCC, HIGH); #endif Serial.begin(9600); SPI_Master.begin(SLAVE); } void loop() { int value; delay(500); SPI_Master.enable(SLAVE); value = SPI_Master.read() << 8; value |= SPI_Master.read(); SPI_Master.disable(); if ((value & 0x0004) != 0) Serial.println("Error"); else Serial.println((value >> 3) * 0.25); } }}} == SPI.cpp == {{{ #!c #include "SPI.h" boolean SPI_Master_Class::initialized_ = false; int SPI_Master_Class::enabled_ = -1; void SPI_Master_Class::begin(int slaveselecter) { if (!initialized_) { initialized_ = true; enabled_ = -1; pinMode(SS, OUTPUT); // Must be set as OUTPUT before SPE is asserted. pinMode(MOSI, OUTPUT); pinMode(MISO, INPUT); digitalWrite(MISO, HIGH); // Pull-up pinMode(SCK, OUTPUT); SPCR = (1<= 0) { digitalWrite(enabled_, HIGH); enabled_ = -1; } } byte SPI_Master_Class::write_and_read(byte data) const { SPDR = data; while (!(SPSR & (1<