NVIDIA Holoscan SDK v3.7.0

Class MultiThreadScheduler

Base Type

class MultiThreadScheduler : public holoscan::gxf::GXFScheduler

Multi-Thread scheduler.

This is a multi-thread scheduler that uses an event-based design. In addition to the specified worker_thread_number of threads for executing operators, it utilizes an additional polling thread that is used to check the execution readiness status of operators at period specified by check_recession_period_ms.

==Parameters==

  • worker_thread_number (int64_t): The number of (CPU) worker threads to use for executing operators. Defaults to 1.

  • stop_on_deadlock (bool): If True, the application will terminate if a deadlock state is reached. Defaults to true.

  • stop_on_deadlock_timeout (int64_t): The amount of time (in ms) before an application is considered to be in deadlock. Defaults to 0.

  • check_recession_period_ms (int64_t): How often the polling thread checks for whether an operator is ready to execute. The value is in ms (default: 5).

  • max_duration_ms_ (int64_t, optional): Terminate the application after the specified duration even if deadlock does not occur. If unspecified, the application can run indefinitely.

Public Functions

template<typename ArgT, typename ...ArgsT, typename = std::enable_if_t<!std::is_base_of_v<::holoscan::Scheduler, std::decay_t<ArgT>> && (std::is_same_v<::holoscan::Arg, std::decay_t<ArgT>> || std::is_same_v<::holoscan::ArgList, std::decay_t<ArgT>>)>>
inline explicit MultiThreadScheduler(ArgT &&arg, ArgsT&&... args)
MultiThreadScheduler() = default
inline virtual const char *gxf_typename() const override

Get the type name of the GXF scheduler.

The returned string is the type name of the GXF scheduler and is used to create the GXF scheduler.

Example: “nvidia::holoscan::GreedyScheduler”

Returns

The type name of the GXF scheduler.

virtual std::shared_ptr<Clock> clock() override

Get the Clock used by the scheduler.

Returns

The Clock used by the scheduler.

virtual void setup(ComponentSpec &spec) override

Define the scheduler specification.

Parameters

spec – The reference to the component specification.

virtual void initialize() override

Initialize the scheduler.

This function is called after the scheduler is created by holoscan::Fragment::make_scheduler().

inline int64_t worker_thread_number()
inline bool stop_on_deadlock()
inline int64_t check_recession_period_ms()
inline int64_t stop_on_deadlock_timeout()
inline int64_t max_duration_ms()
nvidia::gxf::MultiThreadScheduler *get() const

Previous Class MultiMessageAvailableTimeoutCondition
Next Class NetworkContext
© Copyright 2022-2025, NVIDIA. Last updated on Oct 13, 2025.