33 #ifndef GKO_CORE_LOG_STREAM_HPP_ 34 #define GKO_CORE_LOG_STREAM_HPP_ 37 #include <ginkgo/core/log/logger.hpp> 58 template <
typename ValueType = default_precision>
63 const size_type &num_bytes)
const override;
67 const uintptr &location)
const override;
70 const uintptr &location)
const override;
73 const uintptr &location)
const override;
76 const uintptr &location_from,
77 const uintptr &location_to,
78 const size_type &num_bytes)
const override;
81 const uintptr &location_from,
82 const uintptr &location_to,
83 const size_type &num_bytes)
const override;
87 const Operation *operation)
const override;
90 const Operation *operation)
const override;
113 const LinOp *x)
const override;
116 const LinOp *x)
const override;
120 const LinOp *x)
const override;
124 const LinOp *x)
const override;
128 const LinOp *input)
const override;
132 const LinOp *output)
const override;
137 const LinOp *residual,
138 const LinOp *residual_norm,
139 const LinOp *solution,
140 const uint8 &stopping_id,
141 const bool &set_finalized)
const override;
145 const LinOp *residual,
const LinOp *residual_norm,
146 const LinOp *solutino,
const uint8 &stopping_id,
148 const bool &one_changed,
const bool &all_converged)
const override;
153 const LinOp *residual,
const LinOp *solution =
nullptr,
154 const LinOp *residual_norm =
nullptr)
const override;
175 std::shared_ptr<const Executor> exec,
177 std::ostream &os = std::cout,
bool verbose =
false)
179 return std::unique_ptr<Stream>(
180 new Stream(exec, enabled_events, os, verbose));
196 std::shared_ptr<const gko::Executor> exec,
198 std::ostream &os = std::cout,
bool verbose =
false)
199 :
Logger(exec, enabled_events), os_(os), verbose_(verbose)
205 static constexpr
const char *prefix_ =
"[LOG] >>> ";
214 #endif // GKO_CORE_LOG_STREAM_HPP_ Definition: logger.hpp:90
void on_copy_started(const Executor *from, const Executor *to, const uintptr &location_from, const uintptr &location_to, const size_type &num_bytes) const override
Executor's copy started event.
void on_criterion_check_started(const stop::Criterion *criterion, const size_type &num_iterations, const LinOp *residual, const LinOp *residual_norm, const LinOp *solution, const uint8 &stopping_id, const bool &set_finalized) const override
stop::Criterion's check started event.
void on_linop_factory_generate_started(const LinOpFactory *factory, const LinOp *input) const override
LinOp Factory's generate started event.
void on_polymorphic_object_create_started(const Executor *, const PolymorphicObject *po) const override
PolymorphicObject's create started event.
void on_linop_apply_started(const LinOp *A, const LinOp *b, const LinOp *x) const override
LinOp's apply started event.
void on_free_started(const Executor *exec, const uintptr &location) const override
Executor's free started event.
A LinOpFactory represents a higher order mapping which transforms one linear operator into another...
Definition: lin_op.hpp:356
void on_allocation_started(const Executor *exec, const size_type &num_bytes) const override
Executor's allocation started event.
void on_criterion_check_completed(const stop::Criterion *criterion, const size_type &num_iterations, const LinOp *residual, const LinOp *residual_norm, const LinOp *solutino, const uint8 &stopping_id, const bool &set_finalized, const Array< stopping_status > *status, const bool &one_changed, const bool &all_converged) const override
stop::Criterion's check completed event.
void on_polymorphic_object_create_completed(const Executor *exec, const PolymorphicObject *input, const PolymorphicObject *output) const override
PolymorphicObject's create completed event.
std::size_t size_type
Integral type used for allocation quantities.
Definition: types.hpp:94
The Ginkgo namespace.
Definition: abstract_factory.hpp:45
A PolymorphicObject is the abstract base for all "heavy" objects in Ginkgo that behave polymorphicall...
Definition: polymorphic_object.hpp:67
void on_operation_launched(const Executor *exec, const Operation *operation) const override
Executor's operation launched event (method run).
void on_allocation_completed(const Executor *exec, const size_type &num_bytes, const uintptr &location) const override
Executor's allocation completed event.
void on_polymorphic_object_copy_started(const Executor *exec, const PolymorphicObject *from, const PolymorphicObject *to) const override
PolymorphicObject's copy started event.
Definition: lin_op.hpp:134
void on_operation_completed(const Executor *exec, const Operation *operation) const override
Executor's operation completed event (method run).
std::uint8_t uint8
8-bit unsigned integral type.
Definition: types.hpp:123
Stream is a Logger which logs every event to a stream.
Definition: stream.hpp:59
void on_iteration_complete(const LinOp *solver, const size_type &num_iterations, const LinOp *residual, const LinOp *solution=nullptr, const LinOp *residual_norm=nullptr) const override
Register the iteration_complete event which logs every completed iterations.
void on_linop_apply_completed(const LinOp *A, const LinOp *b, const LinOp *x) const override
LinOp's apply completed event.
Operations can be used to define functionalities whose implementations differ among devices...
Definition: executor.hpp:173
void on_linop_advanced_apply_completed(const LinOp *A, const LinOp *alpha, const LinOp *b, const LinOp *beta, const LinOp *x) const override
LinOp's advanced apply completed event.
An Array is a container which encapsulates fixed-sized arrays, stored on the Executor tied to the Arr...
Definition: array.hpp:63
void on_free_completed(const Executor *exec, const uintptr &location) const override
Executor's free completed event.
void on_polymorphic_object_deleted(const Executor *exec, const PolymorphicObject *po) const override
PolymorphicObject's deleted event.
static constexpr mask_type all_events_mask
Bitset Mask which activates all events.
Definition: logger.hpp:103
The Criterion class is a base class for all stopping criteria.
Definition: criterion.hpp:63
void on_polymorphic_object_copy_completed(const Executor *exec, const PolymorphicObject *from, const PolymorphicObject *to) const override
PolymorphicObject's copy completed event.
void on_linop_advanced_apply_started(const LinOp *A, const LinOp *alpha, const LinOp *b, const LinOp *beta, const LinOp *x) const override
LinOp's advanced apply started event.
The first step in using the Ginkgo library consists of creating an executor.
Definition: executor.hpp:410
static std::unique_ptr< Stream > create(std::shared_ptr< const Executor > exec, const Logger::mask_type &enabled_events=Logger::all_events_mask, std::ostream &os=std::cout, bool verbose=false)
Creates a Stream logger.
Definition: stream.hpp:174
void on_copy_completed(const Executor *from, const Executor *to, const uintptr &location_from, const uintptr &location_to, const size_type &num_bytes) const override
Executor's copy completed event.
void on_linop_factory_generate_completed(const LinOpFactory *factory, const LinOp *input, const LinOp *output) const override
LinOp Factory's generate completed event.