Shortcut: SPHERICAL_HARMONIC

Module symfunc
Description Usage
Calculate the values of all the spherical harmonic funtions for a particular value of l. used in 1 tutorialsused in 6 eggs

Output components

This action calculates the values in the following table. These values can be referenced elsewhere in the input by using this Action's label followed by a dot and the name of the value required from the list below.

Name Type Description
rm matrix the real parts of the spherical harmonic values with the m value given
im matrix the real parts of the spherical harmonic values with the m value given

Input

The arguments that serve as the input for this action are specified using one or more of the keywords in the following table.

Keyword Type Description
ARG scalar/vector/matrix the values input to this function

Further details and examples

Calculate the values of all the spherical harmonic funtions for a particular value of l.

This action allows you to the all the spherical harmonic functions for a particular input L value. As discussed in more detail in the article provided above the spherical harmonics this action calculates have the following general form:

Yml(θ,ϕ)=wNeimϕPml(cosθ)

where N is a normalisation constant, Pml is tn associated Legendre Polynomial and w is an optional weight that can be passed in an input argument or simply set equal to one. eiϕ and cos(θ)arecomputedfromtheotherinputarguments,x, yandz$ as follows:

eiϕ=xr+iyrandcos(θ)=zrwherer=x2+y2+z2

At present, the arguments for this action must be matrices. However, it would be easy to add functionality that would allow you to compute this function for scalar or vector input. The arguments must all have the same shape as the two output components will also be matrices that are calculated by applying the function above to each of the elements of the input matrix in turn. The number of components output will be equal to 2(2L+1) and will contain the real and imaginary parts of the Yml functions with the the 2l+1 possible m values.

The following intput provides an example that demonstrates how this function is used:

Click on the labels of the actions for more information on what each action computes
tested on2.11
d: DISTANCE_MATRIXCalculate a matrix of distances between atoms. This action has hidden defaults. More details GROUPthe atoms for which you would like to calculate the adjacency matrix=1-10 COMPONENTS also calculate the components of the vectors connecting the atoms in the contact matrix
c: SPHERICAL_HARMONICCalculate the values of all the spherical harmonic funtions for a particular value of l. More details Lthe value of the angular momentum=1 ARGthe values input to this function=d.x,d.y,d.z
PRINTPrint quantities to a file. More details ARGthe labels of the values that you would like to print to the file=c.rm-n1 FILEthe name of the file on which to output these quantities=real_part_m-1
PRINTPrint quantities to a file. More details ARGthe labels of the values that you would like to print to the file=c.im-n1 FILEthe name of the file on which to output these quantities=imaginary_part_m-1
PRINTPrint quantities to a file. More details ARGthe labels of the values that you would like to print to the file=c.rm-0 FILEthe name of the file on which to output these quantities=real_part_m0
PRINTPrint quantities to a file. More details ARGthe labels of the values that you would like to print to the file=c.im-0 FILEthe name of the file on which to output these quantities=imaginary_part_m0
PRINTPrint quantities to a file. More details ARGthe labels of the values that you would like to print to the file=c.rm-p1 FILEthe name of the file on which to output these quantities=real_part_m+1
PRINTPrint quantities to a file. More details ARGthe labels of the values that you would like to print to the file=c.im-p1 FILEthe name of the file on which to output these quantities=imaginary_part_m+1

The DISTANCE_MATRIX command in the above input computes 3 10×10 matrices. These 3 10×10 matrices are used in the input to the sphierical harmonic command, which in turn outputs 6 10×10 matrices that contain the real and imaginary parts when the three spherical harmonic functions with l=1 are applied element-wise to the above input. These six 10×10 matrices are then output to six separate files.

In the above example the weights for every distance is set equal to one. The following example shows how an argument can be used to set the w values to use when computing the function above.

Click on the labels of the actions for more information on what each action computes
tested on2.11
s: CONTACT_MATRIXAdjacency matrix in which two atoms are adjacent if they are within a certain cutoff. More details GROUPspecifies the list of atoms that should be assumed indistinguishable=1-10 SWITCHthe input for the switching function that acts upon the distance between each pair of atoms. Options for this keyword are explained in the documentation for LESS_THAN.={RATIONAL R_0=1.0}
sc: CONTACT_MATRIXAdjacency matrix in which two atoms are adjacent if they are within a certain cutoff. More details GROUPspecifies the list of atoms that should be assumed indistinguishable=1-10 SWITCHthe input for the switching function that acts upon the distance between each pair of atoms. Options for this keyword are explained in the documentation for LESS_THAN.={RATIONAL R_0=1.0} COMPONENTS also calculate the components of the vectors connecting the atoms in the contact matrix
c: SPHERICAL_HARMONICCalculate the values of all the spherical harmonic funtions for a particular value of l. More details Lthe value of the angular momentum=1 ARGthe values input to this function=sc.x,sc.y,sc.z,s
PRINTPrint quantities to a file. More details ARGthe labels of the values that you would like to print to the file=c.rm-n1 FILEthe name of the file on which to output these quantities=real_part_m-1
PRINTPrint quantities to a file. More details ARGthe labels of the values that you would like to print to the file=c.im-n1 FILEthe name of the file on which to output these quantities=imaginary_part_m-1
PRINTPrint quantities to a file. More details ARGthe labels of the values that you would like to print to the file=c.rm-0 FILEthe name of the file on which to output these quantities=real_part_m0
PRINTPrint quantities to a file. More details ARGthe labels of the values that you would like to print to the file=c.im-0 FILEthe name of the file on which to output these quantities=imaginary_part_m0
PRINTPrint quantities to a file. More details ARGthe labels of the values that you would like to print to the file=c.rm-p1 FILEthe name of the file on which to output these quantities=real_part_m+1
PRINTPrint quantities to a file. More details ARGthe labels of the values that you would like to print to the file=c.im-p1 FILEthe name of the file on which to output these quantities=imaginary_part_m+1

This function is used in the calculation of the Steinhardt order parameters, which are described in detail here.

Syntax

The following table describes the keywords and options that can be used with this action

Keyword Type Default Description
ARG input none the values input to this function
L compulsory none the value of the angular momentum