-
Notifications
You must be signed in to change notification settings - Fork 409
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
LR1110 anomalously high SNR #1161
Comments
Idea: since it's two's complement, and SNR is negative, do we need to undo that? Logic: Real SNR is -8dBm, but we're currently getting 56 from RadioLib
|
As a data point, getting larger SNRs from RadioLib for worse reception, so it does seem like the value may be inverted. |
@fifieldt PRs are welcome of course ;) |
an excerpt from reference Lora-net driver - https://github.com/Lora-net/lr1110_driver/blob/master/src/lr1110_radio.c#L290-L295 |
Thanks @lyusupov . Giving that a test |
I tried: and compared the results to a co-located non-LR1110 device. This table shows the RSSI/SNR for the same nodes for the two different devices:
|
(Don’t have the hardware to confirm yet.) |
OK, I think @GUVWAF is on to something :) Here are the test values using the code above:
The 44 SNR became -8.5, with the rest more or less the same. If that last value was positive rather than negative it'd be the same as a non-LR1110 radio. |
Hmm, only 2dB difference in SNR for 44dB difference in RSSI as reported by the non-LR1110 device looks strange. The 17.8dB difference in SNR reported now by the LR1110 for a difference of 36dB RSSI sounds more reasonable to me. Are you using Meshtastic for the RSSI/SNR reports? It can be a bit tricky because SNR is stored persistently on the device, while you only get RSSI from a new incoming packet. If there are nodes with firmware <2.3 the RSSI/SNR can also be from the last relayer instead of the actual transmitter. Best to check the serial logs to be sure to get the RSSI and SNR from the same packet. |
Most likely yes, I think I probably didn't notice this issue in testing as my devices are right next to each other, so it's quite rare for me to get SNR < 0 on my test setup. What is the "non-LR1110" device? I agree with @GUVWAF that SNR of 9 dB at -100 dBm looks a bit suspicious. |
Thanks for taking a look, @GUVWAF and @jgromes . No caching or firmware issues here. The test device is freshly flashed via SWDIO (i.e full erase) release pre2.4.0, before each test. The others devices are 2.3.15. Xc (Heltec Wireless Tracker 1.1, 3.5dBi omni) and Xa42 (wio-tracker-wm1110, 3.5dBi omni) are in the same room as the test device (wio-sdk-wm1110, terrible stub antenna). XYS (RAK4631, 5.8dBI omni) is on a 6m mast 3 stories up from the test site. |
Sorry, the non-LR1110 Device is a Tbeam, also with a terrible stub antenna. |
I did a little test of my own, here are the results. As the transmitter, I used SX1262 with output power set to 0 dBm and -9 dBm so that I can get lower RSSI/SNR values. I tried couple different possible calculations, as well as the one from the reference driver. Result for 0 dBm transmission:
Result for -9 dBm transmission:
So it looks like casting to |
Fixed in the latest commit ;) |
Hi Jan,
We just added support in Meshtastic for some of the Seeed studio boards featuring the LR111X series of radios thanks to your work in adding support within RadioLib. 😄
One of things we've noted since then, is that the SNR values seem oddly high
meshtastic/firmware#4284
I did a cursory dig into the codebase to see if anything obvious popped up and the only thing I found in comparison to the SX126X family is that there is no
if(snrPkt < 128)
logical analogue in the LR111X family, but I wasn't entirely sure if that had more to do with the uint8 boxing in contrast to the amply sized float buffer we have on the LR111X. Anyway, I may be barking up the wrong tree, but I thought I'd point it out just in case it lead to anything. 😅https://github.com/jgromes/RadioLib/blob/d1bfccd6128f8fc9e35aa29a0d0c21bb077d7af0/src/modules/LR11x0/LR11x0.cpp#L2377C1-L2378C1
RadioLib/src/modules/SX126x/SX126x.cpp
Line 1357 in d1bfccd
The text was updated successfully, but these errors were encountered: