Effacer les filtres
Effacer les filtres

Is there any data type equivalent for queue?

73 vues (au cours des 30 derniers jours)
ROSHITH SEBASTIAN
ROSHITH SEBASTIAN le 30 Avr 2020
Is there any data type which can handle FIFO queue operations?
I am using arrays to handle queues, but it has executional overhead since the size changes on each iteration. Now, I have to handle even array of queues, but it is getting complicated as each queue has different length at the end of each iteration. When I add an element in a row, the columns length of all the rows increases which makes it difficult to handle it.
Is there any efficient way to handle this situation. Even a link which discusses similar topics would be of great help.

Réponses (3)

Guillaume
Guillaume le 30 Avr 2020
The short answer is that no, unfortunately, there's no queue implemented in base matlab (there may be something hidden in one of the toolboxes but it's unlikely you'd be able to use it generically).
I would have a look at the fileexchange, there's probably several implementations of various quality. If there's nothing good enough there, I'd look at implementing it myself. A naive implementation would just grow/shrink an array as the queue fills/empties which indeed would be very innefficient in matlab (and most languages). A better implementation would grow the array in progressively larger chunks.
  4 commentaires
ROSHITH SEBASTIAN
ROSHITH SEBASTIAN le 11 Mai 2020
Modifié(e) : ROSHITH SEBASTIAN le 11 Mai 2020
Thank you sharing the implementation.
I tried to realizre queues wth this approach(not array of queues, but only queues), but it consumed more time than using arrays to realise queue. The simulation duration for 3 repetitions are given below:
Using array for queue : 53.267074, 79.400834, 66.493679 seconds
Using attached file : 147.340302, 96.339909, 98.572212 seconds
I have not implemented the array of queues section of the simulator. I will try both the option and see which would be better for the simujlator as a whole.
Anyways, thanks you so, much for the effort. It might be needed in other efforts or maybe in this if it outperforms for the scenario of array of queues.
*Note : Adding 5000 elements and dequeueing them takes 0.363806 seconds in my machine, hence I think the issue is the function calls and other transfer of data using this approach
Anubhav Kumar
Anubhav Kumar le 19 Mar 2021
@Guillaume I have attached queue.m file in the same directory where my main.m file is present and I am trying to use queue but in main.m where I have written q = queue; on runnung the script error is thrwoing at q = queue.
please help me so that I can solve my issue.

Connectez-vous pour commenter.


埃博拉酱
埃博拉酱 le 5 Avr 2022
Modifié(e) : 埃博拉酱 le 5 Avr 2022
parallel.pool.PollableDataQueue
As revealed by the package name, it can be shared among parallel workers.

Mahendra
Mahendra le 9 Août 2023
Instead of resizing arrays during execution, you can initialize them with zeros up to a generous length. This way, you avoid frequent size adjustments and can simply track the relevant data within this pre-allocated space.
I frequently do this and found it to not have any speed penalties. We are wasting RAM but rarely are a problem on modern day PCs.
  1 commentaire
Melih Furkan SEN
Melih Furkan SEN le 3 Nov 2023
And how will you pop them ?) or sort?)

Connectez-vous pour commenter.

Tags

Produits


Version

R2020a

Community Treasure Hunt

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

Start Hunting!

Translated by