A pythonic Ising model simulation
Project description
Ising
A pythonic implementation of the Ising model.
Check the example for more.
Lattice
This is the main place of the Ising model, we have to initialize it with a tuple of the lattice shape that can be of any dimension or size. The lattice can be initialized with a random state (you can choose the state ratio up) or all in a state 1 or -1.
arguments:
-
shape:
type: tuple(int)
The shape of the lattice is tested for 1 to 4 dimension. Every values of shape must be > 0
Optionnal:
-
all:
type: int == 1 or -1
Set the state at all 1 or -1 it overpass the r parrameter.
-
r:
type: float in [0, ..., 1]
Set a random state with a ratio r of 1 in the lattice (default r = 0.5).
-
adj:
type: numpy.array
A vector of vector: is the representation of the spin interaction.
0 J 0 J # J 0 J 0 Will be written as [[1,0],[-1,0],[0,1],[0,-1]]
As default it's the left right up down direct neighbor matrix will be genereted (whatever this mean in 4 or more dimensions).
-
J:
type: numpy.array or float
Is the interraction between spins, if J is an array he as to be the same length than adj.
(you can choose to make anisotropic iteractions !!)
-
B:
type: numpy.array or float
Is the magnetic field imposed on the lattice, if B is an array he as to have the same shape of the lattice
-
beta:
type: float
Beta is 1/(Kb * T) with T the absolute temp, and Kb is the Boltzmann constant.
Methods
randomize(self, ratio=0.5):
Randomize th lattice state with a given ratio of up state.
arguments:
Optionnal:
-
ratio:
type: float in [0, ..., 1]
The ratio of up state.
all(self, state):
Set all the lattice to the same state.
arguments:
-
state:
type: int == -1 or 1
Value of the spin site.
mag(self):
Compute the magnetization of the lattice.
returns:
-
Magnetization
type: float
Magnetization of the lattice.
hamiltonian(self):
Compute the Halmitonian of each spin.
returns:
-
local_Hamiltonian:
type: numpy array
The Hamiltonian calculated for each spin.
H(self):
Compute the Hamiltonian of the lattice.
returns:
-
Hamiltonian
type: float
Hamiltonian of the lattice.
mH(self):
Compute the mean value of the Hamiltonian.
returns:
type: float
Mean value of the Hamiltonian.
get_state(self):
Method to get the state of the lattice.
returns:
-
state:
type: numpy array
Return the copy of the state.
set_state(self, state):
Method to set the state of the lattice.
arguments:
-
state:
type: numpy array
The new state.
Metropolis.algorithm
Is the class who solve the Ising model with the Metropolis algorithm
Implementation of the Metropolis algorithm
arguments:
- for the arguments look the lattice class.
Methods
step(self, n=0):
step apply the metropolis algorithm on n spin once
arguments:
Optional:
-
n:
type: int
n must be strictly positive is the size of the sample
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file isingm-1.0.3.tar.gz.
File metadata
- Download URL: isingm-1.0.3.tar.gz
- Upload date:
- Size: 17.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.0.5 CPython/2.7.17 Linux/5.3.0-46-generic
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
33d8bb42719cd73ced8ef4a8aa17412d7ed2a24b99aea16c3451a2348378dadc
|
|
| MD5 |
22e7857e2516754d84ffe03d79e3c667
|
|
| BLAKE2b-256 |
73af05fbfc822632ca03a49ae8dacbdb56525619d803bb22391684b0c6e6d843
|
File details
Details for the file isingm-1.0.3-py3-none-any.whl.
File metadata
- Download URL: isingm-1.0.3-py3-none-any.whl
- Upload date:
- Size: 18.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.0.5 CPython/2.7.17 Linux/5.3.0-46-generic
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
861c6a3b78d3dfdea9160d0e0ba2536c14f4a5b44cfd1a902a26466d219203a8
|
|
| MD5 |
33e52cd0b831aa7942c89538091e73b6
|
|
| BLAKE2b-256 |
161bdbbecf60a99c460f92746b699456632efd62e1775726a87e0991230e92af
|