Skip to main content

Python library for communicating with IDM Navigator heat pumps via Modbus TCP. Used by the official Home Assistant integration.

Project description

IDM Heatpump API

PyPI version PyPI downloads Python versions License: MIT

GitHub Sponsors Ko-Fi Buy Me A Coffee PayPal Tesla Referral

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:

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 pymodbus with 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, and exclude_from_write metadata 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:

GitHub Sponsors Ko-Fi Buy Me A Coffee PayPal Tesla Referral

  • 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


Download files

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

Source Distribution

idm_heatpump_api-0.3.0.tar.gz (22.8 kB view details)

Uploaded Source

Built Distribution

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

idm_heatpump_api-0.3.0-py3-none-any.whl (20.8 kB view details)

Uploaded Python 3

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

Hashes for idm_heatpump_api-0.3.0.tar.gz
Algorithm Hash digest
SHA256 426e00556a1ac096a0c1bb28d3db6d8ee145de3167865e891c154c6c359aa090
MD5 706cbd1813e330c773b6b91b3f06561a
BLAKE2b-256 afa9b15ca773a7be04f974f86f5aa2d9de147a1277ffa2e319e9a07c0ba278db

See more details on using hashes here.

File details

Details for the file idm_heatpump_api-0.3.0-py3-none-any.whl.

File metadata

File hashes

Hashes for idm_heatpump_api-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 0d3861bcf763e3371d3036ac9dc1baae46a97ebbdaa9860f8e00e58b359a911f
MD5 785188755774b634e53711de2645f12d
BLAKE2b-256 843220e2ac2baf8e418839e9d3e9df2dcae8daf6b95e68f332a0f7b00207c1b3

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