2016-11-26 13 views
0

私は(配列としてx付き)匿名関数以下のいる配列入力を持つ無名関数の勾配:偏微分/

f = @(x) 312*x(2) - 240*x(1) + 30*x(3) - 24*x(4) + 282*x(1)*x(2) + 30*x(1)*x(3) + 18*x(1)*x(4) + 54*x(2)*x(3) + 6*x(2)*x(4) + 6*x(3)*x(4) + 638*x(1)^2 + 207*x(2)^2 + 6*x(3)^2 + 3*x(4)^2 + 4063 

私は、この関数の勾配を作り、将来の使用のためにそれを保存したいです。また、配列入力もあります。

X = [ 0;... 
     0;... 
     0;... 
     0]; 

F = f(X) 
G = g(X) 

このタイプの機能でこれをアーカイブすることはできますか?あるいは、どういうわけかdiffコマンドでそれを作ることは可能でしょうか?このようなもの:

g = [diff(f, x(1));... 
    diff(f, x(2));... 
    diff(f, x(3));... 
    diff(f, x(4))] 

答えて

1

私はあなたが望むものだと思います。私は恐れます。Symbolic Math Toolboxが簡単な解決策である必要があります。そうでなければ、手で微分を計算するでしょう。

x = [1 2 3 4]; 

%// define function 
syms a b c d 
f = 312*b - 240*a + 30*c - 24*d + 282*a*b + 30*a*c + 18*a*d + 54*b*c + ... 
    6*b*d + 6*c*d + 638*a^2 + 207*b^2 + 6*c^2 + 3*d^2 + 4063 

%// symbolic gradient 
g = gradient(f,[a,b,c,d]) 

%// eval symbolic function 
F = subs(f,[a,b,c,d],x) 
G = subs(g,[a,b,c,d],x) 

%// convert symbolic value to double 
Fd = double(F) 
Gd = double(G) 

または代わり:

%// convert symbolic function to anonymous function 
fd = matlabFunction(f) 
gd = matlabFunction(g) 

%// eval anonymous function 
x = num2cell(x) 
Fd = fd(x{:}) 
Gd = gd(x{:}) 

f = 

638*a^2 + 282*a*b + 30*a*c + 18*a*d - 240*a + 207*b^2 + 54*b*c + 
6*b*d + 312*b + 6*c^2 + 6*c*d + 30*c + 3*d^2 - 24*d + 4063 

g = 

1276*a + 282*b + 30*c + 18*d - 240 
    282*a + 414*b + 54*c + 6*d + 312 
     30*a + 54*b + 12*c + 6*d + 30 
     18*a + 6*b + 6*c + 6*d - 24 

F = 

7179 

G = 

1762 
1608 
    228 
    48 

fd = 

    @(a,b,c,d)a.*-2.4e2+b.*3.12e2+c.*3.0e1-d.*2.4e1+a.*b.*2.82e2+a.*c.*3.0e1+a.*d.*1.8e1+b.*c.*5.4e1+b.*d.*6.0+c.*d.*6.0+a.^2.*6.38e2+b.^2.*2.07e2+c.^2.*6.0+d.^2.*3.0+4.063e3 


gd = 

    @(a,b,c,d)[a.*1.276e3+b.*2.82e2+c.*3.0e1+d.*1.8e1-2.4e2;a.*2.82e2+b.*4.14e2+c.*5.4e1+d.*6.0+3.12e2;a.*3.0e1+b.*5.4e1+c.*1.2e1+d.*6.0+3.0e1;a.*1.8e1+b.*6.0+c.*6.0+d.*6.0-2.4e1] 


x = 

    [1] [2] [3] [4] 


Fd = 

     7179 


Gd = 

     1762 
     1608 
     228 
      48 
+0

おかげで、正しく計算勾配。しかし、私は自分のコードでこれを実行する問題があります - http://pastebin.com/ahZR4Le3(勾配法で最小限の関数を検索する) '添え字インデックスは、正の整数または論理でなければなりません。 sym/subsref(行805)のエラー R_tilde =組み込み( 'subsref'、L_tilde、Idx); fminsearch(189行目)のエラー fv(:、1)= funfcn(x、varargin {:});エラーのグラデーションでエラー> @(a)f(D * a + X) ; 勾配のエラー(行45) [a、y] = fminsearch(fa、0); ' – Gumaa

+0

匿名関数' gd = matlabFunction(g) 'をシンボリックなものの代わりに使うべきでしょうか?しかし、私はあなたのコードをデバッグしません。新しい簡潔な質問をしてください。上のコードは機能しますが、あなたはあなたがどの部分を続ける必要があるかを知る必要があります。 – thewaywewalk