Configure Coded PHY

Hi. I am trying to configure Coded PHY on my custom boards using nRF52840 (module ACN52840), I am using nRF Connect SDK v2.4.0. For communication, I am using NUS UART service, modified to not use physical UART, only communication with calling NUS functions. I have also tried to set Coded PHY communication for my central and peripheral codes using reference from samples Peripheral HR Coded and Central HR Coded. I did all settings in prj.conf and in code from Coded HR examples in my codes, also did get bt_conn_le_phy_info information (tx_phy 4, rx_phy 4, couldnt find what 4 mean, maybe Coded?) from both peripheral and central:

Connected: xx.xx.xx.xx.xx.xx (random), tx_phy 4, rx_phy 4

But I think I still didnt set Coded PHY. I was trying this codes with my boards (one central and one peripheral) outside, with direct visibility between both boards and I lost signal after approximately 70 meters. In inside it is even worse, I lost signal after approximately 8 meters, between boards was only one block wall with a thickness of 30 cm. I want to use chip nRF52840 for small network, with some inside and also outside sensors nodes using nRF52840, but range is very small.

I was also trying to set transmit power in prj.conf to use maximum +8dB, but it didnt help. Is it really everything in Peripheral HR Coded and Central HR Coded what I need to set? I have found some other structures struct bt_conn_le_tx_power and struct bt_conn_le_phy_param which might also set Coded PHY, but are not used in HR Coded examples, so I dont know. I hoped for better range coverage, outside range could be sufficient for me, but inside is not. I will provide my codes and also photo of my board with nRF52840. Thanks for any help setting Coded PHY.


/cfs-file/__key/communityserver-discussions-components-files/4/3286.main_5F00_central_5F00_coded.c
/cfs-file/__key/communityserver-discussions-components-files/4/4572.prj_5F00_central_5F00_coded.txt

/cfs-file/__key/communityserver-discussions-components-files/4/0363.main_5F00_peripheral_5F00_coded.c
/cfs-file/__key/communityserver-discussions-components-files/4/8867.prj_5F00_peripheral_5F00_coded.txt





Parents
  • I believe "tx_phy 4, rx_phy 4" is in fact Coded PHY. 

    I think there's an issue with the design of your board, there should be a keep-out area on both sides of the module, at the right edge of the motherboard. The problem here is that the antenna of the module is 'de-tuned' by the presence of metal in its 'near-space'.

    For reference you should should get ~1km range (outdoor, line-of-sight) with Coded PHY at +8dBm on a decent board. I suggest that you either get the module's Evaluation Kit from the manufacturer of the module, or get the nRF52840DK from us, as a reference. 

    Note:
    Coded PHY trades 8x longer on-air time per symbol for a higher receiver sensitivity. Where a higher sensitivity means that the receiver can resolve signals that are of lower power than regular 1mbps PHY (longer range). 

    However, that 8x longer on-air time is also 8x more likely to encounter spurious interference from other radios, especially Wi-Fi routers. That means that if you are in a typically noisy environment like an office space, the likelyhood that any given BLE packet will be successfully transmitted can be lower for Coded than 1mbps PHY. In this scenario, Coded PHY will still have longer max range than 1mbps if a given Coded PHY transmission is not interferred with. 

    The opposite is true for 2mbps PHY, where a lower receiver sensitivity is traded for shorter on-air time per symbol. In extremely noisy environments 2mbps PHY can actually have significantly higher throughput than 1mbps or Coded PHY (at a range where the throughput of 1mbps and Coded PHY are closer to zero), but with much shorter max range.

    -edit:

    If you share your schematics and layout files we can take a look and see if there are any other issues.

  • Hi and thanks for your answer. I didnt send you the other side of board, there is a cutout for antenna, see in image of my board below:

    I also did some testing with two nRF52840dongle boards which I have. I have tried the same code above with Coded PHY, got same results (Connected: xx.xx.xx.xx.xx.xx (random), tx_phy 4, rx_phy 4) and the range was the same, at least in indoor environment. Is dongle capable of long ranges, are there any restrictions regarding the antenna of dongle board? Because the results look same, and this is original Nordic board.

    I dont know what to test next, I dont have a nRF52840DK or other board from you. I am starting thinking to use external antenna, but I dont know if it will help.

    Thanks for your answer.  

  • Sry for the late reply.

    Your logs end after 3 notifications. I expect to see the output from the disconnected() callback:
    printk("Disconnected (reason 0x%02x)\n", reason); 

    Does the logs really just stop dead after ~3 seconds, or are there more logs? 
    I'm looking for logs from boot until the connection disconnects.
    Also you should set CONFIG_UART_CONSOLE=n when using USB CDC ACM as you can enter a bootloop if the logger subsystem is initialized earlier than the USB driver.
  • Hi. I am sending you logs which you requested. Logs dont stop dead after 3 seconds, there are more logs. 

    Here are peripheral logs:

    /cfs-file/__key/communityserver-discussions-components-files/4/peripheral_5F00_logs.txt

    And here are central logs:

    /cfs-file/__key/communityserver-discussions-components-files/4/central_5F00_logs.txt

    Disconnected reason is 0x08 (the supervision timeout is hit (no packets from the peer is received in x seconds)). Thanks for any help, I will open new thread if you dont mind, where I will be asking just for dongles (devzone.nordicsemi.com/.../short-range-with-coded-phy). This is pretty old thread and maybe someone new from community will come and try to help. Nevertheless, thanks for your support.   

  • Hi,

    Apologies for the delayed response, this case has slipped through the cracks. Have you been able to resolve the issue in the meantime?

    Best regards,

    Vidar

  • Hi, 

    no, unfortunately no. We have developed new board which is not using module ACN52840 but only chip nRF52840 with external ceramic antenna (https://www.mouser.sk/ProductDetail/Quectel/YC0010AA?qs=HBWAp0VN4Rh%252BBydEKHtdNg%3D%3D). We will try the range on this board. We also considered to try Coded PHY with nRF5 SDK, maybe there will be different results, now we are developing with nRF Connect SDK. The last option is to buy two nRF52840 DK and try the range. We will see, thanks.

  • Hi,

    If you have not yet manufactured the new boards, you may create a new private support ticket to have the layout reviewed by one of my colleagues.

    Best regards,

    Vidar

Reply Children
No Data
Related