-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathlasp2extxyz.py
41 lines (30 loc) · 1.1 KB
/
lasp2extxyz.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
# lasp arc/Train file to REANN configuration file for training
# JamesMisaka in 20230503
import sys
from allstr_new import AllStr
def lasp2extxyz(strname, forname, filetype=1):
'''
lasp allstr.arc/allfor.arc or TrainStr.txt/TrainFor.txt
to extxyz for ASE and Nequip
Inputs:
strname: input str file (.arc or .txt will be identified)
forname: input for file
filetype: 0 for allstr/for.arc 1 for TrainStr/For.txt
'''
allstr = AllStr()
if filetype==0 or strname[-4:] == '.arc':
allstr.read_arc( strname, forname)
elif filetype==1 or strname[-4:] == '.txt':
allstr.train_data_init(strname, forname)
else:
print("filetype should be correct !")
allstr.gen_extxyz(range(len(allstr)))
if __name__ == "__main__":
if len(sys.argv) < 3:
print("Input Format: lasp2extxyz.py <strfile> <forfile>")
elif len(sys.argv) == 3:
strname, forname = sys.argv[1], sys.argv[2]
lasp2extxyz(strname, forname)
else:
strname, forname, filetype = sys.argv[1:]
lasp2extxyz(strname, forname, filetype)