//***************************************************************************** // // This is the data acquisition module. It performs acquisition of data from // selected channels, starting and stopping data logging, storing acquired // data, and running the strip chart display. // //***************************************************************************** /* Notes: 12 shared analog input channels 12-bit precision ADC Hardware averaging of up to 64 samples As referred before the ADC has a reference of 3V. Voltage reference selected using the VREF field in the ADCCTL register (page 1217) J0062 PIN 21 - AN_IDS_PRESSENS_7 PIN 9 - GND J0252 PIN 21 - AN_IDS_PRESSENS_1 PIN 9 - GND J0042 PIN 21 - AN_IDS_PRESSENS_3 PIN 9 - GND J0251 PIN 21 - AN_IDS_PRESSENS_4 PIN 9 - GND J0262 PIN 21 - AN_IDS_PRESSENS_6 PIN 9 - GND J0162 PIN 21 - AN_IDS_PRESSENS_5 PIN 9 - GND ----------------- void ADCAcquireInit(void) // (MillisecInit) ok void ADCAcquireStart(ProcessCallback _callback, uint32_t _period)// (called by MillisecStart) //reading Trigger uint32_t ADC_TriggerCollection(void) // MillisecLoop //Data Get void ADC0SS0Handler(void) each ADC there are 4 sequencers with combined sequence steps of 17 (8+4+4+1). Hence out of 24 channels any 17 can be mapped. If all channels are required then both ADC's are required (unless dynamic changes are being sought after). //---------------------------------------------------- uint32_t ADC_GetReading(int DataItemId)// ADC Data get for a single data read Void ADCProcessTask(UArg arg0, UArg arg1) void ADCAcquireStop(void) //MillisecStop //--------------------------------- for (adc_i = 0; adc_i < MAX_ADC_DEVICES ; adc_i++) ADC_Data[adc_i] = ADC_GetReading(adc_i); */ #include "include.h" #include "math.h" #include #include #include #include #include #include #include #include "drivers/I2C_Communication/ADC_MUX/ADC_MUX.h" #include "ADC.h" #include #include //***************************************************************************** // // The following defines which ADC channel control should be used for each // kind of data item. Basically it maps how the ADC channels are connected // on the board. This is a hardware pinmap configuration. // Physical ADC connected channels in the TIVA //***************************************************************************** #define CHAN_AIR_PRESSURE_1 ADC_CTL_CH0 #define CHAN_AIR_PRESSURE_2 ADC_CTL_CH1 #define CHAN_DISPENSE_PRESSURE_1 ADC_CTL_CH2 #define CHAN_DISPENSE_PRESSURE_2 ADC_CTL_CH3 #define CHAN_DISPENSE_PRESSURE_3 ADC_CTL_CH4 #define CHAN_DISPENSE_PRESSURE_4 ADC_CTL_CH5 #define CHAN_DISPENSE_PRESSURE_5 ADC_CTL_CH6 #define CHAN_DISPENSE_PRESSURE_6 ADC_CTL_CH7 #define CHAN_DISPENSE_PRESSURE_7 ADC_CTL_CH8 #define CHAN_DISPENSE_PRESSURE_8 ADC_CTL_CH9 #define CHAN_VOCSENS ADC_CTL_CH10 #define CHAN_SPARE1 ADC_CTL_CH11 #define CHAN_SPARE2 ADC_CTL_CH12 #define CHAN_LEFT_DANCER_1 ADC_CTL_CH13 #define CHAN_LEFT_DANCER_2 ADC_CTL_CH14 #define CHAN_RIGHT_DANCER ADC_CTL_CH15 #define CHAN_DRYER_CURRENT_2 ADC_CTL_CH16 //Dryer Heater 2 #define CHAN_DRYER_CURRENT_1 ADC_CTL_CH17 //Dryer Heater 1 #define CHAN_DRYER_CURRENT_3 ADC_CTL_CH18 #define CHAN_3V3_FPGA ADC_CTL_CH19 /* Connected with pull down to reg GND ADC_CTL_CH20 Connected with pull down to reg GND ADC_CTL_CH21 config as digital input from FPGA 3 ADC_CTL_CH22 config as Digital input from FPGA 3 ADC_CTL_CH23 */ //***************************************************************************** // // The following maps the order that items are acquired and stored by the // ADC sequencers. Note that 16 samples are specified, using 2 of the // 8 sample sequencers. The current is sampled multiple times deliberately // because that value tends to bounce around. It is sampled multiple // times and will be averaged. // //***************************************************************************** uint32_t g_pui32ADCSeq[ADC_MAX_ADC_DEVICES] = { CHAN_AIR_PRESSURE_1, //0 CHAN_AIR_PRESSURE_2, //1 CHAN_DISPENSE_PRESSURE_1, //2 J0252 ,PIN 21 - AN_IDS_PRESSENS_1, PIN 9 - GND CHAN_DISPENSE_PRESSURE_2, //3 J0142 ,PIN 21 - AN_IDS_PRESSENS_2, PIN 9 - GND CHAN_DISPENSE_PRESSURE_3, //4 J0042 ,PIN 21 - AN_IDS_PRESSENS_3, PIN 9 - GND CHAN_DISPENSE_PRESSURE_4, //5 J0152 ,PIN 21 - AN_IDS_PRESSENS_4, PIN 9 - GND CHAN_DISPENSE_PRESSURE_5, //6 J0162 ,PIN 21 - AN_IDS_PRESSENS_5, PIN 9 - GND CHAN_DISPENSE_PRESSURE_6, //7 J0262 ,PIN 21 - AN_IDS_PRESSENS_6, PIN 9 - GND CHAN_DISPENSE_PRESSURE_7, //8 J0062 ,PIN 21 - AN_IDS_PRESSENS_7, PIN 9 - GND CHAN_DISPENSE_PRESSURE_8, //9 J0052 ,PIN 21 - AN_IDS_PRESSENS_8, PIN 9 - GND CHAN_VOCSENS, //10 J0072 ,PIN 21 - AN_VOCSENS, PIN 9 - GND CHAN_SPARE1, //11 CHAN_SPARE2, //12 CHAN_LEFT_DANCER_1, //13 J0002 ,PIN 21 - AN5V_LDANCER1, PIN 9 - GND CHAN_LEFT_DANCER_2, //14 J0002 ,PIN 22 - AN5V_LDANCER1, PIN 10 - GND CHAN_RIGHT_DANCER, //15 J0102 ,PIN 21 - AN5V_RDANCER, PIN 9 - GND CHAN_DRYER_CURRENT_1, //16 J1292 ,PIN 7 - AN_DRYER_CURSEN_1p, PIN 19 - AN_DRYER_CURSEN_1n CHAN_DRYER_CURRENT_2, //17 J1292 ,PIN 8 - AN_DRYER_CURSEN_1p, PIN 20 - AN_DRYER_CURSEN_1n CHAN_DRYER_CURRENT_3, //18 J1292 ,PIN 9 - AN_DRYER_CURSEN_1p, PIN 21 - AN_DRYER_CURSEN_1n CHAN_3V3_FPGA, //19 }; //#define NUM_ADC_CHANNELS (sizeof(g_pui32ADCSeq) / \ sizeof(g_pui32ADCSeq[0])) int DispenserIdToPressureSensorId[MAX_DISPENSERS] = {ADC_DISPENSE_PRESSURE_1, ADC_DISPENSE_PRESSURE_2 , ADC_DISPENSE_PRESSURE_3 , ADC_DISPENSE_PRESSURE_4 , ADC_DISPENSE_PRESSURE_5 , ADC_DISPENSE_PRESSURE_6 , ADC_DISPENSE_PRESSURE_7 , ADC_DISPENSE_PRESSURE_8 }; //const uint8_t Num_ADC_Channels = ( sizeof(g_pui32ADCSeq) / sizeof(g_pui32ADCSeq[0]) ); //#define SAMPLE_ARRAY_SIZE (NUM_ADC_CHANNELS + I2C_NUM_OF_CHANNELS) //#define SAMPLE_ARRAY_SIZE NUM_ADC_CHANNELS static bool isInitialized = false; static bool adcCollectActive = false; static int bufferFlipFlop = 0; //***************************************************************************** // // Global _storage for most recent sampled Sensor Data // //***************************************************************************** // // A buffer to hold one set of ADC data that is acquired per sample time. // //***************************************************************************** static uint32_t g_pui32ADCData[DOUBLE_BUFFER][ADC_MAX_ADC_DEVICES]; //***************************************************************************** //configured in the cfg file and thats why should be defined as extern //***************************************************************************** extern Semaphore_Handle adcResultSem; static ProcessCallback processCallBack; //***************************************************************************** // ADCClockHandle: clock event handler - initiates trigger for the adc sampaling //***************************************************************************** // This function starts an ADC Conversion. //static void ADCClockHandle(UArg arg0) uint32_t ADC_TriggerCollection(void) // (called by MillisecLoop) { // // Kick off the next ADC acquisition. When these are done they will // cause an ADC interrupt. // if (adcCollectActive == true) { MAP_ADCProcessorTrigger(ADC1_BASE, 0); MAP_ADCProcessorTrigger(ADC0_BASE, 0); MAP_ADCProcessorTrigger(ADC0_BASE, 1); } return 0; } //***************************************************************************** // // ADC Data get for a single data read // //***************************************************************************** uint32_t ADC_GetReading(ADC_TYPE DataItemId) // 0 - 19 // ADC Data get for a single data read { int bufnotinuse; assert (DataItemId VADC ---- //ADC 12 bit -> 4096 -> 2.5V temp = VsampleInBits*2.5; VADC = temp / 4096; //---- VADC -> VSensor --- //VADC = 1.96 - 10k( VSensor - 1.96) / 46.4k (from the electrical scheme) // VSensor = 0 V -> VADC = 2.3824 V // VSensor = 10 V -> VADC = 0.2272 V VSensor = (1.96- VADC) * 4.64 + 1.96; if(flow == false) { VPressure_0 = VSensor; return VPressure_0; } else { Pressure = A_offset + B_slope_coefficient * (sqrt(VSensor - VPressure_0)); /`* PKpa = 5 * VSensor; // ---- P[Kpa] -> BAR ---- PBar = PKpa / 100.0; PMicroBar = PBar/1000; Pressure = PMicroBar;*`/ return Pressure; } }*/ uint32_t Read_Dryer_Heaters_Current(HEATERS_CURRENT Heater_ID) // { /* * On Dryer have two heaters , 4*220w and 2*220w that work on 220Vac. Current transformer convert (thru resistor ) the Current of load to Voltage then convert from RMS to DC and connect to A2D pin of Tiva. A2D is 12 bits and his reference is 3.3V (VDDA) or 3V(VREFA+) (depend on s/w). I=A2D bits *K *VREF *N /(4096*R) Where : K= K factor of transformer (less than 1 ) VREF 3 or 3.3v depended of s/w N turns ratio (800 in our case ) Heater_No. Heater_SSR Resistor Power Current AIN# Heater_1 4 SSR_1 50 ohm 880W 8A 17 Heater_2 2 SSR_2 100 ohm 440W 4A 16 * */ uint32_t Status = OK; float temp = 0; float Vref = 3; // External 3V reference using - ADC_REF_EXT_3V float K = 95; //0.95; //See graph in data sheet of CTL-6 float N = 800; //See data sheet of CTL-6 float R; // if (Heaters_Current_Read_Enable[Heater_ID] == false) return ERROR; // Heaters_Current[Heater_ID] switch(Heater_ID) { case HEATER_DRYER_CURRENT_1: temp = ADC_GetReading(ADC_DRYER_CURRENT_1);//ADC_CTL_CH17 R = 50;//50 Ohm //Expected 8A break; case HEATER_DRYER_CURRENT_2: temp = ADC_GetReading(ADC_DRYER_CURRENT_2);//ADC_CTL_CH16 R = 100;//100 Ohm //Expected 4A break; // case DRYER_CURRENT_3: // temp = ADC_GetReading(ADC_DRYER_CURRENT_3);//Not in use // break; default: return ERROR; //break; } Heaters_Current_Bits[Heater_ID] = temp; Heaters_Current[Heater_ID] = (double)((temp * 100 / K * Vref * N) / (4096 * R));// [Amper] // ReportWithPackageFilter(HeatersFilter,"------------Heaters_Current-----------------", __FILE__,__LINE__,Heater_ID, RpMessage, Heaters_Current[Heater_ID]*10000, 0); return Status; } PowerControlFlag Power_Control_Flag; uint8_t Input_Voltage; void CheckAcInputVoltage() { //TODO Change to external Parameters uint8_t High_Voltage_Limit = 237;//for 264V AC - 10% uint8_t Low_Voltage_Limit = 204;//for 185 VAC + 10% //-------------------------------------------------- uint8_t Rt_Heaters_Zone1 = 60; //240||240||240||240 Ohm //uint8_t Rt_Heaters_Zone2 = 120;//240||240 Ohm Read_Heaters_Current(HEATER_DRYER_CURRENT_1); Input_Voltage = Heaters_Current[HEATER_DRYER_CURRENT_1] * Rt_Heaters_Zone1; if( (Input_Voltage) > High_Voltage_Limit ) { Power_Control_Flag = High_Voltage; } else if( (Input_Voltage) < Low_Voltage_Limit ) { Power_Control_Flag = Low_Voltage_Limit; } else { Power_Control_Flag = Normal_Voltage; } }