Trying to read text file inside parfor loop versus passing it as a parameter

3 views (last 30 days)
I have a couple txt/csv files that contain upward to 5000 lines. Each line contains information that I intend to read in as input to a function inside parfor loop. Is it best if I read the text files as a matrix/struct/etc. and the parfor loop can access the information from said matrix/struct? Or is it better have the part that read files inside the parfor loop?
  3 Comments
Giang Le
Giang Le on 24 Mar 2020
Same file! The file basically contains multiple lines. Each line is a set of different parameters/function input.
Mohammad Sami
Mohammad Sami on 24 Mar 2020
Edited: Mohammad Sami on 24 Mar 2020
I suggest just load it once before parfor loop. As long as each loop is not modifying the contents, it should be fine.

Sign in to comment.

Accepted Answer

Rashed Mohammed
Rashed Mohammed on 19 May 2020
Hi Giang Le,
Assuming that you are trying to call a function with its parameters read from a file parallelly. However, using IO functions inside parfor loop can be slow. Hence as suggested by Sami, read the data before hand using readmatrix and then pass the content as parameters to function parallelly using parfor.
Hope this helps!

More Answers (0)

Categories

Find more on Loops and Conditional Statements in Help Center and File Exchange

Community Treasure Hunt

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

Start Hunting!