Bosch Sensortec Community

    cancel
    Showing results for 
    Search instead for 
    Did you mean: 

    BME680 returnng irregular intervals

    BME680 returnng irregular intervals

    ziomau10
    Member

    Hi all,
    I am using a BME680 sensor with an STM32 and a FreeRTOS in ULP sampling mode.

    A thread is dedicated to manage the BME sensor, and in its loop there is a sleep for the duretion of the interval returned by the library itlesf, as suggested in the bsec_iot_loop example.

    time_stamp_interval_ms = (sensor_settings.next_call - get_timestamp_us() * 1000) / 1000000;
    ....
    osDelay(time_stamp_interval_ms);

    I noticed that the returned value is normally slightly less than 300'000mS which looks correct and keep track of processing time.
    Everything works and I have reached Accuracy of 3 after few hours. So far, so good.

    The point is that sometimes the returned timing is much less than the expected value of 300'000.
    I've seen sometimes 130'000, 50'000, or even 24'000, but still the accuracy tells me that the library should be in track.

    Is this normal, or I may have some problem in some initialization code?

    Thank you.
    Mau.

    3 REPLIES 3

    BSTRobin
    Community Moderator
    Community Moderator

    Hello ziomau10,

    Attachment is example code run on STM32, you could refer it and compare it with your code. On my side, it works well.

    Thank you,

    I'll have a deep look at your code, but at first sight looks very similar to mine.

    And indeed it works well also to me. I get IAQ and accuracy up to 3 and other reasonable values for virtual sensors.

    The point is that sometimes the returned interval value is very different from the expected 300Secs, and wanted to know if that is normal ...

    Regards.

    Mau.

    BSTRobin
    Community Moderator
    Community Moderator

    Hello ziomau10,

    You could ensure the accuracy of the two functions on your platform, and then compare it with your current result again.

    void sleep(uint32_t t_ms)
    int64_t get_timestamp_us()

    Icon--AD-black-48x48Icon--address-consumer-data-black-48x48Icon--appointment-black-48x48Icon--back-left-black-48x48Icon--calendar-black-48x48Icon--center-alignedIcon--Checkbox-checkIcon--clock-black-48x48Icon--close-black-48x48Icon--compare-black-48x48Icon--confirmation-black-48x48Icon--dealer-details-black-48x48Icon--delete-black-48x48Icon--delivery-black-48x48Icon--down-black-48x48Icon--download-black-48x48Ic-OverlayAlertIcon--externallink-black-48x48Icon-Filledforward-right_adjustedIcon--grid-view-black-48x48IC_gd_Check-Circle170821_Icons_Community170823_Bosch_Icons170823_Bosch_Icons170821_Icons_CommunityIC-logout170821_Icons_Community170825_Bosch_Icons170821_Icons_CommunityIC-shopping-cart2170821_Icons_CommunityIC-upIC_UserIcon--imageIcon--info-i-black-48x48Icon--left-alignedIcon--Less-minimize-black-48x48Icon-FilledIcon--List-Check-grennIcon--List-Check-blackIcon--List-Cross-blackIcon--list-view-mobile-black-48x48Icon--list-view-black-48x48Icon--More-Maximize-black-48x48Icon--my-product-black-48x48Icon--newsletter-black-48x48Icon--payment-black-48x48Icon--print-black-48x48Icon--promotion-black-48x48Icon--registration-black-48x48Icon--Reset-black-48x48Icon--right-alignedshare-circle1Icon--share-black-48x48Icon--shopping-bag-black-48x48Icon-shopping-cartIcon--start-play-black-48x48Icon--store-locator-black-48x48Ic-OverlayAlertIcon--summary-black-48x48tumblrIcon-FilledvineIc-OverlayAlertwhishlist