開発環境
- OS X Mavericks - Apple(OS)
- Emacs (CUI)、BBEdit - Bare Bones Software, Inc. (GUI) (Text Editor)
- C (プログラミング言語)
- Clang (コンパイラ)
C実践プログラミング 第3版 (Steve Oualline (著)、 望月 康司 (監訳) (翻訳)、谷口 功 (翻訳)、オライリー・ジャパン)のⅡ部(単純なプログラミング)の15章(デバッグと最適化)、15.8(プログラミング実習)、実習 15-2を解いてみる。
その他参考書籍
- プログラミング言語C 第2版 ANSI規格準拠 (B.W. カーニハン D.M. リッチー (著)、 石田 晴久 (翻訳)、共立出版)
- プログラミング言語Cアンサー・ブック 第2版 (クロビス・L.トンド、スコット・E.ギンペル(著)、矢吹 道郎(翻訳))
実習15-2.
コード
sample.c
#include <stdio.h> #include <memory.h> #include <time.h> #define X_SIZE 60 #define Y_SIZE 64 #define Z_SIZE 1024 int matrix1[X_SIZE][Y_SIZE]; int matrix2[Y_SIZE][Z_SIZE]; int matrix[X_SIZE][Z_SIZE]; clock_t t1; int main() { int i, j; int t; memset(matrix1, -1, sizeof(matrix1)); memset(matrix2, 0, sizeof(matrix2)); void multiple_matrix(void); void multiple_martrix_1(void); t1 = clock(); multiple_matrix(); t = clock() - t1; printf("index : %10d ms\n", t); memset(matrix1, -1, sizeof(matrix1)); memset(matrix2, 0, sizeof(matrix2)); t1 = clock(); multiple_martrix_1(); t = clock() - t1; printf("pointer: %10d ms\n", t); return (0); } void multiple_matrix(void) { int i, j; int total; int x, y; for(i = 0; i < X_SIZE; i++){ for(j = 0; j < Z_SIZE; j++){ total = 0; for(y = 0; y < Y_SIZE; y++){ for(x = 0; x < Y_SIZE; x++){ total += matrix1[i][y] * matrix2[x][j]; } } matrix[i][j] = total; } } } void multiple_martrix_1(void){ register int i, j; register int *matrix1_ptr; register int *matrix2_ptr; register int *matrix_ptr; register int *temp_ptr; register int total; register int x, y; matrix1_ptr = &matrix1[0][0]; temp_ptr = &matrix2[0][0]; for(matrix_ptr = &matrix[0][0]; matrix_ptr <= &matrix[X_SIZE - 1][Z_SIZE - 1]; ++matrix_ptr){ total = 0; temp_ptr += Z_SIZE; for(matrix2_ptr = temp_ptr; matrix2_ptr < &matrix2[Y_SIZE - 1][Z_SIZE - 1]; matrix2_ptr += Z_SIZE){ total += (*matrix1_ptr) * (*matrix2_ptr); matrix1_ptr++; } *matrix_ptr = total; } }
makefile
CC=cc CFLAGS=-g sample: sample.c $(CC) $(CFLAGS) -o sample sample.c clean: rm -f sample
入出力結果(Terminal)
$ make cc -g -o sample sample.c $ ./sample index : 1518223 ms pointer: 305 ms $
0 コメント:
コメントを投稿