how to plot a curve fitting on a semilog

4 visualizzazioni (ultimi 30 giorni)
mohamed
mohamed il 7 Apr 2016
Commentato: mohamed il 8 Apr 2016
im trying to plot a curve fitting on a semi log graph to get its slope this is what ive tried
pws=[1150 1794 1823 1850 1876 1890 1910];
t=[0 2 4 8 16 24 48];
tp=3*24;
for i=2:length(pws)
horn(i)=((t(i)+tp)/(t(i)))
end
semilogx(horn,pws,'O-')
m=polyfit(horn,pws,1)
m(1)
k=((162.6*q*b*u)/(m(1)*h))
set(gca,'YLim',[1780 1960])
hold on
mm=polyval(m,horn)
semilogx(horn,mm,'-r');
but when i try it all i get is that
  2 Commenti
Walter Roberson
Walter Roberson il 7 Apr 2016
Your variable q is not defined in this code.
mohamed
mohamed il 7 Apr 2016
q=500;
pwf=1150;
tp=3*24;
h=22;
phi=0.2;
rw=0.3;
b=1.13;
ct=20e-6;
u=1;

Accedi per commentare.

Risposte (1)

Walter Roberson
Walter Roberson il 8 Apr 2016
You are using horn as your base variable to fit against, but horn is not monotonic. If you
plot(horn,pws)
you can see that clearly.
semilogx(horn,pws) does not show how bad the graph is because horn(1) is 0 (because you did not assign any value to horn(1)), and log(0) is -infinity, so the first data point is not drawn on the semilogx plot.
  1 Commento
mohamed
mohamed il 8 Apr 2016
ok after i tried deleting the first element in the vector pws and horn and it helped a little but the generated best fit is still wrong here it is
the best fit curve is suppose to cut the y axis at 1950 and have a slope of 99

Accedi per commentare.

Categorie

Scopri di più su Interpolation in Help Center e File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by