fork

Dependencies:   mbed

Fork of LG by igor Apu

Committer:
Kovalev_D
Date:
Mon Aug 29 11:58:52 2016 +0000
Revision:
191:40028201ddad
Parent:
190:289514f730ee
Child:
192:d32c8cf7bcd9
plc

Who changed what in which revision?

UserRevisionLine numberNew contents of line
igor_v 0:8ad47e2b6f00 1 #ifndef VIBRO_H
igor_v 0:8ad47e2b6f00 2 #define VIBRO_H
igor_v 0:8ad47e2b6f00 3
igor_v 21:bc8c1cec3da6 4 #define ClrV1 LPC_GPIO1->FIOSET=(1<<25);
Kovalev_D 87:7e575d26d6d0 5 #define SetV1 LPC_GPIO1->FIOCLR = (1<<25);
igor_v 1:f2adcae3d304 6
Kovalev_D 47:d902ef6f7564 7 #define TXOn LPC_GPIO2->FIOSET=(1<<7);
Kovalev_D 47:d902ef6f7564 8 #define TXOff LPC_GPIO2->FIOCLR = (1<<7);
Kovalev_D 47:d902ef6f7564 9
igor_v 21:bc8c1cec3da6 10 #define ClrV2 LPC_GPIO1->FIOSET = (1<<28);
igor_v 21:bc8c1cec3da6 11 #define SetV2 LPC_GPIO1->FIOCLR = (1<<28);
igor_v 0:8ad47e2b6f00 12
Kovalev_D 26:52ce5953a5c2 13 #define LoopOn LPC_GPIO1->FIOSET = (1<<30);
Kovalev_D 26:52ce5953a5c2 14 #define LoopOff LPC_GPIO1->FIOCLR = (1<<30);
Kovalev_D 26:52ce5953a5c2 15 #define StartV1 0
Kovalev_D 26:52ce5953a5c2 16 #define StartV2 15
igor_v 0:8ad47e2b6f00 17 #define TIME_INTERVAL (7812)
igor_v 0:8ad47e2b6f00 18
Kovalev_D 132:2c7bec5cf6fe 19
Kovalev_D 150:29c9f7671bac 20
Kovalev_D 107:4d178bcc9d8a 21 extern int tempAMP;
igor_v 33:341521841d3a 22 typedef struct _Gyro {
Kovalev_D 132:2c7bec5cf6fe 23
Kovalev_D 140:1fbf117fc120 24 unsigned int StrayHZ; //помеха
Kovalev_D 140:1fbf117fc120 25 unsigned int StrayHZ_flag;
Kovalev_D 140:1fbf117fc120 26 unsigned int LogHZ;
Kovalev_D 140:1fbf117fc120 27
Kovalev_D 140:1fbf117fc120 28
Kovalev_D 142:7a6f68601291 29 unsigned int StrayPLC_Pls; //помеха +
Kovalev_D 142:7a6f68601291 30 int StrayPLC_Mns; //помеха -
Kovalev_D 140:1fbf117fc120 31 unsigned int StrayPLC_2Mode;
Kovalev_D 140:1fbf117fc120 32 unsigned int StrayPLC_flag;
Kovalev_D 140:1fbf117fc120 33 unsigned int LogPLC;
Kovalev_D 150:29c9f7671bac 34 unsigned int PLC_Lern;
Kovalev_D 168:f4a6abb18358 35 unsigned int ModJump;
Kovalev_D 172:ef7bf1663645 36 unsigned int flagGph_W;
Kovalev_D 139:1716152517aa 37
Kovalev_D 152:cff1321ab25e 38 // unsigned int Test_time;
Kovalev_D 152:cff1321ab25e 39 // unsigned int Test_time1;
Kovalev_D 139:1716152517aa 40
Kovalev_D 132:2c7bec5cf6fe 41 unsigned int FlashMod; //0-ничего не делать, 1 - запись во Flash, 2 чтение из Flash.
Kovalev_D 139:1716152517aa 42
Kovalev_D 124:9ae09249f842 43 unsigned int ModeOut;
Kovalev_D 170:d099c3025f87 44 // unsigned int Rate1_Flag;
Kovalev_D 124:9ae09249f842 45 unsigned int Rate1_Event;
Kovalev_D 170:d099c3025f87 46 // unsigned int Rate2_Flag;
Kovalev_D 124:9ae09249f842 47 unsigned int Rate2_Event;
Kovalev_D 124:9ae09249f842 48 #define Rate1 0x01
Kovalev_D 124:9ae09249f842 49 #define Rate2 0x02
Kovalev_D 124:9ae09249f842 50 #define PRate1 0x81
Kovalev_D 124:9ae09249f842 51 #define PRate2 0x82
Kovalev_D 124:9ae09249f842 52
Kovalev_D 124:9ae09249f842 53
Kovalev_D 124:9ae09249f842 54 unsigned int DeltaEXT_Event;
Kovalev_D 124:9ae09249f842 55 unsigned int Delta500_Event;
Kovalev_D 143:2b15794a6cd2 56
Kovalev_D 143:2b15794a6cd2 57 unsigned int Event_500Hz;
Kovalev_D 162:44e4ded32c6a 58 #define Delta_500 0x10
Kovalev_D 162:44e4ded32c6a 59 #define PDelta_500 0x90
Kovalev_D 162:44e4ded32c6a 60 #define Delta_EXT 0x0
Kovalev_D 162:44e4ded32c6a 61 #define PDelta_EXT 0x80
Kovalev_D 85:0466ee8cdfc8 62 unsigned int RgConA;
Kovalev_D 85:0466ee8cdfc8 63 unsigned int RgConB;
Kovalev_D 26:52ce5953a5c2 64
Kovalev_D 190:289514f730ee 65 unsigned int Gain_Sin;
Kovalev_D 190:289514f730ee 66 unsigned int Gain_Cos;
Kovalev_D 26:52ce5953a5c2 67
igor_v 37:bdd52117b56e 68 unsigned int Frq; // Непосредственное значение частоты для таймера.
igor_v 37:bdd52117b56e 69 unsigned int FrqHZ; // Частота в Гц.
Kovalev_D 191:40028201ddad 70 unsigned int FrqHZmin; //Мин значение частоты ВП
Kovalev_D 191:40028201ddad 71 unsigned int FrqHZmax; //Мах значение частоты ВП
Kovalev_D 191:40028201ddad 72 unsigned int FrqChengSpeed;//скорость регулировки частоты ВП
Kovalev_D 85:0466ee8cdfc8 73
Kovalev_D 152:cff1321ab25e 74 unsigned int VibroFrqRegulF; //флаг регулировки частоты ВП
Kovalev_D 152:cff1321ab25e 75 unsigned int VibroAMPRegulF; //флаг регулировки амплитуды ВП
Kovalev_D 152:cff1321ab25e 76 unsigned int VibroNoiseF; //флаг ошумления амплитуды ВП
Kovalev_D 112:4a96133a1311 77 unsigned int VibroOutF;
Kovalev_D 85:0466ee8cdfc8 78
Kovalev_D 191:40028201ddad 79
Kovalev_D 26:52ce5953a5c2 80 unsigned int Amp;
Kovalev_D 85:0466ee8cdfc8 81 unsigned int AmpT; // значение тиков после которых происходит смена амплитуды ошумления ( rand() % Gyro.AmpTD+Gyro.AmpMin)
Kovalev_D 85:0466ee8cdfc8 82 unsigned int AmpMin; // минимальное значение AmpT(частота ошумления);
Kovalev_D 85:0466ee8cdfc8 83 unsigned int AmpTD; // максимальное значение AmpT(частота ошумления);
Kovalev_D 85:0466ee8cdfc8 84 unsigned int AmpPer; // Амплитуда в процентах;
Kovalev_D 189:8a16378724c4 85 unsigned int AmpPerMin;
Kovalev_D 189:8a16378724c4 86 unsigned int AmpPerMax;
Kovalev_D 189:8a16378724c4 87 unsigned int AmpSpeed;
Kovalev_D 191:40028201ddad 88 unsigned int AmpTarget;
Kovalev_D 180:375dcd9c0cb6 89 unsigned int AmpPerDel;// значение для расчета амплитуды(дельта амплитуды), мин знач : AmpPer, мах знач : AmpPer+AmpPerDel; (в процентах)
Kovalev_D 112:4a96133a1311 90 unsigned int AmpN1; // левая граница импулься ВП
Kovalev_D 112:4a96133a1311 91 unsigned int AmpN2; // равая граница импулься ВП
Kovalev_D 112:4a96133a1311 92 int MaxAmp; // амплитуда Пик-Пик расчтитанная по востановленному синусу.
Kovalev_D 191:40028201ddad 93 int AmpSC;
Kovalev_D 112:4a96133a1311 94 //ЭНКОДЕР
Kovalev_D 112:4a96133a1311 95 int CaunPlus;//
Kovalev_D 112:4a96133a1311 96 int CaunMin;//
igor_v 110:6406b7ac0442 97 // данные АЦП
Kovalev_D 113:8be429494918 98 unsigned int Termo; // значение АЦП
Kovalev_D 113:8be429494918 99 unsigned int DeltaT;
Kovalev_D 113:8be429494918 100 unsigned int In1;
Kovalev_D 113:8be429494918 101 unsigned int In2;
igor_v 111:8ee1ef722ba7 102 //пятый ацп, он же амплитудный детектор "AD". есть два фильтра быстрый "Fast" и медленный "Slow"
igor_v 111:8ee1ef722ba7 103 unsigned int ADF_Accum; //Значенее амплитудного детектора Временное
igor_v 111:8ee1ef722ba7 104 unsigned int ADS_Accum; //Значенее амплитудного детектора Временное
Kovalev_D 158:0c8342e1837a 105 unsigned int ADS_AccumTermLM;
Kovalev_D 158:0c8342e1837a 106 unsigned int TermLM;
igor_v 110:6406b7ac0442 107 unsigned int ADF_Count; //Значенее времени накопления данных
igor_v 111:8ee1ef722ba7 108 unsigned int ADS_Count; //Значенее времени накопления данных
igor_v 110:6406b7ac0442 109
igor_v 110:6406b7ac0442 110 unsigned int AD_Fast; //Значенее амплитудного детектора сдвинутое на 16 бит
igor_v 110:6406b7ac0442 111 unsigned int AD_Slow; //Значенее амплитудного детектора сдвинутое на 16 бит
igor_v 110:6406b7ac0442 112
igor_v 111:8ee1ef722ba7 113 unsigned int ADF_NewData; // есть данные после фильтрации в быстром фильтре
igor_v 111:8ee1ef722ba7 114 unsigned int ADS_NewData; //-----------/----------/----------/--------
igor_v 110:6406b7ac0442 115
igor_v 111:8ee1ef722ba7 116 //контур регулеровки Периметра "PLC"
igor_v 127:6a7472d67804 117 int PLC_Delta; // разница между старым и новым показаниями
igor_v 127:6a7472d67804 118 int PLC_DeltaADD; // разница между старым и новым показаниями с учетом знака управляешего напряжения АЦП
Kovalev_D 116:66f1f0ff2dab 119 int PLC_Old;
igor_v 127:6a7472d67804 120 int PLC_ADC_DOld;
Kovalev_D 170:d099c3025f87 121 //int PLC_Regul;
Kovalev_D 152:cff1321ab25e 122 int PLC_Error2Mode; // счетчик, не ноль когдав двух модовом
Kovalev_D 157:1069c80f4944 123 int PlC_MaxD; // разница между максимальной и текущей амплитудами.
igor_v 110:6406b7ac0442 124
igor_v 111:8ee1ef722ba7 125 //Контур регулеровки накачки (если нужно, например ГВЧ)
igor_v 110:6406b7ac0442 126
igor_v 111:8ee1ef722ba7 127
igor_v 111:8ee1ef722ba7 128
igor_v 111:8ee1ef722ba7 129
igor_v 111:8ee1ef722ba7 130
Kovalev_D 26:52ce5953a5c2 131 unsigned int CMD_In;
Kovalev_D 26:52ce5953a5c2 132 unsigned int SOC_Out;
Kovalev_D 26:52ce5953a5c2 133 unsigned int My_Addres;
Kovalev_D 181:0b022246c43c 134 unsigned int DropDelayGLD;//задержка для мультидропа (дискрета 100кГц)
Kovalev_D 182:ebcd2bc3be8f 135 #define DropDelayGLD_0 45
Kovalev_D 182:ebcd2bc3be8f 136 #define DropDelayGLD_1 45
Kovalev_D 182:ebcd2bc3be8f 137 #define DropDelayGLD_2 60
Kovalev_D 182:ebcd2bc3be8f 138 #define DropDelayGLD_3 75
Kovalev_D 26:52ce5953a5c2 139 unsigned int GLD_Serial;
Kovalev_D 26:52ce5953a5c2 140 unsigned int CRC;
Kovalev_D 26:52ce5953a5c2 141 unsigned int Firmware_Version;
Kovalev_D 26:52ce5953a5c2 142 unsigned int RsErrLine;
Kovalev_D 26:52ce5953a5c2 143
igor_v 110:6406b7ac0442 144
igor_v 110:6406b7ac0442 145
igor_v 110:6406b7ac0442 146
Kovalev_D 106:250ddd8629c6 147
igor_v 111:8ee1ef722ba7 148 int CuruAngle ;
Kovalev_D 152:cff1321ab25e 149 // int OldCuruAngle ;
Kovalev_D 170:d099c3025f87 150 // int Num;
igor_v 111:8ee1ef722ba7 151 int Cnt_Dif;
Kovalev_D 108:030cdde08314 152
Kovalev_D 26:52ce5953a5c2 153 unsigned int F_ras;
Kovalev_D 108:030cdde08314 154
Kovalev_D 170:d099c3025f87 155 // unsigned int ras;
Kovalev_D 104:ab1cb4ff56b2 156
Kovalev_D 104:ab1cb4ff56b2 157
Kovalev_D 171:d227a6045305 158 #define FrqOFF Gyro.RgConA &= ~AFRQ; //установить контур регулировки частоты в "0"
Kovalev_D 171:d227a6045305 159 #define FrqON Gyro.RgConA |= AFRQ; //установить контур регулировки частоты в "1"
Kovalev_D 104:ab1cb4ff56b2 160
Kovalev_D 171:d227a6045305 161
Kovalev_D 171:d227a6045305 162 #define AVibOFF Gyro.RgConA &= ~AVBT; //установить контур регулировки частоты в "0"
Kovalev_D 171:d227a6045305 163 #define AVibON Gyro.RgConA |= AVBT; //установить контур регулировки частоты в "1"
Kovalev_D 171:d227a6045305 164
Kovalev_D 171:d227a6045305 165 #define HFOOFF Gyro.RgConA &= ~AHFO; //установить контур накачки в "0"
Kovalev_D 171:d227a6045305 166 #define HFOON Gyro.RgConA |= AHFO; //установить контур накачки в "1"
Kovalev_D 104:ab1cb4ff56b2 167
Kovalev_D 171:d227a6045305 168 #define PlcOFF Gyro.RgConA &= ~APLC; //установить контур регулировки периметра в "0"
Kovalev_D 171:d227a6045305 169 #define PlcON Gyro.RgConA |= APLC; //установить контур регулировки периметра в "1"
Kovalev_D 104:ab1cb4ff56b2 170
Kovalev_D 171:d227a6045305 171 #define AFRQ (1<<6)
Kovalev_D 171:d227a6045305 172 #define AVBT (1<<5)
Kovalev_D 171:d227a6045305 173 #define APLC (1<<3)
Kovalev_D 104:ab1cb4ff56b2 174 #define AHFO (1<<1)
Kovalev_D 171:d227a6045305 175
Kovalev_D 171:d227a6045305 176
Kovalev_D 171:d227a6045305 177
Kovalev_D 85:0466ee8cdfc8 178
Kovalev_D 152:cff1321ab25e 179 unsigned int PinReg; // bit4 bit3 bit 2 bit1 bit0
Kovalev_D 28:1c9acd3b224d 180 unsigned int PinRegOld; // || светодиод || состояние поджига || состояние подсветки || состояние вибро 2 || состояние вибро 1 ||
Kovalev_D 40:8a6494f61326 181 #define LedOFF Gyro.PinReg &= ~PinRegBitLED; //установить бит светодиода в "0"
igor_v 48:8697dfe679b9 182 #define LedON Gyro.PinReg |= PinRegBitLED; //установить бит светодиода в "1"
Kovalev_D 40:8a6494f61326 183
Kovalev_D 104:ab1cb4ff56b2 184
igor_v 48:8697dfe679b9 185 #define PinRegBitTXE (1<<5)
igor_v 48:8697dfe679b9 186 #define PinRegBitLED (1<<4)
igor_v 48:8697dfe679b9 187 #define PinRegBitD (1<<3)
igor_v 48:8697dfe679b9 188 #define PinRegBitL (1<<2)
igor_v 48:8697dfe679b9 189 #define PinRegBit_2V (1<<1)
igor_v 48:8697dfe679b9 190 #define PinRegBit_1V (1<<0)
igor_v 110:6406b7ac0442 191 unsigned int Discharg; // последовательность бит харрактеризующая форму сигнала поджига.
Kovalev_D 188:4c523cc373cc 192 #define StartDischarg 0x00000222
Kovalev_D 40:8a6494f61326 193 unsigned int BackLight; // последовательность бит харрактеризующая форму сигнала подсветки.
Kovalev_D 188:4c523cc373cc 194 #define StartBackLight 0x00000333
igor_v 110:6406b7ac0442 195
Kovalev_D 188:4c523cc373cc 196 #define ShiftStart0 0x1
Kovalev_D 188:4c523cc373cc 197 #define ShiftStart1 0x1
Kovalev_D 188:4c523cc373cc 198 #define ShiftStart2 0x2
Kovalev_D 188:4c523cc373cc 199 #define ShiftStart3 0x3
igor_v 110:6406b7ac0442 200
Kovalev_D 128:1e4675a36c93 201 unsigned int EXT_Latch;
Kovalev_D 128:1e4675a36c93 202
igor_v 110:6406b7ac0442 203
Kovalev_D 28:1c9acd3b224d 204
Kovalev_D 28:1c9acd3b224d 205
Kovalev_D 26:52ce5953a5c2 206
Kovalev_D 28:1c9acd3b224d 207
Kovalev_D 129:406995a91322 208 } GyroT, *Gyro_p;
Kovalev_D 136:19b9e6abb86f 209
Kovalev_D 129:406995a91322 210 extern GyroT Gyro;
Kovalev_D 129:406995a91322 211 typedef union {
Kovalev_D 129:406995a91322 212 int Array[171];
Kovalev_D 129:406995a91322 213 struct {
Kovalev_D 129:406995a91322 214 // Device_blk
Kovalev_D 129:406995a91322 215 int My_Addres; //e. 0 - device own address //r.0 - собственный адрес устройства
Kovalev_D 129:406995a91322 216
Kovalev_D 129:406995a91322 217 //e. =============== parameters of HFO regulator =============== //r. =============== параметры контура ВЧ генератора накачки ===============
Kovalev_D 129:406995a91322 218 int HF_ref; //e. 1 - value of the reference //r. 1 - значение опоры
Kovalev_D 129:406995a91322 219 int HF_scl; //e. 2 - the gain factor (1.15) //r. 2 - коэффициент передачи (1.15)
Kovalev_D 129:406995a91322 220 int HF_min; //r. 3 - минимум выходного значения на ЦАПе регулятора (соответствует максим. напряжению на ГВЧ)
Kovalev_D 129:406995a91322 221 int HF_max; //e. 4 - maximum of the output value on the regulator DAC (appropriate to minimal voltage on the HFO) //r. 4 - максимум выходного значения на ЦАПе регулятора (соответствует миним. напряжению на ГВЧ)
Kovalev_D 129:406995a91322 222
Kovalev_D 129:406995a91322 223 //e. =============== parameters of the regulator of the DS power regulator ========== //r. =============== параметры контура регулирования мощности ДУП ==========
Kovalev_D 129:406995a91322 224 int RI_ref; //e. 5 - value of the reference //r. 5 - значение опоры
Kovalev_D 129:406995a91322 225 int RI_scl; //e. 6 - the gain factor (1.15) //r. 6 - коэффициент передачи (1.15)
Kovalev_D 129:406995a91322 226
Kovalev_D 129:406995a91322 227 //e. =============== parameters of the CPLC regulator ===== //r. =============== параметры контура стабилизации рабочего периметра (СРП) =====
Kovalev_D 129:406995a91322 228 int WP_ref; //e. 7 - value of the reference //r. 7 - значение опоры
Kovalev_D 129:406995a91322 229 int WP_scl; //e. 8 - the gain factor (1.15) //r. 8 - коэффициент передачи (1.15)
Kovalev_D 129:406995a91322 230 int WP_mdy; //e. 9 - value of the reset delay //r. 9 - значение задержки сброса
Kovalev_D 129:406995a91322 231 int WP_rup; //e. 10 - upper value of DAC adjustment (appropriate to minimal voltage on the heater) //r. 10 - верхнее значение регулировки ЦАП (соответствует миним. напряжению на нагревателе)
Kovalev_D 129:406995a91322 232 int WP_rdw; //e. 11 - lower value of the DAC adjustment (appropriate to maximal voltage on the heater) //r. 11 - верхнее значение регулировки ЦАП (соответствует максим. напряжению на нагревателе)
Kovalev_D 129:406995a91322 233
Kovalev_D 129:406995a91322 234 //e. =============== parameters of the dither drive regulator of the GLD ==================== //r. =============== параметры контура вибропривода ГЛД ====================
Kovalev_D 129:406995a91322 235 int VB_phs; //e. 12 - the phase delay parameter of the dither drive PLL //r. 12 - параметр Phase_зад. СРЧ вибропривода
Kovalev_D 129:406995a91322 236 int VB_scl; //e. 13 - the gain factor (1.15) of the dither drive PLL //r. 13 - коэффициент передачи (1.15) СРЧ вибропривода
Kovalev_D 129:406995a91322 237 unsigned int VB_N; //e. 14 - divider for dither drive period (defines dither period) //r. 14 - коэфф.деления N вибропривода (период колебаний) ВП
Kovalev_D 129:406995a91322 238 unsigned int VB_Nmin; //e. 15 - minimum of the output value of the oscillation period regulator //r. 15 - минимум выходного значения регулятора периода
Kovalev_D 129:406995a91322 239 unsigned int VB_Nmax; //e. 16 - maximum of the output value of the oscillation period regulator //r. 16 - максимум выходного значения регулятора периода
Kovalev_D 129:406995a91322 240
Kovalev_D 129:406995a91322 241 int VB_Fdf_Hi; //e. 17 - adjusted output frequency (H) //r. 17 - заданная частота расщепления (H)
Kovalev_D 129:406995a91322 242 unsigned int VB_Fdf_Lo; //e. 18 - (L) (double precision) //r. 18 - (L) (двойная точность)
Kovalev_D 129:406995a91322 243
Kovalev_D 129:406995a91322 244 int VB_Fsc; //e. 19 - the gain factor of the frequency regulator //r. 19 - коэффициент передачи регулятора частоты расщепления
Kovalev_D 129:406995a91322 245 unsigned int VB_Tmin; //e. 20 - the gain factor of the frequency regulator //r. 19 - коэффициент передачи регулятора частоты расщепления
Kovalev_D 129:406995a91322 246 unsigned int VB_Tmax; //e. 21 - maximum of the output value of the regulator //r. 21 - максимум выходного значения регулятора Tau
Kovalev_D 129:406995a91322 247 unsigned int VB_tau; //e. 22 - pulse width of the dither drive (without noise)//r. 22 - длительность импульса вибропривода (до ошумления)
Kovalev_D 129:406995a91322 248 int VBN_Tzd; //e. 23 - adjusted noise period //r. 23 - заданный период ошумления
Kovalev_D 129:406995a91322 249 int VBN_Ran; //e. 24 - range of the random component of noise //r. 24 - диапазон случайной составляющей ошумления VBN_Tsl
Kovalev_D 129:406995a91322 250 int VBN_k; //e. 25 - adjusted noise constant //r. 25 - заданная константа ошумления
Kovalev_D 129:406995a91322 251
Kovalev_D 129:406995a91322 252 //e. =============== parameters of processing of accurate data ============= //r. =============== параметры обработки точностной информации =============
Kovalev_D 129:406995a91322 253 int PI_Fsc; //_ //e. 26 - the S_ds scale parameter //r. 26 - масштабный коэффициент Sдуп
Kovalev_D 129:406995a91322 254 int PI_Fb0; //_ //e. 27 - the B_ds zero shift of the DS //r. 27 - смещение нуля ДУПа Bдуп
Kovalev_D 129:406995a91322 255 int PI_scl; //_ //e. 28 - the Scale scale coefficient of the gyro //r. 28 - масштабный коэфф. гироскопа Scale
Kovalev_D 129:406995a91322 256 int PI_bia; //_ //e. 29 - the Bias zero shift of the gyro //r. 29 - смещение нуля гироскопа Bias
Kovalev_D 129:406995a91322 257
Kovalev_D 129:406995a91322 258 //e. =============== coefficients of the temperature correction ================= //r. =============== коэффициенты температурной коррекции =================
Kovalev_D 129:406995a91322 259 int PI_a0; //_ // 30
Kovalev_D 129:406995a91322 260 int PI_a1; //_ // 31
Kovalev_D 129:406995a91322 261 int PI_a2; //_ // 32
Kovalev_D 129:406995a91322 262 int PI_a3; //_ // 33
Kovalev_D 129:406995a91322 263 int PI_a4; //_ // 34
Kovalev_D 129:406995a91322 264 int PI_a5; //_ // 35
Kovalev_D 129:406995a91322 265 int PI_a6; //_ // 36
Kovalev_D 129:406995a91322 266 int PI_b1; //_ // 37
Kovalev_D 129:406995a91322 267 int PI_b2; //_ // 38
Kovalev_D 129:406995a91322 268 int PI_b3; //_ // 39
Kovalev_D 129:406995a91322 269 int PI_b4; //_ // 40
Kovalev_D 129:406995a91322 270 int PI_b5; //_ // 41
Kovalev_D 129:406995a91322 271 int PI_b6; //_ // 42
Kovalev_D 129:406995a91322 272
Kovalev_D 129:406995a91322 273 //e. =============== parameters of normalization of the temperature sensors ============= //r. =============== параметры нормировки датчиков температуры =============
Kovalev_D 129:406995a91322 274
Kovalev_D 129:406995a91322 275 int Tmp_bias[6]; //_ //e. 43 - an array of shifts of the 0..5 temperature sensors //r. 43 - массив сдвигов температурных датчиков 0..5
Kovalev_D 129:406995a91322 276 int Tmp_scal[6]; //_ //e. 49 - an array of the scale coefficients of temperature sensors//r. 49 - массив масштабных к-тов температурных датчиков
Kovalev_D 129:406995a91322 277 int WP_reset; //e. 55 - initial position of the CPLC regulator (after reset) //r. 55 - исходное положение регулятора СРП (после сброса)
Kovalev_D 129:406995a91322 278
Kovalev_D 129:406995a91322 279 //e. ================ gain factor of photodetector channels =========== //r. ================ к-т усиления каналов фотоприемника ===========
Kovalev_D 129:406995a91322 280 unsigned int Gain_Ph_A; //e. 56 - initial gain factor of the A channel of photodetector //r. 56 - начальный к-т усиления канала А фотоприемника
Kovalev_D 129:406995a91322 281 unsigned int Gain_Ph_B; //e. 57 - initial gain factor of the B channel of photodetector //r. 57 - начальный к-т усиления канала B фотоприемника
Kovalev_D 129:406995a91322 282
Kovalev_D 129:406995a91322 283 //e. =============== switch of the source of loading GLD variables block === //r. =============== переключатель источника загрузки блока переменных ГЛД (галочка в настороечной программе)
Kovalev_D 129:406995a91322 284
Kovalev_D 129:406995a91322 285 int Header_Word; //e. 58 - flash sector validity header //r. 58 - заголовок-ключ к индикатору источника загрузки
Kovalev_D 129:406995a91322 286 int LoadFlash_enable; //e. 59 - source loading flag: 1 - load from the flash //r. 59 - признак источника загрузки: 1 - грузиться из flesh
Kovalev_D 129:406995a91322 287
Kovalev_D 129:406995a91322 288 //e. 0 - load default parameters (factory) //r. 0 - грузить параметры по умолчанию (заводские)
Kovalev_D 129:406995a91322 289 unsigned int Device_SerialNumber; //e. 60 - serial number of the device //r. 60 - серийный номер прибора
Kovalev_D 129:406995a91322 290 int Reserved0; //e. 61 - not used
Kovalev_D 129:406995a91322 291
Kovalev_D 129:406995a91322 292 int WP_reset2; //e. 91 - voltages of CPLC regulator reset at cooling //r. xx - напряжения обнуления контура СРП при охлаждении
Kovalev_D 129:406995a91322 293 //e. parameters setting termocompensation parameters in dynamics (at heating and cooling) //r. параметры, задающие параметры термокомпенсации в динамике (при нагреве и охлаждении)
Kovalev_D 129:406995a91322 294 float Reserved1; //e. 92 - not used
Kovalev_D 129:406995a91322 295 float Reserved2; //e. 93 - not used
Kovalev_D 129:406995a91322 296 int K_vb_tu; //e. 94 - slope of dependence of the VB_N division factor from temperature (as though Hz/degree, but in relative units ) //r. крутизна зависимости коэффициента деления VB_N от температуры (как бы Гц/градус, но в у.е.)
Kovalev_D 129:406995a91322 297 int TemperNormal; //e. 95 -temperature for which the VB_N division factor of the dither drive is set //r. температура, для которой задан коэффициент деления вибропривода VB_N
Kovalev_D 129:406995a91322 298 int K_WP_rst_heating; //r. 96 - крутизна зависимости напряжения обнуления при нагревании от температуры (как бы вольт/градус, но в у.е. ЦАП и термодатчиков )
Kovalev_D 129:406995a91322 299 int K_WP_rst_cooling; //e. 97 - slope of dependence of a reset voltage at cooling from temperature (as though Volt/degree, but in relative units of DAC and temperature sensors) //r. крутизна зависимости напряжения обнуления при охлаждении от температуры (как бы вольт/градус, но в у.е. ЦАП и термодатчиков )
Kovalev_D 129:406995a91322 300 int WP_transition_step; //e. 98 - step of change of a heater voltage at resetting //r. шаг изменения напряжения нагревателя при выполнении обнуления
Kovalev_D 129:406995a91322 301 int Reserved3; // e. 99 -not used
Kovalev_D 129:406995a91322 302 int HF_scl_2; //r. 100 - коэффициент передачи (1.15) контура ГВЧ при обнулении
Kovalev_D 129:406995a91322 303 // int TemperIntDyn[TERMO_FUNC_SIZE]; //e. 114 -
Kovalev_D 129:406995a91322 304 // float ThermoHeatDelta[TERMO_FUNC_SIZE]; //e. 128 -
Kovalev_D 129:406995a91322 305 int DeltaTempRecalc; //r. 129 - температурный интервал пересчета динамич. компенсации (в у.е.) //e. temperature delta for dynamic thermocompensation recalculation(in relative units)
Kovalev_D 129:406995a91322 306 // int TemperCoolIntDyn[TERMO_FUNC_SIZE]; // e. 143 -
Kovalev_D 129:406995a91322 307 // float ThermoCoolDelta[TERMO_FUNC_SIZE]; //e. 157 -
Kovalev_D 129:406995a91322 308 // TERMO_MODE TermoMode; //e 62 - device operation mode (with thermocompenstion, without it, debug )//r. 62 - режим работы прибора (с термокомпенсацией, без нее или отладка)
Kovalev_D 129:406995a91322 309 //e. addition for the piecewise-linear termocorrection //r. добавление для кусочно-линейной термокоррекции
Kovalev_D 129:406995a91322 310 // int TemperInt[TERMO_FUNC_SIZE]; //e. 63
Kovalev_D 129:406995a91322 311 // float TermoFunc[TERMO_FUNC_SIZE]; //e. 77
Kovalev_D 129:406995a91322 312 } Str;
Kovalev_D 129:406995a91322 313 } GyroParam;
Kovalev_D 129:406995a91322 314
Kovalev_D 129:406995a91322 315 extern GyroParam GyroP;
Kovalev_D 28:1c9acd3b224d 316
Kovalev_D 191:40028201ddad 317 extern void AllRegul (void);
Kovalev_D 107:4d178bcc9d8a 318 extern unsigned int amp;
Kovalev_D 122:fbacb932a30b 319 extern int Rate2VibFlag;
igor_v 0:8ad47e2b6f00 320 extern void cheng(void);
igor_v 0:8ad47e2b6f00 321 extern void Noise(void);
igor_v 0:8ad47e2b6f00 322 extern void VibroOut(void);
Kovalev_D 190:289514f730ee 323
Kovalev_D 150:29c9f7671bac 324 extern void VibroAMPRegul(void);
Kovalev_D 150:29c9f7671bac 325 extern void VibroFrqRegul(void);
Kovalev_D 98:95b8e79f13e1 326 extern unsigned int FrecTp;
Kovalev_D 98:95b8e79f13e1 327 extern int Pulse_midl;
igor_v 0:8ad47e2b6f00 328 extern struct VIBRO Vib;
igor_v 0:8ad47e2b6f00 329 extern int PulseHalf;
igor_v 30:17c84ed091b3 330 extern int CuruAngle;
igor_v 0:8ad47e2b6f00 331 extern unsigned int FrecTemp;
igor_v 0:8ad47e2b6f00 332 #endif
igor_v 0:8ad47e2b6f00 333