前提・実現したいこと
初めて質問します。C++やVSCode等初心者ですので、初歩的なミスによる動作不良かもしれませんがご了承ください。
Win10のPCにて、VSCodeでPlatform IOによりBME280のセンサを動かそうとしていますが、
エラーでビルドができません。
発生している問題・エラーメッセージ
{
"resource": "/c:/Users/takum/Documents/PlatformIO/Projects/BME280_SwitchScience/src/main.cpp",
"owner": "C/C++",
"severity": 8,
"message": "識別子 "Serial" が定義されていません",
"startLineNumber": 40,
"startColumn": 5,
"endLineNumber": 40,
"endColumn": 11
}
該当のソースコード
C++
1#include <Wire.h> 2 3#define BME280_ADDRESS 0x76 4unsigned long int hum_raw,temp_raw,pres_raw; 5signed long int t_fine; 6 7uint16_t dig_T1; 8 int16_t dig_T2; 9 int16_t dig_T3; 10uint16_t dig_P1; 11 int16_t dig_P2; 12 int16_t dig_P3; 13 int16_t dig_P4; 14 int16_t dig_P5; 15 int16_t dig_P6; 16 int16_t dig_P7; 17 int16_t dig_P8; 18 int16_t dig_P9; 19 int8_t dig_H1; 20 int16_t dig_H2; 21 int8_t dig_H3; 22 int16_t dig_H4; 23 int16_t dig_H5; 24 int8_t dig_H6; 25 26void setup() 27{ 28 uint8_t osrs_t = 1; //Temperature oversampling x 1 29 uint8_t osrs_p = 1; //Pressure oversampling x 1 30 uint8_t osrs_h = 1; //Humidity oversampling x 1 31 uint8_t mode = 3; //Normal mode 32 uint8_t t_sb = 5; //Tstandby 1000ms 33 uint8_t filter = 0; //Filter off 34 uint8_t spi3w_en = 0; //3-wire SPI Disable 35 36 uint8_t ctrl_meas_reg = (osrs_t << 5) | (osrs_p << 2) | mode; 37 uint8_t config_reg = (t_sb << 5) | (filter << 2) | spi3w_en; 38 uint8_t ctrl_hum_reg = osrs_h; 39 40 Serial.begin(9600); 41 Wire.begin(); 42 43 writeReg(0xF2,ctrl_hum_reg); 44 writeReg(0xF4,ctrl_meas_reg); 45 writeReg(0xF5,config_reg); 46 readTrim(); // 47} 48 49 50void loop() 51{ 52 double temp_act = 0.0, press_act = 0.0,hum_act=0.0; 53 signed long int temp_cal; 54 unsigned long int press_cal,hum_cal; 55 56 readData(); 57 58 temp_cal = calibration_T(temp_raw); 59 press_cal = calibration_P(pres_raw); 60 hum_cal = calibration_H(hum_raw); 61 temp_act = (double)temp_cal / 100.0; 62 press_act = (double)press_cal / 100.0; 63 hum_act = (double)hum_cal / 1024.0; 64 Serial.print("TEMP : "); 65 Serial.print(temp_act); 66 Serial.print(" DegC PRESS : "); 67 Serial.print(press_act); 68 Serial.print(" hPa HUM : "); 69 Serial.print(hum_act); 70 Serial.println(" %"); 71 72 delay(1000); 73} 74void readTrim() 75{ 76 uint8_t data[32],i=0; 77 Wire.beginTransmission(BME280_ADDRESS); 78 Wire.write(0x88); 79 Wire.endTransmission(); 80 Wire.requestFrom(BME280_ADDRESS,24); 81 while(Wire.available()){ 82 data[i] = Wire.read(); 83 i++; 84 } 85 86 Wire.beginTransmission(BME280_ADDRESS); 87 Wire.write(0xA1); 88 Wire.endTransmission(); 89 Wire.requestFrom(BME280_ADDRESS,1); 90 data[i] = Wire.read(); 91 i++; 92 93 Wire.beginTransmission(BME280_ADDRESS); 94 Wire.write(0xE1); 95 Wire.endTransmission(); 96 Wire.requestFrom(BME280_ADDRESS,7); 97 while(Wire.available()){ 98 data[i] = Wire.read(); 99 i++; 100 } 101 dig_T1 = (data[1] << 8) | data[0]; 102 dig_T2 = (data[3] << 8) | data[2]; 103 dig_T3 = (data[5] << 8) | data[4]; 104 dig_P1 = (data[7] << 8) | data[6]; 105 dig_P2 = (data[9] << 8) | data[8]; 106 dig_P3 = (data[11]<< 8) | data[10]; 107 dig_P4 = (data[13]<< 8) | data[12]; 108 dig_P5 = (data[15]<< 8) | data[14]; 109 dig_P6 = (data[17]<< 8) | data[16]; 110 dig_P7 = (data[19]<< 8) | data[18]; 111 dig_P8 = (data[21]<< 8) | data[20]; 112 dig_P9 = (data[23]<< 8) | data[22]; 113 dig_H1 = data[24]; 114 dig_H2 = (data[26]<< 8) | data[25]; 115 dig_H3 = data[27]; 116 dig_H4 = (data[28]<< 4) | (0x0F & data[29]); 117 dig_H5 = (data[30] << 4) | ((data[29] >> 4) & 0x0F); 118 dig_H6 = data[31]; 119} 120void writeReg(uint8_t reg_address, uint8_t data) 121{ 122 Wire.beginTransmission(BME280_ADDRESS); 123 Wire.write(reg_address); 124 Wire.write(data); 125 Wire.endTransmission(); 126} 127 128 129void readData() 130{ 131 int i = 0; 132 uint32_t data[8]; 133 Wire.beginTransmission(BME280_ADDRESS); 134 Wire.write(0xF7); 135 Wire.endTransmission(); 136 Wire.requestFrom(BME280_ADDRESS,8); 137 while(Wire.available()){ 138 data[i] = Wire.read(); 139 i++; 140 } 141 pres_raw = (data[0] << 12) | (data[1] << 4) | (data[2] >> 4); 142 temp_raw = (data[3] << 12) | (data[4] << 4) | (data[5] >> 4); 143 hum_raw = (data[6] << 8) | data[7]; 144} 145 146 147signed long int calibration_T(signed long int adc_T) 148{ 149 150 signed long int var1, var2, T; 151 var1 = ((((adc_T >> 3) - ((signed long int)dig_T1<<1))) * ((signed long int)dig_T2)) >> 11; 152 var2 = (((((adc_T >> 4) - ((signed long int)dig_T1)) * ((adc_T>>4) - ((signed long int)dig_T1))) >> 12) * ((signed long int)dig_T3)) >> 14; 153 154 t_fine = var1 + var2; 155 T = (t_fine * 5 + 128) >> 8; 156 return T; 157} 158 159unsigned long int calibration_P(signed long int adc_P) 160{ 161 signed long int var1, var2; 162 unsigned long int P; 163 var1 = (((signed long int)t_fine)>>1) - (signed long int)64000; 164 var2 = (((var1>>2) * (var1>>2)) >> 11) * ((signed long int)dig_P6); 165 var2 = var2 + ((var1*((signed long int)dig_P5))<<1); 166 var2 = (var2>>2)+(((signed long int)dig_P4)<<16); 167 var1 = (((dig_P3 * (((var1>>2)*(var1>>2)) >> 13)) >>3) + ((((signed long int)dig_P2) * var1)>>1))>>18; 168 var1 = ((((32768+var1))*((signed long int)dig_P1))>>15); 169 if (var1 == 0) 170 { 171 return 0; 172 } 173 P = (((unsigned long int)(((signed long int)1048576)-adc_P)-(var2>>12)))*3125; 174 if(P<0x80000000) 175 { 176 P = (P << 1) / ((unsigned long int) var1); 177 } 178 else 179 { 180 P = (P / (unsigned long int)var1) * 2; 181 } 182 var1 = (((signed long int)dig_P9) * ((signed long int)(((P>>3) * (P>>3))>>13)))>>12; 183 var2 = (((signed long int)(P>>2)) * ((signed long int)dig_P8))>>13; 184 P = (unsigned long int)((signed long int)P + ((var1 + var2 + dig_P7) >> 4)); 185 return P; 186} 187 188unsigned long int calibration_H(signed long int adc_H) 189{ 190 signed long int v_x1; 191 192 v_x1 = (t_fine - ((signed long int)76800)); 193 v_x1 = (((((adc_H << 14) -(((signed long int)dig_H4) << 20) - (((signed long int)dig_H5) * v_x1)) + 194 ((signed long int)16384)) >> 15) * (((((((v_x1 * ((signed long int)dig_H6)) >> 10) * 195 (((v_x1 * ((signed long int)dig_H3)) >> 11) + ((signed long int) 32768))) >> 10) + (( signed long int)2097152)) * 196 ((signed long int) dig_H2) + 8192) >> 14)); 197 v_x1 = (v_x1 - (((((v_x1 >> 15) * (v_x1 >> 15)) >> 7) * ((signed long int)dig_H1)) >> 4)); 198 v_x1 = (v_x1 < 0 ? 0 : v_x1); 199 v_x1 = (v_x1 > 419430400 ? 419430400 : v_x1); 200 return (unsigned long int)(v_x1 >> 12); 201} 202
試したこと
いろいろ検索してみましたが、有効な対処法を見つけることができませんでした。