Polynomial Anonymous function degree

11 ビュー (過去 30 日間)
Ashish Sahu
Ashish Sahu 2019 年 4 月 27 日
コメント済み: Walter Roberson 2019 年 4 月 28 日
How can I find the degree of a given "anonymous function" like f=@(x) x^2+2x; given the functions are only polynomials?
  1 件のコメント
dpb
dpb 2019 年 4 月 27 日
編集済み: dpb 2019 年 4 月 27 日
Convert to string via func2str and regexp() to return powers of exponentials--find max thereof. Of course, that presumes someone doesn't write a function like using the explicit form of Horner's rule--
f=@(x) (x+2).*x;
in which case you've got more work to do... :)

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

採用された回答

Walter Roberson
Walter Roberson 2019 年 4 月 27 日
Build a vector
X = realmax.^(1./(1:50));
Evaluate the function at X. The first result that is finite is probably the degree. However, it is possible for a polynomial with sufficiently large coefficients to generate an infinity "early", or for with sufficiently small leading coefficient to be "late" relative to this, so you should use that as a starting point to do more cross-checking.
  3 件のコメント
Ashish Sahu
Ashish Sahu 2019 年 4 月 28 日
This method doesn't seem to work for degree 4 & degree 5 polynomials.
f=@(x) x^4;
X = realmax.^(1./(1:50));
for i=1:50
Y = f(X(i));
if Y<Inf
break
end
end
degree = i % degree of polynomial is degree
I am getting degree = 5.
Walter Roberson
Walter Roberson 2019 年 4 月 28 日
x^4 is a leading coefficient of 1 which is "suffiently small" in terms of what I wrote above.
Perhaps a slightly different X would help? You should analyze why this case fails to figure out what changes to make.

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

その他の回答 (0 件)

カテゴリ

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

Community Treasure Hunt

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

Start Hunting!

Translated by