Parfeval with backgorund pool cannot read XML file

6 vues (au cours des 30 derniers jours)
Michaela Konstantinou
Michaela Konstantinou le 1 Août 2024
Modifié(e) : Madheswaran le 6 Août 2024
Inside the parfeval I am using xml_read with an XML path. This function works properly with a parpool object but not with a backgorundPool
  2 commentaires
Animesh
Animesh le 1 Août 2024
Can you attach a code snippet for better understanding of the problem?

Connectez-vous pour commenter.

Réponses (1)

Madheswaran
Madheswaran le 6 Août 2024
Modifié(e) : Madheswaran le 6 Août 2024
Hi Michaela,
I am assuming you are using MATLAB built-in ‘xmlread’ (https://mathworks.com/help/matlab/ref/xmlread.html).
As it is seen from the documentation, ‘backgroundPool’ is a thread based parallel pool.
As you might have seen in the error message, ‘xmlread’ is unfortunately not supported in thread-based workers because of the use of ‘javaMethod’ function in its implementation.
You can view the errors of scheduled function, using ‘parallel.Future’ object, like mentioned below.
>> f = parfeval(backgroundPool, @xmlread, 1, xmlFilePath);
>> f.Error
ans =
ParallelException with properties:
identifier: 'parallel:threadpool:DisallowedBuiltin'
message: 'Use of function javaMethod is not supported on a thread-based worker. Use alternatives supported on the background pool.'
cause: {}
remotecause: {[1×1 MException]}
stack: [2×1 struct]
Correction: []
Please note that if a function supports the thread based environment, it would be explicitly mentioned in the Extended Capabilities section of the documentation. Since nothing is mentioned in the documentation page of ‘xmlread’, it is implied that the function is not supported in the thread-based environment.
Hope this helps!

Catégories

En savoir plus sur Startup and Shutdown dans Help Center et File Exchange

Produits


Version

R2023b

Community Treasure Hunt

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

Start Hunting!

Translated by