calculate derivative of a function using handle

1 回表示 (過去 30 日間)
denial nakayama
denial nakayama 2020 年 6 月 8 日
コメント済み: Walter Roberson 2020 年 6 月 9 日
Hi, Matlab community
I have two scripts, one is
syms f(x)
f=@(x)func(x);
df=diff(f,x);
fplot(@(x) df(x),[0 10])
the other one is
function f=func(x)
if x >= 1 && x <= 2;
f=-x*1/4+2;
else
f=0;
end
And the error shows like:
Conversion to logical from sym is not possible.
How to solve ths problem?
Thank you for your attention
  2 件のコメント
KSSV
KSSV 2020 年 6 月 8 日
How did you use those functions...show us the full code.
denial nakayama
denial nakayama 2020 年 6 月 8 日
thank you for your quick answer.
I put them in the same folder and ran demo.m.

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

回答 (2 件)

Ameer Hamza
Ameer Hamza 2020 年 6 月 8 日
You need to take the derivative of the original function and then apply the limits
syms x
f(x) = (-x*1/4+2);
df(x) = diff(f,x).*(1<=x&x<=2);
fplot(df,[0 10])
  7 件のコメント
Ameer Hamza
Ameer Hamza 2020 年 6 月 9 日
Not sure about the issue. I don't have R2014a. Maybe this will work
fplot(matlabFunction(df),[0 10])
Walter Roberson
Walter Roberson 2020 年 6 月 9 日
In R2014a, fplot() was not yet able to plot symbolic expressions.

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


Walter Roberson
Walter Roberson 2020 年 6 月 8 日
function f=func(x)
f = piecewise(x >= 1 && x <= 2, -x*1/4+2, 0);
  3 件のコメント
denial nakayama
denial nakayama 2020 年 6 月 9 日
Mine is 2014a and Thank you for your attention.
Walter Roberson
Walter Roberson 2020 年 6 月 9 日
function f=func(x)
syms t
temp(t) = feval(symengine, 'piecewise', '([t >= 1 and t <= 2, -t*1/4+2], [Otherwise, 0])');
f = temp(x);

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

タグ

製品


リリース

R2014a

Community Treasure Hunt

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

Start Hunting!

Translated by