Communication with AHT10 failed!

No, it is not necessary. The ESP will automatically enable its internal pull-up 10K resistors when you define the I²C bus.

As you have said the wiring diagram was a mistake, then everything you have done is correct and it looks like you may have a faulty sensor.

The only other thing you could try is to specify a bus frequency of 100kHz:

i2c:
  scl: D1
  sda: D2
  scan: True
  id: bus_a
  frequency: 100kHz

The AHT10 datasheet says it supports 0 to 100kHz (400kHz in high speed mode) and the default frequency ESPHome uses is 50kHz. Generally slower is more reliable, but it’s worth at try. I can’t think of anything else.

The datasheet also says the AHT10’s maximum input voltage is 3.6V. You didn’t accidentally power it from 5V at any time did you?

How long are the cables to the AHT10?

You’re right. But, despite the fact that ESP does have pullups and many sensors have them it did happen to me that sensor didn’t work without them, mostly if cable was too long - in this case 10k is somewhat too high. It worth a try.

The datasheet also says the AHT10’s maximum input voltage is 3.6V. You didn’t accidentally power it from 5V at any time did you?

This can be tested: define two other pins as I2C bus. If inputs 4 and 5 are “gone”, the new ones will work, if not it’s faulty sensor. It’s not mandatory to have GPIO4 and 5 as I2C.

No, not at any time.

10cm

Testet. Same result :frowning:
Thanks for helping out, guys. But it might just be a case where a $1 gadget just don’t work :slight_smile:

I have another board I’ve could have tested it on, but I’m not able to get it to work in ESPHome.
It is called:
UNO R3 Official Box ATMEGA16U2 / UNO+WiFi R3 Original ATMEGA328P Chip CH340G For Arduino UNO R3 Development Board WeMos ESP8266
But I guess that is a story for another day.

You could say my ventures into the ESPHome world has had a bad start.

Thanks again

can your sensor board be powered by just 3.3.v?
maybe it needs 5v
a google image search shows some aht10 breakouts do feature power regulation
but not everyone has this

check your ground connection, sensor may not be properly grounded. I had this issue where there was a difference of 0.5v between the sensor ground and the power supply ground.
hope this helps

So… I have the same problem and I am confused. I’ve spent hours reading several forums, trying different things, but I hope someone can help me. I have a AHT10 as well. I hooked it up to an Arduino Mega with some pull up resistors and it worked the first try. I have an esp8266 NodeMCU that says “LoLin ver 0.1” and on the back it says “New Nodemcu V3”.

I see a “Found no i2c devices!” followed by “Communication with AHT10 failed” a little later.

What I’ve tried:

  • With and without pull up resistors
  • Confirmed the sensor is working fine with an Arduino Mega
  • Swapping the SCL/SDA pins
  • Tried many different configs, e.g. pins “D1, D2”, “GPIO5, GPIO4”, different frequency (100kHz for instance)
  • Soldered everything to a perfboard and again triple checked wiring to avoid wonky breadboard issues (regretting this one a little lol)

My relevant config:

i2c:
  scan: true
  sda: GPIO4
  scl: GPIO5
  id: bus_a

sensor:
  - platform: mhz19
    co2:
      name: "MH-Z19 CO2 Value"
    temperature:
      name: "MH-Z19 Temperature"
    update_interval: 30s
    automatic_baseline_calibration: true
  - platform: aht10
    temperature:
      name: "Living Room Temperature"
    humidity:
      name: "Living Room Humidity"
    update_interval: 30s
    i2c_id: bus_a

Wiring:
Wires are as short as they can be. I connected the SDC to D1 and SDA to D2 with 2x 4,7k resistors going to the 3V. VCC connected to the pin that says “3V”, GND pin connected to “G”. I triple checked all the connections with a multimeter and I am sure nothing is shorting, everything seems to be connected exactly as I intended. There is ~3,3V on the VCC pin. It’s wired exactly the same way I used it with the Arduino when it did work, with the only difference being that Arduino runs at 5V. But the AHT10 says it can run 2.2-5.5V so that should be fine.

I also have a MH-Z17C connected to the same NodeMCU on the UART, using VU (5v) and the rx/tx/gnd pins. That one is working fine. I’m using the same ground pin for both the MH-Z17C and the AHT10 but that should also be fine…right? The store where I purchased it, shows the same pinout as is mentioned by @Dal above, except the picture I got does not mention SCL and SDA.

I can’t figure out why I can’t get this to work. There must be something simple I’m overlooking. What am I doing wrong? :frowning:
I can’t imagine specifically those 2 pins on the NodeMCU are fried. It’s a new NodeMCU and I never used those pins for anything else before. Is there anything I can do with a multimeter to check, or, anything else to debug this further?

Did you try without mhz sensor?

Thanks for the suggestion @Protoncek, I will give that a go!

Hi I´m tring to make it wor too, but I´m not undeertand the message error:

ARDWARE: ESP32 240MHz, 320KB RAM, 4MB Flash
 - toolchain-xtensa-esp32 @ 8.4.0+2021r2-patch5
Dependency Graph
|-- AsyncTCP-esphome @ 1.2.2
|-- WiFi @ 2.0.0
|-- FS @ 2.0.0
|-- Update @ 2.0.0
|-- ESPAsyncWebServer-esphome @ 2.1.0
|-- DNSServer @ 2.0.0
|-- ESPmDNS @ 2.0.0
|-- noise-c @ 0.1.4
|-- Wire @ 2.0.0
Compiling /data/teste/.pioenvs/teste/src/esphome/components/api/api_pb2.cpp.o
xtensa-esp32-elf-g++: fatal error: Killed signal terminated program cc1plus
compilation terminated.
*** [/data/teste/.pioenvs/teste/src/esphome/components/api/api_pb2.cpp.o] Error 1

My code is:

sphome:

  name: teste

  friendly_name: teste

esp32:

  board: esp32dev

  framework:

    type: arduino

# Enable logging

logger:

# Enable Home Assistant API

api:

  encryption:

    key: "uHkCyFmg+XMqlymFHRFr3mgh9roNtGvMBxTjX5Go7W4="

ota:

  password: "umidade"

wifi:

  ssid: !secret wifi_ssid

  password: !secret wifi_password

  # Enable fallback hotspot (captive portal) in case wifi connection fails

  ap:

    ssid: "Teste Fallback Hotspot"

   

captive_portal:

i2c:

  scl: GPIO5

  sda: GPIO4

 

sensor:

  - platform: adc

    pin: A0

    id: 'LDR_1'

    name: "ESP8266 ESP-12E Brightness"

    update_interval: 10s

    filters:

      - multiply: 3.3

  - platform: aht10

    update_interval: 60s # Intervalo de leitura em segundos

    # Sensores individuais

    temperature:

      name: "Temperatura"

      unit_of_measurement: "°C"

   

    humidity:

      name: "Umidade"

      unit_of_measurement: "%"

Hello All,

Sorry to bump this old thread, but I just wanted to say, that I was also having “Communication with aht10 failed” error, even though address 0x38 showed up on the i2c boot scan!! Which means the wiring is correct.
It turned out that using AHT10 in the config was causing the error, I had to use AHT20 to fix the problem. My module says aht10 on the silkscreen, the chip has aht10 laser engraved into it. But it speaks aht20 with esphome!!
Probably got scammed on AliExpress for buying from a choice seller, instead of my goto freeshipping store. aht20 relabled as aht10 is my guess as to this problem

Kind regards

3 Likes

Yes, this works.
I had the exact same problem, probably bought from the same listing on AliExpress as it says AHT10 on the module and only works with AHT20. Thank you so much, if I hadn’t of seen this message I would have been trying to figure out why it wasn’t working for hours.

Funny a while back I bought this one. Although it is clearly advertised as an AHT20 it is only working as an AHT10. There are no markings on the chips,

f.y.i. information I bought the black one with I2C connector/cable; perhaps the purple does contain the AHT20 chip and/or for the black one they received a new shipment. You never know.

Also compared to the BMP280 the AHT10 is 0,5 Celsius lower. Both readings are a bit higher than the real temperature.

See also a lot of read attempt errors but likely I should have done some additional stuff according to the doc?
[15:30:49][D][aht10:099]: Read attempt 1 at 32ms
[15:30:49][D][aht10:107]: AHT10 is busy, waiting…
[15:30:49][D][aht10:099]: Read attempt 2 at 69ms
[15:30:49][D][aht10:125]: Success at 74ms

AHT10 from AliExpress

sensor:
  - platform: aht10  # Use aht10 platform as ESPHome may not have aht20 specific support
    variant: AHT20  # Specify the model as AHT20
    temperature:
      name: "AHT10 Temperature"
      id: aht10_temperature
    humidity:
      name: "AHT10 Humidity"
      id: aht10_humidity

variant: AHT20 # Specify the model as AHT20

Silly thing to miss - Thanks mataksik - took me 5 AHT20 BMP20 cards to discover they were all good :slight_smile:

this one solved my problem. thank you very much

also double checked and it is an aht10 but only works when you set variant to aht20

Thank you for this post. This was my problem also!

Kept getting the “Communication with AHT10 failed!” and “Component aht10.sensor is marked FAILED” error messages, but it showed an address of 0x38 which meant it was communicating. As per your post, changing to “variant: AHT20” did the trick.

It seems like i see a lot of people have issues with this sensor. Its much more common than posts with dht or dallas type IMO. Quick little google search might sway decisions and choose one with less problems. I guess its just easier to be a follower than a leader?

Hi !!!The problem is the same, the sensor itself sees , but it does not show temperature and humidity

i2c:
sda: GPIO2
scl: GPIO0
scan: true
id: bus_a

sensor:

  • platform: aht10 # Use aht10 platform as ESPHome may not have aht20 specific support
    variant: AHT20 # Specify the model as AHT20
    temperature:
    name: “AHT10 Temperature”
    id: aht10_temperature
    humidity:
    name: “AHT10 Humidity”
    id: aht10_humidity

------------------------------------- Text
NFO ESPHome 2024.11.1
INFO Reading configuration /config/esphome/thermo.yaml…
INFO Starting log output from 192.168.1.72 using esphome API
INFO Successfully connected to thermohome @ 192.168.1.72 in 0.007s
INFO Successful handshake with thermohome @ 192.168.1.72 in 2.472s
[17:52:02][I][app:100]: ESPHome version 2024.11.1 compiled on Nov 25 2024, 17:20:08
[17:52:02][C][wifi:600]: WiFi:
[17:52:02][C][wifi:428]: Local MAC: 48:55:19:70:3C:1F
[17:52:02][C][wifi:433]: SSID: [redacted]
[17:52:02][C][wifi:436]: IP Address: 192.168.1.72
[17:52:02][C][wifi:439]: BSSID: [redacted]
[17:52:02][C][wifi:441]: Hostname: ‘thermohome’
[17:52:02][C][wifi:443]: Signal strength: -28 dB ▂▄▆█
[17:52:02][C][wifi:447]: Channel: 3
[17:52:02][C][wifi:448]: Subnet: 255.255.255.0
[17:52:02][C][wifi:449]: Gateway: 192.168.1.1
[17:52:02][C][wifi:450]: DNS1: 0.0.0.0
[17:52:02][C][wifi:451]: DNS2: 0.0.0.0
[17:52:02][C][logger:185]: Logger:
[17:52:02][C][logger:186]: Level: DEBUG
[17:52:02][C][logger:188]: Log Baud Rate: 115200
[17:52:02][C][logger:189]: Hardware UART: UART0
[17:52:02][C][i2c.arduino:071]: I2C Bus:
[17:52:02][C][i2c.arduino:072]: SDA Pin: GPIO2
[17:52:02][C][i2c.arduino:073]: SCL Pin: GPIO0
[17:52:02][C][i2c.arduino:074]: Frequency: 50000 Hz
[17:52:02][C][i2c.arduino:086]: Recovery: bus successfully recovered
[17:52:02][I][i2c.arduino:096]: Results from i2c bus scan:
[17:52:02][I][i2c.arduino:098]: Found no i2c devices!
[17:52:02][C][aht10:162]: AHT10:
[17:52:02][C][aht10:163]: Address: 0x38
[17:52:02][E][aht10:165]: Communication with AHT10 failed!
[17:52:02][C][aht10:167]: Temperature ‘AHT10 Temperature’
[17:52:02][C][aht10:167]: Device Class: ‘temperature’
[17:52:02][C][aht10:167]: State Class: ‘measurement’
[17:52:02][C][aht10:167]: Unit of Measurement: ‘°C’
[17:52:02][C][aht10:167]: Accuracy Decimals: 2
[17:52:02][C][aht10:168]: Humidity ‘AHT10 Humidity’
[17:52:02][C][aht10:168]: Device Class: ‘humidity’
[17:52:02][C][aht10:168]: State Class: ‘measurement’
[17:52:02][C][aht10:168]: Unit of Measurement: ‘%’
[17:52:02][C][aht10:168]: Accuracy Decimals: 2
[17:52:02][E][component:082]: Component aht10.sensor is marked FAILED
[17:52:02][C][captive_portal:089]: Captive Portal:
[17:52:02][C][mdns:116]: mDNS:
[17:52:02][C][mdns:117]: Hostname: thermohome
[17:52:02][C][esphome.ota:073]: Over-The-Air updates:
[17:52:02][C][esphome.ota:074]: Address: 192.168.1.72:8266
[17:52:02][C][esphome.ota:075]: Version: 2
[17:52:02][C][esphome.ota:078]: Password configured
[17:52:02][C][safe_mode:018]: Safe Mode:
[17:52:02][C][safe_mode:019]: Boot considered successful after 60 seconds
[17:52:02][C][safe_mode:021]: Invoke after 10 boot attempts
[17:52:02][C][safe_mode:022]: Remain in safe mode for 300 seconds
[17:52:02][C][api:140]: API Server:
[17:52:02][C][api:141]: Address: 192.168.1.72:6053
[17:52:02][C][api:143]: Using noise encryption: YES

From your log it seems not:

[17:52:02][I][i2c.arduino:096]: Results from i2c bus scan:
[17:52:02][I][i2c.arduino:098]: Found no i2c devices!

either try different address, check pull-up resistors on i2c lines… or try to use original i2c gpio’s on esp (4 and 5 for 8266).

Everything worked fine before the system update.