MATLAB编程求梯度值
下面的程序该怎么修改,使得该函数可以接收参数传递,求得在某点的梯度值function[t]=tidu1(x)n=length(x)fori=1:ns=0;p=1/2*x(...
下面的程序该怎么修改,使得该函数可以接收参数传递,求得在某点的梯度值
function [t]=tidu1(x)
n=length(x)
for i=1:n
s=0;
p=1/2*x(i)^2-log(x(i));
s=s+p;
end
t=jacobian(s,x);
t
end 展开
function [t]=tidu1(x)
n=length(x)
for i=1:n
s=0;
p=1/2*x(i)^2-log(x(i));
s=s+p;
end
t=jacobian(s,x);
t
end 展开
2个回答
推荐于2016-09-22
展开全部
x=[];
m=[];
for i=1:24
sx=['x',num2str(i)];
sm=['m',num2str(i)];
eval(['syms ',sx,' ',sm])
eval(['x=[x,',sx,'];']);
eval(['m=[m,',sm,'];']);
end
sh=sum(x.^2)/2*1e6;
y=0;
for i=1:length(x)
y=y+sum(x(1:i));
sh=sh+(y-sum(x(1:i))/2)^2*m(i);
end
jac=jacobian(sh,x);
jac'
m=[];
for i=1:24
sx=['x',num2str(i)];
sm=['m',num2str(i)];
eval(['syms ',sx,' ',sm])
eval(['x=[x,',sx,'];']);
eval(['m=[m,',sm,'];']);
end
sh=sum(x.^2)/2*1e6;
y=0;
for i=1:length(x)
y=y+sum(x(1:i));
sh=sh+(y-sum(x(1:i))/2)^2*m(i);
end
jac=jacobian(sh,x);
jac'
追问
看不太懂啊,尤其sh的表达式不太懂啊
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询