首页 > 其他 > 详细

matlab secant method

时间:2015-06-05 11:30:53      阅读:180      评论:0      收藏:0      [点我收藏+]
% Matlab script to illustrate the secant method
% to solve a nonlinear equation


% this particular script finds the square root of a number M
% (input by the user)


% note that the function we are trying to zero is f(x) = x^2 - M.
% this function is hard-coded in the script.




g=9.8065;
k=0.00341;
% f(x)=log(cosh(t*srt(g*k)))/k;




format long


% get user input
M = input(‘Please enter the number whose square root you want: ‘)
t0 = input(‘Please enter the first  of two starting guesses: ‘)
t1 = input(‘Please enter the second of two starting guesses: ‘)




% iteration counter
k = 1
% compute first secant iterate to enter loop
s = (((log(cosh(t1*sqrt(g*k)))/k)-M)-((log(cosh(t0*sqrt(g*k)))/k)-M) )/(t1-t0);
% s = ( (x1^2-M) - (x0^2-M) ) / (x1 - x0);
t = t1 - (((log(cosh(t1*sqrt(g*k)))/k)-M))/s
% x = x1 - (x1^2-M)/s
disp(‘Hit return to continue‘)
pause 


while abs(t-t1) > eps*abs(t),
    % reset guesses
    t0 = t1;
    t1 = t;
    % increment iteration counter
    k = k + 1
    % compute and display secant iterate
    s = (((log(cosh(t1*sqrt(g*k)))/k)-M)-((log(cosh(t0*sqrt(g*k)))/k)-M) )/(t1-t0);
%     s = ( (x1^2-M) - (x0^2-M) ) / (x1 - x0);
%     x = x1 - (x1^2-M)/s
    t = t1 - (((log(cosh(t1*sqrt(g*k)))/k)-M))/s
    disp(‘Hit return to continue‘)
    pause 
end

matlab secant method

原文:http://www.cnblogs.com/yxwkf/p/4553880.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!