arduino:grovebeginnerkit

差分

このページの2つのバージョン間の差分を表示します。

この比較画面へのリンク

両方とも前のリビジョン 前のリビジョン
次のリビジョン
前のリビジョン
arduino:grovebeginnerkit [2021/07/14 10:00] babaarduino:grovebeginnerkit [2023/05/30 11:50] (現在) – [10. 3-Axis Accelerator] baba
行 13: 行 13:
   * [[https://www.amazon.co.jp/studio-Arduino用スターターキット-プログラミング-Beginner-Arduino/dp/B087V1GZP8/ref=asc_df_B087V1GZP8/?tag=jpgo-22&linkCode=df0&hvadid=342760492009&hvpos=&hvnetw=g&hvrand=18120942163922411251&hvpone=&hvptwo=&hvqmt=&hvdev=c&hvdvcmdl=&hvlocint=&hvlocphy=1009301&hvtargid=pla-923831628435&psc=1|amazonリンク]]   * [[https://www.amazon.co.jp/studio-Arduino用スターターキット-プログラミング-Beginner-Arduino/dp/B087V1GZP8/ref=asc_df_B087V1GZP8/?tag=jpgo-22&linkCode=df0&hvadid=342760492009&hvpos=&hvnetw=g&hvrand=18120942163922411251&hvpone=&hvptwo=&hvqmt=&hvdev=c&hvdvcmdl=&hvlocint=&hvlocphy=1009301&hvtargid=pla-923831628435&psc=1|amazonリンク]]
   * [[https://www.switch-science.com/catalog/6361/|switchscienceリンク]]   * [[https://www.switch-science.com/catalog/6361/|switchscienceリンク]]
 +
 +このページでは実際にseeed社が提供しているwikiに従って入門を行った場合に必要な補足すべき情報をまとめておきます.まずは以下の公式リンクから進めていきましょう
 +  * [[https://wiki.seeedstudio.com/Grove-Beginner-Kit-For-Arduino/|Grove Beginner Kit for Arduino Wiki]]
 +
 +===== Groveとは =====
 +Seeed社が昔から販売しているArduinoなどのオープンソースハードウェアで利用可能なセンサモジュールの商品名です.特徴としてはセンサとの接続はGroveコネクタと呼ばれる一般的な4芯の基盤実装コネクタを利用することで,ブレッドボードやはんだ付けを不要としている点です.今回のbeginner kitに含まれるモジュール以外にも多くの種類があります.以下のリンクから現在販売されている種類が確認できます.
 +  * https://jp.seeedstudio.com/category/Grove-c-1003.html
 +
 +国内だとスイッチサイエンスのgroveカテゴリで探すとよいでしょう.
 +  * https://www.switch-science.com/catalog/list/145/
 +
 +===== 入門 =====
 +以下は,grove beginner kit を利用するための超シンプルな導入を記載します.授業ではこちらのページを忘備録としています.
 +{{:arduino:pasted:20230515-231827.png}}
 +
 +==== 1. LED ====
 +<file>
 +void setup() {
 +  pinMode(4, OUTPUT); // 4番ピンを出力モードに
 +}
 +
 +void loop() {
 +  digitalWrite(4, HIGH); // 4番ピンをHIGH(5V)にする
 +  delay(1000); // 1秒待つ
 +  digitalWrite(4, LOW); // 4番ピンをLOW(0V)にする
 +  delay(1000); // 1秒待つ
 +}
 +</file>
 +==== 2. Buzzer ====
 +圧電素子の構造:https://www.matsusada.co.jp/column/whats_piezo.html#:~:text=%E5%9C%A7%E9%9B%BB%E8%A3%85%E7%BD%AE%E3%82%92%E5%88%A9%E7%94%A8%E3%81%97%E3%81%9F,%E3%81%AB%E7%94%A8%E3%81%84%E3%82%89%E3%82%8C%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%E3%80%82
 +<file>
 +// 何ヘルツの音がなっていますか?
 +void setup()
 +{
 +  pinMode(5, OUTPUT);
 +}
 +
 +void loop()
 +{
 +  digitalWrite(5, HIGH);
 +  delay(10);
 +  digitalWrite(5, LOW);
 +  delay(10);
 +}
 +</file>
 +
 +<file>
 +// ド(523Hz),ソ(783Hz)を鳴らすサンプル
 +void setup()
 +{
 +  pinMode(5, OUTPUT);
 +}
 +
 +void loop()
 +{
 +  tone(5, 523, 100);
 +  delay(1000);
 +  tone(5, 783, 100);
 +  delay(1000);
 +}
 +</file>
 +
 +delay()のパラメータを変更することで任意の周波数の波形を出力することができました。ただし、決められた周波数を鳴らすために上記のようなコードを使っていると、たくさんの音を鳴らす場合少し面倒になります。そのため、Arduinoにはtone()関数が用意されています。
 +  * https://www.arduino.cc/reference/en/language/functions/advanced-io/tone/
 +
 +  tone(pin, frequency)
 +  tone(pin, frequency, duration)
 +  
 +1つ目の引数にはスピーカーにつながっている制御ピン番号を。2つ目の引数には鳴らしたい周波数を指定します。もし鳴らす音の長さ(音長)を指定したい場合、3番目の引数にmilli second単位で値を指定します。例えば次のようなコードで二種類の異なる周波数を順番に鳴らすことが簡単にできます。
 +<WRAP center round help 60%>
 +これは有名なドラマで使われていた効果音になります.なんだか分かる人はどのくらいいるでしょうか?
 +</WRAP>
 +
 +<code .c countdown.pde>
 +void setup()
 +{
 +  pinMode(5, OUTPUT);
 +}
 +void loop() {
 +  tone(5, 2217, 70);
 +  delay(1000);
 +  tone(5, 1991, 70);
 +  delay(1000);
 +}
 +</code>
 +
 +<code .c ring.pde>
 +// Reference: http://arms22.blog91.fc2.com/blog-entry-276.html
 +void setup()
 +{
 +  pinMode(5, OUTPUT);
 +}
 +void loop(void)
 +{
 +  tone(5,690,25);
 +  delay(50);
 +
 +  tone(5,690,30);
 +  delay(168);
 +
 +  tone(5,690,23);
 +  delay(48);
 +
 +  tone(5,690,30);
 +  delay(360);
 +
 +
 +  tone(5,970,25);
 +  delay(50);
 +
 +  tone(5,970,30);
 +  delay(50);
 +
 +  tone(5,970,30);
 +  delay(50);
 +
 +  tone(5,970,30);
 +  delay(50);
 +
 +
 +  tone(5,487,30);
 +  delay(55);
 +
 +  tone(5,487,30);
 +  delay(55);
 +
 +  tone(5,487,30);
 +  delay(55);
 +
 +  tone(6,487,30);
 +  delay(55);
 +
 +  tone(5,487,30);
 +  delay(55);
 +
 +  tone(5,487,30);
 +  delay(55);
 +
 +  tone(5,487,30);
 +  delay(55);
 +
 +  tone(5,487,30);
 +  delay(55);
 +
 +  delay(1500);
 +}
 +</code>
 +==== 音階で音を鳴らしてみる ====
 +ON/OFFの感覚を狭くすることで、高い音が、広くすることで低い音がなることが確認できました。また、任意の周波数であればtone()関数を利用して簡単に音を鳴らすことができるのも確認できました。ではこれをもう少しわかりやすく、所謂ドレミファソラシド...といった音程にて再現できるようにしてみましょう。
 +
 +まず最初の周波数と音高の関係ですが、ピアノの真ん中辺りの「ド」の音を鳴らし、一オクターブ上の「ド」を鳴らした場合を考えます。
 +最初に鳴らしたドの周波数を $f_1$とした場合、一オクターブ上のドは $f_2 = 2f_1$として表されます。つまり一オクターブ上の音は下の音の倍の周波数になっているわけです。このような関係をより数学的に表現したものが、十二平均律になります。オクターブ間に12の音程を均等に配置するものです。
 +
 +ベースやギターの開放弦を利用した調律では440Hzを利用しますが、この音を基準(ピアノのラ)として、次の式で表すことで、440Hzのオクターブ上(12音上)は $ 440 \times 2^{\frac{12}{12}} = 880 $となります。
 +
 +\[
 +f = 440 \times 2^{(n/12)}
 +\]
 +
 +ただし基準となる440Hzのラはノート番号では69番としているので、nが69のときに440Hzになるように式を下記のようにしておきます。
 +\[
 +f = 440 \times 2^{\frac{n-69}{12}}
 +\]
 +
 +ではここまでの準備を利用して、有名なNokia Tuneを鳴らしてみましょう。下記サイトを参考にします。
 +  * https://musescore.com/user/29944637/scores/5266155
 +
 +<code .c nokiatune.pde>
 +float getFreq(int n)
 +{
 + return 440.0*pow(2, (n-69)/12.0);
 +}
 +void setup()
 +{
 +  pinMode(6, OUTPUT);
 +}
 +int interval = 250;
 +void loop() {
 +  tone(6, getFreq(76), interval/2);
 +  delay(interval/2);
 +  tone(6, getFreq(74), interval/2);
 +  delay(interval/2);
 +  tone(6, getFreq(66), interval);
 +  delay(interval);
 +  tone(6, getFreq(68), interval);
 +  delay(interval);
 +  tone(6,getFreq(73), interval/2);
 +  delay(interval/2);
 +  tone(6, getFreq(71), interval/2);
 +  delay(interval/2);
 +  tone(6, getFreq(62), interval);
 +  delay(interval);
 +  tone(6, getFreq(64), interval);
 +  delay(interval);
 +  tone(6, getFreq(71), interval/2);
 +  delay(interval/2);
 +  tone(6, getFreq(69), interval/2);
 +  delay(interval/2);
 +  tone(6, getFreq(61), interval);
 +  delay(interval);
 +  tone(6, getFreq(64), interval);
 +  delay(interval);
 +  tone(6, getFreq(69), interval*2);
 +  delay(interval*4);
 +  delay(interval*4);
 +}
 +</code>
 +==== 余談 ====
 +鳴らしたいノート番号を指定することでその周波数を計算することができますが、その逆である「鳴らしたい周波数が決まっている場合、それはピアノの鍵盤でいうところのどの位置になるのか?」を計算するには、方程式をnについてとけば良いです。
 +
 +上記式を両辺に自然対数とることで簡単にnについて解くことができます。みなさんも実際に計算して確かめてみましょう。
 +\[
 + n = \frac{12 \times log_e(\frac{f}{440})}{log_e(2)} + 69
 +\]
 +
 +==== 3. OLED Display 0.96 ====
 +Arduino Library Managerから U8g2 をインストールしてから,以下のコードを実行
 +<file>
 +#include <Arduino.h>
 +#include <U8g2lib.h>
 +
 +#ifdef U8X8_HAVE_HW_SPI
 +#include <SPI.h>
 +#endif
 +#ifdef U8X8_HAVE_HW_I2C
 +#include <Wire.h>
 +#endif
 +
 +
 +U8G2_SSD1306_128X64_NONAME_F_HW_I2C u8g2(U8G2_R0, /* clock=*/ SCL, /* data=*/ SDA, /* reset=*/ U8X8_PIN_NONE);  // High speed I2C
 +
 +// U8G2_SSD1306_128X64_NONAME_F_SW_I2C u8g2(U8G2_R0, /* clock=*/ SCL, /* data=*/ SDA, /* reset=*/ U8X8_PIN_NONE);    //Low spped I2C
 +
 +void setup(void) {
 +  u8g2.begin();
 +}
 +
 +void loop(void) {
 +  u8g2.clearBuffer();                   // clear the internal memory
 +  u8g2.setFont(u8g2_font_ncenB08_tr);   // choose a suitable font
 +  u8g2.drawStr(0,10,"Hello World!");    // write something to the internal memory
 +  u8g2.sendBuffer();                    // transfer internal memory to the display
 +  delay(1000);  
 +}
 +</file>
 +==== 4. Button ====
 +一般にスイッチにはいくつかの種類がありますが,まずは具体的に見てみます. もっとも安価なものに,タクタイルスイッチという部品があります.これは一般的にモーメンタリスイッチ と呼ばれるもので,押している間だけ内部の回路が通電する,というものです.下の回路図で試してみます. 一般的にタクタイルスイッチには電極が4つあります.内部的には単純に通電するかしないかなので,実際には 2本あれば十分です.これはタクタイルスイッチが様々な電子部品で利用される際,マトリクススキャン等の スイッチセンシングにおいて,電極がそれぞれ2つづつあると基盤的に都合が良いことが多いからです.
 +
 +{{:arduino:neat_bombul-allis.png?600|}}
 +
 +<file>
 +void setup()
 +{
 +  pinMode(4, OUTPUT);
 +  pinMode(6, INPUT);
 +}
 +void loop() {
 +  int d = digitalRead(6);
 +  if( d == HIGH){
 +    digitalWrite(4, HIGH);
 +  }
 +  else{
 +    digitalWrite(4, LOW);
 +  }
 +}
 +</file>
 +==== 5. Rotary Potentiometer ====
 +ロータリーポテンショメーターとは回転式可変抵抗器のことを指します.つまみを回すと内部の接触点が代わり抵抗値が変化する部品です.A0ピンに接続されているので,この値を読み出してみます.ここではシリアルモニタ,シリアルプロッタの使い方も学習します.
 +<file>
 +void setup()
 +{
 +  Serial.begin(9600);
 +}
 +void loop() {
 +  int a = analogRead(0);
 +  Serial.println(a);
 +  delay(33);
 +}
 +</file>
 +==== 6. Light ====
 +<file>
 +void setup()
 +{
 +  Serial.begin(9600);
 +}
 +void loop() {
 +  int a = analogRead(6);
 +  Serial.println(a);
 +  delay(33);
 +}
 +</file>
 +==== 7. Sound ====
 +<file>
 +void setup()
 +{
 +  Serial.begin(9600);
 +}
 +void loop() {
 +  int a = analogRead(2);
 +  Serial.println(a);
 +  delay(33);
 +}
 +</file>
 +
 +=== FFT ===
 +<file>
 +#include <arduinoFFT.h>
 +
 +#define SAMPLES 64             // サンプル数(2の累乗数)
 +#define SAMPLING_FREQUENCY 1000 // サンプリング周波数
 +
 +
 +unsigned int sampling_period_us;
 +unsigned long microseconds;
 +
 +double vReal[SAMPLES]; // 複素数の実部
 +double vImag[SAMPLES]; // 複素数の虚部
 +
 +arduinoFFT FFT = arduinoFFT();
 +
 +void setup() {
 +  Serial.begin(9600);
 +  sampling_period_us = round(1000000*(1.0/SAMPLING_FREQUENCY));
 +}
 +
 +void loop() {
 +  /* サンプリング */
 +  for(int i=0; i<SAMPLES; i++) {
 +    microseconds = micros();    // サンプリング開始時間を取得
 +    vReal[i] = analogRead(2);
 +    vImag[i] = 0;
 +    // 次のサンプリング時間まで待つ
 +    while(micros() - microseconds < sampling_period_us){
 +      // wait
 +    }
 +  }
 +
 +  /* FFT */
 +  FFT.Windowing(vReal, SAMPLES, FFT_WIN_TYP_HAMMING, FFT_FORWARD);
 +  FFT.Compute(vReal, vImag, SAMPLES, FFT_FORWARD);
 +  FFT.ComplexToMagnitude(vReal, vImag, SAMPLES);
 +  
 +  double peak = FFT.MajorPeak(vReal, SAMPLES, SAMPLING_FREQUENCY);
 +
 +  /* 結果を出力 */
 +  Serial.println(peak);     
 +
 +  // delay(1000);  // 1秒間隔で解析
 +}
 +
 +</file>
 +
 +==== 8. Temperature & Humidity Sensor ====
 +Grove Temperature And Humidity Sensor
 +<file>
 +//Temperature and Humidity Sensor
 +#include "DHT.h"
 +#include <Arduino.h>
 +#include <U8x8lib.h>
 +
 +#define DHTPIN 3     // what pin we're connected to
 +#define DHTTYPE DHT11   // DHT 11 
 +DHT dht(DHTPIN, DHTTYPE);
 +
 +U8X8_SSD1306_128X64_NONAME_HW_I2C u8x8(/* reset=*/ U8X8_PIN_NONE);
 +
 +void setup(void) {
 +  Serial.begin(9600); 
 +  Serial.println("DHTxx test!");
 +  dht.begin();
 +  u8x8.begin();
 +  u8x8.setPowerSave(0);  
 +  u8x8.setFlipMode(1);
 +}
 +
 +void loop(void) {
 +
 +  float temp, humi;
 +  temp = dht.readTemperature();
 +  humi = dht.readHumidity();
 +  
 +  u8x8.setFont(u8x8_font_chroma48medium8_r);
 +  u8x8.setCursor(0, 33);
 +  u8x8.print("Temp:");
 +  u8x8.print(temp);
 +  u8x8.print("C");
 +  u8x8.setCursor(0,50);
 +  u8x8.print("Humidity:");
 +  u8x8.print(humi);
 +  u8x8.print("%");
 +  u8x8.refreshDisplay();
 +  delay(200);
 +}
 +</file>
 +==== 9. Air Pressure Sensor ====
 +Barometer Sensor BMP280 を追加する
 +<file>
 +//Air pressure detection
 +#include "Seeed_BMP280.h"
 +#include <Wire.h>
 +
 +BMP280 bmp280;
 +
 +void setup() {
 +    Serial.begin(9600);
 +    if (!bmp280.init()) {
 +        Serial.println("Device not connected or broken!");
 +    }
 +}
 +
 +void loop() {
 +
 +    float pressure;
 +
 +    //get and print temperatures
 +    Serial.print("Temp: ");
 +    Serial.print(bmp280.getTemperature());
 +    Serial.println("C"); // The unit for  Celsius because original arduino don't support speical symbols
 +
 +    //get and print atmospheric pressure data
 +    Serial.print("Pressure: ");
 +    Serial.print(pressure = bmp280.getPressure());
 +    Serial.println("Pa");
 +
 +    //get and print altitude data
 +    Serial.print("Altitude: ");
 +    Serial.print(bmp280.calcAltitude(pressure));
 +    Serial.println("m");
 +
 +    Serial.println("\n");//add a line between output of different times.
 +
 +    delay(1000);
 +}
 +</file>
 +==== 10. 3-Axis Accelerator ====
 +grove-3-axis-digital-accelerometer-2g-to-16g を追加
 +<file>
 +//Gravity Acceleration
 +#include "LIS3DHTR.h"
 +#ifdef SOFTWAREWIRE
 +    #include <SoftwareWire.h>
 +    SoftwareWire myWire(3, 2);
 +    LIS3DHTR<SoftwareWire> LIS;       //Software I2C
 +    #define WIRE myWire
 +#else
 +    #include <Wire.h>
 +    LIS3DHTR<TwoWire> LIS;           //Hardware I2C
 +    #define WIRE Wire
 +#endif
 +
 +void setup() {
 +    Serial.begin(9600);
 +    while (!Serial) {};
 +    LIS.begin(WIRE, 0x19); //IIC init
 +    delay(100);
 +    LIS.setOutputDataRate(LIS3DHTR_DATARATE_50HZ);
 +}
 +void loop() {
 +    if (!LIS) {
 +        Serial.println("LIS3DHTR didn't connect.");
 +        while (1);
 +        return;
 +    }
 +    //3 axis
 +    Serial.print("x:"); Serial.print(LIS.getAccelerationX()); Serial.print("  ");
 +    Serial.print("y:"); Serial.print(LIS.getAccelerationY()); Serial.print("  ");
 +    Serial.print("z:"); Serial.println(LIS.getAccelerationZ());
 +
 +    delay(500);
 +}
 +</file>
 +
 +
 +
 +
 +
 +
 +
 +
 +
 +
  
  • /home/users/2/lolipop.jp-4404d470cd64c603/web/ws/data/attic/arduino/grovebeginnerkit.1626224419.txt.gz
  • 最終更新: 2021/07/14 10:00
  • by baba