Skip to main content

Python library to communicate with Studer-Innotec devices on the local network via Xcom protocol

Project description

license buy_me_a_coffee

pystuderxcom

Python library for retrieving sensor information from Studer-Innotec devices. This component connects directly over the local network using the Studer xcom protocol.

The custom component is comfirmed to be compatible with:

  • Xtender XTH 8000-48, XTM 4000
  • Xcom-CAN (BSP connection to a third party BMS)
  • Xcom-LAN (which actually is a Xcom232i with a Moxy NPort 5110A)
  • BMS
  • RCC-03
  • VarioTrack

It should also be able to detect and handle

  • Xtender (any other XTH, XTS and XTM models)
  • VarioString
  • RCC-02

Disclaimer: this library is NOT created by Studer-Innotec, but is based on their documentation of the Xcom protocol. That documentation can be found on: Studer-Innotec Download Center -> Software and Updates -> Communication protocol Xcom-232i

Prerequisites

This library depends on having a Studer Xcom-LAN (i.e. an Xcom-232i and a Moxa ethernet gateway) acting as a Xcom client and connecting to this integration. For older systems this will be a separate component, for future systems Studer have indicated that LAN connection will become part of the Xtender range.

The Studer Xcom-LAN will be able to simultaneously send data to the Studer online portal as well as sending data to this libarary.

Configuration steps:

  1. Download and install the Moxa DSU tool (Device Search Utility)

    • Open www.moxa.com in a browser
    • Select Support -> Software and Documentation
    • Choose NPort 5100A series (or whatever specific device you have)
    • Scroll down under 'Related Software, Firmware and Drivers' to find 'Device Search Utility'
    • Download and install the utility
  2. Locate the Moxa NPort device on the local network

    • Run the Moxa Device Search Utility

    • Press the 'Search' button and wait until the search finishes

    • The utility should display the found NPort device

    • Double click on the found device to open its configuration page

      dsu_search_results

  3. Configure the Moxa NPort device

    • In the Main Menu, select 'Operating Settings' -> Port 1

    • Verify that 'Operation Mode' is set to 'TCP Client' (preferred mode, TCP Server and UDP are also supported)

    • Add the ip-address of your computer as 'Destination IP address'

    • Set Delimeter 1 to '0d' and Enable

    • Set Delimeter 2 to '0a' and Enable

    • Set Delimeter Process to 'Strip Delimeter'

    • Press the 'Submit' button

    • Press 'Save/Restart'

      moxa_operating_settings

Usage

The library is available from PyPi using: pip install pystuderxcom

To read an infos or param or write to a param:

from pystuderxcom import XcomApiTcp, XcomApiTcpMode, XcomDataset, XcomVoltage

dataset = XcomFactory.create_dataset(XcomVoltage.AC240, XcomVoltage.DC48)
info_3023 = dataset.get_by_nr(3023, "xt")  # the "xt" part is optional but usefull for detecting mistakes
info_6001 = dataset.get_by_nr(6001, "bsp")
param_1107 = dataset.get_by_nr(1107, "xt")
dataset = None  # Release memory of the dataset

api = XcomApiTcp(mode=XcomApiTcpMode.SERVER, listen_port=4001)    # port number configured in Xcom-LAN/Moxa NPort
try:
    if not api.start():
        logger.info(f"Did not connect to Xcom")
        return

    # Retrieve info #3023 from the first Xtender (Output power)
    value = api.request_value(info_3023, "XT1")    # xt address range is 101 to 109, or use "XT1" to "XT9"
    logger.info(f"XT1 3023: {value} {info_3023.unit} ({info_3023.name})")

    # Retrieve param #6001 from BSP (Nominal capacity)
    value = api.request_value(info_6001, "BSP")    # bsp address range is only 601, or use "BSP"
    logger.info(f"BSP 6001: {value} {info_6001.unit} ({info_6001.name})")

    # Update param 1107 on the first Xtender (Maximum current of AC source)
    value = 4.0    # 4 Ampere
    if api.update_value(param_1107, value, "XT1"):
        logger.info(f"XT1 1107 updated to {value} {param_1107.unit} ({param_1107.name})")

finally:
    api.stop()

A complete list of param and infos numbers can be found in the source of this library in file src/pystuderxcom/xcom_datapoints_240v.json

A complete list of all available device families and their address range can be found in file src/pystuderxcom/xcom_families.py

Several other coding examples are provided:

Synchronous code Asynchronous code Description
example_api_use.py example_api_use_async.py read & write infos and params
example_api_msg.py example_api_msg_async.py display system messages
example_menu.py example_menu_async.py display menu structure
example_discover_devices.py example_discover_devices_async.py discover local xcom devices
example_discover_moxa.py example_discover_moxa_async.py discover url to moxa web-config

Param writes to device RAM

When the value of a Studer param is changed via this library, these are written via Xcom to the affected device. Changes are stored in the device's RAM memory, not in its flash memory as you can only write to flash a limited number of times over its lifetime.

However, reading back the value from the entity will always be from flash. As a result, the change to the entity value is not visible in the RCC or remote console. You can only tell from the behavior of the PV system that the Studer param was indeed changed.

After a restart/reboot of the PV system the system will revert to the value from Flash. So you may want to periodically repeat the write of changed param values via an automation.

IMPORTANT:

Be very carefull in changing params marked as having level Expert, Installer or even Qualified Service Person. If you do not know what the effect of a Studer param change is, then do not change it.

Credits

Special thanks to the following people for providing the information this library is based on:

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

pystuderxcom-3.4.6.tar.gz (92.7 kB view details)

Uploaded Source

Built Distribution

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

pystuderxcom-3.4.6-py3-none-any.whl (93.5 kB view details)

Uploaded Python 3

File details

Details for the file pystuderxcom-3.4.6.tar.gz.

File metadata

  • Download URL: pystuderxcom-3.4.6.tar.gz
  • Upload date:
  • Size: 92.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pystuderxcom-3.4.6.tar.gz
Algorithm Hash digest
SHA256 6e130327151457e34e8d0f16f6683787e756653495e6bba79d0d90375c909c63
MD5 a6af4e6cb3a087e9c0929c735631166c
BLAKE2b-256 ca45cca4c6a0307b3ac4d8c9b9b043f399c6317feb180d0c504cbfa94dfe317e

See more details on using hashes here.

Provenance

The following attestation bundles were made for pystuderxcom-3.4.6.tar.gz:

Publisher: publish.yml on ankohanse/pystuderxcom

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pystuderxcom-3.4.6-py3-none-any.whl.

File metadata

  • Download URL: pystuderxcom-3.4.6-py3-none-any.whl
  • Upload date:
  • Size: 93.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pystuderxcom-3.4.6-py3-none-any.whl
Algorithm Hash digest
SHA256 9cc9f629feb4cd9deabfcd2c243c4eaa3b32cb0629e2c0da31dd99f735ae94f6
MD5 7970b1bee507cd16a79a7a8f9fcb5c06
BLAKE2b-256 43f10b4e87877dea6fb2eacd435b52e9dc2f05dbdfc59bba4a71934887c51214

See more details on using hashes here.

Provenance

The following attestation bundles were made for pystuderxcom-3.4.6-py3-none-any.whl:

Publisher: publish.yml on ankohanse/pystuderxcom

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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