Find cell array and replace with another cell array in main cell array?

I have 3 cell arrays. A={true;true;true;false;false;true;true;true;false;true;true;true;false;false;false}; How can I find B={true,true,true}; in A
and how can I replace that founded part with C={K;L;M};??

댓글 수: 2

Can I ask why you are using a cell array? Are K, L, and M all logical values as well?
If that's the case, generally a logical array would be more memory-efficient, parsing time-efficient, and allow for simpler code.
Actually, when I was writing the question, I made mistakes. A and B are cell arrays that are formed by logical values and C is cell array that is formed by chars. And also, I want the result as cell array with chars and ' '.

댓글을 달려면 로그인하십시오.

 채택된 답변

Chenchal
Chenchal 2017년 11월 3일
편집: Chenchal 2017년 11월 3일
Not efficient -- see below...
% code
A = {true;true;true;false;false;true;true;true;false;true;true;true;false;false;false};%logical row vector
B = {true,true,true};%logical col vector
C = {false,false,false};% assumption: replacement must also be logical col vector
% Convert all to strings, use regexprep, convert back
Rchar = regexprep(num2str(cell2mat(A))',num2str(cell2mat(B)')',num2str(cell2mat(C)')');
% Have to use _arrayfun_ since the output type must also be a cell array
R = arrayfun(@(x) {logical(x)},str2num(char(split(Rchar,''))))';
based in Guillaume comment:
% code
A = {true;true;true;false;false;true;true;true;false;true;true;true;false;false;false};%logical row vector
B = {true,true,true};%logical col vector
C = {false,false,false};% assumption: replacement must also be logical col vector
R = logical(strrep(cell2mat(A'),cell2mat(B),cell2mat(C)))
%need to convert logical array to cell array ??
Based on Cam comment:
%code
Rchar2 = regexprep(char(cell2mat(A)+'0')',char(cell2mat(B)+'0'),char(cell2mat(C)+'0'));
R2 = arrayfun(@(x) {logical(x)},str2num(char(split(Rchar2,''))))';

댓글 수: 3

Pretty close for the adaption of my idea. There's still no need for str2num though - just use the same trick to convert it back:
R2 = logical(Rchar2-'0');
And if you really want a cell array:
R2cell = num2cell(R2);
Careful, STRREP and REGEXPREP are not working the same way. Regexp engines "eat" the string, STRREP does not:
>> strrep( 'aaa', 'aa', 'bb' )
ans =
'bbbb'
>> regexprep( 'aaa', 'aa', 'bb' )
ans =
'bba'
and STRFIND operates like STRREP:
>> strfind( [true,true,true], [true,true] )
ans =
1 2
Actually I made mistakes when I was writing the question but I use that line: "R = logical(strrep(cell2mat(A'),cell2mat(B),cell2mat(C)))" and erase logical function.
R = transpose(strrep(cell2mat(transpose(A)),cell2mat(transpose(B)),cell2mat(transpose(C))))
this code gave me what I want.
Thank you!!

댓글을 달려면 로그인하십시오.

추가 답변 (1개)

Ali,
Regardless of your reason for using cell arrays initially, it is likely to be faster to convert them to logical arrays before searching for the pattern. Chenchal shows you how to do that with cell2mat.
However, I would not recommend converting the logical values into character representations of their values (i.e. converting true into '1' and false into '0'). The conversion from number to character and back takes significant time that is likely to be unnecessary.
Once you have your logical arrays, you can use any of the algorithms mentioned in this blog post to find the location of the patterns, and then replace them with simple indexing and assignment.
If you would like to use any string-search functionality, rather than using num2str, I'd recommend just converting the logical values directly to some character values. It doesn't really matter which character value it is, so long as you can do matching with it. For easy of examination though, you could just do this:
charArray = char(logicalArray+'0');
Hope this helps!
-Cam

댓글 수: 3

I have to agree with Cam. I don't see the need for a cell array in the example provided, so if the logical values are indeed stored in a cell array, I would convert that into a bog standard logical vector.
Following that, a simple strfind will locate your pattern (despite its name, strfind works fine with numerical or logical vectors).
If the K, L and M symbols do not stand for logical values, then I'd say that there is something fundamentally wrong in what you're doing. An heterogeneous container where most of the values are logical but a few are some other types really does not sound right. What is the use case?
Hey thank you Guillaume, I did not realize that! So below should do:
% code
A = {true;true;true;false;false;true;true;true;false;true;true;true;false;false;false};%logical row vector
B = {true,true,true};%logical col vector
C = {false,false,false};% assumption: replacement must also be logical col vector
R = logical(strrep(cell2mat(A'),cell2mat(B),cell2mat(C)))
R is a logical array, how to convert to cell array?
KL
KL 2017년 11월 3일
편집: KL 2017년 11월 3일
R is a logical array, how to convert to cell array
how about num2cell( R)?

댓글을 달려면 로그인하십시오.

카테고리

도움말 센터File Exchange에서 Cell Arrays에 대해 자세히 알아보기

질문:

2017년 11월 3일

댓글:

2017년 11월 4일

Community Treasure Hunt

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

Start Hunting!

Translated by