Scippy

UG

Ubiquity Generator framework

scipParaRacingRampUpParamSetMpi.h
Go to the documentation of this file.
1/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2/* */
3/* This file is part of the program and software framework */
4/* UG --- Ubquity Generator Framework */
5/* */
6/* Copyright Written by Yuji Shinano <shinano@zib.de>, */
7/* Copyright (C) 2021-2024 by Zuse Institute Berlin, */
8/* licensed under LGPL version 3 or later. */
9/* Commercial licenses are available through <licenses@zib.de> */
10/* */
11/* This code is free software; you can redistribute it and/or */
12/* modify it under the terms of the GNU Lesser General Public License */
13/* as published by the Free Software Foundation; either version 3 */
14/* of the License, or (at your option) any later version. */
15/* */
16/* This program is distributed in the hope that it will be useful, */
17/* but WITHOUT ANY WARRANTY; without even the implied warranty of */
18/* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the */
19/* GNU Lesser General Public License for more details. */
20/* */
21/* You should have received a copy of the GNU Lesser General Public License */
22/* along with this program. If not, see <http://www.gnu.org/licenses/>. */
23/* */
24/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
25
26/**@file scipParaRacingRampUpParamSetMpi.h
27 * @brief ScipParaRacingRampUpParamSet extension for MPI communication.
28 * @author Yuji Shinano
29 *
30 *
31 *
32 */
33
34/*---+----1----+----2----+----3----+----4----+----5----+----6----+----7----+----8----+----9----+----0----+----1----+----2*/
35
36
37#ifndef __SCIP_PARA_RACING_RAMP_UP_PARAM_SET_MPI_H__
38#define __SCIP_PARA_RACING_RAMP_UP_PARAM_SET_MPI_H__
39
40#include <mpi.h>
41#include "ug/paraCommMpi.h"
42#include "scipParaTagDef.h"
44
45namespace ParaSCIP
46{
47
48/** The difference between instance and subproblem: this is base class */
50{
51
52 /** create ScipParaRacingRampUpParamSet datatype */
53 MPI_Datatype createDatatype();
54
55public:
56 /** default constructor */
58 )
59 {
60 }
61
62 /** Constructor */
64 int inTerminationCriteria,
65 int inNNodesLeft,
66 double inTimeLimit,
67 int inScipRacingParamSeed,
68 int inPermuteProbSeed,
69 int inGenerateBranchOrderSeed,
70 ScipDiffParamSet *inScipDiffParamSet
71 ) : ScipParaRacingRampUpParamSet(inTerminationCriteria, inNNodesLeft, inTimeLimit,
72 inScipRacingParamSeed,inPermuteProbSeed, inGenerateBranchOrderSeed, inScipDiffParamSet)
73 {
74 }
75
76 /** destructor */
78 )
79 {
80 }
81
82 int send(UG::ParaComm *comm, int dest);
83 int receive(UG::ParaComm *comm, int source);
84};
85
86}
87
88#endif // __SCIP_PARA_RACING_RAMP_UP_PARAM_SET_MPI_H__
89
ScipParaRacingRampUpParamSetMpi(int inTerminationCriteria, int inNNodesLeft, double inTimeLimit, int inScipRacingParamSeed, int inPermuteProbSeed, int inGenerateBranchOrderSeed, ScipDiffParamSet *inScipDiffParamSet)
Base class of communicator object.
Definition: paraComm.h:102
static ScipParaCommTh * comm
Definition: fscip.cpp:73
ParaComm extension for MPI communication.
ParaRacingRampUpParamSet extension for SCIP solver.