mapper.h 2.21 KB
Newer Older
thomas.forbriger's avatar
thomas.forbriger committed
1
2
3
4
5
/*! \file mapper.h
 * \brief map values (prototypes)
 * 
 * ----------------------------------------------------------------------------
 * 
thomas.forbriger's avatar
thomas.forbriger committed
6
 * $Id: mapper.h,v 1.5 2005-04-28 15:01:47 tforb Exp $
thomas.forbriger's avatar
thomas.forbriger committed
7
8
9
10
11
12
13
14
15
16
17
18
19
20
 * \author Thomas Forbriger
 * \date 20/03/2005
 * 
 * map values (prototypes)
 * 
 * Copyright (c) 2005 by Thomas Forbriger (BFO Schiltach) 
 * 
 * REVISIONS and CHANGES 
 *  - 20/03/2005   V1.0   Thomas Forbriger
 * 
 * ============================================================================
 */

// include guard
thomas.forbriger's avatar
thomas.forbriger committed
21
#ifndef AFF_MAPPER_H_VERSION
thomas.forbriger's avatar
thomas.forbriger committed
22

thomas.forbriger's avatar
thomas.forbriger committed
23
24
25
#define AFF_MAPPER_H_VERSION \
  "AFF_MAPPER_H   V1.0   "
#define AFF_MAPPER_H_CVSID \
thomas.forbriger's avatar
thomas.forbriger committed
26
  "$Id: mapper.h,v 1.5 2005-04-28 15:01:47 tforb Exp $"
thomas.forbriger's avatar
thomas.forbriger committed
27

thomas.forbriger's avatar
thomas.forbriger committed
28
#include<aff/iterator.h>
thomas.forbriger's avatar
thomas.forbriger committed
29

thomas.forbriger's avatar
thomas.forbriger committed
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
namespace aff {

  namespace func {

    namespace util {

      /*! Function template to map values from one container to another
       *
       * This is a framework to browse through a container and map
       * values to values of a different type. This function template is used
       * by container functions like aff::func::valmap().
       *
       * \param C any container class like aff::Array
       * \param F any mapper utility class like
       *          aff::func::util::Mapvalmap
       *
       * \param c container to read values to be mapped
       * \param exfun fully initialized mapper utility
       * \return result container of same shape as c but with mapped values
       *
       * \sa aff::func::valmap()
       */
      template<template<class> class C, class F>
        C<typename F::Toutvalue> 
          mapvalues(const typename C<typename F::Tinvalue>::Tcoc& c,
thomas.forbriger's avatar
thomas.forbriger committed
55
                    const F& exfun)
thomas.forbriger's avatar
thomas.forbriger committed
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
        {
          typedef typename C<typename F::Tinvalue>::Tcoc Tin;
          typedef C<typename F::Toutvalue> Tout;
          Tout retval(c.shape());
          aff::Browser<Tin> browser(c);
          aff::Iterator<Tout> iterator(retval);
          while(browser.valid() && iterator.valid())
          {
            *iterator = exfun(*browser);
            ++browser;
            ++iterator;
          }
          return(retval);
        }; // mapvalues

    } // namespace util

  } // namespace func

} // namespace aff
thomas.forbriger's avatar
thomas.forbriger committed
76

thomas.forbriger's avatar
thomas.forbriger committed
77
#endif // AFF_MAPPER_H_VERSION (includeguard)
thomas.forbriger's avatar
thomas.forbriger committed
78
79

/* ----- END OF mapper.h ----- */