Skip to content

philippoo66/optolink-splitter

Repository files navigation

Optolink Switch/Splitter

Make your Viessmann heating locally available via MQTT and TCP/IP while keeping Optolink/ViCare App & more!

System Architecture

Use this software at your own risk.

🎉 Announcements

  • Version 1.3.0.0 is out! Check the changelog for details.
  • Need VS1 / KW protocol support? Use the dedicated branch.
  • Explore other feature branches, there might be something useful for you! 😉

📌 Table of Contents

🚀 Introduction

Key Benefits

  • Local Control and Cloud Capability – Allow full local control and datapoint access while retaining the ability of Viessmann Cloud and App access.
  • Viessmann Heating/Heat Pump Compatibility – Works with Vitodens, Vitocal, Vitocrossal and most other Optolink featured devices.
  • Smart Home Ready – Integrates with Home Assistant, ioBroker, Node-RED or any other system with MQTT Support.
  • Supports VS2 and VS1/KW protocols with different branches.
    • The vs1test branch enables VS1/KW protocol support but works only without Vitoconnect.
    • For VS1/KW with Vitoconnect, the viconn-listener is available (currently in beta).

Videos

🎥 Introduction Video (German): Watch on YouTube

📖 Extended Setup Tutorial (German): Rustimation Blog

📁 Software Requirements

  • Python (version >= 3.9):
    • pyserial: pip install pyserial
    • MQTT (version >= 2.0): pip install paho-mqtt
  • Virtual environments recommended (Guide).

🖥️ Hardware Requirements

  • Raspberry Pi or a suitable system.
  • Viessmann Optolink-compatible heating (Vitodens, Vitocal, Vitocrossal, etc.).
  • Optolink r/w head:
    • Original Viessmann model or self-made.
    • Volkszähler-compatible versions may work if LED distance is adjusted (8€ option).
  • To retain ViCare App functionality, use a USB-to-TTL adapter:
    • Recommended: CP2102 chip (Example).
    • Some newer Vitoconnect models may work with FTDI chips.
    • Raspberry Pi UART voltage = 3.3V → Set jumper accordingly!

🛠️ Installation

1. Clone the Repository

git clone https://github.com/philippoo66/optolink-splitter.git
cd optolink-splitter

2. Create Virtual Environment & Install Dependencies

Using a virtual environment is recommended to keep dependencies isolated and avoid conflicts with system-wide packages. More details can be found in this guide.

2.1. Create & activate the virtual environment:

python3 -m venv myvenv
python3 source myvenv/bin/activate  # On Windows use: myvenv\Scripts\activate

2.2. Install required dependencies:

pip install pyserial
pip install paho-mqtt  # Only if MQTT is used

NOTE: After installation, the environment must be activated before running the script.

3. Configure the Settings

Modify settings_ini.py according to your heating (/ datapoints):

4. Run the Script

python3 source myvenv/bin/activate  # Make sure to activate the virtual environment. On Windows use: venv\Scripts\activate
python3 optolinkvs2_switch.py

For automatic startup, set up a service. See the Wiki Guide.

🔌 Connecting Optolink & Vitoconnect

Parallel use with Vitoconnect / ViCare App

  • Ensure the serial port is enabled and serial console is disabled (Guide).
  • CP2102 Interface:
    • Cross RX/TX lines.
    • Set voltage jumper to 3.3V.
    • Use ttyAMA0 instead of ttyS0 for Raspberry Pi 3+ (Details).

Vitoconnect Interfaces

Vitoconnect 100 OPTO1

To ensure proper communication with the system, follow the power-on sequence exactly:

  1. Connect all wires and plugs to the Raspberry Pi and Vitoconnect.
  2. Power on the Raspberry Pi.
  3. Run the script and wait for the prompt: awaiting VS2....
  4. Power on Vitoconnect 100 OPTO1.

Vitoconnect OPTO2

The startup sequence for this device is not critical, as it will automatically reconnect without issues.

🧾 Command Syntax: MQTT & TCP/IP

Optolink Splitter can connect to an MQTT Broker for sending commands and receiving responses. Alternatively, a direct TCP/IP connection (e.g. using PuTTY) can be established to interact with the application directly. For more details on the command syntax, see the Wiki | Command Syntax Overview or go directly to the section on MQTT and TCP/IP requests.

  • read ambient temperature, scaled with sign:

    • cmnd = read;0x0800;2;0.1;true
    • resp: 1;2048;8.2
  • read DeviceIdent as raw:

    • cmnd = read;0xf8;8
    • resp: 1;248;20CB1FC900000114
  • write hotwater temperature setpoint:

    • cmnd = write;0x6300;1;45
    • resp: 1;25344;45

Important Note for TCP/IP Connections:
When using PuTTY or similar software for a TCP/IP connection, the session must be closed by sending exit as a string, as PuTTY does not appear to send the FIN flag to properly terminate the session when closing.

🏠 Smart Home Integration (e.g. Home Assistant)

Optolink Splitter seamlessly integrates into your smart home setup via MQTT, allowing you to monitor and control your Viessmann heating system using platforms like Home Assistant, ioBroker, or Node-RED. All available heating system data can be visualized in dashboards, automated with custom rules, and integrated into broader smart home routines. With Optolink Splitter’s command-sending capability, you can locally adjust heating modes, temperature setpoints, or pump states directly from your favorite smart home system.

For detailed Home Assistant integration instructions, see the Wiki | Home Assistant Integration of Optolink‐Splitter.

Below are examples of how this integration looks in different smart home environments:

Heating System Overview in Home Assistant (Built with a Picture Entity Card)

grafik

Details

Another Heating System Overview in Home Assistant & Command Buttons

0b87f133-3285-4cb5-871c-87c66598d42d

⁉️ Questions & Issues

🖨️ 3D-Printable Case for Raspberry Pi & USB-TTL Adapter

A compact and practical 3D-printable case designed for Raspberry Pi 2 & 3 including a CP2102 USB-TTL adapter mount. A version for Raspberry Pi 4 may be available in the future. Special thanks to Kristian!

Raspberry Pi 2/3 Case with CP2102 UART Board Holder

📸 Additional Images (MQTT, Visualization)

Datapoints in settings_ini.py & MQTT Explorer monitoring

grafik

Data visualisation

grafik

📝 Disclaimer

This software is not affiliated with, endorsed by, or associated with Viessmann in any way. The terms Vitoconnect, Optolink, Vitocal, ViCare, etc. refer to Viessmann products and technologies. All product and brand names mentioned belong to their respective owners.
It is provided as-is, without any warranties or guarantees. The authors assume no liability for any issues arising from its use.

About

Splitter for Viessmann Optolink connection

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published