123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110 |
- #include "adc.h"
- uint32_t ADC1_Buffer[ADC1_CHANEL_COUNT*ADC1_SAMPLE_COUNT];
- uint32_t ADC2_Buffer[ADC2_CHANEL_COUNT*ADC2_SAMPLE_COUNT];
- uint16_t ADC2_Buffer_Each[ADC2_CHANEL_COUNT][ADC2_SAMPLE_COUNT];
- uint32_t ADC3_Buffer[ADC3_CHANEL_COUNT*ADC3_SAMPLE_COUNT];
- uint16_t ADC3_Buffer_Each[ADC3_CHANEL_COUNT][ADC3_SAMPLE_COUNT];
- uint8_t isDMAEnd_ADC1;
- uint8_t isDMAEnd_ADC2;
- uint8_t isDMAEnd_ADC3;
- struct ADC_VALUE adc_value;
- uint16_t ADCWDGHighThreshold = 3200;
- uint16_t ADCWDGLowThreshold = 820;
- uint8_t is60Hz;
- ADC_HandleTypeDef hadc1;
- ADC_HandleTypeDef hadc2;
- ADC_HandleTypeDef hadc3;
- DMA_HandleTypeDef hdma_adc1;
- DMA_HandleTypeDef hdma_adc2;
- DMA_HandleTypeDef hdma_adc3;
- void MX_ADC1_Init(void)
- {
- ADC_ChannelConfTypeDef sConfig = {0};
-
- hadc1.Instance = ADC1;
- hadc1.Init.ClockPrescaler = ADC_CLOCK_SYNC_PCLK_DIV8;
- hadc1.Init.Resolution = ADC_RESOLUTION_12B;
- hadc1.Init.ScanConvMode = ENABLE;
- hadc1.Init.ContinuousConvMode = ENABLE;
- hadc1.Init.DiscontinuousConvMode = DISABLE;
- hadc1.Init.ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE;
- hadc1.Init.ExternalTrigConv = ADC_SOFTWARE_START;
- hadc1.Init.DataAlign = ADC_DATAALIGN_RIGHT;
- hadc1.Init.NbrOfConversion = 1;
- hadc1.Init.DMAContinuousRequests = ENABLE;
- hadc1.Init.EOCSelection = ADC_EOC_SEQ_CONV;
- if (HAL_ADC_Init(&hadc1) != HAL_OK)
- {
- Error_Handler();
- }
-
- sConfig.Channel = ADC_CHANNEL_4;
- sConfig.Rank = 1;
- sConfig.SamplingTime = ADC_SAMPLETIME_56CYCLES;
- if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
- {
- Error_Handler();
- }
- }
- void MX_ADC2_Init(void)
- {
- ADC_AnalogWDGConfTypeDef AnalogWDGConfig = {0};
- ADC_ChannelConfTypeDef sConfig = {0};
-
- hadc2.Instance = ADC2;
- hadc2.Init.ClockPrescaler = ADC_CLOCK_SYNC_PCLK_DIV8;
- hadc2.Init.Resolution = ADC_RESOLUTION_12B;
- hadc2.Init.ScanConvMode = ENABLE;
- hadc2.Init.ContinuousConvMode = ENABLE;
- hadc2.Init.DiscontinuousConvMode = DISABLE;
- hadc2.Init.ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE;
- hadc2.Init.ExternalTrigConv = ADC_SOFTWARE_START;
- hadc2.Init.DataAlign = ADC_DATAALIGN_RIGHT;
- hadc2.Init.NbrOfConversion = 2;
- hadc2.Init.DMAContinuousRequests = ENABLE;
- hadc2.Init.EOCSelection = ADC_EOC_SEQ_CONV;
- if (HAL_ADC_Init(&hadc2) != HAL_OK)
- {
- Error_Handler();
- }
-
- AnalogWDGConfig.WatchdogMode = ADC_ANALOGWATCHDOG_SINGLE_REG;
- AnalogWDGConfig.HighThreshold = 3722;
- AnalogWDGConfig.LowThreshold = 372;
- AnalogWDGConfig.Channel = ADC_CHANNEL_6;
- AnalogWDGConfig.ITMode = ENABLE;
- if (HAL_ADC_AnalogWDGConfig(&hadc2, &AnalogWDGConfig) != HAL_OK)
- {
- Error_Handler();
- }
-
- sConfig.Channel = ADC_CHANNEL_5;
- sConfig.Rank = 1;
- sConfig.SamplingTime = ADC_SAMPLETIME_480CYCLES;
- if (HAL_ADC_ConfigChannel(&hadc2, &sConfig) != HAL_OK)
- {
- Error_Handler();
- }
-
- sConfig.Channel = ADC_CHANNEL_6;
- sConfig.Rank = 2;
- if (HAL_ADC_ConfigChannel(&hadc2, &sConfig) != HAL_OK)
- {
- Error_Handler();
- }
- }
- void MX_ADC3_Init(void)
- {
- ADC_ChannelConfTypeDef sConfig = {0};
-
- hadc3.Instance = ADC3;
- hadc3.Init.ClockPrescaler = ADC_CLOCK_SYNC_PCLK_DIV8;
- hadc3.Init.Resolution = ADC_RESOLUTION_12B;
- hadc3.Init.ScanConvMode = ENABLE;
- hadc3.Init.ContinuousConvMode = ENABLE;
- hadc3.Init.DiscontinuousConvMode = DISABLE;
- hadc3.Init.ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE;
- hadc3.Init.ExternalTrigConv = ADC_SOFTWARE_START;
- hadc3.Init.DataAlign = ADC_DATAALIGN_RIGHT;
- hadc3.Init.NbrOfConversion = 5;
- hadc3.Init.DMAContinuousRequests = ENABLE;
- hadc3.Init.EOCSelection = ADC_EOC_SEQ_CONV;
- if (HAL_ADC_Init(&hadc3) != HAL_OK)
- {
- Error_Handler();
- }
-
- sConfig.Channel = ADC_CHANNEL_9;
- sConfig.Rank = 1;
- sConfig.SamplingTime = ADC_SAMPLETIME_480CYCLES;
- if (HAL_ADC_ConfigChannel(&hadc3, &sConfig) != HAL_OK)
- {
- Error_Handler();
- }
-
- sConfig.Channel = ADC_CHANNEL_14;
- sConfig.Rank = 2;
- if (HAL_ADC_ConfigChannel(&hadc3, &sConfig) != HAL_OK)
- {
- Error_Handler();
- }
-
- sConfig.Channel = ADC_CHANNEL_15;
- sConfig.Rank = 3;
- if (HAL_ADC_ConfigChannel(&hadc3, &sConfig) != HAL_OK)
- {
- Error_Handler();
- }
-
- sConfig.Channel = ADC_CHANNEL_4;
- sConfig.Rank = 4;
- if (HAL_ADC_ConfigChannel(&hadc3, &sConfig) != HAL_OK)
- {
- Error_Handler();
- }
-
- sConfig.Channel = ADC_CHANNEL_7;
- sConfig.Rank = 5;
- if (HAL_ADC_ConfigChannel(&hadc3, &sConfig) != HAL_OK)
- {
- Error_Handler();
- }
- }
- void HAL_ADC_MspInit(ADC_HandleTypeDef* adcHandle)
- {
- GPIO_InitTypeDef GPIO_InitStruct = {0};
- if(adcHandle->Instance==ADC1)
- {
-
-
-
- __HAL_RCC_ADC1_CLK_ENABLE();
-
- __HAL_RCC_GPIOA_CLK_ENABLE();
-
- GPIO_InitStruct.Pin = ADC1_IN4_CP_Pin;
- GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
- GPIO_InitStruct.Pull = GPIO_NOPULL;
- HAL_GPIO_Init(ADC1_IN4_CP_GPIO_Port, &GPIO_InitStruct);
-
-
- hdma_adc1.Instance = DMA2_Stream0;
- hdma_adc1.Init.Channel = DMA_CHANNEL_0;
- hdma_adc1.Init.Direction = DMA_PERIPH_TO_MEMORY;
- hdma_adc1.Init.PeriphInc = DMA_PINC_DISABLE;
- hdma_adc1.Init.MemInc = DMA_MINC_ENABLE;
- hdma_adc1.Init.PeriphDataAlignment = DMA_PDATAALIGN_WORD;
- hdma_adc1.Init.MemDataAlignment = DMA_MDATAALIGN_WORD;
- hdma_adc1.Init.Mode = DMA_CIRCULAR;
- hdma_adc1.Init.Priority = DMA_PRIORITY_LOW;
- hdma_adc1.Init.FIFOMode = DMA_FIFOMODE_DISABLE;
- if (HAL_DMA_Init(&hdma_adc1) != HAL_OK)
- {
- Error_Handler();
- }
- __HAL_LINKDMA(adcHandle,DMA_Handle,hdma_adc1);
-
- HAL_NVIC_SetPriority(ADC_IRQn, 5, 0);
- HAL_NVIC_EnableIRQ(ADC_IRQn);
-
-
- }
- else if(adcHandle->Instance==ADC2)
- {
-
-
-
- __HAL_RCC_ADC2_CLK_ENABLE();
-
- __HAL_RCC_GPIOA_CLK_ENABLE();
-
- GPIO_InitStruct.Pin = ADC2_IN5_Welding_Pin|ADC2_IN6_GF_Pin;
- GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
- GPIO_InitStruct.Pull = GPIO_NOPULL;
- HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
-
-
- hdma_adc2.Instance = DMA2_Stream3;
- hdma_adc2.Init.Channel = DMA_CHANNEL_1;
- hdma_adc2.Init.Direction = DMA_PERIPH_TO_MEMORY;
- hdma_adc2.Init.PeriphInc = DMA_PINC_DISABLE;
- hdma_adc2.Init.MemInc = DMA_MINC_ENABLE;
- hdma_adc2.Init.PeriphDataAlignment = DMA_PDATAALIGN_WORD;
- hdma_adc2.Init.MemDataAlignment = DMA_MDATAALIGN_WORD;
- hdma_adc2.Init.Mode = DMA_CIRCULAR;
- hdma_adc2.Init.Priority = DMA_PRIORITY_LOW;
- hdma_adc2.Init.FIFOMode = DMA_FIFOMODE_DISABLE;
- if (HAL_DMA_Init(&hdma_adc2) != HAL_OK)
- {
- Error_Handler();
- }
- __HAL_LINKDMA(adcHandle,DMA_Handle,hdma_adc2);
-
- HAL_NVIC_SetPriority(ADC_IRQn, 5, 0);
- HAL_NVIC_EnableIRQ(ADC_IRQn);
-
-
- }
- else if(adcHandle->Instance==ADC3)
- {
-
-
-
- __HAL_RCC_ADC3_CLK_ENABLE();
-
- __HAL_RCC_GPIOF_CLK_ENABLE();
-
- GPIO_InitStruct.Pin = ADC3_IN9_Voltage_L1_Pin|ADC3_IN14_1998_Pin|ADC3_IN15_Temp_Pin|ADC3_IN4_GMI_VL1_Pin
- |ADC3_IN7_Current_L1_Pin;
- GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
- GPIO_InitStruct.Pull = GPIO_NOPULL;
- HAL_GPIO_Init(GPIOF, &GPIO_InitStruct);
-
-
- hdma_adc3.Instance = DMA2_Stream1;
- hdma_adc3.Init.Channel = DMA_CHANNEL_2;
- hdma_adc3.Init.Direction = DMA_PERIPH_TO_MEMORY;
- hdma_adc3.Init.PeriphInc = DMA_PINC_DISABLE;
- hdma_adc3.Init.MemInc = DMA_MINC_ENABLE;
- hdma_adc3.Init.PeriphDataAlignment = DMA_PDATAALIGN_WORD;
- hdma_adc3.Init.MemDataAlignment = DMA_MDATAALIGN_WORD;
- hdma_adc3.Init.Mode = DMA_CIRCULAR;
- hdma_adc3.Init.Priority = DMA_PRIORITY_LOW;
- hdma_adc3.Init.FIFOMode = DMA_FIFOMODE_DISABLE;
- if (HAL_DMA_Init(&hdma_adc3) != HAL_OK)
- {
- Error_Handler();
- }
- __HAL_LINKDMA(adcHandle,DMA_Handle,hdma_adc3);
-
- HAL_NVIC_SetPriority(ADC_IRQn, 5, 0);
- HAL_NVIC_EnableIRQ(ADC_IRQn);
-
-
- }
- }
- void HAL_ADC_MspDeInit(ADC_HandleTypeDef* adcHandle)
- {
- if(adcHandle->Instance==ADC1)
- {
-
-
-
- __HAL_RCC_ADC1_CLK_DISABLE();
-
-
- HAL_GPIO_DeInit(ADC1_IN4_CP_GPIO_Port, ADC1_IN4_CP_Pin);
-
- HAL_DMA_DeInit(adcHandle->DMA_Handle);
-
-
-
-
-
-
-
- }
- else if(adcHandle->Instance==ADC2)
- {
-
-
-
- __HAL_RCC_ADC2_CLK_DISABLE();
-
-
- HAL_GPIO_DeInit(GPIOA, ADC2_IN5_Welding_Pin|ADC2_IN6_GF_Pin);
-
- HAL_DMA_DeInit(adcHandle->DMA_Handle);
-
-
-
-
-
-
-
- }
- else if(adcHandle->Instance==ADC3)
- {
-
-
-
- __HAL_RCC_ADC3_CLK_DISABLE();
-
-
- HAL_GPIO_DeInit(GPIOF, ADC3_IN9_Voltage_L1_Pin|ADC3_IN14_1998_Pin|ADC3_IN15_Temp_Pin|ADC3_IN4_GMI_VL1_Pin
- |ADC3_IN7_Current_L1_Pin);
-
- HAL_DMA_DeInit(adcHandle->DMA_Handle);
-
-
-
-
-
-
-
- }
- }
- void HAL_ADC_ConvCpltCallback(ADC_HandleTypeDef* hadc)
- {
- if(hadc->Instance == ADC1)
- {
- HAL_ADC_Stop_DMA(&hadc1);
- isDMAEnd_ADC1 = ON;
- }
- if(hadc->Instance == ADC2)
- {
- HAL_ADC_Stop_DMA(&hadc2);
- isDMAEnd_ADC2 = ON;
- }
- if(hadc->Instance == ADC3)
- {
- HAL_ADC_Stop_DMA(&hadc3);
- isDMAEnd_ADC3 = ON;
- }
- }
- uint8_t filter_move_avg(MOVE_AVG_FILTER *data, uint32_t value)
- {
- uint8_t result = FAIL;
- uint32_t buf = 0;
- data->buffer[data->idx_put] = value;
- if(++data->idx_put>=LIMIT_MOVE_FILTER)data->idx_put=0;
- for(int idx=0;idx<LIMIT_MOVE_FILTER;idx++)
- {
- buf += data->buffer[idx];
- }
- data->value = buf/LIMIT_MOVE_FILTER;
- return result;
- }
- uint8_t Current_filter_move_avg(MOVE_AVG_FILTER *data, uint32_t value)
- {
- uint8_t result = FAIL;
- uint32_t buf = 0;
- data->buffer[data->idx_put] = value;
- if(++data->idx_put>=CURRENT_LIMIT_MOVE_FILTER)data->idx_put=0;
- for(int idx=0;idx<CURRENT_LIMIT_MOVE_FILTER;idx++)
- {
- buf += data->buffer[idx];
- }
- data->value = buf/CURRENT_LIMIT_MOVE_FILTER;
- return result;
- }
- uint8_t Voltage_filter_move_avg(MOVE_AVG_FILTER *data, uint32_t value)
- {
- uint8_t result = FAIL;
- uint32_t buf = 0;
- data->buffer[data->idx_put] = value;
- if(++data->idx_put>=VOLTAGE_LIMIT_MOVE_FILTER)data->idx_put=0;
- for(int idx=0;idx<VOLTAGE_LIMIT_MOVE_FILTER;idx++)
- {
- buf += data->buffer[idx];
- }
- data->value = buf/VOLTAGE_LIMIT_MOVE_FILTER;
- return result;
- }
- uint16_t cRms_cal(uint16_t *data, uint16_t length)
- {
- float sum = 0;
- float *buffer = (float*)malloc(sizeof(float) * length);
- #ifdef MODIFY_CHECK_MALLOC_RESAULT
- if (buffer == NULL)
- {
- XP("\r\n*** MALLOC [NG] (cRms_cal: %d) ***\r\n\r\n", sizeof(float) * length);
- return HTK_U16_MAX;
- }
- #endif
- uint16_t result = 0;
- uint8_t dirUp = 0;
- uint8_t idx_Cnt = 0;
- uint16_t idx_1st, idx_2nd;
- uint32_t Avg_offset_sum ;
- float Avg_offset ;
- #ifdef MODIFY_FUNC_CRMS_CAL
- for(uint16_t idx=3 ; idx<length ; idx++)
- #else
- for(uint16_t idx=3 ; idx<ADC3_SAMPLE_COUNT ; idx++)
- #endif
- {
- if((data[idx] < 2148) && (data[idx] > 1948) && (dirUp == OFF))
- {
- idx_1st = idx;
- idx_Cnt++;
- dirUp = ON ;
- }
- if((idx-idx_1st)>=69)
- {
- if((data[idx] < 2148) && (data[idx] > 1948))
- {
- idx_2nd = idx;
- idx_Cnt++;
- }
- }
- if(idx_Cnt >= 2)
- break;
- }
- if((idx_1st>=length) || (idx_2nd>=length) || (idx_2nd==0) || (idx_2nd-idx_1st < 69) || (idx_2nd-idx_1st> 90))
- {
- result = adc_value.ADC3_IN7_Current_L1.value;
- }
- else
- {
-
- Avg_offset_sum = 0 ;
- for (uint16_t idx = idx_1st; idx < idx_2nd ; idx++)
- {
- Avg_offset_sum += data [idx] ;
- }
- Avg_offset = (float)(Avg_offset_sum/(idx_2nd-idx_1st))*3.3/4095 ;
- for(uint16_t idx=idx_1st ; idx<idx_2nd ; idx++)
- {
- buffer[idx-idx_1st] = (data[idx]/4095.0*3.3);
- if (buffer[idx-idx_1st] > Avg_offset)
- buffer[idx-idx_1st] = buffer[idx-idx_1st] - Avg_offset ;
- else
- buffer[idx-idx_1st] = Avg_offset - buffer[idx-idx_1st] ;
- buffer[idx-idx_1st] *= 51.1 ;
- sum += pow(buffer[idx-idx_1st],2);
- }
- sum /= (idx_2nd-idx_1st);
- result = (uint16_t) (sqrt(sum)*100);
- }
- free(buffer);
- return result;
- }
- uint16_t GFRms_cal(uint16_t *data, uint16_t length)
- {
- float sum = 0;
- float *buffer = (float*)malloc(sizeof(float) * length);
- #ifdef MODIFY_CHECK_MALLOC_RESAULT
- if (buffer == NULL)
- {
- XP("\r\n*** MALLOC [NG] (GFRms_cal: %d) ***\r\n\r\n", sizeof(float) * length);
- return HTK_U16_MAX;
- }
- #endif
- uint16_t result = 0;
- uint8_t dirUp = 0;
- uint8_t idx_Cnt = 0;
- uint16_t idx_1st, idx_2nd;
- uint32_t Avg_offset_sum ;
- float Avg_offset ;
- #ifdef MODIFY_FUNC_GFRMS_CAL
- for(uint16_t idx=2 ; idx<length ; idx++)
- #else
- for(uint16_t idx=2 ; idx<ADC3_SAMPLE_COUNT ; idx++)
- #endif
- {
- if((data[idx] > data[idx-1]) && (data[idx-1] > data[idx-2]))
- {
- dirUp = ON;
- }
- if(dirUp)
- {
- if((data[idx] < data[idx-1]) && (data[idx-1] < data[idx-2]))
- {
- if(idx_Cnt == 0)
- {
- idx_1st = idx;
- }
- else
- {
- idx_2nd = idx;
- }
- idx_Cnt++;
- dirUp = OFF;
- }
- }
- if(idx_Cnt >= 2)
- break;
- }
- if((idx_1st>=length) || (idx_2nd>=length) || (idx_2nd==0))
- {
- idx_1st = 0;
- idx_2nd = length-1;
- }
- idx_1st = 0;
- idx_2nd = length-1;
-
- Avg_offset_sum = 0 ;
- for (uint16_t idx = idx_1st; idx < idx_2nd ; idx++)
- {
- Avg_offset_sum += data [idx] ;
- }
- Avg_offset = (float)(Avg_offset_sum/(idx_2nd-idx_1st))*3.3/4095 ;
- for(uint16_t idx=idx_1st ; idx<idx_2nd ; idx++)
- {
- buffer[idx-idx_1st] = (data[idx]/4095.0*3.3);
- if (buffer[idx-idx_1st] > Avg_offset)
- buffer[idx-idx_1st] = buffer[idx-idx_1st] - Avg_offset ;
- else
- buffer[idx-idx_1st] = Avg_offset - buffer[idx-idx_1st] ;
- buffer[idx-idx_1st] *= 1000;
- buffer[idx-idx_1st] /= 29.91;
- sum += pow(buffer[idx-idx_1st],2);
- }
- sum /= (idx_2nd-idx_1st);
-
- result = (uint16_t) (sqrt(sum)*100);
-
-
- if (result > 4000)
- {
- DEBUG_INFO("Avg_offset: %f\r\n", Avg_offset);
- DEBUG_INFO("idx_1st: %d\r\n", idx_1st);
- DEBUG_INFO("idx_2nd: %d\r\n", idx_2nd);
- DEBUG_INFO("sum: %f\r\n", sum);
- }
-
- free(buffer);
- return result;
- }
- uint16_t avg_cal(uint16_t *data, uint16_t length)
- {
- uint32_t result = 0;
- for(uint16_t idx=0;idx<length;idx++)
- result += data[idx];
- return (result/length);
- }
- #ifdef FUNC_TEMP_SENSOR_WITH_NEG_VALUE
- int16_t getTemperature(uint16_t adc_raw)
- {
- int16_t rtn = (int16_t)((1526319.45/((363.15* log((8.82353*(adc_raw*3.3/4095)/ (3.3-(adc_raw*3.3/4095)))))+4203))-273.15);
- if (rtn >= -60 && rtn <= 194)
- return rtn;
- else
- return 0;
- }
- #else
- uint16_t getTemperature(uint16_t adc_raw)
- {
-
-
-
-
- if (adc_raw>3438) adc_raw = 3438 ;
- return (uint16_t) ((1526319.45/((363.15* log((8.82353*(adc_raw*3.3/4095)/ (3.3-(adc_raw*3.3/4095)))))+4203))-273.15) ;
- }
- #endif
- uint16_t vRms_cal2(uint16_t *data, uint16_t length)
- {
- float sum = 0;
- float *buffer = (float*)malloc(sizeof(float) * length);
- #ifdef MODIFY_CHECK_MALLOC_RESAULT
- if (buffer == NULL)
- {
- XP("\r\n*** MALLOC [NG] (vRms_cal2: %d) ***\r\n\r\n", sizeof(float) * length);
- return HTK_U16_MAX;
- }
- #endif
- uint16_t result = 0;
- uint8_t dirUp = 0;
- uint8_t idx_Cnt = 0;
- uint16_t idx_1st, idx_2nd;
- uint32_t Avg_offset_sum ;
- float Avg_offset ;
- #ifdef MODIFY_FUNC_VRMS_CAL2
- for(uint16_t idx=3 ; idx<length ; idx++)
- #else
- for(uint16_t idx=3 ; idx<ADC3_SAMPLE_COUNT ; idx++)
- #endif
- {
- if((data[idx] < 2148) && (data[idx] > 1948) && (dirUp == OFF))
- {
- idx_1st = idx;
- idx_Cnt++;
- dirUp = ON ;
- }
- if((idx-idx_1st)>=69)
- {
- if((data[idx] < 2148) && (data[idx] > 1948))
- {
- idx_2nd = idx;
- idx_Cnt++;
- }
- }
- if(idx_Cnt >= 2)
- break;
- }
- if((idx_1st>=length) || (idx_2nd>=length) || (idx_2nd==0) || (idx_2nd-idx_1st < 69) || (idx_2nd-idx_1st> 90))
- {
- result = adc_value.ADC3_IN9_Voltage_L1.value;
- }
- else
- {
-
- ADCWDGHighThreshold = data[idx_1st]-50;
- ADCWDGLowThreshold = data[idx_1st+((idx_2nd-idx_1st)/2)]+50;
- is60Hz = (((idx_2nd-idx_1st)<43)?ON:OFF);
-
- Avg_offset_sum = 0 ;
- for (uint16_t idx = idx_1st; idx < idx_2nd ; idx++)
- {
- Avg_offset_sum += data [idx] ;
- }
- Avg_offset = (float)(Avg_offset_sum/(idx_2nd-idx_1st))*3.3/4095 ;
- for(uint16_t idx=idx_1st ; idx<idx_2nd ; idx++)
- {
- buffer[idx-idx_1st] = (data[idx]/4095.0*3.3);
-
- if (buffer[idx-idx_1st] > Avg_offset)
- buffer[idx-idx_1st] = buffer[idx-idx_1st] - Avg_offset ;
- else
- buffer[idx-idx_1st] = Avg_offset - buffer[idx-idx_1st] ;
- buffer[idx-idx_1st] *= 314.136 ;
- sum += pow(buffer[idx-idx_1st],2);
- }
- sum /= (idx_2nd-idx_1st);
- result = (uint16_t) (sqrt(sum)*100);
- }
- free(buffer);
- return result;
- }
- uint16_t RlyVmax_cal(uint16_t *data, uint16_t length)
- {
- uint16_t result = 0 ;
- uint16_t idx_max_value = 0 ;
- for(uint16_t idx=3 ; idx<ADC2_SAMPLE_COUNT-3 ; idx++)
- {
-
- if((data[idx] < data[idx-1]) && (data[idx] < data[idx-2]) && (data[idx] < data[idx-3]))
- {
- if ( data[idx] > idx_max_value)
- {
- idx_max_value = data[idx] ;
- }
- }
- }
- result = (uint16_t) (idx_max_value*100 *3.3/4095 );
- return result;
- }
- uint16_t avg_v_cal(uint16_t *data, uint16_t length)
- {
- uint16_t result = 0;
- uint32_t idx_max_value = 0 ;
- for(uint16_t idx=0;idx<length;idx++)
- idx_max_value += data[idx];
- result = (uint16_t)(idx_max_value/length*100 *3.3/4095) ;
- return result;
- }
|