Skip to content
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

Atomate2 jz pheasy_phonon #976

Open
wants to merge 33 commits into
base: main
Choose a base branch
from
Open
Changes from 1 commit
Commits
Show all changes
33 commits
Select commit Hold shift + click to select a range
0775785
Add pheasy branch for phonon calculation using LASSO
leslie-zheng Sep 9, 2024
7891554
pheasy_phonons
leslie-zheng Sep 9, 2024
d643fc1
add_pheasy_to_vasp_folder
leslie-zheng Sep 10, 2024
93219ce
Add_pheasy_to_vasp_file
leslie-zheng Sep 10, 2024
f4b59c6
Merge branch 'main' into atomate2_jz_pheasy
JaGeo Sep 16, 2024
e514969
Merge branch 'main' into atomate2_jz_pheasy
JaGeo Sep 20, 2024
11d546b
Modified some parts based on Janine's comments.
leslie-zheng Sep 23, 2024
13acf5a
Merge branch 'atomate2_jz_pheasy' of https://github.com/leslie-zheng/…
leslie-zheng Sep 23, 2024
57ab59f
directly import the class methods from phonons
leslie-zheng Sep 23, 2024
647fe49
clean up the code
leslie-zheng Sep 23, 2024
94a1acc
remove some files.
leslie-zheng Sep 23, 2024
b92e34e
minor change
leslie-zheng Sep 23, 2024
05650d0
allow the users to define the number of displacements for random-disp…
leslie-zheng Sep 23, 2024
0bf1bf8
format_adjustment
leslie-zheng Sep 23, 2024
e9cd8a6
format_adjustment
leslie-zheng Sep 23, 2024
2bacc86
small update
leslie-zheng Sep 24, 2024
4535497
clean up the code and add more comments
leslie-zheng Sep 24, 2024
eab1fe6
minor update
leslie-zheng Sep 24, 2024
36aa5b7
allow the users to control the symmetry precision
leslie-zheng Sep 24, 2024
c69df93
Lower the symmetry precision to allow pheasy to find a correct space …
leslie-zheng Sep 24, 2024
92ea25a
Minor update
leslie-zheng Sep 24, 2024
5d6f122
minor adjustment
leslie-zheng Sep 24, 2024
e17a316
minor update for flow/pheasy.py
leslie-zheng Sep 24, 2024
f46c2fd
resuse some jobs from phonons
leslie-zheng Sep 25, 2024
34a197e
clean up the job(generate_phonon_displacements)
leslie-zheng Sep 25, 2024
be89bce
finished cleaning up the pheasy jobs module
leslie-zheng Sep 25, 2024
1316b1d
finished cleaning up the shemas/pheasy
leslie-zheng Sep 25, 2024
833205a
small adjustment to pass the lint
leslie-zheng Sep 28, 2024
f741a8c
raise a error if ALM is not installed.
leslie-zheng Sep 28, 2024
30de21a
minor update
leslie-zheng Sep 28, 2024
69956d7
Merge branch 'main' into atomate2_jz_pheasy
leslie-zheng Sep 28, 2024
5e2660a
minor update to pass the lint check
leslie-zheng Oct 1, 2024
cabc93a
added support for MLFFs
hrushikesh-s Oct 14, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
15 changes: 9 additions & 6 deletions src/atomate2/common/schemas/pheasy.py
Original file line number Diff line number Diff line change
Expand Up @@ -336,7 +336,7 @@ def from_forces_born(
prim = read('POSCAR')
supercell = read('SPOSCAR')

# To generate the culsters and orbots for second order force constants
# Create the clusters and orbitals for second order force constants
pheasy_cmd_1 = 'pheasy --dim "{0}" "{1}" "{2}" -s -w 2 --symprec 1e-3 --nbody 2'.format(
int(supercell_matrix[0][0]),
int(supercell_matrix[1][1]),
Expand All @@ -349,8 +349,10 @@ def from_forces_born(
int(supercell_matrix[1][1]),
int(supercell_matrix[2][2]))

# Generate the sensing matrix for the input of machine leaning method.i.e., LASSO,
pheasy_cmd_3 = 'pheasy --dim "{0}" "{1}" "{2}" -w 2 -d --symprec 1e-3 --ndata "{3}" --disp_file'.format(
# Generate the Compressive Sensing matrix,i.e., displacment matrix
# for the input of machine leaning method.i.e., LASSO,
pheasy_cmd_3 = 'pheasy --dim "{0}" "{1}" "{2}" -w 2 -d --symprec 1e-3 \
leslie-zheng marked this conversation as resolved.
Show resolved Hide resolved
--ndata "{3}" --disp_file'.format(
int(supercell_matrix[0][0]),
int(supercell_matrix[1][1]),
int(supercell_matrix[2][2]),
Expand All @@ -366,23 +368,24 @@ def from_forces_born(
num_judge = len(disps)

if num_judge > 3:
# Generate the force constants using the LASSO method
# Calculate the force constants using the LASSO method
pheasy_cmd_4 = 'pheasy --dim "{0}" "{1}" "{2}" -f --full_ifc -w 2 --symprec 1e-3 \
-l LASSO --std --rasr BHH --ndata "{3}"'.format(
int(supercell_matrix[0][0]),
int(supercell_matrix[1][1]),
int(supercell_matrix[2][2]),
int(num_har))
else:
# Generate the force constants using the least-squred method
# Calculate the force constants using the least-squred method
pheasy_cmd_4 = 'pheasy --dim "{0}" "{1}" "{2}" -f --full_ifc -w 2 --symprec 1e-3 \
--rasr BHH --ndata "{3}"'.format(
int(supercell_matrix[0][0]),
int(supercell_matrix[1][1]),
int(supercell_matrix[2][2]),
int(num_har))

logger.info("Start running pheasy in andes8: Dartmouth College Clusters or NERSC Perlmutter")
logger.info("Start running pheasy in cluster")

subprocess.call(pheasy_cmd_1, shell=True)
subprocess.call(pheasy_cmd_2, shell=True)
subprocess.call(pheasy_cmd_3, shell=True)
Expand Down