FRODO Version 2.19.1
An open-source framework for Distributed Constraint Optimization (DCOP)
Loading...
Searching...
No Matches
frodo2.algorithms.dpop.param.test.ParamDPOPtest< V extends Addable< V >, U extends Addable< U > > Class Template Reference

JUnit test for Param-DPOP. More...

Inheritance diagram for frodo2.algorithms.dpop.param.test.ParamDPOPtest< V extends Addable< V >, U extends Addable< U > >:

Public Member Functions

 ParamDPOPtest (boolean useXCSP, boolean useTCP, boolean allProbs, boolean useCentralMailer, MessageType startMsgType, Class< V > domClass, Class< U > utilClass)
 Creates a JUnit test case corresponding to the input method.
void setUp () throws Exception
Public Member Functions inherited from frodo2.algorithms.dpop.test.DPOPagentTest< V extends Addable< V >, U extends Addable< U > >
 DPOPagentTest (boolean useXCSP, boolean useTCP, boolean useCentralMailer, boolean useDelay, Class< V > domClass, Class< U > utilClass)
 Creates a JUnit test case corresponding to the input method.
 DPOPagentTest (boolean useXCSP, boolean swap, boolean minNCCCs, boolean countNCCCs, boolean ignoreHypercubeNCCCs)
 Constructor.
 DPOPagentTest (boolean useXCSP, boolean swap, boolean minNCCCs, boolean countNCCCs, boolean ignoreHypercubeNCCCs, String dpopPath)
 Constructor.
 DPOPagentTest (Class<? extends XCSPparser< V, U > > parserClass)
 Constructor for a test with a subsolver.
 DPOPagentTest (boolean useXCSP, boolean useTCP, boolean useCentralMailer, boolean useDelay, Class< V > domClass, Class< U > utilClass, MessageType startMsgType)
 Creates a JUnit test case corresponding to the input method.
 DPOPagentTest (boolean useXCSP, boolean useTCP, boolean useCentralMailer, boolean useDelay, Class< V > domClass, Class< U > utilClass, MessageType startMsgType, Class< ? extends XCSPparser< V, U > > parserClass, boolean swap, boolean minNCCCs, boolean countNCCCs, boolean measureMsgs, boolean ignoreHypercubeNCCCs)
 Creates a JUnit test case corresponding to the input method.
void testRandom () throws Exception
 Tests the DPOPagent on a random problem.
Collection< MessageTypegetMsgTypes ()
void notifyIn (Message msg)
void setQueue (Queue queue)
 Does nothing.
Public Member Functions inherited from frodo2.communication.IncomingMsgPolicyInterface< T >
default void notifyIn (Message msg, Object toAgent)
 Notifies the listener of an incoming message.

Static Public Member Functions

static TestSuite suite ()

Protected Member Functions

void tearDown () throws Exception
void checkOutput ()
Protected Member Functions inherited from frodo2.algorithms.dpop.test.DPOPagentTest< V extends Addable< V >, U extends Addable< U > >
void setStartMsgType (MessageType startMsgType) throws JDOMException
 Sets the type of the start message for all modules.

Private Attributes

final int maxNbrVars = 5
 Maximum number of variables in the problem.
final int maxNbrEdges = 25
 Maximum number of binary constraints in the problem.
final int maxNbrAgents = 5
 Maximum number of agents.
ParamUTIL< V, U > paramUtilModule
 The module listening for the optimal utility to the problem.
ParamVALUE< V > paramValueModule
 The module listening for the optimal assignment to the problem.

Additional Inherited Members

Protected Attributes inherited from frodo2.algorithms.dpop.test.DPOPagentTest< V extends Addable< V >, U extends Addable< U > >
Document agentConfig
 The agent configuration file.
Queue queue
 The queue used to listen to the agents.
Map< Object, QueueOutputPipeInterfacepipes
 For each agent, the output pipe to it.
RandGraphFactory.Graph graph
 Random graph used to generate a constraint graph.
int nbrMsgsReceived
 Used to track the number of various types of messages received from the agents.
int nbrAgentsFinished
 Number of agents finished.
boolean useCentralMailer = false
 true if the algorithm should be tested with the central mailer
Document problemDoc
 The XCSP random problem file.
DCOPProblemInterface< V, U > problem
 The problem.
Class< V > domClass
 The class used for variable values.
Class< U > utilClass
 The class used for utility values.
UTILpropagation< V, U > utilModule
 The module listening for the optimal utility to the problem.
SolutionCollector< V, U > solCollector
 The module listening for the optimal assignment to the problem.
boolean useXCSP
 Whether to use XCSP.
MessageType startMsgType
 The type of the start message.
boolean countNCCCs
 Whether to count NCCCs.
boolean maximize = true
 Whether we should maximize or minimize.
CentralMailer mailman
 The CentralMailer.
boolean aggregate = false
 true when the weighted sum hypercube should be tested

Detailed Description

JUnit test for Param-DPOP.

Author
Thomas Leaute
Parameters
<V>the type used for variable values
<U>the type used for utility values

Constructor & Destructor Documentation

◆ ParamDPOPtest()

frodo2.algorithms.dpop.param.test.ParamDPOPtest< V extends Addable< V >, U extends Addable< U > >.ParamDPOPtest ( boolean useXCSP,
boolean useTCP,
boolean allProbs,
boolean useCentralMailer,
MessageType startMsgType,
Class< V > domClass,
Class< U > utilClass )

Creates a JUnit test case corresponding to the input method.

Parameters
useXCSPwhether to use XCSP
useTCPwhether TCP pipes should be used for communication between agents
allProbsif true, all agents know about all random variables
useCentralMailertrue when the central mailer should be tested
startMsgTypethe type of the start message
domClassthe class used for variable values
utilClassthe class used for utility values

References frodo2.algorithms.dpop.test.DPOPagentTest< V extends Addable< V >, U extends Addable< U > >.domClass, frodo2.algorithms.dpop.test.DPOPagentTest< V extends Addable< V >, U extends Addable< U > >.startMsgType, frodo2.algorithms.dpop.test.DPOPagentTest< V extends Addable< V >, U extends Addable< U > >.useCentralMailer, frodo2.algorithms.dpop.test.DPOPagentTest< V extends Addable< V >, U extends Addable< U > >.useTCP, frodo2.algorithms.dpop.test.DPOPagentTest< V extends Addable< V >, U extends Addable< U > >.useXCSP, and frodo2.algorithms.dpop.test.DPOPagentTest< V extends Addable< V >, U extends Addable< U > >.utilClass.

Referenced by suite().

Member Function Documentation

◆ checkOutput()

◆ setUp()

void frodo2.algorithms.dpop.param.test.ParamDPOPtest< V extends Addable< V >, U extends Addable< U > >.setUp ( ) throws Exception
See also
DPOPagentTest.setUp()

Reimplemented from frodo2.algorithms.dpop.test.DPOPagentTest< V extends Addable< V >, U extends Addable< U > >.

References frodo2.algorithms.dpop.test.DPOPagentTest< V extends Addable< V >, U extends Addable< U > >.agentConfig, frodo2.algorithms.dpop.test.DPOPagentTest< V extends Addable< V >, U extends Addable< U > >.domClass, frodo2.algorithms.test.AllTests.generateProblem(), frodo2.algorithms.RandGraphFactory.getRandGraph(), frodo2.algorithms.dpop.test.DPOPagentTest< V extends Addable< V >, U extends Addable< U > >.graph, frodo2.algorithms.dpop.test.DPOPagentTest< V extends Addable< V >, U extends Addable< U > >.mailman, frodo2.algorithms.dpop.test.DPOPagentTest< V extends Addable< V >, U extends Addable< U > >.maximize, maxNbrAgents, maxNbrEdges, maxNbrVars, frodo2.algorithms.dpop.test.DPOPagentTest< V extends Addable< V >, U extends Addable< U > >.nbrMsgsReceived, paramUtilModule, paramValueModule, frodo2.algorithms.XCSPparser< V extends Addable< V >, U extends Addable< U > >.parse(), frodo2.algorithms.dpop.test.DPOPagentTest< V extends Addable< V >, U extends Addable< U > >.pipes, frodo2.algorithms.dpop.test.DPOPagentTest< V extends Addable< V >, U extends Addable< U > >.problem, frodo2.algorithms.dpop.test.DPOPagentTest< V extends Addable< V >, U extends Addable< U > >.problemDoc, frodo2.algorithms.dpop.test.DPOPagentTest< V extends Addable< V >, U extends Addable< U > >.queue, frodo2.algorithms.Problem< V extends Addable< V >, U extends Addable< U > >.reset(), frodo2.algorithms.XCSPparser< V extends Addable< V >, U extends Addable< U > >.setDomClass(), frodo2.algorithms.XCSPparser< V extends Addable< V >, U extends Addable< U > >.setUtilClass(), frodo2.algorithms.dpop.test.DPOPagentTest< V extends Addable< V >, U extends Addable< U > >.startMsgType, frodo2.algorithms.AgentInterface< V extends Addable< V > >.STATS_MONITOR, and frodo2.algorithms.dpop.test.DPOPagentTest< V extends Addable< V >, U extends Addable< U > >.useCentralMailer.

Here is the call graph for this function:

◆ suite()

TestSuite frodo2.algorithms.dpop.param.test.ParamDPOPtest< V extends Addable< V >, U extends Addable< U > >.suite ( )
static
Returns
the test suite

Reimplemented from frodo2.algorithms.dpop.test.DPOPagentTest< V extends Addable< V >, U extends Addable< U > >.

References ParamDPOPtest(), and suite().

Referenced by frodo2.algorithms.dpop.param.test.AllTestsParamDPOP.suite(), and suite().

Here is the call graph for this function:

◆ tearDown()

Member Data Documentation

◆ maxNbrAgents

final int frodo2.algorithms.dpop.param.test.ParamDPOPtest< V extends Addable< V >, U extends Addable< U > >.maxNbrAgents = 5
private

Maximum number of agents.

Referenced by setUp().

◆ maxNbrEdges

final int frodo2.algorithms.dpop.param.test.ParamDPOPtest< V extends Addable< V >, U extends Addable< U > >.maxNbrEdges = 25
private

Maximum number of binary constraints in the problem.

Referenced by setUp().

◆ maxNbrVars

final int frodo2.algorithms.dpop.param.test.ParamDPOPtest< V extends Addable< V >, U extends Addable< U > >.maxNbrVars = 5
private

Maximum number of variables in the problem.

Note
Must be at least 2.

Referenced by setUp().

◆ paramUtilModule

ParamUTIL<V, U> frodo2.algorithms.dpop.param.test.ParamDPOPtest< V extends Addable< V >, U extends Addable< U > >.paramUtilModule
private

The module listening for the optimal utility to the problem.

Referenced by checkOutput(), and setUp().

◆ paramValueModule

ParamVALUE<V> frodo2.algorithms.dpop.param.test.ParamDPOPtest< V extends Addable< V >, U extends Addable< U > >.paramValueModule
private

The module listening for the optimal assignment to the problem.

Referenced by checkOutput(), and setUp().


The documentation for this class was generated from the following file: