Giter VIP home page Giter VIP logo

bots's Introduction

SUITE DESCRIPTION

The objective of the suite is to provide a collection of applications that allow to test OpenMP tasking implementations. Most of the kernels come from existing ones from other projects. Each of them comes with different implementations that allow to test different possibilities of the OpenMP task model (task tiedness, cut-offs, single/multiple generators, etc). It currently comes with the following kernels:

  • Alignment: Aligns sequences of proteins.
  • FFT: Computes a Fast Fourier Transformation.
  • Floorplan: Computes the optimal placement of cells in a floorplan.
  • Health: Simulates a country health system.
  • NQueens: Finds solutions of the N Queens problem.
  • Sort: Uses a mixture of sorting algorithms to sort a vector.
  • SparseLU: Computes the LU factorization of a sparse matrix.
  • Strassen: Computes a matrix multiply with Strassen's method.

FILE DESCRIPTION

The package directory is organized as follows:

  • ./bin: target directory when compiling the benchmarks (generated by `./configure').
  • ./common: source code for common objects.
  • ./config: config directory, assist the compilation phase.
  • ./inputs: input files for some of the benchmarks (when needed).
  • ./omp-tasks: source code for the OpenMP Task versions.
  • ./run: scripts for running the benchmarks.
  • ./serial: source code for the serial versions.
  • ./templates: template directory.

SUITE COMPILATION

Briefly, the shell commands ./configure and make should configure and build this package.

The ./configure shell script attempts to guess correct values for various system-dependent variables used during compilation (compiler and OpenMP specific flags). The shell script examines the compilers installed in the system and let the user choose among them. It uses those values to create a make.config in ./config directory which will be used during the suite compilation.

If you need to change compilers, linkers or compilation options you can change manually the file ./config/make.config.

OTHER ISSUES TO TAKE INTO ACCOUNT

Some benchmarks are coded following a recursive model which makes an intensive use of stack frames. It is usually needed to increase default stack sizes when working with high recursion levels. Main stack size can be increased using ulimit -s linux command. Thread stacks are usually controlled through runtime specific environment variable (e.g. Intel C Compiler uses KMP_STACKSIZE=value for this purpose).

Developer activities and documentation are centralized in our repository. Mail suggestions, comments and bug reports to pm-tools*. You can also write a bug report here.


(*) All our email accounts are hosted at bsc.es (i.e. <account-name>@bsc.es).

bots's People

Stargazers

 avatar

Watchers

 avatar  avatar  avatar  avatar  avatar

bots's Issues

Documentation URL (in readme) is offline

The readme states

Developer activities and documentation are centralized in http://nanos.ac.upc.edu
This page seems to be offline.

The reason I am looking for more detailed documentation is the following paragraph, also from the readme:

Some benchmarks are coded following a recursive model which makes an intensive use of stack
frames. It is usually needed to increase default stack sizes when working with high recursion
levels. Main stack size can be increased using ulimit -s' linux command. Thread stacks are usually controlled through runtime specific environment variable (e.g. Intel C Compiler uses KMP_STACKSIZE=value' for this purpose).

I am experiencing this problem for the uts kernel. It segfaults unless I increase the main stack size. What I am wondering is whether there are any estimates as to how large the main stack and thread stacks need to be for a given input size.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.