Time consumption of string copied to string array

1 次查看(过去 30 天)
I programmed a simulation and currently optimizing the function in terms of time. Therefore I use the profiler to check the time consumption per function. Here I was wondering, why a simple copy instruction of a string into a string array - that is indeed often called - takes nearly 10% of simulation time:
in line 65 you can see the instruction. ‘obj.dataList’ is a string-array, ‘pos’ a logical array with equal size of ‘obj.dataList’ and only a single true value and ‘value’ a string. I do not know what exactly happens "inside" of Matlab; since I am using strings, there has to be some kind of repeating memory allocation which of course takes time. But that this single line takes 10% of simulation time, seems a bit long.
Does anyone have an idea, how I can optimize that?

采纳的回答

Matt J
Matt J 2022-5-8
pos a scalar between 1 and the length of obj.dataList and value a string.
That is definitely not the case. In the preceding line, you can see that pos is the result of a logical operation, and therefore is an array consisting of logical zeros and ones.
  5 个评论
Thomas Cimiega
Thomas Cimiega 2022-5-8
Thank you. Yes I also thought of mapping the correct indices initially and setting 'pos' according to that instead of using a binary array. I will try this and solve the thread, if it works.
Thomas Cimiega
Thomas Cimiega 2022-5-9
Your approach using
pos=find(pos,1);
if ~isempty(pos)
obj.dataList(pos)=value;
end
reduced the processing time by half, thank you!

请先登录,再进行评论。

更多回答(0 个)

类别

Help CenterFile Exchange 中查找有关 Get Started with MATLAB 的更多信息

产品


版本

R2021b

Community Treasure Hunt

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

Start Hunting!

Translated by