Customising distance measurement using NDT

Today I'm working on distance measurement using NDT.  I have the example code running (on two Thingy:91s).  My next step will be to optimise the code so that rather than running identical code on both devices, I will have one (mobile) device where power consumption is important and a second (fixed) device where it's less of an issue.  I would like the mobile device not to scan for advertisements; looking at this https://developer.nordicsemi.com/nRF_Connect_SDK/doc/2.3.0/nrf/samples/bluetooth/nrf_dm/README.html it seems that it should be possible, but if I just disable scanning on the mobile device then I don't get any distance measurements at all.  I can't immediately see why that is.

Can you please confirm whether distance measurement is possible with only one device scanning, and if so how I should modify the example to do this.

Thanks,

 Frog

Parents
  • Hi, 

    I am afraid the nRF Distance Measurement with Bluetooth LE discovery cannot support mobile phones. The sample requires two nRF devices, one works as the reflector and another as the initiator to measure the distance. 

    Regards,
    Amanda 

  • Hi Amanda,

      When I say 'mobile' and 'fixed' I'm referring to the devices being physically portable or not.  Both devices will use Nordic microcontrollers.

    Cheers,

      Frog

  • Hi, 

    Sorry for the misunderstanding. 

    Can you please confirm whether distance measurement is possible with only one device scanning

    Yes, when you disable scanning, you should also comment out the if (peer_supported_test(info->addr)) line inside adv_scanned_cbcallback function.

    If the device does not act as a scanner it does not build the list of supported peers.

    In the DM sample (from NCS) the device acts as both scanner and advertiser. A list of supported device is build in the scanner callback function. This list is only used for the purpose of sample. It is not used by the dm submodule or the nrf_dm library.

    -Amanda H.

  • Thanks Amanda,
      I've done as you advised and it's working for me.
    What I'm trying to achieve next is to make the 'mobile' device advertise but not scan.  However, in the 'mobile' firmware, if I comment out bt_scan_start() or change from active to passive scanning mode then I don't see any distance measurements.  But from what you say I would expect the 'fixed' device still to see the advertisements from the 'mobile' device, and connect to perform measurements.  So it seems there's more I need to understand.

  • Hi, 

    When printing the results, the list of supported peers is also checked. To print out the measurement result, you can make the following modification in the peer.c:

    if (k_msgq_get(&result_msgq, &result, K_FOREVER) == 0) {
                struct peer_entry *peer;
                print_result(&result);
                // peer = peer_find(&result.bt_addr);
                // if (!peer) {
                //  continue;
                // }
                // memcpy(&peer->result, &result, sizeof(peer->result));
                // peer->timeout_ms = PEER_TIMEOUT_INIT_MS;
                // print_result(&peer->result);
                // closest_peer = mcpd_min_peer_result(closest_peer, peer);
                // led_notification(closest_peer);
                // ble_notification(peer);
            }

    In the nrf_dm sample (from NCS) the device acts as both scanner and advertiser. A list of supported device is build in the scanner callback function. This list is only used for the purpose of sample. It is not used by the dm submodule or the nrf_dm library.

    Here is my test project nrf_dm_withoutScanning.7z for NCS v2.3.0. 

    Beware that this code/configuration is not fully tested or qualified and should be considered provided “as-is”. Please test it with your application and let me know if you find any issues.

    -Amanda H.

  • Thanks Amanda, that's much appreciated.  I've been diverted to another task for a few days but will get back to this in due course.

Reply Children
No Data
Related