forked from m3g/packmol
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcompute_data.f90
63 lines (51 loc) · 2.35 KB
/
compute_data.f90
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
!
! Written by Leandro Martínez, 2009-2011.
! Copyright (c) 2009-2018, Leandro Martínez, Jose Mario Martinez,
! Ernesto G. Birgin.
!
module compute_data
use sizes
integer :: ntotmol, ntype, natfix, ntotat
integer :: nboxes(3), nb2(3)
integer, allocatable :: nmols(:) ! (ntype)
integer, allocatable :: natoms(:) ! (ntype)
integer, allocatable :: idfirst(:) ! (ntype)
integer, allocatable :: nratom(:) ! (ntotat)
integer, allocatable :: iratom(:,:) ! (ntotat,mrperatom)
integer, allocatable :: ityperest(:) ! (maxrest)
integer, allocatable :: ibmol(:) ! (ntotat)
integer, allocatable :: ibtype(:) ! (ntotat)
double precision :: scale, scale2
double precision :: fdist, frest
double precision :: sizemin(3), sizemax(3)
double precision :: boxl(3)
double precision, allocatable :: xcart(:,:) ! (ntotat,3)
double precision, allocatable :: coor(:,:) ! (ntotat,3)
double precision, allocatable :: restpars(:,:) ! (maxrest,9)
double precision, allocatable :: rot_bound(:,:,:) ! (ntype,3,2)
double precision, allocatable :: radius(:), radius_ini(:), fscale(:) ! (ntotat)
double precision, allocatable :: short_radius(:), short_radius_scale(:) ! ntotat
double precision, allocatable :: gxcar(:,:) ! (ntotat,3)
double precision, allocatable :: fdist_atom(:), frest_atom(:) ! (ntotat)
double precision, allocatable :: dmax(:) ! (ntype)
double precision, allocatable :: cmxmin(:), cmymin(:), cmzmin(:) ! (ntype)
double precision, allocatable :: cmxmax(:), cmymax(:), cmzmax(:) ! (ntype)
logical, allocatable :: constrain_rot(:,:) ! (ntype,3)
logical, allocatable :: comptype(:) ! (ntype)
logical, allocatable :: fixedatom(:) ! (ntotat)
logical, allocatable :: use_short_radius(:) ! ntotat
logical :: init1, move
! For linked lists
integer, allocatable :: latomnext(:) ! (ntotat)
integer, allocatable :: latomfirst(:,:,:) ! (0:nbp+1,0:nbp+1,0:nbp+1)
integer, allocatable :: latomfix(:,:,:) ! (0:nbp+1,0:nbp+1,0:nbp+1)
! For movebad
double precision, allocatable :: fmol(:), radiuswork(:) ! (ntotat)
! For restmol
double precision, allocatable :: xmol(:) ! (nn)
logical, allocatable :: compsafe(:) ! (ntype)
! For boxes with atoms linked lists
integer :: lboxfirst
integer, allocatable :: lboxnext(:) ! ((nbp+2)**3)
logical, allocatable :: hasfree(:,:,:) ! (0:nbp+1,0:nbp+1,0:nbp+1)
end module compute_data