epoc32/include/stdapis/stlportv5/stl/_numeric.h
author William Roberts <williamr@symbian.org>
Wed, 31 Mar 2010 12:33:34 +0100
branchSymbian3
changeset 4 837f303aceeb
parent 3 e1b950c65cb4
permissions -rw-r--r--
Current Symbian^3 public API header files (from PDK 3.0.h)
This is the epoc32/include tree with the "platform" subtrees removed, and
all but a selected few mbg and rsg files removed.
williamr@2
     1
/*
williamr@2
     2
 *
williamr@2
     3
 * Copyright (c) 1994
williamr@2
     4
 * Hewlett-Packard Company
williamr@2
     5
 *
williamr@2
     6
 * Copyright (c) 1996,1997
williamr@2
     7
 * Silicon Graphics Computer Systems, Inc.
williamr@2
     8
 *
williamr@4
     9
 * Copyright (c) 1999
williamr@2
    10
 * Boris Fomitchev
williamr@2
    11
 *
williamr@2
    12
 * This material is provided "as is", with absolutely no warranty expressed
williamr@2
    13
 * or implied. Any use is at your own risk.
williamr@2
    14
 *
williamr@4
    15
 * Permission to use or copy this software for any purpose is hereby granted
williamr@2
    16
 * without fee, provided the above notices are retained on all copies.
williamr@2
    17
 * Permission to modify the code and to distribute modified code is granted,
williamr@2
    18
 * provided the above notices are retained, and a notice that the code was
williamr@2
    19
 * modified is included with the above copyright notice.
williamr@2
    20
 *
williamr@2
    21
 */
williamr@2
    22
williamr@2
    23
/* NOTE: This is an internal header file, included by other STL headers.
williamr@2
    24
 *   You should not attempt to use it directly.
williamr@2
    25
 */
williamr@2
    26
williamr@2
    27
#ifndef _STLP_INTERNAL_NUMERIC_H
williamr@2
    28
#define _STLP_INTERNAL_NUMERIC_H
williamr@2
    29
williamr@4
    30
#ifndef _STLP_INTERNAL_FUNCTION_BASE_H
williamr@2
    31
# include <stl/_function_base.h>
williamr@2
    32
#endif
williamr@2
    33
williamr@2
    34
#ifndef _STLP_INTERNAL_ITERATOR_BASE_H
williamr@4
    35
#  include <stl/_iterator_base.h>
williamr@2
    36
#endif
williamr@2
    37
williamr@2
    38
_STLP_BEGIN_NAMESPACE
williamr@2
    39
williamr@2
    40
template <class _InputIterator, class _Tp>
williamr@2
    41
_STLP_INLINE_LOOP
williamr@4
    42
_Tp accumulate(_InputIterator __first, _InputIterator __last, _Tp _Init) {
williamr@4
    43
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@2
    44
  for ( ; __first != __last; ++__first)
williamr@2
    45
    _Init = _Init + *__first;
williamr@2
    46
  return _Init;
williamr@2
    47
}
williamr@2
    48
williamr@2
    49
template <class _InputIterator, class _Tp, class _BinaryOperation>
williamr@2
    50
_STLP_INLINE_LOOP
williamr@2
    51
_Tp accumulate(_InputIterator __first, _InputIterator __last, _Tp _Init,
williamr@4
    52
               _BinaryOperation __binary_op) {
williamr@4
    53
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@2
    54
  for ( ; __first != __last; ++__first)
williamr@2
    55
    _Init = __binary_op(_Init, *__first);
williamr@2
    56
  return _Init;
williamr@2
    57
}
williamr@2
    58
williamr@2
    59
template <class _InputIterator1, class _InputIterator2, class _Tp>
williamr@2
    60
_STLP_INLINE_LOOP
williamr@2
    61
_Tp inner_product(_InputIterator1 __first1, _InputIterator1 __last1,
williamr@4
    62
                  _InputIterator2 __first2, _Tp _Init) {
williamr@4
    63
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first1, __last1))
williamr@2
    64
  for ( ; __first1 != __last1; ++__first1, ++__first2)
williamr@2
    65
    _Init = _Init + (*__first1 * *__first2);
williamr@2
    66
  return _Init;
williamr@2
    67
}
williamr@2
    68
williamr@2
    69
template <class _InputIterator1, class _InputIterator2, class _Tp,
williamr@2
    70
          class _BinaryOperation1, class _BinaryOperation2>
williamr@2
    71
_STLP_INLINE_LOOP
williamr@2
    72
_Tp inner_product(_InputIterator1 __first1, _InputIterator1 __last1,
williamr@4
    73
                  _InputIterator2 __first2, _Tp _Init,
williamr@2
    74
                  _BinaryOperation1 __binary_op1,
williamr@4
    75
                  _BinaryOperation2 __binary_op2) {
williamr@4
    76
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first1, __last1))
williamr@2
    77
  for ( ; __first1 != __last1; ++__first1, ++__first2)
williamr@2
    78
    _Init = __binary_op1(_Init, __binary_op2(*__first1, *__first2));
williamr@2
    79
  return _Init;
williamr@2
    80
}
williamr@2
    81
williamr@4
    82
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
    83
williamr@2
    84
template <class _InputIterator, class _OutputIterator, class _Tp,
williamr@2
    85
          class _BinaryOperation>
williamr@4
    86
_OutputIterator
williamr@4
    87
__partial_sum(_InputIterator __first, _InputIterator __last,
williamr@2
    88
              _OutputIterator __result, _Tp*, _BinaryOperation __binary_op);
williamr@2
    89
williamr@4
    90
_STLP_MOVE_TO_STD_NAMESPACE
williamr@2
    91
williamr@2
    92
template <class _InputIterator, class _OutputIterator>
williamr@4
    93
inline _OutputIterator
williamr@2
    94
partial_sum(_InputIterator __first, _InputIterator __last,
williamr@2
    95
            _OutputIterator __result) {
williamr@4
    96
  return _STLP_PRIV __partial_sum(__first, __last, __result, _STLP_VALUE_TYPE(__first, _InputIterator),
williamr@4
    97
                                  _STLP_PRIV __plus(_STLP_VALUE_TYPE(__first, _InputIterator)));
williamr@2
    98
}
williamr@2
    99
williamr@2
   100
template <class _InputIterator, class _OutputIterator, class _BinaryOperation>
williamr@4
   101
inline _OutputIterator
williamr@2
   102
partial_sum(_InputIterator __first, _InputIterator __last,
williamr@2
   103
            _OutputIterator __result, _BinaryOperation __binary_op) {
williamr@4
   104
  return _STLP_PRIV __partial_sum(__first, __last, __result, _STLP_VALUE_TYPE(__first, _InputIterator),
williamr@4
   105
                                  __binary_op);
williamr@2
   106
}
williamr@2
   107
williamr@4
   108
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@2
   109
williamr@4
   110
template <class _InputIterator, class _OutputIterator, class _Tp,
williamr@2
   111
          class _BinaryOperation>
williamr@2
   112
_OutputIterator
williamr@4
   113
__adjacent_difference(_InputIterator __first, _InputIterator __last,
williamr@2
   114
                      _OutputIterator __result, _Tp*,
williamr@2
   115
                      _BinaryOperation __binary_op);
williamr@2
   116
williamr@4
   117
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
   118
williamr@2
   119
template <class _InputIterator, class _OutputIterator>
williamr@2
   120
inline _OutputIterator
williamr@2
   121
adjacent_difference(_InputIterator __first,
williamr@2
   122
                    _InputIterator __last, _OutputIterator __result) {
williamr@4
   123
  return _STLP_PRIV __adjacent_difference(__first, __last, __result,
williamr@4
   124
                                          _STLP_VALUE_TYPE(__first, _InputIterator),
williamr@4
   125
                                          _STLP_PRIV __minus(_STLP_VALUE_TYPE(__first, _InputIterator)));
williamr@2
   126
}
williamr@2
   127
williamr@2
   128
template <class _InputIterator, class _OutputIterator, class _BinaryOperation>
williamr@4
   129
_OutputIterator
williamr@2
   130
adjacent_difference(_InputIterator __first, _InputIterator __last,
williamr@2
   131
                    _OutputIterator __result, _BinaryOperation __binary_op) {
williamr@4
   132
  return _STLP_PRIV __adjacent_difference(__first, __last, __result,
williamr@4
   133
                                          _STLP_VALUE_TYPE(__first, _InputIterator),
williamr@4
   134
                                          __binary_op);
williamr@2
   135
}
williamr@2
   136
williamr@4
   137
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
   138
williamr@2
   139
template <class _Tp, class _Integer, class _MonoidOperation>
williamr@2
   140
_Tp __power(_Tp __x, _Integer __n, _MonoidOperation __opr);
williamr@2
   141
williamr@4
   142
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
   143
williamr@4
   144
#if !defined (_STLP_NO_EXTENSIONS)
williamr@2
   145
williamr@2
   146
// Returns __x ** __n, where __n >= 0.  _Note that "multiplication"
williamr@2
   147
// is required to be associative, but not necessarily commutative.
williamr@2
   148
williamr@4
   149
_STLP_MOVE_TO_PRIV_NAMESPACE
williamr@4
   150
williamr@2
   151
template <class _Tp, class _Integer>
williamr@4
   152
inline _Tp __power(_Tp __x, _Integer __n) {
williamr@2
   153
  return __power(__x, __n, multiplies<_Tp>());
williamr@2
   154
}
williamr@2
   155
williamr@4
   156
_STLP_MOVE_TO_STD_NAMESPACE
williamr@4
   157
williamr@2
   158
// Alias for the internal name __power.  Note that power is an extension,
williamr@2
   159
// not part of the C++ standard.
williamr@2
   160
template <class _Tp, class _Integer, class _MonoidOperation>
williamr@2
   161
inline _Tp power(_Tp __x, _Integer __n, _MonoidOperation __opr) {
williamr@4
   162
  return _STLP_PRIV __power(__x, __n, __opr);
williamr@2
   163
}
williamr@2
   164
williamr@2
   165
template <class _Tp, class _Integer>
williamr@2
   166
inline _Tp power(_Tp __x, _Integer __n) {
williamr@4
   167
  return _STLP_PRIV __power(__x, __n, multiplies<_Tp>());
williamr@2
   168
}
williamr@2
   169
williamr@2
   170
// iota is not part of the C++ standard.  It is an extension.
williamr@2
   171
williamr@2
   172
template <class _ForwardIterator, class _Tp>
williamr@2
   173
_STLP_INLINE_LOOP
williamr@4
   174
void iota(_ForwardIterator __first, _ForwardIterator __last, _Tp __val) {
williamr@4
   175
  _STLP_DEBUG_CHECK(_STLP_PRIV __check_range(__first, __last))
williamr@2
   176
  while (__first != __last)
williamr@2
   177
    *__first++ = __val++;
williamr@2
   178
}
williamr@4
   179
#endif
williamr@2
   180
williamr@2
   181
_STLP_END_NAMESPACE
williamr@2
   182
williamr@4
   183
#if !defined (_STLP_LINK_TIME_INSTANTIATION)
williamr@2
   184
#  include <stl/_numeric.c>
williamr@4
   185
#endif
williamr@2
   186
williamr@2
   187
#endif /* _STLP_INTERNAL_NUMERIC_H */
williamr@2
   188
williamr@2
   189
// Local Variables:
williamr@2
   190
// mode:C++
williamr@2
   191
// End: