Skip to content

yumin/SMTK

 
 

Repository files navigation

Simulation Modeling Tool Kit (SMTK)

Version 1.0.0

Build Status

SMTK is a library which provides a way to specify attributes (such as initial and boundary conditions, but also things like mesh sizing functions) that describe a physical simulation on a geometric domain, as well as high-level access to model geometry (through various solid model and mesh tools) for the purpose of linking attributes to geometric models of the simulation domain.

Documentation

The SMTK documentation is at Read The Docs. What's below is a quick guide to building SMTK.

Building SMTK

In order to build SMTK you must have

  • A modern C++ compiler (gcc, clang, or VS) that supports C++11 features,
  • CMake 2.8.11 or newer (3.2 is advised), and
  • Boost 1.50.0 or newer.

We recommend using Ninja for fast builds.

You may optionally provide

  • CGMA v13 or newer, built with OpenCascade or Cubit, for importing CAD models;
  • Python version 2.7.3 or newer and Shiboken from the smtk-head branch, for Python wrappings of SMTK's C++ classes;
  • Qt version 4.8 or newer, for widgets to interact with attributes and models;
  • Remus from the master branch, for running SMTK modelers in remote processes; and
  • ParaView version 4.3 or newer, or VTK version 6.2 or newer, for graphical presentation and selection of geometric models.
  • MOAB, built with Netcdf, for importing and exporting mesh files.

If you want to build the documentation you will need

You may wish to obtain the test-data repository for SMTK in order to run tests which require input datasets; run:

git clone [email protected]:SMTKTestData.git

somewhere outside the SMTK source directory. When running CMake on SMTK, set the SMTK_DATA_DIR variable to point to the directory git clone created.

Once you have prepared all of the dependencies, it is time to create a build directory (again, outside the SMTK source directory containing this ReadMe file) and run CMake. These instructions will assume you have the SMTK source in a directory named /source/SMTK, the SMTK test-data in /data/SMTK, that you wish to build in a directory named /build/SMTK, and will install SMTK into /install/SMTK. To begin:

mkdir /build/SMTK
cd /build/SMTK
# If you do not have Ninja and do not have the SMTK test data:
cmake /source/SMTK
# or, if you have Ninja and the SMTK test data:
cmake -G Ninja -DSMTK_DATA_DIR:PATH=/data/SMTK /source/SMTK

At this point, CMake will likely complain that you are missing Boost. It will also default to not build python wrappings, Qt, VTK, or CGMA functionality since those require optional dependencies. To change these defaults and specify where Boost is located, you may do any of the following:

  • manually edit the newly-created /build/SMTK/CMakeCache.txt file,
  • run the Qt cmake-gui command (assuming it is present in your build of CMake), or
  • run the text-based ccmake command (assuming it is present in your build of CMake).

Once you have updated all of the required settings, reconfigure (by re-running cmake, pressing the "Configure" button, or pressing the c key, respectively -- depending on which method above you use to edit CMake settings). Once CMake is in a good state, it will generate project files (either Makefiles, Ninja build files, or an IDE project) either automatically (if you manually re-run cmake) or at your request (when running cmake-gui or ccmake). You may then build and install SMTK using the generated project files.

The documentation is not built by default, but CMake exposes targets named doc and doc-userguide that you can build. The doc target builds the doxygen reference documentation which appears in /build/SMTK/doc/reference/smtk/html/index.xhtml while the doc-userguide target builds the user's guide and tutorials which appear in /build/SMTK/doc/user/html/index.html.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 91.3%
  • Python 4.0%
  • CMake 2.9%
  • Scala 1.3%
  • Shell 0.3%
  • C 0.2%