-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
71 changed files
with
36,313 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
# Sphinx build info version 1 | ||
# This file hashes the configuration used when building these files. When it is not found, a full rebuild will be done. | ||
config: 92fdbd13a33a05f90811066fc53ca8f4 | ||
tags: 645f666f9bcd5a90fca523b33c5a78b7 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,75 @@ | ||
**************************************************************** | ||
Introduction | ||
**************************************************************** | ||
|
||
What is cif2x? | ||
---------------------------------------------------------------- | ||
|
||
In recent years, the use of machine learning for predicting material properties and designing substances (known as materials informatics) has gained considerable attention. | ||
The accuracy of machine learning depends heavily on the preparation of appropriate training data. | ||
Therefore, the development of tools and environments for the rapid generation of training data is expected to contribute significantly to the advancement of research in materials informatics. | ||
|
||
Cif2x is a tool that generates input files for first-principles calculations from cif files. | ||
It constructs parts that vary depending on the type of material and computational conditions from crystal structure data, using input parameters as a template. | ||
It is capable of generating multiple input files tailored to specific computational conditions. | ||
Currently, it supports `VASP <https://www.vasp.at>`, `Quantum ESPRESSO <https://www.quantum-espresso.org>`, and `OpenMX <http://www.openmx-square.org>`, | ||
with plans to support `AkaiKKR <http://kkr.issp.u-tokyo.ac.jp>` in the future. | ||
|
||
License | ||
---------------------------------------------------------------- | ||
|
||
The distribution of the program package and the source codes for cif2x follow GNU General Public License version 3 (GPL v3) or later. | ||
|
||
Contributors | ||
---------------------------------------------------------------- | ||
|
||
This software was developed by the following contributors. | ||
|
||
- ver.1.0-alpha (Released on 2023/12/28) | ||
|
||
- Developers | ||
|
||
- Kazuyoshi Yoshimi (The Instutite for Solid State Physics, The University of Tokyo) | ||
|
||
- Tatsumi Aoyama (The Instutite for Solid State Physics, The University of Tokyo) | ||
|
||
- Yuichi Motoyama (The Instutite for Solid State Physics, The University of Tokyo) | ||
|
||
- Masahiro Fukuda (The Instutite for Solid State Physics, The University of Tokyo) | ||
|
||
- Tetsuya Fukushima (The National Institute of Advanced Industrial Science and Technology (AIST)) | ||
|
||
- Kota Ido (The Instutite for Solid State Physics, The University of Tokyo) | ||
|
||
- Shusuke Kasamatsu (Yamagata University) | ||
|
||
- Takashi Koretsune (Tohoku University) | ||
|
||
- Project Corrdinator | ||
|
||
- Taisuke Ozaki (The Instutite for Solid State Physics, The University of Tokyo) | ||
|
||
|
||
Copyright | ||
---------------------------------------------------------------- | ||
|
||
.. only:: html | ||
|
||
|copy| *2023- The University of Tokyo. All rights reserved.* | ||
|
||
.. |copy| unicode:: 0xA9 .. copyright sign | ||
|
||
.. only:: latex | ||
|
||
:math:`\copyright` *2023- The University of Tokyo. All rights reserved.* | ||
|
||
|
||
This software was developed with the support of "Project for advancement of software usability in materials science" of The Institute for Solid State Physics, The University of Tokyo. | ||
|
||
Operating environment | ||
---------------------------------------------------------------- | ||
|
||
This tool was tested on the following platforms: | ||
|
||
- Ubuntu Linux + python3 | ||
|
47 changes: 47 additions & 0 deletions
47
manual/develop/en/html/_sources/cif2x/appendix/index.rst.txt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,47 @@ | ||
.. _sec-cif2x-appendix: | ||
|
||
================================================================ | ||
Extension guide | ||
================================================================ | ||
|
||
Adding modes of Quantum ESPRESSO | ||
---------------------------------------------------------------- | ||
|
||
In order to add supports to modes of Quantum ESPRESSO, the mapping between the modes and the transformation classes should be added to ``create_modeproc()`` function in ``src/cif2x/qe/calc_mode.py``. | ||
|
||
.. code-block:: python | ||
def create_modeproc(mode, qe): | ||
if mode in ["scf", "nscf"]: | ||
modeproc = QEmode_pw(qe) | ||
else: | ||
modeproc = QEmode_generic(qe) | ||
return modeproc | ||
The transformation functionality for each mode is provided as a derived class of ``QEmode_base`` class. This class implements methods ``update_namelist()`` for updating the namelist block, and ``update_cards()`` for generating data of card blocks. | ||
In the current version, two classes are provided: ``QEmode_pw`` class for scf and nscf calculations of pw.x, and ``QEmode_generic`` class for generating output as-is. | ||
|
||
.. code-block:: python | ||
class QEmode_base: | ||
def __init__(self, qe): | ||
def update_namelist(self, content): | ||
def update_cards(self, content): | ||
For the namelist, the transformation class generates values for blank entries from crystal structure data and other sources. It may also force to set values such as the lattice parameters that are determined from the crystal structure data, or those that must be specified consistently with other parameters. The functions are provided for each mode separately. | ||
|
||
For card blocks, a function is provided for each card, and the mapping between the card type and the function is given in the ``card_table`` variable. | ||
The method ``update_cards()`` in the base class picks up and runs the function associated to the card, and updates the content of the card. Of course, a new ``update_cards()`` function may be defined. | ||
|
||
.. code-block:: python | ||
self.card_table = { | ||
'CELL_PARAMETERS': generate_cell_parameters, | ||
'ATOMIC_SPECIES': generate_atomic_species, | ||
'ATOMIC_POSITIONS': generate_atomic_positions, | ||
'K_POINTS': generate_k_points, | ||
} | ||
The functions for cards are gathered in ``src/cif2x/qe/cards.py`` with the function names as ``generate_{card name}``. These functions takes parameters for card blocks as argument, and returns a dictionary containing the card name, the options, and the data field. |
100 changes: 100 additions & 0 deletions
100
manual/develop/en/html/_sources/cif2x/basic-usage.rst.txt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,100 @@ | ||
Installation and basic usage | ||
================================================================ | ||
|
||
**Prerequisite** | ||
|
||
Input file generator for first-principles calculation ``cif2x`` included in HTP-tools requires the following programs and libraries: | ||
|
||
- python 3.x | ||
- pymatgen module | ||
- ruamel.yaml module | ||
- f90nml module | ||
- qe-tools module | ||
- numpy module | ||
- pandas module | ||
- monty module | ||
- OpenBabel module (optional) | ||
|
||
**Official pages** | ||
|
||
- `GitHub repository <https://github.com/issp-center-dev/cif2x>`_ | ||
|
||
**Downloads** | ||
|
||
cif2x can be downloaded by the following command with git: | ||
|
||
.. code-block:: bash | ||
$ git clone https://github.com/issp-center-dev/cif2x.git | ||
**Installation** | ||
|
||
Once the source files are obtained, you can install cif2x by running the following command. The required libraries will also be installed automatically at the same time. | ||
|
||
.. code-block:: bash | ||
$ cd ./cif2x | ||
$ python3 -m pip install . | ||
The executable file ``cif2x`` will be installed. | ||
You may need to add ``--user`` option next to ``install`` keyword above in case you are not allowed to install packages system-wide. | ||
|
||
|
||
**Directory structure** | ||
|
||
:: | ||
|
||
. | ||
|-- LICENSE | ||
|-- README.md | ||
|-- pyproject.toml | ||
|-- docs/ | ||
| |-- ja/ | ||
| |-- en/ | ||
| |-- tutorial/ | ||
|-- src/ | ||
| |-- cif2x/ | ||
| |-- __init__.py | ||
| |-- main.py | ||
| |-- cif2struct.py | ||
| |-- struct2qe.py | ||
| |-- qe/ | ||
| | |-- __init__.py | ||
| | |-- calc_mode.py | ||
| | |-- cards.py | ||
| | |-- content.py | ||
| | |-- qeutils.py | ||
| | |-- tools.py | ||
| |-- struct2vasp.py | ||
| |-- struct2openmx.py | ||
| |-- openmx/ | ||
| | |-- __init__.py | ||
| | |-- vps_table.py | ||
| |-- utils.py | ||
|-- sample/ | ||
|
||
|
||
**Basic usage** | ||
|
||
``cif2x`` is a tool to generate a set of input files for first-principles calculation software. It takes an input parameter file as a template, and generates parameter items that may vary by materials and calculation conditions from crystallographic data. In the present version, ``cif2x`` supports Quantum ESPRESSO, VASP, and OpenMX. | ||
|
||
#. Prepare input parameter file | ||
|
||
First, you need to create an input parameter file in YAML format that describes contents of the input file to be generated for the first-principles calculation software. | ||
|
||
#. Prepare crystal structure files and pseudo-potential files | ||
|
||
The crystal structure data need to be prepared for the target materials. The file format is CIF, POSCAR, xfs, or those supported by pymatgen. | ||
|
||
For Quantum ESPRESSO, the pseudo-potential files and the index file in CSV format need to be placed. Their locations are specified in the input parameter file. | ||
|
||
For VASP, the location of the pseudo-potential files will be specified in a file ``~/.config/.pmgrc.yaml`` or by an environment variable. It may be specified in the input parameter file. | ||
|
||
#. Run command | ||
|
||
Run ``cif2x`` command with the input parameter file and the crystal structure data as arguments. To generate input files for Quantum ESPRESSO, the target option ``-t QE`` should be specified. The option turns to ``-t VASP`` for VASP, and ``-t OpenMX`` for OpenMX. | ||
|
||
.. code-block:: bash | ||
$ cif2x -t QE input.yaml material.cif | ||
54 changes: 54 additions & 0 deletions
54
manual/develop/en/html/_sources/cif2x/command/index.rst.txt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,54 @@ | ||
Command reference | ||
================================================================ | ||
|
||
cif2x | ||
---------------------------------------------------------------- | ||
|
||
Generate input files for first-principles calculation software | ||
|
||
SYNOPSIS: | ||
|
||
.. code-block:: bash | ||
cif2x [-v][-q] -t target input_yaml material.cif | ||
cif2x -h | ||
cif2x --version | ||
DESCRIPTION: | ||
|
||
This program reads an input parameter file specified by ``input_yaml`` and a crystal data file specified by ``material.cif``, and generates a set of input files for first-principles calculation software. In the current version, the supported software includes Quantum ESPRESSO, VASP, and OpenMX. | ||
It takes the following command line options. | ||
|
||
- ``-v`` | ||
|
||
increases verbosity of the runtime messages. When specified multiple times, the program becomes more verbose. | ||
|
||
- ``-q`` | ||
|
||
decreases verbosity of the runtime messages. It cancels the effect of ``-v`` option, and when specified multiple times, the program becomes more quiet. | ||
|
||
- ``-t`` *target* | ||
|
||
specifies the target first-principles calculation software. The supported software for *target* is listed as follows: | ||
|
||
- ``QE``, ``espresso``, ``quantum_espresso``: generates input files for Quantum ESPRESSO. | ||
|
||
- ``VASP``: generates input files for VASP. | ||
|
||
- ``OpenMX``: generates input files for OpenMX | ||
|
||
- ``input_yaml`` | ||
|
||
specifies an input parameter file in YAML format. | ||
|
||
- ``material.cif`` | ||
|
||
specifies crystal structure data file. It is in CIF (Crystallographic Information Framework) format, or other format supported by pymatgen. | ||
|
||
- ``-h`` | ||
|
||
displays help and exits. | ||
|
||
- ``--version`` | ||
|
||
displays version information. |
Oops, something went wrong.