How to repeat the same function for different matrix ?
1 回表示 (過去 30 日間)
古いコメントを表示
Hello,
I have many vectors with different row sizes and I would like to repeat the same function for them.
Example:
A1 = [8; 9; 10]
A2 = [1; 2]
B1 = [0.1; 0.3; 0.6]
B2 = [0.5; 0.9]
P1 = A1 .* B1
P2 = A2 .* B2
...
How could I do to solve that?
Thanks in advance,
5 件のコメント
Luna
2019 年 3 月 20 日
編集済み: Luna
2019 年 3 月 20 日
Do you want to get each P for each A and B seperately? or the P will be a long vector?
Also your vectors in your workspace or defined in a variable? Simply you can do this:
vectorA = [A1;A2; .. bla bla .. An];
vectorB = [B1;B2; .. bla bla .. Bn];
vectorP = vectorA .* vectorB;
Stephen23
2019 年 3 月 20 日
編集済み: Stephen23
2019 年 3 月 20 日
"But I want to do that for many vectors A (A1, A2, A3, ...) and vectors B(B1, B2, B3, ...)"
Numbered variables are a sign that you are doing something wrong.
Dynamically accessing badly named variables is one way that beginners force themselves into writing slow, complex, obfuscated, buggy code that is hard to debug. Read this to know why:
"How to repeat the same function for different matrix ?"
This is trivial using idnexing.
Indexing is simple, neat, compact, easy to debug, and very efficient (unlike what you are trying to do). You should use indexing, just like experienced MATLAB users do.
回答 (1 件)
YUNUS AKSOY
2019 年 3 月 20 日
for c=1:2;
eval(['P',num2str(c),'=A',num2str(c),'.*B',num2str(c),';']);
end
3 件のコメント
Stephen23
2019 年 3 月 20 日
編集済み: Stephen23
2019 年 3 月 20 日
Note that the MATLAB documentation specifically recommends avoiding doing this:
Dynamically accessing badly named variables is one way that beginners force themselves into writing slow, complex, obfuscated, buggy code that is hard to debug. Read this to know why:
Indexing is simple, neat, compact, easy to debug, and very efficient (unlike what you recommend). Experienced MATLAB users recommend indexing, you can too.
参考
カテゴリ
Help Center および File Exchange で Whos についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!