From 4c0fd9bf559590af91dc41b1277e9a373e4ac682 Mon Sep 17 00:00:00 2001 From: alex-rakowski Date: Fri, 13 Oct 2023 16:47:00 -0700 Subject: [PATCH] removing generic adding prismatic --- py4DSTEM/process/diffraction/crystal.py | 65 +++++++++++++++++-------- 1 file changed, 45 insertions(+), 20 deletions(-) diff --git a/py4DSTEM/process/diffraction/crystal.py b/py4DSTEM/process/diffraction/crystal.py index 23d9a0c82..f1165d00d 100644 --- a/py4DSTEM/process/diffraction/crystal.py +++ b/py4DSTEM/process/diffraction/crystal.py @@ -423,19 +423,12 @@ def from_ASE( cell=atoms.cell.array, ) - def from_generic_file(filepath, **kwargs): + def from_prismatic(filepath): """ - Create a py4DSTEM Crystal from a wide range of generic file types using - `ase.io.read`, kwargs are passed to `ase.io.read` function. For more details - and potentially compatible filetypes please see https://wiki.fysik.dtu.dk/ase/ase/io/io.html. - Note this has not been tested extensively. The loaded file must have these three properties: - .get_scaled_positions() - .numbers - .cell.array, + Create a py4DSTEM Crystal object from an prismatic style xyz co-ordinate file Args: - filepath (str|Pathlib.Path): path to the file - kwargs: key word arguments to be passed to `ase.io.read` + filepath (str|Pathlib.Path): path to the prismatic format xyz file """ @@ -446,16 +439,48 @@ def from_generic_file(filepath, **kwargs): ) else: from ase.io import read - # try loading the file using ase read and get required properties - try: - atoms = read(filepath, **kwargs) - return Crystal( - positions=atoms.get_scaled_positions(), # fractional coords - numbers=atoms.numbers, - cell=atoms.cell.array, - ) - except Exception as e: - raise e + + atoms = read(filepath, format="prismatic") + + return Crystal( + positions=atoms.get_scaled_positions(), # fractional coords + numbers=atoms.numbers, + cell=atoms.cell.array, + ) + + # def from_generic_file(filepath, **kwargs): + # """ + # Create a py4DSTEM Crystal from a wide range of generic file types using + # `ase.io.read`, kwargs are passed to `ase.io.read` function. For more details + # and potentially compatible filetypes please see https://wiki.fysik.dtu.dk/ase/ase/io/io.html. + # Note this has not been tested extensively. The loaded file must have these three properties: + # .get_scaled_positions() + # .numbers + # .cell.array, + + # Args: + # filepath (str|Pathlib.Path): path to the file + # kwargs: key word arguments to be passed to `ase.io.read` + + # """ + + # # check if ase is installed + # if find_spec("ase") is None: + # raise ImportWarning( + # "Could not import ASE, please install, restart and try again" + # ) + # else: + # from ase.io import read + # # try loading the file using ase read and get required properties + # try: + # atoms = read(filepath, **kwargs) + # return Crystal( + # positions=atoms.get_scaled_positions(), # fractional coords + # numbers=atoms.numbers, + # cell=atoms.cell.array, + # ) + # except Exception as e: + # raise e def from_unitcell_parameters( latt_params,