115 9 MPIBNCpack 9.1 BNCpack 1CPU X = , B =
|
|
|
- みいか さどひら
- 7 years ago
- Views:
Transcription
1 115 9 MPIBNCpack 9.1 BNCpack 1CPU X = , B = C = XB X dmat1 B dmat2 C dmat ans 1 : #include <stdio.h> 2 : #include <stdlib.h> 3 : #include <math.h> 4 : 5 : #include "bnc.h" 6 : 7 : #define DIM 5 8 : 9 : int main(int argc, char *argv[]) 10 : { 11 : DMatrix dmat_ans, dmat1, dmat2; 12 : long int i, j; 13 : double start_wtime, end_wtime;
2 : 15 : dmat_ans = init_dmatrix(dim, DIM); 16 : dmat1 = init_dmatrix(dim, DIM); 17 : dmat2 = init_dmatrix(dim, DIM); 18 : for(i = 0; i < DIM; i++) 19 : { 20 : for(j = 0; j < DIM; j++) 21 : { 22 : set_dmatrix_ij(dmat1, i, j, (double)(i*dim + j + 1)); 23 : set_dmatrix_ij(dmat2, i, j, (double)(dim * DIM - (i*d IM +j))); 24 : } 25 : } 26 : 27 : mul_dmatrix(dmat_ans, dmat1, dmat2); 28 : 29 : printf("bnc:\n"); print_dmatrix(dmat_ans); 30 : 31 : free_dmatrix(dmat_ans); 32 : free_dmatrix(dmat1); 33 : free_dmatrix(dmat2); 34 : 35 : return EXIT_SUCCESS; 36 : } 1 : #include <stdio.h> 2 : #include <stdlib.h> 3 : #include <math.h> 4 : 5 : #define USE_GMP 6 : #define USE_MPFR 7 : #include "bnc.h" 8 : 9 : #define DIM 5 10 : 11 : int main(int argc, char *argv[]) 12 : { 13 : MPFMatrix dmat_ans, dmat1, dmat2; 14 : long int i, j; 15 : double start_wtime, end_wtime; 16 : 17 : set_bnc_default_prec_decimal(50); 18 : 19 : dmat_ans = init_mpfmatrix(dim, DIM);
3 : dmat1 = init_mpfmatrix(dim, DIM); 21 : dmat2 = init_mpfmatrix(dim, DIM); 22 : for(i = 0; i < DIM; i++) 23 : { 24 : for(j = 0; j < DIM; j++) 25 : { 26 : set_mpfmatrix_ij_d(dmat1, i, j, (double)(i*dim + j + 1)); 27 : set_mpfmatrix_ij_d(dmat2, i, j, (double)(dim * DIM - (i*dim +j))); 28 : } 29 : } 30 : 31 : mul_mpfmatrix(dmat_ans, dmat1, dmat2); 32 : 33 : printf("bnc:\n"); print_mpfmatrix(dmat_ans); 34 : 35 : free_mpfmatrix(dmat_ans); 36 : free_mpfmatrix(dmat1); 37 : free_mpfmatrix(dmat2); 38 : 39 : return EXIT_SUCCESS; 40 : } 41 : 9.2 PE A, B C = AB B PE PE B 1 1 PE PE 4 ( ) Matrix Computations[9] 9.1 A, B MPIBNCpack A PE
4 118 9 A11 A12 A13 A14 B11 B12 B13 B14 PE0 A21 A22 A23 A24 B21 B22 B23 B24 PE1 A31 A32 A33 A34 B31 B32 B33 B34 PE2 A41 A42 A43 A44 B41 B42 B43 B44 PE3 C 1 11 C 1 12 C 1 13 C 1 14 A11 A12 A13 A14 B11 B22 B33 B44 PE0 C 1 21 C 1 22 C 1 23 C 1 24 = A22 A23 A24 A21 B21 B32 B43 B14 PE1 C 1 31 C 1 32 C 1 33 C 1 34 A33 A34 A31 A32 B31 B42 B13 B24 PE2 C 1 41 C 1 42 C 1 43 C 1 44 A44 A41 A42 A43 B41 B12 B23 B34 PE3 9.1: (1)
5 B PE PE C 1 11 = A 11 B 11, C 1 12 = A 11B 22, C 1 13 = A 13B 33, C 1 14 = A 14B 44 C 1 21 = A 22 B 21, C 1 22 = A 23B 32, C 1 23 = A 24B 43, C 1 24 = A 21B 14 C 1 31 = A 33 B 31, C 1 32 = A 34B 42, C 1 33 = A 31B 13, C 1 34 = A 32B 24 C 1 41 = A 44 B 41, C 1 42 = A 41B 12, C 1 43 = A 42B 23, C 1 44 = A 43B 34 C 1 C 2 11 C 2 12 C 2 13 C 2 14 A12 A13 A14 A11 B21 B32 B43 B14 PE0 C 2 21 C 2 22 C 2 23 C 2 24 = A23 A24 A21 A22 B31 B42 B13 B24 PE1 C 2 31 C 2 32 C 2 33 C 2 34 A34 A31 A32 A33 B41 B12 B23 B34 PE2 C 2 41 C 2 42 C 2 43 C 2 44 A41 A42 A43 A44 B11 B22 B33 B44 PE3 C 3 11 C 3 12 C 3 13 C 3 14 A13 A14 A11 A12 B31 B42 B13 B24 PE0 C 3 21 C 3 22 C 3 23 C 3 24 = A24 A21 A22 A23 B41 B12 B23 B34 PE1 C 3 31 C 3 32 C 3 33 C 3 34 A31 A32 A33 A34 B11 B22 B33 B44 PE2 C 3 41 C 3 42 C 3 43 C 3 44 A42 A43 A44 A41 B21 B32 B43 B14 PE3 9.2: (2) A 1 B 1 PE C 2 C 3 C 4
6 120 9 C 4 11 C 4 12 C 4 13 C 4 14 A14 A11 A12 A13 B41 B12 B23 B34 PE0 C 4 21 C 4 22 C 4 23 C 4 24 = A21 A22 A23 A24 B11 B22 B33 B44 PE1 C 4 31 C 4 32 C 4 33 C 4 34 A32 A33 A34 A31 B21 B32 B43 B14 PE2 C 4 41 C 4 42 C 4 43 C 4 44 A43 A44 A41 A42 B31 B42 B13 B24 PE3 A11 A12 A13 A14 B11 B12 B13 B14 PE0 A21 A22 A23 A24 B21 B22 B23 B24 PE1 A31 A32 A33 A34 B31 B32 B33 B34 PE2 A41 A42 A43 A44 B41 B42 B43 B44 PE3 9.3: (3)
7 9.3. MPIBNCpack 121 C 1, C 2, C 3, C 4 C C = C 1 + C 2 + C 3 + C 4 A B MPIBNCpack mpi mul dmatrix( ) mpi mul mpfmatrix( ) 9.3 MPIBNCpack 1 : #include <stdio.h> 2 : #include <stdlib.h> 3 : #include <math.h> 4 : 5 : #include "mpi.h" 6 : 7 : #include "mpi_bnc.h" 8 : 9 : #define DIM 5 10 : 11 : int main(int argc, char *argv[]) 12 : { 13 : DMatrix my_dmat_ans[10], my_dmat1[10], my_dmat2[10]; 14 : DMatrix dmat_ans, dmat1, dmat2; 15 : 16 : long int d_ddim[mpi_gmp_maxprocs]; 17 : long int i, j, local_dim; 18 : int myrank, num_procs; 19 : double start_wtime, end_wtime; 20 : 21 : MPI_Init(&argc, &argv); 22 : MPI_Comm_rank(MPI_COMM_WORLD, &myrank); 23 : MPI_Comm_size(MPI_COMM_WORLD, &num_procs); 24 : 25 : local_dim = _mpi_divide_dim(d_ddim, DIM, num_procs); 26 : 27 : _mpi_init_dmatrix(my_dmat_ans, d_ddim, DIM, MPI_COMM_WORLD); 28 : _mpi_init_dmatrix(my_dmat1, d_ddim, DIM, MPI_COMM_WORLD); 29 : _mpi_init_dmatrix(my_dmat2, d_ddim, DIM, MPI_COMM_WORLD);
8 : 31 : if(myrank == 0) 32 : { 33 : dmat_ans = init_dmatrix(local_dim * num_procs, local_dim * num_procs); 34 : dmat1 = init_dmatrix(local_dim * num_procs, local_dim * n um_procs); 35 : dmat2 = init_dmatrix(local_dim * num_procs, local_dim * n um_procs); 36 : for(i = 0; i < DIM; i++) 37 : for(j = 0; j < DIM; j++) 38 : { 39 : set_dmatrix_ij(dmat1, i, j, (double)(i*dim + j + 1)); 40 : set_dmatrix_ij(dmat2, i, j, (double)(dim * DIM - (i*dim +j))); 41 : } 42 : } 43 : 44 : _mpi_divide_dmatrix(my_dmat1, d_ddim, dmat1, MPI_COMM_WORLD); 45 : _mpi_divide_dmatrix(my_dmat2, d_ddim, dmat2, MPI_COMM_WORLD); 46 : 47 : if(myrank == 0) start_wtime = MPI_Wtime(); 48 : _mpi_mul_dmatrix(my_dmat_ans, my_dmat1, my_dmat2, MPI_COMM_WO RLD); 49 : if(myrank == 0) end_wtime = MPI_Wtime(); 50 : 51 : _mpi_collect_dmatrix(dmat_ans, d_ddim, my_dmat_ans, MPI_COMM_ WORLD); 52 : 53 : /* free */ 54 : _mpi_free_dmatrix(my_dmat_ans, MPI_COMM_WORLD); 55 : _mpi_free_dmatrix(my_dmat1, MPI_COMM_WORLD); 56 : _mpi_free_dmatrix(my_dmat2, MPI_COMM_WORLD); 57 : 58 : if(myrank == 0) 59 : { 60 : printf("mpibnc:\n"); print_dmatrix(dmat_ans); 61 : printf("mpi_mul_time: %f\n", end_wtime - start_wtime); 62 : 63 : start_wtime = get_secv(); 64 : mul_dmatrix(dmat_ans, dmat1, dmat2); 65 : end_wtime = get_secv(); 66 :
9 9.3. MPIBNCpack : printf("bnc:\n"); print_dmatrix(dmat_ans); 68 : printf("bnc_mul_time: %f\n", end_wtime - start_wtime); 69 : 70 : free_dmatrix(dmat_ans); 71 : free_dmatrix(dmat1); 72 : free_dmatrix(dmat2); 73 : } 74 : MPI_Finalize(); 75 : 76 : return EXIT_SUCCESS; 77 : } 78 : PE0 MPI Wtime CPU BNCpack get secv (second) 2 1 : #include <stdio.h> 2 : #include <stdlib.h> 3 : #include <math.h> 4 : 5 : #include "mpi.h" 6 : 7 : #define USE_GMP 8 : #define USE_MPFR 9 : #include "mpi_bnc.h" 10 : 11 : #define DIM 5 12 : 13 : int main(int argc, char *argv[]) 14 : { 15 : MPFMatrix my_mpfmat_ans[10], my_mpfmat1[10], my_mpfmat2[10]; 16 : MPFMatrix mpfmat_ans, mpfmat1, mpfmat2; 17 : mpf_t tmp; 18 : 19 : long int d_ddim[10]; 20 : long int i, j, local_dim; 21 : int myrank, num_procs; 22 : double start_wtime, end_wtime; 23 : 24 : MPI_Init(&argc, &argv);
10 : MPI_Comm_rank(MPI_COMM_WORLD, &myrank); 26 : MPI_Comm_size(MPI_COMM_WORLD, &num_procs); 27 : 28 : _mpi_set_bnc_default_prec_decimal(50, MPI_COMM_WORLD); 29 : commit_mpf(&(mpi_mpf), ceil(50/log10(2.0)), MPI_COMM_WORLD); 30 : create_mpf_op(&(mpi_mpf_sum), _mpi_mpf_add, MPI_COMM_WORLD); 31 : 32 : local_dim = _mpi_divide_dim(d_ddim, DIM, num_procs); 33 : 34 : _mpi_init_mpfmatrix(my_mpfmat_ans, d_ddim, DIM, MPI_COMM_WORL D); 35 : _mpi_init_mpfmatrix(my_mpfmat1, d_ddim, DIM, MPI_COMM_WORLD); 36 : _mpi_init_mpfmatrix(my_mpfmat2, d_ddim, DIM, MPI_COMM_WORLD); 37 : 38 : if(myrank == 0) 39 : { 40 : mpfmat_ans = init_mpfmatrix(local_dim * num_procs, local_ dim * num_procs); 41 : mpfmat1 = init_mpfmatrix(local_dim * num_procs, local_dim * num_procs); 42 : mpfmat2 = init_mpfmatrix(local_dim * num_procs, local_dim * num_procs); 43 : for(i = 0; i < DIM; i++) 44 : for(j = 0; j < DIM; j++) 45 : { 46 : set_mpfmatrix_ij_ui(mpfmat1, i, j, (unsigned long )(i*dim + j + 1)); 47 : set_mpfmatrix_ij_ui(mpfmat2, i, j, (unsigned long )(DIM * DIM - (i*dim + j))); 48 : } 49 : } 50 : 51 : _mpi_divide_mpfmatrix(my_mpfmat1, d_ddim, mpfmat1, MPI_COMM_W ORLD); 52 : _mpi_divide_mpfmatrix(my_mpfmat2, d_ddim, mpfmat2, MPI_COMM_W ORLD); 53 : 54 : if(myrank == 0) start_wtime = MPI_Wtime(); 55 : _mpi_mul_mpfmatrix(my_mpfmat_ans, my_mpfmat1, my_mpfmat2, MPI _COMM_WORLD); 56 : if(myrank == 0) end_wtime = MPI_Wtime(); 57 : 58 : _mpi_collect_mpfmatrix(mpfmat_ans, d_ddim, my_mpfmat_ans, MPI _COMM_WORLD);
11 9.3. MPIBNCpack : 60 : /* free */ 61 : _mpi_free_mpfmatrix(my_mpfmat_ans, MPI_COMM_WORLD); 62 : _mpi_free_mpfmatrix(my_mpfmat1, MPI_COMM_WORLD); 63 : _mpi_free_mpfmatrix(my_mpfmat2, MPI_COMM_WORLD); 64 : 65 : if(myrank == 0) 66 : { 67 : printf("mpibnc:\n"); print_mpfmatrix(mpfmat_ans); 68 : printf("mpi_mul_time: %f\n", end_wtime - start_wtime); 69 : 70 : start_wtime = get_secv(); 71 : mul_mpfmatrix(mpfmat_ans, mpfmat1, mpfmat2); 72 : end_wtime = get_secv(); 73 : 74 : printf("bnc:\n"); print_mpfmatrix(mpfmat_ans); 75 : printf("bnc_mul_time: %f\n", end_wtime - start_wtime); 76 : 77 : free_mpfmatrix(mpfmat_ans); 78 : free_mpfmatrix(mpfmat1); 79 : free_mpfmatrix(mpfmat2); 80 : } 81 : 82 : free_mpf_op(&(mpi_mpf_sum)); 83 : free_mpf(&(mpi_mpf)); 84 : MPI_Finalize(); 85 : 86 : return EXIT_SUCCESS; 87 : } 88 : 1. mpi-mat5.c mat5.c 1PE 2PEs 4PEs 8PEs
12 mpi-mat5-gmp.c 50, 100, 200
DKA ( 1) 1 n i=1 α i c n 1 = 0 ( 1) 2 n i 1 <i 2 α i1 α i2 c n 2 = 0 ( 1) 3 n i 1 <i 2 <i 3 α i1 α i2 α i3 c n 3 = 0. ( 1) n 1 n i 1 <i 2 < <i
149 11 DKA IEEE754 11.1 DKA n p(x) = a n x n + a n 1 x n 1 + + a 0 (11.1) p(x) = 0 (11.2) p n (x) q n (x) = x n + c n 1 x n 1 + + c 1 x + c 0 q n (x) = 0 (11.3) c i = a i a n (i = 0, 1,..., n 1) (11.3)
Krylov (b) x k+1 := x k + α k p k (c) r k+1 := r k α k Ap k ( := b Ax k+1 ) (d) β k := r k r k 2 2 (e) : r k 2 / r 0 2 < ε R (f) p k+1 :=
127 10 Krylov Krylov (Conjugate-Gradient (CG ), Krylov ) MPIBNCpack 10.1 CG (Conjugate-Gradient CG ) A R n n a 11 a 12 a 1n a 21 a 22 a 2n A T = =... a n1 a n2 a nn n a 11 a 21 a n1 a 12 a 22 a n2 = A...
58 7 MPI 7 : main(int argc, char *argv[]) 8 : { 9 : int num_procs, myrank; 10 : double a, b; 11 : int tag = 0; 12 : MPI_Status status; 13 : 1 MPI_Init
57 7 MPI MPI 1 1 7.1 Bcast( ) allocate Bcast a=1 PE0 a=1 PE1 a=1 PE2 a=1 PE3 7.1: Bcast 58 7 MPI 7 : main(int argc, char *argv[]) 8 : { 9 : int num_procs, myrank; 10 : double a, b; 11 : int tag = 0; 12
44 6 MPI 4 : #LIB=-lmpich -lm 5 : LIB=-lmpi -lm 7 : mpi1: mpi1.c 8 : $(CC) -o mpi1 mpi1.c $(LIB) 9 : 10 : clean: 11 : -$(DEL) mpi1 make mpi1 1 % mpiru
43 6 MPI MPI(Message Passing Interface) MPI 1CPU/1 PC Cluster MPICH[5] 6.1 MPI MPI MPI 1 : #include 2 : #include 3 : #include 4 : 5 : #include "mpi.h" 7 : int main(int argc,
WinHPC ppt
MPI.NET C# 2 2009 1 20 MPI.NET MPI.NET C# MPI.NET C# MPI MPI.NET 1 1 MPI.NET C# Hello World MPI.NET.NET Framework.NET C# API C# Microsoft.NET java.net (Visual Basic.NET Visual C++) C# class Helloworld
Microsoft PowerPoint 並列アルゴリズム04.ppt
並列アルゴリズム 2005 年後期火曜 2 限 青柳睦 [email protected] http://server-500.cc.kyushu-u.ac.jp/ 11 月 8 日 ( 火 ) 5. MPI の基礎 6. 並列処理の性能評価 1 もくじ 1. 序並列計算機の現状 2. 計算方式およびアーキテクチュアの分類 3. 並列計算の目的と課題 4. 数値計算における各種の並列化
£Ã¥×¥í¥°¥é¥ß¥ó¥°ÆþÌç (2018) - Â裵²ó ¨¡ À©¸æ¹½Â¤¡§¾ò·ïʬ´ô ¨¡
(2018) 2018 5 17 0 0 if switch if if ( ) if ( 0) if ( ) if ( 0) if ( ) (0) if ( 0) if ( ) (0) ( ) ; if else if ( ) 1 else 2 if else ( 0) 1 if ( ) 1 else 2 if else ( 0) 1 if ( ) 1 else 2 (0) 2 if else
1 (bit ) ( ) PC WS CPU IEEE754 standard ( 24bit) ( 53bit)
GNU MP BNCpack [email protected] 2002 9 20 ( ) Linux Conference 2002 1 1 (bit ) ( ) PC WS CPU IEEE754 standard ( 24bit) ( 53bit) 10 2 2 3 4 5768:9:; = %? @BADCEGFH-I:JLKNMNOQP R )TSVU!" # %$ & " #
¥Ñ¥Ã¥±¡¼¥¸ Rhpc ¤Î¾õ¶·
Rhpc COM-ONE 2015 R 27 12 5 1 / 29 1 2 Rhpc 3 forign MPI 4 Windows 5 2 / 29 1 2 Rhpc 3 forign MPI 4 Windows 5 3 / 29 Rhpc, R HPC Rhpc, ( ), snow..., Rhpc worker call Rhpc lapply 4 / 29 1 2 Rhpc 3 forign
目 目 用方 用 用 方
大 生 大 工 目 目 用方 用 用 方 用 方 MS-MPI MPI.NET MPICH MPICH2 LAM/MPI Ver. 2 2 1 2 1 C C++ Fortan.NET C# C C++ Fortan 用 行 用 用 用 行 用 言 言 言 行 生 方 方 一 行 高 行 行 文 用 行 If ( rank == 0 ) { // 0 } else if (rank == 1) {
<4D F736F F F696E74202D C097F B A E B93C782DD8EE682E890EA97705D>
並列アルゴリズム 2005 年後期火曜 2 限青柳睦 [email protected] http//server-500.cc.kyushu-u.ac.jp/ 11 月 29( 火 ) 7. 集団通信 (Collective Communication) 8. 領域分割 (Domain Decomposition) 1 もくじ 1. 序並列計算機の現状 2. 計算方式およびアーキテクチュアの分類
£Ã¥×¥í¥°¥é¥ß¥ó¥°(2018) - Âè11²ó – ½ÉÂꣲ¤Î²òÀ⡤±é½¬£² –
(2018) 11 2018 12 13 2 g v dv x dt = bv x, dv y dt = g bv y (1) b v 0 θ x(t) = v 0 cos θ ( 1 e bt) (2) b y(t) = 1 ( v 0 sin θ + g ) ( 1 e bt) g b b b t (3) 11 ( ) p14 2 1 y 4 t m y > 0 y < 0 t m1 h = 0001
comment.dvi
( ) (sample1.c) (sample1.c) 2 2 Nearest Neighbor 1 (2D-class1.dat) 2 (2D-class2.dat) (2D-test.dat) 3 Nearest Neighbor Nearest Neighbor ( 1) 2 1: NN 1 (sample1.c) /* -----------------------------------------------------------------
Microsoft Word - 計算科学演習第1回3.doc
スーパーコンピュータの基本的操作方法 2009 年 9 月 10 日高橋康人 1. スーパーコンピュータへのログイン方法 本演習では,X 端末ソフト Exceed on Demand を使用するが, 必要に応じて SSH クライアント putty,ftp クライアント WinSCP や FileZilla を使用して構わない Exceed on Demand を起動し, 以下のとおり設定 ( 各自のユーザ
MPI usage
MPI (Version 0.99 2006 11 8 ) 1 1 MPI ( Message Passing Interface ) 1 1.1 MPI................................. 1 1.2............................... 2 1.2.1 MPI GATHER.......................... 2 1.2.2
£Ã¥×¥í¥°¥é¥ß¥ó¥°ÆþÌç (2018) - Â裱£²²ó ¡Ý½ÉÂꣲ¤Î²òÀ⡤±é½¬£²¡Ý
(2018) 2018 7 5 f(x) [ 1, 1] 3 3 1 3 f(x) dx c i f(x i ) 1 0 i=1 = 5 ) ( ) 3 ( 9 f + 8 5 9 f(0) + 5 3 9 f 5 1 1 + sin(x) θ ( 1 θ dx = tan 1 + sin x 2 π ) + 1 4 1 3 [a, b] f a, b double G3(double (*f)(),
ex01.dvi
,. 0. 0.0. C () /******************************* * $Id: ex_0_0.c,v.2 2006-04-0 3:37:00+09 naito Exp $ * * 0. 0.0 *******************************/ #include int main(int argc, char **argv) double
[1] #include<stdio.h> main() { printf("hello, world."); return 0; } (G1) int long int float ± ±
[1] #include printf("hello, world."); (G1) int -32768 32767 long int -2147483648 2147483647 float ±3.4 10 38 ±3.4 10 38 double ±1.7 10 308 ±1.7 10 308 char [2] #include int a, b, c, d,
2 T 1 N n T n α = T 1 nt n (1) α = 1 100% OpenMP MPI OpenMP OpenMP MPI (Message Passing Interface) MPI MPICH OpenMPI 1 OpenMP MPI MPI (trivial p
22 6 22 MPI MPI 1 1 2 2 3 MPI 3 4 7 4.1.................................. 7 4.2 ( )................................ 10 4.3 (Allreduce )................................. 12 5 14 5.1........................................
tuat1.dvi
( 1 ) http://ist.ksc.kwansei.ac.jp/ tutimura/ 2012 6 23 ( 1 ) 1 / 58 C ( 1 ) 2 / 58 2008 9 2002 2005 T E X ptetex3, ptexlive pt E X UTF-8 xdvi-jp 3 ( 1 ) 3 / 58 ( 1 ) 4 / 58 C,... ( 1 ) 5 / 58 6/23( )
演習 II 2 つの講義の演習 奇数回 : 連続系アルゴリズム 部分 偶数回 : 計算量理論 部分 連続系アルゴリズム部分は全 8 回を予定 前半 2 回 高性能計算 後半 6 回 数値計算 4 回以上の課題提出 ( プログラム + 考察レポート ) で単位
演習 II ( 連続系アルゴリズム ) 第 1 回 : MPI 須田研究室 M2 本谷徹 [email protected] 2012/10/05 2012/10/18 補足 訂正 演習 II 2 つの講義の演習 奇数回 : 連続系アルゴリズム 部分 偶数回 : 計算量理論 部分 連続系アルゴリズム部分は全 8 回を予定 前半 2 回 高性能計算 後半 6 回 数値計算 4 回以上の課題提出
joho07-1.ppt
0xbffffc5c 0xbffffc60 xxxxxxxx xxxxxxxx 00001010 00000000 00000000 00000000 01100011 00000000 00000000 00000000 xxxxxxxx x y 2 func1 func2 double func1(double y) { y = y + 5.0; return y; } double func2(double*
Microsoft PowerPoint - 演習2:MPI初歩.pptx
演習 2:MPI 初歩 - 並列に計算する - 2013 年 8 月 6 日 神戸大学大学院システム情報学研究科計算科学専攻横川三津夫 MPI( メッセージ パッシング インターフェース ) を使おう! [ 演習 2 の内容 ] はじめの一歩課題 1: Hello, world を並列に出力する. 課題 2: プロセス 0 からのメッセージを受け取る (1 対 1 通信 ). 部分に分けて計算しよう課題
内容に関するご質問は まで お願いします [Oakforest-PACS(OFP) 編 ] 第 85 回お試しアカウント付き並列プログラミング講習会 ライブラリ利用 : 科学技術計算の効率化入門 スパコンへのログイン テストプログラム起動 東京大学情報基盤セ
内容に関するご質問は [email protected] まで お願いします [Oakforest-PACS(OFP) 編 ] 第 85 回お試しアカウント付き並列プログラミング講習会 ライブラリ利用 : 科学技術計算の効率化入門 スパコンへのログイン テストプログラム起動 東京大学情報基盤センター特任准教授伊田明弘 1 講習会 : ライブラリ利用 [FX10] スパコンへのログイン ファイル転送
ex01.dvi
,. 0. 0.0. C () /******************************* * $Id: ex_0_0.c,v.2 2006-04-0 3:37:00+09 naito Exp $ * * 0. 0.0 *******************************/ #include int main(int argc, char **argv) { double
XcalableMP入門
XcalableMP 1 HPC-Phys@, 2018 8 22 XcalableMP XMP XMP Lattice QCD!2 XMP MPI MPI!3 XMP 1/2 PCXMP MPI Fortran CCoarray C++ MPIMPI XMP OpenMP http://xcalablemp.org!4 XMP 2/2 SPMD (Single Program Multiple Data)
±é½¬£²¡§£Í£Ð£É½éÊâ
2012 8 7 1 / 52 MPI Hello World I ( ) Hello World II ( ) I ( ) II ( ) ( sendrecv) π ( ) MPI fortran C wget http://www.na.scitec.kobe-u.ac.jp/ yaguchi/riken2012/enshu2.zip unzip enshu2.zip 2 / 52 FORTRAN
II ( ) prog8-1.c s1542h017%./prog8-1 1 => 35 Hiroshi 2 => 23 Koji 3 => 67 Satoshi 4 => 87 Junko 5 => 64 Ichiro 6 => 89 Mari 7 => 73 D
II 8 2003 11 12 1 6 ( ) prog8-1.c s1542h017%./prog8-1 1 => 35 Hiroshi 2 => 23 Koji 3 => 67 Satoshi 4 => 87 Junko 5 => 64 Ichiro 6 => 89 Mari 7 => 73 Daisuke 8 =>. 73 Daisuke 35 Hiroshi 64 Ichiro 87 Junko
Microsoft PowerPoint - 講義:片方向通信.pptx
MPI( 片方向通信 ) 09 年 3 月 5 日 神戸大学大学院システム情報学研究科計算科学専攻横川三津夫 09/3/5 KOBE HPC Spring School 09 分散メモリ型並列計算機 複数のプロセッサがネットワークで接続されており, れぞれのプロセッサ (PE) が, メモリを持っている. 各 PE が自分のメモリ領域のみアクセス可能 特徴数千から数万 PE 規模の並列システムが可能
( CUDA CUDA CUDA CUDA ( NVIDIA CUDA I
GPGPU (II) GPGPU CUDA 1 GPGPU CUDA(CUDA Unified Device Architecture) CUDA NVIDIA GPU *1 C/C++ (nvcc) CUDA NVIDIA GPU GPU CUDA CUDA 1 CUDA CUDA 2 CUDA NVIDIA GPU PC Windows Linux MaxOSX CUDA GPU CUDA NVIDIA
第1回 プログラミング演習3 センサーアプリケーション
C プログラミング - ポインタなんて恐くない! - 藤田悟 [email protected] 目標 C 言語プログラムとメモリ ポインタの関係を深く理解する C 言語プログラムは メモリを素のまま利用できます これが原因のエラーが多く発生します メモリマップをよく頭にいれて ポインタの動きを理解できれば C 言語もこわくありません 1. ポインタ入門編 ディレクトリの作成と移動 mkdir
Microsoft Word - C.....u.K...doc
C uwêííôöðöõ Ð C ÔÖÐÖÕ ÐÊÉÌÊ C ÔÖÐÖÕÊ C ÔÖÐÖÕÊ Ç Ê Æ ~ if eíè ~ for ÒÑÒ ÌÆÊÉÉÊ ~ switch ÉeÍÈ ~ while ÒÑÒ ÊÍÍÔÖÐÖÕÊ ~ 1 C ÔÖÐÖÕ ÐÊÉÌÊ uê~ ÏÒÏÑ Ð ÓÏÖ CUI Ô ÑÊ ÏÒÏÑ ÔÖÐÖÕÎ d ÈÍÉÇÊ ÆÒ Ö ÒÐÑÒ ÊÔÎÏÖÎ d ÉÇÍÊ
Microsoft PowerPoint - MPIprog-C2.ppt [互換モード]
MPI によるプログラミング概要 ( その ) C 言語編 RIKEN AICS HPC Summer School 01 中島研吾 ( 東大 情報基盤センター ) 横川三津夫 ( 神戸大学 計算科学教育センター ) 1 概要 MPI とは MPI の基礎 :Hello World 全体データと局所データ グループ通信 (Collective Communication) 1 対 1 通信 (Peer-to-Peer
第7章 有限要素法のプログラミング
April 3, 2019 1 / 34 7.1 ( ) 2 Poisson 2 / 34 7.2 femfp.c [1] main( ) input( ) assem( ) ecm( ) f( ) solve( ) gs { solve( ) output( ) 3 / 34 7.3 fopen() #include FILE *fopen(char *fname, char
/* do-while */ #include <stdio.h> #include <math.h> int main(void) double val1, val2, arith_mean, geo_mean; printf( \n ); do printf( ); scanf( %lf, &v
1 http://www7.bpe.es.osaka-u.ac.jp/~kota/classes/jse.html [email protected] /* do-while */ #include #include int main(void) double val1, val2, arith_mean, geo_mean; printf( \n );
新版明解C言語 実践編
2 List - "max.h" a, b max List - max "max.h" #define max(a, b) ((a) > (b)? (a) : (b)) max List -2 List -2 max #include "max.h" int x, y; printf("x"); printf("y"); scanf("%d", &x); scanf("%d", &y); printf("max(x,
j x j j j + 1 l j l j = x j+1 x j, n x n x 1 = n 1 l j j=1 H j j + 1 l j l j E
8 9 7 6 4 2 3 5 1 j x j j j + 1 l j l j = x j+1 x j, n x n x 1 = n 1 l j j=1 H j j + 1 l j l j E a n 1 H = ae l j, j=1 l j = x j+1 x j, x n x 1 = n 1 j=1 l j, l j = ±l l > 0) n 1 H = ϵ l j, j=1 ϵ e x x
実際の株価データを用いたオプション料の計算
2002 2 20 1 1 3 2 3 2.1 : : : : : : : : : : : : : : : : : : : : : : : : : : : : 5 2.1.1 : : : : : : : : : : : : : : : : : : : : 5 2.1.2 : : : : : : : : : : : : : : : : : : : : 6 2.2 : : : : : : : : : :
ex14.dvi
1,, 0, b (b b 2 b ) n k n = n j b j, (0 n j b 1), n =(n k n k 1...n 1 n 0 ) b, n j j j +1, 0,...,b 1 (digit). b b, n b 1 ñ, ñ = k (b 1 n j )b j b N, n b n, n = b N n, n =ñ+1 b N, n m n + m (mod b N ),
1.ppt
/* * Program name: hello.c */ #include int main() { printf( hello, world\n ); return 0; /* * Program name: Hello.java */ import java.io.*; class Hello { public static void main(string[] arg)
(K&R 2.9) ~, &,, >>, << 2. (K&R 5.7) 3. (K&R 5.9) 4. (K&R 5.10) (argc argv atoi(), atof() ) 5. (K&R 7.5) (K&R 7.6) - FILE, stdin, stdout, std
3 3 1. 1 (K&R.9) ~, &,, >>,
新・明解C言語 実践編
第 1 章 見 21 1-1 見えないエラー 見 List 1-1 "max2x1.h" a, b max2 List 1-1 chap01/max2x1.h max2 "max2x1.h" #define max2(a, b) ((a) > (b)? (a) : (b)) max2 List 1-2 List 1-2 chap01/max2x1test.c max2 #include
untitled
II yacc 005 : 1, 1 1 1 %{ int lineno=0; 3 int wordno=0; 4 int charno=0; 5 6 %} 7 8 %% 9 [ \t]+ { charno+=strlen(yytext); } 10 "\n" { lineno++; charno++; } 11 [^ \t\n]+ { wordno++; charno+=strlen(yytext);}
r07.dvi
19 7 ( ) 2019.4.20 1 1.1 (data structure ( (dynamic data structure 1 malloc C free C (garbage collection GC C GC(conservative GC 2 1.2 data next p 3 5 7 9 p 3 5 7 9 p 3 5 7 9 1 1: (single linked list 1
ohp07.dvi
19 7 ( ) 2019.4.20 1 (data structure) ( ) (dynamic data structure) 1 malloc C free 1 (static data structure) 2 (2) C (garbage collection GC) C GC(conservative GC) 2 2 conservative GC 3 data next p 3 5
£Ã¥×¥í¥°¥é¥ß¥ó¥°ÆþÌç (2018) - Â裶²ó ¨¡ À©¸æ¹½Â¤¡§·«¤êÊÖ¤· ¨¡
(2018) 2018 5 24 ( ) while ( ) do while ( ); for ( ; ; ) while int i = 0; while (i < 100) { printf("i = %3d\n", i); i++; while int i = 0; i while (i < 100) { printf("i = %3d\n", i); i++; while int i =
memo
数理情報工学演習第一 C プログラミング演習 ( 第 5 回 ) 2015/05/11 DEPARTMENT OF MATHEMATICAL INFORMATICS 1 今日の内容 : プロトタイプ宣言 ヘッダーファイル, プログラムの分割 課題 : 疎行列 2 プロトタイプ宣言 3 C 言語では, 関数や変数は使用する前 ( ソースの上のほう ) に定義されている必要がある. double sub(int
( ) 1 1: 1 #include <s t d i o. h> 2 #include <GL/ g l u t. h> 3 #include <math. h> 4 #include <s t d l i b. h> 5 #include <time. h>
2007 12 5 1 2 2.1 ( ) 1 1: 1 #include 2 #include 3 #include 4 #include 5 #include 6 7 #define H WIN 400 // 8 #define W WIN 300 // 9
C 2 / 21 1 y = x 1.1 lagrange.c 1 / Laglange / 2 #include <stdio.h> 3 #include <math.h> 4 int main() 5 { 6 float x[10], y[10]; 7 float xx, pn, p; 8 in
C 1 / 21 C 2005 A * 1 2 1.1......................................... 2 1.2 *.......................................... 3 2 4 2.1.............................................. 4 2.2..............................................
120802_MPI.ppt
CPU CPU CPU CPU CPU SMP Symmetric MultiProcessing CPU CPU CPU CPU CPU CPU CPU CPU CPU CPU CPU CPU CP OpenMP MPI MPI CPU CPU CPU CPU CPU CPU CPU CPU CPU CPU MPI MPI+OpenMP CPU CPU CPU CPU CPU CPU CPU CP
C
C 1 2 1.1........................... 2 1.2........................ 2 1.3 make................................................ 3 1.4....................................... 5 1.4.1 strip................................................
lexex.dvi
(2018, c ) http://istksckwanseiacjp/ ishiura/cpl/ 4 41 1 mini-c lexc,, 2 testlexc, lexc mini-c 1 ( ) mini-c ( ) (int, char, if, else, while, return 6 ) ( ) (+, -, *, /, %, &, =, ==,!=, >, >=,
Fundamental MPI 1 概要 MPI とは MPI の基礎 :Hello World 全体データと局所データタ グループ通信 (Collective Communication) 1 対 1 通信 (Point-to-Point Communication)
MPI 超 入門 (C 言語編 ) 東京大学情報基盤センター FOTRAN 編は以下 http://nkl.cc.u-tokyo.ac.jp/seminars/t2kfvm/mpiprogf.pdf tokyo pdf Fundamental MPI 1 概要 MPI とは MPI の基礎 :Hello World 全体データと局所データタ グループ通信 (Collective Communication)
CM-3G 周辺モジュール拡張技術文書 MS5607センサ(温度、気圧)
CM-3G 周辺モジュール拡張技術文書 MS5607 センサ ( 温度 気圧 ) ( 第 1 版 ) Copyright (C)2016 株式会社コンピューテックス 目次 1. はじめに... 1 2. MS5607 について... 1 3. 接続図... 1 4. アプリケーション ソース... 2 5. アプリケーションのコンパイル方法... 7 6. アプリケーションの実行... 8 1. はじめに
1) OOP 2) ( ) 3.2) printf Number3-2.cpp #include <stdio.h> class Number Number(); // ~Number(); // void setnumber(float n); float getnumber();
: : :0757230G :2008/07/18 2008/08/17 1) OOP 2) ( ) 3.2) printf Number3-2.cpp #include class Number Number(); // ~Number(); // void setnumber(float n); float getnumber(); private: float num; ;
