Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: downloads/boost_1_33_1/libs/multi_array/test/access.cpp @ 13

Last change on this file since 13 was 12, checked in by landauf, 17 years ago

added boost

File size: 1.8 KB
Line 
1// Copyright 2002 The Trustees of Indiana University.
2
3// Use, modification and distribution is subject to the Boost Software
4// License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
5// http://www.boost.org/LICENSE_1_0.txt)
6
7//  Boost.MultiArray Library
8//  Authors: Ronald Garcia
9//           Jeremy Siek
10//           Andrew Lumsdaine
11//  See http://www.boost.org/libs/multi_array for documentation.
12
13//
14// access.cpp - operator[] and operator() tests with various arrays
15//    The tests assume that they are working on an Array of shape 2x3x4
16//
17
18#include "generative_tests.hpp"
19#include "boost/static_assert.hpp"
20
21template <typename Array>
22void access(Array& A, const mutable_array_tag&) {
23  assign(A);
24  access(A,const_array_tag());
25
26  const Array& CA = A;
27  access(CA,const_array_tag());
28}
29
30template <typename Array>
31void access(Array& A, const const_array_tag&) {
32  const unsigned int ndims = 3;
33  BOOST_STATIC_ASSERT((Array::dimensionality == ndims));
34  typedef typename Array::index index;
35  const index idx0 = A.index_bases()[0];
36  const index idx1 = A.index_bases()[1];
37  const index idx2 = A.index_bases()[2];
38
39  // operator[]
40  int cnum = 0;
41  const Array& CA = A;
42  for (index i = idx0; i != idx0+2; ++i)
43    for (index j = idx1; j != idx1+3; ++j)
44      for (index k = idx2; k != idx2+4; ++k) {
45        BOOST_CHECK(A[i][j][k] == cnum++);
46        BOOST_CHECK(CA[i][j][k] == A[i][j][k]);
47      }
48
49  // operator()
50  for (index i2 = 0; i2 != 2; ++i2)
51    for (index j2 = 0; j2 != 3; ++j2)
52      for (index k2 = 0; k2 != 4; ++k2) {
53        boost::array<index,ndims> indices;
54        indices[0] = i2; indices[1] = j2; indices[2] = k2;
55        BOOST_CHECK(A(indices) == A[i2][j2][k2]);
56        BOOST_CHECK(CA(indices) == A(indices));
57      }
58  ++tests_run;
59}
60
61int test_main(int,char*[]) {
62  return run_generative_tests();
63}
Note: See TracBrowser for help on using the repository browser.