epoc32/include/stdapis/stlport/stl/_valarray.h
author William Roberts <williamr@symbian.org>
Tue, 16 Mar 2010 16:12:26 +0000
branchSymbian2
changeset 2 2fe1408b6811
parent 0 061f57f2323e
permissions -rw-r--r--
Final list of Symbian^2 public API header files
williamr@2
     1
/*
williamr@2
     2
 * © Portions copyright (c) 2006-2007 Nokia Corporation.  All rights reserved.
williamr@2
     3
 * Copyright (c) 1999
williamr@2
     4
 * Silicon Graphics Computer Systems, Inc.
williamr@2
     5
 *
williamr@2
     6
 * Copyright (c) 1999 
williamr@2
     7
 * Boris Fomitchev
williamr@2
     8
 *
williamr@2
     9
 * This material is provided "as is", with absolutely no warranty expressed
williamr@2
    10
 * or implied. Any use is at your own risk.
williamr@2
    11
 *
williamr@2
    12
 * Permission to use or copy this software for any purpose is hereby granted 
williamr@2
    13
 * without fee, provided the above notices are retained on all copies.
williamr@2
    14
 * Permission to modify the code and to distribute modified code is granted,
williamr@2
    15
 * provided the above notices are retained, and a notice that the code was
williamr@2
    16
 * modified is included with the above copyright notice.
williamr@2
    17
 *
williamr@2
    18
 */ 
williamr@2
    19
williamr@2
    20
#ifndef _STLP_VALARRAY_H
williamr@2
    21
#define _STLP_VALARRAY_H
williamr@2
    22
williamr@2
    23
#ifndef _STLP_CMATH_H_HEADER
williamr@2
    24
#include <stl/_cmath.h>
williamr@2
    25
#endif
williamr@2
    26
#ifndef _STLP_INTERNAL_NEW_HEADER
williamr@2
    27
#include <stl/_new.h>
williamr@2
    28
#endif
williamr@2
    29
#ifndef _STLP_INTERNAL_ALGO_H
williamr@2
    30
#include <stl/_algo.h>
williamr@2
    31
#endif
williamr@2
    32
#ifndef _STLP_INTERNAL_NUMERIC_H
williamr@2
    33
#include <stl/_numeric.h>
williamr@2
    34
#endif
williamr@2
    35
#ifndef _STLP_LIMITS_H
williamr@2
    36
#include <limits>
williamr@2
    37
#endif
williamr@2
    38
williamr@2
    39
//To resolve the unidentified identifier __THROW_BAD_ALLOC 
williamr@2
    40
#include <stl/_alloc.h>
williamr@2
    41
williamr@2
    42
_STLP_BEGIN_NAMESPACE
williamr@2
    43
williamr@2
    44
class slice;
williamr@2
    45
class gslice;
williamr@2
    46
williamr@2
    47
template <class _Tp> class valarray;
williamr@2
    48
typedef valarray<bool>    _Valarray_bool;
williamr@2
    49
typedef valarray<size_t>  _Valarray_size_t;
williamr@2
    50
williamr@2
    51
template <class _Tp> class slice_array;
williamr@2
    52
template <class _Tp> class gslice_array;
williamr@2
    53
template <class _Tp> class mask_array;
williamr@2
    54
template <class _Tp> class indirect_array;
williamr@2
    55
williamr@2
    56
//----------------------------------------------------------------------
williamr@2
    57
// class valarray
williamr@2
    58
williamr@2
    59
// Base class to handle memory allocation and deallocation.  We can't just
williamr@2
    60
// use vector<>, because vector<bool> would be unsuitable as an internal 
williamr@2
    61
// representation for valarray<bool>.
williamr@2
    62
williamr@2
    63
template <class _Tp> 
williamr@2
    64
struct _Valarray_base
williamr@2
    65
{
williamr@2
    66
  _Tp*   _M_first;
williamr@2
    67
  size_t _M_size;
williamr@2
    68
williamr@2
    69
  _Valarray_base() : _M_first(0), _M_size(0) {}
williamr@2
    70
  _Valarray_base(size_t __n) : _M_first(0), _M_size(0) { _M_allocate(__n); }
williamr@2
    71
  ~_Valarray_base() { _M_deallocate(); }
williamr@2
    72
williamr@2
    73
  void _M_allocate(size_t __n) {
williamr@2
    74
    if (__n != 0) {
williamr@2
    75
#ifdef __SYMBIAN32__
williamr@2
    76
      _M_first = ::new _Tp[__n];
williamr@2
    77
#else
williamr@2
    78
      _M_first = __STATIC_CAST(_Tp*, (malloc(__n * sizeof(_Tp))));
williamr@2
    79
#endif
williamr@2
    80
      _M_size  = __n;
williamr@2
    81
      if (_M_first == 0) {
williamr@2
    82
        _M_size = 0;
williamr@2
    83
        __THROW_BAD_ALLOC;
williamr@2
    84
      }
williamr@2
    85
    }
williamr@2
    86
    else {
williamr@2
    87
      _M_first = 0;
williamr@2
    88
      _M_size = 0;
williamr@2
    89
    }
williamr@2
    90
  }
williamr@2
    91
williamr@2
    92
  void _M_deallocate() {
williamr@2
    93
#ifdef __SYMBIAN32__
williamr@2
    94
    delete [] _M_first;
williamr@2
    95
#else
williamr@2
    96
    free(_M_first);
williamr@2
    97
#endif
williamr@2
    98
    _M_first = 0;
williamr@2
    99
    _M_size = 0;
williamr@2
   100
  }
williamr@2
   101
};
williamr@2
   102
williamr@2
   103
template <class _Tp> 
williamr@2
   104
class valarray : private _Valarray_base<_Tp>
williamr@2
   105
{
williamr@2
   106
  friend class gslice;
williamr@2
   107
williamr@2
   108
public:
williamr@2
   109
  typedef _Tp value_type;
williamr@2
   110
williamr@2
   111
  // Basic constructors
williamr@2
   112
  valarray() : _Valarray_base<_Tp>() {}
williamr@2
   113
  valarray(size_t __n) : _Valarray_base<_Tp>(__n) {}
williamr@2
   114
  valarray(const value_type& __x, size_t __n) : _Valarray_base<_Tp>(__n)
williamr@2
   115
    { uninitialized_fill_n(this->_M_first, this->_M_size, __x); }
williamr@2
   116
  valarray(const value_type* __p, size_t __n) : _Valarray_base<_Tp>(__n)
williamr@2
   117
    { uninitialized_copy(__p, __p + __n, this->_M_first); } 
williamr@2
   118
  valarray(const valarray<_Tp>& __x) : _Valarray_base<_Tp>(__x._M_size) {
williamr@2
   119
    uninitialized_copy(__x._M_first, __x._M_first + __x._M_size,
williamr@2
   120
                       this->_M_first);
williamr@2
   121
  }
williamr@2
   122
williamr@2
   123
  // Constructors from auxiliary array types
williamr@2
   124
  valarray(const slice_array<_Tp>&);
williamr@2
   125
  valarray(const gslice_array<_Tp>&);
williamr@2
   126
  valarray(const mask_array<_Tp>&);
williamr@2
   127
  valarray(const indirect_array<_Tp>&);
williamr@2
   128
williamr@2
   129
  // Destructor
williamr@2
   130
  ~valarray() { _STLP_STD::_Destroy(this->_M_first, this->_M_first + this->_M_size); }
williamr@2
   131
williamr@2
   132
  // Extension: constructor that doesn't initialize valarray elements to a
williamr@2
   133
  // specific value.  This is faster for types such as int and double.
williamr@2
   134
private:
williamr@2
   135
  void _M_initialize(const __true_type&) {}
williamr@2
   136
  void _M_initialize(const __false_type&)
williamr@2
   137
    { uninitialized_fill_n(this->_M_first, this->_M_size, value_type()); }
williamr@2
   138
williamr@2
   139
public:
williamr@2
   140
  struct _NoInit {};
williamr@2
   141
  valarray(size_t __n, _NoInit) : _Valarray_base<_Tp>(__n) {
williamr@2
   142
    typedef typename __type_traits<_Tp>::has_trivial_default_constructor _Is_Trivial;
williamr@2
   143
    _M_initialize(_Is_Trivial());
williamr@2
   144
  }
williamr@2
   145
williamr@2
   146
public:                         // Assignment
williamr@2
   147
  // Basic assignment.  Note that 'x = y' is undefined if x.size() != y.size()
williamr@2
   148
  valarray<_Tp>& operator=(const valarray<_Tp>& __x) {
williamr@2
   149
    _STLP_ASSERT(__x.size() == this->size())
williamr@2
   150
    if (this != &__x)
williamr@2
   151
      {
williamr@2
   152
#ifdef __SYMBIAN32__
williamr@2
   153
      resize(__x._M_size);
williamr@2
   154
#endif
williamr@2
   155
      copy(__x._M_first, __x._M_first + __x._M_size, this->_M_first);
williamr@2
   156
      }
williamr@2
   157
    return *this;
williamr@2
   158
  }
williamr@2
   159
williamr@2
   160
  // Scalar assignment
williamr@2
   161
  valarray<_Tp>& operator=(const value_type& __x) {
williamr@2
   162
    fill_n(this->_M_first, this->_M_size, __x);
williamr@2
   163
    return *this;
williamr@2
   164
  }
williamr@2
   165
williamr@2
   166
  // Assignment of auxiliary array types
williamr@2
   167
  valarray<_Tp>& operator=(const slice_array<_Tp>&);
williamr@2
   168
  valarray<_Tp>& operator=(const gslice_array<_Tp>&);
williamr@2
   169
  valarray<_Tp>& operator=(const mask_array<_Tp>&);
williamr@2
   170
  valarray<_Tp>& operator=(const indirect_array<_Tp>&);
williamr@2
   171
williamr@2
   172
public:                         // Element access
williamr@2
   173
  value_type  operator[](size_t __n) const { return this->_M_first[__n]; }
williamr@2
   174
  value_type& operator[](size_t __n)       { return this->_M_first[__n]; }
williamr@2
   175
  size_t size() const { return this->_M_size; }
williamr@2
   176
williamr@2
   177
public:                         // Subsetting operations with auxiliary type
williamr@2
   178
  valarray<_Tp>            operator[](slice) const;
williamr@2
   179
  slice_array<_Tp>    operator[](slice);
williamr@2
   180
  valarray<_Tp>            operator[](gslice) const;
williamr@2
   181
  gslice_array<_Tp>   operator[](const gslice&);  
williamr@2
   182
  valarray<_Tp>            operator[](const _Valarray_bool&) const;
williamr@2
   183
  mask_array<_Tp>     operator[](const _Valarray_bool&);
williamr@2
   184
  valarray<_Tp>            operator[](const _Valarray_size_t&) const;
williamr@2
   185
  indirect_array<_Tp> operator[](const _Valarray_size_t&);
williamr@2
   186
  
williamr@2
   187
public:                         // Unary operators.
williamr@2
   188
  valarray<_Tp> operator+() const { return *this; }
williamr@2
   189
williamr@2
   190
  valarray<_Tp> operator-() const {
williamr@2
   191
    valarray<_Tp> __tmp(this->size(), _NoInit());
williamr@2
   192
    for (size_t __i = 0; __i < this->size(); ++__i)
williamr@2
   193
      __tmp[__i] = -(*this)[__i];
williamr@2
   194
    return __tmp;
williamr@2
   195
  }
williamr@2
   196
  
williamr@2
   197
  valarray<_Tp> operator~() const {
williamr@2
   198
    valarray<_Tp> __tmp(this->size(), _NoInit());
williamr@2
   199
    for (size_t __i = 0; __i < this->size(); ++__i)
williamr@2
   200
      __tmp[__i] = ~(*this)[__i];
williamr@2
   201
    return __tmp;
williamr@2
   202
  }
williamr@2
   203
williamr@2
   204
  _Valarray_bool operator!() const;
williamr@2
   205
williamr@2
   206
public:                         // Scalar computed assignment.
williamr@2
   207
  valarray<_Tp>& operator*= (const value_type& __x) {
williamr@2
   208
    for (size_t __i = 0; __i < this->size(); ++__i)
williamr@2
   209
      (*this)[__i] *= __x;
williamr@2
   210
    return *this;
williamr@2
   211
  }
williamr@2
   212
    
williamr@2
   213
  valarray<_Tp>& operator/= (const value_type& __x) {
williamr@2
   214
    for (size_t __i = 0; __i < this->size(); ++__i)
williamr@2
   215
      (*this)[__i] /= __x;
williamr@2
   216
    return *this;
williamr@2
   217
  }
williamr@2
   218
williamr@2
   219
  valarray<_Tp>& operator%= (const value_type& __x) {
williamr@2
   220
    for (size_t __i = 0; __i < this->size(); ++__i)
williamr@2
   221
      (*this)[__i] %= __x;
williamr@2
   222
    return *this;
williamr@2
   223
  }
williamr@2
   224
williamr@2
   225
  valarray<_Tp>& operator+= (const value_type& __x) {
williamr@2
   226
    for (size_t __i = 0; __i < this->size(); ++__i)
williamr@2
   227
      (*this)[__i] += __x;
williamr@2
   228
    return *this;
williamr@2
   229
  }
williamr@2
   230
williamr@2
   231
  valarray<_Tp>& operator-= (const value_type& __x) {
williamr@2
   232
    for (size_t __i = 0; __i < this->size(); ++__i)
williamr@2
   233
      (*this)[__i] -= __x;
williamr@2
   234
    return *this;
williamr@2
   235
  }
williamr@2
   236
williamr@2
   237
  valarray<_Tp>& operator^= (const value_type& __x) {
williamr@2
   238
    for (size_t __i = 0; __i < this->size(); ++__i)
williamr@2
   239
      (*this)[__i] ^= __x;
williamr@2
   240
    return *this;
williamr@2
   241
  }
williamr@2
   242
williamr@2
   243
  valarray<_Tp>& operator&= (const value_type& __x) {
williamr@2
   244
    for (size_t __i = 0; __i < this->size(); ++__i)
williamr@2
   245
      (*this)[__i] &= __x;
williamr@2
   246
    return *this;
williamr@2
   247
  }
williamr@2
   248
williamr@2
   249
  valarray<_Tp>& operator|= (const value_type& __x) {
williamr@2
   250
    for (size_t __i = 0; __i < this->size(); ++__i)
williamr@2
   251
      (*this)[__i] |= __x;
williamr@2
   252
    return *this;
williamr@2
   253
  }
williamr@2
   254
williamr@2
   255
  valarray<_Tp>& operator<<= (const value_type& __x) {
williamr@2
   256
    for (size_t __i = 0; __i < this->size(); ++__i)
williamr@2
   257
      (*this)[__i] <<= __x;
williamr@2
   258
    return *this;
williamr@2
   259
  }
williamr@2
   260
williamr@2
   261
  valarray<_Tp>& operator>>= (const value_type& __x) {
williamr@2
   262
    for (size_t __i = 0; __i < this->size(); ++__i)
williamr@2
   263
      (*this)[__i] >>= __x;
williamr@2
   264
    return *this;
williamr@2
   265
  }
williamr@2
   266
williamr@2
   267
public:                         // Array computed assignment.
williamr@2
   268
  valarray<_Tp>& operator*= (const valarray<_Tp>& __x) {
williamr@2
   269
    for (size_t __i = 0; __i < this->size(); ++__i)
williamr@2
   270
      (*this)[__i] *= __x[__i];
williamr@2
   271
    return *this;
williamr@2
   272
  }
williamr@2
   273
    
williamr@2
   274
  valarray<_Tp>& operator/= (const valarray<_Tp>& __x) {
williamr@2
   275
    for (size_t __i = 0; __i < this->size(); ++__i)
williamr@2
   276
      (*this)[__i] /= __x[__i];
williamr@2
   277
    return *this;
williamr@2
   278
  }
williamr@2
   279
williamr@2
   280
  valarray<_Tp>& operator%= (const valarray<_Tp>& __x) {
williamr@2
   281
    for (size_t __i = 0; __i < this->size(); ++__i)
williamr@2
   282
      (*this)[__i] %= __x[__i];
williamr@2
   283
    return *this;
williamr@2
   284
  }
williamr@2
   285
williamr@2
   286
  valarray<_Tp>& operator+= (const valarray<_Tp>& __x) {
williamr@2
   287
    for (size_t __i = 0; __i < this->size(); ++__i)
williamr@2
   288
      (*this)[__i] += __x[__i];
williamr@2
   289
    return *this;
williamr@2
   290
  }
williamr@2
   291
williamr@2
   292
  valarray<_Tp>& operator-= (const valarray<_Tp>& __x) {
williamr@2
   293
    for (size_t __i = 0; __i < this->size(); ++__i)
williamr@2
   294
      (*this)[__i] -= __x[__i];
williamr@2
   295
    return *this;
williamr@2
   296
  }
williamr@2
   297
williamr@2
   298
  valarray<_Tp>& operator^= (const valarray<_Tp>& __x) {
williamr@2
   299
    for (size_t __i = 0; __i < this->size(); ++__i)
williamr@2
   300
      (*this)[__i] ^= __x[__i];
williamr@2
   301
    return *this;
williamr@2
   302
  }
williamr@2
   303
williamr@2
   304
  valarray<_Tp>& operator&= (const valarray<_Tp>& __x) {
williamr@2
   305
    for (size_t __i = 0; __i < this->size(); ++__i)
williamr@2
   306
      (*this)[__i] &= __x[__i];
williamr@2
   307
    return *this;
williamr@2
   308
  }
williamr@2
   309
williamr@2
   310
  valarray<_Tp>& operator|= (const valarray<_Tp>& __x) {
williamr@2
   311
    for (size_t __i = 0; __i < this->size(); ++__i)
williamr@2
   312
      (*this)[__i] |= __x[__i];
williamr@2
   313
    return *this;
williamr@2
   314
  }
williamr@2
   315
williamr@2
   316
  valarray<_Tp>& operator<<= (const valarray<_Tp>& __x) {
williamr@2
   317
    for (size_t __i = 0; __i < this->size(); ++__i)
williamr@2
   318
      (*this)[__i] <<= __x[__i];
williamr@2
   319
    return *this;
williamr@2
   320
  }
williamr@2
   321
williamr@2
   322
  valarray<_Tp>& operator>>= (const valarray<_Tp>& __x) {
williamr@2
   323
    for (size_t __i = 0; __i < this->size(); ++__i)
williamr@2
   324
      (*this)[__i] >>= __x[__i];
williamr@2
   325
    return *this;
williamr@2
   326
  }
williamr@2
   327
williamr@2
   328
public:                         // Other member functions.
williamr@2
   329
williamr@2
   330
  // The result is undefined for zero-length arrays
williamr@2
   331
  value_type sum() const {
williamr@2
   332
    return accumulate(this->_M_first + 1, this->_M_first + this->_M_size,
williamr@2
   333
                      (*this)[0]);
williamr@2
   334
  }
williamr@2
   335
williamr@2
   336
  // The result is undefined for zero-length arrays
williamr@2
   337
  value_type (min) () const {
williamr@2
   338
    return *min_element(this->_M_first + 0, this->_M_first + this->_M_size);
williamr@2
   339
  }
williamr@2
   340
williamr@2
   341
  value_type (max) () const {
williamr@2
   342
    return *max_element(this->_M_first + 0, this->_M_first + this->_M_size);
williamr@2
   343
  }
williamr@2
   344
williamr@2
   345
  valarray<_Tp> shift(int __n) const;
williamr@2
   346
  valarray<_Tp> cshift(int __n) const;
williamr@2
   347
williamr@2
   348
  valarray<_Tp> apply(value_type __f(value_type)) const {
williamr@2
   349
    valarray<_Tp> __tmp(this->size());
williamr@2
   350
    transform(this->_M_first + 0, this->_M_first + this->_M_size, __tmp._M_first,
williamr@2
   351
              __f);
williamr@2
   352
    return __tmp;
williamr@2
   353
  }
williamr@2
   354
  valarray<_Tp> apply(value_type __f(const value_type&)) const {
williamr@2
   355
    valarray<_Tp> __tmp(this->size());
williamr@2
   356
    transform(this->_M_first + 0, this->_M_first + this->_M_size, __tmp._M_first,
williamr@2
   357
              __f);
williamr@2
   358
    return __tmp;
williamr@2
   359
  }
williamr@2
   360
  
williamr@2
   361
  void resize(size_t __n, value_type __x = value_type()) {
williamr@2
   362
    _STLP_STD::_Destroy(this->_M_first, this->_M_first + this->_M_size);
williamr@2
   363
    this->_Valarray_base<_Tp>::_M_deallocate();
williamr@2
   364
    this->_Valarray_base<_Tp>::_M_allocate(__n);
williamr@2
   365
    uninitialized_fill_n(this->_M_first, this->_M_size, __x);
williamr@2
   366
  }
williamr@2
   367
};
williamr@2
   368
williamr@2
   369
//----------------------------------------------------------------------
williamr@2
   370
// valarray non-member functions.
williamr@2
   371
williamr@2
   372
// Binary arithmetic operations between two arrays.  Behavior is
williamr@2
   373
// undefined if the two arrays do not have the same length.
williamr@2
   374
williamr@2
   375
template <class _Tp> 
williamr@2
   376
inline valarray<_Tp>  _STLP_CALL operator*(const valarray<_Tp>& __x,
williamr@2
   377
                                           const valarray<_Tp>& __y) {
williamr@2
   378
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   379
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   380
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   381
    __tmp[__i] = __x[__i] * __y[__i];
williamr@2
   382
  return __tmp;
williamr@2
   383
}
williamr@2
   384
williamr@2
   385
template <class _Tp> 
williamr@2
   386
inline valarray<_Tp>  _STLP_CALL operator/(const valarray<_Tp>& __x,
williamr@2
   387
                                           const valarray<_Tp>& __y) {
williamr@2
   388
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   389
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   390
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   391
    __tmp[__i] = __x[__i] / __y[__i];
williamr@2
   392
  return __tmp;
williamr@2
   393
}
williamr@2
   394
williamr@2
   395
template <class _Tp> 
williamr@2
   396
inline valarray<_Tp>  _STLP_CALL operator%(const valarray<_Tp>& __x,
williamr@2
   397
                                           const valarray<_Tp>& __y) {
williamr@2
   398
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   399
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   400
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   401
    __tmp[__i] = __x[__i] % __y[__i];
williamr@2
   402
  return __tmp;
williamr@2
   403
}
williamr@2
   404
williamr@2
   405
template <class _Tp> 
williamr@2
   406
inline valarray<_Tp>  _STLP_CALL operator+(const valarray<_Tp>& __x,
williamr@2
   407
                                           const valarray<_Tp>& __y) {
williamr@2
   408
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   409
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   410
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   411
    __tmp[__i] = __x[__i] + __y[__i];
williamr@2
   412
  return __tmp;
williamr@2
   413
}
williamr@2
   414
williamr@2
   415
template <class _Tp> 
williamr@2
   416
inline valarray<_Tp>  _STLP_CALL operator-(const valarray<_Tp>& __x,
williamr@2
   417
                                           const valarray<_Tp>& __y) {
williamr@2
   418
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   419
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   420
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   421
    __tmp[__i] = __x[__i] - __y[__i];
williamr@2
   422
  return __tmp;
williamr@2
   423
}
williamr@2
   424
williamr@2
   425
template <class _Tp> 
williamr@2
   426
inline valarray<_Tp> _STLP_CALL operator^(const valarray<_Tp>& __x,
williamr@2
   427
                               const valarray<_Tp>& __y) {
williamr@2
   428
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   429
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   430
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   431
    __tmp[__i] = __x[__i] ^ __y[__i];
williamr@2
   432
  return __tmp;
williamr@2
   433
}
williamr@2
   434
williamr@2
   435
template <class _Tp> 
williamr@2
   436
inline valarray<_Tp> _STLP_CALL operator&(const valarray<_Tp>& __x,
williamr@2
   437
                               const valarray<_Tp>& __y) {
williamr@2
   438
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   439
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   440
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   441
    __tmp[__i] = __x[__i] & __y[__i];
williamr@2
   442
  return __tmp;
williamr@2
   443
}
williamr@2
   444
williamr@2
   445
template <class _Tp> 
williamr@2
   446
inline valarray<_Tp> _STLP_CALL operator|(const valarray<_Tp>& __x,
williamr@2
   447
                               const valarray<_Tp>& __y) {
williamr@2
   448
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   449
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   450
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   451
    __tmp[__i] = __x[__i] | __y[__i];
williamr@2
   452
  return __tmp;
williamr@2
   453
}
williamr@2
   454
williamr@2
   455
template <class _Tp> 
williamr@2
   456
inline valarray<_Tp> _STLP_CALL operator<<(const valarray<_Tp>& __x,
williamr@2
   457
                               const valarray<_Tp>& __y) {
williamr@2
   458
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   459
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   460
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   461
    __tmp[__i] = __x[__i] << __y[__i];
williamr@2
   462
  return __tmp;
williamr@2
   463
}
williamr@2
   464
williamr@2
   465
template <class _Tp> 
williamr@2
   466
inline valarray<_Tp> _STLP_CALL operator>>(const valarray<_Tp>& __x,
williamr@2
   467
                               const valarray<_Tp>& __y) {
williamr@2
   468
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   469
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   470
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   471
    __tmp[__i] = __x[__i] >> __y[__i];
williamr@2
   472
  return __tmp;
williamr@2
   473
}
williamr@2
   474
williamr@2
   475
// Binary arithmetic operations between an array and a scalar.
williamr@2
   476
williamr@2
   477
template <class _Tp> 
williamr@2
   478
inline valarray<_Tp> _STLP_CALL operator*(const valarray<_Tp>& __x, const _Tp& __c) {
williamr@2
   479
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   480
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   481
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   482
    __tmp[__i] = __x[__i]  * __c;
williamr@2
   483
  return __tmp;
williamr@2
   484
}
williamr@2
   485
williamr@2
   486
template <class _Tp> 
williamr@2
   487
inline valarray<_Tp> _STLP_CALL operator*(const _Tp& __c, const valarray<_Tp>& __x) {
williamr@2
   488
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   489
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   490
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   491
    __tmp[__i] = __c * __x[__i];
williamr@2
   492
  return __tmp;
williamr@2
   493
}
williamr@2
   494
williamr@2
   495
template <class _Tp> 
williamr@2
   496
inline valarray<_Tp> _STLP_CALL operator/(const valarray<_Tp>& __x, const _Tp& __c) {
williamr@2
   497
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   498
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   499
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   500
    __tmp[__i] = __x[__i]  / __c;
williamr@2
   501
  return __tmp;
williamr@2
   502
}
williamr@2
   503
williamr@2
   504
template <class _Tp> 
williamr@2
   505
inline valarray<_Tp> _STLP_CALL operator/(const _Tp& __c, const valarray<_Tp>& __x) {
williamr@2
   506
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   507
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   508
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   509
    __tmp[__i] = __c / __x[__i];
williamr@2
   510
  return __tmp;
williamr@2
   511
}
williamr@2
   512
williamr@2
   513
template <class _Tp> 
williamr@2
   514
inline valarray<_Tp> _STLP_CALL operator%(const valarray<_Tp>& __x, const _Tp& __c) {
williamr@2
   515
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   516
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   517
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   518
    __tmp[__i] = __x[__i]  % __c;
williamr@2
   519
  return __tmp;
williamr@2
   520
}
williamr@2
   521
williamr@2
   522
template <class _Tp> 
williamr@2
   523
inline valarray<_Tp> _STLP_CALL operator%(const _Tp& __c, const valarray<_Tp>& __x) {
williamr@2
   524
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   525
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   526
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   527
    __tmp[__i] = __c % __x[__i];
williamr@2
   528
  return __tmp;
williamr@2
   529
}
williamr@2
   530
williamr@2
   531
template <class _Tp> 
williamr@2
   532
inline valarray<_Tp> _STLP_CALL operator+(const valarray<_Tp>& __x, const _Tp& __c) {
williamr@2
   533
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   534
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   535
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   536
    __tmp[__i] = __x[__i]  + __c;
williamr@2
   537
  return __tmp;
williamr@2
   538
}
williamr@2
   539
williamr@2
   540
template <class _Tp> 
williamr@2
   541
inline valarray<_Tp> _STLP_CALL operator+(const _Tp& __c, const valarray<_Tp>& __x) {
williamr@2
   542
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   543
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   544
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   545
    __tmp[__i] = __c + __x[__i];
williamr@2
   546
  return __tmp;
williamr@2
   547
}
williamr@2
   548
williamr@2
   549
template <class _Tp> 
williamr@2
   550
inline valarray<_Tp> _STLP_CALL operator-(const valarray<_Tp>& __x, const _Tp& __c) {
williamr@2
   551
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   552
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   553
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   554
    __tmp[__i] = __x[__i]  - __c;
williamr@2
   555
  return __tmp;
williamr@2
   556
}
williamr@2
   557
williamr@2
   558
template <class _Tp> 
williamr@2
   559
inline valarray<_Tp> _STLP_CALL operator-(const _Tp& __c, const valarray<_Tp>& __x) {
williamr@2
   560
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   561
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   562
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   563
    __tmp[__i] = __c - __x[__i];
williamr@2
   564
  return __tmp;
williamr@2
   565
}
williamr@2
   566
williamr@2
   567
template <class _Tp> 
williamr@2
   568
inline valarray<_Tp> _STLP_CALL operator^(const valarray<_Tp>& __x, const _Tp& __c) {
williamr@2
   569
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   570
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   571
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   572
    __tmp[__i] = __x[__i]  ^ __c;
williamr@2
   573
  return __tmp;
williamr@2
   574
}
williamr@2
   575
williamr@2
   576
template <class _Tp> 
williamr@2
   577
inline valarray<_Tp> _STLP_CALL operator^(const _Tp& __c, const valarray<_Tp>& __x) {
williamr@2
   578
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   579
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   580
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   581
    __tmp[__i] = __c ^ __x[__i];
williamr@2
   582
  return __tmp;
williamr@2
   583
}
williamr@2
   584
williamr@2
   585
template <class _Tp> 
williamr@2
   586
inline valarray<_Tp> _STLP_CALL operator&(const valarray<_Tp>& __x, const _Tp& __c) {
williamr@2
   587
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   588
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   589
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   590
    __tmp[__i] = __x[__i]  & __c;
williamr@2
   591
  return __tmp;
williamr@2
   592
}
williamr@2
   593
williamr@2
   594
template <class _Tp> 
williamr@2
   595
inline valarray<_Tp> _STLP_CALL operator&(const _Tp& __c, const valarray<_Tp>& __x) {
williamr@2
   596
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   597
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   598
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   599
    __tmp[__i] = __c & __x[__i];
williamr@2
   600
  return __tmp;
williamr@2
   601
}
williamr@2
   602
williamr@2
   603
template <class _Tp> 
williamr@2
   604
inline valarray<_Tp> _STLP_CALL operator|(const valarray<_Tp>& __x, const _Tp& __c) {
williamr@2
   605
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   606
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   607
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   608
    __tmp[__i] = __x[__i]  | __c;
williamr@2
   609
  return __tmp;
williamr@2
   610
}
williamr@2
   611
williamr@2
   612
template <class _Tp> 
williamr@2
   613
inline valarray<_Tp> _STLP_CALL operator|(const _Tp& __c, const valarray<_Tp>& __x) {
williamr@2
   614
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   615
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   616
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   617
    __tmp[__i] = __c | __x[__i];
williamr@2
   618
  return __tmp;
williamr@2
   619
}
williamr@2
   620
williamr@2
   621
template <class _Tp> 
williamr@2
   622
inline valarray<_Tp> _STLP_CALL operator<<(const valarray<_Tp>& __x, const _Tp& __c) {
williamr@2
   623
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   624
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   625
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   626
    __tmp[__i] = __x[__i]  << __c;
williamr@2
   627
  return __tmp;
williamr@2
   628
}
williamr@2
   629
williamr@2
   630
template <class _Tp> 
williamr@2
   631
inline valarray<_Tp> _STLP_CALL operator<<(const _Tp& __c, const valarray<_Tp>& __x) {
williamr@2
   632
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   633
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   634
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   635
    __tmp[__i] = __c << __x[__i];
williamr@2
   636
  return __tmp;
williamr@2
   637
}
williamr@2
   638
williamr@2
   639
template <class _Tp> 
williamr@2
   640
inline valarray<_Tp> _STLP_CALL operator>>(const valarray<_Tp>& __x, const _Tp& __c) {
williamr@2
   641
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   642
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   643
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   644
    __tmp[__i] = __x[__i]  >> __c;
williamr@2
   645
  return __tmp;
williamr@2
   646
}
williamr@2
   647
williamr@2
   648
template <class _Tp> 
williamr@2
   649
inline valarray<_Tp> _STLP_CALL operator>>(const _Tp& __c, const valarray<_Tp>& __x) {
williamr@2
   650
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   651
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   652
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   653
    __tmp[__i] = __c >> __x[__i];
williamr@2
   654
  return __tmp;
williamr@2
   655
}
williamr@2
   656
williamr@2
   657
// Binary logical operations between two arrays.  Behavior is undefined
williamr@2
   658
// if the two arrays have different lengths.  Note that operator== does
williamr@2
   659
// not do what you might at first expect.
williamr@2
   660
williamr@2
   661
template <class _Tp> 
williamr@2
   662
inline _Valarray_bool _STLP_CALL operator==(const valarray<_Tp>& __x,
williamr@2
   663
                                 const valarray<_Tp>& __y)
williamr@2
   664
{
williamr@2
   665
  _Valarray_bool __tmp(__x.size(), _Valarray_bool::_NoInit());
williamr@2
   666
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   667
    __tmp[__i] = __x[__i] == __y[__i];
williamr@2
   668
  return __tmp;  
williamr@2
   669
}
williamr@2
   670
williamr@2
   671
template <class _Tp> 
williamr@2
   672
inline _Valarray_bool _STLP_CALL operator<(const valarray<_Tp>& __x,
williamr@2
   673
                                const valarray<_Tp>& __y)
williamr@2
   674
{
williamr@2
   675
  _Valarray_bool __tmp(__x.size(), _Valarray_bool::_NoInit());
williamr@2
   676
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   677
    __tmp[__i] = __x[__i] < __y[__i];
williamr@2
   678
  return __tmp;  
williamr@2
   679
}
williamr@2
   680
williamr@2
   681
#ifdef _STLP_USE_SEPARATE_RELOPS_NAMESPACE
williamr@2
   682
williamr@2
   683
template <class _Tp> 
williamr@2
   684
inline _Valarray_bool _STLP_CALL operator!=(const valarray<_Tp>& __x,
williamr@2
   685
                                 const valarray<_Tp>& __y)
williamr@2
   686
{
williamr@2
   687
  _Valarray_bool __tmp(__x.size(), _Valarray_bool::_NoInit());
williamr@2
   688
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   689
    __tmp[__i] = __x[__i] != __y[__i];
williamr@2
   690
  return __tmp;  
williamr@2
   691
}
williamr@2
   692
williamr@2
   693
template <class _Tp> 
williamr@2
   694
inline _Valarray_bool _STLP_CALL operator>(const valarray<_Tp>& __x,
williamr@2
   695
                                const valarray<_Tp>& __y)
williamr@2
   696
{
williamr@2
   697
  _Valarray_bool __tmp(__x.size(), _Valarray_bool::_NoInit());
williamr@2
   698
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   699
    __tmp[__i] = __x[__i] > __y[__i];
williamr@2
   700
  return __tmp;  
williamr@2
   701
}
williamr@2
   702
williamr@2
   703
template <class _Tp> 
williamr@2
   704
inline _Valarray_bool _STLP_CALL operator<=(const valarray<_Tp>& __x,
williamr@2
   705
                                 const valarray<_Tp>& __y)
williamr@2
   706
{
williamr@2
   707
  _Valarray_bool __tmp(__x.size(), _Valarray_bool::_NoInit());
williamr@2
   708
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   709
    __tmp[__i] = __x[__i] <= __y[__i];
williamr@2
   710
  return __tmp;  
williamr@2
   711
}
williamr@2
   712
williamr@2
   713
template <class _Tp> 
williamr@2
   714
inline _Valarray_bool _STLP_CALL operator>=(const valarray<_Tp>& __x,
williamr@2
   715
                                 const valarray<_Tp>& __y)
williamr@2
   716
{
williamr@2
   717
  _Valarray_bool __tmp(__x.size(), _Valarray_bool::_NoInit());
williamr@2
   718
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   719
    __tmp[__i] = __x[__i] >= __y[__i];
williamr@2
   720
  return __tmp;  
williamr@2
   721
}
williamr@2
   722
williamr@2
   723
#endif /* _STLP_USE_SEPARATE_RELOPS_NAMESPACE */
williamr@2
   724
// fbp : swap ?
williamr@2
   725
williamr@2
   726
template <class _Tp> 
williamr@2
   727
inline _Valarray_bool _STLP_CALL operator&&(const valarray<_Tp>& __x,
williamr@2
   728
                                 const valarray<_Tp>& __y)
williamr@2
   729
{
williamr@2
   730
  _Valarray_bool __tmp(__x.size(), _Valarray_bool::_NoInit());
williamr@2
   731
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   732
    __tmp[__i] = __x[__i] && __y[__i];
williamr@2
   733
  return __tmp;  
williamr@2
   734
}
williamr@2
   735
williamr@2
   736
template <class _Tp> 
williamr@2
   737
inline _Valarray_bool _STLP_CALL operator||(const valarray<_Tp>& __x,
williamr@2
   738
                                 const valarray<_Tp>& __y)
williamr@2
   739
{
williamr@2
   740
  _Valarray_bool __tmp(__x.size(), _Valarray_bool::_NoInit());
williamr@2
   741
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   742
    __tmp[__i] = __x[__i] || __y[__i];
williamr@2
   743
  return __tmp;  
williamr@2
   744
}
williamr@2
   745
williamr@2
   746
// Logical operations between an array and a scalar.
williamr@2
   747
williamr@2
   748
template <class _Tp>
williamr@2
   749
inline _Valarray_bool _STLP_CALL operator==(const valarray<_Tp>& __x, const _Tp& __c)
williamr@2
   750
{
williamr@2
   751
  _Valarray_bool __tmp(__x.size(), _Valarray_bool::_NoInit());
williamr@2
   752
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   753
    __tmp[__i] = __x[__i] == __c;
williamr@2
   754
  return __tmp;  
williamr@2
   755
}
williamr@2
   756
williamr@2
   757
template <class _Tp>
williamr@2
   758
inline _Valarray_bool _STLP_CALL operator==(const _Tp& __c, const valarray<_Tp>& __x)
williamr@2
   759
{
williamr@2
   760
  _Valarray_bool __tmp(__x.size(), _Valarray_bool::_NoInit());
williamr@2
   761
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   762
    __tmp[__i] = __c == __x[__i];
williamr@2
   763
  return __tmp;  
williamr@2
   764
}
williamr@2
   765
williamr@2
   766
template <class _Tp>
williamr@2
   767
inline _Valarray_bool _STLP_CALL operator!=(const valarray<_Tp>& __x, const _Tp& __c)
williamr@2
   768
{
williamr@2
   769
  _Valarray_bool __tmp(__x.size(), _Valarray_bool::_NoInit());
williamr@2
   770
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   771
    __tmp[__i] = __x[__i] != __c;
williamr@2
   772
  return __tmp;  
williamr@2
   773
}
williamr@2
   774
williamr@2
   775
template <class _Tp>
williamr@2
   776
inline _Valarray_bool _STLP_CALL operator!=(const _Tp& __c, const valarray<_Tp>& __x)
williamr@2
   777
{
williamr@2
   778
  _Valarray_bool __tmp(__x.size(), _Valarray_bool::_NoInit());
williamr@2
   779
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   780
    __tmp[__i] = __c != __x[__i];
williamr@2
   781
  return __tmp;  
williamr@2
   782
}
williamr@2
   783
williamr@2
   784
template <class _Tp>
williamr@2
   785
inline _Valarray_bool _STLP_CALL operator<(const valarray<_Tp>& __x, const _Tp& __c)
williamr@2
   786
{
williamr@2
   787
  _Valarray_bool __tmp(__x.size(), _Valarray_bool::_NoInit());
williamr@2
   788
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   789
    __tmp[__i] = __x[__i] < __c;
williamr@2
   790
  return __tmp;  
williamr@2
   791
}
williamr@2
   792
williamr@2
   793
template <class _Tp>
williamr@2
   794
inline _Valarray_bool _STLP_CALL operator<(const _Tp& __c, const valarray<_Tp>& __x)
williamr@2
   795
{
williamr@2
   796
  _Valarray_bool __tmp(__x.size(), _Valarray_bool::_NoInit());
williamr@2
   797
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   798
    __tmp[__i] = __c < __x[__i];
williamr@2
   799
  return __tmp;  
williamr@2
   800
}
williamr@2
   801
williamr@2
   802
template <class _Tp>
williamr@2
   803
inline _Valarray_bool _STLP_CALL operator>(const valarray<_Tp>& __x, const _Tp& __c)
williamr@2
   804
{
williamr@2
   805
  _Valarray_bool __tmp(__x.size(), _Valarray_bool::_NoInit());
williamr@2
   806
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   807
    __tmp[__i] = __x[__i] > __c;
williamr@2
   808
  return __tmp;  
williamr@2
   809
}
williamr@2
   810
williamr@2
   811
template <class _Tp>
williamr@2
   812
inline _Valarray_bool _STLP_CALL operator>(const _Tp& __c, const valarray<_Tp>& __x)
williamr@2
   813
{
williamr@2
   814
  _Valarray_bool __tmp(__x.size(), _Valarray_bool::_NoInit());
williamr@2
   815
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   816
    __tmp[__i] = __c > __x[__i];
williamr@2
   817
  return __tmp;  
williamr@2
   818
}
williamr@2
   819
williamr@2
   820
template <class _Tp>
williamr@2
   821
inline _Valarray_bool _STLP_CALL operator<=(const valarray<_Tp>& __x, const _Tp& __c)
williamr@2
   822
{
williamr@2
   823
  _Valarray_bool __tmp(__x.size(), _Valarray_bool::_NoInit());
williamr@2
   824
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   825
    __tmp[__i] = __x[__i]  <= __c;
williamr@2
   826
  return __tmp;  
williamr@2
   827
}
williamr@2
   828
williamr@2
   829
template <class _Tp>
williamr@2
   830
inline _Valarray_bool _STLP_CALL operator<=(const _Tp& __c, const valarray<_Tp>& __x)
williamr@2
   831
{
williamr@2
   832
  _Valarray_bool __tmp(__x.size(), _Valarray_bool::_NoInit());
williamr@2
   833
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   834
    __tmp[__i] = __c <= __x[__i];
williamr@2
   835
  return __tmp;  
williamr@2
   836
}
williamr@2
   837
williamr@2
   838
template <class _Tp>
williamr@2
   839
inline _Valarray_bool _STLP_CALL operator>=(const valarray<_Tp>& __x, const _Tp& __c)
williamr@2
   840
{
williamr@2
   841
  _Valarray_bool __tmp(__x.size(), _Valarray_bool::_NoInit());
williamr@2
   842
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   843
    __tmp[__i] = __x[__i] >= __c;
williamr@2
   844
  return __tmp;  
williamr@2
   845
}
williamr@2
   846
williamr@2
   847
template <class _Tp>
williamr@2
   848
inline _Valarray_bool _STLP_CALL operator>=(const _Tp& __c, const valarray<_Tp>& __x)
williamr@2
   849
{
williamr@2
   850
  _Valarray_bool __tmp(__x.size(), _Valarray_bool::_NoInit());
williamr@2
   851
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   852
    __tmp[__i] = __c >= __x[__i];
williamr@2
   853
  return __tmp;  
williamr@2
   854
}
williamr@2
   855
williamr@2
   856
template <class _Tp>
williamr@2
   857
inline _Valarray_bool _STLP_CALL operator&&(const valarray<_Tp>& __x, const _Tp& __c)
williamr@2
   858
{
williamr@2
   859
  _Valarray_bool __tmp(__x.size(), _Valarray_bool::_NoInit());
williamr@2
   860
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   861
    __tmp[__i] = __x[__i] && __c;
williamr@2
   862
  return __tmp;  
williamr@2
   863
}
williamr@2
   864
williamr@2
   865
template <class _Tp>
williamr@2
   866
inline _Valarray_bool _STLP_CALL operator&&(const _Tp& __c, const valarray<_Tp>& __x)
williamr@2
   867
{
williamr@2
   868
  _Valarray_bool __tmp(__x.size(), _Valarray_bool::_NoInit());
williamr@2
   869
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   870
    __tmp[__i] = __c && __x[__i];
williamr@2
   871
  return __tmp;  
williamr@2
   872
}
williamr@2
   873
williamr@2
   874
template <class _Tp>
williamr@2
   875
inline _Valarray_bool _STLP_CALL operator||(const valarray<_Tp>& __x, const _Tp& __c)
williamr@2
   876
{
williamr@2
   877
  _Valarray_bool __tmp(__x.size(), _Valarray_bool::_NoInit());
williamr@2
   878
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   879
    __tmp[__i] = __x[__i] || __c;
williamr@2
   880
  return __tmp;  
williamr@2
   881
}
williamr@2
   882
williamr@2
   883
template <class _Tp>
williamr@2
   884
inline _Valarray_bool _STLP_CALL operator||(const _Tp& __c, const valarray<_Tp>& __x)
williamr@2
   885
{
williamr@2
   886
  _Valarray_bool __tmp(__x.size(), _Valarray_bool::_NoInit());
williamr@2
   887
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   888
    __tmp[__i] = __c || __x[__i];
williamr@2
   889
  return __tmp;  
williamr@2
   890
}
williamr@2
   891
williamr@2
   892
// valarray "transcendentals" (the list includes abs and sqrt, which,
williamr@2
   893
// of course, are not transcendental).
williamr@2
   894
williamr@2
   895
template <class _Tp>
williamr@2
   896
inline valarray<_Tp> abs(const valarray<_Tp>& __x) {
williamr@2
   897
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   898
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   899
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   900
    __tmp[__i] = _STLP_DO_ABS(_Tp)(__x[__i]);
williamr@2
   901
  return __tmp;
williamr@2
   902
}
williamr@2
   903
williamr@2
   904
template <class _Tp>
williamr@2
   905
inline valarray<_Tp> acos(const valarray<_Tp>& __x) {
williamr@2
   906
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   907
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   908
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   909
    __tmp[__i] = _STLP_DO_ACOS(_Tp)(__x[__i]);
williamr@2
   910
  return __tmp;
williamr@2
   911
}
williamr@2
   912
williamr@2
   913
template <class _Tp>
williamr@2
   914
inline valarray<_Tp> asin(const valarray<_Tp>& __x) {
williamr@2
   915
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   916
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   917
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   918
    __tmp[__i] = _STLP_DO_ASIN(_Tp)(__x[__i]);
williamr@2
   919
  return __tmp;
williamr@2
   920
}
williamr@2
   921
williamr@2
   922
template <class _Tp>
williamr@2
   923
inline valarray<_Tp> atan(const valarray<_Tp>& __x) {
williamr@2
   924
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   925
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   926
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   927
    __tmp[__i] = _STLP_DO_ATAN(_Tp)(__x[__i]);
williamr@2
   928
  return __tmp;
williamr@2
   929
}
williamr@2
   930
williamr@2
   931
template <class _Tp>
williamr@2
   932
inline valarray<_Tp> atan2(const valarray<_Tp>& __x,
williamr@2
   933
                           const valarray<_Tp>& __y) {
williamr@2
   934
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   935
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   936
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   937
    __tmp[__i] = _STLP_DO_ATAN2(_Tp)(__x[__i], __y[__i]);
williamr@2
   938
  return __tmp;
williamr@2
   939
}
williamr@2
   940
williamr@2
   941
template <class _Tp>
williamr@2
   942
inline valarray<_Tp> atan2(const valarray<_Tp>& __x, const _Tp& __c) {
williamr@2
   943
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   944
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   945
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   946
    __tmp[__i] = _STLP_DO_ATAN2(_Tp)(__x[__i], __c);
williamr@2
   947
  return __tmp;
williamr@2
   948
}
williamr@2
   949
williamr@2
   950
template <class _Tp>
williamr@2
   951
inline valarray<_Tp> atan2(const _Tp& __c, const valarray<_Tp>& __x) {
williamr@2
   952
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   953
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   954
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   955
    __tmp[__i] = _STLP_DO_ATAN2(_Tp)(__c, __x[__i]);
williamr@2
   956
  return __tmp;
williamr@2
   957
}
williamr@2
   958
williamr@2
   959
template <class _Tp>
williamr@2
   960
inline valarray<_Tp> cos(const valarray<_Tp>& __x) {
williamr@2
   961
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   962
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   963
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   964
    __tmp[__i] = _STLP_DO_COS(_Tp)(__x[__i]);
williamr@2
   965
  return __tmp;
williamr@2
   966
}
williamr@2
   967
williamr@2
   968
template <class _Tp>
williamr@2
   969
inline valarray<_Tp> cosh(const valarray<_Tp>& __x) {
williamr@2
   970
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   971
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   972
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   973
    __tmp[__i] = _STLP_DO_COSH(_Tp)(__x[__i]);
williamr@2
   974
  return __tmp;
williamr@2
   975
}
williamr@2
   976
williamr@2
   977
template <class _Tp>
williamr@2
   978
inline valarray<_Tp> exp(const valarray<_Tp>& __x) {
williamr@2
   979
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   980
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   981
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   982
    __tmp[__i] = _STLP_DO_EXP(_Tp)(__x[__i]);
williamr@2
   983
  return __tmp;
williamr@2
   984
}
williamr@2
   985
williamr@2
   986
template <class _Tp>
williamr@2
   987
inline valarray<_Tp> log(const valarray<_Tp>& __x) {
williamr@2
   988
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   989
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   990
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
   991
    __tmp[__i] = _STLP_DO_LOG(_Tp)(__x[__i]);
williamr@2
   992
  return __tmp;
williamr@2
   993
}
williamr@2
   994
williamr@2
   995
template <class _Tp>
williamr@2
   996
inline valarray<_Tp> log10(const valarray<_Tp>& __x) {
williamr@2
   997
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
   998
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
   999
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
  1000
    __tmp[__i] = _STLP_DO_LOG10(_Tp)(__x[__i]);
williamr@2
  1001
  return __tmp;
williamr@2
  1002
}
williamr@2
  1003
williamr@2
  1004
template <class _Tp>
williamr@2
  1005
inline valarray<_Tp> pow(const valarray<_Tp>& __x,
williamr@2
  1006
                           const valarray<_Tp>& __y) {
williamr@2
  1007
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
  1008
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
  1009
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
  1010
    __tmp[__i] = _STLP_DO_POW(_Tp)(__x[__i], __y[__i]);
williamr@2
  1011
  return __tmp;
williamr@2
  1012
}
williamr@2
  1013
williamr@2
  1014
template <class _Tp>
williamr@2
  1015
inline valarray<_Tp> pow(const valarray<_Tp>& __x, const _Tp& __c) {
williamr@2
  1016
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
  1017
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
  1018
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
  1019
    __tmp[__i] = _STLP_DO_POW(_Tp)(__x[__i], __c);
williamr@2
  1020
  return __tmp;
williamr@2
  1021
}
williamr@2
  1022
williamr@2
  1023
template <class _Tp>
williamr@2
  1024
inline valarray<_Tp> pow(const _Tp& __c, const valarray<_Tp>& __x) {
williamr@2
  1025
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
  1026
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
  1027
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
  1028
    __tmp[__i] = _STLP_DO_POW(_Tp)(__c, __x[__i]);
williamr@2
  1029
  return __tmp;
williamr@2
  1030
}
williamr@2
  1031
williamr@2
  1032
template <class _Tp>
williamr@2
  1033
inline valarray<_Tp> sin(const valarray<_Tp>& __x) {
williamr@2
  1034
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
  1035
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
  1036
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
  1037
    __tmp[__i] = _STLP_DO_SIN(_Tp)(__x[__i]);
williamr@2
  1038
  return __tmp;
williamr@2
  1039
}
williamr@2
  1040
williamr@2
  1041
template <class _Tp>
williamr@2
  1042
inline valarray<_Tp> sinh(const valarray<_Tp>& __x) {
williamr@2
  1043
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
  1044
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
  1045
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
  1046
    __tmp[__i] = _STLP_DO_SINH(_Tp)(__x[__i]);
williamr@2
  1047
  return __tmp;
williamr@2
  1048
}
williamr@2
  1049
williamr@2
  1050
template <class _Tp>
williamr@2
  1051
inline valarray<_Tp> sqrt(const valarray<_Tp>& __x) {
williamr@2
  1052
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
  1053
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
  1054
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
  1055
    __tmp[__i] = _STLP_DO_SQRT(_Tp)(__x[__i]);
williamr@2
  1056
  return __tmp;
williamr@2
  1057
}
williamr@2
  1058
williamr@2
  1059
template <class _Tp>
williamr@2
  1060
inline valarray<_Tp> tan(const valarray<_Tp>& __x) {
williamr@2
  1061
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
  1062
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
  1063
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
  1064
    __tmp[__i] = _STLP_DO_TAN(_Tp)(__x[__i]);
williamr@2
  1065
  return __tmp;
williamr@2
  1066
}
williamr@2
  1067
williamr@2
  1068
template <class _Tp>
williamr@2
  1069
inline valarray<_Tp> tanh(const valarray<_Tp>& __x) {
williamr@2
  1070
  typedef typename valarray<_Tp>::_NoInit _NoInit;
williamr@2
  1071
  valarray<_Tp> __tmp(__x.size(), _NoInit());
williamr@2
  1072
  for (size_t __i = 0; __i < __x.size(); ++__i)
williamr@2
  1073
    __tmp[__i] = _STLP_DO_TANH(_Tp)(__x[__i]);
williamr@2
  1074
  return __tmp;
williamr@2
  1075
}
williamr@2
  1076
williamr@2
  1077
//----------------------------------------------------------------------
williamr@2
  1078
// slice and slice_array
williamr@2
  1079
williamr@2
  1080
class slice {
williamr@2
  1081
public:
williamr@2
  1082
  slice() : _M_start(0), _M_length(0), _M_stride(0) {}
williamr@2
  1083
  slice(size_t __start, size_t __length, size_t __stride)
williamr@2
  1084
    : _M_start(__start), _M_length(__length), _M_stride(__stride)
williamr@2
  1085
    {}
williamr@2
  1086
  __TRIVIAL_DESTRUCTOR(slice)
williamr@2
  1087
williamr@2
  1088
  size_t start()  const { return _M_start; }
williamr@2
  1089
  size_t size()   const { return _M_length; }
williamr@2
  1090
  size_t stride() const { return _M_stride; }
williamr@2
  1091
williamr@2
  1092
   
williamr@2
  1093
private:
williamr@2
  1094
  size_t _M_start;
williamr@2
  1095
  size_t _M_length;
williamr@2
  1096
  size_t _M_stride;
williamr@2
  1097
};
williamr@2
  1098
williamr@2
  1099
template <class _Tp>
williamr@2
  1100
class slice_array {
williamr@2
  1101
  friend class valarray<_Tp>;
williamr@2
  1102
public:
williamr@2
  1103
  typedef _Tp value_type;
williamr@2
  1104
williamr@2
  1105
  void operator=(const valarray<value_type>& __x) const {
williamr@2
  1106
    size_t __index = _M_slice.start();
williamr@2
  1107
    for (size_t __i = 0;
williamr@2
  1108
         __i < _M_slice.size();
williamr@2
  1109
         ++__i, __index += _M_slice.stride())
williamr@2
  1110
#ifdef __SYMBIAN32__
williamr@2
  1111
      (*_M_array)[__index] = __x[__i];
williamr@2
  1112
#else
williamr@2
  1113
      _M_array[__index] = __x[__i];
williamr@2
  1114
#endif
williamr@2
  1115
  }
williamr@2
  1116
williamr@2
  1117
  void operator*=(const valarray<value_type>& __x) const {
williamr@2
  1118
    size_t __index = _M_slice.start();
williamr@2
  1119
    for (size_t __i = 0;
williamr@2
  1120
         __i < _M_slice.size();
williamr@2
  1121
         ++__i, __index += _M_slice.stride())
williamr@2
  1122
#ifdef __SYMBIAN32__
williamr@2
  1123
        (*_M_array)[__index] *= __x[__i];
williamr@2
  1124
#else
williamr@2
  1125
        _M_array[__index] *= __x[__i];
williamr@2
  1126
#endif
williamr@2
  1127
  }
williamr@2
  1128
williamr@2
  1129
  void operator/=(const valarray<value_type>& __x) const {
williamr@2
  1130
    size_t __index = _M_slice.start();
williamr@2
  1131
    for (size_t __i = 0;
williamr@2
  1132
         __i < _M_slice.size();
williamr@2
  1133
         ++__i, __index += _M_slice.stride())
williamr@2
  1134
#ifdef __SYMBIAN32__
williamr@2
  1135
      (*_M_array)[__index] /= __x[__i];
williamr@2
  1136
#else
williamr@2
  1137
      _M_array[__index] /= __x[__i];
williamr@2
  1138
#endif
williamr@2
  1139
  }
williamr@2
  1140
williamr@2
  1141
  void operator%=(const valarray<value_type>& __x) const {
williamr@2
  1142
    size_t __index = _M_slice.start();
williamr@2
  1143
    for (size_t __i = 0;
williamr@2
  1144
         __i < _M_slice.size();
williamr@2
  1145
         ++__i, __index += _M_slice.stride())
williamr@2
  1146
#ifdef __SYMBIAN32__
williamr@2
  1147
      (*_M_array)[__index] %= __x[__i];
williamr@2
  1148
#else
williamr@2
  1149
      _M_array[__index] %= __x[__i];
williamr@2
  1150
#endif
williamr@2
  1151
  }
williamr@2
  1152
williamr@2
  1153
  void operator+=(const valarray<value_type>& __x) const {
williamr@2
  1154
    size_t __index = _M_slice.start();
williamr@2
  1155
    for (size_t __i = 0;
williamr@2
  1156
         __i < _M_slice.size();
williamr@2
  1157
         ++__i, __index += _M_slice.stride())
williamr@2
  1158
#ifdef __SYMBIAN32__
williamr@2
  1159
      (*_M_array)[__index] += __x[__i];
williamr@2
  1160
#else
williamr@2
  1161
      _M_array[__index] += __x[__i];
williamr@2
  1162
#endif
williamr@2
  1163
  }
williamr@2
  1164
williamr@2
  1165
  void operator-=(const valarray<value_type>& __x) const {
williamr@2
  1166
    size_t __index = _M_slice.start();
williamr@2
  1167
    for (size_t __i = 0;
williamr@2
  1168
         __i < _M_slice.size();
williamr@2
  1169
         ++__i, __index += _M_slice.stride())
williamr@2
  1170
#ifdef __SYMBIAN32__
williamr@2
  1171
      (*_M_array)[__index] -= __x[__i];
williamr@2
  1172
#else
williamr@2
  1173
      _M_array[__index] -= __x[__i];
williamr@2
  1174
#endif
williamr@2
  1175
  }
williamr@2
  1176
williamr@2
  1177
  void operator^=(const valarray<value_type>& __x) const {
williamr@2
  1178
    size_t __index = _M_slice.start();
williamr@2
  1179
    for (size_t __i = 0;
williamr@2
  1180
         __i < _M_slice.size();
williamr@2
  1181
         ++__i, __index += _M_slice.stride())
williamr@2
  1182
#ifdef __SYMBIAN32__
williamr@2
  1183
      (*_M_array)[__index] ^= __x[__i];
williamr@2
  1184
#else
williamr@2
  1185
      _M_array[__index] ^= __x[__i];
williamr@2
  1186
#endif
williamr@2
  1187
  }
williamr@2
  1188
williamr@2
  1189
  void operator&=(const valarray<value_type>& __x) const {
williamr@2
  1190
    size_t __index = _M_slice.start();
williamr@2
  1191
    for (size_t __i = 0;
williamr@2
  1192
         __i < _M_slice.size();
williamr@2
  1193
         ++__i, __index += _M_slice.stride())
williamr@2
  1194
#ifdef __SYMBIAN32__
williamr@2
  1195
      (*_M_array)[__index] &= __x[__i];
williamr@2
  1196
#else
williamr@2
  1197
      _M_array[__index] &= __x[__i];
williamr@2
  1198
#endif
williamr@2
  1199
  }
williamr@2
  1200
williamr@2
  1201
  void operator|=(const valarray<value_type>& __x) const {
williamr@2
  1202
    size_t __index = _M_slice.start();
williamr@2
  1203
    for (size_t __i = 0;
williamr@2
  1204
         __i < _M_slice.size();
williamr@2
  1205
         ++__i, __index += _M_slice.stride())
williamr@2
  1206
#ifdef __SYMBIAN32__
williamr@2
  1207
      (*_M_array)[__index] |= __x[__i];
williamr@2
  1208
#else
williamr@2
  1209
      _M_array[__index] |= __x[__i];
williamr@2
  1210
#endif
williamr@2
  1211
  }
williamr@2
  1212
williamr@2
  1213
  void operator<<=(const valarray<value_type>& __x) const {
williamr@2
  1214
    size_t __index = _M_slice.start();
williamr@2
  1215
    for (size_t __i = 0;
williamr@2
  1216
         __i < _M_slice.size();
williamr@2
  1217
         ++__i, __index += _M_slice.stride())
williamr@2
  1218
#ifdef __SYMBIAN32__
williamr@2
  1219
      (*_M_array)[__index] <<= __x[__i];
williamr@2
  1220
#else
williamr@2
  1221
      _M_array[__index] <<= __x[__i];
williamr@2
  1222
#endif
williamr@2
  1223
  }
williamr@2
  1224
williamr@2
  1225
  void operator>>=(const valarray<value_type>& __x) const {
williamr@2
  1226
    size_t __index = _M_slice.start();
williamr@2
  1227
    for (size_t __i = 0;
williamr@2
  1228
         __i < _M_slice.size();
williamr@2
  1229
         ++__i, __index += _M_slice.stride())
williamr@2
  1230
#ifdef __SYMBIAN32__
williamr@2
  1231
      (*_M_array)[__index] >>= __x[__i];
williamr@2
  1232
#else
williamr@2
  1233
      _M_array[__index] >>= __x[__i];
williamr@2
  1234
#endif
williamr@2
  1235
  }
williamr@2
  1236
williamr@2
  1237
  void operator=(const value_type& __c) {
williamr@2
  1238
    size_t __index = _M_slice.start();
williamr@2
  1239
    for (size_t __i = 0;
williamr@2
  1240
         __i < _M_slice.size();
williamr@2
  1241
         ++__i, __index += _M_slice.stride())
williamr@2
  1242
#ifdef __SYMBIAN32__
williamr@2
  1243
      (*_M_array)[__index] = __c;
williamr@2
  1244
#else
williamr@2
  1245
      _M_array[__index] = __c;
williamr@2
  1246
#endif
williamr@2
  1247
  }
williamr@2
  1248
  
williamr@2
  1249
  slice_array<_Tp>&
williamr@2
  1250
    operator=(const slice_array<_Tp>& __a)
williamr@2
  1251
    {
williamr@2
  1252
    size_t __index = _M_slice.start();
williamr@2
  1253
    for (size_t __i = __a._M_slice.start();
williamr@2
  1254
         __i < _M_slice.size();
williamr@2
  1255
         __i += __a._M_slice.stride(), __index += _M_slice.stride())
williamr@2
  1256
      _M_array[__index] = __a._M_array[__index][__i];
williamr@2
  1257
    return *this;
williamr@2
  1258
    }
williamr@2
  1259
williamr@2
  1260
    slice_array(const slice_array<_Tp>& a)
williamr@2
  1261
      : _M_slice(a._M_slice), _M_array(a._M_array){}
williamr@2
  1262
williamr@2
  1263
  ~slice_array() {}
williamr@2
  1264
williamr@2
  1265
private:
williamr@2
  1266
  slice_array(const slice& __slice, valarray<_Tp>* __array)
williamr@2
  1267
    : _M_slice(__slice), _M_array(__array)
williamr@2
  1268
    {}
williamr@2
  1269
williamr@2
  1270
  slice          _M_slice;
williamr@2
  1271
  valarray<_Tp>* _M_array;
williamr@2
  1272
williamr@2
  1273
private:                        // Disable assignment and default constructor
williamr@2
  1274
  slice_array();
williamr@2
  1275
};
williamr@2
  1276
williamr@2
  1277
// valarray member functions dealing with slice and slice_array
williamr@2
  1278
williamr@2
  1279
template <class _Tp>
williamr@2
  1280
inline valarray<_Tp>::valarray(const slice_array<_Tp>& __x)
williamr@2
  1281
  : _Valarray_base<_Tp>(__x._M_slice.size())
williamr@2
  1282
{
williamr@2
  1283
  typedef typename __type_traits<_Tp>::has_trivial_default_constructor
williamr@2
  1284
          _Is_Trivial;
williamr@2
  1285
  _M_initialize(_Is_Trivial());  
williamr@2
  1286
  *this = __x;
williamr@2
  1287
}
williamr@2
  1288
williamr@2
  1289
williamr@2
  1290
template <class _Tp>
williamr@2
  1291
inline slice_array<_Tp> valarray<_Tp>::operator[](slice __slice) {
williamr@2
  1292
  return slice_array<_Tp>(__slice, this);
williamr@2
  1293
}
williamr@2
  1294
williamr@2
  1295
//----------------------------------------------------------------------
williamr@2
  1296
// gslice and gslice_array
williamr@2
  1297
williamr@2
  1298
template <class _Size>
williamr@2
  1299
struct _Gslice_Iter_tmpl;
williamr@2
  1300
williamr@2
  1301
class gslice {
williamr@2
  1302
  friend struct _Gslice_Iter_tmpl<size_t>;
williamr@2
  1303
public:
williamr@2
  1304
  gslice() : _M_start(0), _M_lengths(0), _M_strides(0) {}
williamr@2
  1305
  gslice(size_t __start,
williamr@2
  1306
         const _Valarray_size_t& __lengths, const _Valarray_size_t& __strides)
williamr@2
  1307
    : _M_start(__start), _M_lengths(__lengths), _M_strides(__strides)
williamr@2
  1308
    {}
williamr@2
  1309
  __TRIVIAL_DESTRUCTOR(gslice)
williamr@2
  1310
williamr@2
  1311
  size_t start()            const { return _M_start; }
williamr@2
  1312
  _Valarray_size_t size()   const { return _M_lengths; }
williamr@2
  1313
  _Valarray_size_t stride() const { return _M_strides; }
williamr@2
  1314
williamr@2
  1315
  // Extension: check for an empty gslice.
williamr@2
  1316
  bool _M_empty() const { return _M_lengths.size() == 0; }
williamr@2
  1317
williamr@2
  1318
  // Extension: number of indices this gslice represents.  (For a degenerate
williamr@2
  1319
  // gslice, they're not necessarily all distinct.)
williamr@2
  1320
  size_t _M_size() const {
williamr@2
  1321
    return !this->_M_empty()
williamr@2
  1322
      ? accumulate(_M_lengths._M_first + 1,
williamr@2
  1323
                   _M_lengths._M_first + _M_lengths._M_size,
williamr@2
  1324
                   _M_lengths[0],
williamr@2
  1325
                   multiplies<size_t>())
williamr@2
  1326
      : 0;
williamr@2
  1327
  }
williamr@2
  1328
williamr@2
  1329
# ifndef __HP_aCC
williamr@2
  1330
private:
williamr@2
  1331
# endif
williamr@2
  1332
williamr@2
  1333
  size_t _M_start;
williamr@2
  1334
  _Valarray_size_t _M_lengths;
williamr@2
  1335
  _Valarray_size_t _M_strides;
williamr@2
  1336
};
williamr@2
  1337
williamr@2
  1338
// This is not an STL iterator.  It is constructed from a gslice, and it
williamr@2
  1339
// steps through the gslice indices in sequence.  See 23.3.6 of the C++
williamr@2
  1340
// standard, paragraphs 2-3, for an explanation of the sequence.  At
williamr@2
  1341
// each step we get two things: the ordinal (i.e. number of steps taken),
williamr@2
  1342
// and the one-dimensional index.
williamr@2
  1343
williamr@2
  1344
template <class _Size>
williamr@2
  1345
struct _Gslice_Iter_tmpl {
williamr@2
  1346
  _Gslice_Iter_tmpl(const gslice& __gslice)
williamr@2
  1347
    : _M_step(0), _M_1d_idx(__gslice.start()),
williamr@2
  1348
      _M_indices(size_t(0), __gslice._M_lengths.size()),
williamr@2
  1349
      _M_gslice(__gslice)
williamr@2
  1350
    {}
williamr@2
  1351
    
williamr@2
  1352
  bool _M_done() const { return _M_indices[0] == _M_gslice._M_lengths[0]; }
williamr@2
  1353
williamr@2
  1354
  bool _M_incr();
williamr@2
  1355
williamr@2
  1356
  _Size _M_step;
williamr@2
  1357
  _Size _M_1d_idx;
williamr@2
  1358
williamr@2
  1359
  valarray<_Size> _M_indices;
williamr@2
  1360
  const gslice& _M_gslice;
williamr@2
  1361
};
williamr@2
  1362
williamr@2
  1363
typedef _Gslice_Iter_tmpl<size_t> _Gslice_Iter;
williamr@2
  1364
williamr@2
  1365
template <class _Tp>
williamr@2
  1366
class gslice_array {
williamr@2
  1367
  friend class valarray<_Tp>;
williamr@2
  1368
public:
williamr@2
  1369
  typedef _Tp value_type;
williamr@2
  1370
williamr@2
  1371
  void operator= (const valarray<value_type>& __x) const {
williamr@2
  1372
    if (!_M_gslice._M_empty()) {
williamr@2
  1373
      _Gslice_Iter __i(_M_gslice);
williamr@2
  1374
      do _M_array[__i._M_1d_idx] = __x[__i._M_step]; while(__i._M_incr());
williamr@2
  1375
    }
williamr@2
  1376
  }
williamr@2
  1377
williamr@2
  1378
  void operator*= (const valarray<value_type>& __x) const {
williamr@2
  1379
    if (!_M_gslice._M_empty()) {
williamr@2
  1380
      _Gslice_Iter __i(_M_gslice);
williamr@2
  1381
      do _M_array[__i._M_1d_idx] *= __x[__i._M_step]; while(__i._M_incr());
williamr@2
  1382
    }
williamr@2
  1383
  }
williamr@2
  1384
williamr@2
  1385
  void operator/= (const valarray<value_type>& __x) const {
williamr@2
  1386
    if (!_M_gslice._M_empty()) {
williamr@2
  1387
      _Gslice_Iter __i(_M_gslice);
williamr@2
  1388
      do _M_array[__i._M_1d_idx] /= __x[__i._M_step]; while(__i._M_incr());
williamr@2
  1389
    }
williamr@2
  1390
  }
williamr@2
  1391
williamr@2
  1392
  void operator%= (const valarray<value_type>& __x) const {
williamr@2
  1393
    if (!_M_gslice._M_empty()) {
williamr@2
  1394
      _Gslice_Iter __i(_M_gslice);
williamr@2
  1395
      do _M_array[__i._M_1d_idx] %= __x[__i._M_step]; while(__i._M_incr());
williamr@2
  1396
    }
williamr@2
  1397
  }
williamr@2
  1398
williamr@2
  1399
  void operator+= (const valarray<value_type>& __x) const {
williamr@2
  1400
    if (!_M_gslice._M_empty()) {
williamr@2
  1401
      _Gslice_Iter __i(_M_gslice);
williamr@2
  1402
      do _M_array[__i._M_1d_idx] += __x[__i._M_step]; while(__i._M_incr());
williamr@2
  1403
    }
williamr@2
  1404
  }
williamr@2
  1405
williamr@2
  1406
  void operator-= (const valarray<value_type>& __x) const {
williamr@2
  1407
    if (!_M_gslice._M_empty()) {
williamr@2
  1408
      _Gslice_Iter __i(_M_gslice);
williamr@2
  1409
      do _M_array[__i._M_1d_idx] -= __x[__i._M_step]; while(__i._M_incr());
williamr@2
  1410
    }
williamr@2
  1411
  }
williamr@2
  1412
williamr@2
  1413
  void operator^= (const valarray<value_type>& __x) const {
williamr@2
  1414
    if (!_M_gslice._M_empty()) {
williamr@2
  1415
      _Gslice_Iter __i(_M_gslice);
williamr@2
  1416
      do _M_array[__i._M_1d_idx] ^= __x[__i._M_step]; while(__i._M_incr());
williamr@2
  1417
    }
williamr@2
  1418
  }
williamr@2
  1419
williamr@2
  1420
  void operator&= (const valarray<value_type>& __x) const {
williamr@2
  1421
    if (!_M_gslice._M_empty()) {
williamr@2
  1422
      _Gslice_Iter __i(_M_gslice);
williamr@2
  1423
      do _M_array[__i._M_1d_idx] &= __x[__i._M_step]; while(__i._M_incr());
williamr@2
  1424
    }
williamr@2
  1425
  }
williamr@2
  1426
williamr@2
  1427
  void operator|= (const valarray<value_type>& __x) const {
williamr@2
  1428
    if (!_M_gslice._M_empty()) {
williamr@2
  1429
      _Gslice_Iter __i(_M_gslice);
williamr@2
  1430
      do _M_array[__i._M_1d_idx] |= __x[__i._M_step]; while(__i._M_incr());
williamr@2
  1431
    }
williamr@2
  1432
  }
williamr@2
  1433
williamr@2
  1434
  void operator<<= (const valarray<value_type>& __x) const {
williamr@2
  1435
    if (!_M_gslice._M_empty()) {
williamr@2
  1436
      _Gslice_Iter __i(_M_gslice);
williamr@2
  1437
      do _M_array[__i._M_1d_idx] <<= __x[__i._M_step]; while(__i._M_incr());
williamr@2
  1438
    }
williamr@2
  1439
  }
williamr@2
  1440
williamr@2
  1441
  void operator>>= (const valarray<value_type>& __x) const {
williamr@2
  1442
    if (!_M_gslice._M_empty()) {
williamr@2
  1443
      _Gslice_Iter __i(_M_gslice);
williamr@2
  1444
      do _M_array[__i._M_1d_idx] >>= __x[__i._M_step]; while(__i._M_incr());
williamr@2
  1445
    }
williamr@2
  1446
  }
williamr@2
  1447
williamr@2
  1448
  void operator= (const value_type& __c) {
williamr@2
  1449
    if (!_M_gslice._M_empty()) {
williamr@2
  1450
      _Gslice_Iter __i(_M_gslice);
williamr@2
  1451
      do _M_array[__i._M_1d_idx] = __c; while(__i._M_incr());
williamr@2
  1452
    }
williamr@2
  1453
  }
williamr@2
  1454
williamr@2
  1455
  ~gslice_array() {}
williamr@2
  1456
williamr@2
  1457
private:                        
williamr@2
  1458
  gslice_array(gslice __gslice, valarray<_Tp>& __array)
williamr@2
  1459
    : _M_gslice(__gslice), _M_array(__array)
williamr@2
  1460
    {}
williamr@2
  1461
williamr@2
  1462
  gslice                _M_gslice;
williamr@2
  1463
  valarray<value_type>& _M_array;
williamr@2
  1464
williamr@2
  1465
private:                        // Disable assignment
williamr@2
  1466
  void operator=(const gslice_array<_Tp>&);
williamr@2
  1467
};
williamr@2
  1468
williamr@2
  1469
// valarray member functions dealing with gslice and gslice_array.  Note
williamr@2
  1470
// that it is illegal (behavior is undefined) to construct a gslice_array
williamr@2
  1471
// from a degenerate gslice.
williamr@2
  1472
williamr@2
  1473
template <class _Tp>
williamr@2
  1474
inline valarray<_Tp>::valarray(const gslice_array<_Tp>& __x)
williamr@2
  1475
  : _Valarray_base<_Tp>(__x._M_gslice._M_size())
williamr@2
  1476
{
williamr@2
  1477
  typedef typename __type_traits<_Tp>::has_trivial_default_constructor
williamr@2
  1478
          _Is_Trivial;
williamr@2
  1479
  _M_initialize(_Is_Trivial());  
williamr@2
  1480
  *this = __x;
williamr@2
  1481
}
williamr@2
  1482
williamr@2
  1483
template <class _Tp>
williamr@2
  1484
inline gslice_array<_Tp> valarray<_Tp>::operator[](const gslice& __slice) {
williamr@2
  1485
  return gslice_array<_Tp>(__slice, *this);
williamr@2
  1486
}
williamr@2
  1487
williamr@2
  1488
williamr@2
  1489
//----------------------------------------------------------------------
williamr@2
  1490
// mask_array
williamr@2
  1491
williamr@2
  1492
template <class _Tp>
williamr@2
  1493
class mask_array {
williamr@2
  1494
  friend class valarray<_Tp>;
williamr@2
  1495
public:
williamr@2
  1496
  typedef _Tp value_type;
williamr@2
  1497
williamr@2
  1498
  void operator=(const valarray<value_type>& __x) const {
williamr@2
  1499
    size_t __idx = 0;
williamr@2
  1500
#ifdef __SYMBIAN32__    
williamr@2
  1501
    for (size_t __i = 0; __i < _M_array.size() && __i < _M_mask.size(); ++__i)
williamr@2
  1502
#else    
williamr@2
  1503
    for (size_t __i = 0; __i < _M_array.size(); ++__i)
williamr@2
  1504
#endif // __SYMBIAN32__    
williamr@2
  1505
      if (_M_mask[__i]) _M_array[__i] = __x[__idx++];
williamr@2
  1506
  }
williamr@2
  1507
williamr@2
  1508
  void operator*=(const valarray<value_type>& __x) const {
williamr@2
  1509
    size_t __idx = 0;
williamr@2
  1510
#ifdef __SYMBIAN32__    
williamr@2
  1511
    for (size_t __i = 0; __i < _M_array.size() && __i < _M_mask.size(); ++__i)
williamr@2
  1512
#else    
williamr@2
  1513
    for (size_t __i = 0; __i < _M_array.size(); ++__i)
williamr@2
  1514
#endif // __SYMBIAN32__    
williamr@2
  1515
      if (_M_mask[__i]) _M_array[__i] *= __x[__idx++];
williamr@2
  1516
  }
williamr@2
  1517
williamr@2
  1518
  void operator/=(const valarray<value_type>& __x) const {
williamr@2
  1519
    size_t __idx = 0;
williamr@2
  1520
#ifdef __SYMBIAN32__    
williamr@2
  1521
    for (size_t __i = 0; __i < _M_array.size() && __i < _M_mask.size(); ++__i)
williamr@2
  1522
#else    
williamr@2
  1523
    for (size_t __i = 0; __i < _M_array.size(); ++__i)
williamr@2
  1524
#endif //__SYMBIAN32__    
williamr@2
  1525
      if (_M_mask[__i]) _M_array[__i] /= __x[__idx++];
williamr@2
  1526
  }
williamr@2
  1527
williamr@2
  1528
  void operator%=(const valarray<value_type>& __x) const {
williamr@2
  1529
    size_t __idx = 0;
williamr@2
  1530
#ifdef __SYMBIAN32__    
williamr@2
  1531
    for (size_t __i = 0; __i < _M_array.size() && __i < _M_mask.size(); ++__i)
williamr@2
  1532
#else        
williamr@2
  1533
    for (size_t __i = 0; __i < _M_array.size(); ++__i)
williamr@2
  1534
#endif    
williamr@2
  1535
      if (_M_mask[__i]) _M_array[__i] %= __x[__idx++];
williamr@2
  1536
  }
williamr@2
  1537
williamr@2
  1538
  void operator+=(const valarray<value_type>& __x) const {
williamr@2
  1539
    size_t __idx = 0;
williamr@2
  1540
#ifdef __SYMBIAN32__    
williamr@2
  1541
    for (size_t __i = 0; __i < _M_array.size() && __i < _M_mask.size(); ++__i)
williamr@2
  1542
#else            
williamr@2
  1543
    for (size_t __i = 0; __i < _M_array.size(); ++__i)
williamr@2
  1544
#endif    
williamr@2
  1545
      if (_M_mask[__i]) _M_array[__i] += __x[__idx++];
williamr@2
  1546
  }
williamr@2
  1547
williamr@2
  1548
  void operator-=(const valarray<value_type>& __x) const {
williamr@2
  1549
    size_t __idx = 0;
williamr@2
  1550
#ifdef __SYMBIAN32__    
williamr@2
  1551
    for (size_t __i = 0; __i < _M_array.size() && __i < _M_mask.size(); ++__i)
williamr@2
  1552
#else            
williamr@2
  1553
    for (size_t __i = 0; __i < _M_array.size(); ++__i)
williamr@2
  1554
#endif //__SYMBIAN32__    
williamr@2
  1555
      if (_M_mask[__i]) _M_array[__i] -= __x[__idx++];
williamr@2
  1556
  }
williamr@2
  1557
  
williamr@2
  1558
  void operator^=(const valarray<value_type>& __x) const {
williamr@2
  1559
    size_t __idx = 0;
williamr@2
  1560
#ifdef __SYMBIAN32__    
williamr@2
  1561
    for (size_t __i = 0; __i < _M_array.size() && __i < _M_mask.size(); ++__i)
williamr@2
  1562
#else            
williamr@2
  1563
    for (size_t __i = 0; __i < _M_array.size(); ++__i)
williamr@2
  1564
#endif // __SYMBIAN32__    
williamr@2
  1565
      if (_M_mask[__i]) _M_array[__i] ^= __x[__idx++];
williamr@2
  1566
  }
williamr@2
  1567
williamr@2
  1568
  void operator&=(const valarray<value_type>& __x) const {
williamr@2
  1569
    size_t __idx = 0;
williamr@2
  1570
#ifdef __SYMBIAN32__    
williamr@2
  1571
    for (size_t __i = 0; __i < _M_array.size() && __i < _M_mask.size(); ++__i)
williamr@2
  1572
#else            
williamr@2
  1573
    for (size_t __i = 0; __i < _M_array.size(); ++__i)
williamr@2
  1574
#endif // __SYMBIAN32__    
williamr@2
  1575
      if (_M_mask[__i]) _M_array[__i] &= __x[__idx++];
williamr@2
  1576
  }
williamr@2
  1577
williamr@2
  1578
  void operator|=(const valarray<value_type>& __x) const {
williamr@2
  1579
    size_t __idx = 0;
williamr@2
  1580
#ifdef __SYMBIAN32__    
williamr@2
  1581
    for (size_t __i = 0; __i < _M_array.size() && __i < _M_mask.size(); ++__i)
williamr@2
  1582
#else            
williamr@2
  1583
    for (size_t __i = 0; __i < _M_array.size(); ++__i)
williamr@2
  1584
#endif // __SYMBIAN32__    
williamr@2
  1585
      if (_M_mask[__i]) _M_array[__i] |= __x[__idx++];
williamr@2
  1586
  }
williamr@2
  1587
williamr@2
  1588
  void operator<<=(const valarray<value_type>& __x) const {
williamr@2
  1589
    size_t __idx = 0;
williamr@2
  1590
#ifdef __SYMBIAN32__    
williamr@2
  1591
    for (size_t __i = 0; __i < _M_array.size() && __i < _M_mask.size(); ++__i)
williamr@2
  1592
#else            
williamr@2
  1593
    for (size_t __i = 0; __i < _M_array.size(); ++__i)
williamr@2
  1594
#endif // __SYMBIAN32__    
williamr@2
  1595
      if (_M_mask[__i]) _M_array[__i] <<= __x[__idx++];
williamr@2
  1596
  }
williamr@2
  1597
williamr@2
  1598
  void operator>>=(const valarray<value_type>& __x) const {
williamr@2
  1599
    size_t __idx = 0;
williamr@2
  1600
#ifdef __SYMBIAN32__    
williamr@2
  1601
    for (size_t __i = 0; __i < _M_array.size() && __i < _M_mask.size(); ++__i)
williamr@2
  1602
#else            
williamr@2
  1603
    for (size_t __i = 0; __i < _M_array.size(); ++__i)
williamr@2
  1604
#endif // __SYMBIAN32__    
williamr@2
  1605
      if (_M_mask[__i]) _M_array[__i] >>= __x[__idx++];
williamr@2
  1606
  }
williamr@2
  1607
williamr@2
  1608
  void operator=(const value_type& __c) const {
williamr@2
  1609
#ifdef __SYMBIAN32__    
williamr@2
  1610
    for (size_t __i = 0; __i < _M_array.size() && __i < _M_mask.size(); ++__i)
williamr@2
  1611
#else          
williamr@2
  1612
    for (size_t __i = 0; __i < _M_array.size(); ++__i)
williamr@2
  1613
#endif // __SYMBIAN32__    
williamr@2
  1614
      if (_M_mask[__i]) _M_array[__i] = __c;
williamr@2
  1615
  }
williamr@2
  1616
williamr@2
  1617
  ~mask_array() {}
williamr@2
  1618
williamr@2
  1619
  // Extension: number of true values in the mask
williamr@2
  1620
  size_t _M_num_true() const {
williamr@2
  1621
    size_t __result = 0;
williamr@2
  1622
    for (size_t __i = 0; __i < _M_mask.size(); ++__i)
williamr@2
  1623
      if (_M_mask[__i]) ++__result;
williamr@2
  1624
    return __result;
williamr@2
  1625
  }
williamr@2
  1626
williamr@2
  1627
private:
williamr@2
  1628
  mask_array(const _Valarray_bool& __mask, valarray<_Tp>& __array)
williamr@2
  1629
    : _M_mask(__mask), _M_array(__array)
williamr@2
  1630
    {}
williamr@2
  1631
williamr@2
  1632
  _Valarray_bool _M_mask;
williamr@2
  1633
  valarray<_Tp>& _M_array;
williamr@2
  1634
williamr@2
  1635
private:                        // Disable assignment
williamr@2
  1636
  void operator=(const mask_array<_Tp>&);
williamr@2
  1637
};
williamr@2
  1638
williamr@2
  1639
// valarray member functions dealing with mask_array
williamr@2
  1640
williamr@2
  1641
template <class _Tp>
williamr@2
  1642
inline valarray<_Tp>::valarray(const mask_array<_Tp>& __x)
williamr@2
  1643
  : _Valarray_base<_Tp>(__x._M_num_true())
williamr@2
  1644
{
williamr@2
  1645
  typedef typename __type_traits<_Tp>::has_trivial_default_constructor
williamr@2
  1646
          _Is_Trivial;
williamr@2
  1647
  _M_initialize(_Is_Trivial());  
williamr@2
  1648
  *this = __x;
williamr@2
  1649
}
williamr@2
  1650
williamr@2
  1651
// Behavior is undefined if __x._M_num_true() != this->size()
williamr@2
  1652
template <class _Tp>
williamr@2
  1653
inline valarray<_Tp>& valarray<_Tp>::operator=(const mask_array<_Tp>& __x) {
williamr@2
  1654
  size_t __idx = 0;
williamr@2
  1655
  for (size_t __i = 0; __i < __x._M_array.size(); ++__i)
williamr@2
  1656
    if (__x._M_mask[__i]) 
williamr@2
  1657
    {
williamr@2
  1658
#ifdef __SYMBIAN32__
williamr@2
  1659
    if(__idx < this->_M_size)
williamr@2
  1660
        (*this)[__idx++] = __x._M_array[__i];
williamr@2
  1661
    else
williamr@2
  1662
        break;
williamr@2
  1663
#else
williamr@2
  1664
   (*this)[__idx++] = __x._M_array[__i];
williamr@2
  1665
#endif
williamr@2
  1666
    }
williamr@2
  1667
  return *this;
williamr@2
  1668
}
williamr@2
  1669
williamr@2
  1670
template <class _Tp>
williamr@2
  1671
inline mask_array<_Tp> valarray<_Tp>::operator[](const _Valarray_bool& __mask)
williamr@2
  1672
{
williamr@2
  1673
  return mask_array<_Tp>(__mask, *this);
williamr@2
  1674
}
williamr@2
  1675
williamr@2
  1676
williamr@2
  1677
//----------------------------------------------------------------------
williamr@2
  1678
// indirect_array
williamr@2
  1679
williamr@2
  1680
template <class _Tp>
williamr@2
  1681
class indirect_array {
williamr@2
  1682
  friend class valarray<_Tp>;
williamr@2
  1683
public:
williamr@2
  1684
  typedef _Tp value_type;
williamr@2
  1685
williamr@2
  1686
  void operator=(const valarray<value_type>& __x) const {
williamr@2
  1687
    for (size_t __i = 0; __i < _M_addr.size(); ++__i)
williamr@2
  1688
      _M_array[_M_addr[__i]] = __x[__i];
williamr@2
  1689
  }
williamr@2
  1690
williamr@2
  1691
  void operator*=(const valarray<value_type>& __x) const {
williamr@2
  1692
    for (size_t __i = 0; __i < _M_addr.size(); ++__i)
williamr@2
  1693
      _M_array[_M_addr[__i]] *= __x[__i];
williamr@2
  1694
  }
williamr@2
  1695
williamr@2
  1696
  void operator/=(const valarray<value_type>& __x) const {
williamr@2
  1697
    for (size_t __i = 0; __i < _M_addr.size(); ++__i)
williamr@2
  1698
      _M_array[_M_addr[__i]] /= __x[__i];
williamr@2
  1699
  }
williamr@2
  1700
williamr@2
  1701
  void operator%=(const valarray<value_type>& __x) const {
williamr@2
  1702
    for (size_t __i = 0; __i < _M_addr.size(); ++__i)
williamr@2
  1703
      _M_array[_M_addr[__i]] %= __x[__i];
williamr@2
  1704
  }
williamr@2
  1705
williamr@2
  1706
  void operator+=(const valarray<value_type>& __x) const {
williamr@2
  1707
    for (size_t __i = 0; __i < _M_addr.size(); ++__i)
williamr@2
  1708
      _M_array[_M_addr[__i]] += __x[__i];
williamr@2
  1709
  }
williamr@2
  1710
williamr@2
  1711
  void operator-=(const valarray<value_type>& __x) const {
williamr@2
  1712
    for (size_t __i = 0; __i < _M_addr.size(); ++__i)
williamr@2
  1713
      _M_array[_M_addr[__i]] -= __x[__i];
williamr@2
  1714
  }
williamr@2
  1715
williamr@2
  1716
  void operator^=(const valarray<value_type>& __x) const {
williamr@2
  1717
    for (size_t __i = 0; __i < _M_addr.size(); ++__i)
williamr@2
  1718
      _M_array[_M_addr[__i]] ^= __x[__i];
williamr@2
  1719
  }
williamr@2
  1720
williamr@2
  1721
  void operator&=(const valarray<value_type>& __x) const {
williamr@2
  1722
    for (size_t __i = 0; __i < _M_addr.size(); ++__i)
williamr@2
  1723
      _M_array[_M_addr[__i]] &= __x[__i];
williamr@2
  1724
  }
williamr@2
  1725
williamr@2
  1726
  void operator|=(const valarray<value_type>& __x) const {
williamr@2
  1727
    for (size_t __i = 0; __i < _M_addr.size(); ++__i)
williamr@2
  1728
      _M_array[_M_addr[__i]] |= __x[__i];
williamr@2
  1729
  }
williamr@2
  1730
williamr@2
  1731
  void operator<<=(const valarray<value_type>& __x) const {
williamr@2
  1732
    for (size_t __i = 0; __i < _M_addr.size(); ++__i)
williamr@2
  1733
      _M_array[_M_addr[__i]] <<= __x[__i];
williamr@2
  1734
  }
williamr@2
  1735
williamr@2
  1736
  void operator>>=(const valarray<value_type>& __x) const {
williamr@2
  1737
    for (size_t __i = 0; __i < _M_addr.size(); ++__i)
williamr@2
  1738
      _M_array[_M_addr[__i]] >>= __x[__i];
williamr@2
  1739
  }
williamr@2
  1740
williamr@2
  1741
  void operator=(const value_type& __c) const {
williamr@2
  1742
    for (size_t __i = 0; __i < _M_addr.size(); ++__i)
williamr@2
  1743
      _M_array[_M_addr[__i]] = __c;
williamr@2
  1744
  }
williamr@2
  1745
williamr@2
  1746
  ~indirect_array() {}
williamr@2
  1747
williamr@2
  1748
private:
williamr@2
  1749
  indirect_array(const _Valarray_size_t& __addr, valarray<_Tp>& __array)
williamr@2
  1750
    : _M_addr(__addr), _M_array(__array)
williamr@2
  1751
    {}
williamr@2
  1752
williamr@2
  1753
  _Valarray_size_t _M_addr;
williamr@2
  1754
  valarray<_Tp>&   _M_array;
williamr@2
  1755
williamr@2
  1756
private:                        // Disable assignment
williamr@2
  1757
  void operator=(const indirect_array<_Tp>&);
williamr@2
  1758
};
williamr@2
  1759
williamr@2
  1760
// valarray member functions dealing with indirect_array
williamr@2
  1761
williamr@2
  1762
template <class _Tp>
williamr@2
  1763
inline valarray<_Tp>::valarray(const indirect_array<_Tp>& __x)
williamr@2
  1764
  : _Valarray_base<_Tp>(__x._M_addr.size())
williamr@2
  1765
{
williamr@2
  1766
  typedef typename __type_traits<_Tp>::has_trivial_default_constructor
williamr@2
  1767
          _Is_Trivial;
williamr@2
  1768
  _M_initialize(_Is_Trivial());  
williamr@2
  1769
  *this = __x;
williamr@2
  1770
}
williamr@2
  1771
williamr@2
  1772
williamr@2
  1773
template <class _Tp>
williamr@2
  1774
inline indirect_array<_Tp>
williamr@2
  1775
valarray<_Tp>::operator[](const _Valarray_size_t& __addr)
williamr@2
  1776
{
williamr@2
  1777
  return indirect_array<_Tp>(__addr, *this);
williamr@2
  1778
}
williamr@2
  1779
williamr@2
  1780
_STLP_END_NAMESPACE
williamr@2
  1781
williamr@2
  1782
# if !defined (_STLP_LINK_TIME_INSTANTIATION)
williamr@2
  1783
#  include <stl/_valarray.c>
williamr@2
  1784
# endif
williamr@2
  1785
williamr@2
  1786
#endif /* _STLP_VALARRAY */
williamr@2
  1787
williamr@2
  1788
williamr@2
  1789
// Local Variables:
williamr@2
  1790
// mode:C++
williamr@2
  1791
// End: