File: application.rst

package info (click to toggle)
simgrid 3.21%2Bdfsg-4
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 21,972 kB
  • sloc: cpp: 88,193; ansic: 69,244; fortran: 6,089; f90: 5,162; xml: 4,861; java: 4,250; perl: 2,056; python: 1,193; sh: 1,159; makefile: 57; sed: 6
file content (64 lines) | stat: -rw-r--r-- 3,316 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
.. _application:

Describing your Application
***************************

.. raw:: html

   <object id="TOC" data="graphical-toc.svg" width="100%" type="image/svg+xml"></object>
   <script>
   window.onload=function() { // Wait for the SVG to be loaded before changing it
     var elem=document.querySelector("#TOC").contentDocument.getElementById("ApplicationBox")
     elem.style="opacity:0.93999999;fill:#ff0000;fill-opacity:0.1;stroke:#000000;stroke-width:0.35277778;stroke-linecap:round;stroke-linejoin:round;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1";
   }
   </script>
   <br/>
   <br/>

Every SimGrid simulation entails a distributed application, that
virtually executes on the simulated platform. You can express this
application using one of the following interfaces. It is even possible
to mix several interfaces in the same simulation.

 - :ref:`Describing Algorithms with the S4U interface <S4U_doc>` (in C++)
 - :ref:`Simulating existing MPI programs with the SMPI toolsuite <SMPI_doc>`
   (in C, C++, or Fortran)
 - In some cases, you may want to replay an execution trace in the simulator. This
   trace lists the events of your application or of your workload, and
   your application is decomposed as a list of event handlers that are
   fired according to the trace. SimGrid comes with a build-in support
   for MPI traces (with solutions to import traces captured by several
   MPI profilers). You can reuse this mecanism for any kind of trace
   that you want to replay, for example to study how a P2P DHT overlay
   reacts to a given workload.
 - Simulating algorithms with one of the legacy interfaces: :ref:`MSG
   for distributed algorithms <MSG_doc>` (in :ref:`C <MSG_doc>` or
   :ref:`Java <Java_doc>`) and SimDAG for
   centralized algorithms (in C). SimGrid was founded in 1998, and
   many interfaces were proposed along the way. MSG (introduced
   around 2002) and SimDag (introduced before 2000), are still present
   in SimGrid. They do not evolve anymore, but given their popularity,
   they will not be removed until at least 2020. That being said, our
   goal is to make S4U so useful that these legacy APIs become useless
   and obsolete.
 - We are currently working on the ability to modify any existing
   application so that it can run on top of SimGrid. This project,
   called `Remote-SimGrid
   <git@framagit.org:simgrid/remote-simgrid.git>`_, is highly
   experimental at this point.

As you can see, SimGrid is very modular and can be used in many
ways. We are working to improve it along two main directions. First,
we plan to further increase the modularity of the simulator so that
users can invent the specific API or DSL they need for their usage. We
call this project BYOS: Build Your Own Simulator.

Executing existing applications within the simulator is another
long-term goal. SMPI and Remote-SimGrid already allow you to execute some
applications, but our long term goal would be to allow for the execution
of any legacy application, with absolutely no modification. We call it
SimOS, even if it will not become usable before several years of
additional work.

.. The old documentation of the obsolete MSG replay module was removed in
..  https://github.com/simgrid/simgrid/commit/e05361c201fb95d2b7605e59001cd0a49a489739