STM32F767とNJL5513Rで遊ぶ(1)
構成
STM32F767
MCP3425A0T-E/CH
NJL5513R
AQM0802A
(1) 室内で ADC直結 6000 or 6062は、約6mV
(2) 太陽に当てる 平均1,054,106は、約1V
q= 1098187
q= 1086875
q= 1066562
q= 1052750
q= 1036500
q= 1021312
q= 1016562
プログラムの説明
16ビットコンバーターを使い約62uVまで測り表示する。
1.SCLとSDAを接続、プルアップも忘れずに
2.電源の接続
3.下記のソースコードを書き込む
4.コンパイル実行で表示されたら終了
5.おわり
その他いろいろ
AFE4404があるらしい
#include "mbed.h"
//10の割り算 0から1028までは、正しい。主に0から999
#define DVI10(n) ((n*205)>>11)
//16ビットadcの4ビットの変換テーブル
#define ADC4BIT { 0 , 62 ,125 ,187 ,250 ,312 ,375 ,437 ,500 ,562 ,625 ,687 ,750 ,812 ,875 ,937 }
//AnalogIn adc_vbat(A3); //PA_4
#define ADDR (0xD0) // address
#define ADDR_LCD (0x7C) // address
I2C i2c(I2C_SDA, I2C_SCL); //767
//I2C i2c(dp5, dp27); //1114
//I2C i2c(PA_10, PA_9); //010
char data_read[8]; //i2cバッファー
char INIT_com[]={0x0,0x38,
0x0,0x39,
0x0,0x4,
0x0,0x14,
0x0,0x70,
0x0,0x56,
0x0,0x6C,
0x0,0x38,
0x0,0xC,
0x0,0x1,
0x40,0x41};
char INIT_cls[]={0x0,0x1};
char ch_hex_a_b[5];
char *ch_hex_a(int l_num)
{
int a,b,c;
b=DVI10(l_num);
c=l_num-(b*10);
l_num=b;
a=DVI10(l_num);
b=l_num-(a*10);
ch_hex_a_b[0] = '@';
ch_hex_a_b[1] = '0' + a;
ch_hex_a_b[2] = '0' + b;
ch_hex_a_b[3] = '0' + c;
ch_hex_a_b[4] = 0;
return(ch_hex_a_b);
}
int ii; //ループカウンタ
int main()
{
printf("767\r\n");
//液晶の初期化
for(ii=0;ii<11;ii++){
i2c.write(ADDR_LCD, &INIT_com[ii*2], 2);wait_ms(2);
} //for
i2c.write(ADDR, "\230", 1); //16bit 15sps PGA x1
int p,s;
// float Volts;
// float Vref = 2.048 ;
int bit4[]=ADC4BIT;
while (1) {
//液晶のクリア
i2c.write(ADDR_LCD,INIT_cls,2);wait_ms(2);
// //adcの読み込み
// s = (adc_vbat.read_u16()>>4);
//
// // (4096*165)/2048=330 電圧の100倍に変換
// //s = 13;
// p = (s*165) >> 11;
//データの読み込み
i2c.read(ADDR | 1, data_read, 2);
s = (data_read[0] * 256 ) + data_read[1];
//s = 32767;
// printf("-s=%d\r\n",s); //767
// printf(" h=%d\r\n",data_read[0]);
// printf(" l=%d\r\n",data_read[1]);
// Volts = s * Vref / 32767.0f ;
// printf(" f=%f\r\n",Volts );
p = ( (s >> 4) * 1000 ) + (bit4[ s & 0xf ]) ;
printf(" q= %d\r\n",p);
//s=(65536/2/2/2)+1;
ii=(s >> 4);
if ( ii >= 2000 ) { ii = ii - 2000; /*printf("2.\n\r");*/ i2c.write(ADDR_LCD,"@2.",3); }
else if( ii >= 1000 ) { ii = ii - 1000; /*printf("1.\n\r");*/ i2c.write(ADDR_LCD,"@1.",3); }
else { /*printf("0.\n\r");*/ i2c.write(ADDR_LCD,"@0.",3); }
//printf(" o=%s\r\n",ch_hex_a( ii ) );
i2c.write(ADDR_LCD, ch_hex_a( ii ) ,4);
//printf(" o=%s\r\n",ch_hex_a( (bit4[ s & 0xf ]) ) );
i2c.write(ADDR_LCD,ch_hex_a( (bit4[ s & 0xf ])) ,4);
// // 32768/(163.84/2)=400 luxに変換
// p=( ((s>>5)*6) + (s>>7) ) >> 4;
// //printf(" p=%d\r\n",p); //767
//
// i2c.write(ADDR_LCD, ch_hex_a( p ) ,4);
wait_ms(1000);
}//while
}//main
//void error(const char* format, ...){}
Author And Source
この問題について(STM32F767とNJL5513Rで遊ぶ(1)), 我々は、より多くの情報をここで見つけました https://qiita.com/caa45040/items/834ded40b8815ece1c5f著者帰属:元の著者の情報は、元のURLに含まれています。著作権は原作者に属する。
Content is automatically searched and collected through network algorithms . If there is a violation . Please contact us . We will adjust (correct author information ,or delete content ) as soon as possible .