Create an anonymous function after Symbolic differentiation

I want to differentiate a function f and the calculate the derivative of f at value of x. How can I do that? for example:
syms x
f=@(x) x^3+3*x+1;
g=diff(f(x))
Preferably I would like to create a function handle of the derivative and then calculate the derivative at x.

 Akzeptierte Antwort

Sean de Wolski
Sean de Wolski am 13 Mai 2013
Almost there!
gfun = matlabFunction(g)
g(2)

4 Kommentare

Thank you. Although it should be gfun(2).
Rule #1 of Answers: if you rewrite something from MATLAB, you will make a typo :)
But what if the original function is just x? For example:
syms x
f=@(x) x;
g = matlabFunction(diff(f(x))
gives the result g = @()1.0 which is not a useable function. How to resolve?
df = diff(f(x));
if isempty(symvar(df))
g = str2func(['@(x) repmat(', char(df), ', size(x))'])
else
g = matlabFunction(df);
end
Note: this will fail in some cases where the derivative just happens to be an expression involving a syntax that differs between MATLAB and the Symbolic Toolbox. For example,
f(x) = int(coth(cos(x)),x,1,5)*x
The int() part is actually a constant independent of the *x it is being muliplied by, so diff(f(x)) should be just int(coth(cos(x)),x,1,5), but if you emit that into the function handle you will fail when the handle is executed.
The situation could probably be improved by using
g = str2func(['@(x) repmat(', char(vpa(df)), ', size(x))'])
which will still lead to some failures, just perhaps fewer of them.

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (1)

Iman Ansari
Iman Ansari am 13 Mai 2013
Hi.
syms x
f=@(x) x^3+3*x+1;
g=diff(f(x))
h=@(y) subs(g,y)

2 Kommentare

Thank you! But then if I ask for g(2) then I get this error:
Error using mupadmex
Error in MuPAD command: Index exceeds matrix dimensions.
Error in sym/subsref (line 1389)
B = mupadmex('symobj::subsref',A.s,inds{:});
with h(2) it works... thank you!

Melden Sie sich an, um zu kommentieren.

Kategorien

Mehr zu Function Creation finden Sie in Hilfe-Center und File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by