/usr/include/music/runtime.hh is in libmusic-dev 1.0.7-1.2ubuntu2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 | /*
* This file is part of MUSIC.
* Copyright (C) 2007, 2008, 2009 INCF
*
* MUSIC is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* MUSIC is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef MUSIC_RUNTIME_HH
#include <mpi.h>
#include <vector>
#include "music/setup.hh"
#include "music/port.hh"
#include "music/clock.hh"
#include "music/connector.hh"
namespace MUSIC {
/*
* This is the Runtime object in the MUSIC API
*
* It is documented in section 4.4 of the MUSIC manual
*/
class Runtime {
public:
Runtime (Setup* s, double h);
~Runtime ();
MPI::Intracomm communicator ();
void finalize ();
void tick ();
double time ();
private:
Clock localTime;
MPI::Intracomm comm;
std::vector<TickingPort*> tickingPorts;
std::vector<Connector*> connectors;
std::vector<Subconnector*> schedule;
std::vector<PostCommunicationConnector*> postCommunication;
static bool isInstantiated_;
typedef std::vector<Connection*> Connections;
typedef std::vector<OutputSubconnector*> OutputSubconnectors;
typedef std::vector<InputSubconnector*> InputSubconnectors;
void takeTickingPorts (Setup* s);
void connectToPeers (Connections* connections);
void specializeConnectors (Connections* connections);
void spatialNegotiation (OutputSubconnectors&, InputSubconnectors&);
void buildSchedule (int localRank,
OutputSubconnectors&,
InputSubconnectors&);
void takePostCommunicators ();
void buildTables (Setup* s);
void temporalNegotiation (Setup* s, Connections* connections);
void initialize ();
};
}
#define MUSIC_RUNTIME_HH
#endif
|