From 78419f6cc78e67404262de202a01db5f891fa879 Mon Sep 17 00:00:00 2001 From: Jean-Louis Dupond Date: Sun, 16 Feb 2020 09:14:31 +0100 Subject: [PATCH] Improve CRC speed --- dsmr_parser/parsers.py | 28 +++++++++++++++++----------- 1 file changed, 17 insertions(+), 11 deletions(-) diff --git a/dsmr_parser/parsers.py b/dsmr_parser/parsers.py index 4609287..0921dc7 100644 --- a/dsmr_parser/parsers.py +++ b/dsmr_parser/parsers.py @@ -11,6 +11,8 @@ logger = logging.getLogger(__name__) class TelegramParser(object): + crc16_tab = [] + def __init__(self, telegram_specification, apply_checksum_validation=True): """ :param telegram_specification: determines how the telegram is parsed @@ -93,24 +95,28 @@ class TelegramParser(object): @staticmethod def crc16(telegram): - crc16_tab = [] - - for i in range(0, 256): - crc = c_ushort(i).value - for j in range(0, 8): - if (crc & 0x0001): - crc = c_ushort(crc >> 1).value ^ 0xA001 - else: - crc = c_ushort(crc >> 1).value - crc16_tab.append(hex(crc)) + """ + Calculate the CRC16 value for the given telegram + :param str telegram: + """ crcValue = 0x0000 + if len(TelegramParser.crc16_tab) == 0: + for i in range(0, 256): + crc = c_ushort(i).value + for j in range(0, 8): + if (crc & 0x0001): + crc = c_ushort(crc >> 1).value ^ 0xA001 + else: + crc = c_ushort(crc >> 1).value + TelegramParser.crc16_tab.append(hex(crc)) + for c in telegram: d = ord(c) tmp = crcValue ^ d rotated = c_ushort(crcValue >> 8).value - crcValue = rotated ^ int(crc16_tab[(tmp & 0x00ff)], 0) + crcValue = rotated ^ int(TelegramParser.crc16_tab[(tmp & 0x00ff)], 0) return crcValue