How to speed up this code?

Hi all,
I have the following code that I need to speed-up:
a(1).a='a';
a(2).a='b';
a(3).a='b';
a(4).a='c';
output=(contains(cellstr(char(a.a),'b')))
the desidered output is:
output=[0 1 1 0]
In my case the size of a is [11'000x1], so the computation is pretty slow.
How can I speed up the code?
Thanks

 采纳的回答

Your code would be much faster if you didn't so many unnecessary conversions. a.a is a comma separated list (which is bascially a cell array) which you convert to a char array and then split back into a cell array.
output = contains({a.a}, 'b')
does the same without any conversion.
It's not clear from your simple example if you really want to use contains (which check that 'b' is present anywhere within the char vector) or strcmp (which check that the char vector is exactly identical to 'b') which would be faster or even == which would be even faster but only work if all char vectors are just one character.
output = strcmp({a.a}, 'b') %faster than contains if whole string comparison is required
Other than that, there's not much option to speed this up.

更多回答(1 个)

pietro
pietro 2019-1-24

0 个投票

Thanks for the aswer. Now the code is really fast. I have to use contains, because I have to search for string patterns.

类别

帮助中心File Exchange 中查找有关 Characters and Strings 的更多信息

产品

版本

R2017b

Community Treasure Hunt

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

Start Hunting!

Translated by