Coder Social home page Coder Social logo

josevnz / npb3.0-jav-fork Goto Github PK

View Code? Open in Web Editor NEW
0.0 1.0 0.0 441 KB

For of NASA NPB 3.0 Java Benchmark (https://www.nas.nasa.gov/publications/npb.html)

License: Other

Makefile 1.02% Fortran 60.79% C 7.28% Roff 0.01% Modula-3 0.01% SourcePawn 0.01% Java 30.80% Shell 0.09%

npb3.0-jav-fork's Introduction

NPB3.0-JAV-FORK

This is a fork of the original NASA NAS Parallel Benchmarks.

Please read the following file: NPB3.0-JAV/README.md

I do not plan to make updates on this code, nor the build. Just used it for some of my tutorials.

Author

  • José Vicente Núñez Zuleta

Original README

The non-MPI Version of NAS Parallel Benchmarks (SER, OMP, HPF, JAV)

=======================================================================

The non-MPI version of NAS Parallel Benchmarks was based on a version that was previously released as PBN, or "Programming Baseline for NPB". This version consists of four sets of source codes based on the NAS Parallel Benchmark version 2.3:

NPB3.0-SER - An improved sequential implementation
NPB3.0-OMP - An OpenMP implementation based on NPB-SER
NPB3.0-HPF - An HPF implementation based on NPB-SER
NPB3.0-JAV - A Java implementation with Java threads

For more details on each implementation, please refer to the README file in each sub-directory.

The rationale behind this release is as follows:

  1. To provide the community with an optimized version of NPB2.3-serial

In our effort to compare compilers and tools using NPB2.3-serial as a baseline, we encountered implementation efficiencies and code organization that greatly limits their parallelization based on the insertion of "directives". While the presence of these "imperfections" reflect the ability of "average" programmers, fixing some of these greatly reduced the noise in the results and helped our evaluation. For example, BT and SP were reorganized so that memory requirements for Class A on one SGI Origin2000 (O2K) node are reduced by 9 times and 2 times respectively. Execution speed almost doubled in each case. An unnecessary code segment, only required in the MPI parallel implementation, was also removed to (almost) double IS's performance on one O2K node. We note further that an LU implementation (with loop organization favoring parallelization based on a "hyperplane" or "wavefront") that favors data-parallelism is also included for the benefit of HPF. These, together with other minor fixes, have been introduced to NPB2.3-serial to produce the NPB3.0-SER

  1. To provide standard implementations based on OpenMP and HPF directives and Java threads

The OpenMP and HPF directives inserted reflect a programmer's parallelization and data-distribution strategy, while the compiler is responsible for implementation and optimization. The Java implementation serves to examine Java as a new language for CFD computation.

NPB3.0 was implemented by Henry Jin [email protected], Michael Frumkin [email protected] and Matthew Schultz. We want to acknowledge support and comments, particularly from the original NPB implementation team of the NAS Division at NASA Ames Research Center.
Additionally, we want to thank Thomas Gruen [email protected] and Allan Snavely [email protected] who pointed out the problem with IS.

For all errors/feedbacks related to NPB3.0, please contact:

  NAS Parallel Benchmarks Team
  [email protected]

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.