Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F100124634
ping_pong.cc
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Subscribers
None
File Metadata
Details
File Info
Storage
Attached
Created
Tue, Jan 28, 08:33
Size
1 KB
Mime Type
text/x-c
Expires
Thu, Jan 30, 08:33 (1 d, 23 h)
Engine
blob
Format
Raw Data
Handle
23904730
Attached To
R11821 phys-743-lecture
ping_pong.cc
View Options
#include "print_size.hh"
#include <chrono>
#include <iomanip>
#include <iostream>
#include <mpi.h>
#include <vector>
void
fill_buffer
(
std
::
vector
<
int
>
&
buf
,
size_t
size
)
{
buf
.
resize
(
size
);
for
(
auto
&
v
:
buf
)
{
v
=
0
;
}
}
using
clk
=
std
::
chrono
::
high_resolution_clock
;
using
second
=
std
::
chrono
::
duration
<
double
>
;
int
main
()
{
int
prank
,
psize
;
const
auto
N
{
30
};
size_t
REP
{
1000
};
MPI_Init
(
NULL
,
NULL
);
MPI_Comm_rank
(
MPI_COMM_WORLD
,
&
prank
);
MPI_Comm_size
(
MPI_COMM_WORLD
,
&
psize
);
std
::
vector
<
int
>
buf
;
auto
partner
=
(
prank
+
1
)
%
psize
;
for
(
size_t
n
=
0
;
n
<
N
;
++
n
)
{
auto
size
=
1
<<
n
;
fill_buffer
(
buf
,
size
);
if
(
size
>
256
)
REP
=
1
;
auto
t_start
=
clk
::
now
();
for
(
size_t
repetition
=
0
;
repetition
<
REP
;
++
repetition
)
{
if
(
prank
==
0
)
{
MPI_Send
(
buf
.
data
(),
buf
.
size
(),
MPI_INT
,
partner
,
0
,
MPI_COMM_WORLD
);
MPI_Recv
(
buf
.
data
(),
buf
.
size
(),
MPI_INT
,
partner
,
0
,
MPI_COMM_WORLD
,
MPI_STATUS_IGNORE
);
}
else
{
MPI_Recv
(
buf
.
data
(),
buf
.
size
(),
MPI_INT
,
partner
,
0
,
MPI_COMM_WORLD
,
MPI_STATUS_IGNORE
);
MPI_Send
(
buf
.
data
(),
buf
.
size
(),
MPI_INT
,
partner
,
0
,
MPI_COMM_WORLD
);
}
}
second
time
=
clk
::
now
()
-
t_start
;
if
(
prank
==
0
)
{
auto
size_b
=
size
*
sizeof
(
int
);
auto
time_s
=
time
.
count
()
/
REP
/
2.
;
std
::
cout
<<
"PingPong"
<<
" size: "
<<
std
::
setw
(
10
)
<<
printHuman
(
size_b
,
"B"
,
2
)
<<
" time: "
<<
std
::
setw
(
10
)
<<
printHuman
(
time_s
,
"s"
)
<<
" bandwidth: "
<<
std
::
setw
(
10
)
<<
printHuman
(
size_b
/
time_s
,
"B/s"
)
<<
std
::
endl
;
}
}
MPI_Finalize
();
return
0
;
}
Event Timeline
Log In to Comment