Integration of these kind of functions
1 次查看(过去 30 天)
显示 更早的评论
I want to integrate
data:image/s3,"s3://crabby-images/3b7d9/3b7d96a7cf4c2f3bfa120f3673030aafbb6561f8" alt=""
data:image/s3,"s3://crabby-images/4fd39/4fd39abb9c900a64cb94ef5ba2ac6a40c9fbba8e" alt=""
data:image/s3,"s3://crabby-images/21ba4/21ba4346369a24e0d77558ab9f89cf2454c6659d" alt=""
data:image/s3,"s3://crabby-images/1af55/1af55b37b032a414ff3cf34d6542a2251242613b" alt=""
Note that the integrand does not diverges as long as η is non-zero, however when η is significantly small, the integrand can be very large for some points in
plane. As an example, I have plot the imaginary part of (1,2) componet of the integrand matrix for
and
below. (the other components also follow the same behavior):
data:image/s3,"s3://crabby-images/4f67d/4f67df65f40961ec3e5030586462ab25ea1da2be" alt=""
data:image/s3,"s3://crabby-images/e192e/e192ee9c10dd2eb634e01e735be14bc9a1c60574" alt=""
data:image/s3,"s3://crabby-images/0189d/0189dfe6139b5438bfbbaa5076568d552d0824a7" alt=""
data:image/s3,"s3://crabby-images/fcef8/fcef86d79025b3a3f6172becae184885d254544f" alt=""
It can be seen that when η is small the integrand is fairly smooth and can be integrated easily even with integrate2 function. But when η is small, the integrand has very sharp peaks due to which integral2 fails. To calculate the correct integration with small η by trapz, we need a lot of grid points which makes everything very slow.
Is there a way to calculate this integration with
?
data:image/s3,"s3://crabby-images/1af55/1af55b37b032a414ff3cf34d6542a2251242613b" alt=""
I have analytically calculated the condition for which the integrand shows sharp peaks, that condition is:
data:image/s3,"s3://crabby-images/8004b/8004bb2563fcd7359d5b971bc099498168d34a5e" alt=""
where
are components of matrix H. We could also find the exact
points on which the condition is satisfied.
data:image/s3,"s3://crabby-images/29a0c/29a0c5959a6251ee04e196f1311e9934ad558f70" alt=""
data:image/s3,"s3://crabby-images/8e65c/8e65c10a859d5d6e48d960c2799c72a7421deeff" alt=""
data:image/s3,"s3://crabby-images/10867/108672d1e48c90b3fc656d56b2040f4774158613" alt=""
where x are the roots of equation
and y is all values between -1 and +1. And
data:image/s3,"s3://crabby-images/717d7/717d72600f10a9d2f62b8ea37edc1ead1f284ba4" alt=""
data:image/s3,"s3://crabby-images/1472c/1472cc509bfd878feee2a1d95d9170061033d30d" alt=""
So, for each y there will be 4 roots, x, which will give eight
pionts (four
and four
. From these eight
pionts, we will take only the real
; imaginary
must be neglected. Also for each y there will be two
points (one
and one
.
data:image/s3,"s3://crabby-images/2d676/2d6766caf78cb3424deb19d39fdbc0a600cea600" alt=""
data:image/s3,"s3://crabby-images/d1917/d19175f5c4379ecef1b9fddabf698a4abf5ee8d3" alt=""
data:image/s3,"s3://crabby-images/ea2bf/ea2bfbdb9a94c579908eabc137ccc9e758b1da63" alt=""
data:image/s3,"s3://crabby-images/2d676/2d6766caf78cb3424deb19d39fdbc0a600cea600" alt=""
data:image/s3,"s3://crabby-images/2d676/2d6766caf78cb3424deb19d39fdbc0a600cea600" alt=""
data:image/s3,"s3://crabby-images/2d676/2d6766caf78cb3424deb19d39fdbc0a600cea600" alt=""
data:image/s3,"s3://crabby-images/3b00d/3b00dc061430c91295333e186e8fdd1be3cfce93" alt=""
data:image/s3,"s3://crabby-images/fd074/fd074dcf915210d10b37a5a703c8a4a789660a07" alt=""
data:image/s3,"s3://crabby-images/f3821/f38212c755043394918463d5155edd62d876e44f" alt=""
Is there any way to tell MATLAB to take a lot of gird pionts near
points and then calculate the integration? Or is there any way to calculate this type of integration?
data:image/s3,"s3://crabby-images/f454a/f454a7f6d55261d627002df3319835ddcded5955" alt=""
Code:
clear; clc;
% parameters
E = 4.4;
eta = 0.1;5e-4;
% kx and ky limits and points
dkx = 0.006;
dky = dkx;
xmin = -2*pi/(3*sqrt(3));
xmax = 4*pi/(3*sqrt(3));
ymin = -2*pi/3;
ymax = 2*pi/3;
kxs = xmin:dkx:xmax;
kys = ymin:dky:ymax;
NBZx = length(kxs);
NBZy = length(kys);
% H matrix:
J = 1;
Dz = 0.5;
S = 1;
s0 = eye(2);
sx = [0, 1; 1, 0];
sy = [0, -1i; 1i, 0];
sz = [1, 0; 0, -1];
h0 = 3 * J * S;
hx = @(kx, ky) -J * S * (cos(ky / 2 - (3^(1/2) * kx) / 2) + cos(ky / 2 + (3^(1/2) * kx) / 2) + cos(ky));
hy = @(kx, ky) -J * S * (sin(ky / 2 - (3^(1/2) * kx) / 2) + sin(ky / 2 + (3^(1/2) * kx) / 2) - sin(ky));
hz = @(kx, ky) -2 * Dz * S * (sin(3^(1/2) * kx) + sin((3 * ky) / 2 - (3^(1/2) * kx) / 2) - sin((3 * ky) / 2 + (3^(1/2) * kx) / 2));
H = @(kx, ky) s0 * h0 + sx * hx(kx, ky) + sy * hy(kx, ky) + sz * hz(kx, ky);
%integrand:
G00 = @(kx, ky) inv(E*eye(2) - H(kx,ky) + 1i*eye(2)*eta); %integrand
2 个评论
David Goodmanson
2024-1-17
Hi Luqman,
since G00 appears to be a 2x2 matrix, what quantity are you plotting?
回答(0 个)
另请参阅
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!