tJ
A block in a \(t-J\) type Hilbert space, i.e. fermions with \(\uparrow, \downarrow\) spin excluding doubly occupied sites.
Constructors
Name | Description | Default |
---|---|---|
nsites | number of sites (integer) | |
nup | number of "up" electrons (integer) | |
ndn | number of "dn" electrons (integer) | |
irrep | Irreducible Representation of the symmetry group | |
backend | backend used for coding the basis states | auto |
The parameter backend
chooses how the block is coded internally. By using the default parameter auto
the backend is chosen automatically. Alternatives are 32bit
, 64bit
.
Iteration
An tJ block can be iterated over, where at each iteration a ProductState representing the corresponding basis state is returned.
Methods
index
Returns the index of a given ProductState in the basis of the tJ block.
1-indexing
In the C++ version, the index count starts from "0" whereas in Julia the index count starts from "1".
nsites
Returns the number of sites of the block.
size
Returns the size of the block, i.e. its dimension.
dim
Returns the dimension of the block, same as "size" for non-distributed blocks.
isreal
Returns whether the block can be used with real arithmetic. Complex arithmetic is needed when a Representation is genuinely complex.
Usage Example
int N = 4;
int nup = 2;
int ndn = 1;
// without permutation symmetries
auto block = tJ(N, nup, ndn);
XDIAG_SHOW(block);
// with permutation symmetries
auto p1 = Permutation({0, 1, 2, 3});
auto p2 = Permutation({1, 2, 3, 0});
auto p3 = Permutation({2, 3, 0, 1});
auto p4 = Permutation({3, 0, 1, 2});
auto group = PermutationGroup({p1, p2, p3, p4});
auto irrep = Representation(group, arma::vec{1, -1, 1, -1});
auto block_sym = tJ(N, nup, ndn, irrep);
XDIAG_SHOW(block_sym);
XDIAG_SHOW(block_sym.nsites());
XDIAG_SHOW(block_sym.size());
// Iteration
for (auto pstate : block_sym) {
Log("{} {}", to_string(pstate), index(block_sym, pstate));
}
N = 4
nup = 2
ndn = 1
# without permutation symmetries
block = tJ(N, nup, ndn)
@show block
# with permutation symmetries
p = Permutation([2, 3, 4, 1])
group = PermutationGroup([p^0, p^1, p^2, p^3])
rep = Representation(group, [1.0, -1.0, 1.0, -1.0])
block_sym = tJ(N, nup, ndn, rep)
@show block_sym
@show nsites(block_sym)
@show size(block_sym)
# Iteration
for pstate in block_sym
@show pstate, index(block_sym, pstate)
end