Main Page | Namespace List | Class Hierarchy | Alphabetical List | Class List | Directories | File List | Namespace Members | Class Members | File Members | Related Pages

dist_list< A > Class Template Reference

#include <dist_list.h>

Collaboration diagram for dist_list< A >:

Collaboration graph
[legend]
List of all members.

Public Member Functions

int get_global_size () const
 Returns the total size of list.
A & at (int index)
 Local access to data.
const A & at (int index) const
 Constant local access to data.
int get_begin_index (int rank) const
 Computes the first index.
int get_end_index (int rank) const
 Computes the (last + 1) index.
int get_local_size (int rank) const
 Computes the local size.
 dist_list (int list_size_)
 Makes an empty list.
 dist_list (int array_size_, const A *array_)
 Makes an list by distributing the list on master process.
template<typename F>
 dist_list (const F &f, int list_size_)
 Makes an list by generating with func.
 dist_list (const dist_list< A > &as)
 Copy constructor.
dist_list< A > & operator= (const dist_list< A > &as)
 The assignment operator.
 ~dist_list ()

Friends

class list_skeletons

Detailed Description

template<typename A>
class dist_list< A >

Definition at line 50 of file dist_list.h.


Constructor & Destructor Documentation

template<typename A>
dist_list< A >::dist_list int  list_size_  )  [inline]
 

Makes an empty list.

Parameters:
list_size_ : The total size of list. [ in ]

Definition at line 89 of file dist_list.tpp.

References skeleton::init().

Here is the call graph for this function:

template<typename A>
dist_list< A >::dist_list int  array_size_,
const A *  array_
[inline]
 

Makes an list by distributing the list on master process.

Parameters:
array_size_ : The total size of array. [ in ]
array_ : The array to distribute. [ in, master ]

Definition at line 97 of file dist_list.tpp.

References dist_list< A >::get_begin_index(), dist_list< A >::get_local_size(), skeleton::init(), skeleton::procs, skeleton::rank, and TAG_DISTRIBUTE.

Here is the call graph for this function:

template<typename A>
template<typename F>
dist_list< A >::dist_list const F &  f,
int  list_size_
[inline]
 

Makes an list by generating with func.

Parameters:
f : The generating function. [ in ]
list_size_ : The total size of list. [ in ]

Definition at line 123 of file dist_list.tpp.

References dist_list< A >::at(), and skeleton::init().

Here is the call graph for this function:

template<typename A>
dist_list< A >::dist_list const dist_list< A > &  as  )  [inline]
 

Copy constructor.

Parameters:
as : The original list.

Definition at line 136 of file dist_list.tpp.

References dist_list< A >::at(), and skeleton::init().

Here is the call graph for this function:

template<typename A>
dist_list< A >::~dist_list  )  [inline]
 

Definition at line 178 of file dist_list.tpp.


Member Function Documentation

template<typename A>
const A & dist_list< A >::at int  index  )  const [inline]
 

Constant local access to data.

Parameters:
index : local index [ in ]
Returns:
The constant reference to local data

Definition at line 39 of file dist_list.tpp.

template<typename A>
A & dist_list< A >::at int  index  )  [inline]
 

Local access to data.

Parameters:
index : local index [ in ]
Returns:
The reference to local data

Definition at line 32 of file dist_list.tpp.

Referenced by list_skeletons::accumulate(), list_skeletons::cataj(), dist_list< A >::dist_list(), list_skeletons::map(), list_skeletons::map_ow(), list_skeletons::mapindex(), list_skeletons::mapindex_ow(), dist_list< A >::operator=(), list_skeletons::prescan(), list_skeletons::prescan_ow(), list_skeletons::prescanr(), list_skeletons::prescanr_ow(), list_skeletons::print(), list_skeletons::reduce(), list_skeletons::scan(), list_skeletons::scanr(), list_skeletons::shiftl(), list_skeletons::shiftl_ow(), list_skeletons::shiftr(), list_skeletons::shiftr_ow(), list_skeletons::zip(), list_skeletons::zip_reduce(), list_skeletons::zipwith(), list_skeletons::zipwith_reduce(), and list_skeletons::zipwithindex().

template<typename A>
int dist_list< A >::get_begin_index int  rank  )  const [inline]
 

Computes the first index.

Parameters:
rank : the rank to obtain the first index for.

Definition at line 46 of file dist_list.tpp.

References skeleton::procs.

Referenced by dist_list< A >::dist_list(), list_skeletons::gather(), and list_skeletons::print().

template<typename A>
int dist_list< A >::get_end_index int  rank  )  const [inline]
 

Computes the (last + 1) index.

Parameters:
rank : the rank to obtain the (last + 1) index for.

Definition at line 60 of file dist_list.tpp.

References skeleton::procs.

Referenced by list_skeletons::print().

template<typename A>
int dist_list< A >::get_global_size  )  const [inline]
 

Returns the total size of list.

Definition at line 25 of file dist_list.tpp.

Referenced by list_skeletons::map(), list_skeletons::mapindex(), list_skeletons::prescan(), list_skeletons::prescanr(), list_skeletons::scan(), list_skeletons::scanr(), list_skeletons::zip(), list_skeletons::zip_reduce(), list_skeletons::zipwith(), list_skeletons::zipwith_reduce(), and list_skeletons::zipwithindex().

template<typename A>
int dist_list< A >::get_local_size int  rank  )  const [inline]
 

Computes the local size.

Parameters:
rank : the rank to obtain the local size for.

Definition at line 74 of file dist_list.tpp.

References skeleton::procs.

Referenced by dist_list< A >::dist_list(), list_skeletons::gather(), and list_skeletons::print().

template<typename A>
dist_list< A > & dist_list< A >::operator= const dist_list< A > &  as  )  [inline]
 

The assignment operator.

Parameters:
as : The list to copy from.

Definition at line 147 of file dist_list.tpp.

References dist_list< A >::at(), dist_list< A >::global_size, and skeleton::init().

Here is the call graph for this function:


Friends And Related Function Documentation

template<typename A>
friend class list_skeletons [friend]
 

Definition at line 52 of file dist_list.h.


The documentation for this class was generated from the following files:
Generated on Wed Jan 18 22:20:10 2006 for SkeTo -- Skeleton Library in Tokyo by  doxygen 1.4.4