Concatenate large matrices a bottleneck in function

Hi,
I have a function that concatenates two matrices, size of 100000 X 90 for an outcome of 100000 X 180.
This is a significant bottleneck as the function has to repeat many times.
Pre-allocating the outcome does not seem to make any difference, and using cat() or [] also seems to make no difference.
Does anyone have suggestions on how to speed this up?
Thank you.

2 件のコメント

Sylvain
Sylvain 2020 年 11 月 4 日
can you post your code?
are you trying to do this ?
A=ones(100000,90);
B=2*ones(100000,90);
C = [A,B];
David McVea
David McVea 2020 年 11 月 4 日
Hello -
Thanks for your comment.
I won't post my code because, yes, that is exactly what I am doing.

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

回答 (1 件)

Subhadeep Koley
Subhadeep Koley 2020 年 11 月 4 日

0 投票

The horzcat() function is usually faster than cat() or [, ]. You may use it.
A = ones(100000,90);
B = 2*ones(100000,90);
result = horzcat(A, B);

1 件のコメント

Walter Roberson
Walter Roberson 2020 年 11 月 4 日
The timing tests I tried show horzcat(A,B) and [A,B] and cat(2,A,B) to be indistinguishable in timing -- the differences were below random variation

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

カテゴリ

ヘルプ センター および File ExchangeLoops and Conditional Statements についてさらに検索

製品

リリース

R2018b

質問済み:

2020 年 11 月 4 日

コメント済み:

2020 年 11 月 4 日

Community Treasure Hunt

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

Start Hunting!

Translated by