GithubHelp home page GithubHelp logo

matthieurouland / adios2 Goto Github PK

View Code? Open in Web Editor NEW

This project forked from ornladios/adios2

0.0 1.0 0.0 17.3 MB

Next generation of ADIOS developed in the Exascale Computing Program

Home Page: https://adios2.readthedocs.io/en/latest/index.html

License: Apache License 2.0

CMake 6.46% C++ 71.74% C 8.54% Fortran 9.56% Makefile 0.06% MATLAB 0.42% Python 2.36% Shell 0.62% Dockerfile 0.23%

adios2's Introduction

License Documentation

GitHub (pre-)release Spack Version

Circle CI Travis CI AppVeyor CI

Coverity Scan Build Status

ADIOS 2 : The Adaptable Input Output System version 2

This is ADIOS 2 : The Adaptable Input/Output (I/O) System, ADIOS 2 is developed as part of the United States Department of Energy's Exascale Computing Program.

ADIOS 2 is a framework designed for scientific data I/O to publish and subscribe (put/get) data when and where required.

ADIOS 2 transports data as groups of self-describing variables and attributes across different media types (such as files, wide-area-networks, and remote direct memory access) using a common application programming interface for all transport modes. ADIOS 2 can be used on supercomputers, commercial clouds, and personal computers.

ADIOS 2 focuses on:

  1. Performance I/O scalability in high performance computing (HPC) applications.
  2. Adaptability unified interfaces to allow for several modes of transport (files, memory-to-memory)
  3. Ease of Use two-level application programming interface (APIs)
    • Full APIs for HPC applications: C++11, Fortran 90, C 99, Python 2 and 3
    • Simplified High-Level APIs for data analysis: Python 2 and 3, C++11, Matlab

In addition, ADIOS 2 APIs are based on:

  • MPI ADIOS 2 is MPI-based, it can be used in non-MPI serial code.

  • Data Groups ADIOS 2 favors a deferred/prefetch/grouped variables transport mode by default to maximize data-per-request ratios. Sync mode, one variable at a time, is treated as the special case.

  • Data Steps ADIOS 2 follow the actual production/consumption of data using an “steps” abstraction removing the need to manage extra indexing information.

  • Data Engines ADIOS 2 Engine abstraction allows for reusing the APIs for different transport modes removing the need for drastic code changes.

Documentation

Please find The ADIOS 2 User Guide at readthedocs

Getting ADIOS2

Releases

Reporting Bugs

If you found a bug, please open an issue on ADIOS2 github repository

Contributing

We invite the community to contribute, see Contributor's Guide to ADIOS 2 for instructions on how to contribute. ADIOS 2 will always be free and open-source.

License

ADIOS >= 2.0 is licensed under the Apache License v2.0. See the accompanying Copyright.txt for more details.

Directory layout

  • bindings - public application programming interface, API, language bindings (C++11, C, Fortran, Python and Matlab)

  • cmake - Project specific CMake modules

  • examples - Simple set of examples in different languages

  • scripts - Project maintenance and development scripts

  • source - Internal source code for private components

    • adios2 - source directory for the ADIOS2 library to be installed under install-dir/lib/libadios2.
    • utils - source directory for the binary utilities, to be installed under install-dir/bin
  • testing - Tests using gtest

adios2's People

Contributors

aronhelser avatar ax3l avatar carreau avatar eisenhauer avatar franzpoeschel avatar germasch avatar godoywf avatar gsjaardema avatar guj avatar jasonruonanwang avatar jychoi-hpc avatar keichi avatar khuck avatar kwrobot avatar kylefromkitware avatar lwan86 avatar nathompson avatar philip-davis avatar pnorbert avatar scottwittenburg avatar shawnyang610 avatar stevenwalton avatar williamfgc avatar

Watchers

 avatar

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.