element14 Community
element14 Community
    Register Log In
  • Site
  • Search
  • Log In Register
  • Community Hub
    Community Hub
    • What's New on element14
    • Feedback and Support
    • Benefits of Membership
    • Personal Blogs
    • Members Area
    • Achievement Levels
  • Learn
    Learn
    • Ask an Expert
    • eBooks
    • element14 presents
    • Learning Center
    • Tech Spotlight
    • STEM Academy
    • Webinars, Training and Events
    • Learning Groups
  • Technologies
    Technologies
    • 3D Printing
    • FPGA
    • Industrial Automation
    • Internet of Things
    • Power & Energy
    • Sensors
    • Technology Groups
  • Challenges & Projects
    Challenges & Projects
    • Design Challenges
    • element14 presents Projects
    • Project14
    • Arduino Projects
    • Raspberry Pi Projects
    • Project Groups
  • Products
    Products
    • Arduino
    • Avnet Boards Community
    • Dev Tools
    • Manufacturers
    • Multicomp Pro
    • Product Groups
    • Raspberry Pi
    • RoadTests & Reviews
  • About Us
  • Store
    Store
    • Visit Your Store
    • Choose another store...
      • Europe
      •  Austria (German)
      •  Belgium (Dutch, French)
      •  Bulgaria (Bulgarian)
      •  Czech Republic (Czech)
      •  Denmark (Danish)
      •  Estonia (Estonian)
      •  Finland (Finnish)
      •  France (French)
      •  Germany (German)
      •  Hungary (Hungarian)
      •  Ireland
      •  Israel
      •  Italy (Italian)
      •  Latvia (Latvian)
      •  
      •  Lithuania (Lithuanian)
      •  Netherlands (Dutch)
      •  Norway (Norwegian)
      •  Poland (Polish)
      •  Portugal (Portuguese)
      •  Romania (Romanian)
      •  Russia (Russian)
      •  Slovakia (Slovak)
      •  Slovenia (Slovenian)
      •  Spain (Spanish)
      •  Sweden (Swedish)
      •  Switzerland(German, French)
      •  Turkey (Turkish)
      •  United Kingdom
      • Asia Pacific
      •  Australia
      •  China
      •  Hong Kong
      •  India
      •  Korea (Korean)
      •  Malaysia
      •  New Zealand
      •  Philippines
      •  Singapore
      •  Taiwan
      •  Thailand (Thai)
      • Americas
      •  Brazil (Portuguese)
      •  Canada
      •  Mexico (Spanish)
      •  United States
      Can't find the country/region you're looking for? Visit our export site or find a local distributor.
  • Translate
  • Profile
  • Settings
Sensors
  • Technologies
  • More
Sensors
Sensor Forum AHT10 - I2C problem
  • Blog
  • Forum
  • Documents
  • Quiz
  • Events
  • Polls
  • Members
  • Mentions
  • Sub-Groups
  • Tags
  • More
  • Cancel
  • New
Join Sensors to participate - click to join for free!
Actions
  • Share
  • More
  • Cancel
Forum Thread Details
  • Replies 41 replies
  • Subscribers 338 subscribers
  • Views 9552 views
  • Users 0 members are here
  • sensors
  • AHT10
Related

AHT10 - I2C problem

msimon
msimon over 2 years ago

I just bought AHT10 humidity and temperature sensor. I have seen that it supports I2C and it is cheap so I didn't think thoroughly and bought two. I wanted to try them then I encounter a problem that only a single AHT10 can be connected to single I2C bus. I thought it is related to static address but it is worse (breakout board also showing two address but no details in the datasheet). The datasheet says that "Only a single AHT10 can be connected to the I2C bus and no other I2C devices can be connected." It sounds like traditional serial communication like RS232 not I2C. 

Is it normal to advertise it as an I2C device? and I also wonder what is the technical issue preventing to connect other devices with different address. Did you have any experience similar to this on any other sensor?

  • Sign in to reply
  • Cancel

Top Replies

  • beacon_dave
    beacon_dave over 2 years ago +4
    Have you tried using the AHT10 with another device on the same I²C bus to see what happens ? It may be that it doesn't observe the stop condition so doesn't release itself from the host and continues…
  • BigG
    BigG over 2 years ago in reply to beacon_dave +4
    Both datasheets (AHT10 & AHT20) show that the sensor operates on microAmps, so powering by GPIO is possible too...
  • michaelkellett
    michaelkellett over 2 years ago +3
    I had a quick look at the data sheet. They don't appear to offer an explanation for why it doesn't work with other devices. I've used several other I2C humidity sensors and lots of I2C devices of other…
  • msimon
    msimon over 2 years ago in reply to shabaz

    I am planning to put one inside the hive the other outside the hive on the same microcontroller. I am thinking to put them roughly 10cm away from each other located on the top of the hive. However, the configuration may change as there are various thermal spots inside the hive. Actually, I may need more than two still researching characteristic of the hive temperature. 

    • Cancel
    • Vote Up 0 Vote Down
    • Sign in to reply
    • Cancel
  • shabaz
    shabaz over 2 years ago in reply to msimon

    I see; in that case, perhaps something like this could be useful, it's a low-cost component (PCA9548A), called an I2C Multiplexer if you're looking for such types of parts. Then you're free to add quite a lot of sensors. 

    Personally I'd do it in software though (i.e. using GPIO pins) if there are enough pins. But this could be a scalable way for up to 8 devices (actually up to 64 devices, since you can install many of these PCA.. chips but that seems an unlikely scenario).

    image

    • Cancel
    • Vote Up +2 Vote Down
    • Sign in to reply
    • Cancel
  • beacon_dave
    beacon_dave over 2 years ago in reply to msimon

    Pin 1 is labelled as 'ADR' on the AHT10 datasheet which may have been intended for address selection at some point. It is shown on the datasheet to be connected to ground.

    On the AHT20 datasheet it has been changed to NC and no ground connection shown. 

    Is the unused pad next to 0x39 connected to VDD per chance? If so looks like it was originally intended that pulling ADR down to GND set the address to 0x38 and pulling ADR up to VDD set the address to 0x39.

    • Cancel
    • Vote Up 0 Vote Down
    • Sign in to reply
    • Cancel
  • beacon_dave
    beacon_dave over 2 years ago in reply to shabaz
    shabaz said:
    Ordinarily, the distance cannot be too great with I2C (i.e. i2C not normally used for local/remote sensing, unless remote is something inside the same enclosure (usually).

    I've seen some pretty long VGA cables in my time... Slight smile

    DDC uses I²C to access the EDID data in the display device to report it back to the source device.

    • Cancel
    • Vote Up +2 Vote Down
    • Sign in to reply
    • Cancel
  • shabaz
    shabaz over 2 years ago in reply to beacon_dave

    There are quite long lengths within large equipment chassis' too, since it's quite common for health/alarms etc from cards plugged into a motherboard, although they may use separate I2C bus segments in some situations. VGA etc is a bit of an exception, since it's only intended for one device, and the cable is designed for it (plus little will go wrong if someone extends it, because either they will get a display or they won't). Whereas for the more general use, I2C needs to configure chips, take measurements, etc.

    • Cancel
    • Vote Up +2 Vote Down
    • Sign in to reply
    • Cancel
  • jc2048
    jc2048 over 2 years ago in reply to beacon_dave

    "DDC uses I²C to access the EDID data..."

    But not at the standard clock rate of 400kHz. They slowed it to about a tenth of that.

    • Cancel
    • Vote Up +2 Vote Down
    • Sign in to reply
    • Cancel
  • msimon
    msimon over 2 years ago in reply to beacon_dave
    beacon_dave said:
    Is the unused pad next to 0x39 connected to VDD per chance? If so looks like it was originally intended that pulling ADR down to GND set the address to 0x38 and pulling ADR up to VDD set the address to 0x39.

    image

    I suspect that 10k resistor is connected to pin1 which is ADR. The empty connection should be pin6 which is stated no connection. Maybe pin1-pin6 is address select. I will try to desolder it and change position. 

    I have attach TMP102 and AHT10 on the same I2C bus. Actually, it works. Occasionally, it stops but not sure it is related to I2C. I will be running the code for a long duration and see how it works.  It looks like, there is a translation error.

    • Cancel
    • Vote Up 0 Vote Down
    • Sign in to reply
    • Cancel
  • msimon
    msimon over 2 years ago in reply to shabaz

    Actually, there may be a translation error. It works with TMP102 sensor. I also think GPIO is a good option.

    I won't invest in a mux for these unreliable sensors. I just want to play with them and see how I can mitigate it. If things not sorted, I will buy a better sensor.

    • Cancel
    • Vote Up +1 Vote Down
    • Sign in to reply
    • Cancel
  • msimon
    msimon over 2 years ago in reply to BigG

    I connected two sensors on the same bus and then connect their Vin pins to GPIO. I also attach another I2C sensor TMP102.  It looks like working but there is a reliability issue. Sometimes it stops. I also suspect the serial port of Arduino IDE. I will check that. 

    • Cancel
    • Vote Up 0 Vote Down
    • Sign in to reply
    • Cancel
  • beacon_dave
    beacon_dave over 2 years ago in reply to msimon

    I suspect that the middle of the three pads is Pin1 (ADR), the left pad is GND and the right pad is VDD. You could confirm that with a meter test onto the 3V3 regulator. 

    I suspect that the intention was pulling low sets it to 0x38 (default) and pulling high sets it to 0x39, but perhaps something went wrong and 0x38 only worked. However you could give it a go in the 0x39 position and see if it responds to that address.

    If you can get a scope on the I²C bus then you should be able to confirm if it is behaving nicely or not.

    • Cancel
    • Vote Up +1 Vote Down
    • Sign in to reply
    • Cancel
<>
element14 Community

element14 is the first online community specifically for engineers. Connect with your peers and get expert answers to your questions.

  • Members
  • Learn
  • Technologies
  • Challenges & Projects
  • Products
  • Store
  • About Us
  • Feedback & Support
  • FAQs
  • Terms of Use
  • Privacy Policy
  • Legal and Copyright Notices
  • Sitemap
  • Cookies

An Avnet Company © 2025 Premier Farnell Limited. All Rights Reserved.

Premier Farnell Ltd, registered in England and Wales (no 00876412), registered office: Farnell House, Forge Lane, Leeds LS12 2NE.

ICP 备案号 10220084.

Follow element14

  • X
  • Facebook
  • linkedin
  • YouTube