-
Notifications
You must be signed in to change notification settings - Fork 875
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
QChem: add CMIRS solvent model support #2215
Merged
Merged
Changes from all commits
Commits
Show all changes
40 commits
Select commit
Hold shift + click to select a range
ef5d3e7
QChem: translate DMSO name in smd_solvent
rkingsbury 970b085
QCInput: support $svp and $pcm_nonels
rkingsbury f02a4c2
QCinput more thorough docstring for svp and pcm_nonels
rkingsbury bf4832c
QChemDictSet: support svp and pcm_nonels
rkingsbury bf95315
bugfix
rkingsbury 6de0663
bugfix
rkingsbury 286efce
don't lowercase svp block
rkingsbury f2773ee
Merge branch 'master' of https://github.com/materialsproject/pymatgen…
rkingsbury f343d1d
Merge branch 'master' of https://github.com/materialsproject/pymatgen…
rkingsbury 9ad3ed7
QCInput: dmso bugfix
rkingsbury 23147b6
QCInput: format svp as dict; update authors+license
rkingsbury eb0a6fe
QCInput: fix read_svp for dict format
rkingsbury 805b71e
QCInput: type conversion fix in read_svp
rkingsbury aeabaeb
QCInput: make everything a str for consistency
rkingsbury e5da4ea
utils: update docstring of lower_and_check_unique
rkingsbury f114e86
QChemDictSet: ISOSVP/CMIRS support; more coming
rkingsbury e24e701
QChemDictSet: add warnings and tests for bad inputs
rkingsbury e7c7c97
QChemDictSet: add CMIRS 0.0005 params; type hinting
rkingsbury 8f241e1
QChem: refactor and test lower_and_check_unique
rkingsbury f667018
QChem: propagate CMIRS/ISOSVP to all InputSet
rkingsbury 6a15781
QChem: CMIRS and ISOSVP tests for SinglePointSet
rkingsbury 5b7c065
QChem: author/credit/copyright updates
rkingsbury 668ea14
QCInput: desc for pcm_nonels and svp templates etc.
rkingsbury 5023658
Merge branch 'master' of https://github.com/materialsproject/pymatgen…
rkingsbury 7e4e511
QCInput: revert is not None for svp and pcm_nonels
rkingsbury 38de6d2
QCOutput: WIP CMIRS and ISOSVP parsing
rkingsbury 9865c77
QChem: restore __credits__; author update in test_outputs
rkingsbury db79c93
Merge branch 'master' of https://github.com/materialsproject/pymatgen…
rkingsbury 29ed510
revert minor author changes
rkingsbury 8210eb2
QCOutput: revert typo
rkingsbury 68db373
QCOutput: revert comment about possible bug
rkingsbury dd69c8a
QCOutput: update multi test files for CMIRS/ISOSVP
rkingsbury 1a16d22
QCOutput: add unit tests for CMIRS / ISOSVP
rkingsbury 01b0744
QCOutput: ensure all solvent keys populated; upd tests
rkingsbury 8b04d30
QCOutput: nest ISOSVP/CMIRS data in solvent_data
rkingsbury a873aaa
QCOutput: bugfix for PCM and SMD solvent_data
rkingsbury 35f31f8
QChem: disable gen_scfman in ISOSVP calcs
rkingsbury 40f1056
QChem: add gen_scfman comment to docstring
rkingsbury 03ce038
QChem: add ipnrf flag for CMIRS
rkingsbury df3a879
QChem: update test for ipnrf
rkingsbury File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
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 |
---|---|---|
|
@@ -18,10 +18,8 @@ | |
|
||
from .utils import lower_and_check_unique, read_pattern, read_table_pattern | ||
|
||
__author__ = "Brandon Wood, Samuel Blau, Shyam Dwaraknath, Julian Self, Evan Spotte-Smith" | ||
__copyright__ = "Copyright 2018, The Materials Project" | ||
__version__ = "0.1" | ||
__email__ = "[email protected]" | ||
__author__ = "Brandon Wood, Samuel Blau, Shyam Dwaraknath, Evan Spotte-Smith, Ryan Kingsbury" | ||
__copyright__ = "Copyright 2018-2022, The Materials Project" | ||
__credits__ = "Xiaohui Qu" | ||
|
||
logger = logging.getLogger(__name__) | ||
|
@@ -50,6 +48,8 @@ def __init__( | |
plots: dict | None = None, | ||
nbo: dict | None = None, | ||
geom_opt: dict | None = None, | ||
svp: dict | None = None, | ||
pcm_nonels: dict | None = None, | ||
): | ||
""" | ||
Args: | ||
|
@@ -110,6 +110,8 @@ def __init__( | |
self.plots = lower_and_check_unique(plots) | ||
self.nbo = lower_and_check_unique(nbo) | ||
self.geom_opt = lower_and_check_unique(geom_opt) | ||
self.svp = lower_and_check_unique(svp) | ||
self.pcm_nonels = lower_and_check_unique(pcm_nonels) | ||
|
||
# Make sure rem is valid: | ||
# - Has a basis | ||
|
@@ -194,6 +196,13 @@ def __str__(self): | |
if self.geom_opt is not None: | ||
combined_list.append(self.geom_opt_template(self.geom_opt)) | ||
combined_list.append("") | ||
# svp section | ||
if self.svp: | ||
rkingsbury marked this conversation as resolved.
Show resolved
Hide resolved
|
||
combined_list.append(self.svp_template(self.svp)) | ||
combined_list.append("") | ||
# pcm_nonels section | ||
if self.pcm_nonels: | ||
rkingsbury marked this conversation as resolved.
Show resolved
Hide resolved
|
||
combined_list.append(self.pcm_nonels_template(self.pcm_nonels)) | ||
return "\n".join(combined_list) | ||
|
||
@staticmethod | ||
|
@@ -238,6 +247,8 @@ def from_string(cls, string: str) -> QCInput: | |
plots = None | ||
nbo = None | ||
geom_opt = None | ||
svp = None | ||
pcm_nonels = None | ||
if "opt" in sections: | ||
opt = cls.read_opt(string) | ||
if "pcm" in sections: | ||
|
@@ -256,6 +267,10 @@ def from_string(cls, string: str) -> QCInput: | |
nbo = cls.read_nbo(string) | ||
if "geom_opt" in sections: | ||
geom_opt = cls.read_geom_opt(string) | ||
if "svp" in sections: | ||
svp = cls.read_svp(string) | ||
if "pcm_nonels" in sections: | ||
pcm_nonels = cls.read_pcm_nonels(string) | ||
return cls( | ||
molecule, | ||
rem, | ||
|
@@ -269,6 +284,8 @@ def from_string(cls, string: str) -> QCInput: | |
plots=plots, | ||
nbo=nbo, | ||
geom_opt=geom_opt, | ||
svp=svp, | ||
pcm_nonels=pcm_nonels, | ||
) | ||
|
||
@staticmethod | ||
|
@@ -429,6 +446,9 @@ def smx_template(smx: dict) -> str: | |
for key, value in smx.items(): | ||
if value == "tetrahydrofuran": | ||
smx_list.append(f" {key} thf") | ||
# Q-Chem bug, see https://talk.q-chem.com/t/smd-unrecognized-solvent/204 | ||
elif value == "dimethyl sulfoxide": | ||
smx_list.append(f" {key} dmso") | ||
else: | ||
smx_list.append(f" {key} {value}") | ||
smx_list.append("$end") | ||
|
@@ -519,14 +539,35 @@ def nbo_template(nbo: dict) -> str: | |
nbo_list.append("$end") | ||
return "\n".join(nbo_list) | ||
|
||
@staticmethod | ||
def svp_template(svp: dict) -> str: | ||
""" | ||
Template for the $svp section. | ||
|
||
Args: | ||
svp: dict of SVP parameters, e.g. | ||
{"rhoiso": "0.001", "nptleb": "1202", "itrngr": "2", "irotgr": "2"} | ||
|
||
Returns: | ||
str: the $svp section. Note that all parameters will be concatenated onto | ||
a single line formatted as a FORTRAN namelist. This is necessary | ||
because the isodensity SS(V)PE model in Q-Chem calls a secondary code. | ||
""" | ||
svp_list = [] | ||
svp_list.append("$svp") | ||
param_list = [f"{_key}={value}" for _key, value in svp.items()] | ||
svp_list.append(", ".join(param_list)) | ||
svp_list.append("$end") | ||
return "\n".join(svp_list) | ||
|
||
@staticmethod | ||
def geom_opt_template(geom_opt: dict) -> str: | ||
""" | ||
Args: | ||
geom_opt (): | ||
|
||
Returns: | ||
(str) | ||
(str) geom_opt parameters. | ||
""" | ||
geom_opt_list = [] | ||
geom_opt_list.append("$geom_opt") | ||
|
@@ -535,6 +576,36 @@ def geom_opt_template(geom_opt: dict) -> str: | |
geom_opt_list.append("$end") | ||
return "\n".join(geom_opt_list) | ||
|
||
@staticmethod | ||
def pcm_nonels_template(pcm_nonels: dict) -> str: | ||
""" | ||
Template for the $pcm_nonels section. | ||
|
||
Arg | ||
pcm_nonels: dict of CMIRS parameters, e.g. | ||
{ | ||
"a": "-0.006736", | ||
"b": "0.032698", | ||
"c": "-1249.6", | ||
"d": "-21.405", | ||
"gamma": "3.7", | ||
"solvrho": "0.05", | ||
"delta": 7, | ||
"gaulag_n": 40, | ||
} | ||
|
||
Returns: | ||
(str) | ||
""" | ||
pcm_nonels_list = [] | ||
pcm_nonels_list.append("$pcm_nonels") | ||
for key, value in pcm_nonels.items(): | ||
# if the value is None, don't write it to output | ||
rkingsbury marked this conversation as resolved.
Show resolved
Hide resolved
|
||
if value is not None: | ||
pcm_nonels_list.append(f" {key} {value}") | ||
pcm_nonels_list.append("$end") | ||
return "\n".join(pcm_nonels_list) | ||
|
||
@staticmethod | ||
def find_sections(string: str) -> list: | ||
""" | ||
|
@@ -767,6 +838,9 @@ def read_smx(string: str) -> dict: | |
smx[key] = val | ||
if smx["solvent"] == "tetrahydrofuran": | ||
smx["solvent"] = "thf" | ||
# Q-Chem bug, see https://talk.q-chem.com/t/smd-unrecognized-solvent/204 | ||
elif smx["solvent"] == "dimethyl sulfoxide": | ||
smx["solvent"] = "dmso" | ||
return smx | ||
|
||
@staticmethod | ||
|
@@ -872,3 +946,45 @@ def read_geom_opt(string: str) -> dict: | |
for key, val in geom_opt_table[0]: | ||
geom_opt[key] = val | ||
return geom_opt | ||
|
||
@staticmethod | ||
def read_svp(string: str) -> dict: | ||
""" | ||
Read svp parameters from string. | ||
""" | ||
header = r"^\s*\$svp" | ||
row = r"(\w.*)\n" | ||
footer = r"^\s*\$end" | ||
svp_table = read_table_pattern(string, header_pattern=header, row_pattern=row, footer_pattern=footer) | ||
if svp_table == []: | ||
print("No valid svp inputs found.") | ||
return {} | ||
svp_list = svp_table[0][0][0].split(", ") | ||
svp_dict = {} | ||
for s in svp_list: | ||
svp_dict[s.split("=")[0]] = s.split("=")[1] | ||
return svp_dict | ||
|
||
@staticmethod | ||
def read_pcm_nonels(string: str) -> dict: | ||
""" | ||
Read pcm_nonels parameters from string. | ||
|
||
Args: | ||
string (str): String | ||
|
||
Returns: | ||
(dict) PCM parameters | ||
""" | ||
header = r"^\s*\$pcm_nonels" | ||
row = r"\s*([a-zA-Z\_]+)\s+(.+)" | ||
footer = r"^\s*\$end" | ||
pcm_nonels_table = read_table_pattern(string, header_pattern=header, row_pattern=row, footer_pattern=footer) | ||
if not pcm_nonels_table: | ||
print( | ||
"No valid $pcm_nonels inputs found. Note that there should be no '=' \ | ||
chracters in $pcm_nonels input lines." | ||
) | ||
return {} | ||
|
||
return dict(pcm_nonels_table[0]) |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Probably Xiaohui should still get credit. His original work inspired what's now in pymatgen.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I guess I'm not clear on the distinction between
__credits__
and__authors__
(I might just be ignorant). Those seemed equivalent to me. Happy to revert though if__credits__
implies origination or some other special status.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I did make sure to add Xiaohui to the
__authors__
list for any file where he was listed in__credits__
, in case that wasn't obvious