Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- /**
- ******************************************************************************
- * @file : main.c
- * @brief : Main program body
- ******************************************************************************
- ** This notice applies to any and all portions of this file
- * that are not between comment pairs USER CODE BEGIN and
- * USER CODE END. Other portions of this file, whether
- * inserted by the user or by software development tools
- * are owned by their respective copyright owners.
- *
- * COPYRIGHT(c) 2018 STMicroelectronics
- *
- * Redistribution and use in source and binary forms, with or without modification,
- * are permitted provided that the following conditions are met:
- * 1. Redistributions of source code must retain the above copyright notice,
- * this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above copyright notice,
- * this list of conditions and the following disclaimer in the documentation
- * and/or other materials provided with the distribution.
- * 3. Neither the name of STMicroelectronics nor the names of its contributors
- * may be used to endorse or promote products derived from this software
- * without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
- * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
- * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
- * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
- * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
- * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
- * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
- * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
- * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- *
- ******************************************************************************
- */
- /* Includes ------------------------------------------------------------------*/
- #include "main.h"
- #include "stm32f4xx_hal.h"
- /* USER CODE BEGIN Includes */
- #include "math.h"
- /* USER CODE END Includes */
- /* Private variables ---------------------------------------------------------*/
- ADC_HandleTypeDef hadc1;
- UART_HandleTypeDef huart2;
- /* USER CODE BEGIN PV */
- /* Private variables ---------------------------------------------------------*/
- // Atramine 3,3V. Max reiksme 4095
- // Tuomet 1mV atitinka:
- #define LSB 3300/4095
- // Polinomu kiekis.
- #define J_Kiekis 5
- #define K_Kiekis 5
- // Para valandomis
- #define para_valandomis 72
- // Cia ADC kvantai
- uint32_t g_ADCValue;
- uint32_t offset=2;
- // Polinomu koeficientai
- const double coef_J[J_Kiekis][3]={
- {-2.157, 3.5834, -36.24},
- {-0.3979, 19.528, -0.176},
- {-0.1505, 19.729, 0.0175},
- {0.0002, 18.068, 5.095},
- {-0.0814, 22.466, -54.51}
- };
- const double coef_K[K_Kiekis][3]={
- {-7.4218, -29.137, -113.71},
- {-1.3281, 22.835, -2.0492},
- {-0.1942, 25.208, -0.1319},
- {-0.0648, 25.822, -5.7738},
- {0.0282, 22.15, 30.866}
- };
- // Temperaturu ribos, apspresti kuri polinoma pasirinkti. Nuo, iki.
- const double TempJ_intervalai[J_Kiekis][2]={
- {-7.890, -2.893},
- {-2.893, 0},
- {0, 5.269},
- {5.269, 28.516},
- {28.516, 39.132}
- };
- const double TempK_intervalai[K_Kiekis][2]={
- {-5.891, -4.138},
- {-3.554, -1.527},
- {-0.778, 4.096},
- {4.92, 20.644},
- {21.497, 29.129}
- };
- // Apskaiciuojamos itampos kintamieji
- float Itampa;
- float Itampa_J_Potenciometru;
- float Itampa_K_Potenciometru;
- float tempK;
- float tempJ;
- // Visos temperaturos per 3 paras (72 valandas).
- float temperaturos[para_valandomis];
- int temperaturos_n = 0; // Siuo metu skaitomas atskaitos taskas
- float temperaturu_suma = 0;
- float temperaturu_vidurkis = 0;
- // Laikmaciai
- uint16_t tt; //UART laikmatis, nustatome kas kiek laiko issiuncia zinute
- uint16_t tt1; // Kas kiek laiko temp. reiksme imam. Siuo momentu kas 200ms
- uint32_t tt2; // Sitas laikmatis isjungtas. Cia yra laikmatis pagal kuri temp. reiksme imama kas 1 val.
- // UART stringas, kuri siunciam
- char m[30];
- // Flag'ai
- int uzsipilde_tmasyvas=0; // Jeigu temperaturu masyvas uzsipilde
- int sild_on; // Sildymas ijungtas, isjungtas.
- uint8_t TXFLAG, Ready, Ready1;
- /* USER CODE END PV */
- /* Private function prototypes -----------------------------------------------*/
- void SystemClock_Config(void);
- static void MX_GPIO_Init(void);
- static void MX_ADC1_Init(void);
- static void MX_USART2_UART_Init(void);
- /* USER CODE BEGIN PFP */
- /* Private function prototypes -----------------------------------------------*/
- double power_J(double input, int pol_funkcija) {
- double temp=0;
- temp = coef_J[pol_funkcija][0]*pow(input,2)+coef_J[pol_funkcija][1]*input+coef_J[pol_funkcija][2];
- return temp;
- }
- double power_K(double input, int pol_funkcija) {
- double temp=0;
- temp = coef_K[pol_funkcija][0]*pow(input,2)+coef_K[pol_funkcija][1]*input+coef_K[pol_funkcija][2];
- return temp;
- }
- double TempJ(double input) {
- double temp=0;
- for(int i=0;i<J_Kiekis;i++) {
- if(input>=TempJ_intervalai[i][0] && input<=TempJ_intervalai[i][1]) {
- temp = power_J(input, i);
- }
- }
- return temp;
- }
- double TempK(double input) {
- double temp=0;
- for(int i=0;i<K_Kiekis;i++) {
- if(input>=TempK_intervalai[i][0] && input<=TempK_intervalai[i][1]) {
- temp = power_K(input, i);
- }
- }
- return temp;
- }
- /* USER CODE END PFP */
- /* USER CODE BEGIN 0 */
- void HAL_UART_TxCpltCallback(UART_HandleTypeDef *huart)
- {
- TXFLAG=0;
- }
- /* USER CODE END 0 */
- /**
- * @brief The application entry point.
- *
- * @retval None
- */
- int main(void)
- {
- /* USER CODE BEGIN 1 */
- /* USER CODE END 1 */
- /* MCU Configuration----------------------------------------------------------*/
- /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
- HAL_Init();
- /* USER CODE BEGIN Init */
- /* USER CODE END Init */
- /* Configure the system clock */
- SystemClock_Config();
- /* USER CODE BEGIN SysInit */
- /* USER CODE END SysInit */
- /* Initialize all configured peripherals */
- MX_GPIO_Init();
- MX_ADC1_Init();
- MX_USART2_UART_Init();
- /* USER CODE BEGIN 2 */
- // Nunulinam temperaturos masyva
- for (int i = 0; i < para_valandomis; i++) {
- temperaturos[i] = 0;
- }
- /* USER CODE END 2 */
- /* Infinite loop */
- /* USER CODE BEGIN WHILE */
- while (1)
- {
- HAL_ADC_Start(&hadc1);
- if(HAL_ADC_PollForConversion(&hadc1, 100)== HAL_OK) {
- // Nuimam offseta
- g_ADCValue = HAL_ADC_GetValue(&hadc1);
- // Paverciame ADC kvantus i itampa
- Itampa = (float) g_ADCValue * LSB;
- //Itampa_tikra=Itampa/189.789; //J termoporai
- // Potenciometrais
- Itampa_J_Potenciometru=(((TempJ_intervalai[J_Kiekis-1][1]-TempJ_intervalai[0][0])/3300)*Itampa)+TempJ_intervalai[0][0];
- Itampa_K_Potenciometru=(((TempK_intervalai[K_Kiekis-1][1]-TempK_intervalai[0][0])/3300)*Itampa)+TempK_intervalai[0][0];
- // Paverciam i temperatura
- tempK = TempK(Itampa_K_Potenciometru);
- tempJ = TempJ(Itampa_J_Potenciometru);
- if(Ready1==1) {
- // Atimama seniausia reiksme. (sitas galioja tik tuo atveju, kai masyvas jau yra pilnai uzsipildes)
- temperaturu_suma = temperaturu_suma - temperaturos[temperaturos_n];
- // Irasome temperatura i masyva
- temperaturos[temperaturos_n] = tempJ;
- // Sumuojame temperaturas
- temperaturu_suma = temperaturu_suma + temperaturos[temperaturos_n];
- // Prie temperaturos atskaitos n, pridedame +1.
- temperaturos_n = temperaturos_n + 1;
- // Jeigu pasiekem temperaturos masyvo pabaiga
- if (temperaturos_n >= para_valandomis) {
- // Nustatome temperaturos atskaitos n i pradzia.
- temperaturos_n= 0;
- // Ijungiame flag, jog masyvas uzsipilde.
- uzsipilde_tmasyvas=1;
- }
- // Jeigu masyvas yra uzsipildes. Yra 72 reiksmes jame.
- if(uzsipilde_tmasyvas==1){
- temperaturu_vidurkis = temperaturu_suma / para_valandomis;
- }
- // Jeigu masyvas dar nespejo uzsipildyti
- else {
- // Dalyba is 0 negalima
- if(temperaturos_n==0) {
- temperaturu_vidurkis = temperaturu_suma;
- }
- // Daliname is tiek reiksmiu, kiek yra masyve
- else {
- temperaturu_vidurkis = temperaturu_suma / temperaturos_n;
- }
- }
- Ready1=0;
- if(temperaturu_vidurkis<10){
- //GPIOB->BSRR=GPIO_PIN_12; // Isvedam 1 i Pin'a
- sild_on=1;
- } else {
- // GPIOB->BRR=GPIO_PIN_12; // Isvedam 0 i Pin'a
- sild_on=0;
- }
- }
- if((Ready==1)&&(TXFLAG==0)){
- if(sild_on==1){
- sprintf(m,"Temperatura=%5.4f, vidurkis=%5.4f,SILDYMAS IJUNGTAS\n\r",tempJ, temperaturu_vidurkis); // convert to string
- }
- else{
- sprintf(m,"Temperatura=%5.4f, vidurkis=%5.4f,NESILDO \n\r",tempJ, temperaturu_vidurkis); // convert to string
- }
- HAL_UART_Transmit_IT(&huart1, (uint8_t*)m, 100);
- Ready=0;
- TXFLAG=1;
- }
- }
- /* USER CODE END WHILE */
- /* USER CODE BEGIN 3 */
- }
- /* USER CODE END 3 */
- }
- /**
- * @brief System Clock Configuration
- * @retval None
- */
- void SystemClock_Config(void)
- {
- RCC_OscInitTypeDef RCC_OscInitStruct;
- RCC_ClkInitTypeDef RCC_ClkInitStruct;
- /**Configure the main internal regulator output voltage
- */
- __HAL_RCC_PWR_CLK_ENABLE();
- __HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE1);
- /**Initializes the CPU, AHB and APB busses clocks
- */
- RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI;
- RCC_OscInitStruct.HSIState = RCC_HSI_ON;
- RCC_OscInitStruct.HSICalibrationValue = 16;
- RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
- RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSI;
- RCC_OscInitStruct.PLL.PLLM = 8;
- RCC_OscInitStruct.PLL.PLLN = 50;
- RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV4;
- RCC_OscInitStruct.PLL.PLLQ = 7;
- if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
- {
- _Error_Handler(__FILE__, __LINE__);
- }
- /**Initializes the CPU, AHB and APB busses clocks
- */
- RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
- |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
- RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
- RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
- RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV8;
- RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV4;
- if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_0) != HAL_OK)
- {
- _Error_Handler(__FILE__, __LINE__);
- }
- /**Configure the Systick interrupt time
- */
- HAL_SYSTICK_Config(HAL_RCC_GetHCLKFreq()/1000);
- /**Configure the Systick
- */
- HAL_SYSTICK_CLKSourceConfig(SYSTICK_CLKSOURCE_HCLK);
- /* SysTick_IRQn interrupt configuration */
- HAL_NVIC_SetPriority(SysTick_IRQn, 0, 0);
- }
- /* ADC1 init function */
- static void MX_ADC1_Init(void)
- {
- ADC_ChannelConfTypeDef sConfig;
- /**Configure the global features of the ADC (Clock, Resolution, Data Alignment and number of conversion)
- */
- hadc1.Instance = ADC1;
- hadc1.Init.ClockPrescaler = ADC_CLOCK_SYNC_PCLK_DIV2;
- hadc1.Init.Resolution = ADC_RESOLUTION_12B;
- hadc1.Init.ScanConvMode = DISABLE;
- hadc1.Init.ContinuousConvMode = DISABLE;
- 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 = DISABLE;
- hadc1.Init.EOCSelection = ADC_EOC_SINGLE_CONV;
- if (HAL_ADC_Init(&hadc1) != HAL_OK)
- {
- _Error_Handler(__FILE__, __LINE__);
- }
- /**Configure for the selected ADC regular channel its corresponding rank in the sequencer and its sample time.
- */
- sConfig.Channel = ADC_CHANNEL_0;
- sConfig.Rank = 1;
- sConfig.SamplingTime = ADC_SAMPLETIME_15CYCLES;
- if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
- {
- _Error_Handler(__FILE__, __LINE__);
- }
- }
- /* USART2 init function */
- static void MX_USART2_UART_Init(void)
- {
- huart2.Instance = USART2;
- huart2.Init.BaudRate = 9600;
- huart2.Init.WordLength = UART_WORDLENGTH_8B;
- huart2.Init.StopBits = UART_STOPBITS_1;
- huart2.Init.Parity = UART_PARITY_NONE;
- huart2.Init.Mode = UART_MODE_TX_RX;
- huart2.Init.HwFlowCtl = UART_HWCONTROL_NONE;
- huart2.Init.OverSampling = UART_OVERSAMPLING_16;
- if (HAL_UART_Init(&huart2) != HAL_OK)
- {
- _Error_Handler(__FILE__, __LINE__);
- }
- }
- /** Pinout Configuration
- */
- static void MX_GPIO_Init(void)
- {
- /* GPIO Ports Clock Enable */
- __HAL_RCC_GPIOA_CLK_ENABLE();
- }
- /* USER CODE BEGIN 4 */
- /* USER CODE END 4 */
- /**
- * @brief This function is executed in case of error occurrence.
- * @param file: The file name as string.
- * @param line: The line in file as a number.
- * @retval None
- */
- void _Error_Handler(char *file, int line)
- {
- /* USER CODE BEGIN Error_Handler_Debug */
- /* User can add his own implementation to report the HAL error return state */
- while(1)
- {
- }
- /* USER CODE END Error_Handler_Debug */
- }
- #ifdef USE_FULL_ASSERT
- /**
- * @brief Reports the name of the source file and the source line number
- * where the assert_param error has occurred.
- * @param file: pointer to the source file name
- * @param line: assert_param error line source number
- * @retval None
- */
- void assert_failed(uint8_t* file, uint32_t line)
- {
- /* USER CODE BEGIN 6 */
- /* User can add his own implementation to report the file name and line number,
- tex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */
- /* USER CODE END 6 */
- }
- #endif /* USE_FULL_ASSERT */
- /**
- * @}
- */
- /**
- * @}
- */
- /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement