Python library for communicating with IDM Navigator heat pumps via Modbus TCP. Used by the official Home Assistant integration.
Project description
IDM Heatpump API
Official Python library for communicating with IDM Navigator heat pumps (2.0, Pro, and Navigator 10) over Modbus TCP.
This package is published on PyPI as idm-heatpump and is the core dependency for the Home Assistant integration.
pip install idm-heatpump
Documentation
- GitHub Pages: https://xerolux.github.io/idm-heatpump-api/
- GitHub Wiki: https://github.com/Xerolux/idm-heatpump-api/wiki
- Project Repository: https://github.com/Xerolux/idm-heatpump-api
The docs/ directory is the single source of truth:
- GitHub Pages is deployed automatically from
docs/. - GitHub Wiki is synchronized automatically from
docs/.
Supported Devices (Current Status)
| 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 |
Note: Zone modules on current hardware (including Navigator 10) support 6 rooms per module. Older documentation sometimes mentioned 8; the library defaults to 6 for accuracy.
Requirements
- Modbus TCP must be enabled in the IDM controller (Settings → Building Management → Modbus TCP = On).
- Default port:
502 - Default slave ID:
1
New in Navigator 10 Support
The library now fully covers the official 2025 Navigator 10 Modbus TCP specification, including:
- Heat sink / plate heat exchanger sensors (flow rate in l/min at 1072 — excellent for filter monitoring)
- 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)
Installation
pip install idm-heatpump
Contributing
Please open an issue or pull request for bug reports, improvements, and documentation updates.
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-0.2.1.tar.gz.
File metadata
- Download URL: idm_heatpump-0.2.1.tar.gz
- Upload date:
- Size: 18.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
18bc75c51ab3a40d1cf5575ce6ab3f05b1dcd2e96838317bdc8a5062132360f8
|
|
| MD5 |
b0ba59af391c421d915fe542f00e30a3
|
|
| BLAKE2b-256 |
15cf2a2f7edee9905ad94492ce6adad154de12a364da1aa46659b4cc37c8d7d7
|
File details
Details for the file idm_heatpump-0.2.1-py3-none-any.whl.
File metadata
- Download URL: idm_heatpump-0.2.1-py3-none-any.whl
- Upload date:
- Size: 18.5 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 |
a5707c01a49662fb59268913e7654a665a155b5c51ed82fdf0223036312be371
|
|
| MD5 |
889830c12d5e4be60bbecd5962f48fbc
|
|
| BLAKE2b-256 |
9d081f37bd671041414d5011aa8005348463caadf6760009a4937cd67c520d31
|