tensor-0.1.0
Main Page
Related Pages
Modules
Namespaces
Data Structures
All
Data Structures
Namespaces
Functions
Variables
Typedefs
Enumerations
Enumerator
Groups
Pages
surrounding_dimensions.cc
1
// -*- mode: c++; fill-column: 80; c-basic-offset: 2; indent-tabs-mode: nil -*-
2
/*
3
Copyright (c) 2010 Juan Jose Garcia Ripoll
4
5
Tensor is free software; you can redistribute it and/or modify it
6
under the terms of the GNU Library General Public License as published
7
by the Free Software Foundation; either version 2 of the License, or
8
(at your option) any later version.
9
10
This program is distributed in the hope that it will be useful,
11
but WITHOUT ANY WARRANTY; without even the implied warranty of
12
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13
GNU Library General Public License for more details.
14
15
You should have received a copy of the GNU General Public License along
16
with this program; if not, write to the Free Software Foundation, Inc.,
17
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
18
*/
19
20
#include <tensor/indices.h>
21
22
namespace
tensor {
23
34
void
35
surrounding_dimensions(
const
Indices &d, index ndx,
36
index *d1, index *d2, index *d3)
37
{
38
index i, l = d.size();
39
for
(i = 0, *d1 = 1; i < ndx; i++) {
40
*d1 *= d[i];
41
}
42
*d2 = d[i++];
43
for
(*d3 = 1; i < l; i++) {
44
*d3 *= d[i];
45
}
46
}
47
48
}
// namespace tensor
src
indices
surrounding_dimensions.cc
Generated on Tue Jun 10 2014 10:24:16 for tensor-0.1.0 by
1.8.6