AQUAgpusph 4.1.2
Loading...
Searching...
No Matches
Public Member Functions | Protected Member Functions
Aqua::CalcServer::Assert Class Reference

Check that a condition holds true, or trhow a fatal error otherwise. More...

#include <CalcServer/Assert.h>

Inheritance diagram for Aqua::CalcServer::Assert:
Inheritance graph
[legend]
Collaboration diagram for Aqua::CalcServer::Assert:
Collaboration graph
[legend]

Public Member Functions

 Assert (const std::string name, const std::string condition, bool once=false)
 Constructor.
 
 ~Assert ()
 Destructor.
 
void setup ()
 Initialize the tool.
 
- Public Member Functions inherited from Aqua::CalcServer::Tool
 Tool (const std::string tool_name, bool once=false)
 
virtual ~Tool ()
 
void name (const std::string tool_name)
 
const std::string name ()
 
virtual void setup ()
 
virtual void execute ()
 Execute the tool measuring the elapsed time.
 
virtual Toolnext_tool ()
 
size_t allocatedMemory () const
 
unsigned int used_times () const
 
float elapsedTime (bool averaged=true) const
 
float elapsedTimeVariance () const
 
float elapsedTimeDeviation () const
 
virtual const int scope_modifier ()
 

Protected Member Functions

cl_event _execute (const std::vector< cl_event > events)
 
- Protected Member Functions inherited from Aqua::CalcServer::Tool
int id_in_pipeline ()
 
void next_tool (Tool *tool)
 
void allocatedMemory (size_t mem_size)
 
virtual cl_event _execute (const std::vector< cl_event > events)
 
void addElapsedTime (float elapsed_time)
 Add new data to the average and squared elapsed times.
 
void setDependencies (std::vector< std::string > var_names)
 Set the depedencies of the tool.
 
void setDependencies (std::vector< InputOutput::Variable * > vars)
 Set the depedencies of the tool.
 
const std::vector< InputOutput::Variable * > getDependencies ()
 Get the depedencies of the tool.
 

Additional Inherited Members

- Static Protected Member Functions inherited from Aqua::CalcServer::Tool
static std::vector< cl_kernel > compile (const std::string source, const std::vector< std::string > names, const std::string flags="")
 Compile an OpenCL source code and generate the corresponding kernel.
 
static cl_kernel compile_kernel (const std::string source, const std::string kernel_name, const std::string flags="")
 Compile an OpenCL source code and generate the corresponding kernel.
 

Detailed Description

Check that a condition holds true, or trhow a fatal error otherwise.

If the result of evaluating the condition expression is equal to 0, the result will be considered false, and therefore a fatal error will be raised. Any other value will be considered as true, letting the simulation to normally continue.

Constructor & Destructor Documentation

◆ Assert()

Aqua::CalcServer::Assert::Assert ( const std::string  name,
const std::string  condition,
bool  once = false 
)

Constructor.

Parameters
nameTool name.
conditionCondition to evaluate. If the result is 0, false will be considered, and fatal error will be raised, otherwise the simulation will continue.
onceRun this tool just once. Useful to make initializations.

◆ ~Assert()

Aqua::CalcServer::Assert::~Assert ( )

Destructor.

Member Function Documentation

◆ _execute()

cl_event Aqua::CalcServer::Assert::_execute ( const std::vector< cl_event >  events)
protectedvirtual

Execute the tool

Parameters
eventsList of events that shall be waited before safe execution
Returns
OpenCL event to be waited before accessing the dependencies

Reimplemented from Aqua::CalcServer::Tool.

Here is the call graph for this function:

◆ setup()

void Aqua::CalcServer::Assert::setup ( )
virtual

Initialize the tool.

Reimplemented from Aqua::CalcServer::Tool.

Here is the call graph for this function:

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