LUQMAN SALEEM
21600778
Calculation Method:
I am using MATLAB for coding and SI units throughout whole calculation. The detailed code is
provided in the end of this document. Ive defined 6x6 Hamiltonian with variable named
Hamiltonian. (Full forms of all other variables used in my code are given in Table I). There are
two parts of Hamiltonian components, Pikusbir (Strain) Part and Luttinger Kohn. Earlier remain
same in a given type of layer over InP substrate while later changes with change in kpoints.
1. GaAs
2. InAs
3. Ga0.47In0.53As
In first, second and third case I put x=1, x=0 and x=0.47 respectively. Values of parameters were
given for first two cases while for third case it was given that we can find values by linear
extrapolation of first two cases except for Energy band gap that is calculated by equation:
Hamiltonian gives plots for Valence band only (heavy hole (HH), light hole (LH) and split off (SO)
bands). To get the conduction band I have used the equation given in detailed discussion of
book Physics of optoelectronics devices.
I placed Hamiltonian and Conduction band equation in for loop in which value of k points is
changing with step of 1 from 1 to 1000. At the end of for loop, after putting specific value of k in
equations, I used eig() function of MATLAB to find eigenvalues of Hamiltonian and stored it in
another variable named Energy, similarly value of conduction band equation for specific k
value is also saved in variable named CB.
After for loop I had 6x1000 matrix of 6 eigenvalues for each 1000 k points, I get real values and
sorted them using real() and sort() functions. At the end I plot this sort matrix and conduction
band EC variable verses kpoints.
InAs:
Ga0.47In0.53As:
Table I
Variable name in Description Variable name in Description
Code Code
hbar Hamiltonian Hamiltonian
m0 Rest electron mass Ec Conduction band
calculation equation
e Electron charge Exx, Eyy, Ezz Strain in directions
selector Variable that take g1, g2, g3 Luttinger parameters
input to decide which
graph to show.
a0 Lattice constant of meff Effective mass
substrate (InP)
al Lattice constant of k, kx, ky, kz kpoints in 3D
layer (GaAs, InAs or
GaInAs)
Delta Split off parameter Energy Variable that stores
eigenvalues of
Hamiltonian
Eg Energy band gap CB Variable that stores
values for conduction
band
ac, av, a, b, d Deformation Pe, Re, Qe, Se Pikusbir part of
potential Parameters Hamiltonian
C11, C12, C44 Strain parameters Pk, Rk, Qk, Sk Luttinger part of
Hamiltonian.
H** Hamiltonian
components
Code:
%{
Project#1 of Special Topics In Applied Physics III
%By: LUQMAN SALEEM, ID:21600778
%}
clear all;
close all;
clc;
%Constants
hbar=1.054e34; %in SI Units
m0=9.1e31; %mass of electron
hm=hbar^2/(2*m0);
e=1.6e19; %charge of electron
%Parameters
selector=input('Enter 1 for GaAs, 2 for InAs and 3 for GaInAs: ');
a0=5.8688e10; %Substrate InP lattice
constant
if selector==1
al=5.6533e10; %Parameters for GaAs,
delta=0.34;
Eg=1.519;
ac=7.17;
av=1.19;
a=8.33;
b=1.7;
d=4.55;
C11=11.879;
C12=5.376;
C44=5.94;
Exx=(a0al)/al;
Eyy=Exx;
Ezz=2*C12*Exx/C11;
Exz=0;
Eyz=0;
Exy=0;
g1=6.85; %Luttinger parameters,
g1, g2 and g3
g2=2.1;
g3=2.9;
meff=0.067;
elseif selector==2 %for InAs, selector2
al=6.0584e10;
Eg=0.42;
delta=0.38;
ac=5.08;
av=1;
a=6.08;
b=1.8;
d=3.6;
C11=8.329;
C12=4.526;
C44=3.96;
Exx=((a0al)/al);
Eyy=Exx;
Ezz=2*C12/C11*Exx;
Exy=0;
Exz=0;
Eyz=0;
meff=0.023;
g1=20.4;
g2=8.3;
g3=9.1;
else
x=0.468; %for GaInAs
al=5.65e10*x+(1x)*6.0584e10; %lattice constant using formula
Eg=0.324+0.7*x+0.4*(x^2);
delta=(0.34+0.38)/2; %taking value using linear
relation
ac=(7.175.08)/2;
av=(1.16+1)/2;
a=(8.336.08)/2;
b=(1.71.9)/2;
d=(4.553.6)/2;
C11=(11.879+8.329)/2;
C12=(5.376+4.526)/2;
C44=(5.94+3.96)/2;
meff=(0.067+0.023)/2;
Exx=((a0al)/al);
Eyy=Exx;
Ezz=2*C12/C11*Exx;
Exy=0;
Exz=0;
Eyz=0;
g1=(6.85+20.4)/2;
g2=(2.1+8.3)/2;
g3=(2.9+ 9.1)/2;
end
%k points
k=zeros(3,1000); %k point matrix
k(1,1:500)=linspace(1,0,500);
k(2,1:500)=linspace(1,0,500);
k(3,1:500)=linspace(1,0,500);
k(3,501:1000)=linspace(0,1,500);
k=k*(2*pi/a0); %Real space k point matrix
%END of PROGRAM
