Constructing operators

Start by importing PauliStrings:

using PauliStrings
import PauliStrings as ps

To construct an operator we first need to declare an empty operator of $N$ qubits:

H = Operator(N)

For the moment, PauliStrings.jl supports a maximum of 64 qubits.

We can add a term of the form $J X_i$ by doing

H += J, "X", i

and a term of the form $J X_iX_j$ by doing

H += J, "X", i, "X", j

Similarly, we add a term of the form $J X_iX_jX_k$ by doing

H += J, "X", i, "X", j, "X", k

etc.

1D transverse Ising model

Let's construct the Hamiltonian of a 1D transverse Ising model $H=-J(\sum_{<i,j>}Z_i Z_j +g \sum_i X_i)$

function ising1D(N, J, g)
    H = Operator(N)
    for j in 1:(N - 1)
        H += "Z",j,"Z",j+1
    end
    H += "Z",1,"Z",N # periodic boundary condition
    for j in 1:N
        H += g,"X",j
    end
    return -J*H
end

Note that the first qubit starts at index 1, following Julia's 1-based index.

Operators can be printed in strings format with the println function:

julia> println(ising1D(3, 1, 0.5))
(-1.0 + 0.0im) Z1Z
(-1.0 + 0.0im) 1ZZ
(-0.5 + 0.0im) 1X1
(-0.5 + 0.0im) X11
(-1.0 + 0.0im) ZZ1
(-0.5 + 0.0im) 11X

2D transverse Ising model

Here we construct a 2D Ising model on a square lattice of L*L sites, with no periodic boundary conditions.

function ising2D(L, J, g)
    H = ps.Operator(L*L)
    for x in 1:L-1
        for y in 1:L
            # convert x,y to qubit index
            i = L*(y-1)+x
            j = L*(y-1)+(x+1)
            # horizontal interaction terms
            H += ('Z',i,'Z',j)
            # convert x,y to qubit index
            i = L*(x-1)+y
            j = L*x+y
            # vertical interaction terms
            H += ('Z',i,'Z',j)
        end
    end
    for j in 1:L*L
        H += g,"X",j
    end
    return -J*H
end