stab_param.h 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. #ifndef __STAB_PARAM_H__
  2. #define __STAB_PARAM_H__
  3. //================================================================
  4. //===========Настраиваемые параметры==============================
  5. //#define USE_EEPROM
  6. //================================================================
  7. //#define Debug // Раскомментить для дебажения
  8. //#define LED_debug // Раскомментить для вывода на светодиод сигнала управления твердотельным реле
  9. #define INTERFACE_ALT // Раскомментить для включения альтернативного интерфейса с большими символами
  10. #define High_level_triac // Раскомментить, если твердотельное реле ТЭНа управляется ВЫСОКИМ уровнем, иначе НИЗКИМ
  11. #define High_level_relay // Раскомментить, если контактное реле ТЭНа управляется ВЫСОКИМ уровнем, иначе НИЗКИМ
  12. //#define NOT_LM358 // Раскомментить, если в датчике напряжения стоит НЕ LM358, а rail-to-rail операционник
  13. //#define DisplayReset // Раскомментить, если используется вывод сброса дисплея
  14. #define DEBOUNCE 26 // Значение для обеспечения защиты от дребезга кнопок DEBOUNCE=1 + <задержка в ms>/10
  15. //
  16. //#define U_LINE_FREQ_60 // Раскомментить, если частота сети 60Гц, иначе - 50Гц
  17. //
  18. #define U_LINE 230 // Номинальное значение действующего напряжения в сети, для которого указана номинальная мощность ТЭНа
  19. #define U_MIN 180 // Значение напряжения в сети, ниже которого сеть считается аварийной
  20. #define U_LINE_Q 52900 // Квадрат номинала сети, для которого указана номинальная мощность ТЭНа
  21. //
  22. #define MENU_TIMEOUT 120 // Таймаут выхода из меню в секундах (не более 255)
  23. //
  24. //==================================================================
  25. //
  26. #ifdef U_LINE_FREQ_60
  27. #define LINE_FREQ 129 // Определяет начальную частоту для фазовой автоподстройки частоты сети (60,1Гц)
  28. #define PSUM_MAX 60 // Количество периодов для набора отсчетов АЦП (60 - это за 1 сек, это порядка 5000 отсчетов)
  29. #define P_TIME_MAX 120 // Количество полупериодов сети в секунду для отсчета времени
  30. #else
  31. #define LINE_FREQ 155 // Определяет начальную частоту для фазовой автоподстройки частоты сети (50,08Гц)
  32. #define PSUM_MAX 50 // Количество периодов для набора отсчетов АЦП (50 - это за 1 сек, это порядка 5000 отсчетов)
  33. #define P_TIME_MAX 100 // Количество полупериодов сети в секунду для отсчета времени
  34. #endif
  35. //
  36. //=============вход АЦП================
  37. #define pin_VACin 0 // Пин входа измеряемого напряжения (A0)
  38. //
  39. //===========входные выводы============
  40. #define pin_PC_STATE(pin) (~(PINC >> (pin - 14)) & 1) // Запрос состояния вывода со сдвигом и инверсией результата
  41. #define pin_PC_InPullUp(pin) DDRC &=~(1 << (pin - 14)); PORTC |=(1 << (pin - 14)) // Инициализация входа с подтяжкой к VCC
  42. //
  43. #define pin_RAZGON_OFF 17 // Пин входа отключения разгона (A3 - это D17/PC3, при изменении подредактировать следующие два макроса)
  44. #define pin_RAZGON_OFF_INIT pin_PC_InPullUp(pin_RAZGON_OFF) // Определяем вывод отключения разгона, как вход и подтягиваем его внутренним резюком к VCC
  45. #define pin_RAZGON_OFF_STATE pin_PC_STATE(pin_RAZGON_OFF) // Читаем состояние пина и переводим в булев формат с учетом инверсии (активный - низкий)
  46. //
  47. #define pin_STAB_OFF 16 // Пин входа отключения стабилизатора (A2 - это D16/PC2, при изменении подредактировать следующие два макроса)
  48. #define pin_STAB_OFF_INIT pin_PC_InPullUp(pin_STAB_OFF) // Определяем вывод останова стаба, как вход и подтягиваем его внутренним резюком к VCC
  49. #define pin_STAB_OFF_STATE pin_PC_STATE(pin_STAB_OFF) // Читаем состояние пина и переводим в булев формат с учетом инверсии (активный - низкий)
  50. //
  51. //===========вЫходные выводы===========
  52. #define pin_PD_Out(pin) DDRD |=(1 << pin) // Инициализация выхода
  53. #define pin_PD_HIGH(pin) PORTD |=(1 << pin) // Установка выхода
  54. #define pin_PD_LOW(pin) PORTD &=~(1 << pin) // Сброс выхода
  55. #define pin_PD_INV(pin) PORTD ^=(1 << pin) // Инверсия выхода
  56. //
  57. //#define pin_OLEDres 2 // Пин сброса OLED индикатора.
  58. //#define pin_OLEDres_INIT pin_PD_Out(pin_OLEDres)
  59. //#define pin_OLEDres_HIGH pin_PD_HIGH(pin_OLEDres)
  60. //#define pin_OLEDres_LOW pin_PD_LOW(pin_OLEDres)
  61. //
  62. #define pin_TOut 6 // Пин выхода управления ТЭНом (на твердотельное реле)
  63. #define pin_TOut_INIT pin_PD_Out(pin_TOut)
  64. #define pin_TOut_HIGH pin_PD_HIGH(pin_TOut)
  65. #define pin_TOut_LOW pin_PD_LOW(pin_TOut)
  66. //
  67. #define pin_TRelay 7 // Пин выхода управления ТЭНом (на контактное реле в режиме максимальной мощности)
  68. #define pin_TRelay_INIT pin_PD_Out(pin_TRelay)
  69. #define pin_TRelay_HIGH pin_PD_HIGH(pin_TRelay)
  70. #define pin_TRelay_LOW pin_PD_LOW(pin_TRelay)
  71. //
  72. //===========тестовые выводы===========
  73. //#define pin_ZeroOut 5 // Пин выхода импульса ноля (D5 - PD5)
  74. //#define pin_ZeroOut_INIT pin_PD_Out(pin_ZeroOut)
  75. //#define pin_ZeroOut_INV pin_PD_INV(pin_ZeroOut)
  76. //#define pin_ZeroOut_HIGH pin_PD_HIGH(pin_ZeroOut)
  77. //#define pin_ZeroOut_LOW pin_PD_LOW(pin_ZeroOut)
  78. //
  79. //#define pin_DebugOut 7 // Пин для отладки (D7 - PD7)
  80. //#define pin_DebugOut_INIT pin_PD_Out(pin_DebugOut)
  81. //#define pin_DebugOut_INV pin_PD_INV(pin_DebugOut)
  82. //#define pin_DebugOut_HIGH pin_PD_HIGH(pin_DebugOut)
  83. //#define pin_DebugOut_LOW pin_PD_LOW(pin_DebugOut)
  84. //
  85. //#define pin_TestOut 3 // Пин для отладки (D3 - PD3)
  86. //#define pin_TestOut_INIT pin_PD_Out(pin_TestOut)
  87. //#define pin_TestOut_INV pin_PD_INV(pin_TestOut)
  88. //#define pin_TestOut_HIGH pin_PD_HIGH(pin_TestOut)
  89. //#define pin_TestOut_LOW pin_PD_LOW(pin_TestOut)
  90. //
  91. //===========выводы подключения кнопок===========
  92. #define pin_PB_STATE(pin) (~(PINB >> (pin - 8)) & 1) // Запрос состояния вывода со сдвигом и инверсией результата
  93. #define pin_PB_InPullUp(pin) DDRB &=~(1 << (pin - 8)); PORTB |=(1 << (pin - 8)) // Инициализация входа с подтяжкой к VCC
  94. #define pin_PB_OutLOW(pin) DDRB |=(1 << (pin - 8)); PORTB &=~(1 << (pin - 8)) // Инициализация выхода и сброс его
  95. //
  96. #define pin_butt_1 3 // Пин кнопки "Р-". Уменьшение уставки мощности. (D10 - PB2)
  97. #define pin_butt_1_INIT pin_PB_InPullUp(pin_butt_1) // Определяем вывод кнопки, как вход и подтягиваем его внутренним резюком к VCC
  98. #define pin_butt_1_STATE pin_PB_STATE(pin_butt_1) // Читаем состояние пина и переводим в булев формат с учетом инверсии (активный - низкий)
  99. //
  100. #define pin_butt_2 2 // Пин кнопки "Р+". Увеличение уставки мощности. (D9 - PB1)
  101. #define pin_butt_2_INIT pin_PB_InPullUp(pin_butt_2) // Определяем вывод кнопки, как вход и подтягиваем его внутренним резюком к VCC
  102. #define pin_butt_2_STATE pin_PB_STATE(pin_butt_2) // Читаем состояние пина и переводим в булев формат с учетом инверсии (активный - низкий)
  103. //
  104. #define pin_butt_3 5 // Пин кнопки "Стоп". Экстренное отключение ТЭНа. (D12 - PB4)
  105. #define pin_butt_3_INIT pin_PB_InPullUp(pin_butt_3) // Определяем вывод кнопки, как вход и подтягиваем его внутренним резюком к VCC
  106. #define pin_butt_3_STATE pin_PB_STATE(pin_butt_3) // Читаем состояние пина и переводим в булев формат с учетом инверсии (активный - низкий)
  107. //
  108. #define pin_butt_4 4 // Пин кнопки "Разгон". Включение/отключение разгона. (D11 - PB3)
  109. #define pin_butt_4_INIT pin_PB_InPullUp(pin_butt_4) // Определяем вывод кнопки, как вход и подтягиваем его внутренним резюком к VCC
  110. #define pin_butt_4_STATE pin_PB_STATE(pin_butt_4) // Читаем состояние пина и переводим в булев формат с учетом инверсии (активный - низкий)
  111. //
  112. #define pin_buttGND 8 // Пин временного общего провода для подключения кнопок. (D8 - PB0)
  113. #define pin_buttGND_INIT pin_PB_OutLOW(pin_buttGND) // Определяем вывод, как вЫход и устанавливаем низкий уровень
  114. //
  115. //===============бортовой светодиод==============
  116. #define pin_LED 13 // Бортовой светодиод подключен к выводу D13 (PB5)
  117. #define pin_LED_INIT pin_PB_OutLOW(pin_LED) // Определяем вывод, как вЫход и устанавливаем низкий уровень
  118. #define TURN_LED_ON PORTB |=(1 << (pin_LED - 8)) // Включаем светодиод
  119. #define TURN_LED_OFF PORTB &=~(1 << (pin_LED - 8))// Выключаем светодиод
  120. //==============управление релюшками=============
  121. #ifdef High_level_triac // управление твердотельным реле высоким уровнем
  122. #define TURN_SSR_ON pin_TOut_HIGH // Включаем ТЭН
  123. #define TURN_SSR_OFF pin_TOut_LOW // Выключаем ТЭН
  124. #else // управление твердотельным реле низким уровнем
  125. #define TURN_SSR_ON pin_TOut_LOW // Включаем ТЭН
  126. #define TURN_SSR_OFF pin_TOut_HIGH // Выключаем ТЭН
  127. #endif
  128. #ifdef High_level_relay // управление контактным реле высоким уровнем
  129. #define TURN_RELAY_ON pin_TRelay_HIGH // Включаем ТЭН
  130. #define TURN_RELAY_OFF pin_TRelay_LOW // Выключаем ТЭН
  131. #else // управление контактным реле низким уровнем
  132. #define TURN_RELAY_ON pin_TRelay_LOW // Выключаем ТЭН
  133. #define TURN_RELAY_OFF pin_TRelay_HIGH // Включаем ТЭН
  134. #endif
  135. //========коэффициенты для ПИД-регулировки=======
  136. #define Kp 2 // Коэффициент пропорциональности для ПИД-подстройки ФЧ сети (степень двойки для регистрового сдвига)
  137. #define Ki 5 // Интегральный коэффициент для ПИД-подстройки ФЧ сети (степень двойки для регистрового сдвига)
  138. #define Kd 1 // Дифференциальный коэффициент для ПИД-подстройки ФЧ сети (степень двойки для регистрового сдвига)
  139. #define Km 6 // Коэффициент для целочисленной математики (степень двойки для регистрового сдвига)
  140. #define PHASE 8 // сдвиг фаз между детекцией ноля и прерыванием таймера (в тиках таймера)
  141. #define T_MAX 180 // ограничение максимальной длительности полупериода в тиках таймера
  142. #define T_MIN 100 // ограничение минимальной длительности полупериода в тиках таймера
  143. //================прочие константы===============
  144. #define ZSUM_MAX 5000 // Количество отсчетов АЦП без детекции ноля (5000 отсчетов это порядка 1 сек)
  145. #define U_ZERO 512 // Значение нуля АЦП для двуполярного сигнала с постоянной составляющей на выходе ОУ
  146. #define T_ADC 49 // Определяет интервал между запусками АЦП (200 мкс) f_OCn = f_clk / 2*N*(1 + X), где N - коэффициент деления предделителя, X- содержимое регистра OCRnA
  147. #define CICLE 500 // Количество полупериодов в полном цикле регулирования (200 полупериодов - 2сек, 500 полупериодов - 5сек, больше ставить не надо)
  148. #define SRVDATA_ARR_SIZE 14 // Размер блока памяти для вспомогательных данных
  149. #define Pnom_ARR_SIZE 8 // Макс. размер массива записанных номинальных мощностей ТЭНа sizeof(Pnom_arr)/sizeof(Pnom_arr[0])
  150. #define PDMset_ARR_SIZE 6 // Размер массива уставок мощности ТЭНа sizeof(PDMset)/sizeof(PDMset[0]) (ставить не меньше 4)
  151. #if Pnom_ARR_SIZE > PDMset_ARR_SIZE
  152. #define ARRAY_SIZE Pnom_ARR_SIZE // Размер массива для работы с номиналами в начальном меню и уставками
  153. #else
  154. #define ARRAY_SIZE PDMset_ARR_SIZE // Размер массива для работы с номиналами в начальном меню и уставками
  155. #endif
  156. #endif // __STAB_PARAM_H__