ctest copied from prerelease
[unres.git] / source / unres / src_CSA / CMakeLists.txt
1 #
2 # CMake project file for UNRES CSA version
3
4
5 enable_language (Fortran)
6
7 #================================
8 # Set source file lists
9 #================================
10 set(UNRES_CSA_SRC0 
11         arcos.f
12         banach.f
13         bank.F
14         cartder.F
15         cartprint.f
16         chainbuild.F
17         checkder_p.F
18         contact.f
19         convert.f
20         cored.f
21         csa.F
22         dfa.F
23         diff12.f
24         distfit.f
25         djacob.f
26         econstr_local.F
27         elecont.f
28         energy_p_new_barrier.F
29         fitsq.f
30         gen_rand_conf.F
31         geomout_min.F
32         gradient_p.F
33         indexx.f
34         initialize_p.F
35         intcartderiv.F
36         intcor.f
37         intlocal.f
38         int_to_cart.f
39         local_move.f
40         matmult.f
41         minimize_p.F
42         minim_jlee.F
43         minim_mult.F
44         misc.f
45         MP.F
46         newconf.F
47         parmread.F
48         pinorm.f
49         printmat.f
50         prng_32.F
51         randgens.f
52         ran.f
53         readpdb.F
54         readrtns_csa.F
55         refsys.f
56         rescode.f
57         rmdd.f
58         rmsd.F
59         sc_move.F
60         shift.F
61         sumsld.f
62         test.F
63         timing.F
64         TMscore_subroutine.f
65         together.F
66         unres_csa.F
67 )
68
69 set(UNRES_CSA_SRC3 energy_p_new_barrier.F gradient_p.F )
70
71 set(UNRES_CSA_PP_SRC
72         bank.F
73         cartder.F
74         chainbuild.F
75         checkder_p.F
76         csa.F
77         dfa.F
78         econstr_local.F
79         energy_p_new_barrier.F
80         gen_rand_conf.F
81         geomout_min.F
82         gradient_p.F
83         initialize_p.F
84         intcartderiv.F
85         minimize_p.F
86         minim_jlee.F
87         minim_mult.F
88         MP.F
89         newconf.F
90         parmread.F
91         prng_32.F
92         readpdb.F
93         readrtns_csa.F
94         rmsd.F
95         sc_move.F
96         shift.F
97         test.F
98         timing.F
99         together.F
100         unres_csa.F
101
102
103
104 #================================================
105 # Set comipiler flags for different sourcefiles  
106 #================================================
107 if (Fortran_COMPILER_NAME STREQUAL "ifort")
108   set(FFLAGS0 "-c -ip -w" ) 
109   set(FFLAGS1 "-c -w -g -d2 -CA -CB" ) 
110   set(FFLAGS2 "-c -w -g -00 ")
111   #set(FFLAGS3 "-c -w -O3 -ipo -ipo_obj -opt_report" )
112   set(FFLAGS3 "-c -w -ipo " )
113 elseif (Fortran_COMPILER_NAME STREQUAL "gfortran")
114   set(FFLAGS0 "-std=legacy -cpp -c -I. ") 
115   set(FFLAGS1 "-std=legacy -cpp -c -g -I. " ) 
116   set(FFLAGS2 "-std=legacy -cpp -c -I. ")
117   set(FFLAGS3 "-cpp -c -I. " )
118 endif (Fortran_COMPILER_NAME STREQUAL "ifort")
119
120
121 # Add MPI compiler flags
122 if(UNRES_WITH_MPI)
123   set(FFLAGS0 "${FFLAGS0} -I${MPI_Fortran_INCLUDE_PATH}")
124   set(FFLAGS1 "${FFLAGS1} -I${MPI_Fortran_INCLUDE_PATH}")
125   set(FFLAGS2 "${FFLAGS2} -I${MPI_Fortran_INCLUDE_PATH}")
126   set(FFLAGS3 "${FFLAGS3} -I${MPI_Fortran_INCLUDE_PATH}")
127 endif(UNRES_WITH_MPI)
128
129 set_property(SOURCE ${UNRES_CSA_SRC0} PROPERTY COMPILE_FLAGS ${FFLAGS0} )
130 set_property(SOURCE ${UNRES_CSA_SRC1} PROPERTY COMPILE_FLAGS ${FFLAGS1} )
131 set_property(SOURCE ${UNRES_CSA_SRC2} PROPERTY COMPILE_FLAGS ${FFLAGS2} )
132 set_property(SOURCE ${UNRES_CSA_SRC3} PROPERTY COMPILE_FLAGS ${FFLAGS3} )
133
134 #=========================================
135 # Settings for CSA force fields 
136 #=========================================
137
138 if(UNRES_CSA_FF STREQUAL "CASP3" )
139   set(CPPFLAGS "UNRES -DISNAN -DSPLITELE -DLANG0 -DMOMENT -DCRYST_BOND -DCRYST_THETA -DCRYST_SC -DCRYST_TOR" )
140 elseif(UNRES_CSA_FF STREQUAL "ALPHA")
141   set(CPPFLAGS "UNRES -DISNAN -DSPLITELE -DLANG0 -DMOMENT -DCRYST_BOND -DCRYST_THETA -DCRYST_SC" )
142 elseif(UNRES_CSA_FF STREQUAL "BETA")
143   set(CPPFLAGS "UNRES -DISNAN -DSPLITELE -DLANG0 -DMOMENT -DCRYST_BOND -DCRYST_THETA -DCRYST_SC" )
144 elseif(UNRES_CSA_FF STREQUAL "ALPHABETA")
145   set(CPPFLAGS "UNRES -DISNAN -DSPLITELE -DLANG0 -DMOMENT -DCRYST_BOND -DCRYST_THETA -DCRYST_SC" )
146 elseif(UNRES_CSA_FF STREQUAL "CASP5")
147   set(CPPFLAGS "UNRES -DISNAN -DSPLITELE -DLANG0 -DMOMENT -DCRYST_BOND -DCRYST_THETA -DCRYST_SC" )
148 elseif(UNRES_CSA_FF STREQUAL "3P")
149   set(CPPFLAGS "UNRES -DISNAN -DSPLITELE -DLANG0 -DCRYST_BOND -DCRYST_THETA -DCRYST_SC -DSCCORPDB" )
150 elseif(UNRES_CSA_FF STREQUAL "4P")
151   set(CPPFLAGS "UNRES -DISNAN -DSPLITELE -DLANG0 -DCRYST_BOND -DCRYST_THETA -DCRYST_SC -DSCCORPDB" )
152 elseif(UNRES_CSA_FF STREQUAL "GAB" )
153   set(CPPFLAGS "PROCOR -DUNRES -DISNAN -DSPLITELE -DLANG0 -DCRYST_BOND -DCRYST_THETA -DCRYST_SC" )
154 elseif(UNRES_CSA_FF STREQUAL "E0LL2Y" )
155   set(CPPFLAGS "PROCOR -DUNRES -DISNAN -DSPLITELE -DLANG0" )
156 endif(UNRES_CSA_FF STREQUAL "CASP3")
157
158 #=========================================
159 # System specific flags
160 #=========================================
161 if(${CMAKE_SYSTEM_NAME} MATCHES "Linux")
162   set(CPPFLAGS "${CPPFLAGS} -DLINUX") 
163 endif(${CMAKE_SYSTEM_NAME} MATCHES "Linux")
164
165 #=========================================
166 # Compiler specific flags
167 #=========================================
168
169 if (Fortran_COMPILER_NAME STREQUAL "ifort")
170   # Add ifort preprocessor flags
171   set(CPPFLAGS "${CPPFLAGS} -DPGI") 
172 elseif (Fortran_COMPILER_NAME STREQUAL "f95")
173   # Add new gfortran flags
174   set(CPPFLAGS "${CPPFLAGS} -DG77") 
175 elseif (Fortran_COMPILER_NAME STREQUAL "gfortran")
176   # Add old gfortran flags
177   set(CPPFLAGS "${CPPFLAGS} -DG77") 
178 endif (Fortran_COMPILER_NAME STREQUAL "ifort")
179
180 #=========================================
181 # Add MPI preprocessor flags
182 #=========================================
183 set(CPPFLAGS "${CPPFLAGS} -DMP -DMPI") 
184
185 #=========================================
186 # add 64-bit specific preprocessor flags
187 #=========================================
188 if (architektura STREQUAL "64")
189   set(CPPFLAGS "${CPPFLAGS} -DAMD64")
190 endif (architektura STREQUAL "64")
191
192 # Apply preprocesor flags to *.F files
193 set_property(SOURCE ${UNRES_CSA_PP_SRC} PROPERTY COMPILE_DEFINITIONS ${CPPFLAGS} )  
194
195
196 #========================================
197 #  Setting binary name
198 #========================================
199 set(UNRES_BIN "unresCSA_${Fortran_COMPILER_NAME}_MPI_${UNRES_CSA_FF}.exe")
200
201 #=========================================
202 # cinfo.f workaround for CMake
203 #=========================================
204 # get the current date  
205 TODAY(DATE)
206 # generate cinfo.f
207
208 set(CINFO "${CMAKE_CURRENT_BINARY_DIR}/cinfo.f")
209 FILE(WRITE ${CINFO}
210 "C CMake generated file
211        subroutine cinfo
212        include 'COMMON.IOUNITS'
213        write(iout,*)'++++ Compile info ++++'
214        write(iout,*)'Version ${UNRES_MAJOR}.${UNRES_MINOR} build ${UNRES_PATCH}'
215 ")
216
217 CINFO_FORMAT(${CINFO} "Compiled" "${DATE}" )
218 CINFO_FORMAT(${CINFO} "Compiled by" "$ENV{USER}@$ENV{HOST}" )
219 CINFO_FORMAT(${CINFO} "OS name:" "${CMAKE_SYSTEM_NAME}" )
220 CINFO_FORMAT(${CINFO} "OS release:" "${CMAKE_SYSTEM}" )
221 CINFO_FORMAT(${CINFO} "Fortran Compiler:" "${CMAKE_Fortran_COMPILER}" )
222 CINFO_FORMAT(${CINFO} "MD Force field:" "${UNRES_MD_FF}" )
223 CINFO_FORMAT(${CINFO} "CPPFLAGS =" "${CPPFLAGS}")
224
225 FILE(APPEND ${CINFO} 
226 "       write(iout,*)'++++ End of compile info ++++'  
227        return 
228        end ")
229
230 # set include path
231 set_property(SOURCE ${CMAKE_CURRENT_BINARY_DIR}/cinfo.f PROPERTY COMPILE_FLAGS "${FFLAGS0} -I${CMAKE_CURRENT_SOURCE_DIR}" )
232
233 #=========================================
234 # Set full unres CSA sources
235 #=========================================
236 set(UNRES_CSA_SRCS ${UNRES_CSA_SRC0} ${UNRES_CSA_SRC3} ${CMAKE_CURRENT_BINARY_DIR}/cinfo.f )
237
238 #=========================================
239 # Build the binary
240 #=========================================
241 add_executable(UNRES_BIN-CSA ${UNRES_CSA_SRCS} )
242 set_target_properties(UNRES_BIN-CSA PROPERTIES OUTPUT_NAME ${UNRES_BIN})
243 set_property(TARGET UNRES_BIN-CSA PROPERTY RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin )
244 #add_dependencies (${UNRES_BIN} ${UNRES_XDRFLIB})
245
246 #=========================================
247 # Link libraries
248 #=========================================
249 # link MPI library (libmpich.a)  
250 target_link_libraries( UNRES_BIN-CSA ${MPI_Fortran_LIBRARIES} )
251 # link libxdrf.a 
252 #target_link_libraries( ${UNRES_BIN} xdrf )
253
254 #=========================================
255 # Install Path
256 #=========================================
257 install(TARGETS UNRES_BIN-CSA DESTINATION ${CMAKE_INSTALL_PREFIX}/unres/CSA)
258
259
260 #=========================================
261 # TESTS 
262 #=========================================
263
264 if(UNRES_CSA_FF STREQUAL "4P")
265
266 FILE(COPY ${CMAKE_SOURCE_DIR}/ctest/1l2y_csa_4P.inp
267         DESTINATION ${CMAKE_CURRENT_BINARY_DIR} )
268
269 FILE(COPY ${CMAKE_SOURCE_DIR}/ctest/1l2y_csa_local_4P.inp
270         DESTINATION ${CMAKE_CURRENT_BINARY_DIR} )
271
272 FILE(COPY ${CMAKE_SOURCE_DIR}/ctest/1l2y_csa_local_4P.CSA.native.int
273         DESTINATION ${CMAKE_CURRENT_BINARY_DIR} )
274
275
276 FILE(COPY ${CMAKE_SOURCE_DIR}/ctest/csa_energy_check.sh
277         DESTINATION ${CMAKE_CURRENT_BINARY_DIR}
278         FILE_PERMISSIONS OWNER_READ OWNER_WRITE OWNER_EXECUTE GROUP_READ GROUP_EXECUTE WORLD_READ WORLD_EXECUTE
279 )
280
281
282 #=========================================
283 #  test_csa_4P.sh
284 #=========================================
285
286 FILE(WRITE ${CMAKE_CURRENT_BINARY_DIR}/scripts/test_csa_4P.sh
287 "#!/bin/sh
288 export POT=GB
289 export FGPROCS=1
290 export PREFIX=$1
291 #-----------------------------------------------------------------------------
292 UNRES_BIN=${CMAKE_BINARY_DIR}/bin/${UNRES_BIN}
293 #-----------------------------------------------------------------------------
294 DD=${CMAKE_SOURCE_DIR}/PARAM
295 export BONDPAR=$DD/bond.parm
296 export THETPAR=$DD/thetaml.5parm
297 export ROTPAR=$DD/scgauss.parm
298 export TORPAR=$DD/torsion_631Gdp.parm
299 export TORDPAR=$DD/torsion_double_631Gdp.parm
300 export ELEPAR=$DD/electr_631Gdp.parm
301 export SIDEPAR=$DD/sc_GB_opt.4P5_iter33_3r
302 export FOURIER=$DD/fourier_opt.parm.1igd_hc_iter3_3
303 #export SCCORPAR=$DD/rotcorr_AM1.parm
304 export SCCORPAR=$DD/sccor_am1_pawel.dat
305 export SCPPAR=$DD/scp.parm
306 export PATTERN=$DD/patterns.cart
307 export PRINT_PARM=NO
308 #-----------------------------------------------------------------------------
309 echo CTEST_FULL_OUTPUT
310 $UNRES_BIN
311 ./csa_energy_check.sh $1
312 ")
313
314 #
315 # File permissions workaround
316 #
317 FILE(   COPY ${CMAKE_CURRENT_BINARY_DIR}/scripts/test_csa_4P.sh
318         DESTINATION ${CMAKE_CURRENT_BINARY_DIR}
319         FILE_PERMISSIONS OWNER_READ OWNER_WRITE OWNER_EXECUTE GROUP_READ GROUP_EXECUTE WORLD_READ WORLD_EXECUTE
320 )
321 endif(UNRES_CSA_FF STREQUAL "4P")
322
323 if(UNRES_CSA_FF STREQUAL "E0LL2Y")
324
325 FILE(COPY ${CMAKE_SOURCE_DIR}/ctest/1l2y_csa.inp
326         DESTINATION ${CMAKE_CURRENT_BINARY_DIR} )
327
328 FILE(COPY ${CMAKE_SOURCE_DIR}/ctest/1l2y_csa_local.inp
329         DESTINATION ${CMAKE_CURRENT_BINARY_DIR} )
330
331 FILE(COPY ${CMAKE_SOURCE_DIR}/ctest/1l2y_csa_local.CSA.native.int
332         DESTINATION ${CMAKE_CURRENT_BINARY_DIR} )
333
334
335 FILE(COPY ${CMAKE_SOURCE_DIR}/ctest/csa_energy_check.sh
336         DESTINATION ${CMAKE_CURRENT_BINARY_DIR}
337         FILE_PERMISSIONS OWNER_READ OWNER_WRITE OWNER_EXECUTE GROUP_READ GROUP_EXECUTE WORLD_READ WORLD_EXECUTE
338 )
339
340
341 #=========================================
342 #  test_csa_E0LL2Y.sh
343 #=========================================
344
345 FILE(WRITE ${CMAKE_CURRENT_BINARY_DIR}/scripts/test_csa_E0LL2Y.sh
346 "#!/bin/sh
347 export POT=GB
348 export FGPROCS=1
349 export PREFIX=$1
350 #-----------------------------------------------------------------------------
351 UNRES_BIN=${CMAKE_BINARY_DIR}/bin/${UNRES_BIN}
352 #-----------------------------------------------------------------------------
353 DD=${CMAKE_SOURCE_DIR}/PARAM
354 export BONDPAR=$DD/bond_AM1.parm
355 export THETPAR=$DD/theta_abinitio.parm
356 export ROTPAR=$DD/rotamers_AM1_aura.10022007.parm
357 export THETPARPDB=$DD/thetaml.5parm   
358 export ROTPARPDB=$DD/scgauss.parm
359 export TORPAR=$DD/torsion_631Gdp.parm
360 export TORDPAR=$DD/torsion_double_631Gdp.parm
361 export ELEPAR=$DD/electr_631Gdp.parm
362 export SIDEPAR=$DD/scinter_$POT.parm
363 export FOURIER=$DD/fourier_opt.parm.1igd_hc_iter3_3
364 #export SCCORPAR=$DD/rotcorr_AM1.parm
365 export SCCORPAR=$DD/sccor_am1_pawel.dat
366 export SCPPAR=$DD/scp.parm
367 export PATTERN=$DD/patterns.cart
368 export PRINT_PARM=NO
369 #-----------------------------------------------------------------------------
370 echo CTEST_FULL_OUTPUT
371 $UNRES_BIN
372 ./csa_energy_check.sh $1
373 ")
374
375 #
376 # File permissions workaround
377 #
378 FILE(   COPY ${CMAKE_CURRENT_BINARY_DIR}/scripts/test_csa_E0LL2Y.sh
379         DESTINATION ${CMAKE_CURRENT_BINARY_DIR}
380         FILE_PERMISSIONS OWNER_READ OWNER_WRITE OWNER_EXECUTE GROUP_READ GROUP_EXECUTE WORLD_READ WORLD_EXECUTE
381 )
382 endif(UNRES_CSA_FF STREQUAL "E0LL2Y")
383
384
385
386 # Add tests
387
388 #  MESSAGE (STATUS "${MPI_Fortran_LIBRARIES}")
389   if ("${MPI_Fortran_LIBRARIES}"  MATCHES "lam")
390      MESSAGE (STATUS "LAM MPI library detected")
391      set (boot_lam "-boot")
392   else()
393      set (boot_lam "")
394   endif()
395
396
397   if (UNRES_SRUN)
398    set (np "-n")
399    set (mpiexec "srun")
400   else()
401    set (np "-np")
402    set (mpiexec "mpiexec")
403   endif()
404
405
406 if(UNRES_CSA_FF STREQUAL "4P")
407     add_test(NAME UNRES_CSA_global COMMAND ${mpiexec} ${boot_lam} ${np} 4 ${CMAKE_CURRENT_BINARY_DIR}/test_csa_4P.sh 1l2y_csa_4P )
408     add_test(NAME UNRES_CSA_local COMMAND ${mpiexec} ${boot_lam} ${np} 4 ${CMAKE_CURRENT_BINARY_DIR}/test_csa_4P.sh 1l2y_csa_local_4P )
409 endif(UNRES_CSA_FF STREQUAL "4P")
410
411 if(UNRES_CSA_FF STREQUAL "E0LL2Y")
412     add_test(NAME UNRES_CSA_global_E0LL2Y COMMAND ${mpiexec} ${boot_lam} ${np} 4 ${CMAKE_CURRENT_BINARY_DIR}/test_csa_E0LL2Y.sh 1l2y_csa )
413     add_test(NAME UNRES_CSA_local_E0LL2Y COMMAND ${mpiexec} ${boot_lam} ${np} 4 ${CMAKE_CURRENT_BINARY_DIR}/test_csa_E0LL2Y.sh 1l2y_csa_local )
414 endif(UNRES_CSA_FF STREQUAL "E0LL2Y")
415
416