Need help solving first order DiffyQ analytically with matrix
2 ビュー (過去 30 日間)
古いコメントを表示
I'm given the equation
. This can also be written as
. Where
where
and
is a 2x1 matrix with initial value of
. I need to solve this problem analytically with Euler method, I've already solved it numerically. I need to plot time vs. intensity.
data:image/s3,"s3://crabby-images/c612f/c612f372819c2d70f3b201bec996721e19b2256f" alt=""
data:image/s3,"s3://crabby-images/9916d/9916d95b850e81d6dd9ace69be9ef991536254c4" alt=""
data:image/s3,"s3://crabby-images/d6811/d6811a1c1500b2b496719091d5335df3ae9fb51b" alt=""
data:image/s3,"s3://crabby-images/ff977/ff9775b91d175ea62c8044d508d4fdaeeedf3fdc" alt=""
data:image/s3,"s3://crabby-images/de451/de45145d15b56e2b6df898f7cb84f6b3f6c7638b" alt=""
data:image/s3,"s3://crabby-images/bfa81/bfa81aa267bcc561749e7a2b9bcee4df18dcbc48" alt=""
my code attempt is as follows:
gamma=0.5;
H=[(gamma*i) -1;-1 -i*gamma];
G=(2:2);
psi=(2:1);
psi(1,1)=1;
psi(2,1)=0;
T=10;
N=1000;
deltat=T/N;
x=[];
y=[];
t=[];
x(1)=0.5;
y(1)=0;
t(1)=0;
t1=[];
for t=1:N
t1(end+1)=t;
x(t+1)=x(t)+y(t)*deltat;
y(t+1)=y(t)+deltat*(-i*H*psi);
intensity=abs(y).^2;
int1(end+1)=intensity(1,1);
int2(end+1)=intensity(2,1);
end
plot (t1,int1,'-*');
hold on;
plot (t1,int2,'-*');
hold off;
I keep getting the error 'Unable to perform assignment because the left and right sides
have a different number of elements.' for line 36: y(n+1)=n*y(n)+deltat*(-i*H*psi);
I am very confused by this and could use the help!
2 件のコメント
Chuguang Pan
2019 年 12 月 10 日
The right n*y(n)+delta*(-i*H*psi) is 2x1 matrix, but left y(n+1) is scalar!
採用された回答
Ridwan Alam
2019 年 12 月 10 日
編集済み: Ridwan Alam
2019 年 12 月 10 日
If I understood it right, your x and y are supposed to be 2x1 vectors.
gamma=0.5;
H=[(gamma*i) -1;-1 -i*gamma];
% G=(2:2); % where is it used?
psi=zeros(2,1);
psi(1)=1;
psi(2)=0;
T=10;
N=1000;
deltat=T/N;
x1=0.5;
y1=0;
t=0;
x=[x1; x1];
y=[y1; y1];
t1=[]; int1 = []; int2 = [];
for t=1:N
t1(end+1)=t;
x(:,t+1)=x(:,t)+y(:,t)*deltat;
y(:,t+1)=y(:,t)+deltat*(-i*H*psi);
intensity=abs(y(:,t+1)).^2;
int1(end+1)=intensity(1);
int2(end+1)=intensity(2);
end
plot (t1,int1,'-*');
hold on;
plot (t1,int2,'-*');
hold off;
Hope this helps!
0 件のコメント
その他の回答 (0 件)
参考
カテゴリ
Help Center および File Exchange で Special Functions についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!