From cde8a76f23a828eca6b9254c782ed7d31d6f0411 Mon Sep 17 00:00:00 2001 From: "Haoyu (Daniel) YANG" Date: Sun, 15 Sep 2024 21:38:30 +0800 Subject: [PATCH] Remove reverse readline, test again NP1 and recover NumPy 1 dependency support (#203) * test monty fix for reverse readline * ensure pip env consistency * remove reverse readline * remove monty pin * test NP1 * use readlines * revert numpy version pin to > 1.26 to support NP1 --- .github/workflows/test.yml | 3 --- chgnet/utils/vasp_utils.py | 42 +++++++++++++++++--------------------- pyproject.toml | 4 +--- 3 files changed, 20 insertions(+), 29 deletions(-) diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 70dc8cc7..95b4a9a7 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -34,9 +34,6 @@ jobs: pip install uv uv pip install -e .[test,logging] --resolution=${{ matrix.version.resolution }} --system - # TODO: remove pin once reverse readline fixed - uv pip install monty==2024.7.12 --system - - name: Run Tests run: pytest --capture=no --cov --cov-report=xml env: diff --git a/chgnet/utils/vasp_utils.py b/chgnet/utils/vasp_utils.py index 96943d3c..82ee659c 100644 --- a/chgnet/utils/vasp_utils.py +++ b/chgnet/utils/vasp_utils.py @@ -5,7 +5,7 @@ import warnings from typing import TYPE_CHECKING -from monty.io import reverse_readfile +from monty.io import zopen from monty.os.path import zpath from pymatgen.io.vasp.outputs import Oszicar, Vasprun @@ -58,13 +58,11 @@ def parse_vasp_dir( exception_on_bad_xml=False, ) - charge, mag_x, mag_y, mag_z, header, all_lines = [], [], [], [], [], [] + charge, mag_x, mag_y, mag_z, header = [], [], [], [], [] - for line in reverse_readfile(outcar_path): - clean = line.strip() - all_lines.append(clean) + with zopen(outcar_path, encoding="utf-8") as file: + all_lines = [line.strip() for line in file.readlines()] - all_lines.reverse() # For single atom systems, VASP doesn't print a total line, so # reverse parsing is very difficult # for SOC calculations only @@ -79,23 +77,21 @@ def parse_vasp_dir( if clean.startswith("# of ion"): header = re.split(r"\s{2,}", clean.strip()) header.pop(0) - else: - m = re.match(r"\s*(\d+)\s+(([\d\.\-]+)\s+)+", clean) - if m: - tokens = [float(token) for token in re.findall(r"[\d\.\-]+", clean)] - tokens.pop(0) - if read_charge: - charge.append(dict(zip(header, tokens))) - elif read_mag_x: - mag_x.append(dict(zip(header, tokens))) - elif read_mag_y: - mag_y.append(dict(zip(header, tokens))) - elif read_mag_z: - mag_z.append(dict(zip(header, tokens))) - elif clean.startswith("tot"): - if ion_step_count == (len(mag_x_all) + 1): - mag_x_all.append(mag_x) - read_charge = read_mag_x = read_mag_y = read_mag_z = False + elif re.match(r"\s*(\d+)\s+(([\d\.\-]+)\s+)+", clean): + tokens = [float(token) for token in re.findall(r"[\d\.\-]+", clean)] + tokens.pop(0) + if read_charge: + charge.append(dict(zip(header, tokens))) + elif read_mag_x: + mag_x.append(dict(zip(header, tokens))) + elif read_mag_y: + mag_y.append(dict(zip(header, tokens))) + elif read_mag_z: + mag_z.append(dict(zip(header, tokens))) + elif clean.startswith("tot"): + if ion_step_count == (len(mag_x_all) + 1): + mag_x_all.append(mag_x) + read_charge = read_mag_x = read_mag_y = read_mag_z = False if clean == "total charge": read_charge = True read_mag_x = read_mag_y = read_mag_z = False diff --git a/pyproject.toml b/pyproject.toml index ce44d983..ae3a444c 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -9,9 +9,7 @@ license = { text = "Modified BSD" } dependencies = [ "ase>=3.23.0", "cython>=3", - # "monty==2024.7.12", # TODO: restore once readline fixed - # "numpy>=1.26", # TODO: remove after test - "numpy>=2.0.0", + "numpy>=1.26", "nvidia-ml-py3>=7.352.0", "pymatgen>=2024.9.10", "torch>=2.4.1",