annotate Lib/fftw-3.2.1/api/.svn/text-base/mktensor-rowmajor.c.svn-base @ 9:262e084a15a9

Vectorised everything and made use of unique_ptr so there should be no more memory leaks. Hurrah for RAII
author Geogaddi\David <d.m.ronan@qmul.ac.uk>
date Wed, 12 Aug 2015 22:25:06 +0100
parents 25bf17994ef1
children
rev   line source
d@0 1 /*
d@0 2 * Copyright (c) 2003, 2007-8 Matteo Frigo
d@0 3 * Copyright (c) 2003, 2007-8 Massachusetts Institute of Technology
d@0 4 *
d@0 5 * This program is free software; you can redistribute it and/or modify
d@0 6 * it under the terms of the GNU General Public License as published by
d@0 7 * the Free Software Foundation; either version 2 of the License, or
d@0 8 * (at your option) any later version.
d@0 9 *
d@0 10 * This program is distributed in the hope that it will be useful,
d@0 11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
d@0 12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
d@0 13 * GNU General Public License for more details.
d@0 14 *
d@0 15 * You should have received a copy of the GNU General Public License
d@0 16 * along with this program; if not, write to the Free Software
d@0 17 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
d@0 18 *
d@0 19 */
d@0 20
d@0 21 #include "api.h"
d@0 22
d@0 23 tensor *X(mktensor_rowmajor)(int rnk, const int *n,
d@0 24 const int *niphys, const int *nophys,
d@0 25 int is, int os)
d@0 26 {
d@0 27 tensor *x = X(mktensor)(rnk);
d@0 28
d@0 29 if (FINITE_RNK(rnk) && rnk > 0) {
d@0 30 int i;
d@0 31
d@0 32 A(n && niphys && nophys);
d@0 33 x->dims[rnk - 1].is = is;
d@0 34 x->dims[rnk - 1].os = os;
d@0 35 x->dims[rnk - 1].n = n[rnk - 1];
d@0 36 for (i = rnk - 1; i > 0; --i) {
d@0 37 x->dims[i - 1].is = x->dims[i].is * niphys[i];
d@0 38 x->dims[i - 1].os = x->dims[i].os * nophys[i];
d@0 39 x->dims[i - 1].n = n[i - 1];
d@0 40 }
d@0 41 }
d@0 42 return x;
d@0 43 }
d@0 44
d@0 45 static int rowmajor_kosherp(int rnk, const int *n)
d@0 46 {
d@0 47 int i;
d@0 48
d@0 49 if (!FINITE_RNK(rnk)) return 0;
d@0 50 if (rnk < 0) return 0;
d@0 51
d@0 52 for (i = 0; i < rnk; ++i)
d@0 53 if (n[i] <= 0) return 0;
d@0 54
d@0 55 return 1;
d@0 56 }
d@0 57
d@0 58 int X(many_kosherp)(int rnk, const int *n, int howmany)
d@0 59 {
d@0 60 return (howmany >= 0) && rowmajor_kosherp(rnk, n);
d@0 61 }