Share PollableDataQueue between Matlab sessions

7 visualizzazioni (ultimi 30 giorni)
I'm trying to send data between two sessions using data queue. Here is how I tried to do that:
  1. First Matlab instance creates PollableDataQueue and saves it in matfile
  2. Second instance reads it and sends data object to the first one
However such approach results in an error when I send a message:
Struct contents reference from a non-struct array object.
Error in parallel.internal.pool.AbstractDataQueue/send (line 135)
if obj.Session.isSessionRunning
Error in QueueManager/send_request (line 33)
request_queue.send(task);
Error in TaskSender/get_latest_max (line 15)
obj.queue_manager.send_request(task);
Is there a way to achieve such communication between Matlab sessions?
  1 Commento
Tomasz Wyrowinski
Tomasz Wyrowinski il 15 Set 2017
I also get a warning when loading queue from matfile:
Warning: While loading an object of class 'parallel.pool.PollableDataQueue':
To send and receive messages there must be a pool.

Accedi per commentare.

Risposte (2)

Thomas Falch
Thomas Falch il 15 Mag 2025
DataQueue and PollableDataQueue are meant for sending data between the client and worker, or between workers in the same parallel pool. In other words, it is meant for sending data between MATLAB sessions that run at the same time.
It can not be used to send data from one MATLAB session to another you run later. To do this, you can simply save the data itself to a .mat file directly, and then load this .mat file in a MATLAB session you open later.

Raymond Norris
Raymond Norris il 20 Giu 2025
@Tomasz Wyrowinski are there other reasons to run a second MATLAB session? Or is it just to "offload" work while the first MATLAB session is running? If so in R2021b we introduced backgroundPool for running code in the background pool, using parfeval. There you could use a dataqueue. Would this suffice?
  1 Commento
Tomasz Wyrowinski
Tomasz Wyrowinski il 20 Giu 2025
Modificato: Tomasz Wyrowinski il 20 Giu 2025
@Raymond Norris @Thomas Falch If I remember correctly, the project I had worked on required me to build a software service capable of interacting with some continuously running calculations in MATLAB. To support that functionality, I tried to start an additional MATLAB session that would use a data queue to send configuration updates for the calculations and also receive some data in response. If I'm not mistaken, I ended up building the service in Python, starting another MATLAB engine instance, and somehow establishing a connection between the engines—most likely by following the documentation here.

Accedi per commentare.

Categorie

Scopri di più su Workspace Variables and MAT Files in Help Center e File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by