Calculating nonequilibrium Green's Functions

In summary, the code does what it is supposed to do, but it does not seem to work correctly when changing the values for gamma_1 or gamma_2 in site number one.
  • #1
danielw96
2
0
TL;DR Summary
I created a Lindbladian for a system of coupled orbitals, and now I want to calculate the interacting non equilibrium Greens function, using the Lehmann representation.
Hey :)
Firstly I want to thank everyone who takes their time to read through this post and who tries to help me.

So the issue is the following:
I wrote a python code that creates a Lindbladian, and I wanted to try to calculate the Greens function using the Lehmann representation.

For the easiest case of one site with no spin this works out. I know that the result is correct, because I used eq. 36 from the following paper: https://arxiv.org/pdf/1312.4586.pdf (this is the paper I will refer to with eq. numbers), which is for the case of non interacting particles, and compared it with the one i get from eq. 43 (Lehmann representation, where I only used the first some since I just wanted to calculate G>+ here) which also includes the case of interaction. Eventually I want to use this for the case of two spins per site, so that's why I am using the formula that also captchers on site interaction between two electrons, but for simplicity reasons I just went to the next step after a one site and no spin case i.e. two sites with no spin that are not coupled.

So I basically set every parameter to zero except for gamma_1 and gamma_2, (eq. 10b) which i individually gave values for each of the two sites. (screenshot). In this case one would expect the result I would get for a single site no spin level with given gamma_1 and gamma_2 values for each of the two sites.

Well and now we get to the reason for my post -> This doesn't work. And even worse if I change the gamma_1 or gamma_2 value for site number one then the result of the greens function calculated from the Lehmann representation also changes for site number two (and vice versa) which makes absolutely no sense, since the two sites are NOT coupled!
However I cannot find the issue with my code, I spent 40 hours in looking for the error, but the code does as far as I could test it everything it's supposed to do.

The Lindbladian itself should be correct, since I not only find the steady state, but also I get consistent results for <N>, as well as the current into and out of each site. I checked the result of <N> for decoupled sites were each site has some gamma_1 and gamma_2 values and it gave me individually what one would expect for single sites i.e. gamma_2/(gamma_1+gamma_2).

I calculated several matrix elements of the Lindbladian in the N - N^tilde = 1 basis (which i need for calculating the greens function) by hand, and all of them were correct.

Also I checked the calculation of the individual terms of the sum of the Greens function in Lehmann representation as shown in eq. 43, and also this function does exactly what it should. -> So what I did was that I let the first annihilation operator act on the right eigenstate of L_+1. This right eigenstate is a superposition of the N - N^tilde = 1 basis and so I checked which states of this basis survives the annihilation. Then my program checks where the corresponding states in the N - N^tilde = 0 basis are, so that I know which components of each L_+1 right eigenstate I have to multiply with the so called left vacuum.

Pretty much the same I did with the creation operator i.e. I let it act on the left eigenstates where it annihilates a particle in each N - N^tilde = 1 state of which each left eigenstates is build up, and multiplied with the corresponding values of the steady state.

You can see in the screenshot called "bases" the two bases N - N^tilde = 0 and = 1, and then in screenshot named "corresponding states" you can see which states my code says are matching after annihilating a particle in the first site, and as you can see (starting numbering from 0) the 1st, 2nd and 3th state of the +1 basis survive and are then |00>|00>, |01>|01>, and |01>|10>, which correspond to 0th, 1st and 2nd state of the 0 basis.

You can find my code attached, the functions of relevance here are called "get_just_L_s", and "get_G_greater", and they are in the file called "main_functions_6_may_1_site" (name is misleading, but originally I planned to use it for a single site, however i then extended two two but can be arbitrarelly choosen)

I hope my explanation of how I proceeded was kinda clear, if not do not hesitate to ask!
Also I am not sure if I gave enough information for you to make a judgement on what might be wrong so if you require anything more just let me know and I'll do my best to provide it.
 

Attachments

  • Gamma matrices.png
    Gamma matrices.png
    1.8 KB · Views: 114
  • bases.png
    bases.png
    2.7 KB · Views: 102
  • corresponding states.png
    corresponding states.png
    1.1 KB · Views: 112
Physics news on Phys.org

FAQ: Calculating nonequilibrium Green's Functions

1. What are nonequilibrium Green's functions?

Nonequilibrium Green's functions are mathematical tools used in quantum mechanics to describe the behavior of a system that is not in thermal equilibrium. They are a way to calculate the probability of a particle or excitation moving from one point to another in a system that is not at equilibrium.

2. How are nonequilibrium Green's functions calculated?

Nonequilibrium Green's functions are calculated using a mathematical approach called the Keldysh formalism. This involves using a contour integration technique to solve for the Green's functions, which describe the propagation of particles in a nonequilibrium system.

3. What are some applications of calculating nonequilibrium Green's functions?

Nonequilibrium Green's functions are used in a variety of fields, including condensed matter physics, quantum field theory, and quantum transport. They are particularly useful for studying systems that are far from equilibrium, such as in nanoscale devices or in high-energy physics experiments.

4. Can nonequilibrium Green's functions be used to describe classical systems?

No, nonequilibrium Green's functions are a quantum mechanical tool and are not applicable to classical systems. They are based on the principles of quantum mechanics, such as superposition and entanglement, and are used to describe the behavior of quantum particles.

5. Are there any limitations to using nonequilibrium Green's functions?

One limitation of using nonequilibrium Green's functions is that they can be computationally intensive, especially for large systems. Additionally, they are only applicable to systems that are close to equilibrium, so they may not accurately describe highly non-equilibrium situations. Furthermore, they do not take into account the effects of interactions between particles, which can be important in certain systems.

Back
Top