Filter löschen
Filter löschen

Reducing Latency in UDP Communications

10 Ansichten (letzte 30 Tage)
Michael
Michael am 13 Aug. 2015
Bearbeitet: Uladzimir am 18 Aug. 2015
I am working on a project where we are flying a quadcopter with an onboard Raspberry Pi which communicates with a host PC. I am currently developing the communications between the two systems using UDP protocols. I am using two Simulink models, one on the PC and one built onto the Pi, that both use the Raspberry Pi UDP Send and Receive blocks. There is very little else in the models - just a clock to generate a signal to send back and forth, and byte pack and unpack blocks. While I have been able to successfully send information back and forth, the latency has been extremely high, ranging anywhere from 2-7 seconds. Obviously, this is not practical for real-time applications. This latency is approximately the same, independent of whether both computers are communicating over WiFi or connected to a router via Ethernet. In addition, ping times between the two systems are low (<5 ms), so I don't believe the hardware configuration to be a problem.
Would anyone be able to provide a few tips or pointers towards helping to reduce the messaging latency?
Thanks.
  2 Kommentare
Walter Roberson
Walter Roberson am 13 Aug. 2015
Is the packet size variable? Did you specify the exact number of values expected for the packet?
If you were using the MATLAB routines directly I would have you check your DatagramTerminateMode
Unfortunately I am having difficulty finding specific documentation on the Raspberry Pi UDP Receive block; I see it exists but the documentation basically says "Open the library and take a look"
Michael
Michael am 14 Aug. 2015
The package size is fixed. As of right now, I am just sending one double value back and forth. Both receive blocks are expecting a packet of that size, and receive it correctly, just with high latency.

Melden Sie sich an, um zu kommentieren.

Antworten (1)

Uladzimir
Uladzimir am 14 Aug. 2015
Dear Michael, You should run your models in external mode. According to mathworks manual for real-time windows target, it provides efficiency up to 20 kHz. For this you need to set discrete fixed step solver, set up rtwin.tlc file in code generation options, then build model and run it in external mode. You could use Packet Input and Packet Output blocks, tuned as standard udp device. Our model worked with 1..3 ms delay.
  5 Kommentare
Uladzimir
Uladzimir am 18 Aug. 2015
I got your point. There is a lot to think about. What solver do you use? I used discrete, fixed-step. Also, you could try real-tyme sync block, it shows amount of missed ticks.
Uladzimir
Uladzimir am 18 Aug. 2015
Bearbeitet: Uladzimir am 18 Aug. 2015
P.S. I've just looked through my normal-mode model and noticed that here UDP SEND Binary and Receive Binary blocks were used. It have a size of the packet option. Also I remember, that there were troubles with byte alignment on the embedded side.

Melden Sie sich an, um zu kommentieren.

Produkte

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by