Python library for communicating with IDM Navigator heat pumps via Modbus TCP. Used by the official Home Assistant integration.
Project description
IDM Heatpump API
An asynchronous Python library for communicating with IDM Navigator heat pumps (2.0, Pro, and Navigator 10) over Modbus TCP.
This library is primarily designed to power the official IDM Heatpump Home Assistant Integration, but it can be used independently for any Python project that needs to monitor or control an IDM heat pump.
Documentation:
- GitHub Pages: https://xerolux.github.io/idm-heatpump-api/
- GitHub Wiki: https://github.com/Xerolux/idm-heatpump-api/wiki
- PyPI: https://pypi.org/project/idm-heatpump-api/
The
docs/directory is the single source of truth and is used for both GitHub Pages and Wiki sync.
Features
- Asynchronous: Fully async operations using
pymodbuswith automatic reconnection. - Auto-Detection: Probes registers to detect the controller model, active heating circuits, zone modules, solar, ISC, PV, and cascade.
- Comprehensive Register Map: 100+ registers covering temperatures, energy, status, heating circuits (A-G), zone modules, solar, ISC, cascade, boosters, and more.
- Batch Reads: Intelligent grouping and batching of register reads for maximum efficiency.
- Resilient: Configurable retries with exponential backoff and permanent failure tracking for unavailable registers.
- Write Support: Safe register writes with validation, min/max bounds, and EEPROM-sensitive write protection.
- Metadata: Each register includes
binary,state_class,icon,enabled_by_default,write_only, andexclude_from_writemetadata for direct Home Assistant entity mapping.
Supported Devices
| Device | Firmware | Heating Circuits | Zone Modules | Status |
|---|---|---|---|---|
| IDM Navigator 10 | NAV10_20.23+ (2025) | up to 7 (A-G) | up to 10 (6 rooms each) | Confirmed |
| IDM Navigator 2.0 | all versions | up to 7 (A-G) | no | Confirmed |
| IDM Navigator Pro | all versions | up to 7 (A-G) | up to 10 (6 rooms each) | Confirmed |
Requirements
- Modbus TCP must be enabled on the IDM controller (Settings -> Building Management -> Modbus TCP = On).
- Default port:
502 - Default slave ID:
1 - Python 3.12+
Installation
pip install idm-heatpump-api
Basic Usage
import asyncio
from idm_heatpump import IdmModbusClient, build_register_map
async def main():
client = IdmModbusClient(host="192.168.1.100", port=502, slave_id=1)
try:
await client.connect()
# Auto-detect model and capabilities
model_info = await client.detect_model()
print(f"Detected: {model_info.model_name}")
print(f"Circuits: {model_info.active_heating_circuits}")
print(f"Solar: {model_info.has_solar}, ISC: {model_info.has_isc}")
# Build register map based on detected model
registers = build_register_map(model_info=model_info)
# Read all registers in efficient batches
values = await client.read_batch(list(registers.values()))
for name, value in sorted(values.items()):
reg = registers[name]
unit = f" {reg.unit}" if reg.unit else ""
print(f" {name}: {value}{unit}")
# Write a register (e.g. set DHW target temperature)
if "dhw_setpoint" in registers:
await client.write_register(registers["dhw_setpoint"], 48)
finally:
await client.disconnect()
if __name__ == "__main__":
asyncio.run(main())
Advanced Usage
The library provides fine-grained control for advanced scenarios:
build_register_map(circuits=["A", "B"], zone_modules=2, rooms_per_zone=4): Manual register map without auto-detection.get_heating_circuit_registers("A"): Registers for a single heating circuit.get_zone_module_registers(zone_index=1, room_count=6): Registers for a single zone module.client.probe_register(address=1850, count=2): Probe a single register without affecting failure tracking.client.reset_failed_registers(): Retry permanently failed registers.
Register metadata for HA integration mapping:
reg = registers["compressor_status_1"]
print(reg.binary) # True -> BinarySensor
print(reg.writable) # False
print(reg.write_only) # False
print(reg.enabled_by_default) # True
print(reg.state_class) # None (or "measurement", "total_increasing")
print(reg.icon) # None (or "mdi:thermometer")
print(reg.exclude_from_write) # None (or {255})
Navigator 10 Support
The library fully covers the official 2025 Navigator 10 Modbus TCP specification, including:
- Heat sink / plate heat exchanger sensors (flow rate in l/min at 1072)
- Power limitation registers (4108 / 4112) for demand response / peak shaving
- Complete Booster A + B (second heat generator) monitoring
- Additional source pump faults and external pump demand control
- Groundwater temperatures and more cascade bivalence points
- All zone module rooms (6 rooms per module on current hardware)
- PV / energy management, solar thermal, and ISC (Intelligent Surface Cooling)
- Cascade temperatures and bivalence points
Contributing
Please open an issue or pull request for bug reports, improvements, and documentation updates.
License
MIT License — see LICENSE.
Support
This library is developed in my spare time. If you find it useful, consider supporting:
- Star the repository on GitHub
- Report bugs
- Share with other IDM heat pump owners
Disclaimer
This project is an unofficial community project and is not affiliated with, endorsed by, or connected to IDM Energiesysteme GmbH.
All trademarks, logos, and product names (e.g., "IDM", "Navigator") are property of their respective owners. The logos and images used are solely for identifying the compatible device and are not used commercially.
This project is provided without any warranty. Use at your own risk — especially when writing Modbus registers.
IDM Energiesysteme GmbH has neither authorized nor endorsed this project.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file idm_heatpump_api-0.3.0.tar.gz.
File metadata
- Download URL: idm_heatpump_api-0.3.0.tar.gz
- Upload date:
- Size: 22.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
426e00556a1ac096a0c1bb28d3db6d8ee145de3167865e891c154c6c359aa090
|
|
| MD5 |
706cbd1813e330c773b6b91b3f06561a
|
|
| BLAKE2b-256 |
afa9b15ca773a7be04f974f86f5aa2d9de147a1277ffa2e319e9a07c0ba278db
|
File details
Details for the file idm_heatpump_api-0.3.0-py3-none-any.whl.
File metadata
- Download URL: idm_heatpump_api-0.3.0-py3-none-any.whl
- Upload date:
- Size: 20.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0d3861bcf763e3371d3036ac9dc1baae46a97ebbdaa9860f8e00e58b359a911f
|
|
| MD5 |
785188755774b634e53711de2645f12d
|
|
| BLAKE2b-256 |
843220e2ac2baf8e418839e9d3e9df2dcae8daf6b95e68f332a0f7b00207c1b3
|