ILF / Mbed 2 deprecated mbed_ILF

Dependencies:   mbed SDFileSystem

Committer:
Kujira
Date:
Tue Jan 18 07:54:54 2022 +0000
Revision:
0:1977c2310ef7
Child:
1:f6a9410c46d2
ver1.2.3 debug mode

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Kujira 0:1977c2310ef7 1 #include "mbed.h"
Kujira 0:1977c2310ef7 2 #include "SDFileSystem.h"
Kujira 0:1977c2310ef7 3 //#include "MODSERIAL.h"
Kujira 0:1977c2310ef7 4
Kujira 0:1977c2310ef7 5 //difine_mbed_LPC1768
Kujira 0:1977c2310ef7 6
Kujira 0:1977c2310ef7 7 /*******************************************************************************
Kujira 0:1977c2310ef7 8
Kujira 0:1977c2310ef7 9 2018.8.31
Kujira 0:1977c2310ef7 10 ILF Iop汎用器
Kujira 0:1977c2310ef7 11
Kujira 0:1977c2310ef7 12 仕様
Kujira 0:1977c2310ef7 13 電圧/抵抗測定:12bit
Kujira 0:1977c2310ef7 14 電流測定:14bit
Kujira 0:1977c2310ef7 15
Kujira 0:1977c2310ef7 16 割込みはP0~P2で可能
Kujira 0:1977c2310ef7 17 シーケンサスタート信号は、回路図「seq_yobi]で対応
Kujira 0:1977c2310ef7 18
Kujira 0:1977c2310ef7 19 ver1.2.3
Kujira 0:1977c2310ef7 20 EEPROM通信のコードを修正。
Kujira 0:1977c2310ef7 21 debug mode の追加
Kujira 0:1977c2310ef7 22
Kujira 0:1977c2310ef7 23 ver1.2.2
Kujira 0:1977c2310ef7 24 過充電防止検査の上限規格の判定追加
Kujira 0:1977c2310ef7 25 CAL情報登録画面において、登録項目の順序入替え(過充電防止上限規格の挿入)
Kujira 0:1977c2310ef7 26 過充電防止上限規格ゼロの場合、判定しない
Kujira 0:1977c2310ef7 27
Kujira 0:1977c2310ef7 28 ver1.2.1
Kujira 0:1977c2310ef7 29 過充電防止検査の上限規格を新たに設置。
Kujira 0:1977c2310ef7 30 それに伴い、規格値のメモリ割り当てと、上限規格設定画面を追加。
Kujira 0:1977c2310ef7 31
Kujira 0:1977c2310ef7 32 ver1.2.0
Kujira 0:1977c2310ef7 33
Kujira 0:1977c2310ef7 34 2021.9.7
Kujira 0:1977c2310ef7 35
Kujira 0:1977c2310ef7 36 CAL.LJ21(A1098A05)専用
Kujira 0:1977c2310ef7 37 発電検出時、高照度条件下でVSS電圧がIC耐圧超える為、VHD-VDD短絡する仕様へ変更(A05)
Kujira 0:1977c2310ef7 38 200lx下でもVHD-VDD短絡の電圧条件を満たす為、ILFも対応。
Kujira 0:1977c2310ef7 39 VSS端子でVOC測定をする。その為、VOC測定時以外はVSS端子と測定器を切り離すリレーを
Kujira 0:1977c2310ef7 40 サブ基板へ取り付け、制御プログラムを追加した。
Kujira 0:1977c2310ef7 41 CH1:P1_23(LPC1768) (led3_on)
Kujira 0:1977c2310ef7 42 CH2:P1_22(LPC1768) (led3_off)
Kujira 0:1977c2310ef7 43
Kujira 0:1977c2310ef7 44 アンテナ測定時にアンテナ測定端子切り離し用リレーのON/OFF制御を追加
Kujira 0:1977c2310ef7 45 (led4_on)
Kujira 0:1977c2310ef7 46 (led4_off)
Kujira 0:1977c2310ef7 47
Kujira 0:1977c2310ef7 48 ver1.1.0
Kujira 0:1977c2310ef7 49 1)VFD_SW23 SW31がタッチ感度故障の為、配置替え
Kujira 0:1977c2310ef7 50 CAL登録画面とMANUAL測定画面
Kujira 0:1977c2310ef7 51 2)DELETE EEPROM ボタンの配置変更
Kujira 0:1977c2310ef7 52 3)シーケンサ判定IOの変更
Kujira 0:1977c2310ef7 53
Kujira 0:1977c2310ef7 54 ver1.1.1
Kujira 0:1977c2310ef7 55 void auto_meas において初期 R[i]の値をクリアすることを追加
Kujira 0:1977c2310ef7 56 自動測定時、タッチパネルでスタートをやめる(外部IO入力のみ)
Kujira 0:1977c2310ef7 57
Kujira 0:1977c2310ef7 58 ver1.1.2
Kujira 0:1977c2310ef7 59 過充電防止検査時の電源電圧:VOC検査時の電圧となっていたのを修正。
Kujira 0:1977c2310ef7 60
Kujira 0:1977c2310ef7 61 ver1.1.3
Kujira 0:1977c2310ef7 62 1)SDカード未挿入の表示を削除
Kujira 0:1977c2310ef7 63
Kujira 0:1977c2310ef7 64 2)R=Hの時間を0.2sから1sへ変更
Kujira 0:1977c2310ef7 65
Kujira 0:1977c2310ef7 66 R5186 ver2.0.3の内容を反映。
Kujira 0:1977c2310ef7 67
Kujira 0:1977c2310ef7 68 未)フラグでR5186系と切替え
Kujira 0:1977c2310ef7 69 未)測定部ごとにクラス分け(過充電防止のところだけでも)
Kujira 0:1977c2310ef7 70
Kujira 0:1977c2310ef7 71 *******************************************************************************/
Kujira 0:1977c2310ef7 72 //
Kujira 0:1977c2310ef7 73 //各種定数
Kujira 0:1977c2310ef7 74 #define DEB_EN 1 //デバッグイネーブル
Kujira 0:1977c2310ef7 75 #define RL_EN 1 //1:io[]を外付けのリードリレー制御用に使用する場合は1.以外は0. ver1.2.3
Kujira 0:1977c2310ef7 76 #define SEQ_EN 0 //1:シーケンサ接続仕様 0:シーケンサ未接続仕様
Kujira 0:1977c2310ef7 77 #define period_pwm 200 //*us
Kujira 0:1977c2310ef7 78 #define COP 0.005 //pwm_duty(%) = COP * DATA(0~255)
Kujira 0:1977c2310ef7 79 #define rsense 1000 //抵抗測定回路のプルアップ抵抗値 1kΩ
Kujira 0:1977c2310ef7 80 #define res_vref 0x800 //抵抗測定回路のリファレンス電圧 2.048V
Kujira 0:1977c2310ef7 81 #define dac_vref 2500 //DACのリファレンス電圧 単位[mV]
Kujira 0:1977c2310ef7 82 #define number_of_channels 2 //測定チャンネル数(MAX 4)
Kujira 0:1977c2310ef7 83 #define time_discharge 0.5 //discharging time(s)
Kujira 0:1977c2310ef7 84 #define time_integral 2 //integral time(s)
Kujira 0:1977c2310ef7 85 #define touch 5 //GU-D タッチパネル感度 0~7で設定。低いほど敏感。
Kujira 0:1977c2310ef7 86 #define wait_voc 0.5 //[s]VOC測定電圧設定後からリセットまでの時間
Kujira 0:1977c2310ef7 87 #define wait_reset 0.3 //[s]リセット解除からVOC測定までの時間
Kujira 0:1977c2310ef7 88 #define wait_poweron 4 //[s]電源投入からリセットまでの時間
Kujira 0:1977c2310ef7 89 #define time_reset 0.5 //reset Hの時間 ver1.1.3
Kujira 0:1977c2310ef7 90 #define TIME_RELAY_ON 0.5 //外付けリードリレー用 Ton[s]
Kujira 0:1977c2310ef7 91 #define TIME_RELAY_OFF 0.2 //外付けリードリレー用 Toff[s]
Kujira 0:1977c2310ef7 92
Kujira 0:1977c2310ef7 93 /***************************************
Kujira 0:1977c2310ef7 94 RESOLUTION SETTINGS VS. LSB
Kujira 0:1977c2310ef7 95 -----------------------------------
Kujira 0:1977c2310ef7 96 |Resolution Setting | LSB |
Kujira 0:1977c2310ef7 97 -----------------------------------
Kujira 0:1977c2310ef7 98 | 12bits(00) | 1mv |
Kujira 0:1977c2310ef7 99 | 14bits(01) | 250uV |
Kujira 0:1977c2310ef7 100 | 16bits(10) | 62.5uV |
Kujira 0:1977c2310ef7 101 | 18bits(11) | 15.625uV |
Kujira 0:1977c2310ef7 102 -----------------------------------
Kujira 0:1977c2310ef7 103 ****************************************/
Kujira 0:1977c2310ef7 104 //ver1.2.0
Kujira 0:1977c2310ef7 105 const int version_major = 1; //ソフトバージョン
Kujira 0:1977c2310ef7 106 const int version_minor = 2; //ソフトバージョン
Kujira 0:1977c2310ef7 107 const int version_build = 3; //ソフトバージョン
Kujira 0:1977c2310ef7 108
Kujira 0:1977c2310ef7 109 //
Kujira 0:1977c2310ef7 110 //繰り返しタイマー割り込み
Kujira 0:1977c2310ef7 111 Ticker flipper; /* 初期化 */
Kujira 0:1977c2310ef7 112 //one shot timer
Kujira 0:1977c2310ef7 113 Timeout oneshot1;
Kujira 0:1977c2310ef7 114 Timeout oneshot2;
Kujira 0:1977c2310ef7 115 Timeout oneshot3;
Kujira 0:1977c2310ef7 116 Timeout oneshot4;
Kujira 0:1977c2310ef7 117 //
Kujira 0:1977c2310ef7 118 //SD-CARD
Kujira 0:1977c2310ef7 119 SDFileSystem sd(P0_9, P0_8, P0_7, P0_6, "sd"); //SDFileSystem name(mosi, miso, sck, cs, mount);
Kujira 0:1977c2310ef7 120 //
Kujira 0:1977c2310ef7 121 //interruput
Kujira 0:1977c2310ef7 122 InterruptIn seq_yobi(P0_19);
Kujira 0:1977c2310ef7 123 //
Kujira 0:1977c2310ef7 124 //start sw
Kujira 0:1977c2310ef7 125 DigitalIn sw_start(P0_4);
Kujira 0:1977c2310ef7 126 //
Kujira 0:1977c2310ef7 127 //DigitalOut
Kujira 0:1977c2310ef7 128 DigitalOut houden[] = { // 配列を用意します
Kujira 0:1977c2310ef7 129 DigitalOut( P2_1 ), //houden1 配列の1番目の要素を**で初期化したDigitalOutに
Kujira 0:1977c2310ef7 130 DigitalOut( P2_0 ), //houden2
Kujira 0:1977c2310ef7 131 DigitalOut( P1_28 ), //houden3
Kujira 0:1977c2310ef7 132 DigitalOut( P1_29 ) //houden4
Kujira 0:1977c2310ef7 133 };
Kujira 0:1977c2310ef7 134
Kujira 0:1977c2310ef7 135 DigitalOut io[] = { // 配列を用意します
Kujira 0:1977c2310ef7 136 DigitalOut( P0_25 ), //io1 配列の1番目の要素をP0_25で初期化したDigitalOutに
Kujira 0:1977c2310ef7 137 DigitalOut( P0_26 ), //io2
Kujira 0:1977c2310ef7 138 DigitalOut( P0_23 ), //io3
Kujira 0:1977c2310ef7 139 DigitalOut( P0_24 ), //io4
Kujira 0:1977c2310ef7 140 DigitalOut( P1_22 ), //io5
Kujira 0:1977c2310ef7 141 DigitalOut( P1_23 ), //io6
Kujira 0:1977c2310ef7 142 DigitalOut( P1_24 ), //io7
Kujira 0:1977c2310ef7 143 DigitalOut( P1_25 ) //io8
Kujira 0:1977c2310ef7 144 };
Kujira 0:1977c2310ef7 145
Kujira 0:1977c2310ef7 146 DigitalOut range[] = { // 配列を用意します
Kujira 0:1977c2310ef7 147 DigitalOut( P2_3 ), //range1 配列の1番目の要素を**で初期化したDigitalOutに
Kujira 0:1977c2310ef7 148 DigitalOut( P2_2 ), //range2
Kujira 0:1977c2310ef7 149 DigitalOut( P1_26 ), //range3
Kujira 0:1977c2310ef7 150 DigitalOut( P1_27 ) //range4
Kujira 0:1977c2310ef7 151 };
Kujira 0:1977c2310ef7 152
Kujira 0:1977c2310ef7 153 /*
Kujira 0:1977c2310ef7 154 DigitalOut led1_green(P0_17);
Kujira 0:1977c2310ef7 155 DigitalOut led2_green(P1_31);
Kujira 0:1977c2310ef7 156 DigitalOut led1_red(P0_18);
Kujira 0:1977c2310ef7 157 DigitalOut led2_red(P1_30);
Kujira 0:1977c2310ef7 158 */
Kujira 0:1977c2310ef7 159
Kujira 0:1977c2310ef7 160 DigitalOut led_green[] = {
Kujira 0:1977c2310ef7 161 DigitalOut( P0_17 ),
Kujira 0:1977c2310ef7 162 DigitalOut( P1_31 ),
Kujira 0:1977c2310ef7 163 DigitalOut( P2_11 ),
Kujira 0:1977c2310ef7 164 DigitalOut( P1_18 )
Kujira 0:1977c2310ef7 165 };
Kujira 0:1977c2310ef7 166
Kujira 0:1977c2310ef7 167 DigitalOut led_red[] = {
Kujira 0:1977c2310ef7 168 DigitalOut( P0_18 ),
Kujira 0:1977c2310ef7 169 DigitalOut( P1_30 ),
Kujira 0:1977c2310ef7 170 DigitalOut( P2_12 ),
Kujira 0:1977c2310ef7 171 DigitalOut( P1_19 )
Kujira 0:1977c2310ef7 172 };
Kujira 0:1977c2310ef7 173 //ver1.1.0
Kujira 0:1977c2310ef7 174 DigitalOut seq_hantei[] = {
Kujira 0:1977c2310ef7 175 DigitalOut( P0_21 ),
Kujira 0:1977c2310ef7 176 DigitalOut( P0_22 ),
Kujira 0:1977c2310ef7 177 DigitalOut( P3_25 ),
Kujira 0:1977c2310ef7 178 DigitalOut( P3_26 )
Kujira 0:1977c2310ef7 179 };
Kujira 0:1977c2310ef7 180
Kujira 0:1977c2310ef7 181 DigitalOut seq_busy(P0_20);
Kujira 0:1977c2310ef7 182 //DigitalIn
Kujira 0:1977c2310ef7 183 DigitalIn seq_start(P4_28);
Kujira 0:1977c2310ef7 184 DigitalIn seq_cal_a(P2_6);
Kujira 0:1977c2310ef7 185 DigitalIn seq_cal_b(P2_7);
Kujira 0:1977c2310ef7 186 DigitalIn seq_cal_c(P2_8);
Kujira 0:1977c2310ef7 187 DigitalIn seq_kosuu_a(P2_13);
Kujira 0:1977c2310ef7 188 DigitalIn seq_kosuu_b(P2_9);
Kujira 0:1977c2310ef7 189 //DigitalIn seq_yobi(P0_19);
Kujira 0:1977c2310ef7 190
Kujira 0:1977c2310ef7 191 //
Kujira 0:1977c2310ef7 192 //PWM
Kujira 0:1977c2310ef7 193 PwmOut leds[] = { //配列を用意
Kujira 0:1977c2310ef7 194 PwmOut(P2_5), //LED1
Kujira 0:1977c2310ef7 195 PwmOut(P2_4), //LED2
Kujira 0:1977c2310ef7 196 PwmOut(P1_21), //LED3
Kujira 0:1977c2310ef7 197 PwmOut(P1_20) //LED4
Kujira 0:1977c2310ef7 198 };
Kujira 0:1977c2310ef7 199
Kujira 0:1977c2310ef7 200 //
Kujira 0:1977c2310ef7 201 //I2C
Kujira 0:1977c2310ef7 202 I2C i2c(P0_10,P0_11); //(PinName sda, PinName scl) I2Cを定義
Kujira 0:1977c2310ef7 203 //
Kujira 0:1977c2310ef7 204 /******************:
Kujira 0:1977c2310ef7 205 SD Card
Kujira 0:1977c2310ef7 206 *******************/
Kujira 0:1977c2310ef7 207 void sd_writetext(char* text);
Kujira 0:1977c2310ef7 208 /******************:
Kujira 0:1977c2310ef7 209 gu-D(表示器) addr:50H
Kujira 0:1977c2310ef7 210 *******************/
Kujira 0:1977c2310ef7 211 //parameter_gu256X128C-D903M
Kujira 0:1977c2310ef7 212 const int addr_gu = 0x50 << 1; // Address of gu256X128C-D903M
Kujira 0:1977c2310ef7 213 //
Kujira 0:1977c2310ef7 214 //prototype
Kujira 0:1977c2310ef7 215 const int Proportional1 = 0x02;
Kujira 0:1977c2310ef7 216 //const int Proportional2 = 0x03;
Kujira 0:1977c2310ef7 217 //const int Proportional3 = 0x04;
Kujira 0:1977c2310ef7 218 //
Kujira 0:1977c2310ef7 219 void gu_cls();
Kujira 0:1977c2310ef7 220 void gu_drawButton(int x, int y, int w, int h, const char *data);
Kujira 0:1977c2310ef7 221 void gu_cursor(int x, int y);
Kujira 0:1977c2310ef7 222 void gu_fontsize(const char code);
Kujira 0:1977c2310ef7 223 void gu_print_dot(int x, int y, const char *ptext);
Kujira 0:1977c2310ef7 224 void gu_fontWidth(const char fontWidth);
Kujira 0:1977c2310ef7 225 void gu_print(const char t[] );
Kujira 0:1977c2310ef7 226 void gu_fontReverse(int code);
Kujira 0:1977c2310ef7 227 void gu_RealTimeImage_dot(int x, int y, int w, int h, const char data[]);
Kujira 0:1977c2310ef7 228 void gu_RealTimeImage(int w, int h, char data[]);
Kujira 0:1977c2310ef7 229 void gu_magnify(int x, int y);
Kujira 0:1977c2310ef7 230 //
Kujira 0:1977c2310ef7 231 //オリジナルgu用関数
Kujira 0:1977c2310ef7 232 void gu_print1(const char* ptext);
Kujira 0:1977c2310ef7 233 void gu_luminance(const char* cl);
Kujira 0:1977c2310ef7 234 void gu_touchPara(int x,int y);
Kujira 0:1977c2310ef7 235 void gu_sendOneByte(char data);
Kujira 0:1977c2310ef7 236 void utility(); //輝度調整サブルーチン
Kujira 0:1977c2310ef7 237 void gu_CRLF();
Kujira 0:1977c2310ef7 238 void gu_reverse(char x);
Kujira 0:1977c2310ef7 239 void gu_drawbutton_cursor(char x,char y);
Kujira 0:1977c2310ef7 240 void gu_onebyte(char data);
Kujira 0:1977c2310ef7 241 //
Kujira 0:1977c2310ef7 242 //Button Trig Function
Kujira 0:1977c2310ef7 243 void adjust_illumination();//LED輝度調整サブ
Kujira 0:1977c2310ef7 244 void gu_initial();//初期設定サブ
Kujira 0:1977c2310ef7 245 void gu_set_button(char sw_num,char* text);//SWナンバーと表示テキストを指定
Kujira 0:1977c2310ef7 246 void gu_set_button_font1(char sw_num,char* text);//fontsize = 1
Kujira 0:1977c2310ef7 247 void gu_button_up(char sw_num); //upボタン表示
Kujira 0:1977c2310ef7 248 void gu_button_down(char sw_num);//downボタン表示
Kujira 0:1977c2310ef7 249 void gu_Button_up1();
Kujira 0:1977c2310ef7 250 void gu_Button_up2();
Kujira 0:1977c2310ef7 251 void gu_Button_up3();
Kujira 0:1977c2310ef7 252 void gu_Button_up4();
Kujira 0:1977c2310ef7 253 void gu_button_up_on(char sw_num);
Kujira 0:1977c2310ef7 254 void gu_Button_up_on2();
Kujira 0:1977c2310ef7 255 void gu_Button_down1();
Kujira 0:1977c2310ef7 256 void gu_Button_down2();
Kujira 0:1977c2310ef7 257 void gu_Button_down3();
Kujira 0:1977c2310ef7 258 void gu_Button_down4();
Kujira 0:1977c2310ef7 259 void gu_button_down_on(char sw_num);
Kujira 0:1977c2310ef7 260 void gu_Button_down_on2();
Kujira 0:1977c2310ef7 261 void gu_Button_power_on();
Kujira 0:1977c2310ef7 262 void gu_Button_power_off();
Kujira 0:1977c2310ef7 263
Kujira 0:1977c2310ef7 264 /***************************
Kujira 0:1977c2310ef7 265 LCP1768(EEPROM) addr:15H
Kujira 0:1977c2310ef7 266 ***************************/
Kujira 0:1977c2310ef7 267 //parameter_PCAS08A(EEPROM)
Kujira 0:1977c2310ef7 268 //const int addr_EEPROM = 0x15 << 3; // Address of PCAS08A(EEPROM) コメント化 ver1.2.1
Kujira 0:1977c2310ef7 269 char rdata[17]; //EEPROMからのリードデータ
Kujira 0:1977c2310ef7 270 char wdata[17]; //EEPROMへのライトデータ
Kujira 0:1977c2310ef7 271 int Jyushin; //受信成功時 Jyushin=0
Kujira 0:1977c2310ef7 272 int Soushin; //送信成功時 Soushin=0
Kujira 0:1977c2310ef7 273 const int fixed_adrs = 0x15 << 3; // Address of PCAS08A(EEPROM) 始めの5bit ver1.2.1
Kujira 0:1977c2310ef7 274 int adrs_eeprom; //slave address ver1.2.1
Kujira 0:1977c2310ef7 275 /***************************
Kujira 0:1977c2310ef7 276 MCP3424(ADC)
Kujira 0:1977c2310ef7 277 ***************************/
Kujira 0:1977c2310ef7 278 //parameter_ADC(MCP3424)
Kujira 0:1977c2310ef7 279 const int addr_ADC1 = 0x6C <<1;//電圧抵抗測定No.1,No.2用ADC
Kujira 0:1977c2310ef7 280 const int addr_ADC2 = 0x6A <<1;//電圧抵抗測定No.3,No.4用ADC
Kujira 0:1977c2310ef7 281 const int addr_ADC3 = 0x68 <<1;//電流測定No.1,No.2
Kujira 0:1977c2310ef7 282 const int addr_ADC4 = 0x6E <<1;//電流測定No.3,No.4
Kujira 0:1977c2310ef7 283 //
Kujira 0:1977c2310ef7 284 char hd[] = "0123456789ABCDEF" ;
Kujira 0:1977c2310ef7 285 //
Kujira 0:1977c2310ef7 286 //関数
Kujira 0:1977c2310ef7 287 void general_call(char com); //power on reset
Kujira 0:1977c2310ef7 288 char adc_config(char ch, char rate);
Kujira 0:1977c2310ef7 289 //
Kujira 0:1977c2310ef7 290 /***************************
Kujira 0:1977c2310ef7 291 AD5625RBUZ(DAC) addr:1F
Kujira 0:1977c2310ef7 292 ***************************/
Kujira 0:1977c2310ef7 293 const char addr_dac = 0x1F <<1;
Kujira 0:1977c2310ef7 294 void dac_out(short mvolt, char addr);
Kujira 0:1977c2310ef7 295 void dac_init();
Kujira 0:1977c2310ef7 296 //
Kujira 0:1977c2310ef7 297 /***************************
Kujira 0:1977c2310ef7 298 表示
Kujira 0:1977c2310ef7 299 関数
Kujira 0:1977c2310ef7 300 ***************************/
Kujira 0:1977c2310ef7 301 void select_cal();//CAL選択画面
Kujira 0:1977c2310ef7 302 void setup_cal_information(char cal_num);//CAL情報登録画面
Kujira 0:1977c2310ef7 303 void manual_int_hyouji();
Kujira 0:1977c2310ef7 304 void auto_int_hyouji();
Kujira 0:1977c2310ef7 305 /***************************
Kujira 0:1977c2310ef7 306 測定関係
Kujira 0:1977c2310ef7 307 関数
Kujira 0:1977c2310ef7 308 ***************************/
Kujira 0:1977c2310ef7 309 void set_pullup();//シーケンサからの入力ピンのプルアップ設定
Kujira 0:1977c2310ef7 310 void trigger();//シーケンサからのスタート信号割込みサブ
Kujira 0:1977c2310ef7 311 void calibration();
Kujira 0:1977c2310ef7 312 void compute_adc(int adc_con, long *avg);//(ADCのCONFIG, 計算結果)
Kujira 0:1977c2310ef7 313 void gu_putdec(short* x);//2byteを10進で表示
Kujira 0:1977c2310ef7 314 void gu_putdeck(short* x);//2byteを10進で表示。1/1000.
Kujira 0:1977c2310ef7 315 void gu_putdeci(float* x);// ver1.1.4
Kujira 0:1977c2310ef7 316 void gu_putdeci_mA(float* x);// ver1.1.4
Kujira 0:1977c2310ef7 317 void meas_current_automode(char amount);//AutoMOdeの電流測定サブ iop ocp共通
Kujira 0:1977c2310ef7 318 void auto_run();//自動測定モード
Kujira 0:1977c2310ef7 319 void auto_meas(char noc);//一括測定。ch:測定する総チャンネル数
Kujira 0:1977c2310ef7 320 void meas_sub();//自動測定モード内の繰り返し処理
Kujira 0:1977c2310ef7 321 void manual();//手動測定モード
Kujira 0:1977c2310ef7 322 void hantei(char noc);//規格値比較エラーフラグ立てる
Kujira 0:1977c2310ef7 323 void select_ich(char ch);//電流測定chの選択と設定
Kujira 0:1977c2310ef7 324 short read_adc(char addr);//指定addressから2byte読込み
Kujira 0:1977c2310ef7 325 short meas_voltage(char ch);//測定チャンネルを指定して、測定値(2byte)を返す
Kujira 0:1977c2310ef7 326 short meas_resistor(char ch);//測定チャンネルを指定して、測定値(2byte)を返す
Kujira 0:1977c2310ef7 327 void display_resistor(short sdata);//測定値を表示する。
Kujira 0:1977c2310ef7 328 void led_off();//判定用LED全消灯
Kujira 0:1977c2310ef7 329 void read_syoudo(char* c);//EEPROMから照度データ(PwmDuty)を読み込んでセットする
Kujira 0:1977c2310ef7 330
Kujira 0:1977c2310ef7 331 //
Kujira 0:1977c2310ef7 332 /***************************
Kujira 0:1977c2310ef7 333 測定関係
Kujira 0:1977c2310ef7 334 変数
Kujira 0:1977c2310ef7 335 ***************************/
Kujira 0:1977c2310ef7 336 char io_voc; //VOC測定時のIO操作。ON(=VDD)の場合は”0x01"OFF(=OPEN)は"0x00"
Kujira 0:1977c2310ef7 337 char err_f[4];//ch1~4 規格外発生時のフラグ 0or1
Kujira 0:1977c2310ef7 338 short V[4];//ADC入力値を3倍した値 測定値[V] 16進数
Kujira 0:1977c2310ef7 339 float I[4];//電流測定値チャンネル毎の
Kujira 0:1977c2310ef7 340 short R[4];//抵抗測定値
Kujira 0:1977c2310ef7 341 short voc[4];//ADC入力値を3倍した値 測定値[mV] 16進数
Kujira 0:1977c2310ef7 342 short vocp[4];//過充電防止確認用電圧
Kujira 0:1977c2310ef7 343 float iop[4];//2byte 補数あり 測定値 1bit 0.01uA
Kujira 0:1977c2310ef7 344 float ocp[4];//2byte 補数あり 測定値
Kujira 0:1977c2310ef7 345 char ch_num ;//選択中の測定チャネル(0~3)
Kujira 0:1977c2310ef7 346
Kujira 0:1977c2310ef7 347 /**********************
Kujira 0:1977c2310ef7 348 暫定
Kujira 0:1977c2310ef7 349 **********************/
Kujira 0:1977c2310ef7 350 /*
Kujira 0:1977c2310ef7 351 #define vss_voc 3600
Kujira 0:1977c2310ef7 352 #define vss_iop 2800
Kujira 0:1977c2310ef7 353 #define vss_ocp 3600
Kujira 0:1977c2310ef7 354 #define wait_vss 4
Kujira 0:1977c2310ef7 355 #define wait_io 2
Kujira 0:1977c2310ef7 356 #define low_limit_voc 0xCE4//[mv] HEX
Kujira 0:1977c2310ef7 357 #define low_limit_iop 0x44C//11uA換算:1100*0.01
Kujira 0:1977c2310ef7 358 #define low_limit_ocp 0xFFE2//-0.3uA換算
Kujira 0:1977c2310ef7 359 */
Kujira 0:1977c2310ef7 360 /******************************
Kujira 0:1977c2310ef7 361
Kujira 0:1977c2310ef7 362 CAL情報登録 -> EEPROM
Kujira 0:1977c2310ef7 363
Kujira 0:1977c2310ef7 364 *******************************/
Kujira 0:1977c2310ef7 365 #define caliber_number 6 /* CAL登録数 */
Kujira 0:1977c2310ef7 366 #define addr_calnum 0x20 /* 起動時に選択するCALnumber */
Kujira 0:1977c2310ef7 367 #define addr_cal1 0x80 /* CAL.No1の情報を保存しているEEPROMのアドレス PCA24S08A BLOCK1 */
Kujira 0:1977c2310ef7 368 #define addr_cal2 0x90 /* CAL.No2の情報を保存しているEEPROMのアドレス PCA24S08A BLOCK1*/
Kujira 0:1977c2310ef7 369 #define addr_cal3 0xA0 /* CAL.No3の情報を保存しているEEPROMのアドレス PCA24S08A BLOCK1*/
Kujira 0:1977c2310ef7 370 #define addr_cal4 0xB0 /* CAL.No4の情報を保存しているEEPROMのアドレス PCA24S08A BLOCK1*/
Kujira 0:1977c2310ef7 371 #define addr_cal5 0xC0 /* CAL.No5の情報を保存しているEEPROMのアドレス PCA24S08A BLOCK1*/
Kujira 0:1977c2310ef7 372 #define addr_cal6 0xD0 /* CAL.No6の情報を保存しているEEPROMのアドレス PCA24S08A BLOCK1*/
Kujira 0:1977c2310ef7 373 //ver1.2.1
Kujira 0:1977c2310ef7 374 //EEPROM BLOCK2へのアドレッシングは、別で初期8bitも制御する必要がある。
Kujira 0:1977c2310ef7 375 #define addr_cal1_2 0x00 /* CAL.No1の情報を保存しているEEPROMのアドレス 追加分 PCA24S08A BLOCK2*/
Kujira 0:1977c2310ef7 376 #define addr_cal2_2 0x10 /* CAL.No2の情報を保存しているEEPROMのアドレス 追加分 PCA24S08A BLOCK2*/
Kujira 0:1977c2310ef7 377 #define addr_cal3_2 0x20 /* CAL.No3の情報を保存しているEEPROMのアドレス 追加分 PCA24S08A BLOCK2*/
Kujira 0:1977c2310ef7 378 #define addr_cal4_2 0x30 /* CAL.No4の情報を保存しているEEPROMのアドレス 追加分 PCA24S08A BLOCK2*/
Kujira 0:1977c2310ef7 379 #define addr_cal5_2 0x40 /* CAL.No5の情報を保存しているEEPROMのアドレス 追加分 PCA24S08A BLOCK2*/
Kujira 0:1977c2310ef7 380 #define addr_cal6_2 0x50 /* CAL.No6の情報を保存しているEEPROMのアドレス 追加分 PCA24S08A BLOCK2*/
Kujira 0:1977c2310ef7 381 //up to here
Kujira 0:1977c2310ef7 382
Kujira 0:1977c2310ef7 383 //structure
Kujira 0:1977c2310ef7 384 struct cal_info {
Kujira 0:1977c2310ef7 385 short number; /* CAL.No. */
Kujira 0:1977c2310ef7 386 short vss_iop; /* IOP測定時のVss電圧 1bit * 0.01uA*/
Kujira 0:1977c2310ef7 387 short vss_ocp; /* 過充電防止(over charge protection)測定時のVss電圧 */
Kujira 0:1977c2310ef7 388 short vss_voc; /* VOC測定時のVss電圧 */
Kujira 0:1977c2310ef7 389 short low_limit_voc; //1bit * 1mv
Kujira 0:1977c2310ef7 390 short low_limit_iop; //1bit * 0.01uA
Kujira 0:1977c2310ef7 391 short low_limit_ocp; //過充電防止検査の上限規格値(プラス側)
Kujira 0:1977c2310ef7 392 short up_limit_ocp; //過充電防止検査の上限規格値(マイナス側)ver1.2.1追加
Kujira 0:1977c2310ef7 393 float wait_iop; /* [s]Iop測定前の待機時間 1bit 1s 換算*/
Kujira 0:1977c2310ef7 394 float wait_ocp; /* [s]過充電防止時消電測定前の待機時間 1bit 1s換算*/
Kujira 0:1977c2310ef7 395 short low_limit_resistor; /* アンテナ抵抗規格 1bit 10Ω*/
Kujira 0:1977c2310ef7 396 short up_limit_resistor; /* アンテナ抵抗規格 1bit 10Ω*/
Kujira 0:1977c2310ef7 397 } ;
Kujira 0:1977c2310ef7 398 //parameter
Kujira 0:1977c2310ef7 399 struct cal_info calinfo;
Kujira 0:1977c2310ef7 400 char reg_num; /* 選択中の登録CALナンバー */
Kujira 0:1977c2310ef7 401 //function
Kujira 0:1977c2310ef7 402 void erace_calinfo();
Kujira 0:1977c2310ef7 403 void read_regnum();
Kujira 0:1977c2310ef7 404 void read_caliber(cal_info *cal, int num);
Kujira 0:1977c2310ef7 405 void write_caliber_information(cal_info *cal, int num);
Kujira 0:1977c2310ef7 406
Kujira 0:1977c2310ef7 407 /*******************************
Kujira 0:1977c2310ef7 408
Kujira 0:1977c2310ef7 409 set mode interruptin/degitalin
Kujira 0:1977c2310ef7 410
Kujira 0:1977c2310ef7 411 *******************************/
Kujira 0:1977c2310ef7 412 void set_pullup()
Kujira 0:1977c2310ef7 413 {
Kujira 0:1977c2310ef7 414 sw_start.mode(PullUp);
Kujira 0:1977c2310ef7 415 seq_start.mode(PullUp);//シーケンサからのスタート信号
Kujira 0:1977c2310ef7 416 seq_cal_a.mode(PullUp);
Kujira 0:1977c2310ef7 417 seq_cal_b.mode(PullUp);
Kujira 0:1977c2310ef7 418 seq_cal_c.mode(PullUp);
Kujira 0:1977c2310ef7 419 seq_kosuu_a.mode(PullUp);
Kujira 0:1977c2310ef7 420 seq_kosuu_b.mode(PullUp);
Kujira 0:1977c2310ef7 421 }
Kujira 0:1977c2310ef7 422 /*******************************
Kujira 0:1977c2310ef7 423
Kujira 0:1977c2310ef7 424 Sequence Mode main screen
Kujira 0:1977c2310ef7 425
Kujira 0:1977c2310ef7 426 *******************************/
Kujira 0:1977c2310ef7 427 void seq()
Kujira 0:1977c2310ef7 428 {
Kujira 0:1977c2310ef7 429 gu_cls();//clear screen
Kujira 0:1977c2310ef7 430 gu_fontsize(2);
Kujira 0:1977c2310ef7 431 gu_print1("Sequenser Mode");
Kujira 0:1977c2310ef7 432
Kujira 0:1977c2310ef7 433 //seq_start.fall(&trigger);//スタート信号立下りで割込み
Kujira 0:1977c2310ef7 434
Kujira 0:1977c2310ef7 435 //シーケンサのトリガ以外は受け付けない
Kujira 0:1977c2310ef7 436 while(1) {
Kujira 0:1977c2310ef7 437
Kujira 0:1977c2310ef7 438 if( seq_start == 0 ) {
Kujira 0:1977c2310ef7 439
Kujira 0:1977c2310ef7 440 trigger();
Kujira 0:1977c2310ef7 441
Kujira 0:1977c2310ef7 442 }
Kujira 0:1977c2310ef7 443
Kujira 0:1977c2310ef7 444 wait(0.3);
Kujira 0:1977c2310ef7 445
Kujira 0:1977c2310ef7 446 }//while(1)
Kujira 0:1977c2310ef7 447 }
Kujira 0:1977c2310ef7 448
Kujira 0:1977c2310ef7 449
Kujira 0:1977c2310ef7 450 /*******************************
Kujira 0:1977c2310ef7 451
Kujira 0:1977c2310ef7 452 Strart Sequence
Kujira 0:1977c2310ef7 453
Kujira 0:1977c2310ef7 454 *******************************/
Kujira 0:1977c2310ef7 455 void trigger()
Kujira 0:1977c2310ef7 456 {
Kujira 0:1977c2310ef7 457 char meas_num;//測定個数
Kujira 0:1977c2310ef7 458 char cal_num; //CAL選択ナンバー
Kujira 0:1977c2310ef7 459 //char cmd_gu[2];
Kujira 0:1977c2310ef7 460
Kujira 0:1977c2310ef7 461 gu_cls();//clear screen
Kujira 0:1977c2310ef7 462 gu_fontsize(2);
Kujira 0:1977c2310ef7 463 gu_print1("Sequenser Mode");
Kujira 0:1977c2310ef7 464 gu_fontsize(1);
Kujira 0:1977c2310ef7 465 gu_cursor(0,3);
Kujira 0:1977c2310ef7 466 gu_print1("start ");
Kujira 0:1977c2310ef7 467 gu_cursor(128,0);
Kujira 0:1977c2310ef7 468 gu_print1("CAL.");
Kujira 0:1977c2310ef7 469
Kujira 0:1977c2310ef7 470 //シーケンサからCAL選択bit読込と表示
Kujira 0:1977c2310ef7 471 cal_num = ( seq_cal_c << 2 ) + ( seq_cal_b << 1 ) + seq_cal_a;
Kujira 0:1977c2310ef7 472
Kujira 0:1977c2310ef7 473 cal_num = ( ~ cal_num ) & 0x7 ; //3bit入力の負論理
Kujira 0:1977c2310ef7 474
Kujira 0:1977c2310ef7 475 //read caliber infomation from eeprom
Kujira 0:1977c2310ef7 476 if( cal_num >= 1 && cal_num <= 6 ) {
Kujira 0:1977c2310ef7 477 read_caliber(&calinfo, cal_num);
Kujira 0:1977c2310ef7 478 gu_onebyte( cal_num + 0x30 );//CAL.No.確認用
Kujira 0:1977c2310ef7 479 } else {
Kujira 0:1977c2310ef7 480 gu_cls();
Kujira 0:1977c2310ef7 481 gu_fontsize(1);
Kujira 0:1977c2310ef7 482 gu_print1("Cal number error");
Kujira 0:1977c2310ef7 483 wait(1);
Kujira 0:1977c2310ef7 484
Kujira 0:1977c2310ef7 485 }
Kujira 0:1977c2310ef7 486
Kujira 0:1977c2310ef7 487 meas_num = ( ~(( seq_kosuu_b << 1 ) + seq_kosuu_a )) & 0x3; //2bit負論理
Kujira 0:1977c2310ef7 488
Kujira 0:1977c2310ef7 489 gu_cursor(128,1);
Kujira 0:1977c2310ef7 490 gu_print1("n=");
Kujira 0:1977c2310ef7 491 gu_onebyte( meas_num + 0x30 );//測定個数確認用
Kujira 0:1977c2310ef7 492
Kujira 0:1977c2310ef7 493 seq_busy = 1;//DegitalOut busy
Kujira 0:1977c2310ef7 494
Kujira 0:1977c2310ef7 495 auto_meas( meas_num );
Kujira 0:1977c2310ef7 496
Kujira 0:1977c2310ef7 497 //判定結果をシーケンサへ出力
Kujira 0:1977c2310ef7 498 hantei( meas_num );
Kujira 0:1977c2310ef7 499
Kujira 0:1977c2310ef7 500 wait(0.1);
Kujira 0:1977c2310ef7 501
Kujira 0:1977c2310ef7 502 //測定終了
Kujira 0:1977c2310ef7 503 seq_busy = 0;//DegitalOut busy
Kujira 0:1977c2310ef7 504
Kujira 0:1977c2310ef7 505 //終了表示
Kujira 0:1977c2310ef7 506 gu_fontsize(1);
Kujira 0:1977c2310ef7 507 gu_cursor(0,3);
Kujira 0:1977c2310ef7 508 gu_print1("ready ");
Kujira 0:1977c2310ef7 509
Kujira 0:1977c2310ef7 510 }
Kujira 0:1977c2310ef7 511
Kujira 0:1977c2310ef7 512 /*******************************
Kujira 0:1977c2310ef7 513
Kujira 0:1977c2310ef7 514 EEPROMへCAL情報(struct)を保存
Kujira 0:1977c2310ef7 515
Kujira 0:1977c2310ef7 516 *******************************/
Kujira 0:1977c2310ef7 517 void write_caliber_information(cal_info *cal, int num)
Kujira 0:1977c2310ef7 518 {
Kujira 0:1977c2310ef7 519 char cdata[17];//1byte
Kujira 0:1977c2310ef7 520
Kujira 0:1977c2310ef7 521 //EEPROM書込み 先頭アドレス
Kujira 0:1977c2310ef7 522 cdata[0] = addr_cal1 + 0x10 * ( num - 1 );
Kujira 0:1977c2310ef7 523
Kujira 0:1977c2310ef7 524 //データ分割 EEPROM_BYTE 0x00~0x0Bまで
Kujira 0:1977c2310ef7 525 cdata[1] = calinfo.vss_iop & 0xFF;//1byte分割
Kujira 0:1977c2310ef7 526 cdata[2] = ( calinfo.vss_iop >> 8 ) & 0xFF;//1byte分割
Kujira 0:1977c2310ef7 527
Kujira 0:1977c2310ef7 528 cdata[3] = calinfo.vss_ocp & 0xFF;//1byte分割
Kujira 0:1977c2310ef7 529 cdata[4] = ( calinfo.vss_ocp >> 8 ) & 0xFF;//1byte分割
Kujira 0:1977c2310ef7 530
Kujira 0:1977c2310ef7 531 cdata[5] = calinfo.vss_voc & 0xFF;//1byte分割
Kujira 0:1977c2310ef7 532 cdata[6] = ( calinfo.vss_voc >> 8 ) & 0xFF;//1byte分割
Kujira 0:1977c2310ef7 533
Kujira 0:1977c2310ef7 534 cdata[7] = calinfo.low_limit_voc & 0xFF;//1byte分割
Kujira 0:1977c2310ef7 535 cdata[8] = ( calinfo.low_limit_voc >> 8 ) & 0xFF;//1byte分割
Kujira 0:1977c2310ef7 536
Kujira 0:1977c2310ef7 537 cdata[9] = calinfo.low_limit_iop & 0xFF;//1byte分割
Kujira 0:1977c2310ef7 538 cdata[10] = ( calinfo.low_limit_iop >> 8 ) & 0xFF;//1byte分割
Kujira 0:1977c2310ef7 539
Kujira 0:1977c2310ef7 540 cdata[11] = calinfo.low_limit_ocp & 0xFF;//1byte分割
Kujira 0:1977c2310ef7 541 cdata[12] = ( calinfo.low_limit_ocp >> 8 ) & 0xFF;//1byte分割
Kujira 0:1977c2310ef7 542
Kujira 0:1977c2310ef7 543 //ver1.1.0
Kujira 0:1977c2310ef7 544 cdata[13] = calinfo.wait_iop; //1bitあたり 1s
Kujira 0:1977c2310ef7 545 cdata[14] = calinfo.wait_ocp; //1bitあたり 1s
Kujira 0:1977c2310ef7 546 /*ver1.1.0
Kujira 0:1977c2310ef7 547 cdata[13] = calinfo.wait_iop * 10; //1bitあたり0.1s
Kujira 0:1977c2310ef7 548 cdata[14] = calinfo.wait_ocp * 10; //1bitあたり0.1s
Kujira 0:1977c2310ef7 549 */
Kujira 0:1977c2310ef7 550
Kujira 0:1977c2310ef7 551 cdata[15] = calinfo.low_limit_resistor / 10; //1bitあたり10ohm
Kujira 0:1977c2310ef7 552 cdata[16] = calinfo.up_limit_resistor / 10; //1bitあたり10ohm
Kujira 0:1977c2310ef7 553
Kujira 0:1977c2310ef7 554 Soushin = i2c.write (fixed_adrs, cdata, 17);
Kujira 0:1977c2310ef7 555
Kujira 0:1977c2310ef7 556 //ver1.2.1
Kujira 0:1977c2310ef7 557 wait(0.1);
Kujira 0:1977c2310ef7 558
Kujira 0:1977c2310ef7 559 char cdata_2[3];
Kujira 0:1977c2310ef7 560
Kujira 0:1977c2310ef7 561 adrs_eeprom = fixed_adrs + 0x2; //BLOCK2の選択
Kujira 0:1977c2310ef7 562
Kujira 0:1977c2310ef7 563 cdata_2[0] = addr_cal1_2 + 0x10 * ( num - 1 ); //PAGE選択
Kujira 0:1977c2310ef7 564 cdata_2[1] = calinfo.up_limit_ocp & 0xFF;//1byte分割
Kujira 0:1977c2310ef7 565 cdata_2[2] = ( calinfo.up_limit_ocp >> 8 ) & 0xFF;//1byte分割
Kujira 0:1977c2310ef7 566
Kujira 0:1977c2310ef7 567 Soushin = i2c.write (adrs_eeprom, cdata_2, 3);
Kujira 0:1977c2310ef7 568 //up to here
Kujira 0:1977c2310ef7 569
Kujira 0:1977c2310ef7 570 }
Kujira 0:1977c2310ef7 571 /*******************************
Kujira 0:1977c2310ef7 572
Kujira 0:1977c2310ef7 573 EEPROMからCAL情報を
Kujira 0:1977c2310ef7 574 読み出して構造体へ代入する
Kujira 0:1977c2310ef7 575
Kujira 0:1977c2310ef7 576 *******************************/
Kujira 0:1977c2310ef7 577 void read_caliber(cal_info *cal, int num)
Kujira 0:1977c2310ef7 578 {
Kujira 0:1977c2310ef7 579 signed short sdata[16]; //CAL設定条件
Kujira 0:1977c2310ef7 580 int i;
Kujira 0:1977c2310ef7 581
Kujira 0:1977c2310ef7 582 //EEPROMからnumで指定したナンバーのCAL情報を読み出し
Kujira 0:1977c2310ef7 583 wdata[0] = addr_cal1 + 0x10 * ( num - 1 );
Kujira 0:1977c2310ef7 584 Soushin = i2c.write (fixed_adrs, wdata, 1,true); //読込先頭アドレス指定 ReStart
Kujira 0:1977c2310ef7 585 Jyushin = i2c.read ((fixed_adrs + 0x01), rdata, 16);//read 1byte
Kujira 0:1977c2310ef7 586
Kujira 0:1977c2310ef7 587 //データ合成 EEPROM_BYTE 0x00~0x0Bまで2byte結合
Kujira 0:1977c2310ef7 588 for ( i = 0; i <= 5; i++ ) {
Kujira 0:1977c2310ef7 589 sdata[i] = rdata[i*2] | ( rdata[ i*2 + 1 ] << 8 );
Kujira 0:1977c2310ef7 590 }
Kujira 0:1977c2310ef7 591 sdata[6] = rdata[12];
Kujira 0:1977c2310ef7 592 sdata[7] = rdata[13];
Kujira 0:1977c2310ef7 593 sdata[8] = rdata[14];
Kujira 0:1977c2310ef7 594 sdata[9] = rdata[15];
Kujira 0:1977c2310ef7 595
Kujira 0:1977c2310ef7 596 cal -> number = num;
Kujira 0:1977c2310ef7 597 cal -> vss_iop = sdata[0];
Kujira 0:1977c2310ef7 598 cal -> vss_ocp = sdata[1];
Kujira 0:1977c2310ef7 599 cal -> vss_voc = sdata[2];
Kujira 0:1977c2310ef7 600 cal -> low_limit_voc = sdata[3];
Kujira 0:1977c2310ef7 601 cal -> low_limit_iop = sdata[4];
Kujira 0:1977c2310ef7 602 cal -> low_limit_ocp = sdata[5];
Kujira 0:1977c2310ef7 603 //ver1.1.0
Kujira 0:1977c2310ef7 604 cal -> wait_iop = sdata[6];
Kujira 0:1977c2310ef7 605 cal -> wait_ocp = sdata[7];
Kujira 0:1977c2310ef7 606 /*
Kujira 0:1977c2310ef7 607 cal -> wait_iop = sdata[6] / 10;
Kujira 0:1977c2310ef7 608 cal -> wait_ocp = sdata[7] / 10;
Kujira 0:1977c2310ef7 609 */
Kujira 0:1977c2310ef7 610 cal -> low_limit_resistor = sdata[8] * 10;
Kujira 0:1977c2310ef7 611 cal -> up_limit_resistor = sdata[9] * 10;
Kujira 0:1977c2310ef7 612
Kujira 0:1977c2310ef7 613 //ver1.2.3
Kujira 0:1977c2310ef7 614 //EEPROMからnumで指定したナンバーのCAL情報を読み出し
Kujira 0:1977c2310ef7 615 char rdata2[2];
Kujira 0:1977c2310ef7 616
Kujira 0:1977c2310ef7 617 adrs_eeprom = fixed_adrs + 0x02; //BLOCK2
Kujira 0:1977c2310ef7 618
Kujira 0:1977c2310ef7 619 wdata[0] = addr_cal1_2 + 0x10 * ( num - 1 );
Kujira 0:1977c2310ef7 620 Soushin = i2c.write (adrs_eeprom, wdata, 1,true); //読込先頭アドレス指定 ReStart
Kujira 0:1977c2310ef7 621 Jyushin = i2c.read ((adrs_eeprom + 0x01), rdata2, 2);//read 1byte
Kujira 0:1977c2310ef7 622
Kujira 0:1977c2310ef7 623 //BYTE0~1
Kujira 0:1977c2310ef7 624 i = 0;
Kujira 0:1977c2310ef7 625 sdata[10] = rdata2[i*2] | ( rdata2[ i*2 + 1 ] << 8 );
Kujira 0:1977c2310ef7 626
Kujira 0:1977c2310ef7 627 cal -> up_limit_ocp = sdata[10];
Kujira 0:1977c2310ef7 628 //ver1.2.1 up to here
Kujira 0:1977c2310ef7 629
Kujira 0:1977c2310ef7 630 }
Kujira 0:1977c2310ef7 631 /*******************************
Kujira 0:1977c2310ef7 632
Kujira 0:1977c2310ef7 633 EEPROMからCAL登録番号を読出し
Kujira 0:1977c2310ef7 634
Kujira 0:1977c2310ef7 635 *******************************/
Kujira 0:1977c2310ef7 636 void read_regnum()
Kujira 0:1977c2310ef7 637 {
Kujira 0:1977c2310ef7 638 wdata[0] = addr_calnum;
Kujira 0:1977c2310ef7 639 Soushin = i2c.write (fixed_adrs, wdata, 1,true); //読込先頭アドレス指定 ReStart
Kujira 0:1977c2310ef7 640 Jyushin = i2c.read ((fixed_adrs + 0x01), rdata, 1);//read 1byte
Kujira 0:1977c2310ef7 641
Kujira 0:1977c2310ef7 642 reg_num = rdata[0];
Kujira 0:1977c2310ef7 643 }
Kujira 0:1977c2310ef7 644 /*******************************
Kujira 0:1977c2310ef7 645
Kujira 0:1977c2310ef7 646 EEPROMからCAL登録情報全消去
Kujira 0:1977c2310ef7 647
Kujira 0:1977c2310ef7 648 *******************************/
Kujira 0:1977c2310ef7 649 void erace_calinfo()
Kujira 0:1977c2310ef7 650 {
Kujira 0:1977c2310ef7 651 int i;
Kujira 0:1977c2310ef7 652
Kujira 0:1977c2310ef7 653 reg_num = 0x01;
Kujira 0:1977c2310ef7 654 wdata[0] = addr_calnum; //word address 書込み先頭アドレス指定
Kujira 0:1977c2310ef7 655 wdata[1] = reg_num;
Kujira 0:1977c2310ef7 656 Soushin = i2c.write (fixed_adrs, wdata, 2);
Kujira 0:1977c2310ef7 657
Kujira 0:1977c2310ef7 658 wait(0.2);
Kujira 0:1977c2310ef7 659
Kujira 0:1977c2310ef7 660 wdata[0] = addr_cal1;
Kujira 0:1977c2310ef7 661 for( i = 1; i <= 16; i++) { //1page全消去
Kujira 0:1977c2310ef7 662 wdata[i] = 0x00;
Kujira 0:1977c2310ef7 663 }
Kujira 0:1977c2310ef7 664 Soushin = i2c.write (fixed_adrs, wdata, 17);
Kujira 0:1977c2310ef7 665
Kujira 0:1977c2310ef7 666 wait(0.2);
Kujira 0:1977c2310ef7 667
Kujira 0:1977c2310ef7 668 wdata[0] = addr_cal2;
Kujira 0:1977c2310ef7 669 for( i = 1; i <= 16; i++) { //1page全消去
Kujira 0:1977c2310ef7 670 wdata[i] = 0x00;
Kujira 0:1977c2310ef7 671 }
Kujira 0:1977c2310ef7 672 Soushin = i2c.write (fixed_adrs, wdata, 17);
Kujira 0:1977c2310ef7 673
Kujira 0:1977c2310ef7 674 wait(0.2);
Kujira 0:1977c2310ef7 675
Kujira 0:1977c2310ef7 676 wdata[0] = addr_cal3;
Kujira 0:1977c2310ef7 677 for( i = 1; i <= 16; i++) { //1page全消去
Kujira 0:1977c2310ef7 678 wdata[i] = 0x00;
Kujira 0:1977c2310ef7 679 }
Kujira 0:1977c2310ef7 680 Soushin = i2c.write (fixed_adrs, wdata, 17);
Kujira 0:1977c2310ef7 681
Kujira 0:1977c2310ef7 682 wait(0.2);
Kujira 0:1977c2310ef7 683
Kujira 0:1977c2310ef7 684 wdata[0] = addr_cal4;
Kujira 0:1977c2310ef7 685 for( i = 1; i <= 16; i++) { //1page全消去
Kujira 0:1977c2310ef7 686 wdata[i] = 0x00;
Kujira 0:1977c2310ef7 687 }
Kujira 0:1977c2310ef7 688 Soushin = i2c.write (fixed_adrs, wdata, 17);
Kujira 0:1977c2310ef7 689
Kujira 0:1977c2310ef7 690 wait(0.2);
Kujira 0:1977c2310ef7 691
Kujira 0:1977c2310ef7 692 wdata[0] = addr_cal5;
Kujira 0:1977c2310ef7 693 for( i = 1; i <= 16; i++) { //1page全消去
Kujira 0:1977c2310ef7 694 wdata[i] = 0x00;
Kujira 0:1977c2310ef7 695 }
Kujira 0:1977c2310ef7 696 Soushin = i2c.write (fixed_adrs, wdata, 17);
Kujira 0:1977c2310ef7 697
Kujira 0:1977c2310ef7 698 wait(0.2);
Kujira 0:1977c2310ef7 699
Kujira 0:1977c2310ef7 700 wdata[0] = addr_cal6;
Kujira 0:1977c2310ef7 701 for( i = 1; i <= 16; i++) { //1page全消去
Kujira 0:1977c2310ef7 702 wdata[i] = 0x00;
Kujira 0:1977c2310ef7 703 }
Kujira 0:1977c2310ef7 704 Soushin = i2c.write (fixed_adrs, wdata, 17);
Kujira 0:1977c2310ef7 705
Kujira 0:1977c2310ef7 706 //ver1.2.1
Kujira 0:1977c2310ef7 707 //BLOCK2の消去
Kujira 0:1977c2310ef7 708 wait(0.2);
Kujira 0:1977c2310ef7 709
Kujira 0:1977c2310ef7 710 adrs_eeprom = fixed_adrs + 0x02; //BLOCK2
Kujira 0:1977c2310ef7 711
Kujira 0:1977c2310ef7 712 wdata[0] = addr_cal1_2;
Kujira 0:1977c2310ef7 713 for( i = 1; i <= 16; i++) { //1page全消去
Kujira 0:1977c2310ef7 714 wdata[i] = 0x00;
Kujira 0:1977c2310ef7 715 }
Kujira 0:1977c2310ef7 716 Soushin = i2c.write (adrs_eeprom, wdata, 17);
Kujira 0:1977c2310ef7 717
Kujira 0:1977c2310ef7 718 wait(0.2);
Kujira 0:1977c2310ef7 719
Kujira 0:1977c2310ef7 720 wdata[0] = addr_cal2_2;
Kujira 0:1977c2310ef7 721 for( i = 1; i <= 16; i++) { //1page全消去
Kujira 0:1977c2310ef7 722 wdata[i] = 0x00;
Kujira 0:1977c2310ef7 723 }
Kujira 0:1977c2310ef7 724 Soushin = i2c.write (adrs_eeprom, wdata, 17);
Kujira 0:1977c2310ef7 725
Kujira 0:1977c2310ef7 726 wait(0.2);
Kujira 0:1977c2310ef7 727
Kujira 0:1977c2310ef7 728 wdata[0] = addr_cal3_2;
Kujira 0:1977c2310ef7 729 for( i = 1; i <= 16; i++) { //1page全消去
Kujira 0:1977c2310ef7 730 wdata[i] = 0x00;
Kujira 0:1977c2310ef7 731 }
Kujira 0:1977c2310ef7 732 Soushin = i2c.write (adrs_eeprom, wdata, 17);
Kujira 0:1977c2310ef7 733
Kujira 0:1977c2310ef7 734 wait(0.2);
Kujira 0:1977c2310ef7 735
Kujira 0:1977c2310ef7 736 wdata[0] = addr_cal4_2;
Kujira 0:1977c2310ef7 737 for( i = 1; i <= 16; i++) { //1page全消去
Kujira 0:1977c2310ef7 738 wdata[i] = 0x00;
Kujira 0:1977c2310ef7 739 }
Kujira 0:1977c2310ef7 740 Soushin = i2c.write (adrs_eeprom, wdata, 17);
Kujira 0:1977c2310ef7 741
Kujira 0:1977c2310ef7 742 wait(0.2);
Kujira 0:1977c2310ef7 743
Kujira 0:1977c2310ef7 744 wdata[0] = addr_cal5_2;
Kujira 0:1977c2310ef7 745 for( i = 1; i <= 16; i++) { //1page全消去
Kujira 0:1977c2310ef7 746 wdata[i] = 0x00;
Kujira 0:1977c2310ef7 747 }
Kujira 0:1977c2310ef7 748 Soushin = i2c.write (adrs_eeprom, wdata, 17);
Kujira 0:1977c2310ef7 749
Kujira 0:1977c2310ef7 750 wait(0.2);
Kujira 0:1977c2310ef7 751
Kujira 0:1977c2310ef7 752 wdata[0] = addr_cal6_2;
Kujira 0:1977c2310ef7 753 for( i = 1; i <= 16; i++) { //1page全消去
Kujira 0:1977c2310ef7 754 wdata[i] = 0x00;
Kujira 0:1977c2310ef7 755 }
Kujira 0:1977c2310ef7 756 Soushin = i2c.write (adrs_eeprom, wdata, 17);
Kujira 0:1977c2310ef7 757
Kujira 0:1977c2310ef7 758 wait(0.2);
Kujira 0:1977c2310ef7 759
Kujira 0:1977c2310ef7 760 //up to herever1.2.1
Kujira 0:1977c2310ef7 761
Kujira 0:1977c2310ef7 762 }
Kujira 0:1977c2310ef7 763 /******************************************
Kujira 0:1977c2310ef7 764
Kujira 0:1977c2310ef7 765 ADC(MCP3424) Configuration Register
Kujira 0:1977c2310ef7 766
Kujira 0:1977c2310ef7 767 ch : Channel Selection Bit
Kujira 0:1977c2310ef7 768 00 = Select Channel 1
Kujira 0:1977c2310ef7 769 01 = Select Channel 2
Kujira 0:1977c2310ef7 770 10 = Select Channel 3
Kujira 0:1977c2310ef7 771 11 = Select Channel 4
Kujira 0:1977c2310ef7 772
Kujira 0:1977c2310ef7 773 rate : Sample Rate Selection Bit
Kujira 0:1977c2310ef7 774 00 = 240 SPS(12bits)
Kujira 0:1977c2310ef7 775 01 = 60 SPS(14bits)
Kujira 0:1977c2310ef7 776 10 = 15 SPS(16bits)
Kujira 0:1977c2310ef7 777 11 = 3.75 SPS(18bits)
Kujira 0:1977c2310ef7 778
Kujira 0:1977c2310ef7 779 ******************************************/
Kujira 0:1977c2310ef7 780 char adc_config(char ch, char rate)
Kujira 0:1977c2310ef7 781 {
Kujira 0:1977c2310ef7 782 char confreg; //Configuration Register 1byte
Kujira 0:1977c2310ef7 783
Kujira 0:1977c2310ef7 784 char rdy = 0; //Ready Bit
Kujira 0:1977c2310ef7 785 char cm = 1; //Conversion Mode Bit
Kujira 0:1977c2310ef7 786 char gain = 0; //PGA Gain Selection Bits
Kujira 0:1977c2310ef7 787
Kujira 0:1977c2310ef7 788 confreg = (( rdy & 0x1 ) << 7 ) + (( ch & 0x3) << 5 ) + (( cm & 0x1 ) << 4) + (( rate & 0x3 ) << 2) + ( gain & 0x3 ) ;
Kujira 0:1977c2310ef7 789
Kujira 0:1977c2310ef7 790 return( confreg );
Kujira 0:1977c2310ef7 791 }
Kujira 0:1977c2310ef7 792 /******************************************
Kujira 0:1977c2310ef7 793
Kujira 0:1977c2310ef7 794 ADC(MCP3424) Configuration Register
Kujira 0:1977c2310ef7 795 電流測定チャンネルの選択
Kujira 0:1977c2310ef7 796 char ch : 1~4ch
Kujira 0:1977c2310ef7 797
Kujira 0:1977c2310ef7 798 ******************************************/
Kujira 0:1977c2310ef7 799 void select_ich(char ch)
Kujira 0:1977c2310ef7 800 {
Kujira 0:1977c2310ef7 801 char com;
Kujira 0:1977c2310ef7 802
Kujira 0:1977c2310ef7 803 switch ( ch ) {
Kujira 0:1977c2310ef7 804 case 0:
Kujira 0:1977c2310ef7 805 com = adc_config( 0, 1 );//ADC3_ch1選択 14bits
Kujira 0:1977c2310ef7 806 i2c.write( addr_ADC3, &com, 1 );
Kujira 0:1977c2310ef7 807 break;
Kujira 0:1977c2310ef7 808 case 1:
Kujira 0:1977c2310ef7 809 com = adc_config( 1, 1 );//ADC3_ch2選択 14bits
Kujira 0:1977c2310ef7 810 i2c.write( addr_ADC3, &com, 1 );
Kujira 0:1977c2310ef7 811 break;
Kujira 0:1977c2310ef7 812 case 2:
Kujira 0:1977c2310ef7 813 com = adc_config( 0, 1 );//ADC4_ch1選択 14bits
Kujira 0:1977c2310ef7 814 i2c.write( addr_ADC4, &com, 1 );
Kujira 0:1977c2310ef7 815 break;
Kujira 0:1977c2310ef7 816 case 3:
Kujira 0:1977c2310ef7 817 com = adc_config( 1, 1 );//ADC4_ch2選択 14bits
Kujira 0:1977c2310ef7 818 i2c.write( addr_ADC4, &com, 1 );
Kujira 0:1977c2310ef7 819 break;
Kujira 0:1977c2310ef7 820 }
Kujira 0:1977c2310ef7 821 }
Kujira 0:1977c2310ef7 822 /******************************************
Kujira 0:1977c2310ef7 823
Kujira 0:1977c2310ef7 824 ADC(MCP3424)
Kujira 0:1977c2310ef7 825 指定addressから2byte読込み
Kujira 0:1977c2310ef7 826
Kujira 0:1977c2310ef7 827 ******************************************/
Kujira 0:1977c2310ef7 828 short read_adc(char addr)//指定addressから2byte読込み
Kujira 0:1977c2310ef7 829 {
Kujira 0:1977c2310ef7 830 char cdata[2];//1byte
Kujira 0:1977c2310ef7 831 short sdata;//2byte
Kujira 0:1977c2310ef7 832
Kujira 0:1977c2310ef7 833 i2c.read( addr + 0x01, cdata, 2);
Kujira 0:1977c2310ef7 834
Kujira 0:1977c2310ef7 835 //connect 2byte
Kujira 0:1977c2310ef7 836 sdata = cdata[0] & 0xFF;
Kujira 0:1977c2310ef7 837 sdata = ( sdata << 8 ) | cdata[1];
Kujira 0:1977c2310ef7 838
Kujira 0:1977c2310ef7 839 return ( sdata );
Kujira 0:1977c2310ef7 840 }
Kujira 0:1977c2310ef7 841 /*****************************
Kujira 0:1977c2310ef7 842
Kujira 0:1977c2310ef7 843 AUTO/SEQ Mode
Kujira 0:1977c2310ef7 844
Kujira 0:1977c2310ef7 845 ワンショットタイマー発生イベント
Kujira 0:1977c2310ef7 846
Kujira 0:1977c2310ef7 847 For Current measurement
Kujira 0:1977c2310ef7 848 a recurring interrupt to repeatedly call a function at a specified rate.
Kujira 0:1977c2310ef7 849
Kujira 0:1977c2310ef7 850 *****************************/
Kujira 0:1977c2310ef7 851 void flip_ch1()
Kujira 0:1977c2310ef7 852 {
Kujira 0:1977c2310ef7 853 short sdata;
Kujira 0:1977c2310ef7 854
Kujira 0:1977c2310ef7 855 sdata = read_adc( addr_ADC3 );
Kujira 0:1977c2310ef7 856
Kujira 0:1977c2310ef7 857 I[0] = sdata * 5 * 0.25;
Kujira 0:1977c2310ef7 858
Kujira 0:1977c2310ef7 859 //次の測定chへ切替
Kujira 0:1977c2310ef7 860 select_ich(1);
Kujira 0:1977c2310ef7 861 }
Kujira 0:1977c2310ef7 862
Kujira 0:1977c2310ef7 863 void flip_ch2()
Kujira 0:1977c2310ef7 864 {
Kujira 0:1977c2310ef7 865 short sdata;
Kujira 0:1977c2310ef7 866
Kujira 0:1977c2310ef7 867 sdata = read_adc( addr_ADC3 );
Kujira 0:1977c2310ef7 868
Kujira 0:1977c2310ef7 869 I[1] = sdata * 5 * 0.25;
Kujira 0:1977c2310ef7 870
Kujira 0:1977c2310ef7 871 //次の測定chへ切替
Kujira 0:1977c2310ef7 872 select_ich(2);
Kujira 0:1977c2310ef7 873 }
Kujira 0:1977c2310ef7 874
Kujira 0:1977c2310ef7 875 void flip_ch3()
Kujira 0:1977c2310ef7 876 {
Kujira 0:1977c2310ef7 877 short sdata;
Kujira 0:1977c2310ef7 878
Kujira 0:1977c2310ef7 879 sdata = read_adc( addr_ADC4 );
Kujira 0:1977c2310ef7 880
Kujira 0:1977c2310ef7 881 I[2] = sdata * 5 * 0.25;
Kujira 0:1977c2310ef7 882
Kujira 0:1977c2310ef7 883 //次の測定chへ切替
Kujira 0:1977c2310ef7 884 select_ich(3);
Kujira 0:1977c2310ef7 885 }
Kujira 0:1977c2310ef7 886
Kujira 0:1977c2310ef7 887 void flip_ch4()
Kujira 0:1977c2310ef7 888 {
Kujira 0:1977c2310ef7 889 short sdata;
Kujira 0:1977c2310ef7 890
Kujira 0:1977c2310ef7 891 sdata = read_adc( addr_ADC4 );
Kujira 0:1977c2310ef7 892
Kujira 0:1977c2310ef7 893 I[3] = sdata * 5 * 0.25;
Kujira 0:1977c2310ef7 894
Kujira 0:1977c2310ef7 895 //次の測定chへ切替 無し
Kujira 0:1977c2310ef7 896 }
Kujira 0:1977c2310ef7 897
Kujira 0:1977c2310ef7 898 /*****************************
Kujira 0:1977c2310ef7 899
Kujira 0:1977c2310ef7 900 Manual Mode
Kujira 0:1977c2310ef7 901
Kujira 0:1977c2310ef7 902 繰り返しタイマー発生イベント
Kujira 0:1977c2310ef7 903
Kujira 0:1977c2310ef7 904 For Current measurement
Kujira 0:1977c2310ef7 905 a recurring interrupt to repeatedly call a function at a specified rate.
Kujira 0:1977c2310ef7 906
Kujira 0:1977c2310ef7 907 *****************************/
Kujira 0:1977c2310ef7 908 void flip()
Kujira 0:1977c2310ef7 909 {
Kujira 0:1977c2310ef7 910 short sdata; //_2byte reading data of ADC
Kujira 0:1977c2310ef7 911 float fdata; // ver1.1.4
Kujira 0:1977c2310ef7 912
Kujira 0:1977c2310ef7 913 switch ( ch_num ) {
Kujira 0:1977c2310ef7 914 case 0:
Kujira 0:1977c2310ef7 915 case 1:
Kujira 0:1977c2310ef7 916 sdata = read_adc( addr_ADC3 );
Kujira 0:1977c2310ef7 917 break;
Kujira 0:1977c2310ef7 918 case 2:
Kujira 0:1977c2310ef7 919 case 3:
Kujira 0:1977c2310ef7 920 sdata = read_adc( addr_ADC4 );
Kujira 0:1977c2310ef7 921 break;
Kujira 0:1977c2310ef7 922 }
Kujira 0:1977c2310ef7 923
Kujira 0:1977c2310ef7 924 //sdata = sdata * 5 * 0.25;//プリアンプのGAINが1/5なのでここで5倍.ADC14bit分解能で、1bitあたり0.25mv
Kujira 0:1977c2310ef7 925 /*ver1.1.4*/
Kujira 0:1977c2310ef7 926 fdata = sdata * 5 * 0.25;//プリアンプのGAINが1/5なのでここで5倍.ADC14bit分解能で、1bitあたり0.25mv
Kujira 0:1977c2310ef7 927
Kujira 0:1977c2310ef7 928 gu_cursor(0,4);
Kujira 0:1977c2310ef7 929 gu_print1(" ");
Kujira 0:1977c2310ef7 930 /*ver1.1.4*/
Kujira 0:1977c2310ef7 931 gu_putdeci(&fdata);
Kujira 0:1977c2310ef7 932 //gu_putdeci(&sdata);
Kujira 0:1977c2310ef7 933
Kujira 0:1977c2310ef7 934 houden[ ch_num ] = 1; //Discharge
Kujira 0:1977c2310ef7 935
Kujira 0:1977c2310ef7 936 wait(time_discharge); //Discharge time
Kujira 0:1977c2310ef7 937
Kujira 0:1977c2310ef7 938 houden[ ch_num ] = 0; //charging
Kujira 0:1977c2310ef7 939
Kujira 0:1977c2310ef7 940 }
Kujira 0:1977c2310ef7 941 /*********************************
Kujira 0:1977c2310ef7 942 Manual Mode
Kujira 0:1977c2310ef7 943 initial screen
Kujira 0:1977c2310ef7 944 *********************************/
Kujira 0:1977c2310ef7 945 void manual_int_hyouji()
Kujira 0:1977c2310ef7 946 {
Kujira 0:1977c2310ef7 947
Kujira 0:1977c2310ef7 948 /* 画面表示 */
Kujira 0:1977c2310ef7 949 gu_cls();
Kujira 0:1977c2310ef7 950 gu_fontsize(2); //change fontsize
Kujira 0:1977c2310ef7 951 gu_fontWidth(Proportional1);
Kujira 0:1977c2310ef7 952 gu_print1("Manual Mode");
Kujira 0:1977c2310ef7 953
Kujira 0:1977c2310ef7 954 gu_cursor(0, 2);
Kujira 0:1977c2310ef7 955 gu_print1("CH.");
Kujira 0:1977c2310ef7 956 gu_cursor(40, 14);
Kujira 0:1977c2310ef7 957 gu_print1("vss");
Kujira 0:1977c2310ef7 958 gu_cursor(192, 14);
Kujira 0:1977c2310ef7 959 gu_print1("ch.");
Kujira 0:1977c2310ef7 960 /*
Kujira 0:1977c2310ef7 961 gu_cursor(128, 14);
Kujira 0:1977c2310ef7 962 gu_print1("slct ch.");
Kujira 0:1977c2310ef7 963 */
Kujira 0:1977c2310ef7 964
Kujira 0:1977c2310ef7 965 //操作ボタン配置
Kujira 0:1977c2310ef7 966 gu_Button_power_on();//メニューへ戻る
Kujira 0:1977c2310ef7 967 gu_button_up(27);//印加電圧増加
Kujira 0:1977c2310ef7 968 gu_button_down(28);//印加電圧減少
Kujira 0:1977c2310ef7 969 gu_button_up(32);//ch切替
Kujira 0:1977c2310ef7 970 //gu_button_down(32);//ch切替
Kujira 0:1977c2310ef7 971
Kujira 0:1977c2310ef7 972 //Show Reset button(LEFT)
Kujira 0:1977c2310ef7 973 gu_set_button(25,"R");
Kujira 0:1977c2310ef7 974
Kujira 0:1977c2310ef7 975 }
Kujira 0:1977c2310ef7 976 /*********************************
Kujira 0:1977c2310ef7 977
Kujira 0:1977c2310ef7 978 Manual Mode (Main)
Kujira 0:1977c2310ef7 979
Kujira 0:1977c2310ef7 980 *********************************/
Kujira 0:1977c2310ef7 981 void manual()
Kujira 0:1977c2310ef7 982 {
Kujira 0:1977c2310ef7 983
Kujira 0:1977c2310ef7 984 char cswnum; //SW_No. sw1->0x00 ~~ sw32->0x1F
Kujira 0:1977c2310ef7 985 char cswdata; // 0x00 or 0x01
Kujira 0:1977c2310ef7 986 char crdata[3];
Kujira 0:1977c2310ef7 987 char *pcswnum = &cswnum;
Kujira 0:1977c2310ef7 988 char *pcswdata = &cswdata;
Kujira 0:1977c2310ef7 989 int i;
Kujira 0:1977c2310ef7 990 int j;
Kujira 0:1977c2310ef7 991 float interval;//繰り返し測定間隔(s) <- 積分時間と、繰り返し割込みサブ中のwait(放電時間)も足す
Kujira 0:1977c2310ef7 992 short vss;
Kujira 0:1977c2310ef7 993 short sdata;
Kujira 0:1977c2310ef7 994 int r_flag;
Kujira 0:1977c2310ef7 995 float ima;
Kujira 0:1977c2310ef7 996 short ssdata;
Kujira 0:1977c2310ef7 997
Kujira 0:1977c2310ef7 998 ch_num = 0; //初期電流測定CH.
Kujira 0:1977c2310ef7 999
Kujira 0:1977c2310ef7 1000 interval = time_integral + time_discharge ;//繰り返し割込みの間隔設定
Kujira 0:1977c2310ef7 1001 flipper.attach(&flip, interval);
Kujira 0:1977c2310ef7 1002
Kujira 0:1977c2310ef7 1003 read_regnum();//CAL登録No.読込
Kujira 0:1977c2310ef7 1004 read_caliber(&calinfo, reg_num);//指定したCAL登録No.の情報を読込後、calinfoへ代入
Kujira 0:1977c2310ef7 1005
Kujira 0:1977c2310ef7 1006 /* 初期表示 */
Kujira 0:1977c2310ef7 1007 manual_int_hyouji();
Kujira 0:1977c2310ef7 1008 //選択測定チャンネルの表示
Kujira 0:1977c2310ef7 1009 gu_fontsize(2); //change fontsize
Kujira 0:1977c2310ef7 1010 gu_cursor(24, 2);
Kujira 0:1977c2310ef7 1011 wdata[0] = ( ch_num + 1 ) + 0x30;
Kujira 0:1977c2310ef7 1012 i2c.write( addr_gu, wdata, 1);
Kujira 0:1977c2310ef7 1013
Kujira 0:1977c2310ef7 1014 //初期測定設定
Kujira 0:1977c2310ef7 1015 //set range
Kujira 0:1977c2310ef7 1016 range[0] = 1;//ch.1 10uA測定レンジ
Kujira 0:1977c2310ef7 1017 //select channel
Kujira 0:1977c2310ef7 1018 wdata[0] = adc_config( 0, 1 );//ADC3_ch1選択 14bits
Kujira 0:1977c2310ef7 1019 i2c.write( addr_ADC3, wdata, 1 );
Kujira 0:1977c2310ef7 1020
Kujira 0:1977c2310ef7 1021 vss = calinfo.vss_iop;
Kujira 0:1977c2310ef7 1022
Kujira 0:1977c2310ef7 1023 //apply Vss to all channel
Kujira 0:1977c2310ef7 1024 for ( i = 0; i <= (number_of_channels - 1); i++) {
Kujira 0:1977c2310ef7 1025 dac_out( calinfo.vss_iop,i); //Vss設定 DAC
Kujira 0:1977c2310ef7 1026 }
Kujira 0:1977c2310ef7 1027
Kujira 0:1977c2310ef7 1028 gu_cursor(0,8);
Kujira 0:1977c2310ef7 1029 gu_print1("Vss ");
Kujira 0:1977c2310ef7 1030
Kujira 0:1977c2310ef7 1031 gu_cursor(64,8);
Kujira 0:1977c2310ef7 1032 sdata = -1 * vss;
Kujira 0:1977c2310ef7 1033 gu_putdeck( &sdata );
Kujira 0:1977c2310ef7 1034 gu_print1("V");
Kujira 0:1977c2310ef7 1035
Kujira 0:1977c2310ef7 1036 while(1) {
Kujira 0:1977c2310ef7 1037
Kujira 0:1977c2310ef7 1038 crdata[0] = 0;
Kujira 0:1977c2310ef7 1039 crdata[1] = 0;
Kujira 0:1977c2310ef7 1040 crdata[2] = 0;
Kujira 0:1977c2310ef7 1041
Kujira 0:1977c2310ef7 1042 //タッチパネルスイッチ読込
Kujira 0:1977c2310ef7 1043 Jyushin = i2c.read ((addr_gu + 0x01), crdata, 3, true);
Kujira 0:1977c2310ef7 1044
Kujira 0:1977c2310ef7 1045 if (crdata[0] == 0x11 ) { //個別タッチスイッチ状態読み出しフォーマット。識別子11h。
Kujira 0:1977c2310ef7 1046 *pcswnum = crdata[1]; //スイッチ番号
Kujira 0:1977c2310ef7 1047 *pcswdata = crdata[2];//ON/OFF情報
Kujira 0:1977c2310ef7 1048
Kujira 0:1977c2310ef7 1049 if (cswdata == 0x01) { //タッチしたならば
Kujira 0:1977c2310ef7 1050 switch( cswnum ) { //SWの番号(位置)
Kujira 0:1977c2310ef7 1051
Kujira 0:1977c2310ef7 1052 case 26:
Kujira 0:1977c2310ef7 1053 //gu_reverse(0x01); //gu_リバース指定
Kujira 0:1977c2310ef7 1054 //gu_button_up(27);//印加電圧増加
Kujira 0:1977c2310ef7 1055
Kujira 0:1977c2310ef7 1056 if ( vss < 4500 ) {
Kujira 0:1977c2310ef7 1057 vss = vss + 100;
Kujira 0:1977c2310ef7 1058 }
Kujira 0:1977c2310ef7 1059
Kujira 0:1977c2310ef7 1060 //apply Vss to all channel
Kujira 0:1977c2310ef7 1061 for ( i = 0; i <= (number_of_channels - 1); i++) {
Kujira 0:1977c2310ef7 1062 dac_out( vss,i); //Vss設定 DAC
Kujira 0:1977c2310ef7 1063 }
Kujira 0:1977c2310ef7 1064
Kujira 0:1977c2310ef7 1065 gu_reverse(0x00);
Kujira 0:1977c2310ef7 1066 gu_cursor(64,8);
Kujira 0:1977c2310ef7 1067 sdata = -1 * vss;
Kujira 0:1977c2310ef7 1068 gu_putdeck( &sdata );
Kujira 0:1977c2310ef7 1069 gu_print1("V");
Kujira 0:1977c2310ef7 1070
Kujira 0:1977c2310ef7 1071 //gu_button_up(27);//印加電圧減少
Kujira 0:1977c2310ef7 1072
Kujira 0:1977c2310ef7 1073 wait(0.1);
Kujira 0:1977c2310ef7 1074
Kujira 0:1977c2310ef7 1075 break;
Kujira 0:1977c2310ef7 1076
Kujira 0:1977c2310ef7 1077 case 27:
Kujira 0:1977c2310ef7 1078 //gu_reverse(0x01); //gu_リバース指定
Kujira 0:1977c2310ef7 1079 //gu_button_down(28);//印加電圧減少
Kujira 0:1977c2310ef7 1080
Kujira 0:1977c2310ef7 1081 if ( vss >= 100 ) {
Kujira 0:1977c2310ef7 1082 vss = vss - 100;
Kujira 0:1977c2310ef7 1083 }
Kujira 0:1977c2310ef7 1084
Kujira 0:1977c2310ef7 1085 //apply Vss to all channel
Kujira 0:1977c2310ef7 1086 for ( i = 0; i <= (number_of_channels - 1); i++) {
Kujira 0:1977c2310ef7 1087 dac_out( vss,i); //Vss設定 DAC
Kujira 0:1977c2310ef7 1088 }
Kujira 0:1977c2310ef7 1089
Kujira 0:1977c2310ef7 1090 //gu_reverse(0x00); //gu_リバース指定
Kujira 0:1977c2310ef7 1091 gu_cursor(64,8);
Kujira 0:1977c2310ef7 1092 sdata = -1 * vss;
Kujira 0:1977c2310ef7 1093 gu_putdeck( &sdata );
Kujira 0:1977c2310ef7 1094 gu_print1("V");
Kujira 0:1977c2310ef7 1095
Kujira 0:1977c2310ef7 1096 //gu_button_down(28);//印加電圧減少
Kujira 0:1977c2310ef7 1097
Kujira 0:1977c2310ef7 1098 wait(0.1);
Kujira 0:1977c2310ef7 1099
Kujira 0:1977c2310ef7 1100 break;
Kujira 0:1977c2310ef7 1101
Kujira 0:1977c2310ef7 1102 case 0x07 ://Exit
Kujira 0:1977c2310ef7 1103
Kujira 0:1977c2310ef7 1104 gu_Button_power_off();//電源ボタンイメージ反転表示
Kujira 0:1977c2310ef7 1105
Kujira 0:1977c2310ef7 1106 //割り込み停止
Kujira 0:1977c2310ef7 1107 flipper.detach();
Kujira 0:1977c2310ef7 1108
Kujira 0:1977c2310ef7 1109 for( i = 0; i <= 3; i++) {
Kujira 0:1977c2310ef7 1110 houden[i] = 1;//discharge
Kujira 0:1977c2310ef7 1111 }
Kujira 0:1977c2310ef7 1112
Kujira 0:1977c2310ef7 1113 wait( time_discharge );
Kujira 0:1977c2310ef7 1114 //set measuring range
Kujira 0:1977c2310ef7 1115 for( i = 0; i <= 3; i++) {
Kujira 0:1977c2310ef7 1116 range[i] = 0;//range 1mA
Kujira 0:1977c2310ef7 1117 houden[i] = 0;//not discharge
Kujira 0:1977c2310ef7 1118 }
Kujira 0:1977c2310ef7 1119
Kujira 0:1977c2310ef7 1120 wait(0.2);
Kujira 0:1977c2310ef7 1121
Kujira 0:1977c2310ef7 1122 for ( i = 0; i <= 7; i++)
Kujira 0:1977c2310ef7 1123 io[i] = 0; //全てのio"L"
Kujira 0:1977c2310ef7 1124
Kujira 0:1977c2310ef7 1125 return;//この関数を抜ける
Kujira 0:1977c2310ef7 1126
Kujira 0:1977c2310ef7 1127 case 0x18 ://sw25 mv_reset
Kujira 0:1977c2310ef7 1128
Kujira 0:1977c2310ef7 1129 //gu_リバース指定
Kujira 0:1977c2310ef7 1130 gu_reverse(0x01);
Kujira 0:1977c2310ef7 1131 //Show Reset button(Left)
Kujira 0:1977c2310ef7 1132 gu_set_button(25,"R");
Kujira 0:1977c2310ef7 1133
Kujira 0:1977c2310ef7 1134 wait(0.1);
Kujira 0:1977c2310ef7 1135
Kujira 0:1977c2310ef7 1136 gu_reverse(0x00); //gu_リバース解除
Kujira 0:1977c2310ef7 1137 gu_set_button(25,"R"); //Show Reset button(Left)
Kujira 0:1977c2310ef7 1138
Kujira 0:1977c2310ef7 1139 io[ch_num] = 1;
Kujira 0:1977c2310ef7 1140
Kujira 0:1977c2310ef7 1141 //set measuring range ver1.1.0
Kujira 0:1977c2310ef7 1142 for( i = 0; i <= 3; i++)
Kujira 0:1977c2310ef7 1143 range[i] = 0;//range 1mA
Kujira 0:1977c2310ef7 1144
Kujira 0:1977c2310ef7 1145 r_flag = 1;
Kujira 0:1977c2310ef7 1146
Kujira 0:1977c2310ef7 1147 //割り込み停止
Kujira 0:1977c2310ef7 1148 flipper.detach();
Kujira 0:1977c2310ef7 1149
Kujira 0:1977c2310ef7 1150 break;
Kujira 0:1977c2310ef7 1151
Kujira 0:1977c2310ef7 1152 case 31 ://sw32 CH選択
Kujira 0:1977c2310ef7 1153
Kujira 0:1977c2310ef7 1154 //gu_reverse(0x01);//gu_リバース指定
Kujira 0:1977c2310ef7 1155 //gu_button_up(32);
Kujira 0:1977c2310ef7 1156 //gu_reverse(0x00);//gu_リバース解除
Kujira 0:1977c2310ef7 1157
Kujira 0:1977c2310ef7 1158 if ( ch_num < ( number_of_channels - 1 )) {
Kujira 0:1977c2310ef7 1159 ch_num = ch_num + 1;
Kujira 0:1977c2310ef7 1160 } else {
Kujira 0:1977c2310ef7 1161 ch_num = 0;
Kujira 0:1977c2310ef7 1162 } //ver1.1.0
Kujira 0:1977c2310ef7 1163
Kujira 0:1977c2310ef7 1164 select_ich(ch_num);//ADC測定CHの変更
Kujira 0:1977c2310ef7 1165
Kujira 0:1977c2310ef7 1166 //set measuring range
Kujira 0:1977c2310ef7 1167 for( i = 0; i <= 3; i++)
Kujira 0:1977c2310ef7 1168 range[i] = 0; //range 1mA
Kujira 0:1977c2310ef7 1169
Kujira 0:1977c2310ef7 1170 range[ch_num] = 1; //range 10uA
Kujira 0:1977c2310ef7 1171
Kujira 0:1977c2310ef7 1172 //選択測定チャンネルの表示
Kujira 0:1977c2310ef7 1173 gu_cursor(24, 2);
Kujira 0:1977c2310ef7 1174 wdata[0] = ( ch_num + 1 ) + 0x30;
Kujira 0:1977c2310ef7 1175 i2c.write( addr_gu, wdata, 1);
Kujira 0:1977c2310ef7 1176
Kujira 0:1977c2310ef7 1177 //gu_button_up(32);
Kujira 0:1977c2310ef7 1178
Kujira 0:1977c2310ef7 1179 wait(0.1);
Kujira 0:1977c2310ef7 1180
Kujira 0:1977c2310ef7 1181 break;
Kujira 0:1977c2310ef7 1182
Kujira 0:1977c2310ef7 1183 /*
Kujira 0:1977c2310ef7 1184 case 0x1F ://sw32 CH選択
Kujira 0:1977c2310ef7 1185
Kujira 0:1977c2310ef7 1186 //gu_reverse(0x01);//gu_リバース指定
Kujira 0:1977c2310ef7 1187 //gu_button_down(32);
Kujira 0:1977c2310ef7 1188 //gu_reverse(0x00);//gu_リバース解除
Kujira 0:1977c2310ef7 1189
Kujira 0:1977c2310ef7 1190 if ( ch_num >= 1 )
Kujira 0:1977c2310ef7 1191 ch_num = ch_num - 1;
Kujira 0:1977c2310ef7 1192
Kujira 0:1977c2310ef7 1193 select_ich(ch_num);//ADC測定CHの変更
Kujira 0:1977c2310ef7 1194
Kujira 0:1977c2310ef7 1195 //set measuring range
Kujira 0:1977c2310ef7 1196 for( i = 0; i <= 3; i++)
Kujira 0:1977c2310ef7 1197 range[i] = 0;
Kujira 0:1977c2310ef7 1198
Kujira 0:1977c2310ef7 1199 range[ ch_num ] = 1; //range 10uA
Kujira 0:1977c2310ef7 1200
Kujira 0:1977c2310ef7 1201 //選択測定チャンネルの表示
Kujira 0:1977c2310ef7 1202 gu_cursor(24, 2);
Kujira 0:1977c2310ef7 1203 wdata[0] =( ch_num + 1 ) + 0x30;
Kujira 0:1977c2310ef7 1204 i2c.write( addr_gu, wdata, 1);
Kujira 0:1977c2310ef7 1205
Kujira 0:1977c2310ef7 1206 //gu_button_down(32);
Kujira 0:1977c2310ef7 1207
Kujira 0:1977c2310ef7 1208 wait(0.1);
Kujira 0:1977c2310ef7 1209
Kujira 0:1977c2310ef7 1210 break;
Kujira 0:1977c2310ef7 1211 */
Kujira 0:1977c2310ef7 1212
Kujira 0:1977c2310ef7 1213 } //switch
Kujira 0:1977c2310ef7 1214 Jyushin = i2c.read ((addr_gu + 0x01), crdata, 3, true);
Kujira 0:1977c2310ef7 1215
Kujira 0:1977c2310ef7 1216 }//if
Kujira 0:1977c2310ef7 1217 }//if
Kujira 0:1977c2310ef7 1218
Kujira 0:1977c2310ef7 1219 //ver1.1.0
Kujira 0:1977c2310ef7 1220 if ( j >= 5 ) {
Kujira 0:1977c2310ef7 1221 io[ch_num] = 0;
Kujira 0:1977c2310ef7 1222 range[ ch_num ] = 1; //range 10uA
Kujira 0:1977c2310ef7 1223 r_flag = 0;
Kujira 0:1977c2310ef7 1224 j = 0;
Kujira 0:1977c2310ef7 1225 flipper.attach(&flip, interval);//割込み開始
Kujira 0:1977c2310ef7 1226 }
Kujira 0:1977c2310ef7 1227
Kujira 0:1977c2310ef7 1228 if ( r_flag == 1 ) {
Kujira 0:1977c2310ef7 1229 j = j + 1;
Kujira 0:1977c2310ef7 1230
Kujira 0:1977c2310ef7 1231 //R=Hの時の電流測定(1ma renge)
Kujira 0:1977c2310ef7 1232 select_ich( ch_num );
Kujira 0:1977c2310ef7 1233 ssdata = read_adc( addr_ADC3 );
Kujira 0:1977c2310ef7 1234 ima = ssdata * 5 * 0.25;
Kujira 0:1977c2310ef7 1235
Kujira 0:1977c2310ef7 1236 gu_cursor(0,4);
Kujira 0:1977c2310ef7 1237 gu_fontsize(2);
Kujira 0:1977c2310ef7 1238 gu_print1(" ");
Kujira 0:1977c2310ef7 1239 gu_putdeci_mA(&ima);
Kujira 0:1977c2310ef7 1240 }
Kujira 0:1977c2310ef7 1241
Kujira 0:1977c2310ef7 1242 //電圧測定
Kujira 0:1977c2310ef7 1243 //ver1.2.0
Kujira 0:1977c2310ef7 1244 if (RL_EN == 1) {
Kujira 0:1977c2310ef7 1245 switch (ch_num) {
Kujira 0:1977c2310ef7 1246 case 0:
Kujira 0:1977c2310ef7 1247 io[4] = 1; //外付けリレーON
Kujira 0:1977c2310ef7 1248 wait(TIME_RELAY_ON);
Kujira 0:1977c2310ef7 1249 break;
Kujira 0:1977c2310ef7 1250 case 1:
Kujira 0:1977c2310ef7 1251 io[5] = 1; //外付けリレーON
Kujira 0:1977c2310ef7 1252 wait(TIME_RELAY_ON);
Kujira 0:1977c2310ef7 1253 break;
Kujira 0:1977c2310ef7 1254 }
Kujira 0:1977c2310ef7 1255 }
Kujira 0:1977c2310ef7 1256 //up to here
Kujira 0:1977c2310ef7 1257
Kujira 0:1977c2310ef7 1258 sdata = meas_voltage( ch_num ) * -1 ;
Kujira 0:1977c2310ef7 1259
Kujira 0:1977c2310ef7 1260 //ver1.2.0
Kujira 0:1977c2310ef7 1261 if (RL_EN == 1) {
Kujira 0:1977c2310ef7 1262 io[4] = 0; //外付けリレーOFF
Kujira 0:1977c2310ef7 1263 io[5] = 0; //外付けリレーOFF
Kujira 0:1977c2310ef7 1264 }
Kujira 0:1977c2310ef7 1265 //up to here
Kujira 0:1977c2310ef7 1266
Kujira 0:1977c2310ef7 1267 gu_fontsize(2);
Kujira 0:1977c2310ef7 1268 gu_cursor(108,4);
Kujira 0:1977c2310ef7 1269 gu_putdeck(&sdata);
Kujira 0:1977c2310ef7 1270 gu_print1("V");
Kujira 0:1977c2310ef7 1271
Kujira 0:1977c2310ef7 1272 //抵抗測定
Kujira 0:1977c2310ef7 1273 sdata = meas_resistor( ch_num );
Kujira 0:1977c2310ef7 1274
Kujira 0:1977c2310ef7 1275 gu_fontsize(2);
Kujira 0:1977c2310ef7 1276 gu_cursor(192,4);
Kujira 0:1977c2310ef7 1277
Kujira 0:1977c2310ef7 1278 display_resistor( sdata ); //抵抗値表示サブ
Kujira 0:1977c2310ef7 1279
Kujira 0:1977c2310ef7 1280 wait( 0.1 );
Kujira 0:1977c2310ef7 1281
Kujira 0:1977c2310ef7 1282 }//While
Kujira 0:1977c2310ef7 1283 }
Kujira 0:1977c2310ef7 1284
Kujira 0:1977c2310ef7 1285 /*****************************
Kujira 0:1977c2310ef7 1286
Kujira 0:1977c2310ef7 1287 I2C General Call
Kujira 0:1977c2310ef7 1288
Kujira 0:1977c2310ef7 1289 *****************************/
Kujira 0:1977c2310ef7 1290 void general_call(char com)
Kujira 0:1977c2310ef7 1291 {
Kujira 0:1977c2310ef7 1292 char cmd[1];
Kujira 0:1977c2310ef7 1293
Kujira 0:1977c2310ef7 1294 cmd[0]= com;
Kujira 0:1977c2310ef7 1295 i2c.write(0x00, cmd, 1); //General Call
Kujira 0:1977c2310ef7 1296 }
Kujira 0:1977c2310ef7 1297 /*******************************************************************************
Kujira 0:1977c2310ef7 1298
Kujira 0:1977c2310ef7 1299 MAIN
Kujira 0:1977c2310ef7 1300
Kujira 0:1977c2310ef7 1301 *******************************************************************************/
Kujira 0:1977c2310ef7 1302 int main(void)
Kujira 0:1977c2310ef7 1303 {
Kujira 0:1977c2310ef7 1304 while(1) {
Kujira 0:1977c2310ef7 1305
Kujira 0:1977c2310ef7 1306 wait(0.2);
Kujira 0:1977c2310ef7 1307
Kujira 0:1977c2310ef7 1308 set_pullup();
Kujira 0:1977c2310ef7 1309
Kujira 0:1977c2310ef7 1310 general_call(0x06); //ADC power on reset
Kujira 0:1977c2310ef7 1311
Kujira 0:1977c2310ef7 1312 dac_init(); //DAC 初期化
Kujira 0:1977c2310ef7 1313
Kujira 0:1977c2310ef7 1314 gu_initial();//初期画面へ
Kujira 0:1977c2310ef7 1315 //utility();
Kujira 0:1977c2310ef7 1316 }
Kujira 0:1977c2310ef7 1317 } //main end
Kujira 0:1977c2310ef7 1318
Kujira 0:1977c2310ef7 1319 void gu_initial()
Kujira 0:1977c2310ef7 1320 {
Kujira 0:1977c2310ef7 1321 char cmd_gu[32] ; //gu-DへのI2Cコマンド用配列 1byte0
Kujira 0:1977c2310ef7 1322 //char *pcmd = cmd_gu;
Kujira 0:1977c2310ef7 1323 char clumi; //輝度設定用変数 01h<=n<=08h
Kujira 0:1977c2310ef7 1324 char* pclumi = &clumi; //ポインタの定義
Kujira 0:1977c2310ef7 1325 char crdata[3];
Kujira 0:1977c2310ef7 1326 char cswnum; //SW_No. sw1->0x00 ~~ sw32->0x1F
Kujira 0:1977c2310ef7 1327 char cswdata; // 0x00 or 0x01
Kujira 0:1977c2310ef7 1328 char *pcswnum = &cswnum;
Kujira 0:1977c2310ef7 1329 char *pcswdata = &cswdata;
Kujira 0:1977c2310ef7 1330 char csyoudo[4];
Kujira 0:1977c2310ef7 1331 int i;
Kujira 0:1977c2310ef7 1332 float duty_pwm;
Kujira 0:1977c2310ef7 1333
Kujira 0:1977c2310ef7 1334
Kujira 0:1977c2310ef7 1335 for ( i = 0; i <= ( number_of_channels - 1 ); i++) {
Kujira 0:1977c2310ef7 1336 leds[i].period_us(period_pwm); //Set tha PWM period(us)
Kujira 0:1977c2310ef7 1337 }
Kujira 0:1977c2310ef7 1338
Kujira 0:1977c2310ef7 1339
Kujira 0:1977c2310ef7 1340 duty_pwm = 0; //表示器立ち上がるまでLEDOFF
Kujira 0:1977c2310ef7 1341
Kujira 0:1977c2310ef7 1342 for( i = 0; i <= 3; i++) {
Kujira 0:1977c2310ef7 1343 leds[i].write(duty_pwm);//Set Duty
Kujira 0:1977c2310ef7 1344 }
Kujira 0:1977c2310ef7 1345
Kujira 0:1977c2310ef7 1346
Kujira 0:1977c2310ef7 1347 i2c.frequency(100000); //gu_D I2Cクロックレート(HZ) 400khz以下
Kujira 0:1977c2310ef7 1348
Kujira 0:1977c2310ef7 1349 cmd_gu[0]= 0x1B;
Kujira 0:1977c2310ef7 1350 cmd_gu[1]= 0x40;
Kujira 0:1977c2310ef7 1351 i2c.write(addr_gu, cmd_gu, 2); //gu-D ESC 初期化
Kujira 0:1977c2310ef7 1352 wait(0.2);
Kujira 0:1977c2310ef7 1353
Kujira 0:1977c2310ef7 1354 //メモリ00h番地(GU_D輝度設定データ)読み出し
Kujira 0:1977c2310ef7 1355 wdata[0] = 0x00;
Kujira 0:1977c2310ef7 1356 Soushin = i2c.write (fixed_adrs, wdata, 1,true); //読込先頭アドレス指定 ReStart
Kujira 0:1977c2310ef7 1357 Jyushin = i2c.read ((fixed_adrs + 0x01), rdata, 1);//read 1byte
Kujira 0:1977c2310ef7 1358 *pclumi = rdata[0];
Kujira 0:1977c2310ef7 1359 //輝度設定更新
Kujira 0:1977c2310ef7 1360 if(*pclumi==0x00 || *pclumi > 0x08) *pclumi=0x05;
Kujira 0:1977c2310ef7 1361 gu_luminance(pclumi);
Kujira 0:1977c2310ef7 1362
Kujira 0:1977c2310ef7 1363 gu_fontsize(2); //change fontsize
Kujira 0:1977c2310ef7 1364 //ver1.2.3
Kujira 0:1977c2310ef7 1365 //gu_print1("ILF Iop/Voc/O.C.P/R");
Kujira 0:1977c2310ef7 1366 gu_print1("ILF mode selectiion");
Kujira 0:1977c2310ef7 1367 //upto
Kujira 0:1977c2310ef7 1368 //gu_CRLF();//CR+LF
Kujira 0:1977c2310ef7 1369 //gu_print1("Settings");
Kujira 0:1977c2310ef7 1370 gu_fontsize(1);
Kujira 0:1977c2310ef7 1371 gu_cursor(192,1);
Kujira 0:1977c2310ef7 1372 gu_print1("ver");
Kujira 0:1977c2310ef7 1373 gu_onebyte( version_major + 0x30 );
Kujira 0:1977c2310ef7 1374 gu_print1(".");
Kujira 0:1977c2310ef7 1375 gu_onebyte( version_minor + 0x30 );
Kujira 0:1977c2310ef7 1376 gu_print1(".");
Kujira 0:1977c2310ef7 1377 gu_onebyte( version_build + 0x30 );
Kujira 0:1977c2310ef7 1378
Kujira 0:1977c2310ef7 1379 gu_touchPara(0,touch);//タッチ感度 00h~07h
Kujira 0:1977c2310ef7 1380
Kujira 0:1977c2310ef7 1381 //MODE選択用ボタンの表示
Kujira 0:1977c2310ef7 1382 gu_set_button(9,"");
Kujira 0:1977c2310ef7 1383 gu_set_button(17,"");
Kujira 0:1977c2310ef7 1384 gu_set_button(25,"");
Kujira 0:1977c2310ef7 1385 gu_set_button(13,"");
Kujira 0:1977c2310ef7 1386 gu_set_button(21,"");
Kujira 0:1977c2310ef7 1387 gu_set_button(29,"");
Kujira 0:1977c2310ef7 1388 //LED Brighness
Kujira 0:1977c2310ef7 1389 gu_fontsize(2);
Kujira 0:1977c2310ef7 1390 gu_cursor(36,32/8);
Kujira 0:1977c2310ef7 1391 gu_print1("CAL");
Kujira 0:1977c2310ef7 1392 gu_cursor(36,64/8);
Kujira 0:1977c2310ef7 1393 gu_print1("LUX");
Kujira 0:1977c2310ef7 1394 //gu_cursor(36,80/8);
Kujira 0:1977c2310ef7 1395 //gu_print1("illumi");
Kujira 0:1977c2310ef7 1396 //Display Brightness
Kujira 0:1977c2310ef7 1397 gu_cursor(36,96/8);
Kujira 0:1977c2310ef7 1398 gu_print1("Utility");
Kujira 0:1977c2310ef7 1399 //Auto MODE
Kujira 0:1977c2310ef7 1400 gu_cursor(164,32/8);
Kujira 0:1977c2310ef7 1401 gu_print1("Auto");
Kujira 0:1977c2310ef7 1402 //Manual Mode
Kujira 0:1977c2310ef7 1403 gu_cursor(164,64/8);
Kujira 0:1977c2310ef7 1404 gu_print1("Manual");
Kujira 0:1977c2310ef7 1405 //Sequenser Mode
Kujira 0:1977c2310ef7 1406 gu_cursor(164,96/8);
Kujira 0:1977c2310ef7 1407 gu_print1("SEQ");
Kujira 0:1977c2310ef7 1408
Kujira 0:1977c2310ef7 1409 /**********************
Kujira 0:1977c2310ef7 1410 SDカードファイルオープン
Kujira 0:1977c2310ef7 1411 **********************/
Kujira 0:1977c2310ef7 1412
Kujira 0:1977c2310ef7 1413 mkdir("/sd/mydir", 0777);
Kujira 0:1977c2310ef7 1414
Kujira 0:1977c2310ef7 1415 FILE *fp = fopen("/sd/mydir/iop.csv", "ab+");//ディレクトリとファイル名の指定
Kujira 0:1977c2310ef7 1416
Kujira 0:1977c2310ef7 1417 if(fp == NULL) {
Kujira 0:1977c2310ef7 1418 /*ver1.1.3
Kujira 0:1977c2310ef7 1419 gu_fontsize(1);
Kujira 0:1977c2310ef7 1420 gu_cursor(0,2);
Kujira 0:1977c2310ef7 1421 gu_print1("Could not open file for SD card");
Kujira 0:1977c2310ef7 1422 */
Kujira 0:1977c2310ef7 1423 } else {
Kujira 0:1977c2310ef7 1424 fprintf(fp, "NewData R IOP OCP VOC");
Kujira 0:1977c2310ef7 1425 fprintf(fp, "\n");
Kujira 0:1977c2310ef7 1426 fclose(fp);
Kujira 0:1977c2310ef7 1427 }
Kujira 0:1977c2310ef7 1428 /**********************
Kujira 0:1977c2310ef7 1429 LED照度初期設定
Kujira 0:1977c2310ef7 1430 **********************/
Kujira 0:1977c2310ef7 1431 read_syoudo( csyoudo );
Kujira 0:1977c2310ef7 1432
Kujira 0:1977c2310ef7 1433 //gu-D タッチスイッチ読み出し動作設定 p49
Kujira 0:1977c2310ef7 1434 cmd_gu[0]= 0x1F;
Kujira 0:1977c2310ef7 1435 cmd_gu[1]= 0x4B;
Kujira 0:1977c2310ef7 1436 cmd_gu[2]= 0x18;
Kujira 0:1977c2310ef7 1437 cmd_gu[3]= 0x02;//SW状態変化時自動送信モード2
Kujira 0:1977c2310ef7 1438 i2c.write(addr_gu, cmd_gu, 4); //gu-D タッチスイッチ読み出し動作設定 p49
Kujira 0:1977c2310ef7 1439
Kujira 0:1977c2310ef7 1440 while(1) {
Kujira 0:1977c2310ef7 1441 //タッチスイッチ読み出し
Kujira 0:1977c2310ef7 1442 i2c.read ((addr_gu + 0x01), crdata, 3, true);
Kujira 0:1977c2310ef7 1443
Kujira 0:1977c2310ef7 1444 if (crdata[0] == 0x11 ) { //個別タッチスイッチ状態読み出しフォーマット。識別子11h。
Kujira 0:1977c2310ef7 1445 *pcswnum = crdata[1]; //スイッチ番号
Kujira 0:1977c2310ef7 1446 *pcswdata = crdata[2];//ON/OFF情報
Kujira 0:1977c2310ef7 1447
Kujira 0:1977c2310ef7 1448 if (cswdata == 0x01) { //タッチしたならば
Kujira 0:1977c2310ef7 1449 switch( cswnum ) { //SWの番号(位置)
Kujira 0:1977c2310ef7 1450
Kujira 0:1977c2310ef7 1451 case 0x08 ://SW9 CAL登録画面
Kujira 0:1977c2310ef7 1452 //gu_リバース指定
Kujira 0:1977c2310ef7 1453 gu_reverse(0x01);
Kujira 0:1977c2310ef7 1454 //Show Button
Kujira 0:1977c2310ef7 1455 gu_set_button(9,"");
Kujira 0:1977c2310ef7 1456 wait(0.1);
Kujira 0:1977c2310ef7 1457 //gu_リバース解除
Kujira 0:1977c2310ef7 1458 gu_reverse(0x00);
Kujira 0:1977c2310ef7 1459
Kujira 0:1977c2310ef7 1460 select_cal();//CAL選択画面へ移動
Kujira 0:1977c2310ef7 1461
Kujira 0:1977c2310ef7 1462 return;
Kujira 0:1977c2310ef7 1463
Kujira 0:1977c2310ef7 1464 case 0x10 ://SW17
Kujira 0:1977c2310ef7 1465 //gu_リバース指定
Kujira 0:1977c2310ef7 1466 gu_reverse(0x01);
Kujira 0:1977c2310ef7 1467 //Show Button
Kujira 0:1977c2310ef7 1468 gu_set_button(17,"");
Kujira 0:1977c2310ef7 1469 wait(0.1);
Kujira 0:1977c2310ef7 1470 //gu_リバース解除
Kujira 0:1977c2310ef7 1471 gu_reverse(0x00);
Kujira 0:1977c2310ef7 1472
Kujira 0:1977c2310ef7 1473 adjust_illumination();//LED照度調整へ移動
Kujira 0:1977c2310ef7 1474
Kujira 0:1977c2310ef7 1475 return;
Kujira 0:1977c2310ef7 1476
Kujira 0:1977c2310ef7 1477 case 0x18 ://SW25
Kujira 0:1977c2310ef7 1478 //gu_リバース指定
Kujira 0:1977c2310ef7 1479 gu_reverse(0x01);
Kujira 0:1977c2310ef7 1480 //Show Button
Kujira 0:1977c2310ef7 1481 gu_set_button(25,"");
Kujira 0:1977c2310ef7 1482 wait(0.1);
Kujira 0:1977c2310ef7 1483 //gu_リバース解除
Kujira 0:1977c2310ef7 1484 gu_reverse(0x00);
Kujira 0:1977c2310ef7 1485
Kujira 0:1977c2310ef7 1486 utility();//画面輝度調整へ移動
Kujira 0:1977c2310ef7 1487
Kujira 0:1977c2310ef7 1488 return;
Kujira 0:1977c2310ef7 1489
Kujira 0:1977c2310ef7 1490 case 0x0C ://SW13 自動測定モード
Kujira 0:1977c2310ef7 1491 //gu_リバース指定
Kujira 0:1977c2310ef7 1492 gu_reverse(0x01);
Kujira 0:1977c2310ef7 1493 //Show Button
Kujira 0:1977c2310ef7 1494 gu_set_button(13,"");
Kujira 0:1977c2310ef7 1495 wait(0.1);
Kujira 0:1977c2310ef7 1496 //gu_リバース解除
Kujira 0:1977c2310ef7 1497 gu_reverse(0x00);
Kujira 0:1977c2310ef7 1498
Kujira 0:1977c2310ef7 1499 auto_run();
Kujira 0:1977c2310ef7 1500
Kujira 0:1977c2310ef7 1501 return;
Kujira 0:1977c2310ef7 1502
Kujira 0:1977c2310ef7 1503 case 0x14 ://SW21 手動測定モード
Kujira 0:1977c2310ef7 1504 //gu_リバース指定
Kujira 0:1977c2310ef7 1505 gu_reverse(0x01);
Kujira 0:1977c2310ef7 1506 //Show Button
Kujira 0:1977c2310ef7 1507 gu_set_button(21,"");
Kujira 0:1977c2310ef7 1508 wait(0.1);
Kujira 0:1977c2310ef7 1509 //gu_リバース解除
Kujira 0:1977c2310ef7 1510 gu_reverse(0x00);
Kujira 0:1977c2310ef7 1511
Kujira 0:1977c2310ef7 1512 manual();
Kujira 0:1977c2310ef7 1513
Kujira 0:1977c2310ef7 1514 return;
Kujira 0:1977c2310ef7 1515
Kujira 0:1977c2310ef7 1516 case 0x1C ://SW29 シーケンサ制御モード
Kujira 0:1977c2310ef7 1517 //gu_リバース指定
Kujira 0:1977c2310ef7 1518 gu_reverse(0x01);
Kujira 0:1977c2310ef7 1519 //Show Button
Kujira 0:1977c2310ef7 1520 gu_set_button(29,"");
Kujira 0:1977c2310ef7 1521 wait(0.1);
Kujira 0:1977c2310ef7 1522 //gu_リバース解除
Kujira 0:1977c2310ef7 1523 gu_reverse(0x00);
Kujira 0:1977c2310ef7 1524
Kujira 0:1977c2310ef7 1525 seq();
Kujira 0:1977c2310ef7 1526
Kujira 0:1977c2310ef7 1527 return;
Kujira 0:1977c2310ef7 1528
Kujira 0:1977c2310ef7 1529 } //switch
Kujira 0:1977c2310ef7 1530
Kujira 0:1977c2310ef7 1531 }//if(cswdata == 0x01) {
Kujira 0:1977c2310ef7 1532 } //if(crdata[0] == 0x11 ) {
Kujira 0:1977c2310ef7 1533
Kujira 0:1977c2310ef7 1534 wait(0.1);//タッチスイッチ入力読み出し間隔
Kujira 0:1977c2310ef7 1535
Kujira 0:1977c2310ef7 1536 } //while(1) {
Kujira 0:1977c2310ef7 1537
Kujira 0:1977c2310ef7 1538 }
Kujira 0:1977c2310ef7 1539
Kujira 0:1977c2310ef7 1540 /*********************************
Kujira 0:1977c2310ef7 1541
Kujira 0:1977c2310ef7 1542 CAL選択画面 sub
Kujira 0:1977c2310ef7 1543
Kujira 0:1977c2310ef7 1544 *********************************/
Kujira 0:1977c2310ef7 1545 void show_info(int n)
Kujira 0:1977c2310ef7 1546 {
Kujira 0:1977c2310ef7 1547 short sdata[6];
Kujira 0:1977c2310ef7 1548
Kujira 0:1977c2310ef7 1549 read_caliber(&calinfo,n);
Kujira 0:1977c2310ef7 1550
Kujira 0:1977c2310ef7 1551 //読出したCAL情報の表示
Kujira 0:1977c2310ef7 1552 gu_fontsize(1);
Kujira 0:1977c2310ef7 1553 gu_cursor(0,2);
Kujira 0:1977c2310ef7 1554 gu_print1("No.");
Kujira 0:1977c2310ef7 1555 gu_putdec(&calinfo.number);
Kujira 0:1977c2310ef7 1556 gu_cursor(0,3);
Kujira 0:1977c2310ef7 1557 gu_print1("Vss(Iop) =");
Kujira 0:1977c2310ef7 1558 sdata[0] = -1 * calinfo.vss_iop;
Kujira 0:1977c2310ef7 1559 gu_putdeck(&sdata[0]);
Kujira 0:1977c2310ef7 1560 gu_print1("V ");
Kujira 0:1977c2310ef7 1561 gu_cursor(0,4);
Kujira 0:1977c2310ef7 1562 gu_print1("Vss(ocp) =");
Kujira 0:1977c2310ef7 1563 sdata[1] = -1 * calinfo.vss_ocp;
Kujira 0:1977c2310ef7 1564 gu_putdeck(&sdata[1]);
Kujira 0:1977c2310ef7 1565 gu_print1("V ");
Kujira 0:1977c2310ef7 1566 gu_cursor(0,5);
Kujira 0:1977c2310ef7 1567 gu_print1("Vss(Voc) =");
Kujira 0:1977c2310ef7 1568 sdata[2] = -1 * calinfo.vss_voc;
Kujira 0:1977c2310ef7 1569 gu_putdeck(&sdata[2]);
Kujira 0:1977c2310ef7 1570 gu_print1("V ");
Kujira 0:1977c2310ef7 1571 }
Kujira 0:1977c2310ef7 1572 /*********************************
Kujira 0:1977c2310ef7 1573
Kujira 0:1977c2310ef7 1574 CAL選択画面 #CAL登録画面
Kujira 0:1977c2310ef7 1575
Kujira 0:1977c2310ef7 1576 *********************************/
Kujira 0:1977c2310ef7 1577 void select_cal()
Kujira 0:1977c2310ef7 1578 {
Kujira 0:1977c2310ef7 1579 char crdata[3];
Kujira 0:1977c2310ef7 1580 char cswnum; //SW_No. sw1->0x00 ~~ sw32->0x1F
Kujira 0:1977c2310ef7 1581 char cswdata; // 0x00 or 0x01
Kujira 0:1977c2310ef7 1582 char *pcswnum = &cswnum;
Kujira 0:1977c2310ef7 1583 char *pcswdata = &cswdata;
Kujira 0:1977c2310ef7 1584 char calnum; //選択したCALナンバー
Kujira 0:1977c2310ef7 1585 //short sdata[3]; //印加電圧表示用wr
Kujira 0:1977c2310ef7 1586
Kujira 0:1977c2310ef7 1587 calnum = 0;//initial
Kujira 0:1977c2310ef7 1588
Kujira 0:1977c2310ef7 1589 gu_cls();
Kujira 0:1977c2310ef7 1590
Kujira 0:1977c2310ef7 1591 read_regnum();//EEPROMに保存した選択CAL_NO.の読み出し
Kujira 0:1977c2310ef7 1592
Kujira 0:1977c2310ef7 1593 show_info(reg_num);
Kujira 0:1977c2310ef7 1594
Kujira 0:1977c2310ef7 1595 /*
Kujira 0:1977c2310ef7 1596 read_caliber(&calinfo,reg_num);
Kujira 0:1977c2310ef7 1597
Kujira 0:1977c2310ef7 1598 //読出したCAL情報の表示
Kujira 0:1977c2310ef7 1599 gu_fontsize(1);
Kujira 0:1977c2310ef7 1600 gu_cursor(0,2);
Kujira 0:1977c2310ef7 1601 gu_print1("No.");
Kujira 0:1977c2310ef7 1602 gu_putdec(&calinfo.number);
Kujira 0:1977c2310ef7 1603 gu_cursor(0,3);
Kujira 0:1977c2310ef7 1604 gu_print1("Vss(Iop) =");
Kujira 0:1977c2310ef7 1605 sdata[0] = -1 * calinfo.vss_iop;
Kujira 0:1977c2310ef7 1606 gu_putdeck(&sdata[0]);
Kujira 0:1977c2310ef7 1607 gu_print1("V ");
Kujira 0:1977c2310ef7 1608 gu_cursor(0,4);
Kujira 0:1977c2310ef7 1609 gu_print1("Vss(ocp) =");
Kujira 0:1977c2310ef7 1610 sdata[1] = -1 * calinfo.vss_ocp;
Kujira 0:1977c2310ef7 1611 gu_putdeck(&sdata[1]);
Kujira 0:1977c2310ef7 1612 gu_print1("V ");
Kujira 0:1977c2310ef7 1613 gu_cursor(0,5);
Kujira 0:1977c2310ef7 1614 gu_print1("Vss(Voc) =");
Kujira 0:1977c2310ef7 1615 sdata[2] = -1 * calinfo.vss_voc;
Kujira 0:1977c2310ef7 1616 gu_putdeck(&sdata[2]);
Kujira 0:1977c2310ef7 1617 gu_print1("V ");
Kujira 0:1977c2310ef7 1618 */
Kujira 0:1977c2310ef7 1619
Kujira 0:1977c2310ef7 1620 gu_fontsize(2); //change fontsize
Kujira 0:1977c2310ef7 1621 gu_cursor(0,0);
Kujira 0:1977c2310ef7 1622 gu_print1("Select CAL.");
Kujira 0:1977c2310ef7 1623 //Set Button
Kujira 0:1977c2310ef7 1624 gu_set_button(17,"1");
Kujira 0:1977c2310ef7 1625 gu_set_button(19,"2");
Kujira 0:1977c2310ef7 1626 gu_set_button(21,"3");
Kujira 0:1977c2310ef7 1627 gu_set_button(25,"4");
Kujira 0:1977c2310ef7 1628 gu_set_button(27,"5");
Kujira 0:1977c2310ef7 1629 gu_set_button(29,"6");
Kujira 0:1977c2310ef7 1630 gu_set_button_font1(7,"slct");
Kujira 0:1977c2310ef7 1631 gu_set_button_font1(8,"reg");
Kujira 0:1977c2310ef7 1632 //gu_set_button_font1(32,"del"); //ver1.1.0
Kujira 0:1977c2310ef7 1633
Kujira 0:1977c2310ef7 1634
Kujira 0:1977c2310ef7 1635 while(1) {
Kujira 0:1977c2310ef7 1636 //タッチスイッチ読み出し
Kujira 0:1977c2310ef7 1637 i2c.read ((addr_gu + 0x01), crdata, 3, true);
Kujira 0:1977c2310ef7 1638
Kujira 0:1977c2310ef7 1639 if (crdata[0] == 0x11 ) { //個別タッチスイッチ状態読み出しフォーマット。識別子11h。
Kujira 0:1977c2310ef7 1640 *pcswnum = crdata[1]; //スイッチ番号
Kujira 0:1977c2310ef7 1641 *pcswdata = crdata[2];//ON/OFF情報
Kujira 0:1977c2310ef7 1642
Kujira 0:1977c2310ef7 1643 if (cswdata == 0x01) { //タッチしたならば
Kujira 0:1977c2310ef7 1644 switch( cswnum ) { //SWの番号(位置)
Kujira 0:1977c2310ef7 1645
Kujira 0:1977c2310ef7 1646 case 0x10: //SW17
Kujira 0:1977c2310ef7 1647
Kujira 0:1977c2310ef7 1648 gu_reverse(0x01); //gu_リバース指定
Kujira 0:1977c2310ef7 1649 gu_set_button(17,"1");
Kujira 0:1977c2310ef7 1650 gu_reverse(0x00); //gu_リバース解除
Kujira 0:1977c2310ef7 1651 gu_set_button(19,"2");
Kujira 0:1977c2310ef7 1652 gu_set_button(21,"3");
Kujira 0:1977c2310ef7 1653 gu_set_button(25,"4");
Kujira 0:1977c2310ef7 1654 gu_set_button(27,"5");
Kujira 0:1977c2310ef7 1655 gu_set_button(29,"6");
Kujira 0:1977c2310ef7 1656
Kujira 0:1977c2310ef7 1657 calnum = 1;
Kujira 0:1977c2310ef7 1658
Kujira 0:1977c2310ef7 1659 show_info(calnum);
Kujira 0:1977c2310ef7 1660
Kujira 0:1977c2310ef7 1661 break;
Kujira 0:1977c2310ef7 1662
Kujira 0:1977c2310ef7 1663 case 0x12: //SW19
Kujira 0:1977c2310ef7 1664
Kujira 0:1977c2310ef7 1665 gu_reverse(0x01); //gu_リバース指定
Kujira 0:1977c2310ef7 1666 gu_set_button(19,"2");
Kujira 0:1977c2310ef7 1667 gu_reverse(0x00); //gu_リバース解除
Kujira 0:1977c2310ef7 1668 gu_set_button(17,"1");
Kujira 0:1977c2310ef7 1669 gu_set_button(21,"3");
Kujira 0:1977c2310ef7 1670 gu_set_button(25,"4");
Kujira 0:1977c2310ef7 1671 gu_set_button(27,"5");
Kujira 0:1977c2310ef7 1672 gu_set_button(29,"6");
Kujira 0:1977c2310ef7 1673
Kujira 0:1977c2310ef7 1674 calnum = 2;
Kujira 0:1977c2310ef7 1675
Kujira 0:1977c2310ef7 1676 show_info(calnum);
Kujira 0:1977c2310ef7 1677
Kujira 0:1977c2310ef7 1678 break;
Kujira 0:1977c2310ef7 1679
Kujira 0:1977c2310ef7 1680 case 0x14: //SW21
Kujira 0:1977c2310ef7 1681
Kujira 0:1977c2310ef7 1682 gu_reverse(0x01); //gu_リバース指定
Kujira 0:1977c2310ef7 1683 gu_set_button(21,"3");
Kujira 0:1977c2310ef7 1684 gu_reverse(0x00); //gu_リバース解除
Kujira 0:1977c2310ef7 1685 gu_set_button(17,"1");
Kujira 0:1977c2310ef7 1686 gu_set_button(19,"2");
Kujira 0:1977c2310ef7 1687 //gu_set_button(21,"3");
Kujira 0:1977c2310ef7 1688 gu_set_button(25,"4");
Kujira 0:1977c2310ef7 1689 gu_set_button(27,"5");
Kujira 0:1977c2310ef7 1690 gu_set_button(29,"6");
Kujira 0:1977c2310ef7 1691
Kujira 0:1977c2310ef7 1692 calnum = 3;
Kujira 0:1977c2310ef7 1693
Kujira 0:1977c2310ef7 1694 show_info(calnum);
Kujira 0:1977c2310ef7 1695
Kujira 0:1977c2310ef7 1696 break;
Kujira 0:1977c2310ef7 1697
Kujira 0:1977c2310ef7 1698 case 0x18: //SW25
Kujira 0:1977c2310ef7 1699
Kujira 0:1977c2310ef7 1700 gu_reverse(0x01); //gu_リバース指定
Kujira 0:1977c2310ef7 1701 gu_set_button(25,"4");
Kujira 0:1977c2310ef7 1702 gu_reverse(0x00); //gu_リバース解除
Kujira 0:1977c2310ef7 1703 gu_set_button(17,"1");
Kujira 0:1977c2310ef7 1704 gu_set_button(19,"2");
Kujira 0:1977c2310ef7 1705 gu_set_button(21,"3");
Kujira 0:1977c2310ef7 1706 //gu_set_button(25,"4");
Kujira 0:1977c2310ef7 1707 gu_set_button(27,"5");
Kujira 0:1977c2310ef7 1708 gu_set_button(29,"6");
Kujira 0:1977c2310ef7 1709
Kujira 0:1977c2310ef7 1710 calnum = 4;
Kujira 0:1977c2310ef7 1711
Kujira 0:1977c2310ef7 1712 show_info(calnum);
Kujira 0:1977c2310ef7 1713
Kujira 0:1977c2310ef7 1714 break;
Kujira 0:1977c2310ef7 1715
Kujira 0:1977c2310ef7 1716 case 0x1A: //SW27
Kujira 0:1977c2310ef7 1717
Kujira 0:1977c2310ef7 1718 gu_reverse(0x01); //gu_リバース指定
Kujira 0:1977c2310ef7 1719 gu_set_button(27,"5");
Kujira 0:1977c2310ef7 1720 gu_reverse(0x00); //gu_リバース解除
Kujira 0:1977c2310ef7 1721 gu_set_button(17,"1");
Kujira 0:1977c2310ef7 1722 gu_set_button(19,"2");
Kujira 0:1977c2310ef7 1723 gu_set_button(21,"3");
Kujira 0:1977c2310ef7 1724 gu_set_button(25,"4");
Kujira 0:1977c2310ef7 1725 //gu_set_button(27,"5");
Kujira 0:1977c2310ef7 1726 gu_set_button(29,"6");
Kujira 0:1977c2310ef7 1727
Kujira 0:1977c2310ef7 1728 calnum = 5;
Kujira 0:1977c2310ef7 1729
Kujira 0:1977c2310ef7 1730 show_info(calnum);
Kujira 0:1977c2310ef7 1731
Kujira 0:1977c2310ef7 1732 break;
Kujira 0:1977c2310ef7 1733
Kujira 0:1977c2310ef7 1734 case 0x1C: //SW29
Kujira 0:1977c2310ef7 1735
Kujira 0:1977c2310ef7 1736 gu_reverse(0x01); //gu_リバース指定
Kujira 0:1977c2310ef7 1737 gu_set_button(29,"6");
Kujira 0:1977c2310ef7 1738 gu_reverse(0x00); //gu_リバース解除
Kujira 0:1977c2310ef7 1739 gu_set_button(17,"1");
Kujira 0:1977c2310ef7 1740 gu_set_button(19,"2");
Kujira 0:1977c2310ef7 1741 gu_set_button(21,"3");
Kujira 0:1977c2310ef7 1742 gu_set_button(25,"4");
Kujira 0:1977c2310ef7 1743 gu_set_button(27,"5");
Kujira 0:1977c2310ef7 1744 //gu_set_button(29,"6");
Kujira 0:1977c2310ef7 1745
Kujira 0:1977c2310ef7 1746 calnum = 6;
Kujira 0:1977c2310ef7 1747
Kujira 0:1977c2310ef7 1748 show_info(calnum);
Kujira 0:1977c2310ef7 1749
Kujira 0:1977c2310ef7 1750 break;
Kujira 0:1977c2310ef7 1751
Kujira 0:1977c2310ef7 1752 case 0x06: //SW7 CAL選択ボタン
Kujira 0:1977c2310ef7 1753
Kujira 0:1977c2310ef7 1754 if ( calnum >= 1 && calnum <=6 ) {
Kujira 0:1977c2310ef7 1755 reg_num = calnum;
Kujira 0:1977c2310ef7 1756
Kujira 0:1977c2310ef7 1757 //EEPROM書込み
Kujira 0:1977c2310ef7 1758 wdata[0] = addr_calnum; //word address 書込み先頭アドレス指定
Kujira 0:1977c2310ef7 1759 wdata[1] = reg_num;
Kujira 0:1977c2310ef7 1760 Soushin = i2c.write (fixed_adrs, wdata, 2);
Kujira 0:1977c2310ef7 1761
Kujira 0:1977c2310ef7 1762 gu_reverse(0x01); //gu_リバース指定
Kujira 0:1977c2310ef7 1763 gu_set_button_font1(7,"slct");
Kujira 0:1977c2310ef7 1764 wait(0.2);
Kujira 0:1977c2310ef7 1765 gu_reverse(0x00); //gu_リバース解除
Kujira 0:1977c2310ef7 1766
Kujira 0:1977c2310ef7 1767 read_caliber(&calinfo,reg_num);
Kujira 0:1977c2310ef7 1768 return;
Kujira 0:1977c2310ef7 1769
Kujira 0:1977c2310ef7 1770 } else if( calnum == 0 ) {
Kujira 0:1977c2310ef7 1771 //CALNo.選択しなければ、何もしないでこのサブを抜ける
Kujira 0:1977c2310ef7 1772 gu_reverse(0x01); //gu_リバース指定
Kujira 0:1977c2310ef7 1773 gu_set_button_font1(7,"slct");
Kujira 0:1977c2310ef7 1774 wait(0.2);
Kujira 0:1977c2310ef7 1775 gu_reverse(0x00); //gu_リバース解除
Kujira 0:1977c2310ef7 1776 return;
Kujira 0:1977c2310ef7 1777 }
Kujira 0:1977c2310ef7 1778
Kujira 0:1977c2310ef7 1779 break;
Kujira 0:1977c2310ef7 1780
Kujira 0:1977c2310ef7 1781 case 0x07: //SW8
Kujira 0:1977c2310ef7 1782
Kujira 0:1977c2310ef7 1783 if ( calnum >= 1 && calnum <= 6 ) {
Kujira 0:1977c2310ef7 1784 gu_reverse(0x01); //gu_リバース指定
Kujira 0:1977c2310ef7 1785 gu_set_button_font1(8,"reg");
Kujira 0:1977c2310ef7 1786 wait(0.2);
Kujira 0:1977c2310ef7 1787 gu_reverse(0x00); //gu_リバース解除
Kujira 0:1977c2310ef7 1788
Kujira 0:1977c2310ef7 1789 setup_cal_information(calnum);//CAL情報登録画面へ
Kujira 0:1977c2310ef7 1790 return;
Kujira 0:1977c2310ef7 1791 }
Kujira 0:1977c2310ef7 1792 break;
Kujira 0:1977c2310ef7 1793
Kujira 0:1977c2310ef7 1794 /*ver1.1.0
Kujira 0:1977c2310ef7 1795 case 0x1F: //SW32
Kujira 0:1977c2310ef7 1796
Kujira 0:1977c2310ef7 1797 gu_reverse(0x01); //gu_リバース指定
Kujira 0:1977c2310ef7 1798 gu_set_button_font1(32,"del");
Kujira 0:1977c2310ef7 1799 gu_reverse(0x00); //gu_リバース解除
Kujira 0:1977c2310ef7 1800
Kujira 0:1977c2310ef7 1801 erace_calinfo();
Kujira 0:1977c2310ef7 1802
Kujira 0:1977c2310ef7 1803 gu_set_button_font1(32,"del");
Kujira 0:1977c2310ef7 1804
Kujira 0:1977c2310ef7 1805 break;
Kujira 0:1977c2310ef7 1806 */
Kujira 0:1977c2310ef7 1807
Kujira 0:1977c2310ef7 1808 } //switch
Kujira 0:1977c2310ef7 1809
Kujira 0:1977c2310ef7 1810 }//if(cswdata == 0x01) {
Kujira 0:1977c2310ef7 1811 } //if(crdata[0] == 0x11 ) {
Kujira 0:1977c2310ef7 1812 wait(0.1);//タッチスイッチ入力読み出し間隔
Kujira 0:1977c2310ef7 1813 } //while(1)
Kujira 0:1977c2310ef7 1814 }
Kujira 0:1977c2310ef7 1815
Kujira 0:1977c2310ef7 1816 /*********************************
Kujira 0:1977c2310ef7 1817
Kujira 0:1977c2310ef7 1818 CAL情報登録画面 サブルーチン
Kujira 0:1977c2310ef7 1819 表示パラメータ
Kujira 0:1977c2310ef7 1820 x=0 : vss_iop[V]
Kujira 0:1977c2310ef7 1821 x=1 : vss_ocp[V]
Kujira 0:1977c2310ef7 1822 x=2 : vss_voc[V]
Kujira 0:1977c2310ef7 1823 x=3 : low_limit_voc[V]
Kujira 0:1977c2310ef7 1824 x=4 : low_limit_iop[uA]
Kujira 0:1977c2310ef7 1825 x=5 : low_limit_ocp[uA]
Kujira 0:1977c2310ef7 1826 x=6 : wait_iop[s]
Kujira 0:1977c2310ef7 1827 x=7 : wait_ocp[s]
Kujira 0:1977c2310ef7 1828 x=8 : low_limit_resistor[Ω]
Kujira 0:1977c2310ef7 1829 x=9 : up_limit_resistor[Ω]
Kujira 0:1977c2310ef7 1830
Kujira 0:1977c2310ef7 1831 ver1.2.2
Kujira 0:1977c2310ef7 1832 up_limit_ocp[]の追加と
Kujira 0:1977c2310ef7 1833 順序の入替え
Kujira 0:1977c2310ef7 1834
Kujira 0:1977c2310ef7 1835 x=6 : up_limit_ocp[]
Kujira 0:1977c2310ef7 1836 x=7 : wait_iop[s]
Kujira 0:1977c2310ef7 1837 x=8 : wait_ocp[s]
Kujira 0:1977c2310ef7 1838 x=9 : low_limit_resistor[Ω]
Kujira 0:1977c2310ef7 1839 x=10 : up_limit_resistor[Ω]
Kujira 0:1977c2310ef7 1840
Kujira 0:1977c2310ef7 1841 *********************************/
Kujira 0:1977c2310ef7 1842 void hyouji_cal_param(char x)
Kujira 0:1977c2310ef7 1843 {
Kujira 0:1977c2310ef7 1844 gu_fontsize(2);
Kujira 0:1977c2310ef7 1845 gu_cursor(0,4);
Kujira 0:1977c2310ef7 1846 gu_print1(" ");
Kujira 0:1977c2310ef7 1847
Kujira 0:1977c2310ef7 1848 switch ( x ) {
Kujira 0:1977c2310ef7 1849 case 0:
Kujira 0:1977c2310ef7 1850 gu_cursor(0,4);
Kujira 0:1977c2310ef7 1851 gu_print1("Vss(Iop)");
Kujira 0:1977c2310ef7 1852 gu_cursor(208,4);
Kujira 0:1977c2310ef7 1853 gu_print1("[V]");
Kujira 0:1977c2310ef7 1854 break;
Kujira 0:1977c2310ef7 1855 case 1:
Kujira 0:1977c2310ef7 1856 gu_cursor(0,4);
Kujira 0:1977c2310ef7 1857 gu_print1("Vss(O.C.P)");
Kujira 0:1977c2310ef7 1858 gu_cursor(208,4);
Kujira 0:1977c2310ef7 1859 gu_print1("[V]");
Kujira 0:1977c2310ef7 1860 break;
Kujira 0:1977c2310ef7 1861 case 2:
Kujira 0:1977c2310ef7 1862 gu_cursor(0,4);
Kujira 0:1977c2310ef7 1863 gu_print1("Vss(Voc)");
Kujira 0:1977c2310ef7 1864 gu_cursor(208,4);
Kujira 0:1977c2310ef7 1865 gu_print1("[V]");
Kujira 0:1977c2310ef7 1866 break;
Kujira 0:1977c2310ef7 1867 case 3:
Kujira 0:1977c2310ef7 1868 gu_cursor(0,4);
Kujira 0:1977c2310ef7 1869 gu_print1("low limit(Voc)");
Kujira 0:1977c2310ef7 1870 gu_cursor(208,4);
Kujira 0:1977c2310ef7 1871 gu_print1("[V]");
Kujira 0:1977c2310ef7 1872 break;
Kujira 0:1977c2310ef7 1873 case 4:
Kujira 0:1977c2310ef7 1874 gu_cursor(0,4);
Kujira 0:1977c2310ef7 1875 gu_print1("low limit(Iop)");
Kujira 0:1977c2310ef7 1876 gu_cursor(208,4);
Kujira 0:1977c2310ef7 1877 gu_print1("[uA]");
Kujira 0:1977c2310ef7 1878 break;
Kujira 0:1977c2310ef7 1879 case 5:
Kujira 0:1977c2310ef7 1880 gu_cursor(0,4);
Kujira 0:1977c2310ef7 1881 gu_print1("low limit(O.C.P)");
Kujira 0:1977c2310ef7 1882 gu_cursor(208,4);
Kujira 0:1977c2310ef7 1883 gu_print1("[uA]");
Kujira 0:1977c2310ef7 1884 break;
Kujira 0:1977c2310ef7 1885 //ver1.2.2
Kujira 0:1977c2310ef7 1886 case 6:
Kujira 0:1977c2310ef7 1887 gu_cursor(0,4);
Kujira 0:1977c2310ef7 1888 gu_print1("up limit(O.C.P)");
Kujira 0:1977c2310ef7 1889 gu_cursor(208,4);
Kujira 0:1977c2310ef7 1890 gu_print1("[uA]");
Kujira 0:1977c2310ef7 1891 break;
Kujira 0:1977c2310ef7 1892 case 7:
Kujira 0:1977c2310ef7 1893 gu_cursor(0,4);
Kujira 0:1977c2310ef7 1894 gu_print1("Wait(Iop)");
Kujira 0:1977c2310ef7 1895 gu_cursor(208,4);
Kujira 0:1977c2310ef7 1896 gu_print1("[s]");
Kujira 0:1977c2310ef7 1897 break;
Kujira 0:1977c2310ef7 1898 case 8:
Kujira 0:1977c2310ef7 1899 gu_cursor(0,4);
Kujira 0:1977c2310ef7 1900 gu_print1("Wait(O.C.P)");
Kujira 0:1977c2310ef7 1901 gu_cursor(208,4);
Kujira 0:1977c2310ef7 1902 gu_print1("[s]");
Kujira 0:1977c2310ef7 1903 break;
Kujira 0:1977c2310ef7 1904 case 9:
Kujira 0:1977c2310ef7 1905 gu_cursor(0,4);
Kujira 0:1977c2310ef7 1906 gu_print1("low limit(ohm)");
Kujira 0:1977c2310ef7 1907 gu_cursor(208,4);
Kujira 0:1977c2310ef7 1908 wdata[0] = 0xEA; //Ω
Kujira 0:1977c2310ef7 1909 i2c.write( addr_gu, wdata, 1);
Kujira 0:1977c2310ef7 1910 break;
Kujira 0:1977c2310ef7 1911 case 10:
Kujira 0:1977c2310ef7 1912 gu_cursor(0,4);
Kujira 0:1977c2310ef7 1913 gu_print1("up limit(ohm)");
Kujira 0:1977c2310ef7 1914 gu_cursor(208,4);
Kujira 0:1977c2310ef7 1915 wdata[0] = 0xEA; //Ω
Kujira 0:1977c2310ef7 1916 i2c.write( addr_gu, wdata, 1);
Kujira 0:1977c2310ef7 1917 break;
Kujira 0:1977c2310ef7 1918 //ver1.2.2 up to here
Kujira 0:1977c2310ef7 1919
Kujira 0:1977c2310ef7 1920 }
Kujira 0:1977c2310ef7 1921 }
Kujira 0:1977c2310ef7 1922
Kujira 0:1977c2310ef7 1923 /*********************************
Kujira 0:1977c2310ef7 1924
Kujira 0:1977c2310ef7 1925 CAL情報登録画面 sub
Kujira 0:1977c2310ef7 1926 para kind of parameter
Kujira 0:1977c2310ef7 1927 idata data value
Kujira 0:1977c2310ef7 1928 inc add number ex)0x64 0x0A 0x01
Kujira 0:1977c2310ef7 1929
Kujira 0:1977c2310ef7 1930 *********************************/
Kujira 0:1977c2310ef7 1931 void increase_param(char para, signed short *sdata, short inc)
Kujira 0:1977c2310ef7 1932 {
Kujira 0:1977c2310ef7 1933 switch ( para ) { //パラメータの項目によって上限値異なる
Kujira 0:1977c2310ef7 1934 case 0://vss_iop
Kujira 0:1977c2310ef7 1935 case 1://vss_ocp
Kujira 0:1977c2310ef7 1936 case 2://vss_voc
Kujira 0:1977c2310ef7 1937 case 3://low_limit_voc
Kujira 0:1977c2310ef7 1938 if(*sdata <= ( 4999 - inc )) {
Kujira 0:1977c2310ef7 1939 *sdata = *sdata + inc ;
Kujira 0:1977c2310ef7 1940 }
Kujira 0:1977c2310ef7 1941 break;//switch ( param ){
Kujira 0:1977c2310ef7 1942
Kujira 0:1977c2310ef7 1943 case 4://low_limit_iop
Kujira 0:1977c2310ef7 1944 case 5://low_limit_o.c.p
Kujira 0:1977c2310ef7 1945 if(*sdata <= ( 2500 - inc / 10 )) {
Kujira 0:1977c2310ef7 1946 *sdata = *sdata + inc /10 ;
Kujira 0:1977c2310ef7 1947 }
Kujira 0:1977c2310ef7 1948 break;//switch ( param )
Kujira 0:1977c2310ef7 1949 case 7://wait_iop
Kujira 0:1977c2310ef7 1950 case 8://wait_ocp
Kujira 0:1977c2310ef7 1951
Kujira 0:1977c2310ef7 1952 if(*sdata <= ( 2550 - inc / 10 )) {
Kujira 0:1977c2310ef7 1953 *sdata = *sdata + inc / 10 ;
Kujira 0:1977c2310ef7 1954 }
Kujira 0:1977c2310ef7 1955 break;//switch ( param )
Kujira 0:1977c2310ef7 1956
Kujira 0:1977c2310ef7 1957 case 9:
Kujira 0:1977c2310ef7 1958 case 10:
Kujira 0:1977c2310ef7 1959 if(*sdata <= ( 2550 - inc )) {
Kujira 0:1977c2310ef7 1960 *sdata = *sdata + inc;
Kujira 0:1977c2310ef7 1961 }
Kujira 0:1977c2310ef7 1962 break;
Kujira 0:1977c2310ef7 1963
Kujira 0:1977c2310ef7 1964 //ver1.2.2
Kujira 0:1977c2310ef7 1965 case 6://up_limit_o.c.p
Kujira 0:1977c2310ef7 1966 if(*sdata <= ( 2500 - inc / 10 )) {
Kujira 0:1977c2310ef7 1967 *sdata = *sdata + inc /10 ;
Kujira 0:1977c2310ef7 1968 }
Kujira 0:1977c2310ef7 1969 break;//switch ( param )
Kujira 0:1977c2310ef7 1970 //ver1.2.1 up to here
Kujira 0:1977c2310ef7 1971
Kujira 0:1977c2310ef7 1972 }//switch ( param ){
Kujira 0:1977c2310ef7 1973 }
Kujira 0:1977c2310ef7 1974
Kujira 0:1977c2310ef7 1975 void decrease_param(char para, signed short *sdata, short dec)
Kujira 0:1977c2310ef7 1976 {
Kujira 0:1977c2310ef7 1977 switch ( para ) { //パラメータの項目によって上限値異なる
Kujira 0:1977c2310ef7 1978 case 0://vss_iop
Kujira 0:1977c2310ef7 1979 case 1://vss_ocp
Kujira 0:1977c2310ef7 1980 case 2://vss_voc
Kujira 0:1977c2310ef7 1981 case 3://low_limit_voc
Kujira 0:1977c2310ef7 1982
Kujira 0:1977c2310ef7 1983 if(*sdata >= dec ) {
Kujira 0:1977c2310ef7 1984 *sdata = *sdata - dec;
Kujira 0:1977c2310ef7 1985 }
Kujira 0:1977c2310ef7 1986 break;
Kujira 0:1977c2310ef7 1987
Kujira 0:1977c2310ef7 1988 case 4://low_limit_iop
Kujira 0:1977c2310ef7 1989
Kujira 0:1977c2310ef7 1990 if(*sdata >= dec / 10 ) {
Kujira 0:1977c2310ef7 1991 *sdata = *sdata - dec / 10;
Kujira 0:1977c2310ef7 1992 }
Kujira 0:1977c2310ef7 1993 break;
Kujira 0:1977c2310ef7 1994
Kujira 0:1977c2310ef7 1995 case 5://low_limit_o.c.p
Kujira 0:1977c2310ef7 1996
Kujira 0:1977c2310ef7 1997 if(*sdata >= -2500 + dec / 10 ) {
Kujira 0:1977c2310ef7 1998 *sdata = *sdata - dec / 10;
Kujira 0:1977c2310ef7 1999 }
Kujira 0:1977c2310ef7 2000 break;
Kujira 0:1977c2310ef7 2001
Kujira 0:1977c2310ef7 2002 case 7://wait_iop
Kujira 0:1977c2310ef7 2003 case 8://wait_ocp
Kujira 0:1977c2310ef7 2004
Kujira 0:1977c2310ef7 2005 if(*sdata >= dec / 10 ) {
Kujira 0:1977c2310ef7 2006 *sdata = *sdata - dec / 10 ;
Kujira 0:1977c2310ef7 2007 }
Kujira 0:1977c2310ef7 2008 break;//switch ( param )
Kujira 0:1977c2310ef7 2009
Kujira 0:1977c2310ef7 2010 case 9:
Kujira 0:1977c2310ef7 2011 case 10:
Kujira 0:1977c2310ef7 2012 if(*sdata >= dec ) {
Kujira 0:1977c2310ef7 2013 *sdata = *sdata - dec;
Kujira 0:1977c2310ef7 2014 }
Kujira 0:1977c2310ef7 2015 break;
Kujira 0:1977c2310ef7 2016
Kujira 0:1977c2310ef7 2017 //ver1.2.1
Kujira 0:1977c2310ef7 2018 case 6://up_limit_o.c.p
Kujira 0:1977c2310ef7 2019
Kujira 0:1977c2310ef7 2020 if(*sdata >= -2500 + dec / 10 ) {
Kujira 0:1977c2310ef7 2021 *sdata = *sdata - dec / 10;
Kujira 0:1977c2310ef7 2022 }
Kujira 0:1977c2310ef7 2023 break;
Kujira 0:1977c2310ef7 2024 //ver1.2.1 ここまで
Kujira 0:1977c2310ef7 2025
Kujira 0:1977c2310ef7 2026 }//switch ( param ){
Kujira 0:1977c2310ef7 2027 }
Kujira 0:1977c2310ef7 2028 /*********************************
Kujira 0:1977c2310ef7 2029
Kujira 0:1977c2310ef7 2030 CAL情報登録画面 MAIN
Kujira 0:1977c2310ef7 2031 別途システム設計図,EEPROMのシートを参照
Kujira 0:1977c2310ef7 2032 param:
Kujira 0:1977c2310ef7 2033 0:vss_iop
Kujira 0:1977c2310ef7 2034 1:vss_ocp
Kujira 0:1977c2310ef7 2035 2:vss_voc
Kujira 0:1977c2310ef7 2036 3:low_limit_voc
Kujira 0:1977c2310ef7 2037 4:low_limit_iop
Kujira 0:1977c2310ef7 2038 5:low_limit_ocp
Kujira 0:1977c2310ef7 2039 6:up_limit_ocp ver1.2.2
Kujira 0:1977c2310ef7 2040 7:wait_iop
Kujira 0:1977c2310ef7 2041 8:wait_ocp
Kujira 0:1977c2310ef7 2042 9:LowLimitResistor
Kujira 0:1977c2310ef7 2043 10:UPLimitResistor
Kujira 0:1977c2310ef7 2044
Kujira 0:1977c2310ef7 2045 *********************************/
Kujira 0:1977c2310ef7 2046 void setup_cal_information(char cal_num) //xは登録ナンバー=EEPROMのPAGEナンバーex)登録No.1→BLOCK0x00 PAGE0x00
Kujira 0:1977c2310ef7 2047 {
Kujira 0:1977c2310ef7 2048 char param; //設定するパラメータの選択 0~9まで ver1.2.1 0~10まで
Kujira 0:1977c2310ef7 2049 char crdata[3];
Kujira 0:1977c2310ef7 2050 signed short sdata_cal[16]; //CAL設定条件
Kujira 0:1977c2310ef7 2051 signed short hyouji_data;
Kujira 0:1977c2310ef7 2052 int param_sum; //設定するパラメータの数 ver1.2.1
Kujira 0:1977c2310ef7 2053 //int i;
Kujira 0:1977c2310ef7 2054 //short sdata_byte[16]; //EEPROM BYTEごとのDATA 1byte
Kujira 0:1977c2310ef7 2055 //char cmd_gu[32]; //gu-DへのI2Cコマンド用配列 1byte0
Kujira 0:1977c2310ef7 2056 //char adrs_cal; //EEPROM CAL情報を保存しているアドレス 0x90~
Kujira 0:1977c2310ef7 2057
Kujira 0:1977c2310ef7 2058 param_sum = 11; //ver1.2.1
Kujira 0:1977c2310ef7 2059
Kujira 0:1977c2310ef7 2060 //画面表示
Kujira 0:1977c2310ef7 2061 gu_cls();//画面のクリア
Kujira 0:1977c2310ef7 2062 gu_fontsize(2);
Kujira 0:1977c2310ef7 2063 gu_print1("Setup Cal No.");
Kujira 0:1977c2310ef7 2064 wdata[0] = ( cal_num % 10 ) + 0x30;//CALナンバーの表示
Kujira 0:1977c2310ef7 2065 i2c.write(addr_gu, wdata, 1);
Kujira 0:1977c2310ef7 2066
Kujira 0:1977c2310ef7 2067 //CAL情報読込
Kujira 0:1977c2310ef7 2068 read_caliber(&calinfo,cal_num);
Kujira 0:1977c2310ef7 2069
Kujira 0:1977c2310ef7 2070 sdata_cal[0] = calinfo.vss_iop;
Kujira 0:1977c2310ef7 2071 sdata_cal[1] = calinfo.vss_ocp;
Kujira 0:1977c2310ef7 2072 sdata_cal[2] = calinfo.vss_voc;
Kujira 0:1977c2310ef7 2073 sdata_cal[3] = calinfo.low_limit_voc;
Kujira 0:1977c2310ef7 2074 sdata_cal[4] = calinfo.low_limit_iop;
Kujira 0:1977c2310ef7 2075 sdata_cal[5] = calinfo.low_limit_ocp;
Kujira 0:1977c2310ef7 2076 //ver1.2.2
Kujira 0:1977c2310ef7 2077 sdata_cal[6] = calinfo.up_limit_ocp;
Kujira 0:1977c2310ef7 2078 sdata_cal[7] = calinfo.wait_iop;
Kujira 0:1977c2310ef7 2079 sdata_cal[8] = calinfo.wait_ocp;
Kujira 0:1977c2310ef7 2080 sdata_cal[9] = calinfo.low_limit_resistor;
Kujira 0:1977c2310ef7 2081 sdata_cal[10] = calinfo.up_limit_resistor;
Kujira 0:1977c2310ef7 2082 /*
Kujira 0:1977c2310ef7 2083 sdata_cal[6] = calinfo.wait_iop;
Kujira 0:1977c2310ef7 2084 sdata_cal[7] = calinfo.wait_ocp;
Kujira 0:1977c2310ef7 2085 sdata_cal[8] = calinfo.low_limit_resistor;
Kujira 0:1977c2310ef7 2086 sdata_cal[9] = calinfo.up_limit_resistor;
Kujira 0:1977c2310ef7 2087 */
Kujira 0:1977c2310ef7 2088 //ver1.2.2 up to here
Kujira 0:1977c2310ef7 2089
Kujira 0:1977c2310ef7 2090 //ボタンの配置
Kujira 0:1977c2310ef7 2091 gu_set_button_font1(8,"reg");
Kujira 0:1977c2310ef7 2092 gu_button_up(17);
Kujira 0:1977c2310ef7 2093 gu_button_down(25);
Kujira 0:1977c2310ef7 2094
Kujira 0:1977c2310ef7 2095 gu_button_up(20);
Kujira 0:1977c2310ef7 2096 gu_button_up(22);
Kujira 0:1977c2310ef7 2097 gu_button_up(24);
Kujira 0:1977c2310ef7 2098 gu_button_down(28);
Kujira 0:1977c2310ef7 2099 gu_button_down(30);
Kujira 0:1977c2310ef7 2100 gu_button_down(32);
Kujira 0:1977c2310ef7 2101
Kujira 0:1977c2310ef7 2102 /*
Kujira 0:1977c2310ef7 2103 gu_button_up(21);
Kujira 0:1977c2310ef7 2104 gu_button_up(22);
Kujira 0:1977c2310ef7 2105 gu_button_up(23);
Kujira 0:1977c2310ef7 2106 gu_button_down(29);
Kujira 0:1977c2310ef7 2107 gu_button_down(30);
Kujira 0:1977c2310ef7 2108 gu_button_down(31);
Kujira 0:1977c2310ef7 2109 */
Kujira 0:1977c2310ef7 2110
Kujira 0:1977c2310ef7 2111 //初期表示はVss_Iop
Kujira 0:1977c2310ef7 2112 param = 0;
Kujira 0:1977c2310ef7 2113 gu_cursor(0,4);
Kujira 0:1977c2310ef7 2114 gu_fontsize(2);
Kujira 0:1977c2310ef7 2115 gu_print1("Vss(Iop)");
Kujira 0:1977c2310ef7 2116 gu_cursor(208,4);
Kujira 0:1977c2310ef7 2117 gu_print1("V");
Kujira 0:1977c2310ef7 2118
Kujira 0:1977c2310ef7 2119 while(1) {
Kujira 0:1977c2310ef7 2120 i2c.read ((addr_gu + 0x01), crdata, 3, true);
Kujira 0:1977c2310ef7 2121
Kujira 0:1977c2310ef7 2122 if (crdata[0] == 0x11 && crdata[2] == 0x01 ) { //個別タッチスイッチ状態読み出しフォーマット。識別子11h。&& タッチしたならば
Kujira 0:1977c2310ef7 2123 //cswnum = crdata[1]; //スイッチ番号
Kujira 0:1977c2310ef7 2124 //cswdata = crdata[2];//ON/OFF情報
Kujira 0:1977c2310ef7 2125
Kujira 0:1977c2310ef7 2126 switch( crdata[1] ) { //SWの番号(位置)
Kujira 0:1977c2310ef7 2127
Kujira 0:1977c2310ef7 2128 /* ver1.2.1
Kujira 0:1977c2310ef7 2129 case 0x10 ://sw17 パラメータ変更スイッチ(上)
Kujira 0:1977c2310ef7 2130
Kujira 0:1977c2310ef7 2131 if ( param <= 8 ) {
Kujira 0:1977c2310ef7 2132 param = param + 1;
Kujira 0:1977c2310ef7 2133 } else {
Kujira 0:1977c2310ef7 2134 param = 0;
Kujira 0:1977c2310ef7 2135 }
Kujira 0:1977c2310ef7 2136
Kujira 0:1977c2310ef7 2137 hyouji_cal_param(param);//設定パラメータ表示
Kujira 0:1977c2310ef7 2138 break;
Kujira 0:1977c2310ef7 2139
Kujira 0:1977c2310ef7 2140 case 0x18 ://sw25 パラメータ変更スイッチ(下)
Kujira 0:1977c2310ef7 2141
Kujira 0:1977c2310ef7 2142 if ( param >= 1 ) {
Kujira 0:1977c2310ef7 2143 param = param - 1;
Kujira 0:1977c2310ef7 2144 } else {
Kujira 0:1977c2310ef7 2145 param = 9;
Kujira 0:1977c2310ef7 2146 }
Kujira 0:1977c2310ef7 2147
Kujira 0:1977c2310ef7 2148 hyouji_cal_param(param);//設定パラメータ表示
Kujira 0:1977c2310ef7 2149 break;
Kujira 0:1977c2310ef7 2150 */
Kujira 0:1977c2310ef7 2151
Kujira 0:1977c2310ef7 2152 case 0x10 ://sw17 パラメータ変更スイッチ(上)
Kujira 0:1977c2310ef7 2153
Kujira 0:1977c2310ef7 2154 if ( param <= param_sum -2 ) {
Kujira 0:1977c2310ef7 2155 param = param + 1;
Kujira 0:1977c2310ef7 2156 } else {
Kujira 0:1977c2310ef7 2157 param = 0;
Kujira 0:1977c2310ef7 2158 }
Kujira 0:1977c2310ef7 2159
Kujira 0:1977c2310ef7 2160 hyouji_cal_param(param);//設定パラメータ表示
Kujira 0:1977c2310ef7 2161 break;
Kujira 0:1977c2310ef7 2162
Kujira 0:1977c2310ef7 2163 case 0x18 ://sw25 パラメータ変更スイッチ(下)
Kujira 0:1977c2310ef7 2164
Kujira 0:1977c2310ef7 2165 if ( param >= 1 ) {
Kujira 0:1977c2310ef7 2166 param = param - 1;
Kujira 0:1977c2310ef7 2167 } else {
Kujira 0:1977c2310ef7 2168 param = param_sum - 1;
Kujira 0:1977c2310ef7 2169 }
Kujira 0:1977c2310ef7 2170
Kujira 0:1977c2310ef7 2171 hyouji_cal_param(param);//設定パラメータ表示
Kujira 0:1977c2310ef7 2172 break;
Kujira 0:1977c2310ef7 2173
Kujira 0:1977c2310ef7 2174 //ver1.2.1 up to here
Kujira 0:1977c2310ef7 2175
Kujira 0:1977c2310ef7 2176 case 19 ://SW20 increase 0x3E8
Kujira 0:1977c2310ef7 2177
Kujira 0:1977c2310ef7 2178 increase_param(param, &sdata_cal[param], 1000);
Kujira 0:1977c2310ef7 2179 break;
Kujira 0:1977c2310ef7 2180
Kujira 0:1977c2310ef7 2181 case 27 ://SW28 decrease 0x3E8
Kujira 0:1977c2310ef7 2182
Kujira 0:1977c2310ef7 2183 decrease_param(param, &sdata_cal[param], 1000);
Kujira 0:1977c2310ef7 2184 break;
Kujira 0:1977c2310ef7 2185
Kujira 0:1977c2310ef7 2186 case 0x15 ://SW22 increase 0x64
Kujira 0:1977c2310ef7 2187
Kujira 0:1977c2310ef7 2188 increase_param(param, &sdata_cal[param], 100);
Kujira 0:1977c2310ef7 2189 break;
Kujira 0:1977c2310ef7 2190
Kujira 0:1977c2310ef7 2191 case 0x1D ://SW30 decrease 0x64
Kujira 0:1977c2310ef7 2192
Kujira 0:1977c2310ef7 2193 decrease_param(param, &sdata_cal[param], 100);
Kujira 0:1977c2310ef7 2194 break;
Kujira 0:1977c2310ef7 2195
Kujira 0:1977c2310ef7 2196 case 23 ://SW24 increase 0x0A
Kujira 0:1977c2310ef7 2197
Kujira 0:1977c2310ef7 2198 increase_param(param, &sdata_cal[param], 10);
Kujira 0:1977c2310ef7 2199 break;
Kujira 0:1977c2310ef7 2200
Kujira 0:1977c2310ef7 2201 case 31 ://SW32 decrease 0x0A
Kujira 0:1977c2310ef7 2202
Kujira 0:1977c2310ef7 2203 decrease_param(param, &sdata_cal[param], 10);
Kujira 0:1977c2310ef7 2204 break;
Kujira 0:1977c2310ef7 2205
Kujira 0:1977c2310ef7 2206
Kujira 0:1977c2310ef7 2207 case 0x07 ://保存ボタン
Kujira 0:1977c2310ef7 2208
Kujira 0:1977c2310ef7 2209 calinfo.vss_iop = sdata_cal[0];
Kujira 0:1977c2310ef7 2210 calinfo.vss_ocp = sdata_cal[1];
Kujira 0:1977c2310ef7 2211 calinfo.vss_voc = sdata_cal[2];
Kujira 0:1977c2310ef7 2212 calinfo.low_limit_voc = sdata_cal[3];
Kujira 0:1977c2310ef7 2213 calinfo.low_limit_iop = sdata_cal[4];
Kujira 0:1977c2310ef7 2214 calinfo.low_limit_ocp = sdata_cal[5];
Kujira 0:1977c2310ef7 2215 //ver1.2.2
Kujira 0:1977c2310ef7 2216 calinfo.up_limit_ocp = sdata_cal[6];
Kujira 0:1977c2310ef7 2217 calinfo.wait_iop = sdata_cal[7];
Kujira 0:1977c2310ef7 2218 calinfo.wait_ocp = sdata_cal[8];
Kujira 0:1977c2310ef7 2219 calinfo.low_limit_resistor = sdata_cal[9];
Kujira 0:1977c2310ef7 2220 calinfo.up_limit_resistor = sdata_cal[10];
Kujira 0:1977c2310ef7 2221 /*
Kujira 0:1977c2310ef7 2222 calinfo.wait_iop = sdata_cal[6];
Kujira 0:1977c2310ef7 2223 calinfo.wait_ocp = sdata_cal[7];
Kujira 0:1977c2310ef7 2224 calinfo.low_limit_resistor = sdata_cal[8];
Kujira 0:1977c2310ef7 2225 calinfo.up_limit_resistor = sdata_cal[9];
Kujira 0:1977c2310ef7 2226 */
Kujira 0:1977c2310ef7 2227 //ver1.2.2 up to here
Kujira 0:1977c2310ef7 2228
Kujira 0:1977c2310ef7 2229 reg_num = cal_num;
Kujira 0:1977c2310ef7 2230
Kujira 0:1977c2310ef7 2231 //CALNO.EEPROM書込み
Kujira 0:1977c2310ef7 2232 wdata[0] = addr_calnum; //word address 書込み先頭アドレス指定
Kujira 0:1977c2310ef7 2233 wdata[1] = reg_num;
Kujira 0:1977c2310ef7 2234 Soushin = i2c.write (fixed_adrs, wdata, 2);
Kujira 0:1977c2310ef7 2235
Kujira 0:1977c2310ef7 2236 wait(0.2);
Kujira 0:1977c2310ef7 2237
Kujira 0:1977c2310ef7 2238 //CAL情報
Kujira 0:1977c2310ef7 2239 //送信完了ならば実行
Kujira 0:1977c2310ef7 2240 if(Soushin == 0) {
Kujira 0:1977c2310ef7 2241
Kujira 0:1977c2310ef7 2242 write_caliber_information(&calinfo, cal_num);
Kujira 0:1977c2310ef7 2243
Kujira 0:1977c2310ef7 2244 //ver1.2.3
Kujira 0:1977c2310ef7 2245 } else {
Kujira 0:1977c2310ef7 2246 gu_fontsize(1);
Kujira 0:1977c2310ef7 2247 gu_cursor(0,2);
Kujira 0:1977c2310ef7 2248 gu_print1("can not save cal no");
Kujira 0:1977c2310ef7 2249 wait(2);
Kujira 0:1977c2310ef7 2250 return;
Kujira 0:1977c2310ef7 2251 }
Kujira 0:1977c2310ef7 2252
Kujira 0:1977c2310ef7 2253 //送信完了ならば実行
Kujira 0:1977c2310ef7 2254 if(Soushin == 0) {
Kujira 0:1977c2310ef7 2255 gu_reverse(1);
Kujira 0:1977c2310ef7 2256 gu_set_button_font1(8,"reg");
Kujira 0:1977c2310ef7 2257 wait(0.2);
Kujira 0:1977c2310ef7 2258 return;//CAL情報登録画面を抜ける
Kujira 0:1977c2310ef7 2259
Kujira 0:1977c2310ef7 2260 //ver1.2.3
Kujira 0:1977c2310ef7 2261 } else {
Kujira 0:1977c2310ef7 2262 gu_fontsize(1);
Kujira 0:1977c2310ef7 2263 gu_cursor(0,2);
Kujira 0:1977c2310ef7 2264 gu_print1("can not save cal information");
Kujira 0:1977c2310ef7 2265 wait(2);
Kujira 0:1977c2310ef7 2266 return;
Kujira 0:1977c2310ef7 2267 }
Kujira 0:1977c2310ef7 2268
Kujira 0:1977c2310ef7 2269 //break;
Kujira 0:1977c2310ef7 2270
Kujira 0:1977c2310ef7 2271 } //switch
Kujira 0:1977c2310ef7 2272 } //if
Kujira 0:1977c2310ef7 2273 //gu-D表示
Kujira 0:1977c2310ef7 2274 gu_cursor(150,4);
Kujira 0:1977c2310ef7 2275
Kujira 0:1977c2310ef7 2276 switch ( param ) {
Kujira 0:1977c2310ef7 2277 case 0://vss_iop
Kujira 0:1977c2310ef7 2278 case 1://vss_ocp
Kujira 0:1977c2310ef7 2279 case 2://vss_voc
Kujira 0:1977c2310ef7 2280 case 3://low_limit_voc
Kujira 0:1977c2310ef7 2281 hyouji_data = sdata_cal[param] * -1;
Kujira 0:1977c2310ef7 2282 gu_putdeck ( &hyouji_data );
Kujira 0:1977c2310ef7 2283 break;
Kujira 0:1977c2310ef7 2284 case 4:
Kujira 0:1977c2310ef7 2285 case 5:
Kujira 0:1977c2310ef7 2286 hyouji_data = sdata_cal[param] * 10;
Kujira 0:1977c2310ef7 2287 gu_putdeck ( &hyouji_data );
Kujira 0:1977c2310ef7 2288 break;
Kujira 0:1977c2310ef7 2289 //ver1.2.2
Kujira 0:1977c2310ef7 2290 case 6:
Kujira 0:1977c2310ef7 2291 hyouji_data = sdata_cal[param] * 10;
Kujira 0:1977c2310ef7 2292 gu_putdeck ( &hyouji_data );
Kujira 0:1977c2310ef7 2293 break;
Kujira 0:1977c2310ef7 2294 case 7:
Kujira 0:1977c2310ef7 2295 case 8:
Kujira 0:1977c2310ef7 2296 //ver1.1.0
Kujira 0:1977c2310ef7 2297 hyouji_data = sdata_cal[param];
Kujira 0:1977c2310ef7 2298 gu_putdec ( &hyouji_data );
Kujira 0:1977c2310ef7 2299 break;
Kujira 0:1977c2310ef7 2300 case 9://low_limit_resistor
Kujira 0:1977c2310ef7 2301 case 10://up_limit_resistor
Kujira 0:1977c2310ef7 2302 hyouji_data = sdata_cal[param];
Kujira 0:1977c2310ef7 2303 gu_putdec ( &hyouji_data );
Kujira 0:1977c2310ef7 2304 break;
Kujira 0:1977c2310ef7 2305 /*
Kujira 0:1977c2310ef7 2306 case 6:
Kujira 0:1977c2310ef7 2307 case 7:
Kujira 0:1977c2310ef7 2308 //ver1.1.0
Kujira 0:1977c2310ef7 2309 hyouji_data = sdata_cal[param];
Kujira 0:1977c2310ef7 2310 gu_putdec ( &hyouji_data );
Kujira 0:1977c2310ef7 2311 break;
Kujira 0:1977c2310ef7 2312 case 8://low_limit_resistor
Kujira 0:1977c2310ef7 2313 case 9://up_limit_resistor
Kujira 0:1977c2310ef7 2314 hyouji_data = sdata_cal[param];
Kujira 0:1977c2310ef7 2315 gu_putdec ( &hyouji_data );
Kujira 0:1977c2310ef7 2316 break;
Kujira 0:1977c2310ef7 2317 */
Kujira 0:1977c2310ef7 2318 //ver1.2.2 uptohere
Kujira 0:1977c2310ef7 2319
Kujira 0:1977c2310ef7 2320 }
Kujira 0:1977c2310ef7 2321 wait(0.1);//gu-D 読込間隔の設定
Kujira 0:1977c2310ef7 2322 }//while
Kujira 0:1977c2310ef7 2323 }
Kujira 0:1977c2310ef7 2324
Kujira 0:1977c2310ef7 2325 /*********************************
Kujira 0:1977c2310ef7 2326
Kujira 0:1977c2310ef7 2327 Auto Mode (sub)
Kujira 0:1977c2310ef7 2328 自動測定モード 初期画面
Kujira 0:1977c2310ef7 2329
Kujira 0:1977c2310ef7 2330 *********************************/
Kujira 0:1977c2310ef7 2331 void auto_int_hyouji()
Kujira 0:1977c2310ef7 2332 {
Kujira 0:1977c2310ef7 2333 //short st;
Kujira 0:1977c2310ef7 2334 char cmd_gu[32] ; //gu-DへのI2Cコマンド用配列 1byte
Kujira 0:1977c2310ef7 2335
Kujira 0:1977c2310ef7 2336 gu_cls();
Kujira 0:1977c2310ef7 2337 gu_fontsize(1);
Kujira 0:1977c2310ef7 2338 gu_print1("AUTO MODE CAL No.");
Kujira 0:1977c2310ef7 2339 cmd_gu[0] = reg_num + 0x30;
Kujira 0:1977c2310ef7 2340 i2c.write(addr_gu, cmd_gu, 1);
Kujira 0:1977c2310ef7 2341 gu_Button_power_on();//show button
Kujira 0:1977c2310ef7 2342
Kujira 0:1977c2310ef7 2343 }
Kujira 0:1977c2310ef7 2344 /*******************************************************
Kujira 0:1977c2310ef7 2345
Kujira 0:1977c2310ef7 2346 Auto Mode (Main)
Kujira 0:1977c2310ef7 2347 自動測定モード 画面
Kujira 0:1977c2310ef7 2348 ver1.04 パネルタッチ -> スタートスイッチで測定開始へ変更
Kujira 0:1977c2310ef7 2349
Kujira 0:1977c2310ef7 2350 *******************************************************/
Kujira 0:1977c2310ef7 2351 void auto_run()
Kujira 0:1977c2310ef7 2352 {
Kujira 0:1977c2310ef7 2353 char cmd_gu[32] ; //gu-DへのI2Cコマンド用配列 1byte
Kujira 0:1977c2310ef7 2354 char crdata[6];
Kujira 0:1977c2310ef7 2355 //char cswnum; //SW_No. sw1->0x00 ~~ sw32->0x1F
Kujira 0:1977c2310ef7 2356 //int i;
Kujira 0:1977c2310ef7 2357 //float fdata[4][4];//ファイル出力用
Kujira 0:1977c2310ef7 2358 //short sdata[4];
Kujira 0:1977c2310ef7 2359 //short s;
Kujira 0:1977c2310ef7 2360
Kujira 0:1977c2310ef7 2361 read_regnum();//CAL登録No.読込
Kujira 0:1977c2310ef7 2362 read_caliber(&calinfo,reg_num);//指定したCAL登録No.の情報を読込後、calinfoへ代入
Kujira 0:1977c2310ef7 2363
Kujira 0:1977c2310ef7 2364 auto_int_hyouji();
Kujira 0:1977c2310ef7 2365
Kujira 0:1977c2310ef7 2366 //dac_init(); //DAC 初期化
Kujira 0:1977c2310ef7 2367
Kujira 0:1977c2310ef7 2368 //gu-D タッチスイッチ読み出し動作設定 p49
Kujira 0:1977c2310ef7 2369 cmd_gu[0]= 0x1F;
Kujira 0:1977c2310ef7 2370 cmd_gu[1]= 0x4B;
Kujira 0:1977c2310ef7 2371 cmd_gu[2]= 0x18;
Kujira 0:1977c2310ef7 2372 cmd_gu[3]= 0x02;//SW状態変化時自動送信モード2
Kujira 0:1977c2310ef7 2373 i2c.write(addr_gu, cmd_gu, 4); //gu-D タッチスイッチ読み出し動作設定 p49
Kujira 0:1977c2310ef7 2374
Kujira 0:1977c2310ef7 2375 wait(0.1);
Kujira 0:1977c2310ef7 2376
Kujira 0:1977c2310ef7 2377 Jyushin = i2c.read ((addr_gu + 0x01), crdata, 3, true);
Kujira 0:1977c2310ef7 2378
Kujira 0:1977c2310ef7 2379 while(1) {
Kujira 0:1977c2310ef7 2380
Kujira 0:1977c2310ef7 2381 //スタートスイッチで測定開始
Kujira 0:1977c2310ef7 2382 if ( sw_start == 0 ) {
Kujira 0:1977c2310ef7 2383 meas_sub();
Kujira 0:1977c2310ef7 2384 }
Kujira 0:1977c2310ef7 2385
Kujira 0:1977c2310ef7 2386 wait(0.1);
Kujira 0:1977c2310ef7 2387
Kujira 0:1977c2310ef7 2388 crdata[0] = 0;
Kujira 0:1977c2310ef7 2389 crdata[1] = 0;
Kujira 0:1977c2310ef7 2390 crdata[2] = 0;
Kujira 0:1977c2310ef7 2391
Kujira 0:1977c2310ef7 2392 i2c.read ((addr_gu + 0x01), crdata, 3, true);
Kujira 0:1977c2310ef7 2393
Kujira 0:1977c2310ef7 2394 if ( crdata[0] == 0x11 && crdata[2] == 1 ) { //個別タッチスイッチ状態読み出しフォーマット。識別子11h。
Kujira 0:1977c2310ef7 2395
Kujira 0:1977c2310ef7 2396 //cswnum = crdata[1]; //スイッチ番号
Kujira 0:1977c2310ef7 2397 //cswdata = crdata[2];//ON/OFF情報
Kujira 0:1977c2310ef7 2398
Kujira 0:1977c2310ef7 2399 //gu-D タッチスイッチ読み出し動作設定 p49
Kujira 0:1977c2310ef7 2400 cmd_gu[0]= 0x1F;
Kujira 0:1977c2310ef7 2401 cmd_gu[1]= 0x4B;
Kujira 0:1977c2310ef7 2402 cmd_gu[2]= 0x18;
Kujira 0:1977c2310ef7 2403 cmd_gu[3]= 0x00;//SW状態変化時自動送信モード2解除
Kujira 0:1977c2310ef7 2404 i2c.write(addr_gu, cmd_gu, 4); //gu-D タッチスイッチ読み出し動作設定 p49
Kujira 0:1977c2310ef7 2405
Kujira 0:1977c2310ef7 2406 if ( crdata[1] == 7 ) {
Kujira 0:1977c2310ef7 2407
Kujira 0:1977c2310ef7 2408 gu_Button_power_off();//電源ボタンイメージ反転表示
Kujira 0:1977c2310ef7 2409 wait(0.5);
Kujira 0:1977c2310ef7 2410
Kujira 0:1977c2310ef7 2411 led_off();//LED全消灯
Kujira 0:1977c2310ef7 2412
Kujira 0:1977c2310ef7 2413 return;//この関数を抜ける
Kujira 0:1977c2310ef7 2414
Kujira 0:1977c2310ef7 2415 } //end if
Kujira 0:1977c2310ef7 2416
Kujira 0:1977c2310ef7 2417 /* ver 1.1.1 タッチパネルで測定開始を削除
Kujira 0:1977c2310ef7 2418 else {
Kujira 0:1977c2310ef7 2419
Kujira 0:1977c2310ef7 2420 meas_sub();//測定用サブ
Kujira 0:1977c2310ef7 2421
Kujira 0:1977c2310ef7 2422
Kujira 0:1977c2310ef7 2423 } //else if
Kujira 0:1977c2310ef7 2424 */
Kujira 0:1977c2310ef7 2425
Kujira 0:1977c2310ef7 2426 //gu-D タッチスイッチ読み出し動作設定 p49
Kujira 0:1977c2310ef7 2427 cmd_gu[0]= 0x1F;
Kujira 0:1977c2310ef7 2428 cmd_gu[1]= 0x4B;
Kujira 0:1977c2310ef7 2429 cmd_gu[2]= 0x18;
Kujira 0:1977c2310ef7 2430 cmd_gu[3]= 0x02;//SW状態変化時自動送信モード2解除
Kujira 0:1977c2310ef7 2431 i2c.write(addr_gu, cmd_gu, 4); //gu-D タッチスイッチ読み出し動作設定 p49
Kujira 0:1977c2310ef7 2432
Kujira 0:1977c2310ef7 2433 wait(0.1);
Kujira 0:1977c2310ef7 2434
Kujira 0:1977c2310ef7 2435 i2c.read ((addr_gu + 0x01), crdata, 3, true);
Kujira 0:1977c2310ef7 2436
Kujira 0:1977c2310ef7 2437 }//if
Kujira 0:1977c2310ef7 2438 wait(0.1);
Kujira 0:1977c2310ef7 2439 }//While
Kujira 0:1977c2310ef7 2440 }
Kujira 0:1977c2310ef7 2441
Kujira 0:1977c2310ef7 2442 /*
Kujira 0:1977c2310ef7 2443 char cmd_gu[32] ; //gu-DへのI2Cコマンド用配列 1byte
Kujira 0:1977c2310ef7 2444 char crdata[6];
Kujira 0:1977c2310ef7 2445 char cswnum; //SW_No. sw1->0x00 ~~ sw32->0x1F
Kujira 0:1977c2310ef7 2446 //int i;
Kujira 0:1977c2310ef7 2447 //float fdata[4][4];//ファイル出力用
Kujira 0:1977c2310ef7 2448 //short sdata[4];
Kujira 0:1977c2310ef7 2449 //short s;
Kujira 0:1977c2310ef7 2450
Kujira 0:1977c2310ef7 2451 read_regnum();//CAL登録No.読込
Kujira 0:1977c2310ef7 2452 read_caliber(&calinfo,reg_num);//指定したCAL登録No.の情報を読込後、calinfoへ代入
Kujira 0:1977c2310ef7 2453
Kujira 0:1977c2310ef7 2454 auto_int_hyouji();
Kujira 0:1977c2310ef7 2455
Kujira 0:1977c2310ef7 2456 //dac_init(); //DAC 初期化
Kujira 0:1977c2310ef7 2457
Kujira 0:1977c2310ef7 2458 //gu-D タッチスイッチ読み出し動作設定 p49
Kujira 0:1977c2310ef7 2459 cmd_gu[0]= 0x1F;
Kujira 0:1977c2310ef7 2460 cmd_gu[1]= 0x4B;
Kujira 0:1977c2310ef7 2461 cmd_gu[2]= 0x18;
Kujira 0:1977c2310ef7 2462 cmd_gu[3]= 0x02;//SW状態変化時自動送信モード2
Kujira 0:1977c2310ef7 2463 i2c.write(addr_gu, cmd_gu, 4); //gu-D タッチスイッチ読み出し動作設定 p49
Kujira 0:1977c2310ef7 2464
Kujira 0:1977c2310ef7 2465 wait(0.1);
Kujira 0:1977c2310ef7 2466
Kujira 0:1977c2310ef7 2467 Jyushin = i2c.read ((addr_gu + 0x01), crdata, 3, true);
Kujira 0:1977c2310ef7 2468
Kujira 0:1977c2310ef7 2469 while(1) {
Kujira 0:1977c2310ef7 2470
Kujira 0:1977c2310ef7 2471 wait(0.1);
Kujira 0:1977c2310ef7 2472
Kujira 0:1977c2310ef7 2473 crdata[0] = 0;
Kujira 0:1977c2310ef7 2474 crdata[1] = 0;
Kujira 0:1977c2310ef7 2475 crdata[2] = 0;
Kujira 0:1977c2310ef7 2476
Kujira 0:1977c2310ef7 2477 i2c.read ((addr_gu + 0x01), crdata, 3, true);
Kujira 0:1977c2310ef7 2478
Kujira 0:1977c2310ef7 2479 if ( crdata[0] == 0x11 && crdata[2] == 1 ) { //個別タッチスイッチ状態読み出しフォーマット。識別子11h。
Kujira 0:1977c2310ef7 2480 cswnum = crdata[1]; //スイッチ番号
Kujira 0:1977c2310ef7 2481 //cswdata = crdata[2];//ON/OFF情報
Kujira 0:1977c2310ef7 2482
Kujira 0:1977c2310ef7 2483 //gu-D タッチスイッチ読み出し動作設定 p49
Kujira 0:1977c2310ef7 2484 cmd_gu[0]= 0x1F;
Kujira 0:1977c2310ef7 2485 cmd_gu[1]= 0x4B;
Kujira 0:1977c2310ef7 2486 cmd_gu[2]= 0x18;
Kujira 0:1977c2310ef7 2487 cmd_gu[3]= 0x00;//SW状態変化時自動送信モード2解除
Kujira 0:1977c2310ef7 2488 i2c.write(addr_gu, cmd_gu, 4); //gu-D タッチスイッチ読み出し動作設定 p49
Kujira 0:1977c2310ef7 2489
Kujira 0:1977c2310ef7 2490 //SWの番号(位置)
Kujira 0:1977c2310ef7 2491 if ( cswnum == 7 ) {
Kujira 0:1977c2310ef7 2492
Kujira 0:1977c2310ef7 2493 gu_Button_power_off();//電源ボタンイメージ反転表示
Kujira 0:1977c2310ef7 2494 wait(0.5);
Kujira 0:1977c2310ef7 2495
Kujira 0:1977c2310ef7 2496 led_off();//LED全消灯
Kujira 0:1977c2310ef7 2497
Kujira 0:1977c2310ef7 2498 return;//この関数を抜ける
Kujira 0:1977c2310ef7 2499
Kujira 0:1977c2310ef7 2500 }
Kujira 0:1977c2310ef7 2501
Kujira 0:1977c2310ef7 2502 //gu-D タッチスイッチ読み出し動作設定 p49
Kujira 0:1977c2310ef7 2503 cmd_gu[0]= 0x1F;
Kujira 0:1977c2310ef7 2504 cmd_gu[1]= 0x4B;
Kujira 0:1977c2310ef7 2505 cmd_gu[2]= 0x18;
Kujira 0:1977c2310ef7 2506 cmd_gu[3]= 0x02;//SW状態変化時自動送信モード2解除
Kujira 0:1977c2310ef7 2507 i2c.write(addr_gu, cmd_gu, 4); //gu-D タッチスイッチ読み出し動作設定 p49
Kujira 0:1977c2310ef7 2508
Kujira 0:1977c2310ef7 2509 wait(0.1);
Kujira 0:1977c2310ef7 2510
Kujira 0:1977c2310ef7 2511 i2c.read ((addr_gu + 0x01), crdata, 3, true);
Kujira 0:1977c2310ef7 2512
Kujira 0:1977c2310ef7 2513 } else if ( sw_start == 0 ) { //if
Kujira 0:1977c2310ef7 2514
Kujira 0:1977c2310ef7 2515 auto_int_hyouji();
Kujira 0:1977c2310ef7 2516
Kujira 0:1977c2310ef7 2517 gu_cursor(0,2);
Kujira 0:1977c2310ef7 2518 gu_print1("Please Wait..");
Kujira 0:1977c2310ef7 2519 gu_fontsize(2);
Kujira 0:1977c2310ef7 2520
Kujira 0:1977c2310ef7 2521 read_regnum();//CAL登録No.読込
Kujira 0:1977c2310ef7 2522
Kujira 0:1977c2310ef7 2523 read_caliber(&calinfo,reg_num);//指定したCAL登録No.の情報を読込後、calinfoへ代入
Kujira 0:1977c2310ef7 2524
Kujira 0:1977c2310ef7 2525 auto_meas( number_of_channels );//2個測定
Kujira 0:1977c2310ef7 2526
Kujira 0:1977c2310ef7 2527 hantei( number_of_channels );//判定LED
Kujira 0:1977c2310ef7 2528
Kujira 0:1977c2310ef7 2529 wait(0.5);
Kujira 0:1977c2310ef7 2530
Kujira 0:1977c2310ef7 2531 gu_fontsize(1);
Kujira 0:1977c2310ef7 2532 gu_cursor(0,2);
Kujira 0:1977c2310ef7 2533 gu_print1("READY ");
Kujira 0:1977c2310ef7 2534
Kujira 0:1977c2310ef7 2535 }
Kujira 0:1977c2310ef7 2536 wait(0.1);
Kujira 0:1977c2310ef7 2537 }//While
Kujira 0:1977c2310ef7 2538 }
Kujira 0:1977c2310ef7 2539 */
Kujira 0:1977c2310ef7 2540
Kujira 0:1977c2310ef7 2541 /*
Kujira 0:1977c2310ef7 2542 void auto_run()
Kujira 0:1977c2310ef7 2543 {
Kujira 0:1977c2310ef7 2544 char cmd_gu[32] ; //gu-DへのI2Cコマンド用配列 1byte
Kujira 0:1977c2310ef7 2545 char crdata[6];
Kujira 0:1977c2310ef7 2546 char cswnum; //SW_No. sw1->0x00 ~~ sw32->0x1F
Kujira 0:1977c2310ef7 2547 //int i;
Kujira 0:1977c2310ef7 2548 //float fdata[4][4];//ファイル出力用
Kujira 0:1977c2310ef7 2549 //short sdata[4];
Kujira 0:1977c2310ef7 2550 //short s;
Kujira 0:1977c2310ef7 2551
Kujira 0:1977c2310ef7 2552 read_regnum();//CAL登録No.読込
Kujira 0:1977c2310ef7 2553 read_caliber(&calinfo,reg_num);//指定したCAL登録No.の情報を読込後、calinfoへ代入
Kujira 0:1977c2310ef7 2554
Kujira 0:1977c2310ef7 2555 auto_int_hyouji();
Kujira 0:1977c2310ef7 2556
Kujira 0:1977c2310ef7 2557 //dac_init(); //DAC 初期化
Kujira 0:1977c2310ef7 2558
Kujira 0:1977c2310ef7 2559 //gu-D タッチスイッチ読み出し動作設定 p49
Kujira 0:1977c2310ef7 2560 cmd_gu[0]= 0x1F;
Kujira 0:1977c2310ef7 2561 cmd_gu[1]= 0x4B;
Kujira 0:1977c2310ef7 2562 cmd_gu[2]= 0x18;
Kujira 0:1977c2310ef7 2563 cmd_gu[3]= 0x02;//SW状態変化時自動送信モード2
Kujira 0:1977c2310ef7 2564 i2c.write(addr_gu, cmd_gu, 4); //gu-D タッチスイッチ読み出し動作設定 p49
Kujira 0:1977c2310ef7 2565
Kujira 0:1977c2310ef7 2566 wait(0.1);
Kujira 0:1977c2310ef7 2567
Kujira 0:1977c2310ef7 2568 Jyushin = i2c.read ((addr_gu + 0x01), crdata, 3, true);
Kujira 0:1977c2310ef7 2569
Kujira 0:1977c2310ef7 2570 while(1) {
Kujira 0:1977c2310ef7 2571
Kujira 0:1977c2310ef7 2572 wait(0.1);
Kujira 0:1977c2310ef7 2573
Kujira 0:1977c2310ef7 2574 crdata[0] = 0;
Kujira 0:1977c2310ef7 2575 crdata[1] = 0;
Kujira 0:1977c2310ef7 2576 crdata[2] = 0;
Kujira 0:1977c2310ef7 2577
Kujira 0:1977c2310ef7 2578 i2c.read ((addr_gu + 0x01), crdata, 3, true);
Kujira 0:1977c2310ef7 2579
Kujira 0:1977c2310ef7 2580 if ( crdata[0] == 0x11 && crdata[2] == 1 ) { //個別タッチスイッチ状態読み出しフォーマット。識別子11h。
Kujira 0:1977c2310ef7 2581 cswnum = crdata[1]; //スイッチ番号
Kujira 0:1977c2310ef7 2582 //cswdata = crdata[2];//ON/OFF情報
Kujira 0:1977c2310ef7 2583
Kujira 0:1977c2310ef7 2584 //gu-D タッチスイッチ読み出し動作設定 p49
Kujira 0:1977c2310ef7 2585 cmd_gu[0]= 0x1F;
Kujira 0:1977c2310ef7 2586 cmd_gu[1]= 0x4B;
Kujira 0:1977c2310ef7 2587 cmd_gu[2]= 0x18;
Kujira 0:1977c2310ef7 2588 cmd_gu[3]= 0x00;//SW状態変化時自動送信モード2解除
Kujira 0:1977c2310ef7 2589 i2c.write(addr_gu, cmd_gu, 4); //gu-D タッチスイッチ読み出し動作設定 p49
Kujira 0:1977c2310ef7 2590
Kujira 0:1977c2310ef7 2591 //SWの番号(位置)
Kujira 0:1977c2310ef7 2592 if ( cswnum == 7 ) {
Kujira 0:1977c2310ef7 2593
Kujira 0:1977c2310ef7 2594 gu_Button_power_off();//電源ボタンイメージ反転表示
Kujira 0:1977c2310ef7 2595 wait(0.5);
Kujira 0:1977c2310ef7 2596
Kujira 0:1977c2310ef7 2597 led_off();//LED全消灯
Kujira 0:1977c2310ef7 2598
Kujira 0:1977c2310ef7 2599 return;//この関数を抜ける
Kujira 0:1977c2310ef7 2600
Kujira 0:1977c2310ef7 2601 } else {
Kujira 0:1977c2310ef7 2602
Kujira 0:1977c2310ef7 2603 auto_int_hyouji();
Kujira 0:1977c2310ef7 2604
Kujira 0:1977c2310ef7 2605 gu_cursor(0,2);
Kujira 0:1977c2310ef7 2606 gu_print1("Please Wait..");
Kujira 0:1977c2310ef7 2607 gu_fontsize(2);
Kujira 0:1977c2310ef7 2608
Kujira 0:1977c2310ef7 2609 read_regnum();//CAL登録No.読込
Kujira 0:1977c2310ef7 2610
Kujira 0:1977c2310ef7 2611 read_caliber(&calinfo,reg_num);//指定したCAL登録No.の情報を読込後、calinfoへ代入
Kujira 0:1977c2310ef7 2612
Kujira 0:1977c2310ef7 2613 auto_meas( number_of_channels );//2個測定
Kujira 0:1977c2310ef7 2614
Kujira 0:1977c2310ef7 2615 hantei( number_of_channels );//判定LED
Kujira 0:1977c2310ef7 2616
Kujira 0:1977c2310ef7 2617 wait(0.5);
Kujira 0:1977c2310ef7 2618
Kujira 0:1977c2310ef7 2619 gu_fontsize(1);
Kujira 0:1977c2310ef7 2620 gu_cursor(0,2);
Kujira 0:1977c2310ef7 2621 gu_print1("READY ");
Kujira 0:1977c2310ef7 2622
Kujira 0:1977c2310ef7 2623 } //else if
Kujira 0:1977c2310ef7 2624
Kujira 0:1977c2310ef7 2625 //gu-D タッチスイッチ読み出し動作設定 p49
Kujira 0:1977c2310ef7 2626 cmd_gu[0]= 0x1F;
Kujira 0:1977c2310ef7 2627 cmd_gu[1]= 0x4B;
Kujira 0:1977c2310ef7 2628 cmd_gu[2]= 0x18;
Kujira 0:1977c2310ef7 2629 cmd_gu[3]= 0x02;//SW状態変化時自動送信モード2解除
Kujira 0:1977c2310ef7 2630 i2c.write(addr_gu, cmd_gu, 4); //gu-D タッチスイッチ読み出し動作設定 p49
Kujira 0:1977c2310ef7 2631
Kujira 0:1977c2310ef7 2632 wait(0.1);
Kujira 0:1977c2310ef7 2633
Kujira 0:1977c2310ef7 2634 i2c.read ((addr_gu + 0x01), crdata, 3, true);
Kujira 0:1977c2310ef7 2635
Kujira 0:1977c2310ef7 2636 }//if
Kujira 0:1977c2310ef7 2637
Kujira 0:1977c2310ef7 2638 wait(0.1);
Kujira 0:1977c2310ef7 2639
Kujira 0:1977c2310ef7 2640 }//While
Kujira 0:1977c2310ef7 2641
Kujira 0:1977c2310ef7 2642 }
Kujira 0:1977c2310ef7 2643 */
Kujira 0:1977c2310ef7 2644
Kujira 0:1977c2310ef7 2645 /*********************************
Kujira 0:1977c2310ef7 2646
Kujira 0:1977c2310ef7 2647 Auto Mode (Sub)
Kujira 0:1977c2310ef7 2648
Kujira 0:1977c2310ef7 2649 *********************************/
Kujira 0:1977c2310ef7 2650 void meas_sub()
Kujira 0:1977c2310ef7 2651 {
Kujira 0:1977c2310ef7 2652 auto_int_hyouji();
Kujira 0:1977c2310ef7 2653
Kujira 0:1977c2310ef7 2654 gu_cursor(0,2);
Kujira 0:1977c2310ef7 2655 gu_print1("Please Wait..");
Kujira 0:1977c2310ef7 2656 gu_fontsize(2);
Kujira 0:1977c2310ef7 2657
Kujira 0:1977c2310ef7 2658 read_regnum();//CAL登録No.読込
Kujira 0:1977c2310ef7 2659
Kujira 0:1977c2310ef7 2660 read_caliber(&calinfo,reg_num);//指定したCAL登録No.の情報を読込後、calinfoへ代入
Kujira 0:1977c2310ef7 2661
Kujira 0:1977c2310ef7 2662 auto_meas( number_of_channels );//2個測定
Kujira 0:1977c2310ef7 2663
Kujira 0:1977c2310ef7 2664 hantei( number_of_channels );//判定LED
Kujira 0:1977c2310ef7 2665
Kujira 0:1977c2310ef7 2666 wait(0.5);
Kujira 0:1977c2310ef7 2667
Kujira 0:1977c2310ef7 2668 gu_fontsize(1);
Kujira 0:1977c2310ef7 2669 gu_cursor(0,2);
Kujira 0:1977c2310ef7 2670 gu_print1("READY ");
Kujira 0:1977c2310ef7 2671
Kujira 0:1977c2310ef7 2672 }
Kujira 0:1977c2310ef7 2673
Kujira 0:1977c2310ef7 2674 /*********************************
Kujira 0:1977c2310ef7 2675
Kujira 0:1977c2310ef7 2676 Auto Mode/SEQ Mode (sub)
Kujira 0:1977c2310ef7 2677 自動測定
Kujira 0:1977c2310ef7 2678 char noc -> 総測定数 1~4
Kujira 0:1977c2310ef7 2679
Kujira 0:1977c2310ef7 2680 *********************************/
Kujira 0:1977c2310ef7 2681 void auto_meas(char noc)
Kujira 0:1977c2310ef7 2682 {
Kujira 0:1977c2310ef7 2683 int x[4] = {0,0,128,128}; //GU_D x座標 4個測定時の表示スタート位置
Kujira 0:1977c2310ef7 2684 int y[4] = {5,11,5,11}; //GU_D y座標 4個測定時の表示スタート位置
Kujira 0:1977c2310ef7 2685 int iy ; //GU_D y座標 2個測定時の表示スタート位置
Kujira 0:1977c2310ef7 2686 int i;
Kujira 0:1977c2310ef7 2687 float fdata[4][4];//ファイル出力用
Kujira 0:1977c2310ef7 2688 short sdata[4];
Kujira 0:1977c2310ef7 2689
Kujira 0:1977c2310ef7 2690 iy = 4;//GU_D 2個測定時の測定値の表示開始位置 y座標
Kujira 0:1977c2310ef7 2691
Kujira 0:1977c2310ef7 2692 if ( noc > 4 ) {
Kujira 0:1977c2310ef7 2693 noc = 4;
Kujira 0:1977c2310ef7 2694 }
Kujira 0:1977c2310ef7 2695
Kujira 0:1977c2310ef7 2696 //値の初期化
Kujira 0:1977c2310ef7 2697 for ( i = 0; i <= 3; i++) {
Kujira 0:1977c2310ef7 2698 I[i] = 0;
Kujira 0:1977c2310ef7 2699 R[i] = 0; //ver 1.1.1
Kujira 0:1977c2310ef7 2700 iop[i] = 0;
Kujira 0:1977c2310ef7 2701 voc[i] = 0;
Kujira 0:1977c2310ef7 2702 ocp[i] = 0;
Kujira 0:1977c2310ef7 2703 }
Kujira 0:1977c2310ef7 2704
Kujira 0:1977c2310ef7 2705 //判定用LED消灯
Kujira 0:1977c2310ef7 2706 led_off();
Kujira 0:1977c2310ef7 2707
Kujira 0:1977c2310ef7 2708 //電源投入
Kujira 0:1977c2310ef7 2709 for ( i = 0; i <= ( noc - 1 ); i++) {
Kujira 0:1977c2310ef7 2710 dac_out( calinfo.vss_iop,i); //Vss設定 DAC_A~D
Kujira 0:1977c2310ef7 2711 }
Kujira 0:1977c2310ef7 2712
Kujira 0:1977c2310ef7 2713 wait( wait_poweron );//パワーブレイク復帰待機?
Kujira 0:1977c2310ef7 2714
Kujira 0:1977c2310ef7 2715 //Reset CAL
Kujira 0:1977c2310ef7 2716 for ( i = 0; i <= ( noc -1 ); i++) {
Kujira 0:1977c2310ef7 2717 io[i] = 1; //io1 = "H"
Kujira 0:1977c2310ef7 2718 }
Kujira 0:1977c2310ef7 2719
Kujira 0:1977c2310ef7 2720 wait(time_reset); //ver1.1.3
Kujira 0:1977c2310ef7 2721 //wait(0.2);
Kujira 0:1977c2310ef7 2722
Kujira 0:1977c2310ef7 2723 for ( i = 0; i <= ( noc -1 ); i++) {
Kujira 0:1977c2310ef7 2724 io[i] = 0; //io1 = "L"
Kujira 0:1977c2310ef7 2725 }
Kujira 0:1977c2310ef7 2726
Kujira 0:1977c2310ef7 2727 //抵抗測定
Kujira 0:1977c2310ef7 2728 for ( i = 0; i <= ( noc -1 ); i++ ) {
Kujira 0:1977c2310ef7 2729 R[i] = meas_resistor(i);
Kujira 0:1977c2310ef7 2730 }
Kujira 0:1977c2310ef7 2731
Kujira 0:1977c2310ef7 2732 //display GU_D
Kujira 0:1977c2310ef7 2733 if ( number_of_channels <= 2 ) { //2個測定の時の表示
Kujira 0:1977c2310ef7 2734 gu_fontsize(2);
Kujira 0:1977c2310ef7 2735 gu_cursor(0,iy);
Kujira 0:1977c2310ef7 2736 gu_print1("[ch.1]");
Kujira 0:1977c2310ef7 2737 gu_cursor(128,iy);
Kujira 0:1977c2310ef7 2738 gu_print1("[ch.2]");
Kujira 0:1977c2310ef7 2739 //CH.1 表示
Kujira 0:1977c2310ef7 2740 gu_cursor(0, iy + 2);
Kujira 0:1977c2310ef7 2741 gu_print1("R ");
Kujira 0:1977c2310ef7 2742 display_resistor( R[0] );
Kujira 0:1977c2310ef7 2743 //CH.2 表示
Kujira 0:1977c2310ef7 2744 gu_cursor(128, iy + 2);
Kujira 0:1977c2310ef7 2745 gu_print("R ");
Kujira 0:1977c2310ef7 2746 display_resistor( R[1] );
Kujira 0:1977c2310ef7 2747 } else if( number_of_channels >= 3) { //3.4個測定の時の表示
Kujira 0:1977c2310ef7 2748 gu_fontsize(1);
Kujira 0:1977c2310ef7 2749 gu_cursor(x[0],y[0]);
Kujira 0:1977c2310ef7 2750 gu_print1("ch.1");
Kujira 0:1977c2310ef7 2751 gu_cursor(x[1],y[1] );
Kujira 0:1977c2310ef7 2752 gu_print1("ch.2");
Kujira 0:1977c2310ef7 2753 gu_cursor(x[2],y[2]);
Kujira 0:1977c2310ef7 2754 gu_print1("ch.3");
Kujira 0:1977c2310ef7 2755
Kujira 0:1977c2310ef7 2756 if ( number_of_channels == 4 ) {
Kujira 0:1977c2310ef7 2757 gu_cursor(x[3],y[3]);
Kujira 0:1977c2310ef7 2758 gu_print1("ch.4");
Kujira 0:1977c2310ef7 2759 }
Kujira 0:1977c2310ef7 2760
Kujira 0:1977c2310ef7 2761 //CH.1~4 表示
Kujira 0:1977c2310ef7 2762 for ( i = 0; i <= ( number_of_channels - 1 ); i++) {
Kujira 0:1977c2310ef7 2763 gu_cursor( x[i], y[i] + 1 );//x座標指定
Kujira 0:1977c2310ef7 2764 gu_print1("R ");
Kujira 0:1977c2310ef7 2765 display_resistor( R[i] );
Kujira 0:1977c2310ef7 2766 }
Kujira 0:1977c2310ef7 2767 }
Kujira 0:1977c2310ef7 2768
Kujira 0:1977c2310ef7 2769 //iop測定
Kujira 0:1977c2310ef7 2770 wait(calinfo.wait_iop);//Vss印加~リセット後からiop測定までの待機時間
Kujira 0:1977c2310ef7 2771
Kujira 0:1977c2310ef7 2772 meas_current_automode( noc );//電流測定サブ 測定値をI[]へ代入
Kujira 0:1977c2310ef7 2773
Kujira 0:1977c2310ef7 2774 for( i = 0; i <= ( noc - 1) ; i++) {
Kujira 0:1977c2310ef7 2775 iop[i] = I[i];
Kujira 0:1977c2310ef7 2776 }
Kujira 0:1977c2310ef7 2777
Kujira 0:1977c2310ef7 2778 //display GU_D
Kujira 0:1977c2310ef7 2779 if ( number_of_channels <= 2 ) { //2個測定の時の表示
Kujira 0:1977c2310ef7 2780 gu_cursor(0, iy + 4 );//IOP測定値表示位置指定
Kujira 0:1977c2310ef7 2781 gu_print1("Iop ");
Kujira 0:1977c2310ef7 2782 gu_putdeci(&iop[0]);
Kujira 0:1977c2310ef7 2783 gu_cursor(128, iy + 4 );
Kujira 0:1977c2310ef7 2784 gu_print1("Iop ");
Kujira 0:1977c2310ef7 2785 gu_putdeci(&iop[1]);
Kujira 0:1977c2310ef7 2786 } else {
Kujira 0:1977c2310ef7 2787 //CH.1~4 表示
Kujira 0:1977c2310ef7 2788 for ( i=0; i <= ( number_of_channels - 1 ); i++) {
Kujira 0:1977c2310ef7 2789 gu_cursor( x[i], y[i] + 2 ); //x座標指定
Kujira 0:1977c2310ef7 2790 gu_print1("Iop ");
Kujira 0:1977c2310ef7 2791 gu_putdeci(&iop[i]);
Kujira 0:1977c2310ef7 2792 }
Kujira 0:1977c2310ef7 2793 }
Kujira 0:1977c2310ef7 2794
Kujira 0:1977c2310ef7 2795 wait(0.01);
Kujira 0:1977c2310ef7 2796
Kujira 0:1977c2310ef7 2797 //過充電防止時電流測定
Kujira 0:1977c2310ef7 2798 for ( i = 0; i <= ( noc - 1 ); i++) {
Kujira 0:1977c2310ef7 2799 dac_out( calinfo.vss_ocp,i); //Vss設定 DAC_A~D //ver1.1.2
Kujira 0:1977c2310ef7 2800 }
Kujira 0:1977c2310ef7 2801
Kujira 0:1977c2310ef7 2802 wait( calinfo.wait_ocp );
Kujira 0:1977c2310ef7 2803
Kujira 0:1977c2310ef7 2804 meas_current_automode( noc );
Kujira 0:1977c2310ef7 2805
Kujira 0:1977c2310ef7 2806 for( i = 0; i <= ( noc - 1) ; i++) {
Kujira 0:1977c2310ef7 2807 ocp[i] = I[i];
Kujira 0:1977c2310ef7 2808 }
Kujira 0:1977c2310ef7 2809
Kujira 0:1977c2310ef7 2810 //display GU_D
Kujira 0:1977c2310ef7 2811 if ( number_of_channels <= 2 ) { //2個測定の時の表示
Kujira 0:1977c2310ef7 2812 gu_cursor(0, iy + 6 );//IOP測定値表示位置指定
Kujira 0:1977c2310ef7 2813 gu_print1("OCP ");
Kujira 0:1977c2310ef7 2814 gu_putdeci(&ocp[0]);
Kujira 0:1977c2310ef7 2815 gu_cursor(128, iy + 6 );
Kujira 0:1977c2310ef7 2816 gu_print1("OCP ");
Kujira 0:1977c2310ef7 2817 gu_putdeci(&ocp[1]);
Kujira 0:1977c2310ef7 2818 } else {
Kujira 0:1977c2310ef7 2819 //CH.1~4 表示
Kujira 0:1977c2310ef7 2820 for ( i=0; i <= ( number_of_channels - 1 ); i++) {
Kujira 0:1977c2310ef7 2821 gu_cursor( x[i], y[i] + 3 ); //x座標指定
Kujira 0:1977c2310ef7 2822 gu_print1("OCP ");
Kujira 0:1977c2310ef7 2823 gu_putdeci(&ocp[i]);
Kujira 0:1977c2310ef7 2824 }
Kujira 0:1977c2310ef7 2825 }
Kujira 0:1977c2310ef7 2826
Kujira 0:1977c2310ef7 2827 //VOC測定
Kujira 0:1977c2310ef7 2828 for ( i = 0; i <= ( noc - 1 ); i++) {
Kujira 0:1977c2310ef7 2829 dac_out( calinfo.vss_voc,i); //Vss設定 DAC_A~D
Kujira 0:1977c2310ef7 2830 }
Kujira 0:1977c2310ef7 2831
Kujira 0:1977c2310ef7 2832 wait( wait_voc );
Kujira 0:1977c2310ef7 2833
Kujira 0:1977c2310ef7 2834 for ( i = 0; i <= ( noc -1 ); i++) {
Kujira 0:1977c2310ef7 2835 io[i] = 1; //io1 = "H"
Kujira 0:1977c2310ef7 2836 }
Kujira 0:1977c2310ef7 2837
Kujira 0:1977c2310ef7 2838 wait( wait_reset );
Kujira 0:1977c2310ef7 2839
Kujira 0:1977c2310ef7 2840 for ( i = 0; i <= ( noc -1 ); i++ ) {
Kujira 0:1977c2310ef7 2841
Kujira 0:1977c2310ef7 2842 //ver1.2.0
Kujira 0:1977c2310ef7 2843 if (RL_EN == 1) {
Kujira 0:1977c2310ef7 2844 switch (i) {
Kujira 0:1977c2310ef7 2845 case 0:
Kujira 0:1977c2310ef7 2846 io[4] = 1; //外付けリレーON
Kujira 0:1977c2310ef7 2847 wait(TIME_RELAY_ON);
Kujira 0:1977c2310ef7 2848 case 1:
Kujira 0:1977c2310ef7 2849 io[5] = 1; //外付けリレーON
Kujira 0:1977c2310ef7 2850 wait(TIME_RELAY_ON);
Kujira 0:1977c2310ef7 2851 }
Kujira 0:1977c2310ef7 2852 }
Kujira 0:1977c2310ef7 2853 //up to here ver1.2.0
Kujira 0:1977c2310ef7 2854
Kujira 0:1977c2310ef7 2855 voc[i] = meas_voltage(i);
Kujira 0:1977c2310ef7 2856 sdata[i] = voc[i] * -1;
Kujira 0:1977c2310ef7 2857
Kujira 0:1977c2310ef7 2858 //ver1.2.0
Kujira 0:1977c2310ef7 2859 if (RL_EN == 1) {
Kujira 0:1977c2310ef7 2860 io[4] = 0; //外付けリレーOFF
Kujira 0:1977c2310ef7 2861 io[5] = 0; //外付けリレーOFF
Kujira 0:1977c2310ef7 2862 wait(TIME_RELAY_OFF);
Kujira 0:1977c2310ef7 2863 }
Kujira 0:1977c2310ef7 2864 //up to here
Kujira 0:1977c2310ef7 2865 }
Kujira 0:1977c2310ef7 2866
Kujira 0:1977c2310ef7 2867
Kujira 0:1977c2310ef7 2868 //display GU_D
Kujira 0:1977c2310ef7 2869 if ( number_of_channels <= 2 ) { //2個測定の時の表示
Kujira 0:1977c2310ef7 2870 gu_cursor(0, iy + 8 );//IOP測定値表示位置指定
Kujira 0:1977c2310ef7 2871 gu_print1("Voc ");
Kujira 0:1977c2310ef7 2872 gu_putdeck(&sdata[0]);
Kujira 0:1977c2310ef7 2873 gu_print1("V");
Kujira 0:1977c2310ef7 2874 gu_cursor(128, iy + 8 );
Kujira 0:1977c2310ef7 2875 gu_print1("Voc ");
Kujira 0:1977c2310ef7 2876 gu_putdeck(&sdata[1]);
Kujira 0:1977c2310ef7 2877 gu_print1("V");
Kujira 0:1977c2310ef7 2878 } else {
Kujira 0:1977c2310ef7 2879 //CH.1~4 表示
Kujira 0:1977c2310ef7 2880 for ( i=0; i <= ( number_of_channels - 1 ); i++) {
Kujira 0:1977c2310ef7 2881 gu_cursor( x[i], y[i] + 4 );//x座標指定
Kujira 0:1977c2310ef7 2882 gu_print1("Voc ");
Kujira 0:1977c2310ef7 2883 gu_putdeck(&sdata[i]);
Kujira 0:1977c2310ef7 2884 gu_print1("V");
Kujira 0:1977c2310ef7 2885 }
Kujira 0:1977c2310ef7 2886 }
Kujira 0:1977c2310ef7 2887
Kujira 0:1977c2310ef7 2888 //R = "L"
Kujira 0:1977c2310ef7 2889 for ( i = 0; i <= ( noc -1 ); i++) {
Kujira 0:1977c2310ef7 2890 io[i] = 0; //io1 = "L"
Kujira 0:1977c2310ef7 2891 }
Kujira 0:1977c2310ef7 2892
Kujira 0:1977c2310ef7 2893 wait(0.1);
Kujira 0:1977c2310ef7 2894
Kujira 0:1977c2310ef7 2895 //Vss=0V
Kujira 0:1977c2310ef7 2896 for ( i = 0; i <= ( noc - 1 ); i++) {
Kujira 0:1977c2310ef7 2897 dac_out( 0, i );//Vss設定 DAC_A~D
Kujira 0:1977c2310ef7 2898 }
Kujira 0:1977c2310ef7 2899
Kujira 0:1977c2310ef7 2900 //ファイルオープン
Kujira 0:1977c2310ef7 2901 mkdir("/sd/mydir", 0777);
Kujira 0:1977c2310ef7 2902
Kujira 0:1977c2310ef7 2903 FILE *fp = fopen("/sd/mydir/iop.csv", "ab+");//ディレクトリとファイル名の指定,追加モード
Kujira 0:1977c2310ef7 2904
Kujira 0:1977c2310ef7 2905 if(fp == NULL) {
Kujira 0:1977c2310ef7 2906 /* ver1.1.3
Kujira 0:1977c2310ef7 2907 gu_fontsize(1);
Kujira 0:1977c2310ef7 2908 gu_cursor(0,2);
Kujira 0:1977c2310ef7 2909 gu_print1("Could not open file for SD card");
Kujira 0:1977c2310ef7 2910 */
Kujira 0:1977c2310ef7 2911 } else {
Kujira 0:1977c2310ef7 2912 for ( i = 0; i <= ( noc - 1 ); i++) {
Kujira 0:1977c2310ef7 2913 fdata[i][0] = iop[i] * 0.01; //1bitあたり0.01uA
Kujira 0:1977c2310ef7 2914 fdata[i][1] = ocp[i] * 0.01; //1bitあたり0.01uA
Kujira 0:1977c2310ef7 2915 fdata[i][2] = voc[i] * 0.001; //1bitあたり0.001V
Kujira 0:1977c2310ef7 2916 }
Kujira 0:1977c2310ef7 2917
Kujira 0:1977c2310ef7 2918 for( i = 0; i <= ( noc - 1 ); i++) {
Kujira 0:1977c2310ef7 2919
Kujira 0:1977c2310ef7 2920 switch ( i ) {
Kujira 0:1977c2310ef7 2921 case 0:
Kujira 0:1977c2310ef7 2922 fprintf(fp, "CH.1");
Kujira 0:1977c2310ef7 2923 break;
Kujira 0:1977c2310ef7 2924 case 1:
Kujira 0:1977c2310ef7 2925 fprintf(fp, "CH.2");
Kujira 0:1977c2310ef7 2926 break;
Kujira 0:1977c2310ef7 2927 case 2:
Kujira 0:1977c2310ef7 2928 fprintf(fp, "CH.3");
Kujira 0:1977c2310ef7 2929 break;
Kujira 0:1977c2310ef7 2930 case 3:
Kujira 0:1977c2310ef7 2931 fprintf(fp, "CH.4");
Kujira 0:1977c2310ef7 2932 break;
Kujira 0:1977c2310ef7 2933 }
Kujira 0:1977c2310ef7 2934
Kujira 0:1977c2310ef7 2935 fprintf(fp, " ");//excel 区切り位置
Kujira 0:1977c2310ef7 2936 if ( R[i] < res_vref && R[0] >= 0 ) {
Kujira 0:1977c2310ef7 2937 fprintf(fp, "%d", R[i]);
Kujira 0:1977c2310ef7 2938 } else {
Kujira 0:1977c2310ef7 2939 fprintf(fp,"OL");
Kujira 0:1977c2310ef7 2940 }
Kujira 0:1977c2310ef7 2941 fprintf(fp, " ");
Kujira 0:1977c2310ef7 2942 fprintf(fp, "%f", fdata[i][0]);
Kujira 0:1977c2310ef7 2943 fprintf(fp, " ");
Kujira 0:1977c2310ef7 2944 fprintf(fp, "%f", fdata[i][1]);
Kujira 0:1977c2310ef7 2945 fprintf(fp, " ");
Kujira 0:1977c2310ef7 2946 fprintf(fp, "%f", fdata[i][2]);
Kujira 0:1977c2310ef7 2947 fprintf(fp, " ");
Kujira 0:1977c2310ef7 2948 }//for
Kujira 0:1977c2310ef7 2949
Kujira 0:1977c2310ef7 2950 //ファイルクローズ
Kujira 0:1977c2310ef7 2951 fprintf(fp, "\n");
Kujira 0:1977c2310ef7 2952 fclose(fp);
Kujira 0:1977c2310ef7 2953 }
Kujira 0:1977c2310ef7 2954
Kujira 0:1977c2310ef7 2955 }
Kujira 0:1977c2310ef7 2956
Kujira 0:1977c2310ef7 2957 /*********************************
Kujira 0:1977c2310ef7 2958
Kujira 0:1977c2310ef7 2959 電流測定(iop/voc共通)
Kujira 0:1977c2310ef7 2960 char amount;//測定数
Kujira 0:1977c2310ef7 2961
Kujira 0:1977c2310ef7 2962 *********************************/
Kujira 0:1977c2310ef7 2963 void meas_current_automode(char amount) //a quantity of measuring channel
Kujira 0:1977c2310ef7 2964 {
Kujira 0:1977c2310ef7 2965 int i;
Kujira 0:1977c2310ef7 2966
Kujira 0:1977c2310ef7 2967 //amount = number_of_channels;
Kujira 0:1977c2310ef7 2968
Kujira 0:1977c2310ef7 2969 //set range
Kujira 0:1977c2310ef7 2970 for ( i = 0; i <= ( amount - 1 ); i++)
Kujira 0:1977c2310ef7 2971 range[i] = 1; //range 10uA
Kujira 0:1977c2310ef7 2972
Kujira 0:1977c2310ef7 2973 wait(0.1);
Kujira 0:1977c2310ef7 2974
Kujira 0:1977c2310ef7 2975 //discharge condenser
Kujira 0:1977c2310ef7 2976 for ( i = 0; i <= ( amount - 1 ); i++)
Kujira 0:1977c2310ef7 2977 houden[i] = 1; //discharge condenser
Kujira 0:1977c2310ef7 2978
Kujira 0:1977c2310ef7 2979 wait(time_discharge);//discharge time
Kujira 0:1977c2310ef7 2980
Kujira 0:1977c2310ef7 2981 ch_num = 0;
Kujira 0:1977c2310ef7 2982 select_ich( ch_num ); //select channel that mesuring current
Kujira 0:1977c2310ef7 2983 houden[0] = 0; //start integral
Kujira 0:1977c2310ef7 2984
Kujira 0:1977c2310ef7 2985 oneshot1.attach ( &flip_ch1, time_integral );
Kujira 0:1977c2310ef7 2986
Kujira 0:1977c2310ef7 2987 if ( amount >= 2 ) {
Kujira 0:1977c2310ef7 2988 wait(0.1);
Kujira 0:1977c2310ef7 2989 houden[1] = 0;
Kujira 0:1977c2310ef7 2990 oneshot2.attach ( &flip_ch2, time_integral );
Kujira 0:1977c2310ef7 2991 }
Kujira 0:1977c2310ef7 2992
Kujira 0:1977c2310ef7 2993 if ( amount >= 3 ) {
Kujira 0:1977c2310ef7 2994 wait(0.1);
Kujira 0:1977c2310ef7 2995 houden[2] = 0;
Kujira 0:1977c2310ef7 2996 oneshot3.attach ( &flip_ch3, time_integral );
Kujira 0:1977c2310ef7 2997 }
Kujira 0:1977c2310ef7 2998
Kujira 0:1977c2310ef7 2999 if ( amount == 4 ) {
Kujira 0:1977c2310ef7 3000 wait(0.1);
Kujira 0:1977c2310ef7 3001 houden[3] = 0;
Kujira 0:1977c2310ef7 3002 oneshot4.attach ( &flip_ch4, time_integral );
Kujira 0:1977c2310ef7 3003 }
Kujira 0:1977c2310ef7 3004
Kujira 0:1977c2310ef7 3005 wait( time_integral + 0.3 );//wait Timeout
Kujira 0:1977c2310ef7 3006
Kujira 0:1977c2310ef7 3007 //discharge condenser
Kujira 0:1977c2310ef7 3008 for ( i = 0; i <= ( amount - 1 ); i++)
Kujira 0:1977c2310ef7 3009 houden[i] = 1; //discharge condenser
Kujira 0:1977c2310ef7 3010
Kujira 0:1977c2310ef7 3011 wait(time_discharge);//discharge time
Kujira 0:1977c2310ef7 3012
Kujira 0:1977c2310ef7 3013 //not discharge condenser
Kujira 0:1977c2310ef7 3014 for ( i = 0; i <= ( amount - 1 ); i++)
Kujira 0:1977c2310ef7 3015 houden[i] = 0;
Kujira 0:1977c2310ef7 3016
Kujira 0:1977c2310ef7 3017 //set range
Kujira 0:1977c2310ef7 3018 for ( i = 0; i <= ( amount - 1 ); i++)
Kujira 0:1977c2310ef7 3019 range[i] = 0; //range 1mA
Kujira 0:1977c2310ef7 3020
Kujira 0:1977c2310ef7 3021 oneshot1.detach();
Kujira 0:1977c2310ef7 3022 oneshot2.detach();
Kujira 0:1977c2310ef7 3023 oneshot3.detach();
Kujira 0:1977c2310ef7 3024 oneshot4.detach();
Kujira 0:1977c2310ef7 3025
Kujira 0:1977c2310ef7 3026 }
Kujira 0:1977c2310ef7 3027
Kujira 0:1977c2310ef7 3028 /*********************************
Kujira 0:1977c2310ef7 3029 DAC 初期設定
Kujira 0:1977c2310ef7 3030 LDACレジスタの設定
Kujira 0:1977c2310ef7 3031 内部リファレンス電圧のセットアップ
Kujira 0:1977c2310ef7 3032 入力シフトレジスタ:
Kujira 0:1977c2310ef7 3033 0011 1000 0000 0000 0000 0001
Kujira 0:1977c2310ef7 3034 (0x3F0001)
Kujira 0:1977c2310ef7 3035 *********************************/
Kujira 0:1977c2310ef7 3036 void dac_init()
Kujira 0:1977c2310ef7 3037 {
Kujira 0:1977c2310ef7 3038
Kujira 0:1977c2310ef7 3039 //内部リファレンス電圧のセットアップ
Kujira 0:1977c2310ef7 3040 wdata[0] = 0x38;
Kujira 0:1977c2310ef7 3041 wdata[1] = 0x00;
Kujira 0:1977c2310ef7 3042 wdata[2] = 0x01;//
Kujira 0:1977c2310ef7 3043
Kujira 0:1977c2310ef7 3044 i2c.write ( addr_dac, wdata, 3);
Kujira 0:1977c2310ef7 3045
Kujira 0:1977c2310ef7 3046 wait(0.1);
Kujira 0:1977c2310ef7 3047
Kujira 0:1977c2310ef7 3048 //LDAC設定
Kujira 0:1977c2310ef7 3049 wdata[0] = 0x30;
Kujira 0:1977c2310ef7 3050 wdata[1] = 0x00;
Kujira 0:1977c2310ef7 3051 wdata[2] = 0x0F;//
Kujira 0:1977c2310ef7 3052
Kujira 0:1977c2310ef7 3053 i2c.write ( addr_dac, wdata, 3);
Kujira 0:1977c2310ef7 3054
Kujira 0:1977c2310ef7 3055 }
Kujira 0:1977c2310ef7 3056
Kujira 0:1977c2310ef7 3057 /**************************************
Kujira 0:1977c2310ef7 3058 DAC 電圧印加
Kujira 0:1977c2310ef7 3059 Vout = 2 * Vref(2.5V) * ( D /2^2 )
Kujira 0:1977c2310ef7 3060 mvolt[mV] 0~5000で設定
Kujira 0:1977c2310ef7 3061 addrは、0x00~03.全チャネルは0x07で指定
Kujira 0:1977c2310ef7 3062 **************************************/
Kujira 0:1977c2310ef7 3063 void dac_out(short mvolt, char addr) //addr DACA:0x00 DACB:0x01 DACC:0x02 DACD:0x03 allDACs:0x07
Kujira 0:1977c2310ef7 3064 {
Kujira 0:1977c2310ef7 3065 char command;//1byte
Kujira 0:1977c2310ef7 3066 short dacdata;//2byte
Kujira 0:1977c2310ef7 3067
Kujira 0:1977c2310ef7 3068 command = 0x02;//write to input register n 仕様書p25参照
Kujira 0:1977c2310ef7 3069
Kujira 0:1977c2310ef7 3070 dacdata = mvolt * 4095 / 2 / dac_vref ; //12bit mvolt[mV] 0~5000で設定する
Kujira 0:1977c2310ef7 3071
Kujira 0:1977c2310ef7 3072 dacdata = dacdata << 4; //後ろ4bitはdon't care bit
Kujira 0:1977c2310ef7 3073
Kujira 0:1977c2310ef7 3074 wdata[0] = command << 3 | addr; //1byte
Kujira 0:1977c2310ef7 3075 wdata[1] = dacdata >> 8 ; //1byte
Kujira 0:1977c2310ef7 3076 wdata[2] = dacdata & 0xFF;//1byte
Kujira 0:1977c2310ef7 3077
Kujira 0:1977c2310ef7 3078 i2c.write(addr_dac, wdata, 3);
Kujira 0:1977c2310ef7 3079
Kujira 0:1977c2310ef7 3080 }
Kujira 0:1977c2310ef7 3081 /*********************************
Kujira 0:1977c2310ef7 3082 ADC測定し、平均値を算出する
Kujira 0:1977c2310ef7 3083
Kujira 0:1977c2310ef7 3084 貰う値:平均値の分母
Kujira 0:1977c2310ef7 3085 渡す値:平均値
Kujira 0:1977c2310ef7 3086 *********************************/
Kujira 0:1977c2310ef7 3087 void compute_adc(int adc_con, long *avg) //(ADCのCONFIG, 計算結果)
Kujira 0:1977c2310ef7 3088 {
Kujira 0:1977c2310ef7 3089
Kujira 0:1977c2310ef7 3090 //short sdata[10];//2byte
Kujira 0:1977c2310ef7 3091 long ldata[10];//4byte
Kujira 0:1977c2310ef7 3092 long nu;//平均値の分子 4byte
Kujira 0:1977c2310ef7 3093 long max;
Kujira 0:1977c2310ef7 3094 long min;
Kujira 0:1977c2310ef7 3095 char i;
Kujira 0:1977c2310ef7 3096 char x;
Kujira 0:1977c2310ef7 3097 //int n;
Kujira 0:1977c2310ef7 3098
Kujira 0:1977c2310ef7 3099 x = 10;
Kujira 0:1977c2310ef7 3100
Kujira 0:1977c2310ef7 3101 wdata[0] = adc_con; //ADC configuration data チャンネルの選択など
Kujira 0:1977c2310ef7 3102 i2c.write( addr_ADC1, wdata, 1 );
Kujira 0:1977c2310ef7 3103 wait(0.1);
Kujira 0:1977c2310ef7 3104
Kujira 0:1977c2310ef7 3105 //平均値の母数の数、測定を実施。
Kujira 0:1977c2310ef7 3106 for( i=0; i<=(x-1); i++) {
Kujira 0:1977c2310ef7 3107
Kujira 0:1977c2310ef7 3108 i2c.read( addr_ADC1 + 0x01, rdata, 3);
Kujira 0:1977c2310ef7 3109 //2byte結合
Kujira 0:1977c2310ef7 3110 ldata[i] = rdata[0] & 0xFF;
Kujira 0:1977c2310ef7 3111 ldata[i] = ( ldata[i] << 8 ) | rdata[1];
Kujira 0:1977c2310ef7 3112
Kujira 0:1977c2310ef7 3113 if ( ldata[i] >= 0x8000 ) {
Kujira 0:1977c2310ef7 3114 ldata[i] = ldata[i] | 0xFFFF0000; //4byteの補数へ変換
Kujira 0:1977c2310ef7 3115 }
Kujira 0:1977c2310ef7 3116
Kujira 0:1977c2310ef7 3117 wait(0.05);
Kujira 0:1977c2310ef7 3118
Kujira 0:1977c2310ef7 3119 }//for
Kujira 0:1977c2310ef7 3120
Kujira 0:1977c2310ef7 3121 //最大値を取得
Kujira 0:1977c2310ef7 3122 max = ldata[0];
Kujira 0:1977c2310ef7 3123 for ( i=0; i<=(x-2); i++) {
Kujira 0:1977c2310ef7 3124 if ( ldata[i+1] > ldata[i]) {
Kujira 0:1977c2310ef7 3125 max = ldata[i+1];
Kujira 0:1977c2310ef7 3126 }
Kujira 0:1977c2310ef7 3127 }
Kujira 0:1977c2310ef7 3128 //最小値
Kujira 0:1977c2310ef7 3129 min = ldata[0];
Kujira 0:1977c2310ef7 3130 for ( i=0; i<=(x-2); i++) {
Kujira 0:1977c2310ef7 3131 if ( ldata[i+1] < ldata[i]) {
Kujira 0:1977c2310ef7 3132 min = ldata[i+1];
Kujira 0:1977c2310ef7 3133 }
Kujira 0:1977c2310ef7 3134 }
Kujira 0:1977c2310ef7 3135
Kujira 0:1977c2310ef7 3136 //平均値
Kujira 0:1977c2310ef7 3137 nu = 0x00000000; //4byte
Kujira 0:1977c2310ef7 3138 for ( i=0; i<=(x-1); i++) {
Kujira 0:1977c2310ef7 3139 nu = nu + ldata[i];
Kujira 0:1977c2310ef7 3140 }
Kujira 0:1977c2310ef7 3141
Kujira 0:1977c2310ef7 3142 *avg = ( nu - max - min ) / ( x - 2 );
Kujira 0:1977c2310ef7 3143
Kujira 0:1977c2310ef7 3144 }
Kujira 0:1977c2310ef7 3145
Kujira 0:1977c2310ef7 3146
Kujira 0:1977c2310ef7 3147 /**************************************
Kujira 0:1977c2310ef7 3148 2バイトを10進数で表示する 0~65535
Kujira 0:1977c2310ef7 3149 format *0.000
Kujira 0:1977c2310ef7 3150 mV→uAへ変換(1/1000)
Kujira 0:1977c2310ef7 3151 プリアンプ GAIN 1/5
Kujira 0:1977c2310ef7 3152 ADC_LSB:0.25mV
Kujira 0:1977c2310ef7 3153 積分時間 2s
Kujira 0:1977c2310ef7 3154 容量 20uF
Kujira 0:1977c2310ef7 3155 **************************************/
Kujira 0:1977c2310ef7 3156 void gu_putdeci(float* idata)
Kujira 0:1977c2310ef7 3157 {
Kujira 0:1977c2310ef7 3158
Kujira 0:1977c2310ef7 3159 float uA; //ver1.1.4
Kujira 0:1977c2310ef7 3160 long y; //ver1.1.4
Kujira 0:1977c2310ef7 3161 long x; //ver1.1.4
Kujira 0:1977c2310ef7 3162
Kujira 0:1977c2310ef7 3163 //千分の一、四捨五入。
Kujira 0:1977c2310ef7 3164 if ( *idata > 0 ) {
Kujira 0:1977c2310ef7 3165 uA = *idata + 0.5;
Kujira 0:1977c2310ef7 3166 } else {
Kujira 0:1977c2310ef7 3167 uA = *idata - 0.5;
Kujira 0:1977c2310ef7 3168 }
Kujira 0:1977c2310ef7 3169
Kujira 0:1977c2310ef7 3170 x = uA; //小数点以下切り捨て
Kujira 0:1977c2310ef7 3171
Kujira 0:1977c2310ef7 3172 //四捨五入 up to here
Kujira 0:1977c2310ef7 3173
Kujira 0:1977c2310ef7 3174 //プラスマイナスの表示
Kujira 0:1977c2310ef7 3175 if( x >= 0 ) {
Kujira 0:1977c2310ef7 3176 wdata[0] = 0x2B;//ascii "+"
Kujira 0:1977c2310ef7 3177 i2c.write(addr_gu, wdata, 1);
Kujira 0:1977c2310ef7 3178
Kujira 0:1977c2310ef7 3179 y = x;
Kujira 0:1977c2310ef7 3180
Kujira 0:1977c2310ef7 3181 } else {
Kujira 0:1977c2310ef7 3182 wdata[0] = 0x2D;//ascii "-"
Kujira 0:1977c2310ef7 3183 i2c.write(addr_gu, wdata, 1);
Kujira 0:1977c2310ef7 3184
Kujira 0:1977c2310ef7 3185 y = ( ~x ) + 0x01;//2の補数
Kujira 0:1977c2310ef7 3186 }
Kujira 0:1977c2310ef7 3187
Kujira 0:1977c2310ef7 3188 //y = y * 5 * 0.25;//プリアンプのGAINが1/5なのでここで5倍.ADC14bit分解能で、1bitあたり0.25mv
Kujira 0:1977c2310ef7 3189
Kujira 0:1977c2310ef7 3190 wdata[0] = (( y / 1000 ) % 10 ) + 0x30;
Kujira 0:1977c2310ef7 3191
Kujira 0:1977c2310ef7 3192 if( wdata[0] == 0x30 )//2桁目が零の場合、"0"を表示しない。
Kujira 0:1977c2310ef7 3193 wdata[0] = 0x20;
Kujira 0:1977c2310ef7 3194
Kujira 0:1977c2310ef7 3195 wdata[1] = (( y / 100 ) % 10 ) + 0x30;
Kujira 0:1977c2310ef7 3196 wdata[2] = 0x2E;//ASCII "."
Kujira 0:1977c2310ef7 3197 wdata[3] = (( y / 10 ) % 10 ) + 0x30;
Kujira 0:1977c2310ef7 3198 wdata[4] = ( y % 10 ) + 0x30;
Kujira 0:1977c2310ef7 3199
Kujira 0:1977c2310ef7 3200 i2c.write(addr_gu, wdata, 5);
Kujira 0:1977c2310ef7 3201
Kujira 0:1977c2310ef7 3202 gu_print1("uA");
Kujira 0:1977c2310ef7 3203
Kujira 0:1977c2310ef7 3204 }
Kujira 0:1977c2310ef7 3205
Kujira 0:1977c2310ef7 3206 /**************************************
Kujira 0:1977c2310ef7 3207 2バイトを10進数で表示する 0~65535
Kujira 0:1977c2310ef7 3208 format *0.000
Kujira 0:1977c2310ef7 3209 mV→uAへ変換(1/1000)
Kujira 0:1977c2310ef7 3210 プリアンプ GAIN 1/5
Kujira 0:1977c2310ef7 3211 ADC_LSB:0.25mV
Kujira 0:1977c2310ef7 3212 シャント抵抗1kΩ
Kujira 0:1977c2310ef7 3213 **************************************/
Kujira 0:1977c2310ef7 3214 void gu_putdeci_mA(float* idata)
Kujira 0:1977c2310ef7 3215 {
Kujira 0:1977c2310ef7 3216 float uA; //ver1.1.4
Kujira 0:1977c2310ef7 3217 long y; //ver1.1.4
Kujira 0:1977c2310ef7 3218 long x; //ver1.1.4
Kujira 0:1977c2310ef7 3219
Kujira 0:1977c2310ef7 3220 //千分の一、四捨五入。
Kujira 0:1977c2310ef7 3221 if ( *idata > 0 ) {
Kujira 0:1977c2310ef7 3222 uA = *idata + 0.5;
Kujira 0:1977c2310ef7 3223 } else {
Kujira 0:1977c2310ef7 3224 uA = *idata - 0.5;
Kujira 0:1977c2310ef7 3225 }
Kujira 0:1977c2310ef7 3226
Kujira 0:1977c2310ef7 3227 x = uA; //小数点以下切り捨て
Kujira 0:1977c2310ef7 3228
Kujira 0:1977c2310ef7 3229 //四捨五入 up to here
Kujira 0:1977c2310ef7 3230
Kujira 0:1977c2310ef7 3231 //プラスマイナスの表示
Kujira 0:1977c2310ef7 3232 if( x >= 0 ) {
Kujira 0:1977c2310ef7 3233 wdata[0] = 0x2B;//ascii "+"
Kujira 0:1977c2310ef7 3234 i2c.write(addr_gu, wdata, 1);
Kujira 0:1977c2310ef7 3235
Kujira 0:1977c2310ef7 3236 y = x;
Kujira 0:1977c2310ef7 3237
Kujira 0:1977c2310ef7 3238 } else {
Kujira 0:1977c2310ef7 3239 wdata[0] = 0x2D;//ascii "-"
Kujira 0:1977c2310ef7 3240 i2c.write(addr_gu, wdata, 1);
Kujira 0:1977c2310ef7 3241
Kujira 0:1977c2310ef7 3242 y = ( ~x ) + 0x01;//2の補数
Kujira 0:1977c2310ef7 3243 }
Kujira 0:1977c2310ef7 3244
Kujira 0:1977c2310ef7 3245 //y = y * 5 * 0.25;//プリアンプのGAINが1/5なのでここで5倍.ADC14bit分解能で、1bitあたり0.25mv
Kujira 0:1977c2310ef7 3246
Kujira 0:1977c2310ef7 3247 /*
Kujira 0:1977c2310ef7 3248 wdata[0] = (( *y / 100000 ) % 10 ) + 0x30;
Kujira 0:1977c2310ef7 3249
Kujira 0:1977c2310ef7 3250 if( wdata[0] == 0x30 )//3桁目が零の場合、"0"を表示しない。
Kujira 0:1977c2310ef7 3251 wdata[0] = 0x20;
Kujira 0:1977c2310ef7 3252 */
Kujira 0:1977c2310ef7 3253
Kujira 0:1977c2310ef7 3254 wdata[0] = (( y / 1000 ) % 10 ) + 0x30;
Kujira 0:1977c2310ef7 3255
Kujira 0:1977c2310ef7 3256 if( wdata[0] == 0x30 )//2桁目が零の場合、"0"を表示しない。
Kujira 0:1977c2310ef7 3257 wdata[0] = 0x20;
Kujira 0:1977c2310ef7 3258
Kujira 0:1977c2310ef7 3259 wdata[1] = (( y / 100 ) % 10 ) + 0x30;
Kujira 0:1977c2310ef7 3260 wdata[2] = 0x2E;//ASCII "."
Kujira 0:1977c2310ef7 3261 wdata[3] = (( y / 10 ) % 10 ) + 0x30;
Kujira 0:1977c2310ef7 3262 wdata[4] = ( y % 10 ) + 0x30;
Kujira 0:1977c2310ef7 3263
Kujira 0:1977c2310ef7 3264 i2c.write(addr_gu, wdata, 5);
Kujira 0:1977c2310ef7 3265
Kujira 0:1977c2310ef7 3266 gu_print1("mA");
Kujira 0:1977c2310ef7 3267
Kujira 0:1977c2310ef7 3268 }
Kujira 0:1977c2310ef7 3269
Kujira 0:1977c2310ef7 3270 /**************************************
Kujira 0:1977c2310ef7 3271 2バイトを10進数で表示する 0~65535
Kujira 0:1977c2310ef7 3272 1/1000倍 format *0.000
Kujira 0:1977c2310ef7 3273 mV→V Ω→kΩ
Kujira 0:1977c2310ef7 3274 **************************************/
Kujira 0:1977c2310ef7 3275 void gu_putdeck(short* x)
Kujira 0:1977c2310ef7 3276 {
Kujira 0:1977c2310ef7 3277
Kujira 0:1977c2310ef7 3278 short num;
Kujira 0:1977c2310ef7 3279
Kujira 0:1977c2310ef7 3280 //プラスマイナスの表示
Kujira 0:1977c2310ef7 3281 if( *x >= 0 ) {
Kujira 0:1977c2310ef7 3282 wdata[0] = 0x2B;//ascii "+"
Kujira 0:1977c2310ef7 3283 i2c.write(addr_gu, wdata, 1);
Kujira 0:1977c2310ef7 3284 num = *x;
Kujira 0:1977c2310ef7 3285
Kujira 0:1977c2310ef7 3286 } else {
Kujira 0:1977c2310ef7 3287 wdata[0] = 0x2D;//ascii "-"
Kujira 0:1977c2310ef7 3288 i2c.write(addr_gu, wdata, 1);
Kujira 0:1977c2310ef7 3289
Kujira 0:1977c2310ef7 3290 //*x = ( ~*x ) + 0x01;//2の補数
Kujira 0:1977c2310ef7 3291 num = *x * -1;
Kujira 0:1977c2310ef7 3292 }
Kujira 0:1977c2310ef7 3293
Kujira 0:1977c2310ef7 3294 wdata[0] = (( num / 10000 ) % 10 ) + 0x30;
Kujira 0:1977c2310ef7 3295
Kujira 0:1977c2310ef7 3296 if( wdata[0] == 0x30 )//2桁目が零の場合、"0"を表示しない。
Kujira 0:1977c2310ef7 3297 wdata[0] = 0x20;
Kujira 0:1977c2310ef7 3298
Kujira 0:1977c2310ef7 3299 wdata[1] = (( num / 1000 ) % 10 ) + 0x30;
Kujira 0:1977c2310ef7 3300 wdata[2] = 0x2E;//ASCII "."
Kujira 0:1977c2310ef7 3301 wdata[3] = (( num / 100 ) % 10 ) + 0x30;
Kujira 0:1977c2310ef7 3302 wdata[4] = (( num / 10 ) % 10 ) + 0x30;
Kujira 0:1977c2310ef7 3303 //wdata[5] = ( num % 10 ) + 0x30;
Kujira 0:1977c2310ef7 3304
Kujira 0:1977c2310ef7 3305 i2c.write(addr_gu, wdata, 5);
Kujira 0:1977c2310ef7 3306
Kujira 0:1977c2310ef7 3307 }
Kujira 0:1977c2310ef7 3308
Kujira 0:1977c2310ef7 3309 /********************************
Kujira 0:1977c2310ef7 3310
Kujira 0:1977c2310ef7 3311 判定 LED点灯
Kujira 0:1977c2310ef7 3312
Kujira 0:1977c2310ef7 3313 ********************************/
Kujira 0:1977c2310ef7 3314 void hantei(char noc)
Kujira 0:1977c2310ef7 3315 {
Kujira 0:1977c2310ef7 3316 int i;
Kujira 0:1977c2310ef7 3317
Kujira 0:1977c2310ef7 3318 //エラーフラグ
Kujira 0:1977c2310ef7 3319 for ( i=0; i<= 3 ; i++) {
Kujira 0:1977c2310ef7 3320 err_f[i] = 0;
Kujira 0:1977c2310ef7 3321 }
Kujira 0:1977c2310ef7 3322
Kujira 0:1977c2310ef7 3323 //ver1.2
Kujira 0:1977c2310ef7 3324 if (DEB_EN == 1) {
Kujira 0:1977c2310ef7 3325 voc[0] = 3100;//[mV]
Kujira 0:1977c2310ef7 3326 ocp[0] = -0.4*100;//[uA] 0.1uAのときocp[]の値は10
Kujira 0:1977c2310ef7 3327 iop[0] = 16.5*100;//[uA] 0.1uAのときicp[]の値は10
Kujira 0:1977c2310ef7 3328 voc[1] = 3100;//[V]
Kujira 0:1977c2310ef7 3329 ocp[1] = 0.4*100;//[uA]
Kujira 0:1977c2310ef7 3330 iop[1] = 16.5*100;//[uA]
Kujira 0:1977c2310ef7 3331 }
Kujira 0:1977c2310ef7 3332 //upto
Kujira 0:1977c2310ef7 3333
Kujira 0:1977c2310ef7 3334 for ( i = 0; i <= ( noc - 1 ); i++) {
Kujira 0:1977c2310ef7 3335
Kujira 0:1977c2310ef7 3336 /*ver1.1.3 規格設置値=0の場合は判定しない*/
Kujira 0:1977c2310ef7 3337 if( voc[i] < calinfo.low_limit_voc && calinfo.low_limit_voc != 0) {
Kujira 0:1977c2310ef7 3338 err_f[i] = 1;
Kujira 0:1977c2310ef7 3339 }
Kujira 0:1977c2310ef7 3340
Kujira 0:1977c2310ef7 3341 if( iop[i] < calinfo.low_limit_iop ) {
Kujira 0:1977c2310ef7 3342 err_f[i] = 1;
Kujira 0:1977c2310ef7 3343 }
Kujira 0:1977c2310ef7 3344
Kujira 0:1977c2310ef7 3345 if( ocp[i] > calinfo.low_limit_ocp ) {
Kujira 0:1977c2310ef7 3346 err_f[i] = 1;
Kujira 0:1977c2310ef7 3347 }
Kujira 0:1977c2310ef7 3348
Kujira 0:1977c2310ef7 3349 //ver1.2.2
Kujira 0:1977c2310ef7 3350 if( ocp[i] < calinfo.up_limit_ocp && calinfo.up_limit_ocp != 0) {
Kujira 0:1977c2310ef7 3351 err_f[i] = 1;
Kujira 0:1977c2310ef7 3352 }
Kujira 0:1977c2310ef7 3353
Kujira 0:1977c2310ef7 3354 if( R[i] < calinfo.low_limit_resistor && calinfo.low_limit_resistor != 0 ) {
Kujira 0:1977c2310ef7 3355 err_f[i] = 1;
Kujira 0:1977c2310ef7 3356 }
Kujira 0:1977c2310ef7 3357
Kujira 0:1977c2310ef7 3358 if( R[i] > calinfo.up_limit_resistor && calinfo.up_limit_resistor != 0 ) {
Kujira 0:1977c2310ef7 3359 err_f[i] = 1;
Kujira 0:1977c2310ef7 3360 }
Kujira 0:1977c2310ef7 3361
Kujira 0:1977c2310ef7 3362 if( err_f[i] == 1) {
Kujira 0:1977c2310ef7 3363 led_red[i] = 1;
Kujira 0:1977c2310ef7 3364 } else {
Kujira 0:1977c2310ef7 3365 led_green[i] = 1;
Kujira 0:1977c2310ef7 3366 }
Kujira 0:1977c2310ef7 3367
Kujira 0:1977c2310ef7 3368 if ( SEQ_EN == 1 && err_f[i] == 0 ) {
Kujira 0:1977c2310ef7 3369 seq_hantei[i] = 1;
Kujira 0:1977c2310ef7 3370 }
Kujira 0:1977c2310ef7 3371
Kujira 0:1977c2310ef7 3372 //ver1.2.3
Kujira 0:1977c2310ef7 3373 char *print_text;
Kujira 0:1977c2310ef7 3374
Kujira 0:1977c2310ef7 3375 if(DEB_EN == 1) {
Kujira 0:1977c2310ef7 3376
Kujira 0:1977c2310ef7 3377 gu_fontsize(1);
Kujira 0:1977c2310ef7 3378 gu_cursor(0,2);
Kujira 0:1977c2310ef7 3379 gu_print1(" ");
Kujira 0:1977c2310ef7 3380
Kujira 0:1977c2310ef7 3381 if(err_f[i] == 1) {
Kujira 0:1977c2310ef7 3382
Kujira 0:1977c2310ef7 3383 switch(i){
Kujira 0:1977c2310ef7 3384 case 0:
Kujira 0:1977c2310ef7 3385 print_text="FAIL DUT1";
Kujira 0:1977c2310ef7 3386 break;
Kujira 0:1977c2310ef7 3387 case 1:
Kujira 0:1977c2310ef7 3388 print_text="FAIL DUT2";
Kujira 0:1977c2310ef7 3389 break;
Kujira 0:1977c2310ef7 3390 }
Kujira 0:1977c2310ef7 3391
Kujira 0:1977c2310ef7 3392 gu_fontsize(1);
Kujira 0:1977c2310ef7 3393 gu_cursor(0,2);
Kujira 0:1977c2310ef7 3394 gu_print1(print_text);
Kujira 0:1977c2310ef7 3395 wait(1);
Kujira 0:1977c2310ef7 3396 }
Kujira 0:1977c2310ef7 3397 if(err_f[i] == 0) {
Kujira 0:1977c2310ef7 3398
Kujira 0:1977c2310ef7 3399
Kujira 0:1977c2310ef7 3400 switch(i){
Kujira 0:1977c2310ef7 3401 case 0:
Kujira 0:1977c2310ef7 3402 print_text="PASS DUT1";
Kujira 0:1977c2310ef7 3403 break;
Kujira 0:1977c2310ef7 3404 case 1:
Kujira 0:1977c2310ef7 3405 print_text="PASS DUT2";
Kujira 0:1977c2310ef7 3406 break;
Kujira 0:1977c2310ef7 3407 }
Kujira 0:1977c2310ef7 3408
Kujira 0:1977c2310ef7 3409 gu_fontsize(1);
Kujira 0:1977c2310ef7 3410 gu_cursor(0,2);
Kujira 0:1977c2310ef7 3411 gu_print1(print_text);
Kujira 0:1977c2310ef7 3412
Kujira 0:1977c2310ef7 3413 wait(1);
Kujira 0:1977c2310ef7 3414 }
Kujira 0:1977c2310ef7 3415 }
Kujira 0:1977c2310ef7 3416 //upto
Kujira 0:1977c2310ef7 3417
Kujira 0:1977c2310ef7 3418 }//for
Kujira 0:1977c2310ef7 3419
Kujira 0:1977c2310ef7 3420
Kujira 0:1977c2310ef7 3421 }
Kujira 0:1977c2310ef7 3422
Kujira 0:1977c2310ef7 3423 /*********************************
Kujira 0:1977c2310ef7 3424
Kujira 0:1977c2310ef7 3425 measure voltage
Kujira 0:1977c2310ef7 3426 測定CHを指定して、電圧値Rを返す
Kujira 0:1977c2310ef7 3427 char ch 0~3 -> 1ch ~ 4ch
Kujira 0:1977c2310ef7 3428
Kujira 0:1977c2310ef7 3429 *********************************/
Kujira 0:1977c2310ef7 3430 short meas_voltage(char ch)//ch 0~3 -> 1ch ~ 4ch
Kujira 0:1977c2310ef7 3431 {
Kujira 0:1977c2310ef7 3432 char com;
Kujira 0:1977c2310ef7 3433 short sdata;
Kujira 0:1977c2310ef7 3434
Kujira 0:1977c2310ef7 3435 switch(ch) {
Kujira 0:1977c2310ef7 3436 case 0:
Kujira 0:1977c2310ef7 3437 com = adc_config(2,0);//ch1(adc),12bit
Kujira 0:1977c2310ef7 3438 i2c.write( addr_ADC1, &com, 1);
Kujira 0:1977c2310ef7 3439 wait(0.1);
Kujira 0:1977c2310ef7 3440 sdata = read_adc(addr_ADC1);
Kujira 0:1977c2310ef7 3441 break;
Kujira 0:1977c2310ef7 3442 case 1:
Kujira 0:1977c2310ef7 3443 com = adc_config(3,0);//ch2(adc),12bit
Kujira 0:1977c2310ef7 3444 i2c.write( addr_ADC1, &com, 1);
Kujira 0:1977c2310ef7 3445 wait(0.1);
Kujira 0:1977c2310ef7 3446 sdata = read_adc(addr_ADC1);
Kujira 0:1977c2310ef7 3447 break;
Kujira 0:1977c2310ef7 3448 case 2:
Kujira 0:1977c2310ef7 3449 com = adc_config(2,0);//ch1(adc),12bit
Kujira 0:1977c2310ef7 3450 i2c.write( addr_ADC2, &com, 1);
Kujira 0:1977c2310ef7 3451 wait(0.1);
Kujira 0:1977c2310ef7 3452 sdata = read_adc(addr_ADC2);
Kujira 0:1977c2310ef7 3453 break;
Kujira 0:1977c2310ef7 3454 case 3:
Kujira 0:1977c2310ef7 3455 com = adc_config(3,0);//ch2(adc),12bit
Kujira 0:1977c2310ef7 3456 i2c.write( addr_ADC2, &com, 1);
Kujira 0:1977c2310ef7 3457 wait(0.1);
Kujira 0:1977c2310ef7 3458 sdata = read_adc(addr_ADC2);
Kujira 0:1977c2310ef7 3459 break;
Kujira 0:1977c2310ef7 3460 }// end switch
Kujira 0:1977c2310ef7 3461
Kujira 0:1977c2310ef7 3462 //プリアンプ倍率を代入して、電圧値を算出する(単位はmV)
Kujira 0:1977c2310ef7 3463
Kujira 0:1977c2310ef7 3464
Kujira 0:1977c2310ef7 3465 sdata = sdata * 5;//プリアンプ倍率
Kujira 0:1977c2310ef7 3466
Kujira 0:1977c2310ef7 3467 return ( sdata );
Kujira 0:1977c2310ef7 3468 }
Kujira 0:1977c2310ef7 3469
Kujira 0:1977c2310ef7 3470
Kujira 0:1977c2310ef7 3471 /*********************************
Kujira 0:1977c2310ef7 3472
Kujira 0:1977c2310ef7 3473 measure resistor
Kujira 0:1977c2310ef7 3474 測定CHを指定して、抵抗測定値Rを返す
Kujira 0:1977c2310ef7 3475 char ch 0~3 -> 1ch ~ 4ch
Kujira 0:1977c2310ef7 3476
Kujira 0:1977c2310ef7 3477 *********************************/
Kujira 0:1977c2310ef7 3478 short meas_resistor(char ch)//ch 0~3 -> 1ch ~ 4ch
Kujira 0:1977c2310ef7 3479 {
Kujira 0:1977c2310ef7 3480 char com;
Kujira 0:1977c2310ef7 3481 short sdata;
Kujira 0:1977c2310ef7 3482
Kujira 0:1977c2310ef7 3483 switch(ch) {
Kujira 0:1977c2310ef7 3484 case 0:
Kujira 0:1977c2310ef7 3485 //ver1.2.0
Kujira 0:1977c2310ef7 3486 if (RL_EN == 1) {
Kujira 0:1977c2310ef7 3487 io[6] = 1; //外付けリレーON
Kujira 0:1977c2310ef7 3488 wait(TIME_RELAY_ON);
Kujira 0:1977c2310ef7 3489 }
Kujira 0:1977c2310ef7 3490 //up to here
Kujira 0:1977c2310ef7 3491
Kujira 0:1977c2310ef7 3492 com = adc_config(0,0);//ch1(adc),12bit
Kujira 0:1977c2310ef7 3493 i2c.write( addr_ADC1, &com, 1);
Kujira 0:1977c2310ef7 3494 wait(0.1);
Kujira 0:1977c2310ef7 3495 sdata = read_adc(addr_ADC1);
Kujira 0:1977c2310ef7 3496 //ver1.2.0
Kujira 0:1977c2310ef7 3497 if (RL_EN == 1) {
Kujira 0:1977c2310ef7 3498 io[6] = 0 ;
Kujira 0:1977c2310ef7 3499 }
Kujira 0:1977c2310ef7 3500
Kujira 0:1977c2310ef7 3501 break;
Kujira 0:1977c2310ef7 3502
Kujira 0:1977c2310ef7 3503 case 1:
Kujira 0:1977c2310ef7 3504 //ver1.2.0
Kujira 0:1977c2310ef7 3505 if (RL_EN == 1) {
Kujira 0:1977c2310ef7 3506 io[7] = 1; //外付けリレーON
Kujira 0:1977c2310ef7 3507 wait(TIME_RELAY_ON);
Kujira 0:1977c2310ef7 3508 }
Kujira 0:1977c2310ef7 3509 //up to here
Kujira 0:1977c2310ef7 3510
Kujira 0:1977c2310ef7 3511 com = adc_config(1,0);//ch2(adc),12bit
Kujira 0:1977c2310ef7 3512 i2c.write( addr_ADC1, &com, 1);
Kujira 0:1977c2310ef7 3513 wait(0.1);
Kujira 0:1977c2310ef7 3514 sdata = read_adc(addr_ADC1);
Kujira 0:1977c2310ef7 3515 //ver1.2.0
Kujira 0:1977c2310ef7 3516 if (RL_EN == 1) {
Kujira 0:1977c2310ef7 3517 io[7] = 0;
Kujira 0:1977c2310ef7 3518 }
Kujira 0:1977c2310ef7 3519
Kujira 0:1977c2310ef7 3520 break;
Kujira 0:1977c2310ef7 3521
Kujira 0:1977c2310ef7 3522 case 2:
Kujira 0:1977c2310ef7 3523 com = adc_config(0,0);//ch1(adc),12bit
Kujira 0:1977c2310ef7 3524 i2c.write( addr_ADC2, &com, 1);
Kujira 0:1977c2310ef7 3525 wait(0.1);
Kujira 0:1977c2310ef7 3526 sdata = read_adc(addr_ADC2);
Kujira 0:1977c2310ef7 3527 break;
Kujira 0:1977c2310ef7 3528 case 3:
Kujira 0:1977c2310ef7 3529 com = adc_config(1,0);//ch2(adc),12bit
Kujira 0:1977c2310ef7 3530 i2c.write( addr_ADC2, &com, 1);
Kujira 0:1977c2310ef7 3531 wait(0.1);
Kujira 0:1977c2310ef7 3532 sdata = read_adc(addr_ADC2);
Kujira 0:1977c2310ef7 3533 break;
Kujira 0:1977c2310ef7 3534 }// end switch
Kujira 0:1977c2310ef7 3535
Kujira 0:1977c2310ef7 3536 //検出用抵抗値を代入して、測定抵抗値を算出する(単位はmV,Ω)
Kujira 0:1977c2310ef7 3537 if ( sdata < res_vref ) {
Kujira 0:1977c2310ef7 3538 sdata =( rsense * sdata ) / ( res_vref - sdata);
Kujira 0:1977c2310ef7 3539 } else {
Kujira 0:1977c2310ef7 3540 sdata = res_vref;//overload
Kujira 0:1977c2310ef7 3541 }
Kujira 0:1977c2310ef7 3542
Kujira 0:1977c2310ef7 3543
Kujira 0:1977c2310ef7 3544 return ( sdata );
Kujira 0:1977c2310ef7 3545 }
Kujira 0:1977c2310ef7 3546
Kujira 0:1977c2310ef7 3547
Kujira 0:1977c2310ef7 3548 /*********************************
Kujira 0:1977c2310ef7 3549
Kujira 0:1977c2310ef7 3550 display resistor
Kujira 0:1977c2310ef7 3551 測定抵抗値を表示する
Kujira 0:1977c2310ef7 3552
Kujira 0:1977c2310ef7 3553 *********************************/
Kujira 0:1977c2310ef7 3554 void display_resistor(short sdata)//測定値を表示する。
Kujira 0:1977c2310ef7 3555 {
Kujira 0:1977c2310ef7 3556 if ( sdata < res_vref && sdata >= 0 ) {
Kujira 0:1977c2310ef7 3557 gu_putdec(&sdata);
Kujira 0:1977c2310ef7 3558 } else {
Kujira 0:1977c2310ef7 3559 gu_print1(" OL ");//overload
Kujira 0:1977c2310ef7 3560 }
Kujira 0:1977c2310ef7 3561 gu_onebyte(0xEA);//ohm
Kujira 0:1977c2310ef7 3562 }
Kujira 0:1977c2310ef7 3563
Kujira 0:1977c2310ef7 3564 /**************************************
Kujira 0:1977c2310ef7 3565 4バイトを10進数で表示する 0~9999
Kujira 0:1977c2310ef7 3566 **************************************/
Kujira 0:1977c2310ef7 3567 void gu_putdec(short* x)
Kujira 0:1977c2310ef7 3568 {
Kujira 0:1977c2310ef7 3569
Kujira 0:1977c2310ef7 3570 char cmd[4];
Kujira 0:1977c2310ef7 3571
Kujira 0:1977c2310ef7 3572 //cmd[0] = (( *x / 100000 ) % 10 ) + 0x30;
Kujira 0:1977c2310ef7 3573 cmd[0] = (( *x / 1000 ) % 10 ) + 0x30;
Kujira 0:1977c2310ef7 3574 cmd[1] = (( *x / 100 ) % 10 ) + 0x30;
Kujira 0:1977c2310ef7 3575 cmd[2] = (( *x / 10 ) % 10 ) + 0x30;
Kujira 0:1977c2310ef7 3576 cmd[3] = ( *x % 10 ) + 0x30;
Kujira 0:1977c2310ef7 3577
Kujira 0:1977c2310ef7 3578 i2c.write(addr_gu, cmd, 4);
Kujira 0:1977c2310ef7 3579
Kujira 0:1977c2310ef7 3580 }
Kujira 0:1977c2310ef7 3581 /*********************************
Kujira 0:1977c2310ef7 3582
Kujira 0:1977c2310ef7 3583 LED 照度
Kujira 0:1977c2310ef7 3584 設定読込~反映
Kujira 0:1977c2310ef7 3585 //メモリから設定値を読み出して、LEDのPWMのDutyを設定する
Kujira 0:1977c2310ef7 3586 //LED1設定値&LED2設定値の計2Byte読込
Kujira 0:1977c2310ef7 3587
Kujira 0:1977c2310ef7 3588 *********************************/
Kujira 0:1977c2310ef7 3589 void read_syoudo(char* c)
Kujira 0:1977c2310ef7 3590 {
Kujira 0:1977c2310ef7 3591 char cmd; //gu-DへのI2Cコマンド用配列 1byte0
Kujira 0:1977c2310ef7 3592 //char csyoudo[4];//led出力用pwm duty 設定比1バイト255段階
Kujira 0:1977c2310ef7 3593 float duty_pwm; //pwm パーセンテージ
Kujira 0:1977c2310ef7 3594 int i;
Kujira 0:1977c2310ef7 3595
Kujira 0:1977c2310ef7 3596 //
Kujira 0:1977c2310ef7 3597 //メモリ10h番地(照度設定データ)読み出し
Kujira 0:1977c2310ef7 3598 cmd = 0x10;
Kujira 0:1977c2310ef7 3599 i2c.write (fixed_adrs, &cmd, 1,true); //読込先頭アドレス指定 ReStart
Kujira 0:1977c2310ef7 3600 i2c.read ((fixed_adrs + 0x01), rdata, 4);//read 1byte
Kujira 0:1977c2310ef7 3601
Kujira 0:1977c2310ef7 3602 for ( i = 0; i <=3; i++) {
Kujira 0:1977c2310ef7 3603 c[i] = rdata[i];
Kujira 0:1977c2310ef7 3604 }
Kujira 0:1977c2310ef7 3605
Kujira 0:1977c2310ef7 3606 //set pwm duty
Kujira 0:1977c2310ef7 3607 for ( i = 0; i <= ( number_of_channels - 1 ); i++) {
Kujira 0:1977c2310ef7 3608
Kujira 0:1977c2310ef7 3609 if(c[i] == 0x00) {
Kujira 0:1977c2310ef7 3610 c[i] = 0x32;
Kujira 0:1977c2310ef7 3611 }
Kujira 0:1977c2310ef7 3612
Kujira 0:1977c2310ef7 3613 duty_pwm = COP * c[i];
Kujira 0:1977c2310ef7 3614
Kujira 0:1977c2310ef7 3615 leds[i].write (duty_pwm);//Set Duty
Kujira 0:1977c2310ef7 3616 }
Kujira 0:1977c2310ef7 3617 }
Kujira 0:1977c2310ef7 3618 /*********************************
Kujira 0:1977c2310ef7 3619
Kujira 0:1977c2310ef7 3620 LED 照度調整 (Main)
Kujira 0:1977c2310ef7 3621
Kujira 0:1977c2310ef7 3622 *********************************/
Kujira 0:1977c2310ef7 3623 void adjust_illumination()
Kujira 0:1977c2310ef7 3624 {
Kujira 0:1977c2310ef7 3625 char cmd_gu[32] ; //gu-DへのI2Cコマンド用配列 1byte0
Kujira 0:1977c2310ef7 3626 //char *pcmd = cmd_gu;
Kujira 0:1977c2310ef7 3627 //char msg;
Kujira 0:1977c2310ef7 3628 //char *pmsg = &msg;
Kujira 0:1977c2310ef7 3629 char crdata[3];
Kujira 0:1977c2310ef7 3630 char cswnum; //SW_No. sw1->0x00 ~~ sw32->0x1F gu-D スイッチNo.
Kujira 0:1977c2310ef7 3631 char cswdata; // 0x00 or 0x01 ONかOFFか
Kujira 0:1977c2310ef7 3632 char *pcswnum = &cswnum;
Kujira 0:1977c2310ef7 3633 char *pcswdata = &cswdata;
Kujira 0:1977c2310ef7 3634 char csyoudo[4];//led出力用pwm duty 設定比1バイト255段階
Kujira 0:1977c2310ef7 3635 char ch;
Kujira 0:1977c2310ef7 3636 float duty_pwm;//pwm パーセンテージ
Kujira 0:1977c2310ef7 3637 int i;
Kujira 0:1977c2310ef7 3638 int x[4] = {64,64,192,192}; //レベル値の表示位置 x座標
Kujira 0:1977c2310ef7 3639 int y[4] = {2,4,2,4}; //レベル値の表示位置 y座標
Kujira 0:1977c2310ef7 3640 //
Kujira 0:1977c2310ef7 3641 //EEPROMから照度データ読込とPWMDUTYセット
Kujira 0:1977c2310ef7 3642 read_syoudo( csyoudo );
Kujira 0:1977c2310ef7 3643 //
Kujira 0:1977c2310ef7 3644 //画面表示
Kujira 0:1977c2310ef7 3645 gu_cls();//画面のクリア
Kujira 0:1977c2310ef7 3646 gu_fontsize(2);
Kujira 0:1977c2310ef7 3647 gu_print1("Adjust illumination ");
Kujira 0:1977c2310ef7 3648 //照度レベルを256段階で表示
Kujira 0:1977c2310ef7 3649 //LED1
Kujira 0:1977c2310ef7 3650 gu_cursor(0,16/8);
Kujira 0:1977c2310ef7 3651 gu_print1("LED1 Lv ");
Kujira 0:1977c2310ef7 3652 //LED2
Kujira 0:1977c2310ef7 3653 gu_cursor(0,32/8);
Kujira 0:1977c2310ef7 3654 gu_print1("LED2 Lv ");
Kujira 0:1977c2310ef7 3655 //LED3
Kujira 0:1977c2310ef7 3656 if( number_of_channels >= 3 ) {
Kujira 0:1977c2310ef7 3657 gu_cursor(128,2);
Kujira 0:1977c2310ef7 3658 gu_print1("LED3 Lv ");
Kujira 0:1977c2310ef7 3659 }
Kujira 0:1977c2310ef7 3660 //LED4
Kujira 0:1977c2310ef7 3661 if( number_of_channels >= 4 ) {
Kujira 0:1977c2310ef7 3662 gu_cursor(128,4);
Kujira 0:1977c2310ef7 3663 gu_print1("LED4 Lv ");
Kujira 0:1977c2310ef7 3664 }
Kujira 0:1977c2310ef7 3665 //
Kujira 0:1977c2310ef7 3666 for ( i = 0; i <= ( number_of_channels - 1 ); i++) {
Kujira 0:1977c2310ef7 3667
Kujira 0:1977c2310ef7 3668 gu_cursor(x[i],y[i]);
Kujira 0:1977c2310ef7 3669
Kujira 0:1977c2310ef7 3670 cmd_gu[0] = ((csyoudo[i] / 100) & 0xFF) + 0x30;
Kujira 0:1977c2310ef7 3671 cmd_gu[1] = (csyoudo[i] - (csyoudo[i] / 100) * 100) / 10 + 0x30;
Kujira 0:1977c2310ef7 3672 cmd_gu[2] = ((csyoudo[i] % 10) & 0xFF) + 0x30;
Kujira 0:1977c2310ef7 3673 i2c.write(addr_gu, cmd_gu, 3);
Kujira 0:1977c2310ef7 3674 }
Kujira 0:1977c2310ef7 3675
Kujira 0:1977c2310ef7 3676 //
Kujira 0:1977c2310ef7 3677 gu_fontsize(1);
Kujira 0:1977c2310ef7 3678 gu_cursor(0,56/8);
Kujira 0:1977c2310ef7 3679 gu_print1("LED1");
Kujira 0:1977c2310ef7 3680 gu_cursor(32,56/8);
Kujira 0:1977c2310ef7 3681 gu_print1("fine");
Kujira 0:1977c2310ef7 3682 gu_cursor(64,56/8);
Kujira 0:1977c2310ef7 3683 gu_print1("LED2");
Kujira 0:1977c2310ef7 3684 gu_cursor(96,56/8);
Kujira 0:1977c2310ef7 3685 gu_print1("fine");
Kujira 0:1977c2310ef7 3686
Kujira 0:1977c2310ef7 3687 if( number_of_channels >= 3) {
Kujira 0:1977c2310ef7 3688 gu_cursor(128,56/8);
Kujira 0:1977c2310ef7 3689 gu_print1("LED3");
Kujira 0:1977c2310ef7 3690 gu_cursor(160,56/8);
Kujira 0:1977c2310ef7 3691 gu_print1("fine");
Kujira 0:1977c2310ef7 3692 }
Kujira 0:1977c2310ef7 3693 if( number_of_channels >= 4) {
Kujira 0:1977c2310ef7 3694 gu_cursor(192,56/8);
Kujira 0:1977c2310ef7 3695 gu_print1("LED4");
Kujira 0:1977c2310ef7 3696 gu_cursor(224,56/8);
Kujira 0:1977c2310ef7 3697 gu_print1("fine");
Kujira 0:1977c2310ef7 3698 }
Kujira 0:1977c2310ef7 3699 //
Kujira 0:1977c2310ef7 3700 //gu-D タッチスイッチ読み出し動作設定 p49
Kujira 0:1977c2310ef7 3701 cmd_gu[0]= 0x1F;
Kujira 0:1977c2310ef7 3702 cmd_gu[1]= 0x4B;
Kujira 0:1977c2310ef7 3703 cmd_gu[2]= 0x18;
Kujira 0:1977c2310ef7 3704 cmd_gu[3]= 0x02;//SW状態変化時自動送信モード2
Kujira 0:1977c2310ef7 3705 i2c.write(addr_gu, cmd_gu, 4); //gu-D タッチスイッチ読み出し動作設定 p49
Kujira 0:1977c2310ef7 3706 //
Kujira 0:1977c2310ef7 3707 //ボタンイメージの表示
Kujira 0:1977c2310ef7 3708 for ( i = 17; i < 17 + ( number_of_channels * 2 ); i++) {
Kujira 0:1977c2310ef7 3709 gu_button_up(i);
Kujira 0:1977c2310ef7 3710 }
Kujira 0:1977c2310ef7 3711 for ( i = 25; i < 25 + ( number_of_channels * 2 ); i++) {
Kujira 0:1977c2310ef7 3712 gu_button_down(i);
Kujira 0:1977c2310ef7 3713 }
Kujira 0:1977c2310ef7 3714 gu_Button_power_on();//show button
Kujira 0:1977c2310ef7 3715 wait(0.2);
Kujira 0:1977c2310ef7 3716
Kujira 0:1977c2310ef7 3717 while(1) {
Kujira 0:1977c2310ef7 3718
Kujira 0:1977c2310ef7 3719 i2c.read ((addr_gu + 0x01), crdata, 3);
Kujira 0:1977c2310ef7 3720
Kujira 0:1977c2310ef7 3721 if (crdata[0] == 0x11 ) { //個別タッチスイッチ状態読み出しフォーマット。識別子11h。
Kujira 0:1977c2310ef7 3722 *pcswnum = crdata[1]; //スイッチ番号
Kujira 0:1977c2310ef7 3723 *pcswdata = crdata[2];//ON/OFF情報
Kujira 0:1977c2310ef7 3724
Kujira 0:1977c2310ef7 3725 if (cswdata == 0x01) { //タッチしたならば
Kujira 0:1977c2310ef7 3726
Kujira 0:1977c2310ef7 3727 switch ( number_of_channels ) { //ver1.1.0
Kujira 0:1977c2310ef7 3728
Kujira 0:1977c2310ef7 3729 case 1:
Kujira 0:1977c2310ef7 3730 case 2:
Kujira 0:1977c2310ef7 3731 if ( cswnum >= 20 && cswnum <= 23 )
Kujira 0:1977c2310ef7 3732 cswnum = 0;
Kujira 0:1977c2310ef7 3733
Kujira 0:1977c2310ef7 3734 if ( cswnum >= 28 && cswnum <= 31 )
Kujira 0:1977c2310ef7 3735 cswnum = 0;
Kujira 0:1977c2310ef7 3736
Kujira 0:1977c2310ef7 3737 break;
Kujira 0:1977c2310ef7 3738
Kujira 0:1977c2310ef7 3739 case 3:
Kujira 0:1977c2310ef7 3740 if ( cswnum >= 22 && cswnum <= 23 )
Kujira 0:1977c2310ef7 3741 cswnum = 0;
Kujira 0:1977c2310ef7 3742
Kujira 0:1977c2310ef7 3743 if ( cswnum >= 30 && cswnum <= 31 )
Kujira 0:1977c2310ef7 3744 cswnum = 0;
Kujira 0:1977c2310ef7 3745
Kujira 0:1977c2310ef7 3746 break;
Kujira 0:1977c2310ef7 3747
Kujira 0:1977c2310ef7 3748 } //switch
Kujira 0:1977c2310ef7 3749
Kujira 0:1977c2310ef7 3750 switch( cswnum ) { //SWの番号(位置)
Kujira 0:1977c2310ef7 3751
Kujira 0:1977c2310ef7 3752 case 22:
Kujira 0:1977c2310ef7 3753 case 20:
Kujira 0:1977c2310ef7 3754 case 16:
Kujira 0:1977c2310ef7 3755 case 18:
Kujira 0:1977c2310ef7 3756
Kujira 0:1977c2310ef7 3757 ch = ( cswnum - 16 ) / 2; //SWnoから選択したLEDNoの算出
Kujira 0:1977c2310ef7 3758
Kujira 0:1977c2310ef7 3759 gu_button_up_on( cswnum + 1 );
Kujira 0:1977c2310ef7 3760 wait(0.2);
Kujira 0:1977c2310ef7 3761 gu_button_up( cswnum + 1 );
Kujira 0:1977c2310ef7 3762 wait(0.1);
Kujira 0:1977c2310ef7 3763
Kujira 0:1977c2310ef7 3764 if(csyoudo[ch] <= 0xEF ) {
Kujira 0:1977c2310ef7 3765 csyoudo[ch] = csyoudo[ch] + 0x0A;
Kujira 0:1977c2310ef7 3766 }
Kujira 0:1977c2310ef7 3767
Kujira 0:1977c2310ef7 3768 break;
Kujira 0:1977c2310ef7 3769
Kujira 0:1977c2310ef7 3770 case 23:
Kujira 0:1977c2310ef7 3771 case 21:
Kujira 0:1977c2310ef7 3772 case 17:
Kujira 0:1977c2310ef7 3773 case 19:
Kujira 0:1977c2310ef7 3774
Kujira 0:1977c2310ef7 3775 ch = ( cswnum - 17 ) / 2; //SWnoから選択したLEDNoの算出
Kujira 0:1977c2310ef7 3776
Kujira 0:1977c2310ef7 3777 gu_button_up_on( cswnum + 1 );
Kujira 0:1977c2310ef7 3778 wait(0.2);
Kujira 0:1977c2310ef7 3779 gu_button_up( cswnum + 1 );
Kujira 0:1977c2310ef7 3780 wait(0.1);
Kujira 0:1977c2310ef7 3781
Kujira 0:1977c2310ef7 3782 if(csyoudo[ch] <= 0xFF ) {
Kujira 0:1977c2310ef7 3783 csyoudo[ch] = csyoudo[ch] + 0x01;
Kujira 0:1977c2310ef7 3784 }
Kujira 0:1977c2310ef7 3785
Kujira 0:1977c2310ef7 3786 break;
Kujira 0:1977c2310ef7 3787
Kujira 0:1977c2310ef7 3788 case 24:
Kujira 0:1977c2310ef7 3789 case 26:
Kujira 0:1977c2310ef7 3790 case 28:
Kujira 0:1977c2310ef7 3791 case 30:
Kujira 0:1977c2310ef7 3792
Kujira 0:1977c2310ef7 3793 ch = ( cswnum - 24 ) / 2; //SWnoから選択したLEDNoの算出
Kujira 0:1977c2310ef7 3794
Kujira 0:1977c2310ef7 3795 gu_button_down_on( cswnum + 1 );
Kujira 0:1977c2310ef7 3796 wait(0.2);
Kujira 0:1977c2310ef7 3797 gu_button_down( cswnum + 1 );
Kujira 0:1977c2310ef7 3798 wait(0.1);
Kujira 0:1977c2310ef7 3799
Kujira 0:1977c2310ef7 3800 if(csyoudo[ch] >= 0x0A ) {
Kujira 0:1977c2310ef7 3801 csyoudo[ch] = csyoudo[ch] - 0x0A;
Kujira 0:1977c2310ef7 3802 }
Kujira 0:1977c2310ef7 3803
Kujira 0:1977c2310ef7 3804 break;
Kujira 0:1977c2310ef7 3805
Kujira 0:1977c2310ef7 3806 case 25:
Kujira 0:1977c2310ef7 3807 case 27:
Kujira 0:1977c2310ef7 3808 case 29:
Kujira 0:1977c2310ef7 3809 case 31:
Kujira 0:1977c2310ef7 3810
Kujira 0:1977c2310ef7 3811 ch = ( cswnum - 24 ) / 2; //SWnoから選択したLEDNoの算出
Kujira 0:1977c2310ef7 3812
Kujira 0:1977c2310ef7 3813 gu_button_down_on( cswnum + 1 );
Kujira 0:1977c2310ef7 3814 wait(0.2);
Kujira 0:1977c2310ef7 3815 gu_button_down( cswnum + 1 );
Kujira 0:1977c2310ef7 3816 wait(0.1);
Kujira 0:1977c2310ef7 3817
Kujira 0:1977c2310ef7 3818 if(csyoudo[ch] >= 0x01 ) {
Kujira 0:1977c2310ef7 3819 csyoudo[ch] = csyoudo[ch] - 0x01;
Kujira 0:1977c2310ef7 3820 }
Kujira 0:1977c2310ef7 3821
Kujira 0:1977c2310ef7 3822 break;
Kujira 0:1977c2310ef7 3823
Kujira 0:1977c2310ef7 3824 case 7 ://SW.8 保存ボタンを押すと現在の輝度をEEPROMへ保存する
Kujira 0:1977c2310ef7 3825
Kujira 0:1977c2310ef7 3826 wdata[0] = 0x10 ; //word address 書込み先頭アドレス指定
Kujira 0:1977c2310ef7 3827
Kujira 0:1977c2310ef7 3828 for ( i = 0; i <= ( number_of_channels - 1 ); i++) {
Kujira 0:1977c2310ef7 3829 wdata[ i + 1 ] = csyoudo[i]; //DATA_LED i
Kujira 0:1977c2310ef7 3830 }
Kujira 0:1977c2310ef7 3831
Kujira 0:1977c2310ef7 3832 Soushin = i2c.write (fixed_adrs, wdata,( number_of_channels + 1 ));
Kujira 0:1977c2310ef7 3833
Kujira 0:1977c2310ef7 3834 if(Soushin == 0) {
Kujira 0:1977c2310ef7 3835 gu_Button_power_off();//電源ボタンイメージ反転表示
Kujira 0:1977c2310ef7 3836 wait(0.3);
Kujira 0:1977c2310ef7 3837
Kujira 0:1977c2310ef7 3838 return;//照度調整ルーチンを抜ける
Kujira 0:1977c2310ef7 3839 }
Kujira 0:1977c2310ef7 3840 } //switch
Kujira 0:1977c2310ef7 3841
Kujira 0:1977c2310ef7 3842
Kujira 0:1977c2310ef7 3843
Kujira 0:1977c2310ef7 3844 //PWMのDUTY設定
Kujira 0:1977c2310ef7 3845
Kujira 0:1977c2310ef7 3846 for( i = 0; i <= ( number_of_channels - 1 ); i++) {
Kujira 0:1977c2310ef7 3847 duty_pwm = COP * csyoudo[i];
Kujira 0:1977c2310ef7 3848 leds[i].write (duty_pwm);//Set Duty
Kujira 0:1977c2310ef7 3849 }
Kujira 0:1977c2310ef7 3850
Kujira 0:1977c2310ef7 3851
Kujira 0:1977c2310ef7 3852 //照度レベルを256段階で表示
Kujira 0:1977c2310ef7 3853 //LED1
Kujira 0:1977c2310ef7 3854 gu_fontsize(2);
Kujira 0:1977c2310ef7 3855
Kujira 0:1977c2310ef7 3856 for ( i = 0; i <= ( number_of_channels - 1 ); i++) {
Kujira 0:1977c2310ef7 3857
Kujira 0:1977c2310ef7 3858 gu_cursor(x[i],y[i]);
Kujira 0:1977c2310ef7 3859
Kujira 0:1977c2310ef7 3860 cmd_gu[0] = ((csyoudo[i] / 100) & 0xFF) + 0x30;
Kujira 0:1977c2310ef7 3861 cmd_gu[1] = (csyoudo[i] - (csyoudo[i] / 100) * 100) / 10 + 0x30;
Kujira 0:1977c2310ef7 3862 cmd_gu[2] = ((csyoudo[i] % 10) & 0xFF) + 0x30;
Kujira 0:1977c2310ef7 3863 i2c.write(addr_gu, cmd_gu, 3);
Kujira 0:1977c2310ef7 3864 }
Kujira 0:1977c2310ef7 3865 }
Kujira 0:1977c2310ef7 3866 } //if
Kujira 0:1977c2310ef7 3867
Kujira 0:1977c2310ef7 3868 wait(0.1);//gu-D 読込間隔の設定
Kujira 0:1977c2310ef7 3869
Kujira 0:1977c2310ef7 3870 }
Kujira 0:1977c2310ef7 3871 }
Kujira 0:1977c2310ef7 3872
Kujira 0:1977c2310ef7 3873 /*********************************
Kujira 0:1977c2310ef7 3874
Kujira 0:1977c2310ef7 3875 サブ基板LED(判定用)全消灯
Kujira 0:1977c2310ef7 3876
Kujira 0:1977c2310ef7 3877 *********************************/
Kujira 0:1977c2310ef7 3878 void led_off()
Kujira 0:1977c2310ef7 3879 {
Kujira 0:1977c2310ef7 3880 int i;
Kujira 0:1977c2310ef7 3881
Kujira 0:1977c2310ef7 3882 for( i = 0; i <= ( number_of_channels - 1 ); i++) {
Kujira 0:1977c2310ef7 3883 led_green[ i ] = 0;
Kujira 0:1977c2310ef7 3884 led_red[ i ] = 0;
Kujira 0:1977c2310ef7 3885 }
Kujira 0:1977c2310ef7 3886
Kujira 0:1977c2310ef7 3887 }
Kujira 0:1977c2310ef7 3888 /*********************************
Kujira 0:1977c2310ef7 3889
Kujira 0:1977c2310ef7 3890 Utility Main
Kujira 0:1977c2310ef7 3891 gu_D 輝度調整 タッチ感度調整
Kujira 0:1977c2310ef7 3892
Kujira 0:1977c2310ef7 3893 *********************************/
Kujira 0:1977c2310ef7 3894 void utility() //輝度調整サブルーチン
Kujira 0:1977c2310ef7 3895 {
Kujira 0:1977c2310ef7 3896
Kujira 0:1977c2310ef7 3897 char cmd_gu[32] ; //gu-DへのI2Cコマンド用配列 1byte0
Kujira 0:1977c2310ef7 3898 //char *pcmd = cmd_gu;
Kujira 0:1977c2310ef7 3899 char clumi; //輝度設定用変数 01h<=n<=08h
Kujira 0:1977c2310ef7 3900 char* pclumi = &clumi; //ポインタの定義
Kujira 0:1977c2310ef7 3901 char msg;
Kujira 0:1977c2310ef7 3902 char *pmsg = &msg;
Kujira 0:1977c2310ef7 3903 char crdata[3];
Kujira 0:1977c2310ef7 3904 char cswnum; //SW_No. sw1->0x00 ~~ sw32->0x1F
Kujira 0:1977c2310ef7 3905 char cswdata; // 0x00 or 0x01
Kujira 0:1977c2310ef7 3906 char *pcswnum = &cswnum;
Kujira 0:1977c2310ef7 3907 char *pcswdata = &cswdata;
Kujira 0:1977c2310ef7 3908 //
Kujira 0:1977c2310ef7 3909 //メモリ00h番地(輝度設定データ)読み出し
Kujira 0:1977c2310ef7 3910 wdata[0] = 0x00;
Kujira 0:1977c2310ef7 3911 Soushin = i2c.write (fixed_adrs, wdata, 1,true); //読込先頭アドレス指定 ReStart
Kujira 0:1977c2310ef7 3912 Jyushin = i2c.read ((fixed_adrs + 0x01), rdata, 1);//read 1byte
Kujira 0:1977c2310ef7 3913 *pclumi = rdata[0];
Kujira 0:1977c2310ef7 3914
Kujira 0:1977c2310ef7 3915 //輝度設定更新
Kujira 0:1977c2310ef7 3916 if(*pclumi==0x00 || *pclumi > 0x08) *pclumi=0x05;
Kujira 0:1977c2310ef7 3917 gu_luminance(pclumi);
Kujira 0:1977c2310ef7 3918
Kujira 0:1977c2310ef7 3919 //画面表示
Kujira 0:1977c2310ef7 3920 gu_cls();//画面のクリア
Kujira 0:1977c2310ef7 3921 gu_print1("Set Display Brightness");
Kujira 0:1977c2310ef7 3922 gu_cursor(0,16/8);
Kujira 0:1977c2310ef7 3923 gu_print1("LEVEL ");
Kujira 0:1977c2310ef7 3924 *pmsg = *pclumi + 0x30;
Kujira 0:1977c2310ef7 3925 gu_print1(pmsg);
Kujira 0:1977c2310ef7 3926
Kujira 0:1977c2310ef7 3927 gu_cursor(0,96/8); //ver1.1.0
Kujira 0:1977c2310ef7 3928 gu_print1("DELETE EEPROM_DATA");
Kujira 0:1977c2310ef7 3929 gu_set_button_font1(30,"del");
Kujira 0:1977c2310ef7 3930
Kujira 0:1977c2310ef7 3931 //SW状態変化時自動送信モード2
Kujira 0:1977c2310ef7 3932 cmd_gu[0]= 0x1F;
Kujira 0:1977c2310ef7 3933 cmd_gu[1]= 0x4B;
Kujira 0:1977c2310ef7 3934 cmd_gu[2]= 0x18;
Kujira 0:1977c2310ef7 3935 cmd_gu[3]= 0x02;
Kujira 0:1977c2310ef7 3936 i2c.write(addr_gu, cmd_gu, 4); //gu-D タッチスイッチ読み出し動作設定 p49
Kujira 0:1977c2310ef7 3937
Kujira 0:1977c2310ef7 3938 //ボタンイメージの表示
Kujira 0:1977c2310ef7 3939 gu_button_up(6);//show button
Kujira 0:1977c2310ef7 3940 gu_button_down(14);//show button
Kujira 0:1977c2310ef7 3941 gu_Button_power_on();//show button
Kujira 0:1977c2310ef7 3942
Kujira 0:1977c2310ef7 3943 while(1) {
Kujira 0:1977c2310ef7 3944
Kujira 0:1977c2310ef7 3945 i2c.read ((addr_gu + 0x01), crdata, 3, true);
Kujira 0:1977c2310ef7 3946
Kujira 0:1977c2310ef7 3947 if (crdata[0] == 0x11 ) { //個別タッチスイッチ状態読み出しフォーマット。識別子11h。
Kujira 0:1977c2310ef7 3948 *pcswnum = crdata[1]; //スイッチ番号
Kujira 0:1977c2310ef7 3949 *pcswdata = crdata[2];//ON/OFF情報
Kujira 0:1977c2310ef7 3950
Kujira 0:1977c2310ef7 3951 if (cswdata == 0x01) { //タッチしたならば
Kujira 0:1977c2310ef7 3952 switch( cswnum ) { //SWの番号(位置)
Kujira 0:1977c2310ef7 3953 case 5 ://SW6
Kujira 0:1977c2310ef7 3954 gu_button_up_on( 6 );
Kujira 0:1977c2310ef7 3955 wait(0.2);
Kujira 0:1977c2310ef7 3956 gu_button_up( 6 );
Kujira 0:1977c2310ef7 3957 wait(0.1);
Kujira 0:1977c2310ef7 3958
Kujira 0:1977c2310ef7 3959 if(clumi < 8 ) *pclumi = *pclumi + 1;
Kujira 0:1977c2310ef7 3960
Kujira 0:1977c2310ef7 3961 break;
Kujira 0:1977c2310ef7 3962
Kujira 0:1977c2310ef7 3963 case 13 ://SW14
Kujira 0:1977c2310ef7 3964 gu_button_down_on( 14 );
Kujira 0:1977c2310ef7 3965 wait(0.2);
Kujira 0:1977c2310ef7 3966 gu_button_down( 14 );
Kujira 0:1977c2310ef7 3967 wait(0.1);
Kujira 0:1977c2310ef7 3968
Kujira 0:1977c2310ef7 3969 if(clumi >= 1 ) *pclumi = *pclumi - 1;
Kujira 0:1977c2310ef7 3970
Kujira 0:1977c2310ef7 3971 break;
Kujira 0:1977c2310ef7 3972
Kujira 0:1977c2310ef7 3973 case 29: //SW30
Kujira 0:1977c2310ef7 3974
Kujira 0:1977c2310ef7 3975 gu_reverse(0x01); //gu_リバース指定
Kujira 0:1977c2310ef7 3976 gu_set_button_font1(30,"del");
Kujira 0:1977c2310ef7 3977 gu_reverse(0x00); //gu_リバース解除
Kujira 0:1977c2310ef7 3978
Kujira 0:1977c2310ef7 3979 erace_calinfo();
Kujira 0:1977c2310ef7 3980
Kujira 0:1977c2310ef7 3981 gu_set_button_font1(30,"del");
Kujira 0:1977c2310ef7 3982
Kujira 0:1977c2310ef7 3983 break;
Kujira 0:1977c2310ef7 3984
Kujira 0:1977c2310ef7 3985 case 0x07 ://保存ボタンを押すと現在の輝度をEEPROMへ保存する
Kujira 0:1977c2310ef7 3986
Kujira 0:1977c2310ef7 3987 wdata[0] = 0x00 ; //word address 書込み先頭アドレス指定
Kujira 0:1977c2310ef7 3988 wdata[1] = *pclumi ; //DATA
Kujira 0:1977c2310ef7 3989 Soushin = i2c.write (fixed_adrs, wdata, 2);
Kujira 0:1977c2310ef7 3990
Kujira 0:1977c2310ef7 3991 if(Soushin == 0) {
Kujira 0:1977c2310ef7 3992 gu_Button_power_off();//電源ボタンイメージ反転表示
Kujira 0:1977c2310ef7 3993 wait(0.5);
Kujira 0:1977c2310ef7 3994 return;//輝度調整ルーチンを抜ける
Kujira 0:1977c2310ef7 3995 }
Kujira 0:1977c2310ef7 3996
Kujira 0:1977c2310ef7 3997 } //switch
Kujira 0:1977c2310ef7 3998
Kujira 0:1977c2310ef7 3999 gu_luminance(pclumi);//輝度変更
Kujira 0:1977c2310ef7 4000 gu_cursor(0,16/8);
Kujira 0:1977c2310ef7 4001 gu_print1("LEVEL ");
Kujira 0:1977c2310ef7 4002 *pmsg = *pclumi + 0x30;
Kujira 0:1977c2310ef7 4003 gu_print1(pmsg);
Kujira 0:1977c2310ef7 4004
Kujira 0:1977c2310ef7 4005 }
Kujira 0:1977c2310ef7 4006 } //if
Kujira 0:1977c2310ef7 4007
Kujira 0:1977c2310ef7 4008 wait(0.1);//gu-D 読込間隔の設定
Kujira 0:1977c2310ef7 4009
Kujira 0:1977c2310ef7 4010 }
Kujira 0:1977c2310ef7 4011 }
Kujira 0:1977c2310ef7 4012
Kujira 0:1977c2310ef7 4013 /*********************************
Kujira 0:1977c2310ef7 4014 gu_D グラフィックデータ
Kujira 0:1977c2310ef7 4015 *********************************/
Kujira 0:1977c2310ef7 4016 char gu_Button_MODE_data[] = {
Kujira 0:1977c2310ef7 4017 0x7F,0xF0,0x80,0x08,0x80,0x0C,0x80,0x0A,0x80,0x0A,0x80,0x0A,0x80,0x0A,0x80,0x0A,
Kujira 0:1977c2310ef7 4018 0x80,0x0A,0x80,0x0A,0x80,0x0A,0x80,0x0A,0x7F,0xF2,0x20,0x02,0x1F,0xFC,0x00,0x00,
Kujira 0:1977c2310ef7 4019 };
Kujira 0:1977c2310ef7 4020
Kujira 0:1977c2310ef7 4021 void gu_set_button(char sw_num,char* text)
Kujira 0:1977c2310ef7 4022 {
Kujira 0:1977c2310ef7 4023 char x;
Kujira 0:1977c2310ef7 4024 char y;
Kujira 0:1977c2310ef7 4025
Kujira 0:1977c2310ef7 4026 //SW_NoからSWの座標を求める
Kujira 0:1977c2310ef7 4027 x = ((sw_num - 1) % 8 ) * 32;
Kujira 0:1977c2310ef7 4028 y = ((sw_num - 1) / 8 ) * 32;
Kujira 0:1977c2310ef7 4029
Kujira 0:1977c2310ef7 4030 gu_drawButton(x,y,32,32, gu_Button_MODE_data );
Kujira 0:1977c2310ef7 4031
Kujira 0:1977c2310ef7 4032 // Change Font Size
Kujira 0:1977c2310ef7 4033 gu_fontsize(2);
Kujira 0:1977c2310ef7 4034 // set font width
Kujira 0:1977c2310ef7 4035 gu_fontWidth(Proportional1);
Kujira 0:1977c2310ef7 4036 gu_print_dot( x + 8,y + 8,text);
Kujira 0:1977c2310ef7 4037 // Change Font Size
Kujira 0:1977c2310ef7 4038 gu_fontsize(1);
Kujira 0:1977c2310ef7 4039 // set font width
Kujira 0:1977c2310ef7 4040 gu_fontWidth(1);
Kujira 0:1977c2310ef7 4041 }
Kujira 0:1977c2310ef7 4042
Kujira 0:1977c2310ef7 4043 void gu_set_button_font1(char sw_num,char* text)
Kujira 0:1977c2310ef7 4044 {
Kujira 0:1977c2310ef7 4045 char x;
Kujira 0:1977c2310ef7 4046 char y;
Kujira 0:1977c2310ef7 4047
Kujira 0:1977c2310ef7 4048 //SW_NoからSWの座標を求める
Kujira 0:1977c2310ef7 4049 x = ((sw_num - 1) % 8 ) * 32;
Kujira 0:1977c2310ef7 4050 y = ((sw_num - 1) / 8 ) * 32;
Kujira 0:1977c2310ef7 4051
Kujira 0:1977c2310ef7 4052 gu_drawButton(x,y,32,32, gu_Button_MODE_data );
Kujira 0:1977c2310ef7 4053
Kujira 0:1977c2310ef7 4054 // Change Font Size
Kujira 0:1977c2310ef7 4055 gu_fontsize(1);
Kujira 0:1977c2310ef7 4056 // set font width
Kujira 0:1977c2310ef7 4057 gu_fontWidth(1);
Kujira 0:1977c2310ef7 4058 gu_print_dot( x + 2,y + 10,text);
Kujira 0:1977c2310ef7 4059
Kujira 0:1977c2310ef7 4060 }
Kujira 0:1977c2310ef7 4061
Kujira 0:1977c2310ef7 4062 char gu_Button_up_data[] = {
Kujira 0:1977c2310ef7 4063 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x0F,0xFF,0xFF,0xF0,0x10,0x00,0x00,0x08,
Kujira 0:1977c2310ef7 4064 0x20,0x00,0x00,0x04,0x20,0x00,0x00,0x04,0x20,0x00,0x00,0x04,0x20,0x00,0x18,0x04,
Kujira 0:1977c2310ef7 4065 0x20,0x00,0x38,0x04,0x20,0x00,0x78,0x04,0x20,0x00,0xF8,0x04,0x20,0x01,0xF8,0x04,
Kujira 0:1977c2310ef7 4066 0x20,0x03,0xF8,0x04,0x20,0x07,0xF8,0x04,0x20,0x0F,0xF8,0x04,0x20,0x1F,0xF8,0x04,
Kujira 0:1977c2310ef7 4067 0x20,0x1F,0xF8,0x04,0x20,0x0F,0xF8,0x04,0x20,0x07,0xF8,0x04,0x20,0x03,0xF8,0x04,
Kujira 0:1977c2310ef7 4068 0x20,0x01,0xF8,0x04,0x20,0x00,0xF8,0x04,0x20,0x00,0x78,0x04,0x20,0x00,0x38,0x04,
Kujira 0:1977c2310ef7 4069 0x20,0x00,0x18,0x04,0x20,0x00,0x00,0x04,0x20,0x00,0x00,0x04,0x20,0x00,0x00,0x04,
Kujira 0:1977c2310ef7 4070 0x10,0x00,0x00,0x08,0x0F,0xFF,0xFF,0xF0,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
Kujira 0:1977c2310ef7 4071 };
Kujira 0:1977c2310ef7 4072
Kujira 0:1977c2310ef7 4073 void gu_button_up(char sw_num)
Kujira 0:1977c2310ef7 4074 {
Kujira 0:1977c2310ef7 4075 char x;
Kujira 0:1977c2310ef7 4076 char y;
Kujira 0:1977c2310ef7 4077
Kujira 0:1977c2310ef7 4078 //SW_NoからSWの座標を求める
Kujira 0:1977c2310ef7 4079 x = ((sw_num - 1) % 8 ) * 32;
Kujira 0:1977c2310ef7 4080 y = ((sw_num - 1) / 8 ) * 32;
Kujira 0:1977c2310ef7 4081
Kujira 0:1977c2310ef7 4082 gu_cursor( x, y/8 );
Kujira 0:1977c2310ef7 4083 gu_RealTimeImage(32, 32, gu_Button_up_data);
Kujira 0:1977c2310ef7 4084 }
Kujira 0:1977c2310ef7 4085
Kujira 0:1977c2310ef7 4086 void gu_Button_up1()
Kujira 0:1977c2310ef7 4087 {
Kujira 0:1977c2310ef7 4088 gu_cursor(224,8);
Kujira 0:1977c2310ef7 4089 gu_RealTimeImage(32, 32, gu_Button_up_data);
Kujira 0:1977c2310ef7 4090 }
Kujira 0:1977c2310ef7 4091
Kujira 0:1977c2310ef7 4092 void gu_Button_up2()
Kujira 0:1977c2310ef7 4093 {
Kujira 0:1977c2310ef7 4094 gu_cursor(192,8);
Kujira 0:1977c2310ef7 4095 gu_RealTimeImage(32, 32, gu_Button_up_data);
Kujira 0:1977c2310ef7 4096 }
Kujira 0:1977c2310ef7 4097
Kujira 0:1977c2310ef7 4098 void gu_Button_up3()
Kujira 0:1977c2310ef7 4099 {
Kujira 0:1977c2310ef7 4100 gu_cursor(160,8);
Kujira 0:1977c2310ef7 4101 gu_RealTimeImage(32, 32, gu_Button_up_data);
Kujira 0:1977c2310ef7 4102 }
Kujira 0:1977c2310ef7 4103
Kujira 0:1977c2310ef7 4104 void gu_Button_up4()
Kujira 0:1977c2310ef7 4105 {
Kujira 0:1977c2310ef7 4106 gu_cursor(128,8);
Kujira 0:1977c2310ef7 4107 gu_RealTimeImage(32, 32, gu_Button_up_data);
Kujira 0:1977c2310ef7 4108 }
Kujira 0:1977c2310ef7 4109
Kujira 0:1977c2310ef7 4110 char gu_Button_down_data[] = {
Kujira 0:1977c2310ef7 4111 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x0F,0xFF,0xFF,0xF0,0x10,0x00,0x00,0x08,
Kujira 0:1977c2310ef7 4112 0x20,0x00,0x00,0x04,0x20,0x00,0x00,0x04,0x20,0x00,0x00,0x04,0x20,0x18,0x00,0x04,
Kujira 0:1977c2310ef7 4113 0x20,0x1C,0x00,0x04,0x20,0x1E,0x00,0x04,0x20,0x1F,0x00,0x04,0x20,0x1F,0x80,0x04,
Kujira 0:1977c2310ef7 4114 0x20,0x1F,0xC0,0x04,0x20,0x1F,0xE0,0x04,0x20,0x1F,0xF0,0x04,0x20,0x1F,0xF8,0x04,
Kujira 0:1977c2310ef7 4115 0x20,0x1F,0xF8,0x04,0x20,0x1F,0xF0,0x04,0x20,0x1F,0xE0,0x04,0x20,0x1F,0xC0,0x04,
Kujira 0:1977c2310ef7 4116 0x20,0x1F,0x80,0x04,0x20,0x1F,0x00,0x04,0x20,0x1E,0x00,0x04,0x20,0x1C,0x00,0x04,
Kujira 0:1977c2310ef7 4117 0x20,0x18,0x00,0x04,0x20,0x00,0x00,0x04,0x20,0x00,0x00,0x04,0x20,0x00,0x00,0x04,
Kujira 0:1977c2310ef7 4118 0x10,0x00,0x00,0x08,0x0F,0xFF,0xFF,0xF0,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
Kujira 0:1977c2310ef7 4119 };
Kujira 0:1977c2310ef7 4120
Kujira 0:1977c2310ef7 4121 void gu_button_down(char sw_num)
Kujira 0:1977c2310ef7 4122 {
Kujira 0:1977c2310ef7 4123 char x;
Kujira 0:1977c2310ef7 4124 char y;
Kujira 0:1977c2310ef7 4125
Kujira 0:1977c2310ef7 4126 //SW_NoからSWの座標を求める
Kujira 0:1977c2310ef7 4127 x = ((sw_num - 1) % 8 ) * 32;
Kujira 0:1977c2310ef7 4128 y = ((sw_num - 1) / 8 ) * 32;
Kujira 0:1977c2310ef7 4129
Kujira 0:1977c2310ef7 4130 gu_cursor( x, y/8 );
Kujira 0:1977c2310ef7 4131 gu_RealTimeImage(32, 32, gu_Button_down_data);
Kujira 0:1977c2310ef7 4132 }
Kujira 0:1977c2310ef7 4133
Kujira 0:1977c2310ef7 4134 void gu_Button_down1()
Kujira 0:1977c2310ef7 4135 {
Kujira 0:1977c2310ef7 4136 gu_cursor(224,12);
Kujira 0:1977c2310ef7 4137 gu_RealTimeImage(32, 32, gu_Button_down_data);
Kujira 0:1977c2310ef7 4138 }
Kujira 0:1977c2310ef7 4139
Kujira 0:1977c2310ef7 4140 void gu_Button_down2()
Kujira 0:1977c2310ef7 4141 {
Kujira 0:1977c2310ef7 4142 gu_cursor(192,12);
Kujira 0:1977c2310ef7 4143 gu_RealTimeImage(32, 32, gu_Button_down_data);
Kujira 0:1977c2310ef7 4144 }
Kujira 0:1977c2310ef7 4145
Kujira 0:1977c2310ef7 4146 void gu_Button_down3()
Kujira 0:1977c2310ef7 4147 {
Kujira 0:1977c2310ef7 4148 gu_cursor(160,12);
Kujira 0:1977c2310ef7 4149 gu_RealTimeImage(32, 32, gu_Button_down_data);
Kujira 0:1977c2310ef7 4150 }
Kujira 0:1977c2310ef7 4151
Kujira 0:1977c2310ef7 4152 void gu_Button_down4()
Kujira 0:1977c2310ef7 4153 {
Kujira 0:1977c2310ef7 4154 gu_cursor(128,12);
Kujira 0:1977c2310ef7 4155 gu_RealTimeImage(32, 32, gu_Button_down_data);
Kujira 0:1977c2310ef7 4156 }
Kujira 0:1977c2310ef7 4157
Kujira 0:1977c2310ef7 4158 char gu_Button_up_on_data[] = {
Kujira 0:1977c2310ef7 4159 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x0F,0xFF,0xFF,0xF0,0x1F,0xFF,0xFF,0xF8,
Kujira 0:1977c2310ef7 4160 0x3F,0xFF,0xFF,0xFC,0x3F,0xFF,0xFF,0xFC,0x3F,0xFF,0xFF,0xFC,0x3F,0xFF,0xE7,0xFC,
Kujira 0:1977c2310ef7 4161 0x3F,0xFF,0xC7,0xFC,0x3F,0xFF,0x87,0xFC,0x3F,0xFF,0x07,0xFC,0x3F,0xFE,0x07,0xFC,
Kujira 0:1977c2310ef7 4162 0x3F,0xFC,0x07,0xFC,0x3F,0xF8,0x07,0xFC,0x3F,0xF0,0x07,0xFC,0x3F,0xE0,0x07,0xFC,
Kujira 0:1977c2310ef7 4163 0x3F,0xE0,0x07,0xFC,0x3F,0xF0,0x07,0xFC,0x3F,0xF8,0x07,0xFC,0x3F,0xFC,0x07,0xFC,
Kujira 0:1977c2310ef7 4164 0x3F,0xFE,0x07,0xFC,0x3F,0xFF,0x07,0xFC,0x3F,0xFF,0x87,0xFC,0x3F,0xFF,0xC7,0xFC,
Kujira 0:1977c2310ef7 4165 0x3F,0xFF,0xE7,0xFC,0x3F,0xFF,0xFF,0xFC,0x3F,0xFF,0xFF,0xFC,0x3F,0xFF,0xFF,0xFC,
Kujira 0:1977c2310ef7 4166 0x1F,0xFF,0xFF,0xF8,0x0F,0xFF,0xFF,0xF0,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
Kujira 0:1977c2310ef7 4167 };
Kujira 0:1977c2310ef7 4168
Kujira 0:1977c2310ef7 4169 void gu_button_up_on( char sw_num )
Kujira 0:1977c2310ef7 4170 {
Kujira 0:1977c2310ef7 4171 char x;
Kujira 0:1977c2310ef7 4172 char y;
Kujira 0:1977c2310ef7 4173
Kujira 0:1977c2310ef7 4174 //SW_NoからSWの座標を求める
Kujira 0:1977c2310ef7 4175 x = ((sw_num - 1) % 8 ) * 32;
Kujira 0:1977c2310ef7 4176 y = ((sw_num - 1) / 8 ) * 32;
Kujira 0:1977c2310ef7 4177
Kujira 0:1977c2310ef7 4178 gu_cursor( x, y/8 );
Kujira 0:1977c2310ef7 4179
Kujira 0:1977c2310ef7 4180 gu_RealTimeImage(32, 32, gu_Button_up_on_data);
Kujira 0:1977c2310ef7 4181 }
Kujira 0:1977c2310ef7 4182
Kujira 0:1977c2310ef7 4183 void gu_Button_up_on2()
Kujira 0:1977c2310ef7 4184 {
Kujira 0:1977c2310ef7 4185 gu_cursor(192,8);
Kujira 0:1977c2310ef7 4186 gu_RealTimeImage(32, 32, gu_Button_up_on_data);
Kujira 0:1977c2310ef7 4187 }
Kujira 0:1977c2310ef7 4188
Kujira 0:1977c2310ef7 4189 char gu_Button_down_on_data[] = {
Kujira 0:1977c2310ef7 4190 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x0F,0xFF,0xFF,0xF0,0x1F,0xFF,0xFF,0xF8,
Kujira 0:1977c2310ef7 4191 0x3F,0xFF,0xFF,0xFC,0x3F,0xFF,0xFF,0xFC,0x3F,0xFF,0xFF,0xFC,0x3F,0xE7,0xFF,0xFC,
Kujira 0:1977c2310ef7 4192 0x3F,0xE3,0xFF,0xFC,0x3F,0xE1,0xFF,0xFC,0x3F,0xE0,0xFF,0xFC,0x3F,0xE0,0x7F,0xFC,
Kujira 0:1977c2310ef7 4193 0x3F,0xE0,0x3F,0xFC,0x3F,0xE0,0x1F,0xFC,0x3F,0xE0,0x0F,0xFC,0x3F,0xE0,0x07,0xFC,
Kujira 0:1977c2310ef7 4194 0x3F,0xE0,0x07,0xFC,0x3F,0xE0,0x0F,0xFC,0x3F,0xE0,0x1F,0xFC,0x3F,0xE0,0x3F,0xFC,
Kujira 0:1977c2310ef7 4195 0x3F,0xE0,0x7F,0xFC,0x3F,0xE0,0xFF,0xFC,0x3F,0xE1,0xFF,0xFC,0x3F,0xE3,0xFF,0xFC,
Kujira 0:1977c2310ef7 4196 0x3F,0xE7,0xFF,0xFC,0x3F,0xFF,0xFF,0xFC,0x3F,0xFF,0xFF,0xFC,0x3F,0xFF,0xFF,0xFC,
Kujira 0:1977c2310ef7 4197 0x1F,0xFF,0xFF,0xF8,0x0F,0xFF,0xFF,0xF0,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
Kujira 0:1977c2310ef7 4198 };
Kujira 0:1977c2310ef7 4199
Kujira 0:1977c2310ef7 4200 void gu_button_down_on(char sw_num)
Kujira 0:1977c2310ef7 4201 {
Kujira 0:1977c2310ef7 4202 char x;
Kujira 0:1977c2310ef7 4203 char y;
Kujira 0:1977c2310ef7 4204
Kujira 0:1977c2310ef7 4205 //SW_NoからSWの座標を求める
Kujira 0:1977c2310ef7 4206 x = ((sw_num - 1) % 8 ) * 32;
Kujira 0:1977c2310ef7 4207 y = ((sw_num - 1) / 8 ) * 32;
Kujira 0:1977c2310ef7 4208
Kujira 0:1977c2310ef7 4209 gu_cursor( x, y/8 );
Kujira 0:1977c2310ef7 4210
Kujira 0:1977c2310ef7 4211 gu_RealTimeImage(32, 32, gu_Button_down_on_data);
Kujira 0:1977c2310ef7 4212 }
Kujira 0:1977c2310ef7 4213
Kujira 0:1977c2310ef7 4214 void gu_Button_down_on2()
Kujira 0:1977c2310ef7 4215 {
Kujira 0:1977c2310ef7 4216 gu_cursor(192,12);
Kujira 0:1977c2310ef7 4217 gu_RealTimeImage(32, 32, gu_Button_down_on_data);
Kujira 0:1977c2310ef7 4218 }
Kujira 0:1977c2310ef7 4219
Kujira 0:1977c2310ef7 4220 char gu_Button_power_on_data[] = {
Kujira 0:1977c2310ef7 4221 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x0F,0xFF,0xFF,0xF0,0x10,0x00,0x00,0x08,
Kujira 0:1977c2310ef7 4222 0x20,0x00,0x00,0x04,0x20,0x00,0x00,0x04,0x20,0x00,0x00,0x04,0x20,0x03,0xF0,0x04,
Kujira 0:1977c2310ef7 4223 0x20,0x0F,0xFC,0x04,0x20,0x1F,0xFE,0x04,0x20,0x3C,0x0F,0x04,0x20,0x38,0x07,0x84,
Kujira 0:1977c2310ef7 4224 0x20,0x00,0x03,0x84,0x20,0x00,0x03,0xC4,0x20,0x00,0x01,0xC4,0x21,0xFF,0x01,0xC4,
Kujira 0:1977c2310ef7 4225 0x21,0xFF,0x01,0xC4,0x20,0x00,0x01,0xC4,0x20,0x00,0x03,0xC4,0x20,0x00,0x03,0x84,
Kujira 0:1977c2310ef7 4226 0x20,0x38,0x07,0x84,0x20,0x3C,0x0F,0x04,0x20,0x1F,0xFE,0x04,0x20,0x0F,0xFC,0x04,
Kujira 0:1977c2310ef7 4227 0x20,0x03,0xF0,0x04,0x20,0x00,0x00,0x04,0x20,0x00,0x00,0x04,0x20,0x00,0x00,0x04,
Kujira 0:1977c2310ef7 4228 0x10,0x00,0x00,0x08,0x0F,0xFF,0xFF,0xF0,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
Kujira 0:1977c2310ef7 4229 };
Kujira 0:1977c2310ef7 4230
Kujira 0:1977c2310ef7 4231 void gu_Button_power_on()
Kujira 0:1977c2310ef7 4232 {
Kujira 0:1977c2310ef7 4233 gu_cursor(224,0);
Kujira 0:1977c2310ef7 4234 gu_RealTimeImage(32, 32, gu_Button_power_on_data);
Kujira 0:1977c2310ef7 4235 }
Kujira 0:1977c2310ef7 4236
Kujira 0:1977c2310ef7 4237
Kujira 0:1977c2310ef7 4238 char gu_Button_power_off_data[] = {
Kujira 0:1977c2310ef7 4239 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x0F,0xFF,0xFF,0xF0,0x1F,0xFF,0xFF,0xF8,
Kujira 0:1977c2310ef7 4240 0x3F,0xFF,0xFF,0xFC,0x3F,0xFF,0xFF,0xFC,0x3F,0xFF,0xFF,0xFC,0x3F,0xFC,0x0F,0xFC,
Kujira 0:1977c2310ef7 4241 0x3F,0xF0,0x03,0xFC,0x3F,0xE0,0x01,0xFC,0x3F,0xC3,0xF0,0xFC,0x3F,0xC7,0xF8,0x7C,
Kujira 0:1977c2310ef7 4242 0x3F,0xFF,0xFC,0x7C,0x3F,0xFF,0xFC,0x3C,0x3F,0xFF,0xFE,0x3C,0x3C,0x00,0x7E,0x3C,
Kujira 0:1977c2310ef7 4243 0x3C,0x00,0x7E,0x3C,0x3F,0xFF,0xFE,0x3C,0x3F,0xFF,0xFC,0x3C,0x3F,0xFF,0xFC,0x7C,
Kujira 0:1977c2310ef7 4244 0x3F,0xC7,0xF8,0x7C,0x3F,0xC1,0xE0,0xFC,0x3F,0xE0,0x01,0xFC,0x3F,0xF0,0x03,0xFC,
Kujira 0:1977c2310ef7 4245 0x3F,0xFC,0x0F,0xFC,0x3F,0xFF,0xFF,0xFC,0x3F,0xFF,0xFF,0xFC,0x3F,0xFF,0xFF,0xFC,
Kujira 0:1977c2310ef7 4246 0x1F,0xFF,0xFF,0xF8,0x0F,0xFF,0xFF,0xF0,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
Kujira 0:1977c2310ef7 4247 };
Kujira 0:1977c2310ef7 4248
Kujira 0:1977c2310ef7 4249 void gu_Button_power_off()
Kujira 0:1977c2310ef7 4250 {
Kujira 0:1977c2310ef7 4251 gu_cursor(224,0);
Kujira 0:1977c2310ef7 4252 gu_RealTimeImage(32, 32, gu_Button_power_off_data);
Kujira 0:1977c2310ef7 4253 }
Kujira 0:1977c2310ef7 4254
Kujira 0:1977c2310ef7 4255 /*********************************
Kujira 0:1977c2310ef7 4256 ノリタケ関数
Kujira 0:1977c2310ef7 4257 ここから
Kujira 0:1977c2310ef7 4258 **********************************/
Kujira 0:1977c2310ef7 4259 //
Kujira 0:1977c2310ef7 4260 // Clear screen//
Kujira 0:1977c2310ef7 4261 void gu_cls()
Kujira 0:1977c2310ef7 4262 {
Kujira 0:1977c2310ef7 4263
Kujira 0:1977c2310ef7 4264 i2c.start();
Kujira 0:1977c2310ef7 4265 i2c.write(addr_gu);
Kujira 0:1977c2310ef7 4266 i2c.write(0x0c);
Kujira 0:1977c2310ef7 4267 i2c.stop();
Kujira 0:1977c2310ef7 4268
Kujira 0:1977c2310ef7 4269 }
Kujira 0:1977c2310ef7 4270
Kujira 0:1977c2310ef7 4271 void gu_drawButton(int x, int y, int w, int h, const char data[])
Kujira 0:1977c2310ef7 4272 {
Kujira 0:1977c2310ef7 4273 h = h >> 3; // get height in byte
Kujira 0:1977c2310ef7 4274 y = y >> 3; // get Y location in byte
Kujira 0:1977c2310ef7 4275
Kujira 0:1977c2310ef7 4276 gu_cursor(x,y);
Kujira 0:1977c2310ef7 4277 // Realtime Image draw header
Kujira 0:1977c2310ef7 4278
Kujira 0:1977c2310ef7 4279 i2c.start();
Kujira 0:1977c2310ef7 4280 i2c.write(addr_gu);
Kujira 0:1977c2310ef7 4281 gu_sendOneByte(0x1f);
Kujira 0:1977c2310ef7 4282 gu_sendOneByte(0x28);
Kujira 0:1977c2310ef7 4283 gu_sendOneByte(0x66);
Kujira 0:1977c2310ef7 4284 gu_sendOneByte(0x11);
Kujira 0:1977c2310ef7 4285 gu_sendOneByte( w & 0xff);
Kujira 0:1977c2310ef7 4286 gu_sendOneByte( w >> 8);
Kujira 0:1977c2310ef7 4287 gu_sendOneByte( h & 0xff);
Kujira 0:1977c2310ef7 4288 gu_sendOneByte( h >> 8);
Kujira 0:1977c2310ef7 4289 gu_sendOneByte(0x01);
Kujira 0:1977c2310ef7 4290
Kujira 0:1977c2310ef7 4291 for(int i = 0; i<w; i++) {
Kujira 0:1977c2310ef7 4292 if(i<8) { // 8 dots from left
Kujira 0:1977c2310ef7 4293 gu_sendOneByte(data[i*2]);
Kujira 0:1977c2310ef7 4294 if(h>2) {
Kujira 0:1977c2310ef7 4295 for(int j=0; j<(h-2); j++) {
Kujira 0:1977c2310ef7 4296 if((data[i*2]&0x01)==0) {
Kujira 0:1977c2310ef7 4297 gu_sendOneByte(0x00);
Kujira 0:1977c2310ef7 4298 } else {
Kujira 0:1977c2310ef7 4299 gu_sendOneByte(0xff);
Kujira 0:1977c2310ef7 4300 }
Kujira 0:1977c2310ef7 4301 }
Kujira 0:1977c2310ef7 4302 }
Kujira 0:1977c2310ef7 4303 gu_sendOneByte(data[i*2+1]);
Kujira 0:1977c2310ef7 4304 } else if (i > (w-8)) { // 8 dots from right
Kujira 0:1977c2310ef7 4305
Kujira 0:1977c2310ef7 4306 gu_sendOneByte(data[(16+i-w)*2]);
Kujira 0:1977c2310ef7 4307 if(h>2) for(int j=0; j<(h-2); j++) {
Kujira 0:1977c2310ef7 4308 if((data[(16+i-w)*2]&0x01)==0) {
Kujira 0:1977c2310ef7 4309 gu_sendOneByte(0x00);
Kujira 0:1977c2310ef7 4310 } else {
Kujira 0:1977c2310ef7 4311 gu_sendOneByte(0xff);
Kujira 0:1977c2310ef7 4312 }
Kujira 0:1977c2310ef7 4313 }
Kujira 0:1977c2310ef7 4314 gu_sendOneByte(data[(16+i-w)*2+1]);
Kujira 0:1977c2310ef7 4315
Kujira 0:1977c2310ef7 4316 } else { // in the middle
Kujira 0:1977c2310ef7 4317 gu_sendOneByte(data[14]);
Kujira 0:1977c2310ef7 4318 if(h>2) {
Kujira 0:1977c2310ef7 4319 for(int j=0; j<(h-2); j++) {
Kujira 0:1977c2310ef7 4320 if((data[14]&0x01)==0) {
Kujira 0:1977c2310ef7 4321 gu_sendOneByte(0x00);
Kujira 0:1977c2310ef7 4322 } else {
Kujira 0:1977c2310ef7 4323 gu_sendOneByte(0xff);
Kujira 0:1977c2310ef7 4324 }
Kujira 0:1977c2310ef7 4325 }
Kujira 0:1977c2310ef7 4326 }
Kujira 0:1977c2310ef7 4327 gu_sendOneByte(data[15]);
Kujira 0:1977c2310ef7 4328 }
Kujira 0:1977c2310ef7 4329 }
Kujira 0:1977c2310ef7 4330
Kujira 0:1977c2310ef7 4331 i2c.stop();
Kujira 0:1977c2310ef7 4332
Kujira 0:1977c2310ef7 4333 }
Kujira 0:1977c2310ef7 4334
Kujira 0:1977c2310ef7 4335
Kujira 0:1977c2310ef7 4336 // ドット単位キャラクタ表示 p37
Kujira 0:1977c2310ef7 4337 void gu_print_dot(int x, int y, const char* ptext)
Kujira 0:1977c2310ef7 4338 {
Kujira 0:1977c2310ef7 4339
Kujira 0:1977c2310ef7 4340 i2c.start();
Kujira 0:1977c2310ef7 4341 i2c.write(addr_gu);
Kujira 0:1977c2310ef7 4342 gu_sendOneByte(0x1f);
Kujira 0:1977c2310ef7 4343 gu_sendOneByte(0x28);
Kujira 0:1977c2310ef7 4344 gu_sendOneByte(0x64);
Kujira 0:1977c2310ef7 4345 gu_sendOneByte(0x30);
Kujira 0:1977c2310ef7 4346 gu_sendOneByte(x & 0xff);
Kujira 0:1977c2310ef7 4347 gu_sendOneByte(x >> 8);
Kujira 0:1977c2310ef7 4348 gu_sendOneByte(y & 0xff);
Kujira 0:1977c2310ef7 4349 gu_sendOneByte(y >> 8);
Kujira 0:1977c2310ef7 4350 gu_sendOneByte(0x00);
Kujira 0:1977c2310ef7 4351
Kujira 0:1977c2310ef7 4352 int i=0;
Kujira 0:1977c2310ef7 4353 int j=0;
Kujira 0:1977c2310ef7 4354 while(*(ptext+i)) {
Kujira 0:1977c2310ef7 4355 if (*(ptext + i++) =='%') {
Kujira 0:1977c2310ef7 4356 j+=2; //文字列終端”0%"までインクリメント
Kujira 0:1977c2310ef7 4357 }
Kujira 0:1977c2310ef7 4358 }
Kujira 0:1977c2310ef7 4359
Kujira 0:1977c2310ef7 4360 gu_sendOneByte(i-j); //キャラクタデータ長
Kujira 0:1977c2310ef7 4361 gu_print(ptext); //キャラクタデータ
Kujira 0:1977c2310ef7 4362
Kujira 0:1977c2310ef7 4363 i2c.stop();
Kujira 0:1977c2310ef7 4364
Kujira 0:1977c2310ef7 4365 }
Kujira 0:1977c2310ef7 4366
Kujira 0:1977c2310ef7 4367 //
Kujira 0:1977c2310ef7 4368 // Print test//
Kujira 0:1977c2310ef7 4369 void gu_print(const char t[] )
Kujira 0:1977c2310ef7 4370 {
Kujira 0:1977c2310ef7 4371 i2c.start();
Kujira 0:1977c2310ef7 4372 i2c.write(addr_gu);
Kujira 0:1977c2310ef7 4373
Kujira 0:1977c2310ef7 4374 int i=0;
Kujira 0:1977c2310ef7 4375 int j=0;
Kujira 0:1977c2310ef7 4376 int k=0;
Kujira 0:1977c2310ef7 4377 while(t[i]) {
Kujira 0:1977c2310ef7 4378 if(t[i] != 37) {
Kujira 0:1977c2310ef7 4379 gu_sendOneByte(t[i++]);
Kujira 0:1977c2310ef7 4380 } else {
Kujira 0:1977c2310ef7 4381 i++;
Kujira 0:1977c2310ef7 4382 j=t[i++]-0x30;
Kujira 0:1977c2310ef7 4383 if(j>9) {
Kujira 0:1977c2310ef7 4384 j -= 7;
Kujira 0:1977c2310ef7 4385 }
Kujira 0:1977c2310ef7 4386 if(j>0x10) {
Kujira 0:1977c2310ef7 4387 j -= 0x20;
Kujira 0:1977c2310ef7 4388 }
Kujira 0:1977c2310ef7 4389 k=t[i++]-0x30;
Kujira 0:1977c2310ef7 4390 if(k>9) {
Kujira 0:1977c2310ef7 4391 k -= 7;
Kujira 0:1977c2310ef7 4392 }
Kujira 0:1977c2310ef7 4393 if(k>0x10) {
Kujira 0:1977c2310ef7 4394 k -= 0x20;
Kujira 0:1977c2310ef7 4395 }
Kujira 0:1977c2310ef7 4396 gu_sendOneByte(j*16+k);
Kujira 0:1977c2310ef7 4397 }
Kujira 0:1977c2310ef7 4398 }
Kujira 0:1977c2310ef7 4399 i2c.stop();
Kujira 0:1977c2310ef7 4400 }
Kujira 0:1977c2310ef7 4401
Kujira 0:1977c2310ef7 4402 void gu_RealTimeImage(int w, int h, char data[])
Kujira 0:1977c2310ef7 4403 {
Kujira 0:1977c2310ef7 4404 h = h >> 3; // get height in byte
Kujira 0:1977c2310ef7 4405
Kujira 0:1977c2310ef7 4406 i2c.start();
Kujira 0:1977c2310ef7 4407 gu_sendOneByte(addr_gu);
Kujira 0:1977c2310ef7 4408 gu_sendOneByte(0x1f);
Kujira 0:1977c2310ef7 4409 gu_sendOneByte(0x28);
Kujira 0:1977c2310ef7 4410 gu_sendOneByte(0x66);
Kujira 0:1977c2310ef7 4411 gu_sendOneByte(0x11);
Kujira 0:1977c2310ef7 4412 gu_sendOneByte( w & 0xff);
Kujira 0:1977c2310ef7 4413 gu_sendOneByte( w >> 8);
Kujira 0:1977c2310ef7 4414 gu_sendOneByte( h & 0xff);
Kujira 0:1977c2310ef7 4415 gu_sendOneByte( h >> 8);
Kujira 0:1977c2310ef7 4416 gu_sendOneByte(0x01);
Kujira 0:1977c2310ef7 4417 for( int i=0; i < ( w * h ); i++) {
Kujira 0:1977c2310ef7 4418 gu_sendOneByte( data[i]);
Kujira 0:1977c2310ef7 4419 }
Kujira 0:1977c2310ef7 4420 i2c.stop();
Kujira 0:1977c2310ef7 4421 }
Kujira 0:1977c2310ef7 4422
Kujira 0:1977c2310ef7 4423 // Draw RealTimeBitImage by dot
Kujira 0:1977c2310ef7 4424 void gu_RealTimeImage_dot(int x, int y, int w, int h, const char data[])
Kujira 0:1977c2310ef7 4425 {
Kujira 0:1977c2310ef7 4426 i2c.start();
Kujira 0:1977c2310ef7 4427 gu_sendOneByte(addr_gu);
Kujira 0:1977c2310ef7 4428 gu_sendOneByte(0x1f);
Kujira 0:1977c2310ef7 4429 gu_sendOneByte(0x28);
Kujira 0:1977c2310ef7 4430 gu_sendOneByte(0x64);
Kujira 0:1977c2310ef7 4431 gu_sendOneByte(0x21);
Kujira 0:1977c2310ef7 4432 gu_sendOneByte(x & 0xff);
Kujira 0:1977c2310ef7 4433 gu_sendOneByte(x >> 8);
Kujira 0:1977c2310ef7 4434 gu_sendOneByte(y & 0xff);
Kujira 0:1977c2310ef7 4435 gu_sendOneByte(y >> 8);
Kujira 0:1977c2310ef7 4436 gu_sendOneByte(w & 0xff);
Kujira 0:1977c2310ef7 4437 gu_sendOneByte(w >> 8);
Kujira 0:1977c2310ef7 4438 gu_sendOneByte(h & 0xff);
Kujira 0:1977c2310ef7 4439 gu_sendOneByte(h >> 8);
Kujira 0:1977c2310ef7 4440 gu_sendOneByte(0x01);
Kujira 0:1977c2310ef7 4441 for(int i=0; i<( w * ((h + 7)>>3)); i++ ) {
Kujira 0:1977c2310ef7 4442 gu_sendOneByte(data[i]);
Kujira 0:1977c2310ef7 4443 }
Kujira 0:1977c2310ef7 4444 i2c.stop();
Kujira 0:1977c2310ef7 4445 }
Kujira 0:1977c2310ef7 4446
Kujira 0:1977c2310ef7 4447
Kujira 0:1977c2310ef7 4448 // Set Font width
Kujira 0:1977c2310ef7 4449 void gu_fontWidth(const char fontWidth)
Kujira 0:1977c2310ef7 4450 {
Kujira 0:1977c2310ef7 4451 /*
Kujira 0:1977c2310ef7 4452 gu_sendOneByte(0x1f);
Kujira 0:1977c2310ef7 4453 gu_sendOneByte(0x28);
Kujira 0:1977c2310ef7 4454 gu_sendOneByte(0x67);
Kujira 0:1977c2310ef7 4455 gu_sendOneByte(0x03);
Kujira 0:1977c2310ef7 4456 gu_sendOneByte(fontWidth);
Kujira 0:1977c2310ef7 4457 */
Kujira 0:1977c2310ef7 4458
Kujira 0:1977c2310ef7 4459 char accom_gu[5] ; //gu-DへのI2Cコマンド用配列
Kujira 0:1977c2310ef7 4460
Kujira 0:1977c2310ef7 4461 accom_gu[0] = 0x1F;
Kujira 0:1977c2310ef7 4462 accom_gu[1] = 0x28;
Kujira 0:1977c2310ef7 4463 accom_gu[2] = 0x67;
Kujira 0:1977c2310ef7 4464 accom_gu[3] = 0x03;
Kujira 0:1977c2310ef7 4465 accom_gu[4] = fontWidth;
Kujira 0:1977c2310ef7 4466
Kujira 0:1977c2310ef7 4467 i2c.write(addr_gu, accom_gu, 5);
Kujira 0:1977c2310ef7 4468
Kujira 0:1977c2310ef7 4469 }
Kujira 0:1977c2310ef7 4470
Kujira 0:1977c2310ef7 4471 //
Kujira 0:1977c2310ef7 4472 // Move Cursor
Kujira 0:1977c2310ef7 4473 // 動作確認完了 2017/6/26
Kujira 0:1977c2310ef7 4474 void gu_cursor(int x, int y)
Kujira 0:1977c2310ef7 4475 {
Kujira 0:1977c2310ef7 4476
Kujira 0:1977c2310ef7 4477 /*
Kujira 0:1977c2310ef7 4478 gu_sendOneByte(0x1f);
Kujira 0:1977c2310ef7 4479 gu_sendOneByte(0x24);
Kujira 0:1977c2310ef7 4480 gu_sendOneByte(x%256);
Kujira 0:1977c2310ef7 4481 gu_sendOneByte(x>>8);
Kujira 0:1977c2310ef7 4482 gu_sendOneByte(y%256);
Kujira 0:1977c2310ef7 4483 gu_sendOneByte(y>>8);
Kujira 0:1977c2310ef7 4484 */
Kujira 0:1977c2310ef7 4485
Kujira 0:1977c2310ef7 4486 char accom_gu[6] ; //gu-DへのI2Cコマンド用配列
Kujira 0:1977c2310ef7 4487
Kujira 0:1977c2310ef7 4488 accom_gu[0] = 0x1f;
Kujira 0:1977c2310ef7 4489 accom_gu[1] = 0x24;
Kujira 0:1977c2310ef7 4490 accom_gu[2] = x & 0xFF;
Kujira 0:1977c2310ef7 4491 accom_gu[3] = x >> 8;
Kujira 0:1977c2310ef7 4492 accom_gu[4] = y & 0xFF;
Kujira 0:1977c2310ef7 4493 accom_gu[5] = y >> 8;
Kujira 0:1977c2310ef7 4494
Kujira 0:1977c2310ef7 4495 i2c.write(addr_gu, accom_gu, 6);
Kujira 0:1977c2310ef7 4496
Kujira 0:1977c2310ef7 4497 }
Kujira 0:1977c2310ef7 4498
Kujira 0:1977c2310ef7 4499 // Font Body Size
Kujira 0:1977c2310ef7 4500 // 動作確認2017/6/26
Kujira 0:1977c2310ef7 4501 void gu_fontsize(const char code)
Kujira 0:1977c2310ef7 4502 {
Kujira 0:1977c2310ef7 4503 /*
Kujira 0:1977c2310ef7 4504 gu_sendOneByte(0x1f);
Kujira 0:1977c2310ef7 4505 gu_sendOneByte(0x28);
Kujira 0:1977c2310ef7 4506 gu_sendOneByte(0x67);
Kujira 0:1977c2310ef7 4507 gu_sendOneByte(0x01);
Kujira 0:1977c2310ef7 4508 gu_sendOneByte(code);
Kujira 0:1977c2310ef7 4509 */
Kujira 0:1977c2310ef7 4510 char accom_gu[5] ; //gu-DへのI2Cコマンド用配列
Kujira 0:1977c2310ef7 4511
Kujira 0:1977c2310ef7 4512 accom_gu[0] = 0x1F;
Kujira 0:1977c2310ef7 4513 accom_gu[1] = 0x28;
Kujira 0:1977c2310ef7 4514 accom_gu[2] = 0x67;
Kujira 0:1977c2310ef7 4515 accom_gu[3] = 0x01;
Kujira 0:1977c2310ef7 4516 accom_gu[4] = code;
Kujira 0:1977c2310ef7 4517
Kujira 0:1977c2310ef7 4518 i2c.write(addr_gu, accom_gu, 5);
Kujira 0:1977c2310ef7 4519
Kujira 0:1977c2310ef7 4520 }
Kujira 0:1977c2310ef7 4521
Kujira 0:1977c2310ef7 4522
Kujira 0:1977c2310ef7 4523 //
Kujira 0:1977c2310ef7 4524 // Reverse video font
Kujira 0:1977c2310ef7 4525 void gu_fontReverse(int code)
Kujira 0:1977c2310ef7 4526 {
Kujira 0:1977c2310ef7 4527
Kujira 0:1977c2310ef7 4528 i2c.start();
Kujira 0:1977c2310ef7 4529 gu_sendOneByte(addr_gu);
Kujira 0:1977c2310ef7 4530 gu_sendOneByte(0x1f);
Kujira 0:1977c2310ef7 4531 gu_sendOneByte(0x72);
Kujira 0:1977c2310ef7 4532 gu_sendOneByte(code);
Kujira 0:1977c2310ef7 4533 i2c.stop();
Kujira 0:1977c2310ef7 4534
Kujira 0:1977c2310ef7 4535 }
Kujira 0:1977c2310ef7 4536
Kujira 0:1977c2310ef7 4537 void gu_touchPara(int x,int y)
Kujira 0:1977c2310ef7 4538 {
Kujira 0:1977c2310ef7 4539 i2c.start();
Kujira 0:1977c2310ef7 4540 i2c.write(addr_gu);
Kujira 0:1977c2310ef7 4541 i2c.write(0x1F);
Kujira 0:1977c2310ef7 4542 i2c.write(0x4B);
Kujira 0:1977c2310ef7 4543 i2c.write(0x70);
Kujira 0:1977c2310ef7 4544 i2c.write(x & 0xFF);
Kujira 0:1977c2310ef7 4545 i2c.write(y & 0xFF);
Kujira 0:1977c2310ef7 4546 i2c.stop();
Kujira 0:1977c2310ef7 4547 }
Kujira 0:1977c2310ef7 4548
Kujira 0:1977c2310ef7 4549 // Magnify Font キャラクタ拡大表示
Kujira 0:1977c2310ef7 4550 void gu_magnify(int x, int y)
Kujira 0:1977c2310ef7 4551 {
Kujira 0:1977c2310ef7 4552 gu_sendOneByte(0x1f);
Kujira 0:1977c2310ef7 4553 gu_sendOneByte(0x28);
Kujira 0:1977c2310ef7 4554 gu_sendOneByte(0x67);
Kujira 0:1977c2310ef7 4555 gu_sendOneByte(0x40);
Kujira 0:1977c2310ef7 4556 gu_sendOneByte(x);
Kujira 0:1977c2310ef7 4557 gu_sendOneByte(y);
Kujira 0:1977c2310ef7 4558 }
Kujira 0:1977c2310ef7 4559
Kujira 0:1977c2310ef7 4560 /*********************************
Kujira 0:1977c2310ef7 4561 ノリタケ関数
Kujira 0:1977c2310ef7 4562 ここまで
Kujira 0:1977c2310ef7 4563 **********************************/
Kujira 0:1977c2310ef7 4564 //
Kujira 0:1977c2310ef7 4565 //Show text
Kujira 0:1977c2310ef7 4566 void gu_print1(const char* ptext)
Kujira 0:1977c2310ef7 4567 {
Kujira 0:1977c2310ef7 4568 i2c.write(addr_gu, ptext, strlen(ptext));
Kujira 0:1977c2310ef7 4569 }
Kujira 0:1977c2310ef7 4570 //
Kujira 0:1977c2310ef7 4571 //輝度調整
Kujira 0:1977c2310ef7 4572 void gu_luminance(const char* cl)
Kujira 0:1977c2310ef7 4573 {
Kujira 0:1977c2310ef7 4574 i2c.start();
Kujira 0:1977c2310ef7 4575 i2c.write(addr_gu);
Kujira 0:1977c2310ef7 4576 i2c.write(0x1F);
Kujira 0:1977c2310ef7 4577 i2c.write(0x58);
Kujira 0:1977c2310ef7 4578 i2c.write(*cl & 0xFF);
Kujira 0:1977c2310ef7 4579 i2c.stop();
Kujira 0:1977c2310ef7 4580 }
Kujira 0:1977c2310ef7 4581 //
Kujira 0:1977c2310ef7 4582 //gu_Dクラス用 1バイト送信
Kujira 0:1977c2310ef7 4583 void gu_sendOneByte(char data) //arduino->mbed
Kujira 0:1977c2310ef7 4584 {
Kujira 0:1977c2310ef7 4585 i2c.write(data);
Kujira 0:1977c2310ef7 4586 //while(digitalRead(gu_MBUSY)==HIGH){} // wait for ready.
Kujira 0:1977c2310ef7 4587 //Serial.write(data); // send a byte.
Kujira 0:1977c2310ef7 4588 }
Kujira 0:1977c2310ef7 4589 //
Kujira 0:1977c2310ef7 4590 //CF+RF
Kujira 0:1977c2310ef7 4591 void gu_CRLF()
Kujira 0:1977c2310ef7 4592 {
Kujira 0:1977c2310ef7 4593 char com[2];
Kujira 0:1977c2310ef7 4594
Kujira 0:1977c2310ef7 4595 com[0] = 0x0A; //LF
Kujira 0:1977c2310ef7 4596 com[1] = 0x0D; //CR
Kujira 0:1977c2310ef7 4597 i2c.write(addr_gu, com, 2); //LF+CR
Kujira 0:1977c2310ef7 4598 }
Kujira 0:1977c2310ef7 4599 //
Kujira 0:1977c2310ef7 4600 //リバース指定or解除
Kujira 0:1977c2310ef7 4601 void gu_reverse(char x) //リバース指定or解除
Kujira 0:1977c2310ef7 4602 {
Kujira 0:1977c2310ef7 4603 char com[3];
Kujira 0:1977c2310ef7 4604
Kujira 0:1977c2310ef7 4605 com[0] = 0x1F;
Kujira 0:1977c2310ef7 4606 com[1] = 0x72;
Kujira 0:1977c2310ef7 4607 com[2] = x & 0xFF; //0x01:指定 0x00:解除
Kujira 0:1977c2310ef7 4608 i2c.write(addr_gu, com, 3);
Kujira 0:1977c2310ef7 4609 }
Kujira 0:1977c2310ef7 4610 //1byte送信用
Kujira 0:1977c2310ef7 4611 void gu_onebyte(char data)
Kujira 0:1977c2310ef7 4612 {
Kujira 0:1977c2310ef7 4613 i2c.write(addr_gu, &data, 1);
Kujira 0:1977c2310ef7 4614 }
Kujira 0:1977c2310ef7 4615 /*****************************************
Kujira 0:1977c2310ef7 4616
Kujira 0:1977c2310ef7 4617 SD CARD
Kujira 0:1977c2310ef7 4618
Kujira 0:1977c2310ef7 4619 *****************************************/
Kujira 0:1977c2310ef7 4620 void sd_writetext(const char* ptext)
Kujira 0:1977c2310ef7 4621 {
Kujira 0:1977c2310ef7 4622
Kujira 0:1977c2310ef7 4623 mkdir("/sd/mydir", 0777);
Kujira 0:1977c2310ef7 4624
Kujira 0:1977c2310ef7 4625 FILE *fp = fopen("/sd/mydir/iop.txt", "w");//ディレクトリとファイル名の指定
Kujira 0:1977c2310ef7 4626
Kujira 0:1977c2310ef7 4627 if(fp == NULL) {
Kujira 0:1977c2310ef7 4628
Kujira 0:1977c2310ef7 4629 gu_fontsize(1);
Kujira 0:1977c2310ef7 4630 gu_cursor(0,2);
Kujira 0:1977c2310ef7 4631 /* ver1.1.3*/
Kujira 0:1977c2310ef7 4632 gu_print1("No SD card");
Kujira 0:1977c2310ef7 4633 //gu_print1("Could not open file for SD card");
Kujira 0:1977c2310ef7 4634 //error("Could not open file for write\n");
Kujira 0:1977c2310ef7 4635
Kujira 0:1977c2310ef7 4636 }
Kujira 0:1977c2310ef7 4637
Kujira 0:1977c2310ef7 4638 fprintf(fp, ptext);
Kujira 0:1977c2310ef7 4639 fclose(fp);
Kujira 0:1977c2310ef7 4640
Kujira 0:1977c2310ef7 4641 }