5dd13798c293d4405b503bf944785b6c78fa4db2
[unres.git] / source / cluster / wham / src-M / CMakeLists.txt
1 #
2 # CMake project file for cluster analysis from WHAM for oligomeric proteins  
3
4
5 enable_language (Fortran C)
6
7 #================================
8 # Set source file lists
9 #================================
10 set(UNRES_CLUSTER_WHAM_M_SRC0 
11         arcos.f
12         cartprint.f
13         chainbuild.f
14         contact.f
15         convert.f
16         energy_p_new.F
17         fitsq.f
18         geomout.F
19         gnmr1.f
20         hc.f
21         icant.f
22         initialize_p.F
23         intcor.f
24         int_from_cart1.f
25         main_clust.F
26         matmult.f
27         misc.f
28         noyes.f
29         parmread.F
30         permut.f
31         pinorm.f
32         printmat.f
33         probabl.F
34         read_coords.F
35         readpdb.f
36         readrtns.F
37         rescode.f
38         setup_var.f
39         srtclust.f
40         timing.F
41         track.F
42         wrtclust.f
43         work_partition.F
44 )
45
46 set(UNRES_CLUSTER_WHAM_M_PP_SRC
47         energy_p_new.F
48         initialize_p.F
49         geomout.F
50         main_clust.F
51         parmread.F
52         probabl.F
53         read_coords.F
54         readrtns.F
55         timing.F
56         track.F
57         work_partition.F
58
59
60
61 #================================================
62 # Set comipiler flags for different sourcefiles  
63 #================================================
64 if (Fortran_COMPILER_NAME STREQUAL "ifort")
65   set(FFLAGS0 "-ip -w -I. -I${CMAKE_CURRENT_SOURCE_DIR}/include_unres"  ) 
66 elseif (Fortran_COMPILER_NAME STREQUAL "gfortran")
67   set(FFLAGS0 "-std=legacy -I. -I${CMAKE_CURRENT_SOURCE_DIR}/include_unres" ) 
68 else ()
69   set(FFLAGS0 "-I. -I${CMAKE_CURRENT_SOURCE_DIR}/include_unres" ) 
70 endif (Fortran_COMPILER_NAME STREQUAL "ifort")
71
72 #=========================================
73 # Add MPI compiler flags
74 #=========================================
75 if(UNRES_WITH_MPI)
76   set(FFLAGS0 "${FFLAGS0} -I${MPI_Fortran_INCLUDE_PATH}")
77 endif(UNRES_WITH_MPI)
78
79 set_property(SOURCE ${UNRES_CLUSTER_WHAM_M_SRC0} PROPERTY COMPILE_FLAGS ${FFLAGS0} )
80
81 #=========================================
82 #  Settings for GAB force field
83 #=========================================
84 if(UNRES_MD_FF STREQUAL "GAB" )
85    # set preprocesor flags   
86    set(CPPFLAGS "PROCOR  -DSPLITELE -DCRYST_BOND  -DCRYST_THETA -DCRYST_SC  -DSCCORPDB" )
87  
88 #=========================================
89 #  Settings for E0LL2Y force field
90 #=========================================
91 elseif(UNRES_MD_FF STREQUAL "E0LL2Y")
92    # set preprocesor flags   
93    set(CPPFLAGS "PROCOR  -DSPLITELE -DSCCORPDB" )
94 elseif(UNRES_MD_FF STREQUAL "4P")
95   set(CPPFLAGS "SPLITELE -DLANG0 -DCRYST_BOND -DCRYST_THETA -DCRYST_SC -DSCCORPDB" )
96 endif(UNRES_MD_FF STREQUAL "GAB")
97
98 #=========================================
99 # Additional flags
100 #=========================================
101 set(CPPFLAGS "${CPPFLAGS} -DUNRES -DISNAN") 
102
103 #=========================================
104 # Compiler specific flags
105 #=========================================
106 if (Fortran_COMPILER_NAME STREQUAL "ifort")
107   # Add ifort preprocessor flags
108   set(CPPFLAGS "${CPPFLAGS} -DPGI") 
109 elseif (Fortran_COMPILER_NAME STREQUAL "f95")
110   # Add new gfortran flags
111   set(CPPFLAGS "${CPPFLAGS} -DG77") 
112 elseif (Fortran_COMPILER_NAME STREQUAL "gfortran")
113   # Add old gfortran flags
114   set(CPPFLAGS "${CPPFLAGS} -DG77") 
115 endif (Fortran_COMPILER_NAME STREQUAL "ifort")
116
117
118 #=========================================
119 # System specific flags
120 #=========================================
121 if(${CMAKE_SYSTEM_NAME} MATCHES "Linux")
122   set(CPPFLAGS "${CPPFLAGS} -DLINUX") 
123 endif(${CMAKE_SYSTEM_NAME} MATCHES "Linux")
124
125 #=========================================
126 # Add MPI preprocessor flags
127 #=========================================
128 if (UNRES_WITH_MPI)
129   set(CPPFLAGS "${CPPFLAGS} -DMP -DMPI") 
130 endif(UNRES_WITH_MPI)
131
132
133 #=========================================
134 # Apply preprocesor flags to *.F files
135 #=========================================
136 set_property(SOURCE ${UNRES_CLUSTER_WHAM_M_PP_SRC} PROPERTY COMPILE_DEFINITIONS ${CPPFLAGS} )  
137
138 set_property(SOURCE proc_proc.c PROPERTY COMPILE_DEFINITIONS "LINUX -DPGI" )
139
140 #========================================
141 #  Setting binary name
142 #========================================
143 set(UNRES_CLUSTER_WHAM_M_BIN "cluster_wham-mult_${Fortran_COMPILER_NAME}_MPI_${UNRES_MD_FF}.exe")
144
145 #=========================================
146 # Set full unres CLUSTER sources
147 #=========================================
148 set(UNRES_CLUSTER_WHAM_M_SRCS ${UNRES_CLUSTER_WHAM_M_SRC0} proc_proc.c)
149
150 #=========================================
151 # Build the binary
152 #=========================================
153 add_executable(UNRES_CLUSTER_WHAM_M_BIN ${UNRES_CLUSTER_WHAM_M_SRCS} )
154 set_target_properties(UNRES_CLUSTER_WHAM_M_BIN PROPERTIES OUTPUT_NAME ${UNRES_CLUSTER_WHAM_M_BIN})
155 set_property(TARGET UNRES_CLUSTER_WHAM_M_BIN PROPERTY RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin )
156
157 #=========================================
158 # Link libraries
159 #=========================================
160 # link MPI libraries
161 if(UNRES_WITH_MPI)
162   target_link_libraries( UNRES_CLUSTER_WHAM_M_BIN ${MPI_Fortran_LIBRARIES} )
163 endif(UNRES_WITH_MPI)
164 # link libxdrf.a 
165 target_link_libraries( UNRES_CLUSTER_WHAM_M_BIN xdrf )
166
167
168 #=========================================
169 # Install Path
170 #=========================================
171 install(TARGETS UNRES_CLUSTER_WHAM_M_BIN DESTINATION ${CMAKE_INSTALL_PREFIX}/cluster)
172
173
174 #=========================================
175 # TESTS 
176 #=========================================
177
178 #  MESSAGE (STATUS "${MPI_Fortran_LIBRARIES}")
179   if ("${MPI_Fortran_LIBRARIES}"  MATCHES "lam")
180      MESSAGE (STATUS "LAM MPI library detected")
181      set (boot_lam "-boot")
182   else()
183      set (boot_lam "")
184   endif()
185
186   if (UNRES_SRUN)
187    set (np "-n")
188    set (mpiexec "srun")
189   elseif(UNRES_MPIRUN)
190    set (np "-np")
191    set (mpiexec "mpirun")
192   else()
193    set (np "-np")
194    set (mpiexec "mpiexec")
195   endif()
196
197
198 FILE(WRITE ${CMAKE_CURRENT_BINARY_DIR}/scripts/cluster_wham_mpi_E0LL2Y.sh
199 "#!/bin/sh
200 export POT=GB
201 export INPUT=$1
202 export INTIN=1L2Y_wham
203 export OUTPUT=1L2Y_clust
204 export PDB=CART
205 export COORD=CX
206 export PRINTCOOR=PRINT_PDB
207 #-----------------------------------------------------------------------------
208 CLUSTER_WHAM_BIN=${CMAKE_BINARY_DIR}/bin/${UNRES_CLUSTER_WHAM_M_BIN}
209 #-----------------------------------------------------------------------------
210 DD=${CMAKE_SOURCE_DIR}/PARAM
211 export BONDPAR=$DD/bond_AM1.parm
212 export THETPAR=$DD/theta_abinitio.parm
213 export ROTPAR=$DD/rotamers_AM1_aura.10022007.parm
214 export TORPAR=$DD/torsion_631Gdp.parm
215 export TORDPAR=$DD/torsion_double_631Gdp.parm
216 export ELEPAR=$DD/electr_631Gdp.parm
217 export SIDEPAR=$DD/scinter_$POT.parm
218 export FOURIER=$DD/fourier_opt.parm.1igd_hc_iter3_3
219 export SCPPAR=$DD/scp.parm
220 export SCCORPAR=$DD/sccor_am1_pawel.dat
221 export THETPARPDB=$DD/thetaml.5parm
222 export ROTPARPDB=$DD/scgauss.parm
223 export PATTERN=$DD/patterns.cart
224 export CONTFUNC=GB
225 export SIDEP=$DD/contact.3.parm
226 export SCRATCHDIR=.
227 #-----------------------------------------------------------------------------
228 echo CTEST_FULL_OUTPUT
229 ${mpiexec} ${boot_lam} ${np} $2 $CLUSTER_WHAM_BIN 
230 ./cluster_wham_check.sh $1 
231 ")
232
233 #
234 # File permissions workaround
235 #
236 FILE(   COPY ${CMAKE_CURRENT_BINARY_DIR}/scripts/cluster_wham_mpi_E0LL2Y.sh 
237         DESTINATION ${CMAKE_CURRENT_BINARY_DIR}
238         FILE_PERMISSIONS OWNER_READ OWNER_WRITE OWNER_EXECUTE GROUP_READ GROUP_EXECUTE WORLD_READ WORLD_EXECUTE
239 )
240
241 FILE(COPY ${CMAKE_SOURCE_DIR}/ctest/cluster_wham_check.sh
242         DESTINATION ${CMAKE_CURRENT_BINARY_DIR} 
243         FILE_PERMISSIONS OWNER_READ OWNER_WRITE OWNER_EXECUTE GROUP_READ GROUP_EXECUTE WORLD_READ WORLD_EXECUTE
244 )
245
246 FILE(COPY ${CMAKE_SOURCE_DIR}/ctest/1L2Y_clust.inp
247         DESTINATION ${CMAKE_CURRENT_BINARY_DIR} )
248
249 FILE(COPY ${CMAKE_SOURCE_DIR}/ctest/1L2Y_wham.cx
250         DESTINATION ${CMAKE_CURRENT_BINARY_DIR} )
251
252 FILE(COPY ${CMAKE_SOURCE_DIR}/ctest/1L2Y.pdb
253         DESTINATION ${CMAKE_CURRENT_BINARY_DIR} )
254
255
256 if(UNRES_MD_FF STREQUAL "E0LL2Y")
257     add_test(NAME CLUSTER_WHAM_M_remd COMMAND sh ${CMAKE_CURRENT_BINARY_DIR}/cluster_wham_mpi_E0LL2Y.sh 1L2Y_clust 2 )
258 endif(UNRES_MD_FF STREQUAL "E0LL2Y")