Skip to main content

Python package source for KELLER protocol

Project description

keller-protocol - The KELLER Protocol (Python)

General Pre-requirement:

  • A KELLER device is needed that can communicate with the Serial Port.
  • ...with a USB-COM converter cable (eg.K114 series) AND the needed FTDI driver (https://www.ftdichip.com/Drivers/VCP.htm)
  • ...or directly with a cable of the K-10X series

Installation

pip install keller-protocol
See https://pypi.org/project/keller-protocol/

Usage

See https://keller-druck.com/en/downloads?categories=Software.Communication-Protocols for the Communication Protocol.

  1. Import the Keller Protocol (keller_protocol.py) in your Python Project:
from keller_protocol import keller_protocol as kp
  1. Define Communication settings like port, baud-rate, timeout and echo:
transmitter = kp.KellerProtocol(
    port="COM17", baud_rate=115200, timeout=0.2, echo=True
)
  1. To be able to communicate with the transmitter you will have to use F48 first to initialize. Otherwise, an exception occurs. F48 will return the firmware version. Make sure the device address is correct. (Default 1). If only one transmitter is connected, you can use the "transparent" address 250.
device_address = 1
firmware = transmitter.f48(device_address)
  1. Read out current pressure value from the transmitter. You will receive the pressure value P1 with channel 1.
p1 = transmitter.f73(device_address, 1)

Usage Example with X Line

import keller_protocol.keller_protocol as kp
import time


class XLine:
    def __init__(self, port, baud_rate, address, timeout, echo=True):
        self.bus = kp.KellerProtocol(port, baud_rate, timeout, echo)
        self.address = address
        self.serial_number = None
        self.f73_channels = {
            "CH0": 0,
            "P1": 1,
            "P2": 2,
            "T": 3,
            "TOB1": 4,
            "TOB2": 5,
            "ConTc": 10,
            "ConRaw": 11,
        }
        self.init_f48()

    def init_f48(self) -> str:
        """Initialise and release"""
        answer = self.bus.f48(self.address)
        print(f" Init of Device Address: {self.address} with Firmware: {answer}")

    def get_serial(self) -> int:
        """Get Serial Number from X-Line

        :returns Serial Number
        """
        self.serial_number = self.bus.f69(self.address)
        return self.serial_number

    def get_address(self) -> int:
        return self.address

    def set_address(self, new_address: int) -> int:
        """Change the Device address. -> Has to be unique on the RS485 bus

        :param new_address: New address of the Device
        :return: If successful return new_address otherwise old address and throw exception
        """
        self.address = self.bus.f66(self.address, new_address)
        return self.address

    def measure_tob1(self) -> float:
        """Get temperature TOB1

        :return: temperature
        """
        temperature = self.bus.f73(self.address, self.f73_channels["TOB1"])
        return temperature

    def measure_p1(self) -> float:
        """Get pressure P1

        :return: pressure
        """
        pressure = self.bus.f73(self.address, self.f73_channels["P1"])
        return pressure


if __name__ == "__main__":
    # Example usage:
    # Init transmitter
    transmitter = XLine(
        port="COM17", baud_rate=115200, address=2, timeout=0.2, echo=True
    )
    serial_number = transmitter.get_serial()
    print(f"Transmitter serial number:{serial_number}")
    print("Press CTRL + C to quit")
    while True:
        try:
            p1 = transmitter.measure_p1()
            tob1 = transmitter.measure_tob1()
            print(f"Pressure P1:{p1:.3f} Temperature TOB1:{tob1:.3f}")
            time.sleep(1)
        except KeyboardInterrupt:
            print("Quit!")
            break

Code style: black Upload Python Package License: MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

keller_protocol-1.0.20.tar.gz (7.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

keller_protocol-1.0.20-py3-none-any.whl (8.2 kB view details)

Uploaded Python 3

File details

Details for the file keller_protocol-1.0.20.tar.gz.

File metadata

  • Download URL: keller_protocol-1.0.20.tar.gz
  • Upload date:
  • Size: 7.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.17

File hashes

Hashes for keller_protocol-1.0.20.tar.gz
Algorithm Hash digest
SHA256 29464b08ad7b35463a0531abfb1c64607f5865bfcf92d8fec3d2ab7d37f3fbe7
MD5 4549fe5627da16410c2d91cc167a5874
BLAKE2b-256 4b729723ec9402577e11e8b74c5942adda77b824423f412484b7d74b2796248c

See more details on using hashes here.

File details

Details for the file keller_protocol-1.0.20-py3-none-any.whl.

File metadata

File hashes

Hashes for keller_protocol-1.0.20-py3-none-any.whl
Algorithm Hash digest
SHA256 c15106a5d1628c3c83ea20c9ae9c3496c9f1a3b880c75f2fc8a84f50d2d9ef92
MD5 d7be530f3c58f934087ec3541e74ff81
BLAKE2b-256 48c133417a098cd11bae103ea038531a07b30d25faa4c6bf248eb68875459e38

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page