-
Notifications
You must be signed in to change notification settings - Fork 111
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
[VASP] Add handler for PSMAXN warnings and associated failures #133
Comments
The order of the POTCARs matters? That's crazy. Is this true even though we set e.g. ENCUT manually? |
After further reading, I think those forum posts are out of date. According to the current docs:
|
As an additional note, @mkhorton and I noticed that when this failure occurs, somehow the output from stdout is not written to
O O P P E NN N MM MM P P
|
Yes, |
After further testing, it seems that LREAL=False is not always a reliable fix for this. The other challenge is that often times the calculation can complete succesfully with a PSMAXN warning, so having a Custodian handler for it is problematic - we don't want to keep restarting the calculation just because that warning is present, but only when the calculation fails. I've updated the Handler to respond only to the REALOPT error, not the PSMAXN warning. The real question is - how can we make sure that |
I’d open a separate issue for the vasp.out issue, I don’t think it’s
specific to this particular warning.
…On Tue, Nov 19, 2019 at 08:58, Ryan Kingsbury ***@***.***> wrote:
After further testing, it seems that LREAL=False is not always a reliable
fix for this. The other challenge is that often times the calculation can
complete succesfully with a PSMAXN warning, so having a Custodian handler
for it is problematic - we don't want to keep restarting the calculation
just because that warning is present, but only when the calculation fails.
The real question is - how can we make sure that vasp.out gets populated
correctly when these failures occur?
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#133?email_source=notifications&email_token=AAWWWRGWXQMD5E33ZBRMUOLQUQLLVA5CNFSM4JNQZLB2YY3PNVWWK3TUL52HS4DFVREXG43VMVBW63LNMVXHJKTDN5WW2ZLOORPWSZGOEEO5PSA#issuecomment-555603912>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AAWWWRDYFM7TGO7HKUZALK3QUQLLVANCNFSM4JNQZLBQ>
.
|
I would say we want to know what is a reliable way to resolve the problem first. If there is a reliable way, then fixing even runs that theoretically could finish is fine. You can also set a counter, e.g., if you have tried to fix PSMAXN a few times, the job will be flagged as unrecoverable. |
Summary
Details
With certain combinations of ENCUT, LREAL, and pseudopotentials, VASP issues the warning
WARNING: PSMAXN for non-local potential too small
In some cases vasp still runs successfully, in other cases it will fail, e.g.
It appears that Custodian does not recognize the above type of failure as an error. As a result,
_run_job()
will attempt to validate the output of the calculation (which never ran in the first place and therefore never generated output) and raise aValidationError
.The ValidationError is very difficult to troubleshoot without running vasp manually. In this situation, the contents of
vasp.out
are empty andstd_err.txt
contains onlysrun: fatal: Can not execute vasp_std
Suggested solution
Information about the PSMAXN warning and associated failures is scarce, but there appear to be several possible fixes:
I have had the most success with Option 1.
Option 2 has not solved the issue for me and is only applicable if the user does not specify ENCUT in the INCAR file (I think; see docs ). It is also not clear whether this fix is still relevant to the latest versions of VASP.
I'm not yet familiar enough with the architecture of Custodian to know the best way to address this, but it seems to me that, at a minimum, an error handler to catch this type of failure would be valuable. Even better would be to modify LREAL to FALSE on the fly.
Further reading on troubleshooting the VASP PSMAXN warnings:
https://cms.mpi.univie.ac.at/vasp-forum/viewtopic.php?f=3&t=8370
https://cms.mpi.univie.ac.at/vasp-forum/viewtopic.php?t=14811
https://www.researchgate.net/post/Relaxation_in_metal_using_vasp2
http://materials.duke.edu/AFLOW/README_AFLOW.TXT)
The text was updated successfully, but these errors were encountered: