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