/* * Copyright 2010-2011 Stefan Lankes * Chair for Operating Systems, RWTH Aachen University * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * */ #include #include #include #include #include #include #include #define MATRIX_SIZE 128 #define MAXVALUE 1337 #define PAGE_SIZE 4096 #define CACHE_SIZE (256*1024) #define ALIGN(x,a) (((x)+(a)-1)&~((a)-1)) static int generate_empty_matrix(double*** A , unsigned int N) { unsigned int iCnt; int i,j; *A = (double**) malloc((N+1)*sizeof(double*)); if (*A == NULL) return -2; /* Error */ (*A)[0] = (double*) malloc((N+1)*N*sizeof(double)); if (**A == NULL) return -2; /* Error */ for(iCnt=1; iCnt Sum |A[i][j]| with (i != j) */ (*A)[i][i] = sum + 2.0; (*A)[i][N] += sum + 2.0; } return 0; } int main(int argc, char **argv) { double* temp; unsigned int i, j, iter_start, iter_end; unsigned int iterations = 0; double error, norm, max = 0.0; double** A=0; double* X; double* X_old, xi; clock_t start, end; if (generate_empty_matrix(&A,MATRIX_SIZE) < 0) { printf("generate_empty_matrix() failed...\n"); exit(-1); } printf("generate_empty_matrix() done...\n"); X = (double*) malloc(MATRIX_SIZE*sizeof(double)); X_old = (double*) malloc(MATRIX_SIZE*sizeof(double)); if(X == NULL || X_old == NULL) { printf("X or X_old is NULL...\n"); exit(-1); } for(i=0; i 0.01f) { printf("Result is on position %d wrong (%f != 1.0)\n", i, X[i]); exit(1); } } printf("maximal error is %f\n", max); printf("\nmatrix size: %d x %d\n", MATRIX_SIZE, MATRIX_SIZE); printf("number of iterations: %d\n", iterations); printf("calculation time: %f s\n", (float) (end-start) / (float) CLOCKS_PER_SEC); free((void*) X_old); free((void*) X); return 0; }