2 This file is part of GNUnet.
3 (C) 2011 Christian Grothoff (and other contributing authors)
5 GNUnet is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published
7 by the Free Software Foundation; either version 3, or (at your
8 option) any later version.
10 GNUnet is distributed in the hope that it will be useful, but
11 WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 General Public License for more details.
15 You should have received a copy of the GNU General Public License
16 along with GNUnet; see the file COPYING. If not, write to the
17 Free Software Foundation, Inc., 59 Temple Place - Suite 330,
18 Boston, MA 02111-1307, USA.
22 * @file ats/gnunet-service-ats_addresses_mlp.h
23 * @brief ats mlp problem solver
24 * @author Matthias Wachs
25 * @author Christian Grothoff
28 #include "gnunet_statistics_service.h"
29 #include "gnunet-service-ats_addresses.h"
34 #ifndef GNUNET_SERVICE_ATS_ADDRESSES_MLP_H
35 #define GNUNET_SERVICE_ATS_ADDRESSES_MLP_H
37 #define VERBOSE GNUNET_EXTRA_LOGGING
38 #define DEBUG_MLP GNUNET_EXTRA_LOGGING
40 #define MLP_MAX_EXEC_DURATION GNUNET_TIME_relative_multiply(GNUNET_TIME_UNIT_SECONDS, 3)
41 #define MLP_MAX_ITERATIONS INT_MAX
51 struct GNUNET_STATISTICS_Handle *stats;
54 * GLPK (MLP) problem object
63 * GLPK LP control parameter
65 glp_smcp control_param_lp;
68 * GLPK LP control parameter
70 glp_iocp control_param_mlp;
73 * Maximum execution time per problem solving
75 struct GNUNET_TIME_Relative max_exec_duration;
78 * Maximum number of LP iterations per problem solving
80 unsigned int max_iterations;
82 /* state information */
85 * Do we need to use the LP presolver?
87 * If the problem addresses were added or removed and the last basis was we
88 * need to use the presolver.
89 * presolver_required == GNUNET_YES
91 * If values were modified, we can reuse a valid basis
92 * presolver_required == GNUNET_NO
94 int presolver_required;
99 * Time of last execution
101 struct GNUNET_TIME_Absolute last_execution;
105 * How often was the LP problem solved
107 unsigned int lp_solved;
110 * total duration of all lp solver executions
112 uint64_t lp_total_duration;
115 * How often was the MLP problem solved
117 unsigned int mlp_solved;
120 * total duration of all mlp solver executions
122 uint64_t mlp_total_duration;
127 * Address specific MLP information
129 struct MLP_information
136 * Init the MLP problem solving component
138 * @param stats the GNUNET_STATISTICS handle
139 * @param max_duration maximum numbers of iterations for the LP/MLP Solver
140 * @param max_iterations maximum time limit for the LP/MLP Solver
141 * @return GNUNET_OK on success, GNUNET_SYSERR on fail
144 GAS_mlp_init (const struct GNUNET_STATISTICS_Handle *stats,
145 struct GNUNET_TIME_Relative max_duration,
146 unsigned int max_iterations);
149 * Updates a single address in the MLP problem
151 * If the address did not exist before in the problem:
152 * The MLP problem has to be recreated and the problem has to be resolved
154 * Otherwise the addresses' values can be updated and the existing base can
158 GAS_mlp_address_update (struct GNUNET_CONTAINER_MultiHashMap * addresses, struct ATS_Address *address);
162 * Deletes a single address in the MLP problem
164 * The MLP problem has to be recreated and the problem has to be resolved
167 GAS_mlp_address_delete (struct GNUNET_CONTAINER_MultiHashMap * addresses, struct ATS_Address *address);
171 * Deletes a single address in the MLP problem
174 GAS_mlp_address_change_preference (struct GNUNET_CONTAINER_MultiHashMap * addresses, struct ATS_Address *address);
178 * Shutdown the MLP problem solving component
184 /* end of gnunet-service-ats_addresses_mlp.h */