STAPL API Reference          
Overview   Containers   Algorithms   Views   Skeletons   Run-Time System
Modules     Classes    
List of all members | Public Member Functions | Public Types | Friends
stapl::steal_policy_base Class Reference

Base class for stealing policies. More...

Public Member Functions

 steal_policy_base (size_type chunk_size, size_type fraction) noexcept
 Constructs a new steal_policy_base. More...
 
template<typename Scheduler >
bool has_work (Scheduler const &scheduler) const noexcept
 Returns true if the scheduler has available work to be stolen.
 
template<typename Scheduler >
void process_steal_requests (Scheduler &scheduler, task_graph *tg_ptr)
 Processes steal requests that it got from thieves. More...
 
template<typename Scheduler >
void migrate_work (Scheduler &scheduler, location_type loc, size_type num_to_migrate, task_graph *tg_ptr)
 Migrate some work to a thief. More...
 
int expected_work (void) const noexcept
 
void receive_work_notification (void) noexcept
 Receive notification of a received work request.
 
void receive_steal_completion (const size_type loot) noexcept
 Receive notification of a steal request completion.
 

Public Types

typedef std::size_t size_type
 

Friends

std::ostream & operator<< (std::ostream &os, steal_policy_base const &p)
 

Detailed Description

Base class for stealing policies.

Constructor & Destructor Documentation

◆ steal_policy_base()

stapl::steal_policy_base::steal_policy_base ( size_type  chunk_size,
size_type  fraction 
)
noexcept

Constructs a new steal_policy_base.

Parameters
chunk_sizeNumber of entries to steal.
fractionFraction of the total entries to steal.

Member Function Documentation

◆ process_steal_requests()

template<typename Scheduler >
void stapl::steal_policy_base::process_steal_requests ( Scheduler &  scheduler,
task_graph tg_ptr 
)

Processes steal requests that it got from thieves.

This function migrates work to the thieves. It will distribute work according to the steal requests that were received.

◆ migrate_work()

template<typename Scheduler >
void stapl::steal_policy_base::migrate_work ( Scheduler &  scheduler,
location_type  loc,
size_type  num_to_migrate,
task_graph tg_ptr 
)

Migrate some work to a thief.

Parameters
schedulerScheduler to migrate work from.
locThief to migrate work to.
num_to_migrateHow much work to migrate.

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