Find minimum error function using gradient descent
조회 수: 9 (최근 30일)
이전 댓글 표시
Find the minimum error function using gradient descent
for the function (x-1).^2 - 2
I found a code in matlabcentral, but I'm not sure how to edit it according to my requirement.
%% Code I got from matlabcentral
X = -2:0.1:2;
Y = -2:0.1:2;
[X,Y] = meshgrid(X,Y);
% Z = 2*X.^2+3*Y.^2;
Z = (x-1).^2 - 2;
surf(X,Y,Z)
hold on
x(1) = 2; % initial value of x
y(1) = 2; % initial value of y
z(1) = 2.*x(1).^2 + 3.*y(1).^2;
stepsize = 0.1;
for i = 1:30
zx = 4*x(i);
zy = 6*y(i);
x(i+1) = x(i) - stepsize*zx; %gradient descent
y(i+1) = y(i) - stepsize*zy;
z(i+1) = 2.*x(i+1).^2 + 3.*y(i+1).^2
end
댓글 수: 0
채택된 답변
Dyuman Joshi
2023년 1월 17일
편집: Dyuman Joshi
2023년 1월 18일
I don't know about the code you found, the method of operation for the given optimization algorithm should be like this -
funcChoice=2;
%error function
switch funcChoice
case 1
fun = @(x) (x-1).^2 - 2;
fungrad = @(x) 2*(x-1);
minval = -2;
case 2
fun = @(x) exp(x) - 2*x;
fungrad = @(x) exp(x)-2;
minval = 2*(1-log(2));
case 3
fun = @(x) -log(x) + 2*x;
fungrad = @(x) -1./x+2;
minval = 1+log(2);
end
disp(fun)
disp(fungrad)
disp(minval)
%starting point, can be changed as per wish
x=4;
%learning rate
rate = 0.01;
%counter
itr=0;
%tolerance, adjust accordingly
tol=1e-3;
%main algorithm
while abs(fun(x(end))-minval)>=tol
itr=itr+1;
x(end+1)=x(end)-rate*fungrad(x(end));
end
%number of iterations
itr
%corresponding x-value, already had a starting point, that's why +1
finalx=x(itr+1)
%minimum function value
finalval=fun(x(itr+1))
%minimum error
minError=abs(minval-finalval)
댓글 수: 8
Dyuman Joshi
2023년 1월 18일
편집: Dyuman Joshi
2023년 1월 18일
That doesn't make any sense to me or doesn't strike any logic
Was a justification given for it? If not, check notes or ask the instructor what does it mean by a good point.
추가 답변 (0개)
참고 항목
카테고리
Help Center 및 File Exchange에서 Mathematics and Optimization에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!