You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
grogu/test.ipynb

1999 lines
168 KiB

3 months ago
{
"cells": [
{
"cell_type": "code",
"execution_count": 13,
3 months ago
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"'0.14.3'"
]
},
"execution_count": 13,
"metadata": {},
"output_type": "execute_result"
}
],
3 months ago
"source": [
"from tqdm import tqdm\n",
"from sys import getsizeof\n",
"from timeit import default_timer as timer\n",
"\n",
3 months ago
"import numpy as np\n",
"import sisl\n",
"from src.grogu_magn.useful import *\n",
3 months ago
"from mpi4py import MPI\n",
"import pickle\n",
3 months ago
"from numpy.linalg import inv\n",
"import warnings\n",
"\n",
"# runtime information\n",
"times = dict()\n",
"times[\"start_time\"] = timer()\n",
"########################\n",
3 months ago
"# it works if data is in downloads folder\n",
"########################\n",
"sisl.__version__"
3 months ago
]
},
{
"cell_type": "code",
"execution_count": 14,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"-12.806878959999999"
]
},
"execution_count": 14,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"dat = sisl.io.siesta.eigSileSiesta(\n",
" \"/Users/danielpozsar/Downloads/nojij/Fe3GeTe2/monolayer/soc/lat3_791/Fe3GeTe2.EIG\"\n",
")\n",
"dat.read_data().min()"
]
},
{
"cell_type": "code",
"execution_count": null,
3 months ago
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"================================================================================================================================================================\n",
"Input file: \n",
"/Users/danielpozsar/Downloads/nojij/Fe3GeTe2/monolayer/soc/lat3_791/Fe3GeTe2.fdf\n",
"Output file: \n",
"Fe3GeTe2.pickle\n",
"Number of nodes in the parallel cluster: 1\n",
"================================================================================================================================================================\n",
"Cell [Ang]: \n",
"[[ 3.79100000e+00 0.00000000e+00 0.00000000e+00]\n",
" [-1.89550000e+00 3.28310231e+00 0.00000000e+00]\n",
" [ 1.25954923e-15 2.18160327e-15 2.05700000e+01]]\n",
"================================================================================================================================================================\n",
"DFT axis: \n",
"[0 0 1]\n",
"Quantization axis and perpendicular rotation directions:\n",
"[1 0 0] --» [array([0, 1, 0]), array([0, 0, 1])]\n",
"[0 1 0] --» [array([1, 0, 0]), array([0, 0, 1])]\n",
"[0 0 1] --» [array([1, 0, 0]), array([0, 1, 0])]\n",
"================================================================================================================================================================\n",
"Parameters for the contour integral:\n",
"Number of k points: 100\n",
"k point directions: xy\n",
"Ebot: -13\n",
"Eset: 60\n",
"Esetp: 10000\n",
"================================================================================================================================================================\n",
"Setup done. Elapsed time: 291.062782833 s\n",
"================================================================================================================================================================\n"
]
}
],
3 months ago
"source": [
"################################################################################\n",
"#################################### INPUT #####################################\n",
"################################################################################\n",
"path = (\n",
" \"/Users/danielpozsar/Downloads/nojij/Fe3GeTe2/monolayer/soc/lat3_791/Fe3GeTe2.fdf\"\n",
")\n",
"outfile = \"Fe3GeTe2\"\n",
"\n",
3 months ago
"# this information needs to be given at the input!!\n",
"scf_xcf_orientation = np.array([0, 0, 1]) # z\n",
3 months ago
"# list of reference directions for around which we calculate the derivatives\n",
"# o is the quantization axis, v and w are two axes perpendicular to it\n",
"# at this moment the user has to supply o,v,w on the input.\n",
3 months ago
"# we can have some default for this\n",
"ref_xcf_orientations = [\n",
" dict(o=np.array([1, 0, 0]), vw=[np.array([0, 1, 0]), np.array([0, 0, 1])]),\n",
" dict(o=np.array([0, 1, 0]), vw=[np.array([1, 0, 0]), np.array([0, 0, 1])]),\n",
" dict(o=np.array([0, 0, 1]), vw=[np.array([1, 0, 0]), np.array([0, 1, 0])]),\n",
"]\n",
"magnetic_entities = [\n",
" dict(atom=3, l=2),\n",
" dict(atom=4, l=2),\n",
" dict(atom=5, l=2),\n",
"]\n",
"pairs = [\n",
" dict(ai=0, aj=1, Ruc=np.array([0, 0, 0])),\n",
" dict(ai=0, aj=2, Ruc=np.array([0, 0, 0])),\n",
" dict(ai=1, aj=2, Ruc=np.array([0, 0, 0])),\n",
" dict(ai=0, aj=1, Ruc=np.array([1, 0, 0])),\n",
" dict(ai=0, aj=2, Ruc=np.array([1, 0, 0])),\n",
" dict(ai=1, aj=2, Ruc=np.array([1, 0, 0])),\n",
" dict(ai=0, aj=1, Ruc=np.array([-1, 0, 0])),\n",
" dict(ai=0, aj=2, Ruc=np.array([-1, 0, 0])),\n",
" dict(ai=1, aj=2, Ruc=np.array([-1, 0, 0])),\n",
" dict(ai=0, aj=1, Ruc=np.array([0, 1, 0])),\n",
" dict(ai=0, aj=2, Ruc=np.array([0, 1, 0])),\n",
" dict(ai=1, aj=2, Ruc=np.array([0, 1, 0])),\n",
" dict(ai=0, aj=1, Ruc=np.array([0, -1, 0])),\n",
" dict(ai=0, aj=2, Ruc=np.array([0, -1, 0])),\n",
" dict(ai=1, aj=2, Ruc=np.array([0, -1, 0])),\n",
"]\n",
"\n",
3 months ago
"# Brilloun zone sampling and Green function contour integral\n",
"kset = 10\n",
"kdirs = \"xy\"\n",
"ebot = -13\n",
"eset = 60\n",
"esetp = 10000\n",
"################################################################################\n",
"#################################### INPUT #####################################\n",
"################################################################################\n",
3 months ago
"\n",
"# MPI parameters\n",
"comm = MPI.COMM_WORLD\n",
"size = comm.Get_size()\n",
"rank = comm.Get_rank()\n",
"root_node = 0\n",
"\n",
"# rename outfile\n",
"if not outfile.endswith(\".pickle\"):\n",
" outfile += \".pickle\"\n",
"\n",
"simulation_parameters = dict(\n",
" path=path,\n",
" outpath=outfile,\n",
" scf_xcf_orientation=scf_xcf_orientation,\n",
" ref_xcf_orientations=ref_xcf_orientations,\n",
" kset=kset,\n",
" kdirs=kdirs,\n",
" ebot=ebot,\n",
" eset=eset,\n",
" esetp=esetp,\n",
" parallel_size=size,\n",
")\n",
"\n",
"# digestion of the input\n",
"# read sile\n",
"fdf = sisl.get_sile(path)\n",
"# read in hamiltonian\n",
"dh = fdf.read_hamiltonian()\n",
"simulation_parameters[\"cell\"] = fdf.read_geometry().cell\n",
"\n",
"# unit cell index\n",
"uc_in_sc_idx = dh.lattice.sc_index([0, 0, 0])\n",
"\n",
"if rank == root_node:\n",
" print_parameters(simulation_parameters)\n",
" times[\"setup_time\"] = timer()\n",
" print(f\"Setup done. Elapsed time: {times['setup_time']} s\")\n",
" print(\n",
" \"================================================================================================================================================================\"\n",
" )"
3 months ago
]
},
{
"cell_type": "code",
"execution_count": 23,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"xyz[-3:]: red, green, blue\n"
]
},
{
"name": "stderr",
"output_type": "stream",
"text": [
"/Users/danielpozsar/Documents/oktatás/elte/phd/grogu_project/.venv/lib/python3.9/site-packages/matplotlib/cbook.py:1762: ComplexWarning: Casting complex values to real discards the imaginary part\n",
" return math.isfinite(val)\n",
"/Users/danielpozsar/Documents/oktatás/elte/phd/grogu_project/.venv/lib/python3.9/site-packages/matplotlib/cbook.py:1398: ComplexWarning: Casting complex values to real discards the imaginary part\n",
" return np.asarray(x, float)\n"
]
},
{
"data": {
"image/png": "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
"text/plain": [
"<Figure size 1500x500 with 2 Axes>"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"data": {
"image/png": "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
"text/plain": [
"<Figure size 1500x500 with 3 Axes>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"import matplotlib.pyplot as plt\n",
"\n",
"plt.figure(figsize=(15, 5))\n",
"plt.subplot(121)\n",
"plt.plot(np.sort(dh.eigh()))\n",
"plt.grid()\n",
"plt.subplot(122)\n",
"DOS = sisl.physics.electron.DOS(np.linspace(-15, 85, 50), dh.eig())\n",
"plt.plot(DOS, np.linspace(-15, 85, 50))\n",
"\n",
"coords = dh.xyz[-3:]\n",
"\n",
"\n",
"plt.figure(figsize=(15, 5))\n",
"plt.subplot(131)\n",
"plt.scatter(coords[:, 0], coords[:, 2], color=[\"r\", \"g\", \"b\"])\n",
"plt.xlabel(\"x\")\n",
"plt.ylabel(\"z\")\n",
"plt.subplot(132)\n",
"plt.scatter(coords[:, 1], coords[:, 2], color=[\"r\", \"g\", \"b\"])\n",
"plt.xlabel(\"y\")\n",
"plt.ylabel(\"z\")\n",
"plt.subplot(133)\n",
"plt.scatter(coords[:, 0], coords[:, 1], color=[\"r\", \"g\", \"b\"])\n",
"plt.xlabel(\"x\")\n",
"plt.ylabel(\"y\")\n",
"print(\"xyz[-3:]: red, green, blue\")"
]
},
{
"cell_type": "code",
"execution_count": 24,
3 months ago
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Hamiltonian and exchange field rotated. Elapsed time: 292.32726 s\n",
"================================================================================================================================================================\n"
]
}
],
3 months ago
"source": [
"NO = dh.no # shorthand for number of orbitals in the unit cell\n",
3 months ago
"\n",
3 months ago
"# preprocessing Hamiltonian and overlap matrix elements\n",
"h11 = dh.tocsr(dh.M11r)\n",
"h11 += dh.tocsr(dh.M11i) * 1.0j\n",
"h11 = h11.toarray().reshape(NO, dh.n_s, NO).transpose(0, 2, 1).astype(\"complex128\")\n",
3 months ago
"\n",
"h22 = dh.tocsr(dh.M22r)\n",
"h22 += dh.tocsr(dh.M22i) * 1.0j\n",
"h22 = h22.toarray().reshape(NO, dh.n_s, NO).transpose(0, 2, 1).astype(\"complex128\")\n",
3 months ago
"\n",
"h12 = dh.tocsr(dh.M12r)\n",
"h12 += dh.tocsr(dh.M12i) * 1.0j\n",
"h12 = h12.toarray().reshape(NO, dh.n_s, NO).transpose(0, 2, 1).astype(\"complex128\")\n",
3 months ago
"\n",
"h21 = dh.tocsr(dh.M21r)\n",
"h21 += dh.tocsr(dh.M21i) * 1.0j\n",
"h21 = h21.toarray().reshape(NO, dh.n_s, NO).transpose(0, 2, 1).astype(\"complex128\")\n",
3 months ago
"\n",
"sov = (\n",
" dh.tocsr(dh.S_idx)\n",
" .toarray()\n",
" .reshape(NO, dh.n_s, NO)\n",
" .transpose(0, 2, 1)\n",
" .astype(\"complex128\")\n",
")\n",
3 months ago
"\n",
"\n",
3 months ago
"# Reorganization of Hamiltonian and overlap matrix elements to SPIN BOX representation\n",
"U = np.vstack(\n",
" [np.kron(np.eye(NO, dtype=int), [1, 0]), np.kron(np.eye(NO, dtype=int), [0, 1])]\n",
")\n",
3 months ago
"# This is the permutation that transforms ud1ud2 to u12d12\n",
"# That is this transforms FROM SPIN BOX to ORBITAL BOX => U\n",
"# the inverse transformation is U.T u12d12 to ud1ud2\n",
"# That is FROM ORBITAL BOX to SPIN BOX => U.T\n",
"\n",
3 months ago
"# From now on everything is in SPIN BOX!!\n",
"hh, ss = np.array(\n",
" [\n",
" U.T @ np.block([[h11[:, :, i], h12[:, :, i]], [h21[:, :, i], h22[:, :, i]]]) @ U\n",
" for i in range(dh.lattice.nsc.prod())\n",
" ]\n",
"), np.array(\n",
" [\n",
" U.T\n",
" @ np.block([[sov[:, :, i], sov[:, :, i] * 0], [sov[:, :, i] * 0, sov[:, :, i]]])\n",
" @ U\n",
" for i in range(dh.lattice.nsc.prod())\n",
" ]\n",
")\n",
"\n",
"\n",
"# symmetrizing Hamiltonian and overlap matrix to make them hermitian\n",
3 months ago
"for i in range(dh.lattice.sc_off.shape[0]):\n",
" j = dh.lattice.sc_index(-dh.lattice.sc_off[i])\n",
" h1, h1d = hh[i], hh[j]\n",
" hh[i], hh[j] = (h1 + h1d.T.conj()) / 2, (h1d + h1.T.conj()) / 2\n",
" s1, s1d = ss[i], ss[j]\n",
" ss[i], ss[j] = (s1 + s1d.T.conj()) / 2, (s1d + s1.T.conj()) / 2\n",
3 months ago
"\n",
"# identifying TRS and TRB parts of the Hamiltonian\n",
"TAUY = np.kron(np.eye(NO), tau_y)\n",
"hTR = np.array([TAUY @ hh[i].conj() @ TAUY for i in range(dh.lattice.nsc.prod())])\n",
"hTRS = (hh + hTR) / 2\n",
"hTRB = (hh - hTR) / 2\n",
3 months ago
"\n",
"# extracting the exchange field\n",
"traced = [spin_tracer(hTRB[i]) for i in range(dh.lattice.nsc.prod())] # equation 77\n",
"XCF = np.array(\n",
" [\n",
" np.array([f[\"x\"] for f in traced]),\n",
" np.array([f[\"y\"] for f in traced]),\n",
" np.array([f[\"z\"] for f in traced]),\n",
" ]\n",
") # equation 77\n",
3 months ago
"\n",
3 months ago
"# Check if exchange field has scalar part\n",
"max_xcfs = abs(np.array(np.array([f[\"c\"] for f in traced]))).max()\n",
"if max_xcfs > 1e-12:\n",
" warnings.warn(\n",
" f\"Exchange field has non negligible scalar part. Largest value is {max_xcfs}\"\n",
" )\n",
"\n",
"if rank == root_node:\n",
" times[\"H_and_XCF_time\"] = timer()\n",
" print(\n",
" f\"Hamiltonian and exchange field rotated. Elapsed time: {times['H_and_XCF_time']} s\"\n",
" )\n",
" print(\n",
" \"================================================================================================================================================================\"\n",
" )"
3 months ago
]
},
{
"cell_type": "code",
"execution_count": 25,
3 months ago
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Site and pair dictionaries created. Elapsed time: 292.347581791 s\n",
"================================================================================================================================================================\n"
]
}
],
3 months ago
"source": [
3 months ago
"# for every site we have to store 3 Greens function (and the associated _tmp-s) in the 3 reference directions\n",
"for i, mag_ent in enumerate(magnetic_entities):\n",
" parsed = parse_magnetic_entity(dh, **mag_ent) # parse orbital indexes\n",
" magnetic_entities[i][\"orbital_indeces\"] = parsed\n",
" # calculate spin box indexes\n",
" magnetic_entities[i][\"spin_box_indeces\"] = blow_up_orbindx(parsed)\n",
" # if orbital is not set use all\n",
" if \"l\" not in mag_ent.keys():\n",
" mag_ent[\"l\"] = \"all\"\n",
" if isinstance(mag_ent[\"atom\"], int):\n",
" mag_ent[\"tags\"] = [\n",
" f\"[{mag_ent['atom']}]{dh.atoms[mag_ent['atom']].tag}({mag_ent['l']})\"\n",
" ]\n",
" mag_ent[\"xyz\"] = [dh.xyz[mag_ent[\"atom\"]]]\n",
" if isinstance(mag_ent[\"atom\"], list):\n",
" mag_ent[\"tags\"] = []\n",
" mag_ent[\"xyz\"] = []\n",
" # iterate over atoms\n",
" for atom_idx in mag_ent[\"atom\"]:\n",
" mag_ent[\"tags\"].append(\n",
" f\"[{atom_idx}]{dh.atoms[atom_idx].tag}({mag_ent['l']})\"\n",
" )\n",
" mag_ent[\"xyz\"].append(dh.xyz[atom_idx])\n",
"\n",
" # calculate size for Greens function generation\n",
" spin_box_shape = len(mag_ent[\"spin_box_indeces\"])\n",
"\n",
" mag_ent[\"energies\"] = [] # we will store the second order energy derivations here\n",
"\n",
" mag_ent[\"Gii\"] = [] # Greens function\n",
" mag_ent[\"Gii_tmp\"] = [] # Greens function for parallelization\n",
" # These will be the perturbed potentials from eq. 100\n",
" mag_ent[\"Vu1\"] = [list([]) for _ in range(len(ref_xcf_orientations))]\n",
" mag_ent[\"Vu2\"] = [list([]) for _ in range(len(ref_xcf_orientations))]\n",
3 months ago
" for i in ref_xcf_orientations:\n",
" # Greens functions for every quantization axis\n",
" mag_ent[\"Gii\"].append(\n",
" np.zeros((eset, spin_box_shape, spin_box_shape), dtype=\"complex128\")\n",
" )\n",
" mag_ent[\"Gii_tmp\"].append(\n",
" np.zeros((eset, spin_box_shape, spin_box_shape), dtype=\"complex128\")\n",
" )\n",
"\n",
"# for every site we have to store 2x3 Greens function (and the associated _tmp-s)\n",
"# in the 3 reference directions, because G_ij and G_ji are both needed\n",
3 months ago
"for pair in pairs:\n",
" # calculate size for Greens function generation\n",
" spin_box_shape_i = len(magnetic_entities[pair[\"ai\"]][\"spin_box_indeces\"])\n",
" spin_box_shape_j = len(magnetic_entities[pair[\"aj\"]][\"spin_box_indeces\"])\n",
" pair[\"tags\"] = []\n",
" for mag_ent in [magnetic_entities[pair[\"ai\"]], magnetic_entities[pair[\"aj\"]]]:\n",
" tag = \"\"\n",
" # get atoms of magnetic entity\n",
" atoms_idx = mag_ent[\"atom\"]\n",
" orbitals = mag_ent[\"l\"]\n",
"\n",
" # if magnetic entity contains one atoms\n",
" if isinstance(atoms_idx, int):\n",
" tag += f\"[{atoms_idx}]{dh.atoms[atoms_idx].tag}({orbitals})\"\n",
"\n",
" # if magnetic entity contains more than one atoms\n",
" if isinstance(atoms_idx, list):\n",
" # iterate over atoms\n",
" atom_group = \"{\"\n",
" for atom_idx in atoms_idx:\n",
" atom_group += f\"[{atom_idx}]{dh.atoms[atom_idx].tag}({orbitals})--\"\n",
" # end {} of the atoms in the magnetic entity\n",
" tag += atom_group[:-2] + \"}\"\n",
" pair[\"tags\"].append(tag)\n",
" pair[\"energies\"] = [] # we will store the second order energy derivations here\n",
"\n",
" pair[\"Gij\"] = [] # Greens function\n",
" pair[\"Gji\"] = []\n",
" pair[\"Gij_tmp\"] = [] # Greens function for parallelization\n",
" pair[\"Gji_tmp\"] = []\n",
" for i in ref_xcf_orientations:\n",
" # Greens functions for every quantization axis\n",
" pair[\"Gij\"].append(\n",
" np.zeros((eset, spin_box_shape_i, spin_box_shape_j), dtype=\"complex128\")\n",
" )\n",
" pair[\"Gij_tmp\"].append(\n",
" np.zeros((eset, spin_box_shape_i, spin_box_shape_j), dtype=\"complex128\")\n",
" )\n",
" pair[\"Gji\"].append(\n",
" np.zeros((eset, spin_box_shape_j, spin_box_shape_i), dtype=\"complex128\")\n",
" )\n",
" pair[\"Gji_tmp\"].append(\n",
" np.zeros((eset, spin_box_shape_j, spin_box_shape_i), dtype=\"complex128\")\n",
" )\n",
"\n",
"if rank == root_node:\n",
" times[\"site_and_pair_dictionaries_time\"] = timer()\n",
" print(\n",
" f\"Site and pair dictionaries created. Elapsed time: {times['site_and_pair_dictionaries_time']} s\"\n",
" )\n",
" print(\n",
" \"================================================================================================================================================================\"\n",
" )"
3 months ago
]
},
{
"cell_type": "code",
"execution_count": 26,
3 months ago
"metadata": {},
"outputs": [
{
"name": "stderr",
"output_type": "stream",
"text": [
"k loop: 0%| | 0/100 [00:37<?, ?it/s]\n",
"k loop: 0%| | 0/10000 [00:00<?, ?it/s]"
]
},
{
"name": "stdout",
"output_type": "stream",
"text": [
"k set created. Elapsed time: 292.813134416 s\n",
"================================================================================================================================================================\n"
]
}
],
3 months ago
"source": [
"kset = make_kset(dirs=kdirs, NUMK=kset) # generate k space sampling\n",
"wkset = np.ones(len(kset)) / len(kset) # generate weights for k points\n",
"kpcs = np.array_split(kset, size) # split the k points based on MPI size\n",
"kpcs[root_node] = tqdm(kpcs[root_node], desc=\"k loop\")\n",
"\n",
"if rank == root_node:\n",
" times[\"k_set_time\"] = timer()\n",
" print(f\"k set created. Elapsed time: {times['k_set_time']} s\")\n",
" print(\n",
" \"================================================================================================================================================================\"\n",
" )"
3 months ago
]
},
{
"cell_type": "code",
"execution_count": 8,
3 months ago
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Rotations done perpendicular to quantization axis. Elapsed time: 135.307556041 s\n",
"================================================================================================================================================================\n"
]
}
],
3 months ago
"source": [
"# this will contain the three hamiltonians in the reference directions needed to calculate the energy variations upon rotation\n",
3 months ago
"hamiltonians = []\n",
3 months ago
"\n",
3 months ago
"# iterate over the reference directions (quantization axes)\n",
"for i, orient in enumerate(ref_xcf_orientations):\n",
" # obtain rotated exchange field\n",
" R = RotMa2b(scf_xcf_orientation, orient[\"o\"])\n",
" rot_XCF = np.einsum(\"ij,jklm->iklm\", R, XCF)\n",
" rot_H_XCF = sum(\n",
" [np.kron(rot_XCF[i], tau) for i, tau in enumerate([tau_x, tau_y, tau_z])]\n",
" )\n",
3 months ago
" rot_H_XCF_uc = rot_H_XCF[uc_in_sc_idx]\n",
"\n",
3 months ago
" # obtain total Hamiltonian with the rotated exchange field\n",
" rot_H = (\n",
" hTRS + rot_H_XCF\n",
" ) # equation 76 #######################################################################################\n",
3 months ago
"\n",
" hamiltonians.append(\n",
" dict(orient=orient[\"o\"], H=rot_H)\n",
" ) # store orientation and rotated Hamiltonian\n",
"\n",
" # these are the rotations (for now) perpendicular to the quantization axis\n",
" for u in orient[\"vw\"]:\n",
" Tu = np.kron(np.eye(NO, dtype=int), tau_u(u)) # section 2.H\n",
3 months ago
"\n",
" Vu1 = 1j / 2 * commutator(rot_H_XCF_uc, Tu) # equation 100\n",
" Vu2 = 1 / 8 * commutator(commutator(Tu, rot_H_XCF_uc), Tu) # equation 100\n",
3 months ago
"\n",
3 months ago
" for mag_ent in magnetic_entities:\n",
" # fill up the perturbed potentials (for now) based on the on-site projections\n",
" mag_ent[\"Vu1\"][i].append(\n",
" Vu1[:, mag_ent[\"spin_box_indeces\"]][mag_ent[\"spin_box_indeces\"], :]\n",
" )\n",
" mag_ent[\"Vu2\"][i].append(\n",
" Vu2[:, mag_ent[\"spin_box_indeces\"]][mag_ent[\"spin_box_indeces\"], :]\n",
" )\n",
"\n",
"if rank == root_node:\n",
" times[\"reference_rotations_time\"] = timer()\n",
" print(\n",
" f\"Rotations done perpendicular to quantization axis. Elapsed time: {times['reference_rotations_time']} s\"\n",
" )\n",
" print(\n",
" \"================================================================================================================================================================\"\n",
" )"
3 months ago
]
},
{
"cell_type": "code",
"execution_count": 9,
3 months ago
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Starting matrix inversions\n",
"Total number of k points: 100\n",
"Number of energy samples per k point: 60\n",
"Total number of directions: 3\n",
"Total number of matrix inversions: 18000\n",
"The shape of the Hamiltonian and the Greens function is 84x84=7056\n",
"Memory taken by a single Hamiltonian is: 0.015625 KB\n",
"Expected memory usage per matrix inversion: 0.5 KB\n",
"Expected memory usage per k point for parallel inversion: 90.0 KB\n",
"Expected memory usage on root node: 8.7890625 MB\n",
"================================================================================================================================================================\n"
]
},
{
"name": "stderr",
"output_type": "stream",
"text": [
"k loop: 100%|██████████| 100/100 [00:35<00:00, 2.82it/s]"
]
},
{
"name": "stdout",
"output_type": "stream",
"text": [
"Calculated Greens functions. Elapsed time: 170.554620458 s\n",
"================================================================================================================================================================\n"
]
},
{
"name": "stderr",
"output_type": "stream",
"text": [
"\n"
]
}
],
3 months ago
"source": [
3 months ago
"if rank == root_node:\n",
" print(\"Starting matrix inversions\")\n",
" print(f\"Total number of k points: {kset.shape[0]}\")\n",
" print(f\"Number of energy samples per k point: {eset}\")\n",
" print(f\"Total number of directions: {len(hamiltonians)}\")\n",
" print(\n",
" f\"Total number of matrix inversions: {kset.shape[0] * len(hamiltonians) * eset}\"\n",
" )\n",
" print(f\"The shape of the Hamiltonian and the Greens function is {NO}x{NO}={NO*NO}\")\n",
" # https://stackoverflow.com/questions/70746660/how-to-predict-memory-requirement-for-np-linalg-inv\n",
" # memory is O(64 n**2) for complex matrices\n",
" memory_size = getsizeof(hamiltonians[0][\"H\"].base) / 1024\n",
" print(\n",
" f\"Memory taken by a single Hamiltonian is: {getsizeof(hamiltonians[0]['H'].base) / 1024} KB\"\n",
" )\n",
" print(f\"Expected memory usage per matrix inversion: {memory_size * 32} KB\")\n",
" print(\n",
" f\"Expected memory usage per k point for parallel inversion: {memory_size * len(hamiltonians) * eset * 32} KB\"\n",
" )\n",
" print(\n",
" f\"Expected memory usage on root node: {len(np.array_split(kset, size)[0]) * memory_size * len(hamiltonians) * eset * 32 / 1024} MB\"\n",
" )\n",
" print(\n",
" \"================================================================================================================================================================\"\n",
" )\n",
"\n",
3 months ago
"comm.Barrier()\n",
"# ----------------------------------------------------------------------\n",
3 months ago
"\n",
"# make energy contour\n",
3 months ago
"# we are working in eV now !\n",
"# and sisil shifts E_F to 0 !\n",
"cont = make_contour(emin=ebot, enum=eset, p=esetp)\n",
3 months ago
"eran = cont.ze\n",
"\n",
"# ----------------------------------------------------------------------\n",
3 months ago
"# sampling the integrand on the contour and the BZ\n",
"for k in kpcs[rank]:\n",
" wk = wkset[rank] # weight of k point in BZ integral\n",
" # iterate over reference directions\n",
" for i, hamiltonian_orientation in enumerate(hamiltonians):\n",
" # calculate Greens function\n",
3 months ago
" H = hamiltonian_orientation[\"H\"]\n",
" HK, SK = hsk(H, ss, dh.sc_off, k)\n",
" # Gk = inv(SK * eran.reshape(eset, 1, 1) - HK)\n",
"\n",
" # solve Greens function sequentially for the energies, because of memory bound\n",
" Gk = np.zeros(shape=(eset, HK.shape[0], HK.shape[1]), dtype=\"complex128\")\n",
" for j in range(eset):\n",
" Gk[j] = inv(SK * eran[j] - HK)\n",
"\n",
3 months ago
" # store the Greens function slice of the magnetic entities (for now) based on the on-site projections\n",
" for mag_ent in magnetic_entities:\n",
" mag_ent[\"Gii_tmp\"][i] += (\n",
" Gk[:, mag_ent[\"spin_box_indeces\"]][..., mag_ent[\"spin_box_indeces\"]]\n",
" * wk\n",
" )\n",
3 months ago
"\n",
" for pair in pairs:\n",
" # add phase shift based on the cell difference\n",
" phase = np.exp(1j * 2 * np.pi * k @ pair[\"Ruc\"].T)\n",
"\n",
3 months ago
" # get the pair orbital sizes from the magnetic entities\n",
" ai = magnetic_entities[pair[\"ai\"]][\"spin_box_indeces\"]\n",
" aj = magnetic_entities[pair[\"aj\"]][\"spin_box_indeces\"]\n",
"\n",
" # store the Greens function slice of the magnetic entities (for now) based on the on-site projections\n",
" pair[\"Gij_tmp\"][i] += Gk[:, ai][..., aj] * phase * wk\n",
" pair[\"Gji_tmp\"][i] += Gk[:, aj][..., ai] * phase * wk\n",
3 months ago
"\n",
"# summ reduce partial results of mpi nodes\n",
"for i in range(len(hamiltonians)):\n",
" for mag_ent in magnetic_entities:\n",
" comm.Reduce(mag_ent[\"Gii_tmp\"][i], mag_ent[\"Gii\"][i], root=root_node)\n",
3 months ago
"\n",
3 months ago
" for pair in pairs:\n",
" comm.Reduce(pair[\"Gij_tmp\"][i], pair[\"Gij\"][i], root=root_node)\n",
" comm.Reduce(pair[\"Gji_tmp\"][i], pair[\"Gji\"][i], root=root_node)\n",
"\n",
"if rank == root_node:\n",
" times[\"green_function_inversion_time\"] = timer()\n",
" print(\n",
" f\"Calculated Greens functions. Elapsed time: {times['green_function_inversion_time']} s\"\n",
" )\n",
" print(\n",
" \"================================================================================================================================================================\"\n",
" )"
3 months ago
]
},
{
"cell_type": "code",
"execution_count": 10,
3 months ago
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Magnetic entities integrated.\n",
"Pairs integrated.\n",
"Magnetic parameters calculated.\n",
"##################################################################### GROGU OUTPUT #############################################################################\n",
"================================================================================================================================================================\n",
"Input file: \n",
"/Users/danielpozsar/Downloads/nojij/Fe3GeTe2/monolayer/soc/lat3_791/Fe3GeTe2.fdf\n",
"Output file: \n",
"Fe3GeTe2.pickle\n",
"Number of nodes in the parallel cluster: 1\n",
"================================================================================================================================================================\n",
"Cell [Ang]: \n",
"[[ 3.79100000e+00 0.00000000e+00 0.00000000e+00]\n",
" [-1.89550000e+00 3.28310231e+00 0.00000000e+00]\n",
" [ 1.25954923e-15 2.18160327e-15 2.05700000e+01]]\n",
"================================================================================================================================================================\n",
"DFT axis: \n",
"[0 0 1]\n",
"Quantization axis and perpendicular rotation directions:\n",
"[1 0 0] --» [array([0, 1, 0]), array([0, 0, 1])]\n",
"[0 1 0] --» [array([1, 0, 0]), array([0, 0, 1])]\n",
"[0 0 1] --» [array([1, 0, 0]), array([0, 1, 0])]\n",
"================================================================================================================================================================\n",
"Parameters for the contour integral:\n",
"Number of k points: 10\n",
"k point directions: xy\n",
"Ebot: -13\n",
"Eset: 60\n",
"Esetp: 10000\n",
"================================================================================================================================================================\n",
"Atomic information: \n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[atom index]Element(orbitals) x [Ang] y [Ang] z [Ang] Sx Sy Sz Q Lx Ly Lz Jx Jy Jz\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[3]Fe(2) -7.339158738013707e-06 4.149278510690423e-06 11.657585837928032\n",
"\n",
"[4]Fe(2) -7.326987662162937e-06 4.158274523275774e-06 8.912422537596708\n",
"\n",
"[5]Fe(2) 1.8954667088117545 1.0943913231921656 10.285002698393109\n",
"\n",
"================================================================================================================================================================\n",
"Exchange [meV]\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"Magnetic entity1 Magnetic entity2 [i j k] d [Ang]\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[3]Fe(2) [4]Fe(2) [0 0 0] d [Ang] Not yet.\n",
"Isotropic: -37.10407661401345\n",
"DMI: [-3.49488624e-01 2.55729732e-04 -2.76782696e-07]\n",
"Symmetric-anisotropy: [ 1.17610396e+00 -2.12018279e-05 -1.68775278e-06 -2.12018279e-05\n",
" 1.26217741e+00 -6.17661677e-07 -1.68775278e-06 -6.17661677e-07\n",
" -2.43828137e+00]\n",
"J: [-3.59279727e+01 -2.12018279e-05 -1.68775278e-06 -2.12018279e-05\n",
" -3.58418992e+01 -6.17661677e-07 -1.68775278e-06 -6.17661677e-07\n",
" -3.95423580e+01]\n",
"Energies for debugging: \n",
"array([[-3.94549786e-02, -3.49488006e-04, 3.49489241e-04,\n",
" -3.91968963e-02],\n",
" [-3.96297374e-02, -2.54041979e-07, 2.57417485e-07,\n",
" -3.93690691e-02],\n",
" [-3.24869021e-02, 2.09250452e-08, 2.14786106e-08,\n",
" -3.24868762e-02]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.03936907, -0.0324869 , -0.03945498])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.0393690691402239 -0.03248687617162827\n",
"\n",
"[3]Fe(2) [5]Fe(2) [0 0 0] d [Ang] Not yet.\n",
"Isotropic: -65.61259672738467\n",
"DMI: [ 3.55875363e+00 -6.14764701e+00 2.16400609e-05]\n",
"Symmetric-anisotropy: [-0.0859418 0.03699169 -0.10152731 0.03699169 -0.29085831 -0.04979059\n",
" -0.10152731 -0.04979059 0.37680011]\n",
"J: [-6.56985385e+01 3.69916940e-02 -1.01527307e-01 3.69916940e-02\n",
" -6.59034550e+01 -4.97905921e-02 -1.01527307e-01 -4.97905921e-02\n",
" -6.52357966e+01]\n",
"Energies for debugging: \n",
"array([[-6.53628254e-02, 3.60854422e-03, -3.50896304e-03,\n",
" -6.58406049e-02],\n",
" [-6.51087679e-02, 6.24917432e-03, -6.04611971e-03,\n",
" -6.54738265e-02],\n",
" [-6.59663052e-02, -3.69700539e-05, -3.70133340e-05,\n",
" -6.59232506e-02]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.06547383, -0.06596631, -0.06536283])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.06547382649599318 -0.06592325055847004\n",
"\n",
"[4]Fe(2) [5]Fe(2) [0 0 0] d [Ang] Not yet.\n",
"Isotropic: -65.61291582804701\n",
"DMI: [-3.57656657e+00 6.16370250e+00 1.72769889e-05]\n",
"Symmetric-anisotropy: [-0.08507475 0.03698984 0.09551784 0.03698984 -0.29208857 0.04348767\n",
" 0.09551784 0.04348767 0.37716332]\n",
"J: [-6.56979906e+01 3.69898372e-02 9.55178378e-02 3.69898372e-02\n",
" -6.59050044e+01 4.34876702e-02 9.55178378e-02 4.34876702e-02\n",
" -6.52357525e+01]\n",
"Energies for debugging: \n",
"array([[-6.53645241e-02, -3.62005424e-03, 3.53307890e-03,\n",
" -6.58436843e-02],\n",
" [-6.51069809e-02, -6.25922034e-03, 6.06818466e-03,\n",
" -6.54727085e-02],\n",
" [-6.59663245e-02, -3.69725603e-05, -3.70071142e-05,\n",
" -6.59232727e-02]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.06547271, -0.06596632, -0.06536452])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.0654727084967254 -0.0659232726509173\n",
"\n",
"[3]Fe(2) [4]Fe(2) [1 0 0] d [Ang] Not yet.\n",
"Isotropic: -1.0251660485588765\n",
"DMI: [5.56147340e-01 3.31683446e-04 6.04521494e-06]\n",
"Symmetric-anisotropy: [-9.32615331e-01 -3.84767890e-05 1.75789862e-05 -3.84767890e-05\n",
" 3.05904797e-02 3.50989682e-05 1.75789862e-05 3.50989682e-05\n",
" 9.02024851e-01]\n",
"J: [-1.95778138e+00 -3.84767890e-05 1.75789862e-05 -3.84767890e-05\n",
" -9.94575569e-01 3.50989682e-05 1.75789862e-05 3.50989682e-05\n",
" -1.23141198e-01]\n",
"Energies for debugging: \n",
"array([[ 4.97965048e-04, 5.56112241e-04, -5.56182439e-04,\n",
" 8.57005683e-04],\n",
" [-7.44247443e-04, -3.49262432e-07, 3.14104460e-07,\n",
" -8.04849198e-04],\n",
" [-2.84615682e-03, 4.45220039e-08, 3.24315741e-08,\n",
" -3.11071356e-03]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.00080485, -0.00284616, 0.00049797])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.0008048491979002433 -0.003110713560414389\n",
"\n",
"[3]Fe(2) [5]Fe(2) [1 0 0] d [Ang] Not yet.\n",
"Isotropic: -3.861520076312661\n",
"DMI: [-3.85977504 -2.52369277 -4.22692922]\n",
"Symmetric-anisotropy: [ 0.28001794 -0.01136935 0.01587327 -0.01136935 -0.12598869 0.05899784\n",
" 0.01587327 0.05899784 -0.15402925]\n",
"J: [-3.58150213 -0.01136935 0.01587327 -0.01136935 -3.98750877 0.05899784\n",
" 0.01587327 0.05899784 -4.01554933]\n",
"Energies for debugging: \n",
"array([[-0.00437283, -0.00391877, 0.00380078, -0.0044349 ],\n",
" [-0.00365826, 0.00250782, -0.00253957, -0.00358946],\n",
" [-0.00354012, -0.00421556, 0.0042383 , -0.00357354]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.00358946, -0.00354012, -0.00437283])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.003589463621997051 -0.003573540645545602\n",
"\n",
"[4]Fe(2) [5]Fe(2) [1 0 0] d [Ang] Not yet.\n",
"Isotropic: -4.458620479895359\n",
"DMI: [-4.33083787 -5.9385644 -4.22684544]\n",
"Symmetric-anisotropy: [ 0.07272859 -0.01136933 -0.06310261 -0.01136933 0.39785991 -0.00993305\n",
" -0.06310261 -0.00993305 -0.4705885 ]\n",
"J: [-4.38589189 -0.01136933 -0.06310261 -0.01136933 -4.06076057 -0.00993305\n",
" -0.06310261 -0.00993305 -4.92920898]\n",
"Energies for debugging: \n",
"array([[-0.00452019, -0.0043209 , 0.00434077, -0.0045815 ],\n",
" [-0.00533823, 0.00600167, -0.00587546, -0.00519834],\n",
" [-0.00354003, -0.00421548, 0.00423821, -0.00357345]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.00519834, -0.00354003, -0.00452019])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.005198338074976103 -0.0035734456953877562\n",
"\n",
"[3]Fe(2) [4]Fe(2) [-1 0 0] d [Ang] Not yet.\n",
"Isotropic: -0.6592236155327585\n",
"DMI: [ 5.59127613e-01 3.58728563e-05 -2.86086982e-06]\n",
"Symmetric-anisotropy: [-6.83716963e-01 -1.51898472e-05 5.53583253e-05 -1.51898472e-05\n",
" 1.41032214e-01 -2.42119712e-05 5.53583253e-05 -2.42119712e-05\n",
" 5.42684748e-01]\n",
"J: [-1.34294058e+00 -1.51898472e-05 5.53583253e-05 -1.51898472e-05\n",
" -5.18191401e-01 -2.42119712e-05 5.53583253e-05 -2.42119712e-05\n",
" -1.16538867e-01]\n",
"Energies for debugging: \n",
"array([[ 5.05733178e-04, 5.59151825e-04, -5.59103401e-04,\n",
" 8.53125820e-04],\n",
" [-7.38810912e-04, -9.12311817e-08, -1.94854690e-08,\n",
" -7.84577563e-04],\n",
" [-1.88950862e-03, 1.23289774e-08, 1.80507170e-08,\n",
" -1.90130359e-03]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.00078458, -0.00188951, 0.00050573])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.0007845775626293201 -0.0019013035936397693\n",
"\n",
"[3]Fe(2) [5]Fe(2) [-1 0 0] d [Ang] Not yet.\n",
"Isotropic: -5.329274876444571\n",
"DMI: [4.32561582 5.93073478 4.17207926]\n",
"Symmetric-anisotropy: [-0.2835386 -0.01607429 0.06200728 -0.01607429 -0.10548755 0.01356167\n",
" 0.06200728 0.01356167 0.38902615]\n",
"J: [-5.61281347 -0.01607429 0.06200728 -0.01607429 -5.43476243 0.01356167\n",
" 0.06200728 0.01356167 -4.94024873]\n",
"Energies for debugging: \n",
"array([[-0.00454026, 0.00431205, -0.00433918, -0.00458051],\n",
" [-0.00534024, -0.00599274, 0.00586873, -0.00521439],\n",
" [-0.00628902, 0.00418815, -0.004156 , -0.00601124]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.00521439, -0.00628902, -0.00454026])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.005214386566508839 -0.006011240381521584\n",
"\n",
"[4]Fe(2) [5]Fe(2) [-1 0 0] d [Ang] Not yet.\n",
"Isotropic: -4.725061132133376\n",
"DMI: [3.8792295 2.52874087 4.17199723]\n",
"Symmetric-anisotropy: [-0.07053775 -0.01607386 -0.01391118 -0.01607386 -0.64500259 -0.04924493\n",
" -0.01391118 -0.04924493 0.71554034]\n",
"J: [-4.79559888 -0.01607386 -0.01391118 -0.01607386 -5.37006372 -0.04924493\n",
" -0.01391118 -0.04924493 -4.00952079]\n",
"Energies for debugging: \n",
"array([[-0.00436494, 0.00392847, -0.00382998, -0.00445121],\n",
" [-0.0036541 , -0.00251483, 0.00254265, -0.00358006],\n",
" [-0.00628891, 0.00418807, -0.00415592, -0.00601114]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.00358006, -0.00628891, -0.00436494])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.0035800556270865367 -0.006011142134174699\n",
"\n",
"[3]Fe(2) [4]Fe(2) [0 1 0] d [Ang] Not yet.\n",
"Isotropic: -1.0496996447984108\n",
"DMI: [-1.97020604e-01 3.93326251e-01 -7.99021874e-06]\n",
"Symmetric-anisotropy: [-0.20217197 0.11453163 -0.03920952 0.11453163 -0.68803384 -0.03787685\n",
" -0.03920952 -0.03787685 0.8902058 ]\n",
"J: [-1.25187161 0.11453163 -0.03920952 0.11453163 -1.73773348 -0.03787685\n",
" -0.03920952 -0.03787685 -0.15949384]\n",
"Energies for debugging: \n",
"array([[-0.00047568, -0.00015914, 0.0002349 , -0.00043124],\n",
" [ 0.00015669, -0.00035412, 0.00043254, 0.00040814],\n",
" [-0.00304422, -0.00011454, -0.00011452, -0.00291188]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([ 0.00040814, -0.00304422, -0.00047568])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"0.0004081381450225469 -0.002911881367375347\n",
"\n",
"[3]Fe(2) [5]Fe(2) [0 1 0] d [Ang] Not yet.\n",
"Isotropic: -1.6451863500909631\n",
"DMI: [ 0.24862131 -0.06829953 -0.0003067 ]\n",
"Symmetric-anisotropy: [-0.17839237 -0.07756692 -0.00999969 -0.07756692 -0.01604251 0.00447534\n",
" -0.00999969 0.00447534 0.19443488]\n",
"J: [-1.82357872 -0.07756692 -0.00999969 -0.07756692 -1.66122887 0.00447534\n",
" -0.00999969 0.00447534 -1.45075147]\n",
"Energies for debugging: \n",
"array([[-1.33932568e-03, 2.44145966e-04, -2.53096646e-04,\n",
" -1.15417279e-03],\n",
" [-1.56217725e-03, 7.82992297e-05, -5.82998403e-05,\n",
" -1.38940645e-03],\n",
" [-2.16828494e-03, 7.72602195e-05, 7.78736263e-05,\n",
" -2.25775098e-03]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.00138941, -0.00216828, -0.00133933])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.001389406450933013 -0.0022577509836049143\n",
"\n",
"[4]Fe(2) [5]Fe(2) [0 1 0] d [Ang] Not yet.\n",
"Isotropic: -1.925466529428356\n",
"DMI: [ 5.35912969e-01 -3.81240204e-01 -3.13285724e-04]\n",
"Symmetric-anisotropy: [-0.05397076 -0.07756762 0.06269827 -0.07756762 0.02186579 0.0475358\n",
" 0.06269827 0.0475358 0.03210497]\n",
"J: [-1.97943729 -0.07756762 0.06269827 -0.07756762 -1.90360074 0.0475358\n",
" 0.06269827 0.0475358 -1.89336156]\n",
"Energies for debugging: \n",
"array([[-1.87844392e-03, 4.88377165e-04, -5.83448773e-04,\n",
" -1.63886730e-03],\n",
" [-1.90827920e-03, 3.18541935e-04, -4.43938473e-04,\n",
" -1.70107327e-03],\n",
" [-2.16833418e-03, 7.72543295e-05, 7.78809009e-05,\n",
" -2.25780130e-03]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.00170107, -0.00216833, -0.00187844])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.0017010732733817554 -0.0022578013038436714\n",
"\n",
"[3]Fe(2) [4]Fe(2) [ 0 -1 0] d [Ang] Not yet.\n",
"Isotropic: -0.68223039919425\n",
"DMI: [-1.89525393e-01 3.91001992e-01 1.58428064e-05]\n",
"Symmetric-anisotropy: [-0.05823148 0.00509602 0.02845826 0.00509602 -0.47544519 0.02675952\n",
" 0.02845826 0.02675952 0.53367667]\n",
"J: [-0.74046188 0.00509602 0.02845826 0.00509602 -1.15767559 0.02675952\n",
" 0.02845826 0.02675952 -0.14855373]\n",
"Energies for debugging: \n",
"array([[-4.64649982e-04, -2.16284909e-04, 1.62765877e-04,\n",
" -4.17183456e-04],\n",
" [ 1.67542528e-04, -4.19460248e-04, 3.62543736e-04,\n",
" 4.11325899e-04],\n",
" [-1.89816773e-03, -5.08017987e-06, -5.11186549e-06,\n",
" -1.89224965e-03]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([ 0.00041133, -0.00189817, -0.00046465])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"0.0004113258993876115 -0.0018922496544738186\n",
"\n",
"[3]Fe(2) [5]Fe(2) [ 0 -1 0] d [Ang] Not yet.\n",
"Isotropic: -1.3572259825150497\n",
"DMI: [-5.38839939e-01 3.89611153e-01 8.70420696e-05]\n",
"Symmetric-anisotropy: [ 0.26558549 0.01373365 -0.05609544 0.01373365 0.28408137 -0.04203485\n",
" -0.05609544 -0.04203485 -0.54966686]\n",
"J: [-1.09164049 0.01373365 -0.05609544 0.01373365 -1.07314461 -0.04203485\n",
" -0.05609544 -0.04203485 -1.90689284]\n",
"Energies for debugging: \n",
"array([[-1.89490240e-03, -4.96805090e-04, 5.80874787e-04,\n",
" -1.64794979e-03],\n",
" [-1.91888329e-03, -3.33515713e-04, 4.45706592e-04,\n",
" -1.70084474e-03],\n",
" [-4.98339441e-04, -1.36466118e-05, -1.38206959e-05,\n",
" -4.82436238e-04]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.00170084, -0.00049834, -0.0018949 ])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.001700844742244848 -0.00048243623752327756\n",
"\n",
"[4]Fe(2) [5]Fe(2) [ 0 -1 0] d [Ang] Not yet.\n",
"Isotropic: -1.0714146881035242\n",
"DMI: [-2.39958377e-01 5.49853449e-02 9.53349954e-05]\n",
"Symmetric-anisotropy: [ 0.13849155 0.0137361 0.01047494 0.0137361 0.24743038 -0.00279692\n",
" 0.01047494 -0.00279692 -0.38592192]\n",
"J: [-0.93292314 0.0137361 0.01047494 0.0137361 -0.82398431 -0.00279692\n",
" 0.01047494 -0.00279692 -1.45733661]\n",
"Energies for debugging: \n",
"array([[-1.34446326e-03, -2.37161457e-04, 2.42755297e-04,\n",
" -1.14953629e-03],\n",
" [-1.57020997e-03, -6.54602885e-05, 4.45104012e-05,\n",
" -1.38331981e-03],\n",
" [-4.98432325e-04, -1.36407658e-05, -1.38314358e-05,\n",
" -4.82526480e-04]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.00138332, -0.00049843, -0.00134446])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.001383319805189735 -0.0004825264795417615\n",
"\n",
"================================================================================================================================================================\n",
"Runtime information: \n",
"Total runtime: 36.825569167000026 s\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"Initial setup: 0.20532049999999913 s\n",
"Hamiltonian conversion and XC field extraction: 0.972 s\n",
"Pair and site datastructure creatrions: 0.027 s\n",
"k set cration and distribution: 0.027 s\n",
"Rotating XC potential: 0.255 s\n",
"Greens function inversion: 35.247 s\n",
"Calculate energies and magnetic components: 0.092 s\n"
]
}
],
3 months ago
"source": [
"if rank == root_node:\n",
" # iterate over the magnetic entities\n",
" for tracker, mag_ent in enumerate(magnetic_entities):\n",
" # iterate over the quantization axes\n",
" for i, Gii in enumerate(mag_ent[\"Gii\"]):\n",
" storage = []\n",
" # iterate over the first and second order local perturbations\n",
" for Vu1, Vu2 in zip(mag_ent[\"Vu1\"][i], mag_ent[\"Vu2\"][i]):\n",
3 months ago
" # The Szunyogh-Lichtenstein formula\n",
" traced = np.trace((Vu2 @ Gii + 0.5 * Gii @ Vu1 @ Gii), axis1=1, axis2=2)\n",
3 months ago
" # evaluation of the contour integral\n",
" storage.append(np.trapz(-1 / np.pi * np.imag(traced * cont.we)))\n",
"\n",
" # fill up the magnetic entities dictionary with the energies\n",
" magnetic_entities[tracker][\"energies\"].append(storage)\n",
" # convert to np array\n",
" magnetic_entities[tracker][\"energies\"] = np.array(\n",
" magnetic_entities[tracker][\"energies\"]\n",
" )\n",
" print(\"Magnetic entities integrated.\")\n",
"\n",
" # iterate over the pairs\n",
" for tracker, pair in enumerate(pairs):\n",
" # iterate over the quantization axes\n",
" for i, (Gij, Gji) in enumerate(zip(pair[\"Gij\"], pair[\"Gji\"])):\n",
" site_i = magnetic_entities[pair[\"ai\"]]\n",
" site_j = magnetic_entities[pair[\"aj\"]]\n",
"\n",
" storage = []\n",
" # iterate over the first order local perturbations in all possible orientations for the two sites\n",
" for Vui in site_i[\"Vu1\"][i]:\n",
" for Vuj in site_j[\"Vu1\"][i]:\n",
" # The Szunyogh-Lichtenstein formula\n",
" traced = np.trace((Vui @ Gij @ Vuj @ Gji), axis1=1, axis2=2)\n",
" # evaluation of the contour integral\n",
" storage.append(np.trapz(-1 / np.pi * np.imag(traced * cont.we)))\n",
" # fill up the pairs dictionary with the energies\n",
" pairs[tracker][\"energies\"].append(storage)\n",
" # convert to np array\n",
" pairs[tracker][\"energies\"] = np.array(pairs[tracker][\"energies\"])\n",
"\n",
" print(\"Pairs integrated.\")\n",
"\n",
" # calculate magnetic parameters\n",
" for pair in pairs:\n",
" J_iso, J_S, D, J = calculate_exchange_tensor(pair)\n",
" pair[\"J_iso\"] = J_iso * sisl.unit_convert(\"eV\", \"meV\")\n",
" pair[\"J_S\"] = J_S * sisl.unit_convert(\"eV\", \"meV\")\n",
" pair[\"D\"] = D * sisl.unit_convert(\"eV\", \"meV\")\n",
" pair[\"J\"] = J * sisl.unit_convert(\"eV\", \"meV\")\n",
"\n",
" print(\"Magnetic parameters calculated.\")\n",
"\n",
" times[\"end_time\"] = timer()\n",
" print(\n",
" \"##################################################################### GROGU OUTPUT #############################################################################\"\n",
" )\n",
"\n",
" print_parameters(simulation_parameters)\n",
" print_atoms_and_pairs(magnetic_entities, pairs)\n",
" print_runtime_information(times)\n",
"\n",
" # remove clutter from magnetic entities and pair information\n",
" for pair in pairs:\n",
" del pair[\"Gij\"]\n",
" del pair[\"Gij_tmp\"]\n",
" del pair[\"Gji\"]\n",
" del pair[\"Gji_tmp\"]\n",
" for mag_ent in magnetic_entities:\n",
" del mag_ent[\"Gii\"]\n",
" del mag_ent[\"Gii_tmp\"]\n",
" del mag_ent[\"Vu1\"]\n",
" del mag_ent[\"Vu2\"]\n",
" # create output dictionary with all the relevant data\n",
" results = dict(\n",
" parameters=simulation_parameters,\n",
" magnetic_entities=magnetic_entities,\n",
" pairs=pairs,\n",
" runtime=times,\n",
" )\n",
" # save dictionary\n",
" with open(outfile, \"wb\") as output_file:\n",
" pickle.dump(results, output_file)"
]
},
{
"cell_type": "code",
"execution_count": 11,
"metadata": {},
"outputs": [
{
"ename": "SyntaxError",
"evalue": "invalid syntax (1445642317.py, line 1)",
"output_type": "error",
"traceback": [
"\u001b[0;36m Cell \u001b[0;32mIn[11], line 1\u001b[0;36m\u001b[0m\n\u001b[0;31m Magnetic entities integrated.\u001b[0m\n\u001b[0m ^\u001b[0m\n\u001b[0;31mSyntaxError\u001b[0m\u001b[0;31m:\u001b[0m invalid syntax\n"
]
}
],
"source": [
"Magnetic entities integrated.\n",
"Pairs integrated.\n",
"Magnetic parameters calculated.\n",
"##################################################################### GROGU OUTPUT #############################################################################\n",
"================================================================================================================================================================\n",
"Input file: \n",
"Not yet specified.\n",
"Output file: \n",
"test.pickle\n",
"Number of nodes in the parallel cluster: 1\n",
"================================================================================================================================================================\n",
"Cell [Ang]: \n",
"[[ 3.79100000e+00 0.00000000e+00 0.00000000e+00]\n",
" [-1.89550000e+00 3.28310231e+00 0.00000000e+00]\n",
" [ 1.25954923e-15 2.18160327e-15 2.05700000e+01]]\n",
"================================================================================================================================================================\n",
"DFT axis: \n",
"[0 0 1]\n",
"Quantization axis and perpendicular rotation directions:\n",
"[1 0 0] --» [array([0, 1, 0]), array([0, 0, 1])]\n",
"[0 1 0] --» [array([1, 0, 0]), array([0, 0, 1])]\n",
"[0 0 1] --» [array([1, 0, 0]), array([0, 1, 0])]\n",
"================================================================================================================================================================\n",
"Parameters for the contour integral:\n",
"Number of k points: 20\n",
"k point directions: x\n",
"Ebot: -13\n",
"Eset: 600\n",
"Esetp: 10000\n",
"================================================================================================================================================================\n",
"Atomic information: \n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[atom index]Element(orbitals) x [Ang] y [Ang] z [Ang] Sx Sy Sz Q Lx Ly Lz Jx Jy Jz\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[3]Fe(2) -7.339158738013707e-06 4.149278510690423e-06 11.657585837928032\n",
"\n",
"[4]Fe(2) -7.326987662162937e-06 4.158274523275774e-06 8.912422537596708\n",
"\n",
"[5]Fe(2) 1.8954667088117545 1.0943913231921656 10.285002698393109\n",
"\n",
"================================================================================================================================================================\n",
"Exchange [meV]\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"Magnetic entity1 Magnetic entity2 [i j k] d [Ang]\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[3]Fe(2) [4]Fe(2) [0 0 0] d [Ang] Not yet.\n",
"Isotropic: -37.73293438752643\n",
"DMI: [-1.95914479e+00 6.21772915e+00 -7.63210027e-06]\n",
"Symmetric-anisotropy: [ 1.76549627e+00 1.32018786e+00 8.70141772e-04 1.32018786e+00\n",
" 3.02084625e+00 -1.61370176e-02 8.70141772e-04 -1.61370176e-02\n",
" -4.78634252e+00]\n",
"Energies for debugging: \n",
"array([[-0.03971497, -0.00194301, 0.00197528, -0.0357954 ],\n",
" [-0.04532359, -0.0062186 , 0.00621686, -0.03983102],\n",
" [-0.03362878, -0.0013202 , -0.00132018, -0.03210385]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.03983102, -0.03362878, -0.03971497])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.0398310234439899 -0.03210385279422295\n",
"\n",
"[3]Fe(2) [5]Fe(2) [0 0 0] d [Ang] Not yet.\n",
"Isotropic: -73.83015029521252\n",
"DMI: [ 7.76660921e+00 -1.22515694e+01 6.25989582e-04]\n",
"Symmetric-anisotropy: [-1.94961899 -0.25694518 1.17973546 -0.25694518 -0.9315989 0.68240007\n",
" 1.17973546 0.68240007 2.8812179 ]\n",
"Energies for debugging: \n",
"array([[-0.06985729, 0.00708421, -0.00844901, -0.06974285],\n",
" [-0.07204057, 0.01107183, -0.0134313 , -0.07148291],\n",
" [-0.07978065, 0.00025757, 0.00025632, -0.08007663]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.07148291, -0.07978065, -0.06985729])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.07148290532391263 -0.08007663325482241\n",
"\n",
"[4]Fe(2) [5]Fe(2) [0 0 0] d [Ang] Not yet.\n",
"Isotropic: -73.78915203163939\n",
"DMI: [-7.75054625e+00 1.22185627e+01 6.29159323e-04]\n",
"Symmetric-anisotropy: [-1.96064992 -0.25693115 -1.19384894 -0.25693115 -0.94861315 -0.70360485\n",
" -1.19384894 -0.70360485 2.90926307]\n",
"Energies for debugging: \n",
"array([[-0.06978756, -0.00704694, 0.00845415, -0.06969528],\n",
" [-0.07197222, -0.01102471, 0.01341241, -0.07142338],\n",
" [-0.07978025, 0.00025756, 0.0002563 , -0.08007622]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.07142338, -0.07978025, -0.06978756])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.07142338168884173 -0.08007622222171976\n",
"\n",
"================================================================================================================================================================\n",
"Runtime information: \n",
"Total runtime: 60.559684874999995 s\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"Initial setup: 0.13768908300000016 s\n",
"Hamiltonian conversion and XC field extraction: 0.822 s\n",
"Pair and site datastructure creatrions: 0.036 s\n",
"k set cration and distribution: 0.025 s\n",
"Rotating XC potential: 0.245 s\n",
"Greens function inversion: 59.066 s\n",
"Calculate energies and magnetic components: 0.228 s"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"Magnetic entities integrated.\n",
"Pairs integrated.\n",
"Magnetic parameters calculated.\n",
"##################################################################### GROGU OUTPUT #############################################################################\n",
"================================================================================================================================================================\n",
"Input file: \n",
"Not yet specified.\n",
"Output file: \n",
"test.pickle\n",
"Number of nodes in the parallel cluster: 1\n",
"================================================================================================================================================================\n",
"Cell [Ang]: \n",
"[[ 3.79100000e+00 0.00000000e+00 0.00000000e+00]\n",
" [-1.89550000e+00 3.28310231e+00 0.00000000e+00]\n",
" [ 1.25954923e-15 2.18160327e-15 2.05700000e+01]]\n",
"================================================================================================================================================================\n",
"DFT axis: \n",
"[0 0 1]\n",
"Quantization axis and perpendicular rotation directions:\n",
"[1 0 0] --» [array([0, 1, 0]), array([0, 0, 1])]\n",
"[0 1 0] --» [array([1, 0, 0]), array([0, 0, 1])]\n",
"[0 0 1] --» [array([1, 0, 0]), array([0, 1, 0])]\n",
"================================================================================================================================================================\n",
"Parameters for the contour integral:\n",
"Number of k points: 1000\n",
"k point directions: x\n",
"Ebot: -13\n",
"Eset: 500\n",
"Esetp: 10000\n",
"================================================================================================================================================================\n",
"Atomic information: \n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[atom index]Element(orbitals) x [Ang] y [Ang] z [Ang] Sx Sy Sz Q Lx Ly Lz Jx Jy Jz\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[3]Fe(2) -7.339158738013707e-06 4.149278510690423e-06 11.657585837928032\n",
"\n",
"[4]Fe(2) -7.326987662162937e-06 4.158274523275774e-06 8.912422537596708\n",
"\n",
"[5]Fe(2) 1.8954667088117545 1.0943913231921656 10.285002698393109\n",
"\n",
"================================================================================================================================================================\n",
"Exchange [meV]\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"Magnetic entity1 Magnetic entity2 [i j k] d [Ang]\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[3]Fe(2) [4]Fe(2) [0 0 0] d [Ang] Not yet.\n",
"Isotropic: -29.367092812942317\n",
"DMI: [-8.89792781e-01 4.16580540e+00 -3.59948517e-06]\n",
"Symmetric-anisotropy: [-4.56670448 1.17667365 0.33235705 4.15578143 -0.03089926]\n",
"Energies for debugging: \n",
"array([[-0.02819042, -0.00085889, 0.00092069, -0.02597706],\n",
" [-0.03690207, -0.00415578, 0.00417583, -0.0339338 ],\n",
" [-0.03160427, -0.00033236, -0.00033235, -0.03122101]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.0339338 , -0.03160427, -0.02819042])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.03393379729617979 -0.03122101431812066\n",
"\n",
"[4]Fe(2) [5]Fe(2) [0 0 0] d [Ang] Not yet.\n",
"Isotropic: -74.98944973858333\n",
"DMI: [-6.82212886e+00 1.12891691e+01 5.77778279e-04]\n",
"Symmetric-anisotropy: [-1.03411109 0.63716653 -0.16031601 10.67952816 -0.32649278]\n",
"Energies for debugging: \n",
"array([[-0.07435228, -0.00649564, 0.00714862, -0.07459251],\n",
" [-0.07593353, -0.01067953, 0.01189881, -0.07602356],\n",
" [-0.0795701 , 0.00016089, 0.00015974, -0.07975458]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.07602356, -0.0795701 , -0.07435228])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.07602356083253432 -0.07975458355080561\n",
"\n",
"================================================================================================================================================================\n",
"Runtime information: \n",
"Total runtime: 2369.9501148750005 s\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"Initial setup: 0.17246508400057792 s\n",
"Hamiltonian conversion and XC field extraction: 0.904 s\n",
"Pair and site datastructure creatrions: 0.028 s\n",
"k set cration and distribution: 0.009 s\n",
"Rotating XC potential: 0.212 s\n",
"Greens function inversion: 2368.445 s\n",
"Calculate energies and magnetic components: 0.180 s"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"Magnetic entities integrated.\n",
"Pairs integrated.\n",
"Magnetic parameters calculated.\n",
"##################################################################### GROGU OUTPUT #############################################################################\n",
"================================================================================================================================================================\n",
"Input file: \n",
"Not yet specified.\n",
"Output file: \n",
"test.pickle\n",
"Number of nodes in the parallel cluster: 1\n",
"================================================================================================================================================================\n",
"Cell [Ang]: \n",
"[[ 3.79100000e+00 0.00000000e+00 0.00000000e+00]\n",
" [-1.89550000e+00 3.28310231e+00 0.00000000e+00]\n",
" [ 1.25954923e-15 2.18160327e-15 2.05700000e+01]]\n",
"================================================================================================================================================================\n",
"DFT axis: \n",
"[0 0 1]\n",
"Quantization axis and perpendicular rotation directions:\n",
"[1 0 0] --» [array([0, 1, 0]), array([0, 0, 1])]\n",
"[0 1 0] --» [array([1, 0, 0]), array([0, 0, 1])]\n",
"[0 0 1] --» [array([1, 0, 0]), array([0, 1, 0])]\n",
"================================================================================================================================================================\n",
"Parameters for the contour integral:\n",
"Number of k points: 1000\n",
"k point directions: x\n",
"Ebot: -13\n",
"Eset: 100\n",
"Esetp: 10000\n",
"================================================================================================================================================================\n",
"Atomic information: \n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[atom index]Element(orbitals) x [Ang] y [Ang] z [Ang] Sx Sy Sz Q Lx Ly Lz Jx Jy Jz\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[3]Fe(2) -7.339158738013707e-06 4.149278510690423e-06 11.657585837928032\n",
"\n",
"[4]Fe(2) -7.326987662162937e-06 4.158274523275774e-06 8.912422537596708\n",
"\n",
"[5]Fe(2) 1.8954667088117545 1.0943913231921656 10.285002698393109\n",
"\n",
"================================================================================================================================================================\n",
"Exchange [meV]\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"Magnetic entity1 Magnetic entity2 [i j k] d [Ang]\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[3]Fe(2) [4]Fe(2) [0 0 0] d [Ang] Not yet.\n",
"Isotropic: -29.36445059067917\n",
"DMI: [-8.91784089e-01 4.16579134e+00 -3.59901207e-06]\n",
"Symmetric-anisotropy: [-4.5685362 1.18301202 0.3323615 4.15576769 -0.02915828]\n",
"Energies for debugging: \n",
"array([[-0.02818144, -0.00086263, 0.00092094, -0.02597893],\n",
" [-0.03690122, -0.00415577, 0.00417581, -0.03393299],\n",
" [-0.03160383, -0.00033237, -0.00033236, -0.03122058]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.03393299, -0.03160383, -0.02818144])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.03393298678958339 -0.031220578858898954\n",
"\n",
"[4]Fe(2) [5]Fe(2) [0 0 0] d [Ang] Not yet.\n",
"Isotropic: -74.99083333178646\n",
"DMI: [-6.82222254e+00 1.12891474e+01 5.95795483e-04]\n",
"Symmetric-anisotropy: [-1.03214008 0.64046775 -0.16031723 10.67951504 -0.32709547]\n",
"Energies for debugging: \n",
"array([[-0.07435037, -0.00649513, 0.00714932, -0.07459916],\n",
" [-0.07593293, -0.01067952, 0.01189878, -0.07602297],\n",
" [-0.0795695 , 0.00016091, 0.00015972, -0.07975399]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.07602297, -0.0795695 , -0.07435037])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.07602297341278706 -0.07975398680085131\n",
"\n",
"================================================================================================================================================================\n",
"Runtime information: \n",
"Total runtime: 501.2763705420002 s\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"Initial setup: 0.12531970899999578 s\n",
"Hamiltonian conversion and XC field extraction: 0.888 s\n",
"Pair and site datastructure creatrions: 0.062 s\n",
"k set cration and distribution: 0.024 s\n",
"Rotating XC potential: 0.245 s\n",
"Greens function inversion: 499.875 s\n",
"Calculate energies and magnetic components: 0.056 s"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"Magnetic entities integrated.\n",
"Pairs integrated.\n",
"Magnetic parameters calculated.\n",
"##################################################################### GROGU OUTPUT #############################################################################\n",
"================================================================================================================================================================\n",
"Input file: \n",
"Not yet specified.\n",
"Output file: \n",
"test.pickle\n",
"Number of nodes in the parallel cluster: 1\n",
"================================================================================================================================================================\n",
"Cell [Ang]: \n",
"[[ 3.79100000e+00 0.00000000e+00 0.00000000e+00]\n",
" [-1.89550000e+00 3.28310231e+00 0.00000000e+00]\n",
" [ 1.25954923e-15 2.18160327e-15 2.05700000e+01]]\n",
"================================================================================================================================================================\n",
"DFT axis: \n",
"[0 0 1]\n",
"Quantization axis and perpendicular rotation directions:\n",
"[1 0 0] --» [array([0, 1, 0]), array([0, 0, 1])]\n",
"[0 1 0] --» [array([1, 0, 0]), array([0, 0, 1])]\n",
"[0 0 1] --» [array([1, 0, 0]), array([0, 1, 0])]\n",
"================================================================================================================================================================\n",
"Parameters for the contour integral:\n",
"Number of k points: 1000\n",
"k point directions: x\n",
"Ebot: -13\n",
"Eset: 50\n",
"Esetp: 10000\n",
"================================================================================================================================================================\n",
"Atomic information: \n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[atom index]Element(orbitals) x [Ang] y [Ang] z [Ang] Sx Sy Sz Q Lx Ly Lz Jx Jy Jz\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[3]Fe(2) -7.339158738013707e-06 4.149278510690423e-06 11.657585837928032\n",
"\n",
"[4]Fe(2) -7.326987662162937e-06 4.158274523275774e-06 8.912422537596708\n",
"\n",
"[5]Fe(2) 1.8954667088117545 1.0943913231921656 10.285002698393109\n",
"\n",
"================================================================================================================================================================\n",
"Exchange [meV]\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"Magnetic entity1 Magnetic entity2 [i j k] d [Ang]\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[3]Fe(2) [4]Fe(2) [0 0 0] d [Ang] Not yet.\n",
"Isotropic: -29.359042196157713\n",
"DMI: [-8.93813379e-01 4.16574774e+00 -3.59758916e-06]\n",
"Symmetric-anisotropy: [-4.57147523 1.18770348 0.33237646 4.15572505 -0.02850636]\n",
"Energies for debugging: \n",
"array([[-0.02817134, -0.00086531, 0.00092232, -0.02597527],\n",
" [-0.03689861, -0.00415573, 0.00417577, -0.03393052],\n",
" [-0.03160252, -0.00033238, -0.00033237, -0.03121927]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.03393052, -0.03160252, -0.02817134])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.03393051742760642 -0.031219274782673133\n",
"\n",
"[4]Fe(2) [5]Fe(2) [0 0 0] d [Ang] Not yet.\n",
"Isotropic: -74.98947011735306\n",
"DMI: [-6.82126017e+00 1.12890803e+01 6.51055432e-04]\n",
"Symmetric-anisotropy: [-1.03170277 0.64211178 -0.16032097 10.67947464 -0.32714492]\n",
"Energies for debugging: \n",
"array([[-0.07434736, -0.00649412, 0.00714841, -0.07459988],\n",
" [-0.07593108, -0.01067947, 0.01189869, -0.07602117],\n",
" [-0.07956766, 0.00016097, 0.00015967, -0.07975216]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.07602117, -0.07956766, -0.07434736])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.07602117288317486 -0.07975215648287909\n",
"\n",
"[3]Fe(2) [5]Fe(2) [0 0 0] d [Ang] Not yet.\n",
"Isotropic: -75.04936117965987\n",
"DMI: [ 6.85701206e+00 -1.13051160e+01 6.39732773e-04]\n",
"Symmetric-anisotropy: [ -1.05318057 0.68103129 -0.16032 -10.70364791 0.31624841]\n",
"Energies for debugging: \n",
"array([[-0.07436833, 0.00654076, -0.00717326, -0.07467721],\n",
" [-0.07601601, 0.01070365, -0.01190658, -0.07610254],\n",
" [-0.07956796, 0.00016096, 0.00015968, -0.07975245]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.07610254, -0.07956796, -0.07436833])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.07610254174486064 -0.07975245001820208\n",
"\n",
"================================================================================================================================================================\n",
"Runtime information: \n",
"Total runtime: 261.890385875 s\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"Initial setup: 0.1216103749998183 s\n",
"Hamiltonian conversion and XC field extraction: 1.045 s\n",
"Pair and site datastructure creatrions: 0.011 s\n",
"k set cration and distribution: 0.006 s\n",
"Rotating XC potential: 0.224 s\n",
"Greens function inversion: 260.450 s\n",
"Calculate energies and magnetic components: 0.033 s"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"Magnetic entities integrated.\n",
"Pairs integrated.\n",
"Magnetic parameters calculated.\n",
"##################################################################### GROGU OUTPUT #############################################################################\n",
"================================================================================================================================================================\n",
"Input file: \n",
"Not yet specified.\n",
"Output file: \n",
"test.pickle\n",
"Number of nodes in the parallel cluster: 1\n",
"================================================================================================================================================================\n",
"Cell [Ang]: \n",
"[[ 3.79100000e+00 0.00000000e+00 0.00000000e+00]\n",
" [-1.89550000e+00 3.28310231e+00 0.00000000e+00]\n",
" [ 1.25954923e-15 2.18160327e-15 2.05700000e+01]]\n",
"================================================================================================================================================================\n",
"DFT axis: \n",
"[0 0 1]\n",
"Quantization axis and perpendicular rotation directions:\n",
"[1 0 0] --» [array([0, 1, 0]), array([0, 0, 1])]\n",
"[0 1 0] --» [array([1, 0, 0]), array([0, 0, 1])]\n",
"[0 0 1] --» [array([1, 0, 0]), array([0, 1, 0])]\n",
"================================================================================================================================================================\n",
"Parameters for the contour integral:\n",
"Number of k points: 3000\n",
"k point directions: x\n",
"Ebot: -13\n",
"Eset: 50\n",
"Esetp: 10000\n",
"================================================================================================================================================================\n",
"Atomic information: \n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[atom index]Element(orbitals) x [Ang] y [Ang] z [Ang] Sx Sy Sz Q Lx Ly Lz Jx Jy Jz\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[3]Fe(2) -7.339158738013707e-06 4.149278510690423e-06 11.657585837928032\n",
"\n",
"[4]Fe(2) -7.326987662162937e-06 4.158274523275774e-06 8.912422537596708\n",
"\n",
"[5]Fe(2) 1.8954667088117545 1.0943913231921656 10.285002698393109\n",
"\n",
"================================================================================================================================================================\n",
"Exchange [meV]\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"Magnetic entity1 Magnetic entity2 [i j k] d [Ang]\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[3]Fe(2) [4]Fe(2) [0 0 0] d [Ang] Not yet.\n",
"Isotropic: -29.437239263932703\n",
"DMI: [-8.91096571e-01 4.16386016e+00 -3.68076797e-06]\n",
"Symmetric-anisotropy: [-4.68204753 1.22980695 0.33079224 4.15200152 -0.03180686]\n",
"Energies for debugging: \n",
"array([[-0.02820743, -0.00085929, 0.0009229 , -0.025985 ],\n",
" [-0.03707978, -0.004152 , 0.00417572, -0.03411929],\n",
" [-0.03167345, -0.0003308 , -0.00033079, -0.03129215]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.03411929, -0.03167345, -0.02820743])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.03411928679618277 -0.03129215156448653\n",
"\n",
"[4]Fe(2) [5]Fe(2) [0 0 0] d [Ang] Not yet.\n",
"Isotropic: -74.98086703681366\n",
"DMI: [-6.81158085e+00 1.13265508e+01 5.68487147e-04]\n",
"Symmetric-anisotropy: [-1.03582622 0.63764125 -0.15959679 10.72110977 -0.32326625]\n",
"Energies for debugging: \n",
"array([[-0.07434323, -0.00648831, 0.00713485, -0.07458268],\n",
" [-0.07592777, -0.01072111, 0.01193199, -0.07601669],\n",
" [-0.07959289, 0.00016017, 0.00015903, -0.07977653]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.07601669, -0.07959289, -0.07434323])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.07601669325607426 -0.07977653333847946\n",
"\n",
"================================================================================================================================================================\n",
"Runtime information: \n",
"Total runtime: 808.34989875 s\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"Initial setup: 0.1594020829999998 s\n",
"Hamiltonian conversion and XC field extraction: 0.995 s\n",
"Pair and site datastructure creatrions: 0.021 s\n",
"k set cration and distribution: 0.021 s\n",
"Rotating XC potential: 0.232 s\n",
"Greens function inversion: 806.884 s\n",
"Calculate energies and magnetic components: 0.037 s"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"Magnetic entities integrated.\n",
"Pairs integrated.\n",
"Magnetic parameters calculated.\n",
"##################################################################### GROGU OUTPUT #############################################################################\n",
"================================================================================================================================================================\n",
"Input file: \n",
"Not yet specified.\n",
"Output file: \n",
"test.pickle\n",
"Number of nodes in the parallel cluster: 1\n",
"================================================================================================================================================================\n",
"Cell [Ang]: \n",
"[[ 3.79100000e+00 0.00000000e+00 0.00000000e+00]\n",
" [-1.89550000e+00 3.28310231e+00 0.00000000e+00]\n",
" [ 1.25954923e-15 2.18160327e-15 2.05700000e+01]]\n",
"================================================================================================================================================================\n",
"DFT axis: \n",
"[0 0 1]\n",
"Quantization axis and perpendicular rotation directions:\n",
"[1 0 0] --» [array([0, 1, 0]), array([0, 0, 1])]\n",
"[0 1 0] --» [array([1, 0, 0]), array([0, 0, 1])]\n",
"[0 0 1] --» [array([1, 0, 0]), array([0, 1, 0])]\n",
"================================================================================================================================================================\n",
"Parameters for the contour integral:\n",
"Number of k points: 2000\n",
"k point directions: x\n",
"Ebot: -13\n",
"Eset: 50\n",
"Esetp: 10000\n",
"================================================================================================================================================================\n",
"Atomic information: \n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[atom index]Element(orbitals) x [Ang] y [Ang] z [Ang] Sx Sy Sz Q Lx Ly Lz Jx Jy Jz\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[3]Fe(2) -7.339158738013707e-06 4.149278510690423e-06 11.657585837928032\n",
"\n",
"[4]Fe(2) -7.326987662162937e-06 4.158274523275774e-06 8.912422537596708\n",
"\n",
"[5]Fe(2) 1.8954667088117545 1.0943913231921656 10.285002698393109\n",
"\n",
"================================================================================================================================================================\n",
"Exchange [meV]\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"Magnetic entity1 Magnetic entity2 [i j k] d [Ang]\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[3]Fe(2) [4]Fe(2) [0 0 0] d [Ang] Not yet.\n",
"Isotropic: -29.313466612791018\n",
"DMI: [-8.85106686e-01 4.16843252e+00 -3.50602459e-06]\n",
"Symmetric-anisotropy: [-4.7530289 1.27630805 0.34469396 4.15760367 -0.03005581]\n",
"Energies for debugging: \n",
"array([[-0.02803716, -0.00085505, 0.00091516, -0.02583675],\n",
" [-0.03702114, -0.0041576 , 0.00417926, -0.0340665 ],\n",
" [-0.03178903, -0.0003447 , -0.00034469, -0.03139132]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.0340665 , -0.03178903, -0.02803716])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.03406649551707385 -0.031391324924774755\n",
"\n",
"[4]Fe(2) [5]Fe(2) [0 0 0] d [Ang] Not yet.\n",
"Isotropic: -74.97640334609967\n",
"DMI: [-6.84069197e+00 1.12809486e+01 8.75098125e-04]\n",
"Symmetric-anisotropy: [-1.03102826 0.63307456 -0.16123618 10.67285449 -0.32447457]\n",
"Energies for debugging: \n",
"array([[-0.07434333, -0.00651622, 0.00716517, -0.07457845],\n",
" [-0.07591065, -0.01067285, 0.01188904, -0.07600743],\n",
" [-0.07959609, 0.00016211, 0.00016036, -0.07978159]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.07600743, -0.07959609, -0.07434333])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.07600743160328334 -0.07978158717380361\n",
"\n",
"================================================================================================================================================================\n",
"Runtime information: \n",
"Total runtime: 534.5927785000001 s\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"Initial setup: 0.14542879100008577 s\n",
"Hamiltonian conversion and XC field extraction: 0.903 s\n",
"Pair and site datastructure creatrions: 0.016 s\n",
"k set cration and distribution: 0.014 s\n",
"Rotating XC potential: 0.242 s\n",
"Greens function inversion: 533.223 s\n",
"Calculate energies and magnetic components: 0.050 s"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"Magnetic entities integrated.\n",
"Pairs integrated.\n",
"Magnetic parameters calculated.\n",
"##################################################################### GROGU OUTPUT #############################################################################\n",
"================================================================================================================================================================\n",
"Input file: \n",
"Not yet specified.\n",
"Output file: \n",
"test.pickle\n",
"Number of nodes in the parallel cluster: 1\n",
"================================================================================================================================================================\n",
"Cell [Ang]: \n",
"[[ 3.79100000e+00 0.00000000e+00 0.00000000e+00]\n",
" [-1.89550000e+00 3.28310231e+00 0.00000000e+00]\n",
" [ 1.25954923e-15 2.18160327e-15 2.05700000e+01]]\n",
"================================================================================================================================================================\n",
"DFT axis: \n",
"[0 0 1]\n",
"Quantization axis and perpendicular rotation directions:\n",
"[1 0 0] --» [array([0, 1, 0]), array([0, 0, 1])]\n",
"[0 1 0] --» [array([1, 0, 0]), array([0, 0, 1])]\n",
"[0 0 1] --» [array([1, 0, 0]), array([0, 1, 0])]\n",
"================================================================================================================================================================\n",
"Parameters for the contour integral:\n",
"Number of k points: 1000\n",
"k point directions: x\n",
"Ebot: -13\n",
"Eset: 50\n",
"Esetp: 10000\n",
"================================================================================================================================================================\n",
"Atomic information: \n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[atom index]Element(orbitals) x [Ang] y [Ang] z [Ang] Sx Sy Sz Q Lx Ly Lz Jx Jy Jz\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[3]Fe(2) -7.339158738013707e-06 4.149278510690423e-06 11.657585837928032\n",
"\n",
"[4]Fe(2) -7.326987662162937e-06 4.158274523275774e-06 8.912422537596708\n",
"\n",
"[5]Fe(2) 1.8954667088117545 1.0943913231921656 10.285002698393109\n",
"\n",
"================================================================================================================================================================\n",
"Exchange [meV]\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"Magnetic entity1 Magnetic entity2 [i j k] d [Ang]\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[3]Fe(2) [4]Fe(2) [0 0 0] d [Ang] Not yet.\n",
"Isotropic: -29.359042196157713\n",
"DMI: [-8.93813379e-01 4.16574774e+00 -3.59758916e-06]\n",
"Symmetric-anisotropy: [-4.57147523 1.18770348 0.33237646 4.15572505 -0.02850636]\n",
"Energies for debugging: \n",
"array([[-0.02817134, -0.00086531, 0.00092232, -0.02597527],\n",
" [-0.03689861, -0.00415573, 0.00417577, -0.03393052],\n",
" [-0.03160252, -0.00033238, -0.00033237, -0.03121927]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.03393052, -0.03160252, -0.02817134])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.03393051742760642 -0.031219274782673133\n",
"\n",
"[4]Fe(2) [5]Fe(2) [0 0 0] d [Ang] Not yet.\n",
"Isotropic: -74.98947011735306\n",
"DMI: [-6.82126017e+00 1.12890803e+01 6.51055432e-04]\n",
"Symmetric-anisotropy: [-1.03170277 0.64211178 -0.16032097 10.67947464 -0.32714492]\n",
"Energies for debugging: \n",
"array([[-0.07434736, -0.00649412, 0.00714841, -0.07459988],\n",
" [-0.07593108, -0.01067947, 0.01189869, -0.07602117],\n",
" [-0.07956766, 0.00016097, 0.00015967, -0.07975216]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.07602117, -0.07956766, -0.07434736])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.07602117288317486 -0.07975215648287909\n",
"\n",
"================================================================================================================================================================\n",
"Runtime information: \n",
"Total runtime: 272.760337666 s\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"Initial setup: 0.13726933300000033 s\n",
"Hamiltonian conversion and XC field extraction: 0.970 s\n",
"Pair and site datastructure creatrions: 0.013 s\n",
"k set cration and distribution: 0.017 s\n",
"Rotating XC potential: 0.217 s\n",
"Greens function inversion: 271.373 s\n",
"Calculate energies and magnetic components: 0.034 s"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"##################################################################### GROGU OUTPUT #############################################################################\n",
"================================================================================================================================================================\n",
"Input file: \n",
"Not yet specified.\n",
"Output file: \n",
"test.pickle\n",
"Number of nodes in the parallel cluster: 1\n",
"================================================================================================================================================================\n",
"Cell [Ang]: \n",
"[[ 3.79100000e+00 0.00000000e+00 0.00000000e+00]\n",
" [-1.89550000e+00 3.28310231e+00 0.00000000e+00]\n",
" [ 1.25954923e-15 2.18160327e-15 2.05700000e+01]]\n",
"================================================================================================================================================================\n",
"DFT axis: \n",
"[0 0 1]\n",
"Quantization axis and perpendicular rotation directions:\n",
"[1 0 0] --» [array([0, 1, 0]), array([0, 0, 1])]\n",
"[0 1 0] --» [array([1, 0, 0]), array([0, 0, 1])]\n",
"[0 0 1] --» [array([1, 0, 0]), array([0, 1, 0])]\n",
"================================================================================================================================================================\n",
"Parameters for the contour integral:\n",
"Number of k points: 20\n",
"k point directions: xy\n",
"Ebot: -15\n",
"Eset: 100\n",
"Esetp: 1000\n",
"================================================================================================================================================================\n",
"Atomic information: \n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[atom index]Element(orbitals) x [Ang] y [Ang] z [Ang] Sx Sy Sz Q Lx Ly Lz Jx Jy Jz\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[3]Fe(2) -7.339158738013707e-06 4.149278510690423e-06 11.657585837928032\n",
"\n",
"[4]Fe(2) -7.326987662162937e-06 4.158274523275774e-06 8.912422537596708\n",
"\n",
"[5]Fe(2) 1.8954667088117545 1.0943913231921656 10.285002698393109\n",
"\n",
"================================================================================================================================================================\n",
"Exchange [meV]\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"Magnetic entity1 Magnetic entity2 [i j k] d [Ang]\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"[3]Fe(2) [4]Fe(2) [0 0 0] d [Ang] Not yet.\n",
"Isotropic: -63.51146633376187\n",
"DMI: [-9.32966002e-01 -8.89800564e-04 -2.02862680e-06]\n",
"Symmetric-anisotropy: [-3.33721683e+00 1.29672703e+00 6.03687008e-04 -8.09695186e-04\n",
" -6.00702131e-06]\n",
"Energies for debugging: \n",
"array([[-6.22147393e-02, -9.32959995e-04, 9.32972009e-04,\n",
" -6.14709765e-02],\n",
" [-6.75755955e-02, 8.09695186e-07, -9.69905943e-07,\n",
" -6.68486832e-02],\n",
" [-5.36624493e-02, -6.05715634e-07, -6.01658381e-07,\n",
" -5.36632256e-02]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.06684868, -0.05366245, -0.06221474])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.06684868316242108 -0.053663225627735525\n",
"\n",
"[4]Fe(2) [5]Fe(2) [0 0 0] d [Ang] Not yet.\n",
"Isotropic: -60.97776480541008\n",
"DMI: [-3.79946502e+00 6.15248803e+00 3.52644581e-03]\n",
"Symmetric-anisotropy: [0.09164177 0.11139034 0.07107136 6.24190815 0.03636875]\n",
"Energies for debugging: \n",
"array([[-6.08663745e-02, -3.83583377e-03, 3.76309627e-03,\n",
" -6.11807969e-02],\n",
" [-6.06347990e-02, -6.24190815e-03, 6.06306790e-03,\n",
" -6.08861230e-02],\n",
" [-5.98977554e-02, -6.75449092e-05, -7.45978008e-05,\n",
" -5.98154343e-02]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.06088612, -0.05989776, -0.06086637])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.060886123032493376 -0.05981543426889457\n",
"\n",
"[3]Fe(2) [5]Fe(2) [0 0 0] d [Ang] Not yet.\n",
"Isotropic: -60.9832595805832\n",
"DMI: [ 3.78505688e+00 -6.13845903e+00 3.52688440e-03]\n",
"Symmetric-anisotropy: [ 0.08120798 0.11261323 0.07107254 -6.23157554 -0.04249828]\n",
"Energies for debugging: \n",
"array([[-6.08706463e-02, 3.82755516e-03, -3.74255860e-03,\n",
" -6.11770808e-02],\n",
" [-6.06458648e-02, 6.23157554e-03, -6.04534251e-03,\n",
" -6.09020516e-02],\n",
" [-5.98977110e-02, -6.75456589e-05, -7.45994277e-05,\n",
" -5.98153841e-02]])\n",
"J_ii for debugging: (check if this is the same as in calculate_exchange_tensor)\n",
"array([-0.06090205, -0.05989771, -0.06087065])\n",
"Test J_xx = E(y,z) = E(z,y)\n",
"-0.060902051599344476 -0.05981538413498572\n",
"\n",
"================================================================================================================================================================\n",
"Runtime information: \n",
"Total runtime: 203.083672208 s\n",
"----------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"Initial setup: 0.1483790410000001 s\n",
"Hamiltonian conversion and XC field extraction: 0.861 s\n",
"Pair and site datastructure creatrions: 0.017 s\n",
"k set cration and distribution: 0.022 s\n",
"Rotating XC potential: 0.247 s\n",
"Greens function inversion: 201.715 s\n",
"Calculate energies and magnetic components: 0.073 s"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"========================================\n",
" \n",
"Atom Angstrom\n",
"# Label, x y z Sx Sy Sz #Q Lx Ly Lz Jx Jy Jz\n",
"--------------------------------------------------------------------------------------------------------------------------------------------------------------------------\n",
"Te1 1.8955 1.0943 13.1698 -0.0000 0.0000 -0.1543 # 5.9345 -0.0000 0.0000 -0.0537 -0.0000 0.0000 -0.2080 \n",
"Te2 1.8955 1.0943 7.4002 0.0000 -0.0000 -0.1543 # 5.9345 0.0000 -0.0000 -0.0537 0.0000 -0.0000 -0.2080 \n",
"Ge3 -0.0000 2.1887 10.2850 0.0000 0.0000 -0.1605 # 3.1927 -0.0000 0.0000 0.0012 0.0000 0.0000 -0.1593 \n",
"Fe4 -0.0000 0.0000 11.6576 0.0001 -0.0001 2.0466 # 8.3044 0.0000 -0.0000 0.1606 0.0001 -0.0001 2.2072 \n",
"Fe5 -0.0000 0.0000 8.9124 -0.0001 0.0001 2.0466 # 8.3044 -0.0000 0.0000 0.1606 -0.0001 0.0001 2.2072 \n",
"Fe6 1.8955 1.0944 10.2850 0.0000 0.0000 1.5824 # 8.3296 -0.0000 -0.0000 0.0520 -0.0000 0.0000 1.6344 \n",
"==================================================================================================================================\n",
" \n",
"Exchange meV\n",
"--------------------------------------------------------------------------------\n",
"# at1 at2 i j k # d (Ang)\n",
"--------------------------------------------------------------------------------\n",
"Fe4 Fe5 0 0 0 # 2.7452\n",
"Isotropic -82.0854\n",
"DMI 0.12557 -0.00082199 6.9668e-08\n",
"Symmetric-anisotropy -0.60237 -0.83842 -0.00032278 -1.2166e-05 -3.3923e-05\n",
"--------------------------------------------------------------------------------\n",
"Fe4 Fe6 0 0 0 # 2.5835\n",
"Isotropic -41.9627\n",
"DMI 1.1205 -1.9532 0.0018386\n",
"Symmetric-anisotropy 0.26007 -0.00013243 0.12977 -0.069979 -0.042066\n",
"--------------------------------------------------------------------------------\n"
]
3 months ago
}
],
"metadata": {
"kernelspec": {
"display_name": ".venv",
"language": "python",
"name": "python3"
},
"language_info": {
"codemirror_mode": {
"name": "ipython",
"version": 3
},
"file_extension": ".py",
"mimetype": "text/x-python",
"name": "python",
"nbconvert_exporter": "python",
"pygments_lexer": "ipython3",
"version": "3.9.6"
3 months ago
}
},
"nbformat": 4,
"nbformat_minor": 2
}