forked from zhangdft/scripts
-
Notifications
You must be signed in to change notification settings - Fork 0
/
lammpstogen.pl
executable file
·47 lines (46 loc) · 1.43 KB
/
lammpstogen.pl
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
37
38
39
40
41
42
43
44
45
46
47
#!/usr/bin/perl
$atom_types = "O H";
print "WARNING!! check atom types: $atom_types\n";
open (INF, "<$ARGV[0]") || die "Can't open input dump file\n";
open (OUT, ">lmp_traj.gen") || die "Can't open lmp_traj.gen\n";
while (<INF>) {
$time_step = <INF>;
chomp($time_step);
$line = <INF>;
$natom = <INF>;
chomp($natom);
print (OUT " $natom S # time step $time_step\n");
print (OUT "$atom_types\n");
$line = <INF>;
# assumes orthorhombic box
@line = split " ", <INF>;
$lx = $line[1] - $line[0];
@line = split " ", <INF>;
$ly = $line[1] - $line[0];
@line = split " ", <INF>;
$lz = $line[1] - $line[0];
@line = split " ", <INF>;
for ($i = 0; $i < @line; $i++) {
if ($line[$i] =~ /id/) {
$id_ind = $i-2;
} elsif ($line[$i] =~ /type/) {
$type_ind = $i - 2;
} elsif ($line[$i] =~ /x/) {
$x_ind = $i - 2;
} elsif ($line[$i] =~ /y/) {
$y_ind = $i - 2;
} elsif ($line[$i] =~ /z/) {
$z_ind = $i - 2;
}
}
for ($i = 0; $i < $natom; $i++) {
@line = split " ", <INF>;
print (OUT " $line[$id_ind] $line[$type_ind] $line[$x_ind] $line[$y_ind] $line[$z_ind]\n");
}
print (OUT " 0.0000000000E+00 0.0000000000E+00 0.0000000000E+00\n");
print (OUT " $lx 0.0000000000E+00 0.0000000000E+00\n");
print (OUT " 0.0000000000E+00 $ly 0.0000000000E+00\n");
print (OUT " 0.0000000000E+00 0.0000000000E+00 $lz\n");
}
close (INF);
close (OUT);