need help with problem

1 visualizzazione (ultimi 30 giorni)
dulanga
dulanga il 3 Apr 2019
Commentato: dulanga il 4 Apr 2019
what is wrong in this code i dont get the correct answer
xleft=0;
xright=(9*pi)/4;
N=20;
x=linspace(xleft,xright,N);
x=x';
dx=(xright-xleft)/(N-1);
yleft=1;
yright=1;
a=1;
b=-2;
c=-2;
% M is the matrix when multiplied by y gives y'' y' and y
M2=(diag(-2*ones(N,1),0)+diag(ones(N-1,1),-1)+diag(ones(N-1,1),1))/dx^2;
M1=(diag(ones(N-1,1),1)-diag(ones(N-1,1),-1))/(2*dx);
M0=eye(N);
M=a*M2+b*M1+c*M0;
%treating boundaries separate
M(1,:)=[1,zeros(1,N-1)];
M(end,:)=[zeros(1,N-1),1];
k=(sin(x))/((cos(x))+2);
k(1) = yleft;
k(end) = yright;
y=M\k

Risposta accettata

Matt J
Matt J il 3 Apr 2019
is my code correct i dont get the correct answer
Then by definition, it is not correct...
  8 Commenti
Matt J
Matt J il 4 Apr 2019
Modificato: Matt J il 4 Apr 2019
Why is there no M1? The only thing that has changed is b=c=0.
dulanga
dulanga il 4 Apr 2019
yes so when it goes to M equation since b is zero M1 doesnt matter anymore ?
There is a M1 yes since b*M1 and b is zero M1 holds no impact on M then ?

Accedi per commentare.

Più risposte (1)

Muhammad Ibrahim
Muhammad Ibrahim il 4 Apr 2019
Modificato: Muhammad Ibrahim il 4 Apr 2019
k=(sin(x))/((cos(x))+2);
should be
k=(sin(x))./((cos(x))+2);
That small dot after sin(x) can make a big difference.
Also. read the question carefully, you might be keying the maximum value when it maybe asking minimum value.If you still have problems just ask again in this forum maybe I can help out.

Tag

Community Treasure Hunt

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

Start Hunting!

Translated by