SST  14.0.0
StructuralSimulationToolkit
coreTest_Component.h
1 // Copyright 2009-2024 NTESS. Under the terms
2 // of Contract DE-NA0003525 with NTESS, the U.S.
3 // Government retains certain rights in this software.
4 //
5 // Copyright (c) 2009-2024, NTESS
6 // All rights reserved.
7 //
8 // This file is part of the SST software package. For license
9 // information, see the LICENSE file in the top level directory of the
10 // distribution.
11 
12 #ifndef SST_CORE_CORETEST_COMPONENT_H
13 #define SST_CORE_CORETEST_COMPONENT_H
14 
15 #include "sst/core/component.h"
16 #include "sst/core/link.h"
17 #include "sst/core/rng/marsaglia.h"
18 
19 namespace SST {
20 namespace CoreTestComponent {
21 
22 // These first two classes are just base classes to test ELI
23 // inheritance. The definition of the ELI items are spread through 2
24 // component base classes to make sure they get inherited in the
25 // actual component that can be instanced.
27 {
28 public:
29  SST_ELI_REGISTER_COMPONENT_BASE(SST::CoreTestComponent::coreTestComponentBase)
30 
31  SST_ELI_DOCUMENT_PARAMS(
32  { "workPerCycle", "Count of busy work to do during a clock tick.", NULL},
33  { "clockFrequency", "Frequency of the clock", "1GHz"}
34  )
35 
36  SST_ELI_DOCUMENT_STATISTICS(
37  { "N", "events sent on N link", "counts", 1 }
38  )
39 
40  SST_ELI_DOCUMENT_PORTS(
41  {"Nlink", "Link to the coreTestComponent to the North", { "coreTestComponent.coreTestComponentEvent", "" } }
42  )
43 
44  SST_ELI_DOCUMENT_ATTRIBUTES(
45  { "test_element", "true" }
46  )
47 
48  coreTestComponentBase(ComponentId_t id) : SST::Component(id) {}
50 };
51 
53 {
54 public:
55  SST_ELI_REGISTER_COMPONENT_DERIVED_BASE(
57 
58  SST_ELI_DOCUMENT_PARAMS(
59  { "commFreq", "There is a 1/commFreq chance each clock cycle of sending an event to a neighbor", NULL}
60  )
61 
62  SST_ELI_DOCUMENT_STATISTICS(
63  { "S", "events sent on S link", "counts", 1 }
64  )
65 
66  SST_ELI_DOCUMENT_PORTS(
67  {"Slink", "Link to the coreTestComponent to the South", { "coreTestComponent.coreTestComponentEvent", "" } }
68  )
69 
70  coreTestComponentBase2(ComponentId_t id) : coreTestComponentBase(id) {}
72 };
73 
75 {
76 public:
77  // REGISTER THIS COMPONENT INTO THE ELEMENT LIBRARY
78  SST_ELI_REGISTER_COMPONENT(
80  "coreTestElement",
81  "coreTestComponent",
82  SST_ELI_ELEMENT_VERSION(1,0,0),
83  "CoreTest Test Component",
84  COMPONENT_CATEGORY_PROCESSOR
85  )
86 
87  SST_ELI_DOCUMENT_PARAMS(
88  { "commSize", "Size of communication to send.", "16"}
89  )
90 
91  SST_ELI_DOCUMENT_STATISTICS(
92  { "E", "events sent on E link", "counts", 1 },
93  { "W", "events sent on W link", "counts", 1 }
94  )
95 
96  SST_ELI_DOCUMENT_PORTS(
97  {"Elink", "Link to the coreTestComponent to the East", { "coreTestComponent.coreTestComponentEvent", "" } },
98  {"Wlink", "Link to the coreTestComponent to the West", { "coreTestComponent.coreTestComponentEvent", "" } }
99  )
100 
101  // Optional since there is nothing to document
102  SST_ELI_DOCUMENT_SUBCOMPONENT_SLOTS(
103  )
104 
105  coreTestComponent(SST::ComponentId_t id, SST::Params& params);
107 
108  void setup() {}
109  void finish() { printf("Component Finished.\n"); }
110 
111 private:
112  coreTestComponent(); // for serialization only
113  coreTestComponent(const coreTestComponent&); // do not implement
114  void operator=(const coreTestComponent&); // do not implement
115 
116  void handleEvent(SST::Event* ev);
117  virtual bool clockTic(SST::Cycle_t);
118 
119  int workPerCycle;
120  int commFreq;
121  int commSize;
122  int neighbor;
123 
125  SST::Link* N;
126  SST::Link* S;
127  SST::Link* E;
128  SST::Link* W;
133 };
134 
135 } // namespace CoreTestComponent
136 } // namespace SST
137 
138 #endif // SST_CORE_CORETEST_COMPONENT_H
void setup()
Called after all components have been constructed and initialization has completed, but before simulation time has begun.
Definition: coreTest_Component.h:108
Main component object for the simulation.
Definition: component.h:30
Definition: coreTest_Component.h:74
Definition: action.cc:18
Definition: coreTest_Component.h:26
Definition: coreTest_Component.h:52
Implements a random number generator using the Marsaglia method.
Definition: marsaglia.h:40
Parameter store.
Definition: params.h:55
void finish()
Called after complete phase, but before objects are destroyed.
Definition: coreTest_Component.h:109
Base class for Events - Items sent across links to communicate between components.
Definition: event.h:34