How to avoid If statement?

7 ビュー (過去 30 日間)
JFz
JFz 2015 年 8 月 19 日
コメント済み: JFz 2015 年 8 月 20 日
Hi,
I have a few lines of code like this:
if(volTbl.ReturnType(k) == 1)
logR = diff(log(abs(newtable.price)));
else
logR = diff(newtable.price);
end
I would like to avoide the if statement because the tables are large and the calculation is intensive. How to do that? Thanks a lot.
Jennifer
  2 件のコメント
Image Analyst
Image Analyst 2015 年 8 月 19 日
How large? Like hundreds of millions of elements?
And it's not the "if" that's taking up the time, it's the diff(), and log(). Is this code in a loop over many millions of iterations? Or is it just a one time calculation?
JFz
JFz 2015 年 8 月 20 日
Thanks. yes, you are right. It is indeed in a large for loop.

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

回答 (1 件)

Walter Roberson
Walter Roberson 2015 年 8 月 19 日
selectfun = @(cond, tf_funs, x) tf_funs{cond+1}(x);
logR = diff( selectfun(volTbl.ReturnType(k) == 1, {@(x) log(abs(x)), @(x) x}, newtable.price) );
This does not use "if", but I suspect it will be slower than if you used "if".
To get much performance improvement you would need to be writing to a different result location for each "k", such as if the statement were logR(k,:) = ... and you would need a different input location for each, such as newtable(k).price, and you would need to be doing a whole series of "k" values. But when your input is always the same and your output is always the same and you are only doing one "k" value, then it is difficult to get faster than "if".
  1 件のコメント
JFz
JFz 2015 年 8 月 20 日
Thanks! Let me try it.

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

カテゴリ

Help Center および File ExchangeLogical についてさらに検索

タグ

製品

Community Treasure Hunt

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

Start Hunting!

Translated by