Решение уравнения Колебрука с использованием Ньютона в Matlab

Я делаю этот скрипт:

Эта часть предназначена для создания переменных de Re и Ru, поэтому я могу заменить использование другой. Затем создайте выражение, чтобы MATLAB мог его получить.

Re = 152788; % Reynolds
Ru = 4e-05; % roughnesss
syms x a b
dy = subs(1/sqrt(x)+2*log10((a/3.7)+2.51/(b*sqrt(x))), [a, b], [Ru,Re]);
df1 = diff(dy);

Это скрипт для Ньютона-Рапсона, он работает для других выражений.

f=inline(dy);
df=inline(df1);
x0=input('Enter the initial value of x; x0:  ');
precis=input('Enter the calculation precision; precis:  ');
it=0;
x=x0;
d=f(x)/df(x);
fprintf('\n %6s %7s  \n ','Iter.','x');
while abs(d)>precis
fprintf('\n %8.4f %8.4f  \n',it,x);
x1=x-d;
it=it+1;
x=x1;
d=f(x)/df(x);
end;
fprintf('\n %8.4f %8.4f  \n',it,x);

Когда я запускаю скрипт, итерация никогда не заканчивается, переходите к бесконечности. Коэффициент трения, полученный по данным 0,016

0 ответов

Другие вопросы по тегам