• 追加された行はこの色です。
  • 削除された行はこの色です。
* 忘備録-Sparkfun.com MP3 Player Shieldを使う時のチュートリアル指定ファイルが存在しない [#s4a9511f]
#contents
//もくじです

#pcomment(reply)
//こめんとです

*2014/4/26 I2CカラーセンサS11059−02DTの使い方 [#de0b747a]
-irone用。I2Cで動く。色の対応が面倒くさかったので載せておく。
参考URL:http://blog.kemushicomputer.com/2013/08/i2c.html ~
前提として、3オクターブに合わせる為36種類ぐらいの色が欲しい ~
→RGBで考えると3*3*4ぐらいが妥当 ~
→直接取ってきた値を吟味しても上手くいかない(明るさによって同じ色が違う値になる,そもそも65535付近の明るさに行かない) ~
→赤外線信号を取って来れるという便利な機能に気付く。明るさによって変化するのか ~
→きれいに変化した。というわけでrgb値/IR値で補正できる。また、その値は大体0〜12の範囲に収まる ~
→これを3*3*4等分したものを最終的な色判断に使う ~

 /******************************************************************************* * 
 * S11059_02dt I2C color sensor test sketch  v20130818   by KentN 
 *
 * http://www.hamamatsu.com/jp/ja/product/new/S11059-02DT/index.html  (Ja 
 * http://www.hamamatsu.com/jp/en/product/new/S11059-02DT/index.html  (EN
 * 
 *  tested boards  
 *  MSP430 LaunchPad(G2553) (Energia IDE 0101E009 & patched latest  MSP430/cores library) 
 *   Arduino 1.0 or later (need 3.3V board or I2C level converter) 
 * 
 *  MSP430LaunchPad (& Energia) 
 * before enabling I2C bus, remove led2 JUMPER PIN 
 * Energia IDE must be patched with latest cores library on github 
 * (In energiaIDEdirectory/hardware/MSP430/cores) 
 ********************************************************************************/
 #include "Wire.h"
 #define device_address 0x2A
 #define control_reg 0x00
 /* //色の種類。3オクターブに合わせて36種類になっている
 #define black 0
 #define dark_blue 1
 #define navy 2
 #define blueblue 3
 #define greenteamilk 4
 #define emerald 5
 #define sky 6
 #define aqua 7
 #define yellowgreen 8
 #define lightemerald 9
 #define shallowsea 10
 #define lightaqua 11
 #define redblack 12
 #define lightredpurple 13
 #define lightpurple 14
 #define lightbluepurple 15
 #define mastard 16
 #define ash 17
 #define lightblueash 18
 #define lightbluewhiteash 19
 #define neonyellowgreen 20
 #define lightashyellowgreen 21
 #define lightashemerald 22
 #define lightashwhiteblue 23
 #define redred 24
 #define pink 25
 #define pinkpurple 26
 #define purple 27
 #define orange 28
 #define fleshcolor 29
 #define whitepink 30
 #define kirby 31
 #define yellow 32
 #define lightyellow 33
 #define verylightyellow 34
 #define white 35
 */
 //センサーからの値を持ってくる。16bitなので0〜65535
 uint16_t red = 0;
 uint16_t green = 0;
 uint16_t blue = 0;
 uint16_t IR = 0; 
 //センサーのRGB値から色を決定する際に使う
 uint16_t r = 0;
 uint16_t g = 0;
 uint16_t b = 0; 
 //group センサーから補正後の値が大体12ぐらいまでなので、
 uint16_t r_1 = 4;
 uint16_t r_2 = 8;
 uint16_t r_3 = 20; 
 uint16_t g_1 = 4;
 uint16_t g_2 = 8;
 uint16_t g_3 = 20;
 uint16_t b_1 = 3;
 uint16_t b_2 = 6;
 uint16_t b_3 = 9;
 uint16_t b_4 = 20;
 uint16_t color = 0;
 uint16_t colorGroup[3][3][4] = {
                            {
                              {0,1,2,3},
                              {4,5,6,7},
                              {8,9,10,11}
                            },
                            {
                              {12,13,14,15},
                              {16,17,18,19},
                              {20,21,22,23}
                            },
                            {
                              {24,25,26,27},
                              {28,29,30,31},
                              {32,33,34,35}
                            }
                          };
 void getRGB();
 void getColor();
 void getColor()
 {
  if(red <= r_1){r = 0;}
  else if(red <= r_2){r = 1;}
  else if(red <= r_3){r = 2;}
  if(blue <= b_1){b = 0;}
  else if(blue <= b_2){b = 1;}
  else if(blue <= b_3){b = 2;}
  else if(blue <= b_4){b = 3;}
  if(green <= g_1){g = 0;}
  else if(green <= g_2){g = 1;}
  else if(green <= g_3){g = 2;}  
  color = colorGroup[r][g][b];
 }
 void setup()
 {
  Wire.begin();
  Serial.begin(9600);
 }
 void loop()
 {
  getRGB();
  Serial.print(red);
  Serial.print(',');
  Serial.print(green);
  Serial.print(',');
  Serial.print(blue);
  Serial.print(',');
  Serial.println(IR);
  red= red/IR;
  green=green/IR;
  blue=blue/IR;
  getColor();
  Serial.print(red);
  Serial.print(',');
  Serial.print(green);
  Serial.print(',');
  Serial.print(blue);
  Serial.print(',');
  Serial.println(color);
  delay(500);
 }
 void getRGB()
 {
  uint16_t colordata= 0;
  //この辺のプロトコルはデータシートに載っている
  Wire.beginTransmission(device_address);
  Wire.write(control_reg);
  Wire.write(0x83); // ADC reset, wakeup, low gain, fixed time mode, 179.2ms
  Wire.endTransmission(false);
  Wire.beginTransmission(device_address);
  Wire.write(control_reg);
  //ADC start, wakeup, low gain, fixed time mode, 179.2ms
  Wire.write(0x03);
  Wire.endTransmission(true); 
  //probably for RGB+IR
  delay(180*4); //total exposure time
  Wire.beginTransmission(device_address);
  Wire.write(0x03);
  Wire.endTransmission(false);
  Wire.requestFrom(0x2A,8,true);
  //read data
  colordata = Wire.read();
  colordata <<= 8;
  colordata |= Wire.read();
  red = colordata;
  colordata =0;
  colordata = Wire.read();
  colordata <<= 8;
  colordata |= Wire.read();
  green = colordata;
  colordata =0;
  colordata = Wire.read();
  colordata <<= 8;
  colordata |= Wire.read();
  blue = colordata;
  colordata =0;
  colordata = Wire.read();
  colordata <<= 8;
  colordata |= Wire.read();
  IR = colordata;
  return; 
 }

上手く動いたが改善は都度していきたい。

*2014/4/26 OZVの使い方 [#q72fd410]
-irone用。XBeeとあまり変わらないが、パケットを作成したりデータを取り出す必要がある。
-プログラム ~
-send側 ~
 #include <SoftwareSerial.h>
 SoftwareSerial ozvSerial(10, 11); // RX, TX
 //send packet, for the last 3elements, length, data and check sum
 byte send[10]={0xFE, 0x05, 0x2A, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};
 //length of data
 int length = 0x01;
 //data
 int data = 0xCA;
 int i = 0; //loop
 void setup(){
    Serial.begin(9600);
    ozvSerial.begin(38400);
    //complete send packet
    send[sizeof(send) - 3] = length;
    send[sizeof(send) - 2] = data;
    //culculate checksum and complete send command
    for(i = 1; i < sizeof(send) - 1; i++){
        send[sizeof(send) - 1] = send[i] ^ send[sizeof(send) - 1];
    }
 }
 void loop(){
    //send
    delay(1000);
    ozvSerial.write(send,sizeof(send));
 }

-receive側 ~
 #include <SoftwareSerial.h>
 SoftwareSerial ozvSerial(10, 11); // RX, TX
 // for the last 2elements, data and SUM
 //receive packet
 byte receive[12];
 //data from received packet
 int getData = 0x00;
 //serial received data
 byte receivebyte = 0x00;
 int i = 0;//loop
 int count = 0;//insert data into receive array
 int start = 0;//start inserting
 int receiveLen = 12;//receive packet length is 12
 void setup(){
    Serial.begin(9600);
    ozvSerial.begin(38400);
 }
 void loop(){
    //receive
    if(ozvSerial.available()){
        receivebyte = ozvSerial.read();
        //0xFE is start of a paket
        if(receivebyte == 0xFE){
            start = 1;
        //other than 0xFE, 11elements remaining to receive
        }else if(start == 1 && count < receiveLen - 1){
            receive[count] = receivebyte;
            count++;
        //when finished inserting, get data from the packet
        }else if(count == receiveLen - 1){
            count = 0;
            start = 0;
            getData = receive[receiveLen - 3];
            Serial.print("data = ");
            Serial.println(getData, HEX);
        }
    }
 }

詳しくは忘れたのでプログラムだけでも忘備録と

*2014/1/10 追記 [#q314a404]
-日本語のencodingは、%!TEX encoding = UTF-8 Unicodeの一文を.texファイルの最初10行以内に入れる

*2014/1/10 TeXをMacにインストール・コマンドのパスを通す [#i29e5e51]
-今更ながらマックにTeX環境を構築した。LaTeXも使えてpdfファイルも出力できたので、まとめ。
-sasadaさんの作業日誌をヒントに進めた→http://ifdl.ec.t.kanazawa-u.ac.jp/diary/index.php?sasada#b53f5bea

-.ぅ鵐好函璽襦初期設定 ~
http://d.hatena.ne.jp/lucky_pool/20120209/1328758735 このサイトの手順に従う。~
1. Drag & Drop UpTeX ~
2. ESP Ghostscriptに加えて、~
3. UpTeX差分ファイル ~
も、と別のところで書いてあったのでダウンロード。3については、解凍後のdvipdfmxファイルを ~
/Applications/UpTeX.app/teTeX/binにドラッグ&ドロップして全てのインストール完了。 ~
サイトに書いてある初期設定はしておく。 ~
さらに、アプリケーション内のTeXPadは、一度ダブルクリックで開いて初期設定をokと押しておく。

-▲僖垢鯆未 ~
コマンドから直接コンパイルやdivファイルを作る際には、コマンド郡(?)にパスを通しておく必要がある。 ~
http://xn--p8ja5bwe1i.jp/wiki/%E3%81%9D%E3%81%AE%E4%BB%96/Mac%E3%81%A7%E3%83%91%E3%82%B9%E3%82%92%E9%80%9A%E3%81%99/ ~
この記事がとても参考になる。ただし、.bashrcの作成の仕方とPATHの前にexport付けるとかは書いてないので付け加え。 ~
https://gist.github.com/disktnk/4104284 上記2つの解決法が載っていた。 ~
さらに、編集の仕方と保存・終了の仕方は ~
http://www14.plala.or.jp/campus-note/vine_linux/operation/vi.html ~
要するに、.bashrcを開いてiを押すと編集画面になり、コマンドモードに戻る時はescを押す。保存+終了はwqをコマンド入力する。 ~
ここまでが終わるとパスの確認をする。ターミナルに platex -v を入力してcommand not found以外のplatexに関する説明が出てきたらok ~
あとはチュートリアルhttp://www.comp.tmu.ac.jp/tsakai/lectures/intro_tex.htmlにあるコマンド入力 ~
platex sample.tex
でエラーがなければdviファイルができて、 ~
dvipdfmx sample.dvi ~
でpdfファイルができる。 ~

*2013/12/8 RFM12B(微弱無線モジュール)を使ってみた [#y7e8e6c5]
-先生に頂いたライブラリをいじってみた
-未完成部分(電場強度の計算・irone用に完全arduino UNO抜きでの通信・通信距離測定)
-完成部分(データの送信・受信)
-SPI通信によって制御する。

―猗:

データシート

http://www.hoperf.com/upload/rf/rfm12b.pdf

コマンド

http://www.hoperf.com/upload/rf/rfm12b.pdf

コマンド早見表 

http://tools.jeelabs.org/rfm12b.html

http://www.sevenwatt.com/main/

電波強度 

http://eleclog.quitsq.com/2011/11/rfm12b-radio-act.html

Arduino cookbook 

https://www.inkling.com/read/arduino-cookbook-michael-margolis-2nd/chapter-14/recipe-14-6

パケット内容 

http://lowpowerlab.com/blog/2012/12/28/rfm12b-arduino-library/#more-109

http://lowpowerlab.com/blog/2013/06/20/rfm69-library/

http://jeelabs.org/2011/12/11/inside-the-rf12-driver-part-2/

2進数計算 

http://hogehoge.tk/tool/number.html

Arduinoピン配置 

http://wiki.onakasuita.org/pukiwiki/?Arduino%2F%E3%83%94%E3%83%B3%E9%85%8D%E7%BD%AE

回路:
#ref(rfm_1.png)
今回はこれらに加えてnINT/VDI, FSK/DATA/nFFS, DCLK/CFIL/FFIT, nRESピンをマイコンと繋いだ。
Arduino UNOは5Vで動作するので、RFM12Bに入る信号を分圧する。どの信号が入るかはデータシートのDIを見ると分かる。

ライブラリ:

-RF12.cpp

  /*useful command: http://tools.jeelabs.org/rfm12b.html
  arduinoを使用するときは16MHzになっているので/4(デフォルト)に加えて/2のに分圧して使う。(RFM12Bが  2.5MHzまでしか受け付けない設定のため)
  #define arduino
  先生のライブラリから変更した箇所 */
  #define changed
  /*commands*/
  #define SET_TX 0x8279
  #define SET_RX 0x82D9
  #define RESET 0x0000
  #define STATUS_CHECK 0x0000
  #define TX_SEND 0xB800 //+ data
  #define RX_RECEIVE 0xB000
  #define CONFIGURATION 0x80D7 // el(enable tx regigter), ef(enable FIFO) 12.0pF, 433MHz
  #define SET_FREQUENCY 0xA4B0 // 433MHz
  #define SET_DATARATE 0xC623 // 9.6kbps
  #define SET_PLL 0xCC17 // CLK=2.5MHz, !ddy ddit, PLL BW=256k
  #define RX_CONTROL 0x94C2 // VDI,FAST,67kHz,LNA=0dBm,RSSI=-91dBm 
  #define Data_Filter_Clock_Recovery 0xC2AC // AL,!ml,DIG,DQD4 
  #define FIFO_RESET_MODE 0xCA83 // FIFO8,2byte-SYNC,!AL,ff,DR
  #define TX_CONTROL 0x9850 // !mp,90kHz,MAX OUT TXpower=0(max)
  #define AUTO_FREQUENCY_CONTROL 0xC483 // @PWR,NO RSTRIC,!st,!fi,OE,EN 
  #define SET_WAKEUP_TIMER 0xE000 // wake up timer / NOT USE 
  #define SET_LOW_DUTY_CYCLE 0xC800 // low duty cycle / NOT USE//status
  #define SET_LOW_BATTERY_DETECT_uC_CLK 0xC049 // 1.66MHz,3.1V 
  #define SET_SYNC_PATTERN 0xCED4 // SYNC=2DD4
  //status
  #define TX_READY 0x8000
  #define FIFO_REACHED 0x8000
  //pin
  #define SPI_MOSI 11
  #define SPI_MISO 12
  #define SPI_SCK 13
  #include <pins_arduino.h>
  #include <avr/interrupt.h>
  #include <Arduino.h>
  #include <RF12.h>
  int nIRQ_pin, SS_pin, RST_pin;
  int mode;
  uint8_t RF12::spi_byte(uint8_t out) {
    SPDR = out;
    while (!(SPSR & _BV(SPIF)));
    return SPDR;
  }
  uint16_t RF12::xfer_byte(uint16_t cmd)
  {
  uint16_t dat = 0;
  digitalWrite(SS_pin, 0);
  dat = spi_byte(cmd >> 8) << 8;
  dat |= spi_byte(cmd);
  digitalWrite(SS_pin, 1);
  return(dat);
  }
  void RF12::send_byte(byte data)
  {
  uint16_t d;
  //  while(!((d = xfer_byte(0x0000)) & 0x8000)) Serial.println(d, HEX);
  //send 0000(status check). when returned 8000 TX is ready
  while(!(xfer_byte(STATUS_CHECK) & TX_READY)); // wait for TX ready
  xfer_byte(TX_SEND + data);
  delay(1);
  }
  //sending 1bit per time
  //would I need this?
  void RF12::send_data(byte *data, byte len)
  {
  byte cksum = 0;
  for (int i = 0; i < len; i++){
    send_byte(data[i]);
    cksum += data[i];
  }
  send_byte(cksum);
  }
  //wait(blocks) until it receives -> it's okay cuz used only for speaker
  #ifdef changed
  byte RF12::receive_byte()
  {
  //interrupt request output(from RFM12B), active low
	while(digitalRead(nIRQ_pin) == 1); // wait for any data received
  //status check, reset functions
  //xfer_byte(0x0000);
  // while(!(xfer_byte(0x0000) & 0x8000))Serial.println(xfer_byte(0x0000), HEX); // wait for RX ready
  //read 8 bits from the receiver FIFO (even if FIFO not used it still shares the same pin with RX(pin6))
  xfer_byte(RESET);
  return(xfer_byte(RX_RECEIVE));
  }
  #else
  byte RF12::receive_byte()
  {
  //interrupt request output(from RFM12B), active low
  while(digitalRead(nIRQ_pin) == 1); // wait for any data received
  //status check, reset functions
  xfer_byte(0x0000);
  //read 8 bits from the receiver FIFO (even if FIFO not used it still shares the same pin with RX(pin6))
  return(xfer_byte(0xB000));
  }
  #endif
  //needed to recaive less than a byte?
  byte *RF12::receive_data(byte *data, byte len)
  {
  int i;
  for (i = 0; i < len; i++){
    data[i] = receive_byte();
  }
  return(data);
  }
  void RF12::begin(uint8_t nIRQ, uint8_t SS, uint8_t RST)
  {
  nIRQ_pin = nIRQ;
  SS_pin = SS;
  RST_pin = RST;
  pinMode(RST_pin, INPUT);
  //  digitalWrite(RST_pin, 0);
  digitalWrite(SS_pin, 1);
  pinMode(SS_pin, OUTPUT);
  //digital 11,12,13 is fixed
  //faster when set it directly?
  #ifdef changed
  DDRB |= ((1<<DDB3)|(1<<DDB4)|(1<<DDB5));
  #else
  pinMode(SPI_MOSI, OUTPUT);
  pinMode(SPI_MISO, INPUT);
  pinMode(SPI_SCK, OUTPUT);
  #endif
  //need to make this smaller than 2.5MHz? arduino is 16MHz
  SPCR = _BV(SPE) | _BV(MSTR); // SPI master enable, Mode0
  #ifdef arduino
  SPSR |= _BV(SPI2X);
  #endif
  pinMode(nIRQ_pin, INPUT);
  digitalWrite(nIRQ_pin, 1); // pull-up, active low
  //status check for return and initialization
  xfer_byte(RESET); // intitial SPI transfer added to avoid power-up problem
  // wait until RFM12B is out of power-up reset, this takes several *seconds*
  //empty Tx buffer
  xfer_byte(TX_SEND); // in case we're still in OOK mode
  //reset again and again
  while (digitalRead(nIRQ_pin) == 0) xfer_byte(RESET);
  //yes, commands start
  //enable internal register and FIFO mode ---> why? needed for real time and 1 byte transmission?
  xfer_byte(CONFIGURATION); // el, ef 12.0pF, 433MHz 
  //fastest way it might be: turning on the whole receiver chain, synthesizer, and oscillator
  //I don't understand here according to datasheet
  #ifdef changed
  xfer_byte(0x82d9); // RX mode -> in case didn't set the mode?
  xfer_byte(SET_FREQUENCY); // 433MHz
  xfer_byte(SET_DATARATE); // 9.6kbps
  xfer_byte(SET_PLL); // CLK=2.5MHz, !ddy ddit, PLL BW=256k
  //especially here
  //xfer_byte(TX_CONTROL); // !mp,90kHz,MAX OUT TXpower=0(max)
  xfer_byte(RX_CONTROL); // VDI,FAST,67kHz,LNA=0dBm,RSSI=-91dBm 
  #else
  //receiver baseband circuite separately switched on
  xfer_byte(0x82d9); // RX mode -> in case didn't set the mode?
  xfer_byte(0xA640); // 437MHz (430+0.0025*(0x640)[MHz]) 
  xfer_byte(0xC647); // 4.8kbps
  xfer_byte(0xCC77); // CLK=2.5MHz, !ddy ddit, PLL BW=256k
  xfer_byte(0x94A2); // VDI,FAST,134kHz,LNA=0dBm,RSSI=-91dBm 
  #endif
  //Data Filter & Clock Recovery
  xfer_byte(Data_Filter_Clock_Recovery); // AL,!ml,DIG,DQD4 
  //FIFO and reset mode
  xfer_byte(FIFO_RESET_MODE); // FIFO8,2byte-SYNC,!AL,ff,DR 
  //Automatic Frequency Control
  xfer_byte(AUTO_FREQUENCY_CONTROL); // @PWR,NO RSTRIC,!st,!fi,OE,EN 
  //replaced----------------------------------------------------------------  
  //TX control
  xfer_byte(TX_CONTROL); // !mp,90kHz,MAX OUT TXpower=0(max)
  //------------------------------------------------------------------------
  xfer_byte(SET_WAKEUP_TIMER); // wake up timer / NOT USE 
  xfer_byte(SET_LOW_DUTY_CYCLE); // low duty cycle / NOT USE
  //Low Battery Detect and &#181;C Clock 
  xfer_byte(SET_LOW_BATTERY_DETECT_uC_CLK); // 1.66MHz,3.1V 
  //Synchronization Pattern
  xfer_byte(SET_SYNC_PATTERN); // SYNC=2DD4
  delay(1);
  }
  void RF12::set_tx_power(uint8_t pow)
  {
  //just setting the power on TX Configuration Command
  xfer_byte(TX_CONTROL + (pow & 0x07));
  }
  uint16_t RF12::read_status(void)
  {
  return(xfer_byte(STATUS_CHECK));
  }
  RF12::RF12(void)
  {
  }
  void RF12::set_mode(uint8_t md)
  {
	mode = md;
  //  xfer_byte(0x8239); // !er, !ebb,  et, es, ex, !eb, !ew, dc (for tx)
  //  xfer_byte(0x82D9); //  er,  ebb, !et, es, ex, !eb, !ew, dc (for rx)
  //new-------------------------------------------------------------------
	//xfer_byte(0x8279); // !er, ebb,  et, es, ex, !eb, !ew, dc (for tx)
  //  xfer_byte(0x82D9); //  er, ebb, !et, es, ex, !eb, !ew, dc (for rx)
  #ifdef changed
  if (md == RF12_MODE_TX) xfer_byte(SET_TX);
  else if (md == RF12_MODE_RX) xfer_byte(SET_RX);
  #else
  if (md == RF12_MODE_TX) xfer_byte(0x8239);
  else if (md == RF12_MODE_RX) xfer_byte(0x82d9);
  #endif
  }
  int RF12::available(void)
  {
  if (digitalRead(nIRQ_pin) == 0) return(1);
  else return(0);
  }

  -送受信のinoファイル
  Rx:
  #include <RF12.h>
  int RF12_SS = 10;
  int RF12_nIRQ = 9;
  int RF12_RST = 8;
  uint8_t payload[16];
  uint16_t pckt;
  RF12 rf12 = RF12();
  byte data;
  byte packet[16];
  void setup()
  {
  Serial.begin(9600);
  rf12.begin(RF12_nIRQ, RF12_SS, RF12_RST);
  rf12.set_mode(RF12_MODE_RX);
  Serial.println("Ready Rx");
  }
  int header = 4;
  int tail = 6;
  int index = 0, check = 0;
  void loop()
  {
  //uint8_t c;
	if (rf12.available()){
		data = rf12.receive_byte();
		if((data == 0xAA) || (data == 0x55)) ; else Serial.write(data);
	}
	//Serial.println();
  }

  Tx:
  #include <RF12.h>
  int RF12_SS = 10;
  int RF12_nIRQ = 9;
  int RF12_RST = 8;
  uint16_t payload[16];
  uint16_t c;
  RF12 rf12 = RF12();
  void setup()
  {
  Serial.begin(9600);
  pinMode(4, OUTPUT);
  rf12.begin(RF12_nIRQ, RF12_SS, RF12_RST);
  rf12.set_mode(RF12_MODE_TX);
  Serial.println("TX ready");
   c = '!'; 
  }
  void loop()
  {
	//packet format - only activating necessary parts for just 1 byte transmission
	//see http://jeelabs.org/2011/12/11/inside-the-rf12-driver-part-2/
	//or http://lowpowerlab.com/blog/2012/12/28/rfm12b-arduino-library/#more-109
	//for full packet information	
	//necessary part(5 bytes)
	//preamble
    rf12.send_byte(0xAA);
    rf12.send_byte(0xAA);
    rf12.send_byte(0xAA);
	//SYN-ox2d
    rf12.send_byte(0x2D);
	//SYN-network ID (network group (can be in the range 1-255) -> 212)
    rf12.send_byte(0xD4);
	//header
	//CTLflag + DestID(unique node ID of receiver (1 through 30) -> 85)
	//0 + 55
	//rf12.send_byte(c);
    rf12.send_byte(0x55);
	//ACK + SourceID(unique node ID of receiver (1 through 30))
	//1 + 42?
    rf12.send_byte(0xaa);
	//DataLength
    rf12.send_byte(0x55);
	//Data
    rf12.send_byte(0xaa);
    rf12.send_byte(c);	//CRC
	rf12.send_byte(c+1);
	rf12.send_byte(c+2);
    rf12.send_byte(0x55);
	//CRC
    rf12.send_byte(0xaa);
    rf12.send_byte(0x55);
    rf12.send_byte(0xaa);
    rf12.send_byte(0xaa);
    rf12.send_byte(0xaa);
    //Serial.println("Sent.");
	digitalWrite(4, HIGH);
	delay(250);
	digitalWrite(4, LOW);
	delay(250);
  //}
  }

注意:Serial.printを使うとSerialがハイになっている時に何故か0を読む。するとビットがずれて値がおかしくなるのでSerial.writeを使う方が良かった。(1byteの通信はこちらの方がいいということも書いてあった)
100回に1回ぐらい値を間違えることがある。
上記プログラムの細かい内容については後ほど更新予定

*2013/12/8 Serial.printとSerial.write [#hdc93cf4]
-参考: http://arduino.cc/en/Serial/write
1byteあるいはそれ以上のバイト単位毎に、Serial.writeはバイナリーデータそのままをシリアルポートに送るらしい。→1byte毎のデータ通信にはwriteの方がいいのかも

*2013/9/30 unsignedに気をつける [#m66236ad]
-ただのintで-がつくのは値が大きい場合

*2013/9/26 ATmega3238Pブートローダ後のスケッチ書き込みメモ [#q6db51f1]
-リセットスイッチにつけるコンデンサは0.1μFだと上手くいくけれども22pFだと書き込みできない(容量が小さすぎて上手くリセットされていないのかも?)

* 2013/9/24 ATmega328Pのブートローダー書き込みメモ(PU) [#p9c3868b]
-ヒューズ設定表
#ref(3_1.png)
-どのブートローダーを使うかはbootloader.txtに載っている
-ATmega328pではhttp://ifdl.ec.t.kanazawa-u.ac.jp/~akita/lt/index.php?Hardware%2FLED_Tile%2F328
#ref(3_2.png)
-手順(巨匠さんの作業日誌も参考にさせて頂きました。)
-図がたくさんで分かりやすい、、、
-http://mizupc8.bio.mie-u.ac.jp/pukiwiki/index.php?Arduino%2F%E8%87%AA%E4%BD%9C


* 2013/9/23 忘備録-Sparkfun.com MP3 Player Shieldを使う時のチュートリアル指定ファイルが存在しない [#s4a9511f]
-Sparkfun.com MP3 Player ShieldをUNOで使う時にインストールするライブラリのピン(SSを10→9)に変更しないといけない。
-https://www.sparkfun.com/tutorials/295 の
#ref(2_1.png)
 が存在しないのですが、Arduino/libraries/SdFat/SdFatConfig.hの一番下
#ref(2_2.png)
 にありました。ここのCSを10→9に変えると動きました。

* Eclipseを使ってJavaでシリアル通信 [#ga87d6a8]
- 動作環境:Windows7 64bit
- 手順

  .轡螢▲訥命を行いたいEclipseのpackage下に追加ライブラリ用のフォルダを作る(名前は何でもいいけど写真ではlib)
#ref(1.png)

  追加用のライブラリをインストール
-- http://mfizz.com/oss/rxtx-for-java

  このフォルダを解凍した中の、

   rxtxParallel.dll

   rxtxSerial.dll

   RXTXcomm.jar

  をコピーして、,離侫ルダ内にペースト

-もしもパソコン自体にインストールしたい場合は、Program Files内のJavaファイルのライブラリに入れる(やってないので動くかは不明)

  EclipseでLibrary  Pathを追加する
-Eclipseを起動
 
-まず、新しく作ったフォルダが入っているPackage名を右クリックして、Refreshを選択。(または、Package名を選択後、F5を押す。)
  
これで、新フォルダがPackageに仲間入り。
 
-ProjectタブのPropertiesをクリックする。Propertiesの左にJava Build Pathがあるのでクリック。

-Librariesタブをクリック。Add Jars...をクリックして、,悩遒辰織侫ルダ内のRXTXcomm.jarを選択。
#ref(2.png)
-これで設定は完了。あとはプログラムを書くのみ。

  ぅ廛蹈哀薀犧鄒
-CommLight.java(メインがあるファイル)
  //port check
  //JDK check
  import java.io.*;
  public class CommLight{
	static File sharedText;
	
	public static void main(String[] args){
        
        SerialComm serialcomm = new SerialComm();
        serialcomm.open();
        int i = 10;
        while(i>0){
        	serialcomm.write((byte)0x34);
        	try{
            	Thread.sleep(500);
            }catch(Exception e){
            	
            }
            serialcomm.write((byte)0x20);
            try{
            	Thread.sleep(500);
            }catch(Exception e){
            	
            }
            serialcomm.write((byte)0x78);
            try{
            	Thread.sleep(500);
            }catch(Exception e){
            	
            }
            i--;
        }
		System.out.println("Hello, World");
	}
}

-SerialComm.java
  import gnu.io.*;
  import java.io.*;
  import java.util.*;
  public class SerialComm implements SerialPortEventListener{
	private SerialPort port;
  //	private static BufferedReader reader;
	private InputStream in;
	private OutputStream out;
	SerialComm(){
		super();
	}
	public void open(){
		try {
			// Serial port initialize
			CommPortIdentifier portId = CommPortIdentifier.getPortIdentifier("COM6");
			port = (SerialPort)portId.open("USB Serial Port", 2000);
			port.setSerialPortParams(
					9600,					 // í&#160;êMë¨ìx[bps]
					SerialPort.DATABITS_8,   // ÉfÅ[É^ÉrÉbÉgêî
					SerialPort.STOPBITS_1,   // ÉXÉgÉbÉvÉrÉbÉg
					SerialPort.PARITY_NONE   // ÉpÉäÉeÉB
					9600,					 // &#237;&#160;&#234;M&#235;¨&#236;x[bps]
					SerialPort.DATABITS_8,   // &#201;f&#197;[&#201;^&#201;r&#201;b&#201;g&#234;&#238;
					SerialPort.STOPBITS_1,   // &#201;X&#201;g&#201;b&#201;v&#201;r&#201;b&#201;g
					SerialPort.PARITY_NONE   // &#201;p&#201;&#228;&#201;e&#201;B
					);
			port.setFlowControlMode(SerialPort.FLOWCONTROL_NONE);
			try{
				port.addEventListener(this);
				port.notifyOnDataAvailable(true);
				
				in = port.getInputStream();
				out = port.getOutputStream();
			}catch(TooManyListenersException ex){
				System.out.println("Error1: "+ex);
			}
		} catch (Exception e) {
			System.out.println("Error2: " + e);
			System.exit(1);
		}
	}
	public void close(){
		try{
			in.close();
			out.close();
			port.close();
		}catch(Exception e){
			System.out.println("close: "+e);
		}
	}
	public void read(){
		try{
			byte[] buffer;
			int temp = in.available();
			if(temp>0){
				System.out.println("temp: "+temp);
				buffer = new byte[temp];
				temp = in.read(buffer);
				int num = 0;
				while(num<temp){
					System.out.println("b "+num+": "+Integer.toHexString((byte)buffer[num]));
					num++;
				}
			}
			in.close();
		}catch(Exception e){
			System.out.println("error4: "+e);
		}
	}
	public static String toHex(byte[] digest) {
		StringBuilder sb = new StringBuilder();
		for (byte b : digest) {
			sb.append(String.format("%1$02X", b));
		}
		return sb.toString();
	}
	public void write(byte data){
		try{
			out.write((byte)data);   
			out.flush();
			//ÉXÉgÉäÅ[ÉÄÇ&#8710;COMÉ|Å[ÉgÇ&#63743;ï¬Ç∂ÇÈèàóù
			//&#201;X&#201;g&#201;&#228;&#197;[&#201;&#196;&#199;&#8710;COM&#201;|&#197;[&#201;g&#199;&#63743;&#239;¬&#199;∂&#199;&#200;&#232;&#224;&#243;&#249;
		}catch(Exception e){
			System.out.println("port exception: "+e);
		}
	}
	public void run() {
		try {
			InputStreamReader isr = new InputStreamReader(System.in);
			BufferedReader br = new BufferedReader(isr);
			OutputStream out = port.getOutputStream();
			boolean flagQuit = false;
			while (!flagQuit) {
				String input = br.readLine();
				if (input.length() > 0) {
					if (input.equals(":quit"))
						break;
					input += "\r";
					out.write(input.getBytes("US-ASCII"));
				}
			}
			port.close();
		} catch (Exception e) {
			System.out.println("Error3: " + e);
		}
	}
	public void serialEvent(SerialPortEvent event) {
		if (event.getEventType() == SerialPortEvent.DATA_AVAILABLE) {
			read();
		}
	}
  }

  ゴ粟