/* * Copyright (C) 2010 Thorsten Liebig (Thorsten.Liebig@gmx.de) * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #include "array_ops.h" #include #ifdef WIN32 #define __MSVCRT_VERSION__ 0x0700 #include //(void**)&array, 16, sizeof(typeof(f4vector**))*numLines[0] #define MEMALIGN( array, alignment, size ) !(*array = _aligned_malloc( size, alignment )) #define FREE( array ) _aligned_free( array ) #else #define MEMALIGN( array, alignment, size ) posix_memalign( array, alignment, size ) #define FREE( array ) free( array ) #endif FDTD_FLOAT** Create2DArray(const unsigned int* numLines) { FDTD_FLOAT** array=NULL; unsigned int pos[3]; array = new FDTD_FLOAT*[numLines[0]]; for (pos[0]=0;pos[0]