Introduction to strain calculation

Here we introduce the theoretical background of the strain and stress calculation in nextnano++. At first we will describe the definition of a strain tensor ε and stress tensor σ and then describe the basis of strain tensor calculation in nextnano++. A strain tensor is used to calculate the shifts and splittings of band-edge energies and piezoelectric charges.

The detailed explanation for the syntax in strain{ } is here: strain{ }.

Table of contents

Strain tensor ε

The calculation of strain effects in nextnano++ is based on linear continuum elasticity theory, in which a crystal can be described by a field of material points with coordinates x. A distortion of the crystal shifts any point to a new position x=x(x). A field of displacement vectors u is defined as the devision between the new position and the original position:

u(x):=x(x)x
../../../_images/displacement_vector.jpg

Figure 2.2.1 The field of displacement vector u at x. This is the vector along which the point that was at the position x moved through the displacement.

A strain tensor ε is defined using this displacement vector:

εij:=12[uixj+ujxi];(i,j=1,2,3)

Strain is dimensionless. The diagonal elements of this strain tensor εii represents the length changes per unit length in xi-direction as described in Figure 2.2.2.

../../../_images/strain_diagonal.jpg

Figure 2.2.2 Deformation of a dilatable string in an unstrained (top) and strained state (bottom). We can see the diagonal element εii=uixi represents the length changes per unit length in xi-direction.

The off-diagonal elements εij(ij) arise due to shear deformations of the crystal. Figure 2.2.3 shows the deformation of an infinitesimal rectangle in x1x2 plane. We can see u2x1=u2(x1+Δx1,x2)u2(x1,x2)Δx=sinαα and u1x2=u1(x1,x2+Δx2)u1(x1,x2)Δx2=sinββ. In these angle changes, αβ2 corresponds to a pure solid-body rotation and α+β2=12[u2x1+u1x2]=ε12 measures the shear strain.

../../../_images/strain_offdiagonal.jpg

Figure 2.2.3 Deformation of an infinitesimal rectangle in a strained state.

By definition strain tensor ε is symmetric (i.e. εij=εji) so the number of components that must be specified is actually 6. Voigt notation is the useful convention in which these 6 independent components are written in form of a 6×1 matrix for short. This notation reads:

111,222,333,234,315,126

and

[ε1ε2ε3ε4ε5ε6]=[ε11ε22ε332ε232ε132ε12]

Stress tensor σ

A stress tensor component σij represents the force towards xj-direction acting on infinitsimal area that is perpendicular to xi-direction. Its unit is the same with pressure ([Pa]=[N/m2]).

../../../_images/stress_tensor.jpg

Figure 2.2.4 The components of stress tensor σ.

In linear approximation, this stress tensor is related to the strain tensor ε by means of Hook’s law:

σij=klCijklεkl

where Cijkl is the component of eleasticity stiffness tensor, which is the forth-order tensor comprising 34=81 components. It’s dimension is the same with stress tensor components and defined as [GPa] in nextnano++. In Voigt notation, C is the form of a 6×6 matrix by putting Cijkl=Cmn (i,j,k,l=1,2,3, m,n=1,...6). Then the Hook’s law reads

[σ1σ2σ3σ4σ5σ6]=[C11C12C13C14C15C16C21C22C23C24C25C26C31C32C33C34C35C36C41C42C43C44C45C46C51C52C53C54C55C56C61C62C63C64C65C66][ε1ε2ε3ε4ε5ε6]

For many crystal structures with high symmetry, many of these coefficients are 0 and some are related to others. The elasticity tensor of zincblende and wurtzite crystals are given by

Czb=[C11C12C12C12C11C12C12C12C11C44C44C44]
Cwz=[C11C12C13C12C11C13C13C13C33C44C44C66]

with C66=12[C11C22] in wurtzite.

These constants are defined in database_nnp.in. You can also overwrite these values in your input file.

  • For zinc-blend materials, for example:

    database{
        binary_zb{
            name = GaAs
            valence = III_V
    
            elastic_consts{
                c11 = 122.1                  # [GPa] elastic constants
                c12 = 56.6                   # 1 * 1011 dyn/cm2 = 10 GPa  ->  12.21 * 1011 dyn/cm2 = 122.1 GPa
                c44 = 60.0                   # The elastic constants are needed for the calculation of the strain in heterostructures.
            }
        }
    }
    
  • For wurtzite materials, for example:

    database{
        binary_zb{
            name = GaN
            valence = III_V
    
            elastic_consts{
                c11 = 390                    # [GPa] elastic constants
                c12 = 145                    # 1 * 1011 dyn/cm2 = 10 GPa  ->  39.0 * 1011 dyn/cm2 = 390 GPa
                c13 = 106                    #
                c33 = 398                    #
                c44 = 105                    # The elastic constants are needed for the calculation of the strain in heterostructures.
            }
        }
    }
    

Strain and stress calculation

Next we will describe how the strain tensor ε and stress tensor σ are determined in general. Then the two types of calculation implemented in nextnano++ are introduced briefly.

In general

The principle of conservation of linear momentum results in the following equations of stress tensor components for i=1,2,3:

j=13σjixj+fi=0

where f is the body force such as gravity. When the boundary conditions are specified, the field of displacement vector u, by which the stress tensor components σij are eventually written, is determined according to these simultaneous differential equations. Then the strain tensor ε and stress tensor σ are also determined from u.

Note

The principle of conservation of angular momentum, on the other hand, results in the symmetricity of stress tensor: σij=σji

The field of displacement vector which satisfies the above balance equations and boundary conditions also minimizes the total potential energy U+VE where U is the elastic strain energy and VE is the potential energy associated with the body force f. This is so called minimum total potential energy principle.

In the linear approximation regime, the elastic energy stored in the whole body is:

U=12VCijklεijεkl dV

When the body force f is assumed to be zero throughout the system, solving the above differential equations is equivalent to find the strain tensor that minimizes this elastic energy U.

In nextnano++

There are two kinds of calculation of strain, pseudomorphic_strain{ } and minimized_strain{ }, in nextnano++. In both of implementations pseudomorphic layer is assumed as the boundary condition between the substrate and the layer grown on this substrate. The substrate is assumed to be so thick that the in-plane lattice constants of the layer is matched to that of substrate. Also, the body force f is assumed to be 0 throughout the structure.

In this assumption, the analytic expressions for strain tensor that satisfies the aforementioned stress balance equations (i.e. that minimizes the elastic energy) can be found for 1D structures. This analytic solution is implemented on pseudomorphic_strain{ }. This feature also works in 2D or 3D but the user must be sure that the model makes sense from a physical point of view (i.e. the 2D/3D structure should consist of different layers along the growth direction whereas the layers must be homogenous along the two perpendicular directions).

On the other hand, minimized_strain{ } calculates the strain tensor by minimizing the elastic energy mentioned before. This can also be used for 1D simulations. In this case, the results will be equivalent to the analytical model pseudomorphic_strain{ }.

The detailed explanation for the syntax in strain{ } is here: strain{ }. Please refer to [AndlauerPhD2009] for more details about these topics.

Last update: nn/nn/nnnn