From e04e6e1d9cac2179bc449c916dc7fa9340dac349 Mon Sep 17 00:00:00 2001 From: Pjotr Prins Date: Sun, 20 Aug 2017 09:21:01 +0000 Subject: Support files --- .gitignore | 1 + .travis.yml | 6 +++--- INSTALL.md | 2 +- Makefile | 22 ++++++++++++++++------ README.md | 10 ++++++---- 5 files changed, 27 insertions(+), 14 deletions(-) diff --git a/.gitignore b/.gitignore index 5088ec4..ef520c8 100644 --- a/.gitignore +++ b/.gitignore @@ -4,6 +4,7 @@ src/Eigen example/output test/output ./output +bin/ doc/manual.aux doc/manual.bbl doc/manual.blg diff --git a/.travis.yml b/.travis.yml index bc033f9..df74fb2 100644 --- a/.travis.yml +++ b/.travis.yml @@ -1,4 +1,4 @@ -language: g++ +language: C++ compiler: gcc matrix: include: @@ -36,11 +36,11 @@ script: - $CXX --version # build and test debug version - make CXX=$CXX FORCE_DYNAMIC=1 WITH_OPENBLAS=1 DEBUG=1 -j 4 - - time make check + - time make CXX=$CXX FORCE_DYNAMIC=1 WITH_OPENBLAS=1 DEBUG=1 check - make clean # build and test release version - make CXX=$CXX FORCE_DYNAMIC=1 WITH_OPENBLAS=1 -j 4 - - time make check + - time make CXX=$CXX FORCE_DYNAMIC=1 WITH_OPENBLAS=1 check # build static release (fast-check only) # - make clean # - make CXX=$CXX TRAVIS_CI=1 -j 4 fast-check diff --git a/INSTALL.md b/INSTALL.md index d373dc3..6f7f200 100644 --- a/INSTALL.md +++ b/INSTALL.md @@ -69,7 +69,7 @@ work another example overriding optimization and LIB flags (so as to link against gslv1) would be - make EIGEN_INCLUDE_PATH=~/.guix-profile/include/eigen3 WITH_OPENBLAS=1 DEBUG=1 FORCE_DYNAMIC=1 GCC_FLAGS="-O3" LIBS="$HOME/opt/gsl1/lib/libgsl.a $HOME/opt/gsl1/lib/libgslcblas.a -L$HOME/.guix-profile/lib -pthread -llapack -lblas -lz" + make EIGEN_INCLUDE_PATH=~/.guix-profile/include/eigen3 WITH_OPENBLAS=1 DEBUG=1 FORCE_DYNAMIC=1 GCC_FLAGS="-Wall" LIBS="$HOME/opt/gsl1/lib/libgsl.a $HOME/opt/gsl1/lib/libgslcblas.a -L$HOME/.guix-profile/lib -pthread -llapack -lblas -lz" to run GEMMA tests diff --git a/Makefile b/Makefile index 875573c..86eaff8 100644 --- a/Makefile +++ b/Makefile @@ -29,6 +29,7 @@ EIGEN_INCLUDE_PATH=/usr/include/eigen3 BIN_DIR = ./bin SRC_DIR = ./src +TEST_SRC_DIR = ./test/src ifdef CXX CPP = $(CXX) @@ -38,10 +39,10 @@ else endif ifdef DEBUG - CPPFLAGS = -g $(GCC_FLAGS) -std=gnu++11 -isystem/$(EIGEN_INCLUDE_PATH) + CPPFLAGS = -g $(GCC_FLAGS) -std=gnu++11 -isystem/$(EIGEN_INCLUDE_PATH) -Icontrib/catch-1.9.7 -Isrc else # release mode - CPPFLAGS = -DNDEBUG $(GCC_FLAGS) -std=gnu++11 -isystem/$(EIGEN_INCLUDE_PATH) + CPPFLAGS = -DNDEBUG $(GCC_FLAGS) -std=gnu++11 -isystem/$(EIGEN_INCLUDE_PATH) -Icontrib/catch-1.9.7 -Isrc endif ifdef SHOW_COMPILER_WARNINGS @@ -72,7 +73,7 @@ LIBS_MAC_D_LAPACK = -framework Veclib LIBS_LNX_S_LAPACK = /usr/lib/lapack/liblapack.a -lgfortran /usr/lib/atlas-base/libatlas.a /usr/lib/libblas/libblas.a -Wl,--allow-multiple-definition -SOURCES += $(SRC_DIR)/param.cpp $(SRC_DIR)/gemma.cpp $(SRC_DIR)/io.cpp $(SRC_DIR)/lm.cpp $(SRC_DIR)/lmm.cpp $(SRC_DIR)/vc.cpp $(SRC_DIR)/mvlmm.cpp $(SRC_DIR)/bslmm.cpp $(SRC_DIR)/prdt.cpp $(SRC_DIR)/mathfunc.cpp $(SRC_DIR)/gzstream.cpp $(SRC_DIR)/eigenlib.cpp $(SRC_DIR)/ldr.cpp $(SRC_DIR)/bslmmdap.cpp $(SRC_DIR)/logistic.cpp $(SRC_DIR)/varcov.cpp +SOURCES += $(SRC_DIR)/param.cpp $(SRC_DIR)/gemma.cpp $(SRC_DIR)/io.cpp $(SRC_DIR)/lm.cpp $(SRC_DIR)/lmm.cpp $(SRC_DIR)/vc.cpp $(SRC_DIR)/mvlmm.cpp $(SRC_DIR)/bslmm.cpp $(SRC_DIR)/prdt.cpp $(SRC_DIR)/mathfunc.cpp $(SRC_DIR)/gzstream.cpp $(SRC_DIR)/eigenlib.cpp $(SRC_DIR)/ldr.cpp $(SRC_DIR)/bslmmdap.cpp $(SRC_DIR)/logistic.cpp $(SRC_DIR)/varcov.cpp $(SRC_DIR)/debug.cpp HDR += $(SRC_DIR)/param.h $(SRC_DIR)/gemma.h $(SRC_DIR)/io.h $(SRC_DIR)/lm.h $(SRC_DIR)/lmm.h $(SRC_DIR)/vc.h $(SRC_DIR)/mvlmm.h $(SRC_DIR)/bslmm.h $(SRC_DIR)/prdt.h $(SRC_DIR)/mathfunc.h $(SRC_DIR)/gzstream.h $(SRC_DIR)/eigenlib.h ifdef WITH_LAPACK @@ -118,19 +119,28 @@ $(OBJS) : $(HDR) $(CPP) $(CPPFLAGS) $(HEADERS) -c $*.cpp -o $*.o .SUFFIXES : .cpp .c .o $(SUFFIXES) -fast-check: all +unittests: all contrib/catch-1.9.7/catch.hpp $(TEST_SRC_DIR)/unittests-main.o $(TEST_SRC_DIR)/unittests-math.o + $(CPP) $(CPPFLAGS) $(TEST_SRC_DIR)/unittests-main.o $(TEST_SRC_DIR)/unittests-math.o $(filter-out $(SRC_DIR)/main.o, $(OBJS)) $(LIBS) -o ./bin/unittests + ./bin/unittests + +fast-check: all unittests + rm -vf test/output/* cd test && ./dev_test_suite.sh | tee ../dev_test.log grep -q 'success rate: 100%' dev_test.log slow-check: all + rm -vf test/output/* cd test && ./test_suite.sh | tee ../test.log grep -q 'success rate: 100%' test.log check: fast-check slow-check clean: - rm -rf ${SRC_DIR}/*.o ${SRC_DIR}/*~ *~ $(OUTPUT) - rm -f test/output/* + rm -vf $(SRC_DIR)/*.o + rm -vf $(SRC_DIR)/*~ + rm -vf $(TEST_SRC_DIR)/*.o + rm -vf $(OUTPUT) + rm -vf ./bin/unittests DIST_COMMON = COPYING.txt README.txt Makefile DIST_SUBDIRS = src doc example bin diff --git a/README.md b/README.md index fa0bffa..d6209a8 100644 --- a/README.md +++ b/README.md @@ -101,16 +101,18 @@ warranty**; without even the implied warranty of **merchantability or fitness for a particular purpose**. See file [LICENSE](LICENSE) for the full text of the license. - - The source code for the [shUnit2](https://github.com/genenetwork/shunit2) unit testing -framework, included in this repository [here](test/shunit2-2.0.3), is +framework, included in this repository [here](contrib/shunit2-2.0.3), is distributed under the -[GNU Lesser General Public License](test/shunit2-2.0.3/doc/LGPL-2.1), +[GNU Lesser General Public License](contrib/shunit2-2.0.3/doc/LGPL-2.1), either version 2.1 of the License, or (at your option) any later revision. +The source code for the included [Catch](http://catch-lib.net) unit +testing framework is distributed under the +[Boost Software Licence version 1](https://github.com/philsquared/Catch/blob/master/LICENSE.txt). + ## What's included This is the current structure of the GEMMA source repository: -- cgit v1.2.3