python-ogn-client/ogn/parser/aprs_comment/flarm_parser.py

31 wiersze
1.8 KiB
Python
Czysty Zwykły widok Historia

2017-10-05 08:36:53 +00:00
import re
from ogn.parser.pattern import PATTERN_FLARM_POSITION_COMMENT
from ogn.parser.utils import FPM_TO_MS, HPM_TO_DEGS
2017-10-05 08:36:53 +00:00
from .base import BaseParser
class FlarmParser(BaseParser):
def __init__(self):
self.beacon_type = 'flarm'
2019-06-03 19:09:57 +00:00
self.position_pattern = re.compile(PATTERN_FLARM_POSITION_COMMENT)
2017-10-05 08:36:53 +00:00
2019-06-03 19:09:57 +00:00
def parse_position(self, aprs_comment):
ac_match = self.position_pattern.match(aprs_comment)
2017-10-05 08:36:53 +00:00
return {'address_type': int(ac_match.group('details'), 16) & 0b00000011,
'aircraft_type': (int(ac_match.group('details'), 16) & 0b01111100) >> 2,
'stealth': (int(ac_match.group('details'), 16) & 0b10000000) >> 7 == 1,
2018-04-28 11:44:01 +00:00
'address': ac_match.group('address'),
2018-04-30 19:00:08 +00:00
'climb_rate': int(ac_match.group('climb_rate')) * FPM_TO_MS,
'turn_rate': float(ac_match.group('turn_rate')) * HPM_TO_DEGS,
'signal_quality': float(ac_match.group('signal_quality')),
2018-04-20 21:57:51 +00:00
'error_count': int(ac_match.group('error_count')),
'frequency_offset': float(ac_match.group('frequency_offset')),
2018-04-20 21:57:51 +00:00
'gps_quality': {'horizontal': int(ac_match.group('gps_quality_horizontal')),
'vertical': int(ac_match.group('gps_quality_vertical'))} if ac_match.group('gps_quality') else None,
'software_version': float(ac_match.group('software_version')) if ac_match.group('software_version') else None,
'hardware_version': int(ac_match.group('hardware_version'), 16) if ac_match.group('hardware_version') else None,
'real_address': ac_match.group('real_address') if ac_match.group('real_address') else None,
'signal_power': float(ac_match.group('signal_power')) if ac_match.group('signal_power') else None}