stab_param.h 16 KB

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