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.1.tar.gz (24.4 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.1-py3-none-any.whl (20.9 kB view details)

Uploaded Python 3

File details

Details for the file idm_heatpump_api-0.3.1.tar.gz.

File metadata

  • Download URL: idm_heatpump_api-0.3.1.tar.gz
  • Upload date:
  • Size: 24.4 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.1.tar.gz
Algorithm Hash digest
SHA256 b9d442a1ce198fa554f0b621b5ef421a72167d0322ed369da4454774bb605bc8
MD5 33bac8c72a77de6720b28186552c7e80
BLAKE2b-256 0d61ff6ccd1a0803afdb4e3894707da7535262778133169a4cc3fe9ca306072e

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for idm_heatpump_api-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 acedb05211a81bdc65ff09f62dbc9dd553da40391334de5bdc917e72dd01be9f
MD5 f51d0d66b883ab1e3e55c9a3bf79c7ab
BLAKE2b-256 e97ab7c3c816e15d345d3db024c2e434140170d8e14a5071ffc11e2b438dfd04

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