Skip to main content

Base module of castepinput

Project description

A simple CASTEP input files parser/writer

This package provide a basic framework for read/write input files of CASTEP. There is already a excellent reader/writer implemented in ase but they are ortentated to work with the Atoms and Calculator classes in ase. It also requires a CASTEP binary to exist to work. This package aim to provide a more generic framework with minimum dependency for simple (but important) tasks of writing and reading inputs files of CASTEP.

Usage

The two classes to be used for reading/writing inputs are ParamInput and CellInput. Keyword-value pairs can be set the same as dictionaries. For example:

from castepinput import CellInput, ParamInput, Block
# ParamInput is in fact just a subclass of OrderedDict
param = ParamInput(cut_off_energy=300, task="singlepoint")
param["opt_strategy"] = "speed"

# Use the Block class to signal that it is a BLOCK
# The following line sets the positions_abs
cell = CellInput(positions_abs=Block(["C 0 0 0", "C 1 0 0"])

The two classes use simple string formatting when writing out the content. See the following code as example.

cell = CellInput(snap_to_symmetry=True)

# Should give 'snap_to_symmetry : True'
cell.get_string()

# Should give 'symmetry_genreate : true'
cell['snap_to_symmetry'] = 'true'
cell.get_string()

# Not all CASTEP keyword requires a value
# Use "" as the value will result just a keyword on a line
cell['symmetry_generate'] = ''
# Should give a string with a line 'symmetry_generate'
cell.get_string()

# Set cell and positions use the set methods
cell.set_cell([10 ,10 , 10])
cell.set_positions(["O", "O"], [[0, 0, 0], [1.4, 0, 0]])
# Save to file
cell.save("O2.cell")

To initialize from a existing param/cell file, use the ParamInput.from_file method.

cell = CellInput.from_file("O2.cell")
# This should give [[10, 0, 0], [0, 10, 0], [0, 0, 10]]
cell.get_cell()

# The value returned should be "" to be consistent with setting
cell["symmetry_generate"]

We also try to be smart and convert string into python types where it is possible. Supported types are integer, floats and 1-d arrays made of integer/floats. These coversions can be avoided by using ParamInput.from_file(filename, plain=True) when loading files.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

castepinput-0.1.10.tar.gz (8.1 kB view details)

Uploaded Source

Built Distribution

castepinput-0.1.10-py3-none-any.whl (9.5 kB view details)

Uploaded Python 3

File details

Details for the file castepinput-0.1.10.tar.gz.

File metadata

  • Download URL: castepinput-0.1.10.tar.gz
  • Upload date:
  • Size: 8.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.3

File hashes

Hashes for castepinput-0.1.10.tar.gz
Algorithm Hash digest
SHA256 03c4966e58783c95b4990f74ff7dd29bcc669156c5abea27e9e9c43a2ce430e7
MD5 0b1d583c8593000ebd19acaa17221b2a
BLAKE2b-256 df31b42e13cd6f3696020108e8faa0be32285f5525077bd5b79863dc7ca0c326

See more details on using hashes here.

File details

Details for the file castepinput-0.1.10-py3-none-any.whl.

File metadata

File hashes

Hashes for castepinput-0.1.10-py3-none-any.whl
Algorithm Hash digest
SHA256 94f995b151cdaab7a103e8e41491104b02e04fb4a2a37a0f022be14de95d0443
MD5 73ad7fb67fa8eb5a82a4b42cbb3edb23
BLAKE2b-256 a92892dcd4d773e1714dacdd2fc53ce064705527ac5c1766fcac7ee941e1ff43

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page