udcm-su / NTMpy

Simulation of multi temperature and multi layer heat diffusion
http://udcm.fysik.su.se/code
MIT License
20 stars 15 forks source link

NTMpy - N-Temperature Model solver

To download pip install NTMpy

To call routines in a script: from NTMpy import NTMpy as ntm

To update to lates version: pip install --upgrade NTMpy

Information and citation refere to NTMpy: An open source package for solving coupled parabolic differential equations in the framework of the three-temperature model paper.

Further information on the solver package itself can be found here: NTMpy.

Documentation and example sessions can be found in the Wiki.


This is a code providing a solution to the heat diffusion in a 1D structure in a 3-temperature model approximation.

We consider:

The equation under consideration is:

where C = specific heat, k = conductivity, G is the coupling constant between the two systems (Electron and Lattice) and are the respective temperatures of the electron lattice and spin system with respect to space x and time t. The superscripts L and E indicate whether a parameter belongs to the electron (E) lattice (L) or spin (S) system and the subindex i denotes to which layer the parameter belongs.

A sketch of the model:

Our approach is to use a combination of finite elements (B-Splines) to approximate the derivation in space and Explicit Euler to approximate the evolution in time. To stay within the stability region of the Explicit Euler algorithm, a well-suited time step is automatically computed.

Example:

Using the material parameters, reported in Ultrafast Spin Dynamics in Ferromagnetic Nickel we consider a 3- 3-temperature system in a Nickel layer. We are able to simulate the reported temperature map for all systems, in accordance with the paper.

Temperature evolution of 3-coupled systems Gaussian laser pulse S(x,t) hitting sample

Here we consider an energy source S(x,t), that is Gaussian in time and decays exponentially, representing a laser pulse hitting the material from the left. Note, that the implemented Transfer Matrix Method makes it easily able to simulate realistic laser sources, taking multiple reflection, different incident angles and polarization into account.

The animation clearly shows the following effects:

  1. The electron system heats up immediately, as expected looking at the equation above.
  2. The heat in the electronic system diffuses along the x-axis.
  3. The heat transfers to the subsystems on longer time scales.

    Working code: 10 Lines to run the simulation + 2 Line for the animated plot

    A short example of code to simulate a nonlinear 2-temperature model with 2 layers

    
    from NTMpy import NTMpy as ntm

Initialize source

s = ntm.source() # default option, Gaussian pulse s.fluence = 1 # Energy per meter square s.FWHM = 2e-12 # Full Width Half Maximum (duration of the pulse) s.t0 = 2e-12 # time the maximum intensity hits s.lambda_vac = 400 # Wavelength of source (in nanometers)

initialize simulation: ntm.simulation(number of temperatures, source)

sim = ntm.simulation(2,s) # Default initial temperature: 300 Kelvin

add material layers:

> non constant quantities are inserted as lambda functions

> if more temperature are used, conductivity and heat capacity are vectors

addlayer ( Length, refractive index, conductivity, Heat Capacity, density, coupling)

sim.addLayer( 30e-9, 1+3j, [ 8, 0], [lambda T: .112T, 450], 6500, 6e17) # first layer sim.addLayer( 80e-9, 1+3j, [24, 12], [lambda T: .025T, 730], 5100, 6e17) # second layer

set final simulation time (in seconds)

sim.final_time = 50e-12

Run simulation

[x,t,phi] = sim.run()

Link the plotting library to the simulation

vs = ntm.visual(sim)

Show animation (like the one in the github page)

vs.animation(1) # input is the animation speed



The ouput `phi` is a 3D array with the following structure:
* the first index selects the temperature.
For example, `phi[0]` is the electron temperature, `phi[1]` is the lattice temperature.
* the second index is the time instant.
`phi[0][0]` contains the initial temperature of the electron system, `phi[0][100]` contains the electron temperature after 100 time steps.
* the third index is the space position
`phi[0][100][10]` is the temperature of the electron system after 100 time steps in the 10th point of the grid.

#### Documentation
Complete documentation and example sessions can be found in the [Wiki](https://github.com/udcm-su/heat-diffusion-1D/wiki)

#### With: 
This is a project from the Ultrafast Dynamics in Condensed Matter group at Stockholm University and at the Ca' Foscari University of Venice. The main contributors are: 
* [Lukas Alber](https://github.com/luksen99) <img align="right" height="100" src="https://github.com/udcm-su/heat-diffusion-1D/blob/Developer/Pictures/CFlogoposvertP207.png"> <img align="right" height="100" src="https://github.com/udcm-su/heat-diffusion-1D/blob/Developer/Pictures/SU.jpg">  <img align="right" height="100" src="https://github.com/udcm-su/heat-diffusion-1D/blob/Developer/Pictures/UDCM_logo.png">
* [Valentino Scalera](https://github.com/VaSca92) 
* [Vivek Unikandanunni](https://github.com/VivekUUnni)
* [Stefano Bonetti](https://udcm.eu/)

#### Cite 

`@article{alber2020ntmpy,
    title={NTMpy: An open source package for solving coupled parabolic differential equations in the framework of the three-temperature model},
    author = {Lukas Alber and Valentino Scalera and Vivek Unikandanunni and Daniel Schick and Stefano Bonetti},
    journal = {Computer Physics Communications},
    year={2021},
    volume = {265},
    pages = {107990},
    issn = {0010-4655},
    doi = {https://doi.org/10.1016/j.cpc.2021.107990},
    url = {https://www.sciencedirect.com/science/article/pii/S0010465521001028}
}`

#### How to contribute : 

Since finding the thermophysical parameters needed to solve the equation under consideration (see above) is currently subject to research, we want to encourage our users to contribute with their knowledge of parameters. That is, please **send us the data of the parameters in use, together with references from literature**. We are working on providing an open-source data base. Also, see [NTMpy](https://github.com/udcm-su/heat-diffusion-1D/edit/master/NTMpy/README.md) page.

Fork from the `Developer`- branch and pull request to merge back into the original `Developer`- branch. 
Working updates and improvements will then be merged into the `Master` branch, which will always contain the latest working version.

#### Dependencies:

[Numpy](http://www.numpy.org/)

[Matplotlib](https://matplotlib.org/)

[B-splines](https://github.com/johntfoster)

[Progressbar](https://pypi.org/project/tqdm/2.2.3/)

Note that by downloading the package via `pip install NTMpy` a routine, which automatically checks if all the required packages exist on the local machine is implemented. If one of the dependent pip packages, listed here, is missing an automatic download is initiated.