analog_in.py 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242
  1. from io_module import IO_Module
  2. from modbus import Modbus
  3. from log_reader import AnalogInputLogReader
  4. import colorama
  5. from colorama import Fore
  6. from time import sleep
  7. from serial import Serial
  8. from mb_registers import AI_REGS
  9. import matplotlib.pyplot as plt
  10. import matplotlib.animation as animation
  11. ai_name = {'AIN_1': 0, 'AIN_2': 1, 'AIN_3': 2, 'AIN_4': 3, 'AIN_5': 4,
  12. 'AIN_6': 5, 'AIN_7': 6, 'AIN_8': 7, 'AIN_9': 8, 'AIN_10': 9,
  13. 'AIN_11': 10, 'AIN_12': 11, 'V_ISO_CL': 12, 'V_ISO': 13,
  14. 'CRNT_LIM_U_BFR_R': 14, 'CRNT_LIM_U_ABFR_R': 15,
  15. 'AIN_FIL_1': 0, 'AIN_FIL_2': 1, 'AIN_FIL_3': 2, 'AIN_FIL_4': 3,
  16. 'AIN_FIL_5': 4, 'AIN_FIL_6': 5, 'AIN_FIL_7': 6, 'AIN_FIL_8': 7,
  17. 'AIN_FIL_9': 8, 'AIN_FIL_10': 9, 'AIN_FIL_11': 10, 'AIN_FIL_12': 11
  18. }
  19. class IO_AnalogInput(IO_Module):
  20. GRAPTH_LEN = 100
  21. def __init__(self, modbus: Modbus):
  22. self.modbus = modbus
  23. super().__init__(self.modbus)
  24. self.log = AnalogInputLogReader(self.modbus)
  25. self.fig = plt.figure(1)
  26. self.input = self.fig.add_subplot(1, 1, 1)
  27. self.input.set_title('input_1')
  28. self.x = [0]
  29. self.data = []
  30. self.graph_input = ai_name['AIN_1']
  31. self.graph_input_func = 0
  32. '''Чтение параметров'''
  33. # Значения состояний входов вкл./выкл. (битовое поле)
  34. def get_inputs_state(self):
  35. data = self.modbus.read_holding_registers(AI_REGS['ain_state'], 1)
  36. return format(data[0], '012b')
  37. # Режим измерения входов (0 - напряжение или 1 - ток. (битовое поле))
  38. def get_inputs_mode(self):
  39. data = self.modbus.read_holding_registers(AI_REGS['ain_mode'], 1)
  40. return format(data[0], '012b')
  41. def get_input_gain(self, input):
  42. data = self.modbus.read_holding_registers(AI_REGS['ain_gain'] + input - 1, 1)
  43. return data[0]
  44. def get_inputs_alarm(self):
  45. data = self.modbus.read_holding_registers(AI_REGS['ain_alarm'], 1)
  46. return format(data[0], '012b')
  47. def get_raw_inputs(self):
  48. data = self.modbus.read_holding_registers(AI_REGS['ain_raw'], 16)
  49. return data
  50. def get_fil_inputs(self):
  51. data = self.modbus.read_holding_registers(AI_REGS['ain_fil'], 12)
  52. return data
  53. '''Установка параметров'''
  54. def set_inputs_state(self, val):
  55. self.modbus.write_holding_register(AI_REGS['ain_state'], val)
  56. def set_inputs_mode(self, val):
  57. self.modbus.write_holding_register(AI_REGS['ain_mode'], val)
  58. def set_input_gain(self, input, value):
  59. # if value not in (1, 2, 4, 8, 16, 32, 64, 128):
  60. # return None
  61. self.modbus.write_holding_register(AI_REGS['ain_gain'] + input - 1, value)
  62. def set_ext_sens_power(self, val):
  63. self.modbus.write_holding_register(AI_REGS['esens_pow'], val)
  64. '''Настройки входов'''
  65. def print_inputs(self):
  66. print(Fore.GREEN + '____________________________________________')
  67. print(Fore.GREEN + 'Analog inputs settings:')
  68. # Значения состояний входов вкл./выкл. (битовое поле)
  69. print('Inputs state [bit field] :', Fore.GREEN + self.get_inputs_state())
  70. # Режим измерения входов напряжение или ток. (битовое поле)
  71. print('Inputs mode [bit field] :', Fore.GREEN + self.get_inputs_mode())
  72. # Коэффициенты усиления
  73. for i in range(1, 13):
  74. print(f'Gain factor channel {i} : ', end='')
  75. print(Fore.GREEN + str(self.get_input_gain(i)))
  76. '''Вывод параметров. Сырые данные 16 входов'''
  77. def print_raw_inputs(self):
  78. data = self.get_raw_inputs()
  79. print(f"[ADC raw] IN_1: {data[0]}, IN_2: {data[1]}, IN_3: {data[2]}, IN_4: {data[3]}")
  80. print(f"[ADC raw] IN_5: {data[4]}, IN_6: {data[5]}, IN_7: {data[6]}, IN_8: {data[7]}")
  81. print(f"[ADC raw] IN_9: {data[8]}, IN_10: {data[9]}, IN_11: {data[10]}, IN_12: {data[11]}")
  82. print(f"[ADC raw] V_ISO_CL: {data[12]}, V_ISO: {data[13]}")
  83. print(f"[ADC raw] CRNT_LIM_U_BFR_R: {data[14]}, CRNT_LIM_U_ABFR_R: {data[15]}")
  84. '''Вывод параметров. Фильтрованные данные 12 входов'''
  85. def print_filtered_inputs(self):
  86. data = self.get_fil_inputs()
  87. print(f"[ADC fil] IN_1: {data[0]}, IN_2: {data[1]}, IN_3: {data[2]}, IN_4: {data[3]}")
  88. print(f"[ADC fil] IN_5: {data[4]}, IN_6: {data[5]}, IN_7: {data[6]}, IN_8: {data[7]}")
  89. print(f"[ADC fil] IN_9: {data[8]}, IN_10: {data[9]}, IN_11: {data[10]}, IN_12: {data[11]}")
  90. '''Вывод данных на график'''
  91. def show_graph(self, func, channel: str):
  92. self.graph_input_func = func
  93. self.graph_input = ai_name[channel]
  94. ani = animation.FuncAnimation(self.fig, self.draw, interval=50)
  95. plt.show()
  96. def show_graph_filtered(self, channel: str):
  97. self.graph_input = ai_name[channel]
  98. def draw(self, i):
  99. data = self.graph_input_func()
  100. self.data.append(data[self.graph_input])
  101. self.input.clear()
  102. self.input.plot(self.x, self.data)
  103. if len(self.data) == self.GRAPTH_LEN:
  104. self.data.pop(0)
  105. self.x.pop(0)
  106. self.x.append(self.x[-1] + 1)
  107. # print(self.in1)
  108. # print(self.x)
  109. def main():
  110. colorama.init(autoreset=True)
  111. serial_port = Serial('COM22', 115200, timeout=0.05, parity='N', xonxoff=False)
  112. modbus_tester = Modbus(serial_port, 1)
  113. # modbus_tester.MB_DEBUG = True
  114. # dev_tester = IO_Digital(modbus_tester)
  115. ai = IO_AnalogInput(modbus_tester)
  116. '''Режим работы аналоговых входов'''
  117. # ai.print_inputs()
  118. '''Установка коэффициентов усиления. Тесты'''
  119. '''
  120. for i in range(1, 13):
  121. ai.set_input_gain(i, i + 20)
  122. '''
  123. '''Установка коэффициентов усиления. Канал, коэффициент'''
  124. # ai.set_input_gain(11, 1)
  125. # for i in range(1000):
  126. # ai.print_inputs()
  127. # sleep(1)
  128. '''Последовательное включение входов по одному.'''
  129. '''
  130. while True:
  131. for i in range(12):
  132. ai.set_inputs_state(1 << i)
  133. print(ai.get_inputs_state())
  134. sleep(1)
  135. '''
  136. '''Настройка режима измерения'''
  137. '''
  138. while True:
  139. for i in range(12):
  140. ai.set_inputs_mode(1 << i)
  141. print(ai.get_inputs_mode())
  142. sleep(1)
  143. '''
  144. # ai.sys.get_system_vars()
  145. # print(ai.get_inputs_state())
  146. # ai.set_inputs_state(0b1111_1111_1111)
  147. # ai.set_inputs_state(0b0000_0000_0000)
  148. # ai.set_inputs_state(0b1111_1111_1111)
  149. # print(ai.get_inputs_state())
  150. # sleep(1)
  151. # ai.set_inputs_state(0b0)
  152. # print(ai.get_inputs_mode())
  153. # ai.set_inputs_mode(0b0000_0000_0000)
  154. # print(ai.get_inputs_mode())
  155. '''Питание внешних датчиков'''
  156. # ai.set_ext_sens_power(0)
  157. '''Аварии аналоговых входов'''
  158. # for i in range(100):
  159. # print(ai.get_inputs_alarm())
  160. # sleep(1)
  161. '''Данные каналов'''
  162. # while True:
  163. # ai.print_raw_inputs()
  164. # ai.print_filtered_inputs()
  165. # sleep(1)
  166. # ai.get_raw_inputs()
  167. # ai.print_raw_inputs()
  168. '''Вывод на график. Сырые данные'''
  169. # ai.show_graph(ai.get_raw_inputs, 'AIN_7')
  170. '''Вывод на график. Фильтрованные данные'''
  171. # ai.show_graph(ai.get_fil_inputs, 'AIN_FIL_12')
  172. '''Системные настройки'''
  173. # ai.sys.get_system_vars()
  174. '''Сохранение настроек'''
  175. ai.sys.save_sattings()
  176. '''Обновление прошивки'''
  177. # serial_port.timeout = 1
  178. # modbus_tester.MB_DEBUG = True
  179. # ai.updater.update('fw.bin', 'MAI_12')
  180. if __name__ == '__main__':
  181. main()