Unable to use parfor with strcmpi

3 ビュー (過去 30 日間)
Anurag Passi
Anurag Passi 2017 年 11 月 28 日
コメント済み: Walter Roberson 2017 年 11 月 28 日
Hello, I am trying to use PARFOR in a loop which runs a strcmpi() function. The code is:
parfor i = 1:size(data_1,1)
idx = find(strcmpi(data_1{i,1},data_2(:,1)));
dd = data_2(idx,:);
for j = 1:size(dd,1)
fprintf(file,'%s\t%s\n',dd{j,1},dd{j,2}); % print to file
end
end
I am not able to slice the "data_2" which is a 31mn x 2 cell array due to which I am not able to run parfor. Can anyone suggest how I can modify this program for parfor? Moreover, will this effect the way I am printing the data in the file?
Thank you.
  1 件のコメント
Walter Roberson
Walter Roberson 2017 年 11 月 28 日
find(strcmpi(data_1{i,1},data_2(:,1)))
... you are expecting multiple matches?
Is either data_1(:,1) or data_2(:,1) a set of unique strings?

サインインしてコメントする。

採用された回答

Edric Ellis
Edric Ellis 2017 年 11 月 28 日
編集済み: Edric Ellis 2017 年 11 月 28 日
The variable data_2 is not being sliced because every iteration of the parfor loop needs access to the whole array. This is not an error though - the code analyzer warning is simply telling you that the code is incurring extra communication because the whole of data_2 is being sent to each worker.
  4 件のコメント
Anurag Passi
Anurag Passi 2017 年 11 月 28 日
So I think maybe I should try some other way of working with this data. Thank you for your replies.
Walter Roberson
Walter Roberson 2017 年 11 月 28 日
If either data_1(:,1) or data_2(:,1) are sets of unique strings then ismember() can be used before-hand to find the indexing.

サインインしてコメントする。

その他の回答 (0 件)

カテゴリ

Help Center および File ExchangeLarge Files and Big Data についてさらに検索

Community Treasure Hunt

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

Start Hunting!

Translated by