Multi Particle Process

#include <psMultiParticleProcess.hpp>

The multi particle process is a simple process model that simulates either etching or deposition, where an arbitrary number of particles can be specified. The particles can be neutral or ions, and the model can be used to simulate a wide range of processes. The rate equation for combining the fluxes of the particles has to be provided by the user.

Neutral Particles

Neutral particles are characterized by their sticking probability, which quantifies the likelihood that a neutral particle will adhere to a surface upon impact. This probability ranges between 0 and 1, where:

  • A sticking probability of 1 indicates that the particle will always stick to the surface.
  • A sticking probability of 0 indicates that the particle will always be reflected.

The sticking probability determines the reflection behavior of neutral particles and can be defined specifically for each material within the domain.

Ion Particles

Ion particles are defined by their source exponent, which is the exponent of the power cosine distribution for the initial directions of the ions. The source exponent defines the distribution of the initial directions of the ions. A source exponent of 1 means that the ions are emitted isotropically, while a source exponent of 1000 means that the ions are emitted mostly perpendicular to the surface.

The ion sticking function is defined by the parameters $\theta_{min}$ and $\theta_{max}$. The ion sticking function is a function of the incoming angle $\theta$ that defines the probability that an ion will stick to the surface upon impact. The ion sticking function is a linear function defined as:

\[S(\theta) = \begin{cases} 0 & \text{if } \theta < \theta_{min} \\ 1 & \text{if } \theta > \theta_{max} \\ \frac{\theta - \theta_{min}}{\theta_{max} - \theta_{min}} & \text{otherwise} \end{cases}\]

Ions striking the surface at an angle denoted by $\theta$ relative to the surface normal undergo reflection, where the angular dispersion is characterized by a cosine function centered around the direction of specular reflection defined by $\theta_\textrm{spec}$. This reflection process distinguishes between ions approaching the surface at glancing angles, which undergo nearly perfect specular reflection, and those striking the surface perpendicularly, which undergo nearly diffuse reflection. The ray’s reflected direction is randomly chosen from a cone around the specular direction. The opening angle of this cone is given by the incidence angle $\theta$ or the minimum specified angle $\theta_{min}$.

drawing

Optional Parameters:

Ion can be assigned an energy which can be used to calculate a surface yield. This feature can be activated by setting the mean energy > 0 and is deactivated by setting the mean energy = 0. The energy distribution of the ions is assumed to be Gaussian with a standard deviation of sigmaEnergy. The threshold energy is the energy below which the ion will not sputter the surface, and the energy dependent yield is defined as:

\[Y(E) = \begin{cases} 0 & \text{if } E < E_{\textrm{threshold}} \\ \sqrt{E} - \sqrt{E_{\textrm{threshold}}} & \text{if } E \geq E_{\textrm{threshold}} \end{cases}\]

The inflection angle and n are parameters of the ion energy reduction function, which is used to calculate the energy after reflection. The ion energy reduction function is defined as:

\[E_{\textrm{ref}}= \begin{cases} 1-(1-A)\frac{\frac{\pi}{2}-\theta}{\frac{\pi}{2}-\theta_\textrm{inflect}} & \text{ if } \theta \geqslant \theta_\textrm{inflect} \\ \mathrm{A}\left(\frac{\theta}{\theta_\textrm{inflect}}\right)^{n_l} & \text{ if } \theta<\theta_\textrm{inflect}, \end{cases}\]

where $A = (1 + n(\frac{\pi}{2 \theta_\textrm{inflect}} - 1))^{-1}$.

The angle-dependent sputtering yield is defined as:

\begin{equation} Y(\theta) = (1 + B_{sp}(1-\cos^2(\theta)))\cos(\theta). \end{equation}

Implementation


// default empty constructor
MultiParticleProcess()

// member functions
void addNeutralParticle(NumericType stickingProbability,
                        std::string label = "neutralFlux")

void addNeutralParticle(std::unordered_map<Material, NumericType> materialSticking,
                        NumericType defaultStickingProbability = 1.,
                        std::string label = "neutralFlux")

void addIonParticle(NumericType sourceExponent, 
                    NumericType thetaRMin = 0.,
                    NumericType thetaRMax = 90., 
                    NumericType minAngle = 0.,
                    NumericType B_sp = -1.,
                    NumericType meanEnergy = 0.,
                    NumericType sigmaEnergy = 0.,
                    NumericType thresholdEnergy = 0., 
                    NumericType inflectAngle = 0., 
                    NumericType n = 1,
                    std::string label = "ionFlux")

void setRateFunction(std::function<NumericType(std::vector<NumericType> &, 
                                               const Material &)> rateFunction)

Parameter Description Default Value
stickingProbability Sticking probability of the neutral particle -
sourceExponent Exponent of the power cosine distribution for the initial directions of ions -
thetaRMin $\theta_{min}$ in the ion sticking function 0.0
thetaRMax $\theta_{max}$ in the ion sticking function 90.0
minAngle Minimum angle for the ion reflection 0.0
B_sp Sputtering yield parameter -1.0
meanEnergy Mean initial energy of the ions 0.0
sigmaEnergy Standard deviation of the initial energy of the ions 0.0
thresholdEnergy Threshold energy for ion sputtering 0.0
inflectAngle Inflection angle of the ion energy reduction function 0.0
n Exponent of the ion energy reduction function 1.0

Example usage:

C++

...
auto model = SmartPointer<MultiParticleProcess<NumericType, D>>::New();
std::unordered_map<Material, NumericType> materialSticking{{Material::Si, 0.1}, {Material::Mask, 0.5}};
model->addNeutralParticle(materialSticking, 1.0); // default sticking probability of 1 on all other materials
model->addIonParticle(1000.);

// for material specific rates
auto rateFunction = [](std::vector<NumericType> &fluxes, const Material &material) {
        // fluxes contains the neutral flux at first index and ion flux at second index
        return material == Material::Si ? -(fluxes[0] + fluxes[1]) : 0.;
};
model->setRateFunction(rateFunction);

...

Python

...
model = vps.MultiParticleProcess()
materialSticking = {vps.Material.Si: 0.1, vps.Material.Mask: 0.5}
model.addNeutralParticle(materialSticking, defaultStickingProbability=1.0)
model.addIonParticle(1000.)

# for material specific rates
def rateFunction(fluxes, material):
    if material == vps.Material.Si:
        # fluxes contains the neutral flux at first index and ion flux at second index
        return -sum(fluxes)
    else:
        return 0.

model.setRateFunction(rateFunction)
...