openEMS/openEMS.pro

276 lines
8.1 KiB
Prolog
Raw Normal View History

2010-02-28 21:48:03 +00:00
# -------------------------------------------------
# Project created by QtCreator 2010-02-26T22:34:51
# -------------------------------------------------
TARGET = openEMS
2010-04-17 19:54:47 +00:00
CONFIG -= app_bundle qt
2010-02-28 21:48:03 +00:00
TEMPLATE = app
OBJECTS_DIR = obj
2012-04-23 07:37:07 +00:00
INCLUDEPATH += .
INCLUDEPATH += ../CSXCAD \
2012-04-11 09:43:30 +00:00
../fparser
CONFIG += debug_and_release
2010-04-28 09:15:59 +00:00
2012-03-01 21:24:49 +00:00
#
# VERSION
#
2012-06-13 09:00:23 +00:00
VERSION=0.0.28
2012-03-01 21:24:49 +00:00
###############################################################################
# CONFIG SECTION
# the SSE engine defaults to flush-to-zero mode, because of speed advantages
# to restore the correct handling of denormals and to comply to IEEE 754 uncomment:
# DEFINES += SSE_CORRECT_DENORMALS
# openEMS defaults to output length in unit meters; to recover the old behaviour
# to output length in terms of the drawing unit, uncomment:
# DEFINES += OUTPUT_IN_DRAWINGUNITS
# CONFIG SECTION
###############################################################################
2010-04-28 09:15:59 +00:00
win32 {
2012-03-02 19:26:36 +00:00
CONFIG += console
2012-05-24 07:55:48 +00:00
WIN32_LIB_ROOT = ..
# tinyxml
INCLUDEPATH += $$WIN32_LIB_ROOT/tinyxml
LIBS += -L../tinyxml/release -ltinyxml2
# fparser
LIBS += -L../fparser/release -lfparser4
# CSXCAD
LIBS += -L../CSXCAD/release -lCSXCAD0
# hdf5
INCLUDEPATH += $$WIN32_LIB_ROOT/hdf5/include $$WIN32_LIB_ROOT/hdf5/include/cpp
LIBS += -L$$WIN32_LIB_ROOT/hdf5/lib -lhdf5
# boost
DEFINES += BOOST_THREAD_USE_LIB
INCLUDEPATH += $$WIN32_LIB_ROOT/boost/include
2012-03-02 19:26:36 +00:00
LIBS += $$WIN32_LIB_ROOT/boost/lib/libboost_thread-mgw44-mt.lib
2012-05-24 07:55:48 +00:00
# vtk
INCLUDEPATH += $$WIN32_LIB_ROOT/vtk \
$$WIN32_LIB_ROOT/vtk/Common \
2012-04-23 07:38:46 +00:00
$$WIN32_LIB_ROOT/vtk/Filtering \
$$WIN32_LIB_ROOT/vtk/IO
2012-05-24 07:55:48 +00:00
LIBS += -L$$WIN32_LIB_ROOT/vtk/bin -lvtkCommon -lvtkIO -lvtkFiltering
2010-04-28 09:15:59 +00:00
}
!win32 {
2012-03-01 21:24:49 +00:00
LIBS += -L../fparser -lfparser
2012-04-11 09:43:30 +00:00
LIBS += -ltinyxml
2012-05-24 07:55:48 +00:00
LIBS += -L../CSXCAD -lCSXCAD
2012-03-02 19:26:36 +00:00
LIBS += -lboost_thread-mt
2010-04-28 09:15:59 +00:00
LIBS += -lhdf5 -lhdf5_cpp
2011-04-01 13:08:56 +00:00
### vtk ###
INCLUDEPATH += /usr/include/vtk-5.2 \
/usr/include/vtk-5.4 \
2012-03-01 21:24:49 +00:00
/usr/include/vtk-5.6 \
/usr/include/vtk-5.8 \
2012-06-13 09:00:14 +00:00
/usr/include/vtk-5.10 \
2012-03-01 21:24:49 +00:00
/usr/include/vtk
INCLUDEPATH += /usr/include/CSXCAD
2011-04-01 13:08:56 +00:00
LIBS += -lvtkCommon \
-lvtkIO \
-lvtksys \
-lvtkFiltering
2010-04-28 09:15:59 +00:00
}
QMAKE_LFLAGS += \'-Wl,-rpath,\$$ORIGIN/../CSXCAD\'
QMAKE_LFLAGS += \'-Wl,-rpath,\$$ORIGIN/../fparser\'
2012-03-02 19:26:36 +00:00
# hdf5 compat
DEFINES += H5_USE_16_API
2011-04-01 13:08:56 +00:00
#### SOURCES ################################################################
2010-02-28 21:48:03 +00:00
SOURCES += main.cpp \
openems.cpp
2011-04-01 13:08:56 +00:00
# FDTD
SOURCES += FDTD/engine.cpp \
FDTD/operator.cpp \
FDTD/engine_multithread.cpp \
FDTD/operator_cylinder.cpp \
FDTD/engine_cylinder.cpp \
FDTD/engine_sse.cpp \
FDTD/operator_sse.cpp \
FDTD/operator_sse_compressed.cpp \
FDTD/engine_sse_compressed.cpp \
FDTD/operator_multithread.cpp \
FDTD/excitation.cpp \
FDTD/operator_cylindermultigrid.cpp \
FDTD/engine_cylindermultigrid.cpp \
FDTD/engine_interface_fdtd.cpp \
FDTD/engine_interface_sse_fdtd.cpp \
FDTD/engine_interface_cylindrical_fdtd.cpp
# FDTD/extensions source files
SOURCES += FDTD/extensions/engine_extension.cpp \
FDTD/extensions/operator_ext_dispersive.cpp \
FDTD/extensions/operator_ext_lorentzmaterial.cpp \
FDTD/extensions/operator_ext_conductingsheet.cpp \
FDTD/extensions/engine_ext_dispersive.cpp \
FDTD/extensions/engine_ext_lorentzmaterial.cpp \
FDTD/extensions/operator_ext_pml_sf.cpp \
FDTD/extensions/engine_ext_pml_sf.cpp \
FDTD/extensions/engine_ext_cylindermultigrid.cpp \
FDTD/extensions/operator_ext_upml.cpp \
FDTD/extensions/engine_ext_upml.cpp \
FDTD/extensions/operator_extension.cpp \
FDTD/extensions/engine_ext_mur_abc.cpp \
FDTD/extensions/operator_ext_mur_abc.cpp \
FDTD/extensions/operator_ext_cylinder.cpp \
FDTD/extensions/engine_ext_cylinder.cpp \
FDTD/extensions/operator_ext_excitation.cpp \
FDTD/extensions/engine_ext_excitation.cpp
# Common source files
SOURCES += Common/operator_base.cpp \
Common/engine_interface_base.cpp \
Common/processmodematch.cpp \
Common/processvoltage.cpp \
Common/processing.cpp \
Common/processintegral.cpp \
Common/processfields.cpp \
Common/processfields_td.cpp \
Common/processcurrent.cpp \
Common/processfields_fd.cpp \
2012-03-02 19:26:36 +00:00
Common/processfieldprobe.cpp \
Common/processfields_sar.cpp
2011-04-01 13:08:56 +00:00
# tools
SOURCES += tools/global.cpp \
tools/useful.cpp \
tools/array_ops.cpp \
tools/ErrorMsg.cpp \
tools/AdrOp.cpp \
tools/vtk_file_writer.cpp \
tools/hdf5_file_writer.cpp
2011-04-01 13:08:56 +00:00
#### HEADERS ################################################################
HEADERS += openems.h
# FDTD
HEADERS += FDTD/engine.h \
FDTD/operator.h \
FDTD/engine_multithread.h \
FDTD/operator_cylinder.h \
FDTD/engine_cylinder.h \
FDTD/engine_sse.h \
FDTD/operator_sse.h \
FDTD/excitation.h \
FDTD/operator_sse_compressed.h \
FDTD/engine_sse_compressed.h \
FDTD/operator_multithread.h \
FDTD/operator_cylindermultigrid.h \
FDTD/engine_cylindermultigrid.h \
2012-03-02 19:26:36 +00:00
FDTD/engine_interface_fdtd.h \
FDTD/engine_interface_sse_fdtd.h \
FDTD/engine_interface_cylindrical_fdtd.h
# FDTD/extensions header files
HEADERS += FDTD/extensions/operator_extension.h \
FDTD/extensions/engine_extension.h \
FDTD/extensions/engine_ext_mur_abc.h \
FDTD/extensions/operator_ext_mur_abc.h \
FDTD/extensions/operator_ext_cylinder.h \
FDTD/extensions/engine_ext_cylinder.h \
FDTD/extensions/operator_ext_dispersive.h \
FDTD/extensions/operator_ext_lorentzmaterial.h \
FDTD/extensions/operator_ext_conductingsheet.h \
FDTD/extensions/cond_sheet_parameter.h \
FDTD/extensions/engine_ext_dispersive.h \
FDTD/extensions/engine_ext_lorentzmaterial.h \
FDTD/extensions/operator_ext_pml_sf.h \
FDTD/extensions/engine_ext_pml_sf.h \
FDTD/extensions/engine_ext_cylindermultigrid.h \
FDTD/extensions/operator_ext_upml.h \
FDTD/extensions/engine_ext_upml.h \
FDTD/extensions/operator_ext_excitation.h \
FDTD/extensions/engine_ext_excitation.h
# Common header files
HEADERS += Common/operator_base.h \
Common/engine_interface_base.h \
Common/processvoltage.h \
Common/processing.h \
Common/processintegral.h \
Common/processfields.h \
Common/processfields_td.h \
Common/processcurrent.h \
Common/processmodematch.h \
Common/processfields_fd.h \
2011-04-01 13:08:56 +00:00
Common/processfieldprobe.h \
2012-03-02 19:26:36 +00:00
Common/processfields_sar.h
2011-04-01 13:08:56 +00:00
# tools
HEADERS += tools/ErrorMsg.h \
tools/AdrOp.h \
tools/constants.h \
tools/array_ops.h \
tools/global.h \
tools/useful.h \
tools/aligned_allocator.h \
tools/vtk_file_writer.h \
tools/hdf5_file_writer.h
2012-03-02 19:26:36 +00:00
!packaging {
# if packaging is not set in CONFIG, set some default flags
# if packaging is enabled, give the flags on the qmake comandline
QMAKE_CXXFLAGS_RELEASE = -O3 \
-g \
-march=native
QMAKE_CXXFLAGS_DEBUG = -O0 \
-g \
-march=native
2012-03-02 19:26:36 +00:00
}
MPI_SUPPORT {
2012-03-02 19:26:36 +00:00
DEFINES += MPI_SUPPORT
QMAKE_CC = mpicc
QMAKE_CXX = mpicxx
QMAKE_LINK = mpicxx
QMAKE_LINK_C = mpicc
2011-02-08 13:08:58 +00:00
HEADERS += FDTD/operator_mpi.h \
2012-03-02 19:26:36 +00:00
FDTD/engine_mpi.h \
FDTD/openems_fdtd_mpi.h
2011-02-08 13:08:58 +00:00
SOURCES += FDTD/operator_mpi.cpp \
2012-03-02 19:26:36 +00:00
FDTD/engine_mpi.cpp \
FDTD/openems_fdtd_mpi.cpp
2011-02-08 13:08:58 +00:00
2012-03-02 19:26:36 +00:00
QMAKE_CXXFLAGS_RELEASE += -Wno-unused-parameter #needed because mpich2 produces tons of unused parameter
}
2010-05-04 07:31:10 +00:00
# add git revision
GITREV = $$system(git describe --tags)
DEFINES += GIT_VERSION=\\\"$$GITREV\\\"
2010-04-28 10:30:24 +00:00
2012-03-01 21:24:49 +00:00
#
# create tar file (for the whole openEMS project)
#
tarball.target = tarball
tarball.commands = git archive --format=tar --prefix=openEMS-$$VERSION/ HEAD | bzip2 > openEMS-$${VERSION}.tar.bz2
QMAKE_EXTRA_TARGETS += tarball
#
# INSTALL (only the openEMS executable and matlab scripts)
#
install.target = install
install.commands = mkdir -p \"$(INSTALL_ROOT)/usr/bin\"
install.commands += && mkdir -p \"$(INSTALL_ROOT)/usr/share/openEMS/matlab\"
install.commands += && cp -at \"$(INSTALL_ROOT)/usr/bin/\" openEMS.sh openEMS_MPI.sh openEMS
install.commands += && cp -at \"$(INSTALL_ROOT)/usr/share/openEMS/\" matlab/
QMAKE_EXTRA_TARGETS += install
#
# create .PHONY target
#
phony.target = .PHONY
phony.depends = $$QMAKE_EXTRA_TARGETS
QMAKE_EXTRA_TARGETS += phony