我在以下Makefile中面临一个奇怪的问题:
# Mosek path
MOSEKPATH = /autofs/fs1.ece/fs1.eecg.najm/b/b1/power_grid_code/mosek
# Include paths
INCPATHS = -I$(MOSEKPATH)/7/tools/platform/linux64x86/h -I/usr/include/suitesparse -I../include
# Libraries paths
LIBPATHS = -L$(MOSEKPATH)/7/tools/platform/linux64x86/bin
# Link libraries
LIBS = -lboost_timer-mt -lboost_system -lumfpack -lamd -lcolamd -lcholmod -lccolamd -lcamd -lbtf -lcsparse -lcxsparse -lklu -lldl -lspqr -llapack -lblas
MOSEKLIB = -lmosek64
LDOPT = -Wl,-rpath-link,$(MOSEKPATH)/7/tools/platform/linux64x86/bin -Wl,-rpath,'/autofs/fs1.ece/fs1.eecg.najm/b/b1/power_grid_code/mosek/7/tools/platform/linux64x86/bin' -pthread -lc -lm
# Specify compiler
CC = g++-4.7 -m64
# Compiler flags
FLAGS = -O3 -Wall -g
lo1: lo1.c
$(CC) $(FLAGS) -c $(INCPATHS) -o lo1.o lo1.c
$(CC) $(FLAGS) $(LIBPATHS) lo1.o $(LIBS) $(MOSEKLIB) $(LDOPT) -o lo1
clean:
rm -f lo1 *.o
我从MOSEK提供的示例中获得了大部分内容。 Makefile工作正常,结果如预期。问题是,我使用的MOSEK版本是多线程的(MOSEK 7.1)。 MOSEK应该检测机器上的核心数量,并使用它们。当我按原样使用Makefile时,MOSEK只检测一个核心,并且只使用一个线程:
Computer
Platform : Linux/64-X86
Cores : 1
但是,当我在没有$(LIBS)的情况下编译时,MOSEK确实检测到4个核心:
Computer
Platform : Linux/64-X86
Cores : 4
我在lo1.c中的代码现在不使用$(LIBS),但是稍后我会在lo1.c中需要这些库。那些图书馆怎么会影响MOSEK的行为?
谢谢。
答案 0 :(得分:0)
事实证明问题出在BLAS上。 SuiteSparse中的一些库需要BLAS和服务器上的BLAS库与OpenMP混淆,这显然是MOSEK要求并行化其代码。无论如何,解决方案是使用OpenBLAS,使用标志" USE_OPENMP = 1"编译。