-
Notifications
You must be signed in to change notification settings - Fork 9
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
ESP Now LR mode #6
Comments
or is there an option to have LR and WiFi enabled simultaneously? |
You should be able to do: w0.config(protocol=network.MODE_11B|network.MODE_11G|network.MODE_11N|network.MODE_11N) and wifi will work as well as LR mode. From my understanding LR mode will be used if the other device is also capable of LR mode - but I have not verified that myself. (see esp_wifi_set_protocol()). The protocol is a bitmask you can use to select which modes you want enabled. I have not personally worked with LR mode much at all - other than when prompted to check a few things by users :-). |
No Luck, the multiple modes when include LR - the beacon disappears.When LR mode is in the list only ESPNow works |
I will revisit this LR mode after finishing my target application. What I have observed practically so far is, with two devices in LR mode we don't gain anything extra. This is with ESP-IDF SDK itself I get reception on the receiver upto -98dB RSSI without LR mode itself, which is good enough for time being. |
LR is a different physical layer encoding to normal WIFI. Your best bet
would be to have another esp32 as an AP, and somehow connect it up to your
WIFI router. Ethernet, perhaps? That's an exercise for the reader
…On Mon, 3 Oct 2022, 13:58 krishnak, ***@***.***> wrote:
or is there an option to have LR and WiFi enabled simultaneously?
—
Reply to this email directly, view it on GitHub
<#6 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/ADYZMDXR5J45TTPLTXUAKX3WBJHFNANCNFSM6AAAAAAQ3E4EUI>
.
You are receiving this because you are subscribed to this thread.Message
ID: ***@***.***>
|
I'm very interested in this for CircuitPython. From my understanding LR mode can be enabled in addition to the b/g/n modes (presumably in some time-slicing sense), but I've seen problems if the wifi + esp-now channels vary, and another problem means esp-now is channel 1 on circuitpython for now. The other issue is it's probably unrealistic if you expect / activate the true long range functionality (LowRate mode), as I was under the impression that longer range reduces the bandwidth to 1Mbps/500kbps/250kbps [presumably the LORA low-rates?] rather than the usual Mbps from >=WIFI_11B, so you'll want all the air-time available for low-bandwidth long-range comms instead. Maybe as suggested having a bridge device, or a co-processor like the matter devices do, would be best option. Personally I'm going for time slicing, manually if necessary (the nodes can repeat for a minute or so while the "hub" fires data over 802.11g for a few seconds). This comment is a third "my 2cents", a third just a subscription to the topic, and a third a request for advice or question to see if you lot in micropython land have the same problems/restrictions. |
Although the docs from espressif suggest you can mix the modes, I havent seen any reports that this works effectively with espnow and it is better to just select the LR mode as the only option. I suggest then trying the mixed modes. Im not familiar with the circuitpython interface to espnow, but espnow traffic just runs over whatever channel the radio is currently set to. Eg. if you connect to an AP on STA_IF, the radio switches to the channel of the AP, and espnow traffic will be sent and received on that channel. If you start an AP on your device on channel X, then espnow traffic will be sent and received on channel X. (Caveat: espressif may have changed some of this behviour in the IDF, but my experience has been that there is no automatic swiching of channels between STA_IF, AP_IF and espnow operations. So, if you start espnow, you can change the channel of operations by changing the channel on the STA_IF or AP_IF. Micropython allows manually setting the channel number of the STA_IF or the AP_IF, however it is possible that circuitpython only provides access to setting the AP_IF channel. (Earlier versions of the IDF did not support setting the channel on the STA_IF). Eg. turn on STA_IF, turn on AP_IF, set the channel of the AP and then turn off AP_IF. The radio will continue to operate on the channel you set for the AP_IF. (See the micropython espnow docs.
This looks like a good starting point and then progress from there. One comment is that I have seen that users often expect to see an improved RSSI reading in LR mode, but that is not how I believe LR mode operates. Instead it should result in a lower packet loss rate compared to wifi for the same (low) RSSI. (eg, see glenn20/micropython-espnow-images#20 (comment)).
I am sure that we have some of the same restrictions, but over the last few years a few PRs have been merged into micropython (mostly in |
When you enable Long range mode w0.config(protocol=network.MODE_LR) - I am no longer able to see the WiFi beacon of AP from my computer's network scan. Can you please confirm whether you can connect to AP with LR mode enabled?
The text was updated successfully, but these errors were encountered: