Skip to content

FrancescoQuaglia/PARSIR

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

6 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

PARSIR

PARSIR (PARallel SImulation Runner) is a compile/runtime environment for discrete event simulation models written using the C programming language

The directory models/phold provides and implementation of the PHOLD benchmark that constitutes a common example of how to realize simulation applications using PARSIR

The building of the application is based on the following API:

a) int ScheduleNewEvent(int destination, double timestamp, int event_type, char* body, int size) which allows inserting an event for a destination simulation object, that will occur at a given simulation time, into the PARSIR runtime

b) void ProcessEvent(unsigned int me, double now, int event_type, void *event_content, unsigned int size, void *ptr) a callback that enables processing an event occurring at a given time in some specific simulation object - this callback is initially called with a runtime injected INIT event occurring at simulation time zero in order to setup in memory the state of each simulation object and to enable the initial scheduling of new events

To use PARSIR you can simply go to the build directory to compile the runtime or the phold target

After compiling the phold target, the PARSIR-simulator for running the PHOLD model will be available in the bin directory and can be simply launched

The include directory contains the file run.h which determines how many simulation objects will belong to the model as well as how many threads will be started up by the PARSIR-simulator, and the lookahead of the simulation model to be executed. Currently they are specified as: #define THREADS (10) #define OBJECTS (1024) #define LOOKAHEAD (1.0)

The include directory also holds other .h files where the specification of macros for managing/building the PARSIR-simulator is defined, such as the maximum number of NUMA nodes to be managed, as well as the the maximum number of CPUs per NUMA node

Parallel execution of the simulation objects is carried out by PARSIR in a fully transparent manner to the application level code

REQUIREMENTS: PARSIR requires the numa library and its header to be installed on the system (it compiles with the -lnuma option)

About

PARSIR (PARallel SImulation Runner)

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published