Index
start module-attribute
¶
A Program starting point, alias of empty [ListOfLocations
][bloqade.ir.location.list.ListOfLocations].
- Next possible steps to build your program are:
- Specify which level coupling to address with:
- continue/start building your geometry with:
start.add_position()
: to add atom(s) to current register. It will accept:- A single coordinate, represented as a tuple (e.g.
(5,6)
) with a value that can either be:- integers:
(5,6)
- floats:
(5.1, 2.5)
- strings (for later variable assignment):
("x", "y")
Scalar
objects:(2*cast("x"), 5+cast("y"))
- integers:
- A list of coordinates, represented as a list of types mentioned previously.
- A numpy array with shape (n, 2) where n is the total number of atoms
- A single coordinate, represented as a tuple (e.g.
AtomArrangement ¶
Bases: ProgramStart
, TransformTrait
BoundedBravais ¶
Bases: AtomArrangement
Source code in src/bloqade/ir/location/bravais.py
__match_args__ class-attribute
instance-attribute
¶
Base classe for Bravais lattices AtomArrangement
.
n_dims property
¶
dimension of the lattice
Returns:
Name | Type | Description |
---|---|---|
int | dimension of the lattice |
coordinates ¶
calculate the coordinates of a cell in the lattice given the cell index.
Source code in src/bloqade/ir/location/bravais.py
scale ¶
Scale the current location with a factor.
(x,y) -> factor*(x,y)
Parameters:
Name | Type | Description | Default |
---|---|---|---|
factor | str | Real | Decimal | Scalar | scale factor | required |
Returns:
Name | Type | Description |
---|---|---|
BoundedBravais | BoundedBravais | The lattice with the scaled locations |
Source code in src/bloqade/ir/location/bravais.py
Chain ¶
Bases: BoundedBravais
Chain lattice.
- 1D lattice
- primitive (cell) vector(s)
- a1 = (1,0).
- unit cell (1 atom(s))
- loc (0,0)
Parameters:
Name | Type | Description | Default |
---|---|---|---|
L | int | number of sites in the chain | required |
lattice_spacing | (Scalar, Real) | lattice spacing. Defaults to 1.0. | 1.0 |
- Possible Next: continue with
.
to see possible next step in auto-prompt supported setting (IPython, IDE ...)
Source code in src/bloqade/ir/location/bravais.py
Honeycomb ¶
Bases: BoundedBravais
Honeycomb lattice.
- 2D lattice
- primitive (cell) vector(s)
- a1 = (1, 0)
- a2 = (½, sqrt(3)/2)
- unit cell (2 atom(s))
- loc1 (0, 0)
- loc2 (½, 1/(2*sqrt(3))
Parameters:
Name | Type | Description | Default |
---|---|---|---|
L | int | number of sites in linear direction. n_atoms = L * L * 2. | required |
lattice_spacing | (Scalar, Real) | lattice spacing. Defaults to 1.0. | 1.0 |
- Possible Next: continue with
.
to see possible next step in auto-prompt supported setting (IPython, IDE ...)
Source code in src/bloqade/ir/location/bravais.py
Kagome ¶
Bases: BoundedBravais
Kagome lattice.
- 2D lattice
- primitive (cell) vector(s)
- a1 = (1, 0)
- a2 = (½, sqrt(3)/2)
- unit cell (3 atom(s))
- loc1 (0, 0)
- loc2 (0.5, 0)
- loc3 (0.25 ,0.25sqrt(3))
Parameters:
Name | Type | Description | Default |
---|---|---|---|
L | int | number of sites in linear direction. n_atoms = L * L. | required |
lattice_spacing | (Scalar, Real) | lattice spacing. Defaults to 1.0. | 1.0 |
- Possible Next: continue with
.
to see possible next step in auto-prompt supported setting (IPython, IDE ...)
Source code in src/bloqade/ir/location/bravais.py
Lieb ¶
Bases: BoundedBravais
Lieb lattice.
- 2D lattice
- primitive (cell) vector(s)
- a1 = (1, 0)
- a2 = (0, 1)
- unit cell (3 atom(s))
- loc1 (0, 0)
- loc2 (0.5, 0)
- loc3 (0 ,0.5)
Parameters:
Name | Type | Description | Default |
---|---|---|---|
L | int | number of sites in linear direction. n_atoms = L * L. | required |
lattice_spacing | (Scalar, Real) | lattice spacing. Defaults to 1.0. | 1.0 |
- Possible Next: continue with
.
to see possible next step in auto-prompt supported setting (IPython, IDE ...)
Source code in src/bloqade/ir/location/bravais.py
ParallelRegister ¶
Bases: ProgramStart
Parallel Register
Source code in src/bloqade/ir/location/base.py
Rectangular ¶
Bases: BoundedBravais
Rectangular lattice.
- 2D lattice
- primitive (cell) vector(s)
- a1 = (1,0)
- a2 = (0,1)
- unit cell (1 atom(s))
- loc (0,0)
Parameters:
Name | Type | Description | Default |
---|---|---|---|
width | int | number of sites in x direction. | required |
height | int | number of sites in y direction. | required |
lattice_spacing_x | (Scalar, Real) | lattice spacing. Defaults to 1.0. | 1.0 |
lattice_spacing_y | (Scalar, Real) | lattice spacing in y direction. optional. | None |
- Possible Next: continue with
.
to see possible next step in auto-prompt supported setting (IPython, IDE ...)
Source code in src/bloqade/ir/location/bravais.py
Square ¶
Bases: BoundedBravais
Square lattice.
- 2D lattice
- primitive (cell) vector(s)
- a1 = (1,0)
- a2 = (0,1)
- unit cell (1 atom(s))
- loc (0,0)
Parameters:
Name | Type | Description | Default |
---|---|---|---|
L | int | number of sites in linear direction. n_atoms = L * L. | required |
lattice_spacing | (Scalar, Real) | lattice spacing. Defaults to 1.0. | 1.0 |
- Possible Next: continue with
.
to see possible next step in auto-prompt supported setting (IPython, IDE ...)
Source code in src/bloqade/ir/location/bravais.py
Triangular ¶
Bases: BoundedBravais
Triangular lattice.
- 2D lattice
- primitive (cell) vector(s)
- a1 = (1, 0)
- a2 = (½, sqrt(3)/2)
- unit cell (1 atom(s))
- loc (0, 0)
Parameters:
Name | Type | Description | Default |
---|---|---|---|
L | int | number of sites in linear direction. n_atoms = L * L. | required |
lattice_spacing | (Scalar, Real) | lattice spacing. Defaults to 1.0. | 1.0 |
- Possible Next: continue with
.
to see possible next step in auto-prompt supported setting (IPython, IDE ...)