clear all; clc; t1 = 1; % hopping parameter along x, y, z directions t2 = t1/sqrt(2); % hopping parameter along body diagonals a = 1; % lattice constant k = linspace(-pi/a, pi/a, 100); % wave vector N = length(k); % number of points in k-space % define the tight binding Hamiltonian H = zeros(N,N); for i=1:N-1 H(i,i+1) = -t1; H(i+1,i) = -t1; end H(1,N) = -t1; H(N,1) = -t1; for i=1:4:N-3 H(i,i+2) = -t2; H(i+2,i) = -t2; H(i+1,i+3) = -t2; H(i+3,i+1) = -t2; end for i=1:2:N-1 H(i,i+3) = -t2; H(i+3,i) = -t2; end % calculate the eigenvalues of the Hamiltonian E = eig(H); % plot the band structure plot(k, E, 'b'); hold on; plot(k, zeros(size(k)), 'k--'); xlabel('k'); ylabel('E'); title('Band structure');怎么检查k长度是否正确
时间: 2024-02-20 11:56:57 浏览: 83
可以使用MATLAB内置函数`length`检查向量的长度是否正确。在这个例子中,应该检查生成的$k$向量的长度是否为100,即:
```MATLAB
if length(k) == 100
disp('Length of k is correct.');
else
disp('Length of k is incorrect.');
end
```
上述代码会检查$k$向量的长度是否为100,如果长度正确,则输出"Length of k is correct.",否则输出"Length of k is incorrect."。可以将上述代码添加到原始代码中以检查$k$向量的长度是否正确。
相关问题
clear,clc syms x fun=cos(2*x); fourier(fun)
在MATLAB中,您可以使用 `syms` 命令定义符号变量,然后使用 `fourier` 函数计算傅里叶变换。
下面是您提供的代码示例:
```
clear, clc
syms x
fun = cos(2*x);
fourier(fun)
```
输出结果为:
```
ans =
(2^(1/2)*pi*dirac(ksi - 2))/2 - (2^(1/2)*pi*dirac(ksi + 2))/2
```
其中,`dirac` 函数表示狄拉克函数,`ksi` 表示频率变量。因此,这个结果表示 `cos(2x)` 的傅里叶变换为 `(2^(1/2)*pi*dirac(ksi - 2))/2 - (2^(1/2)*pi*dirac(ksi + 2))/2`。
% clc % clear all % a=20e-9; % eps0=8.854e-12; % eps_h=70eps0; % sigma_h=0.1; % eps_i=12eps0; % sigma_i=500;
这段代码是MATLAB代码,主要实现的是对一些变量进行赋值操作。其中:
% clc:清空命令窗口
% clear all:清除所有变量
% a=20e-9:将20乘以10的负9次方赋值给变量a
% eps0=8.854e-12:将8.854乘以10的负12次方赋值给变量eps0
% eps_h=70*eps0:将70乘以eps0的值赋值给变量eps_h
% sigma_h=0.1:将0.1赋值给变量sigma_h
% eps_i=12*eps0:将12乘以eps0的值赋值给变量eps_i
% sigma_i=500:将500赋值给变量sigma_i
如果您需要进一步了解这些变量的含义和用途,可以提出相关问题。
阅读全文
相关推荐
















