Skip to content

Latest commit

 

History

History
224 lines (164 loc) · 10.2 KB

README.md

File metadata and controls

224 lines (164 loc) · 10.2 KB

Start

Description

Start is a sophisticated software prototype designed for optimizing technological processes in vacuum-plasma installations. It focuses on the precise modeling of particle trajectories, gas discharge simulations, and plasma chemical reactions within these installations. The software aims to provide accurate parameters for vacuum-plasma processes, even for non-standard geometries, thereby improving the efficiency and quality of thin-film deposition on substrates.

Features

  • Particle Trajectory Calculation: Simulates the movement of particles within the vacuum chamber using advanced algorithms.
  • Scattering Models: Includes models for hard spheres (HS), variable hard spheres (VHS), and variable soft spheres (VSS).
  • Deposition Process Simulation: Models the deposition of particles on substrates, taking into account various material interactions.
  • Optimization: Optimizes the technological parameters for the deposition process to achieve the best possible outcomes.
  • User Interface: A user-friendly interface developed in Python for ease of use and visualization.

Dependencies

  • Programming Languages: C++17/20, Python 3.7+

  • C++ Libraries and Tools:

    • GCC 13 (GNU Compiler Collection)
    • HDF5
    • CGAL
    • Gmsh
    • Boost
    • GMP
    • TBB
    • json
    • OpenMP (optional)
    • MPI (optional)
    • CUDA (optional)
    • Trilinos
      • Belos: Belos is used for solving large sparse linear systems that arise during the finite element analysis. It provides iterative solvers such as GMRES or CG, which are crucial for efficiently handling systems involving global stiffness matrices.
      • Intrepid2: For defining basis functions and performing operations such as calculating gradients and integrating over finite elements. It plays a central role in the assembly of local stiffness matrices and transforming physical coordinates in the finite element methods.
      • Kokkos: Kokkos provides a performance-portable framework to run the finite element assembly and matrix-vector operations on different hardware architectures (CPUs, GPUs): It is essential for the parallel execution of these operations, ensuring that application scales efficiently across various systems.
      • KokkosKernels: This package complements Kokkos by offering specialized linear algebra and sparse matrix operations optimized for parallelism. This project utilize KokkosKernels for performing matrix-vector operations and solving sparse systems that are fundamental to finite element method (FEM) workflow.
      • MueLu: MueLu serves as a multigrid preconditioner in the project, improving the convergence of iterative solvers like those in Belos. This is particularly important for solving the large, complex systems of equations that arise during finite element analysis.
      • Shards: Helps manage the geometric definitions of the finite elements (such as tetrahedrons), providing a way to handle different element topologies and ensuring correct integration over them during stiffness matrix assembly.
      • Teuchos: Provides utility tools for memory management (smart pointers), parameter lists, and numerical utilities, which project rely on for efficient memory handling and managing solver parameters throughout the finite element computations.
      • Tpetra: Tpetra is used for parallel distributed matrix and vector operations. Project leveraging it for storing and manipulating the global stiffness matrix and solution vectors in a distributed memory environment, ensuring scalability and parallelism across distributed systems like MPI clusters.
  • Python Libraries:

The program uses C++20 features, so ensure your compiler supports this standard. But minimal requirements for the C++ standard is C++17.

HDF5 installation example

To install the necessary dependencies and run the software on Debian-based Linux distributions, follow these steps:

  • Install Python 3.7
  • Install pip dependency
pip install h5py
  • Install development package
sudo apt-get update
sudo apt-get install -y libhdf5-dev
  • Add the following environment variables to your ~/.bashrc to ensure the HDF5 libraries are correctly linked:
export HDF5_LIBRARY_DIRS=/usr/lib/x86_64-linux-gnu/hdf5/serial
export HDF5_INCLUDE_DIRS=/usr/include/hdf5/serial
export LD_LIBRARY_PATH=/usr/lib/x86_64-linux-gnu/hdf5/openmpi:/usr/lib/x86_64-linux-gnu/hdf5/serial:$LD_LIBRARY_PATH

Technical Specifications

  • Grid Size: 1 to 15 mm
  • Calculation Time:
    • Local PC: 1 to 5 hours
    • Computational Cluster: 1 hour to 10 days
  • Optimization Time: 1 to 24 hours

Installation

To install the necessary dependencies and run the software, follow these steps:

  1. Install Python 3.7 or later.
  2. Install required Python libraries:
pip install PyQt5 h5py gmsh vtk

or just install them from requirements.txt:

pip install -r requirements.txt

Usage

Example: C++ Code Snippet

#include "Particle.h"
#include "RealNumberGenerator.h"
#include "VolumeCreator.h"

int main() {
    // Initialize particle generator
    RealNumberGenerator rng;
    Particle particle = rng.generateParticle();

    // Create volume
    VolumeCreator volume;
    volume.createMesh(particle);

    // Update particle position
    particle.updatePosition(0.01);

    return 0;
}

This snippet demonstrates how to initialize a particle generator, create a mesh volume, and update the particle's position using the updatePosition function.

Example: Python Code Snippet

from PyQt5.QtGui import QDoubleValidator

class CustomSignedDoubleValidator(QDoubleValidator):
    def __init__(self, bottom, top, decimals, parent=None):
        super().__init__(bottom, top, decimals, parent)
        self.decimals = decimals

    def validate(self, input_str, pos):
        # Replace comma with dot for uniform interpretation
        input_str = input_str.replace(',', '.')

        # Allow empty input
        if not input_str:
            return self.Intermediate, input_str, pos

        # Allow '-' if it's the first character
        if input_str == '-':
            return self.Intermediate, input_str, pos

        # Check if the input string is a valid number
        try:
            value = float(input_str)

            # Allow zero value regardless of format
            if value == 0:
                return self.Acceptable, input_str, pos

            # Check if the value is within the valid range
            if self.bottom() <= value <= self.top():
                parts = input_str.split('.')
                if len(parts) == 2 and len(parts[1]) <= self.decimals:
                    return self.Acceptable, input_str, pos
                elif len(parts) == 1:
                    return self.Acceptable, input_str, pos

            return self.Invalid, input_str, pos

        except ValueError:
            return self.Invalid, input_str, pos

This snippet shows how to create a custom validator for a signed double input in PyQt5.

Parameter FEM Accuracy

FEM accuracy is the parameter that manages count of cubature points for the more accurate integration. The following table shows relationship beetween parameters FEM accuracy and Count of cubature points.

FEM accuracy Count of cubature points
1 1
2 4
3 5
4 11
5 14
6 24
7 31
8 43
9 126
10 126
11 126
12 210
13 210
14 330
15 330
16 495
17 495
18 715
19 715
20 1001

Variables to set within .bashrc to work with OpenMP and CUDA

OpenMP Environment Variables

OMP_PROC_BIND=spread: This setting controls how OpenMP threads are distributed across the cores. By setting it to spread, OpenMP threads are distributed across as many processors as possible, which can help maximize memory bandwidth usage and avoid oversubscribing a single core. This setting is optimal for multi-threaded parallelism.

OMP_PLACES=threads: This variable specifies the places on which OpenMP threads can execute. Setting it to threads means that each OpenMP thread is bound to a separate processing unit (core), which further enhances the parallel efficiency of the program by distributing the workload across available CPU cores.

export OMP_PROC_BIND=spread

export OMP_PLACES=threads

or

vim ~/.bashrc and write down the vars within, then write :wq.

CUDA Environment Variables

export CUDA_VISIBLE_DEVICES=0 or any other number of the GPU you want to use. See this source for more info.

Briefly:

Just add the following lines to your .bashrc file:

export CUDA_VISIBLE_DEVICES=0 if you have only one GPU.