Skip to content

Commit

Permalink
fix: orca_ctnums.py also looks for *.log now
Browse files Browse the repository at this point in the history
improved detection of singlet-triplet excitations for ORCA
  • Loading branch information
eljost committed Apr 9, 2024
1 parent 59a0757 commit 96efe81
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 5 deletions.
2 changes: 1 addition & 1 deletion pysisyphus/calculators/ORCA.py
Original file line number Diff line number Diff line change
Expand Up @@ -675,7 +675,7 @@ def __init__(
)
except AttributeError:
self.log("Doing TDA/TDDFT calculation without gradient.")
self.triplets = bool(re.search(r"triplets\s+true", self.blocks))
self.triplets = bool(re.search(r"triplets\s+true|irootmult\s+triplet", self.blocks))
self.inp_fn = "orca.inp"
self.out_fn = "orca.out"
self.to_keep = (
Expand Down
17 changes: 13 additions & 4 deletions scripts/orca_ctnums.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,9 @@
from pysisyphus.wavefunction.excited_states import norm_ci_coeffs, ct_numbers_for_states


def load_data(base_name: Path, triplets: bool = False, ignore_bonds: Optional[list[int]] = None):
def load_data(
base_name: Path, triplets: bool = False, ignore_bonds: Optional[list[int]] = None
):
if ignore_bonds is None:
ignore_bonds = list()

Expand All @@ -31,6 +33,9 @@ def load_data(base_name: Path, triplets: bool = False, ignore_bonds: Optional[li
log_fn = base_name.with_suffix(".log")
wf_fn = base_name.with_suffix(".bson")

if not log_fn.exists():
log_fn = base_name.with_suffix(".out")

# Drop GS, only keep excitation energies
all_ens = parse_orca_all_energies(log_fn, triplets=triplets, do_tddft=True)
exc_ens = all_ens[1:] - all_ens[0]
Expand All @@ -41,7 +46,9 @@ def load_data(base_name: Path, triplets: bool = False, ignore_bonds: Optional[li
wf = Wavefunction.from_file(wf_fn)
print(f"Loaded wavefunction from '{wf_fn}'.")

frags = get_fragments(wf.atoms, wf.coords, ignore_bonds=ignore_bonds, with_unconnected_atoms=True)
frags = get_fragments(
wf.atoms, wf.coords, ignore_bonds=ignore_bonds, with_unconnected_atoms=True
)
# Convert from list of frozensets to list of lists
frags = list(map(list, frags))

Expand Down Expand Up @@ -104,7 +111,7 @@ def run():
nbonds = len(bonds) // 2
ignore_bonds = list()
for i in range(nbonds):
ignore_bonds.append(bonds[2*i:2*(i+1)])
ignore_bonds.append(bonds[2 * i : 2 * (i + 1)])

data = load_data(base_name, triplets, ignore_bonds)

Expand All @@ -116,7 +123,9 @@ def run():
homogenous_frags = data["frags"]

frags = []
for key, _frag in it.groupby(homogenous_frags, key=lambda frag_atom_ind: frag_atom_ind[0]):
for key, _frag in it.groupby(
homogenous_frags, key=lambda frag_atom_ind: frag_atom_ind[0]
):
cur_frag = []
for _, atom_ind in _frag:
cur_frag.append(atom_ind)
Expand Down

0 comments on commit 96efe81

Please sign in to comment.