Skip to content

Commit

Permalink
Add timer to basic_io example
Browse files Browse the repository at this point in the history
  • Loading branch information
yncxcw committed Nov 25, 2023
1 parent dffcc3b commit c4dad0c
Showing 1 changed file with 42 additions and 1 deletion.
43 changes: 42 additions & 1 deletion cpp/examples/basic_io.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@
* limitations under the License.
*/

#include <chrono>
#include <iostream>

#include <cuda_runtime_api.h>
Expand All @@ -27,6 +28,27 @@

using namespace std;

class Timer {
public:
Timer(const std::string& name) : name(name), start(std::chrono::high_resolution_clock::now()) {}

~Timer()
{
auto end = std::chrono::high_resolution_clock::now();
auto start_ms =
std::chrono::time_point_cast<std::chrono::microseconds>(start).time_since_epoch().count();
auto end_ms =
std::chrono::time_point_cast<std::chrono::microseconds>(end).time_since_epoch().count();

std::cout << "Benchmark " << name << " takes: " << end_ms - start_ms << " microseconds"
<< std::endl;
}

private:
std::string name;
std::chrono::time_point<std::chrono::high_resolution_clock> start;
};

void check(bool condition)
{
if (!condition) {
Expand Down Expand Up @@ -82,6 +104,7 @@ int main()
check(kvikio::is_host_memory(c_dev) == false);

{
Timer timer("Write");
kvikio::FileHandle f("/tmp/test-file", "w");
check(cudaMemcpy(a_dev, a, SIZE, cudaMemcpyHostToDevice) == cudaSuccess);
size_t written = f.pwrite(a_dev, SIZE, 0, 1).get();
Expand All @@ -90,6 +113,8 @@ int main()
cout << "Write: " << written << endl;
}
{
std::cout << std::endl;
Timer timer("Read");
kvikio::FileHandle f("/tmp/test-file", "r");
size_t read = f.pread(b_dev, SIZE, 0, 1).get();
check(read == SIZE);
Expand All @@ -102,6 +127,8 @@ int main()
}
kvikio::defaults::thread_pool_nthreads_reset(16);
{
std::cout << std::endl;
Timer timer("Parallel write");
kvikio::FileHandle f("/tmp/test-file", "w");
size_t written = f.pwrite(a_dev, SIZE).get();
check(written == SIZE);
Expand All @@ -110,16 +137,20 @@ int main()
<< " threads): " << written << endl;
}
{
std::cout << std::endl;
Timer timer("Parallel read");
kvikio::FileHandle f("/tmp/test-file", "r");
size_t read = f.pread(b_dev, SIZE, 0).get();
cout << "Parallel write (" << kvikio::defaults::thread_pool_nthreads() << " threads): " << read
cout << "Parallel read (" << kvikio::defaults::thread_pool_nthreads() << " threads): " << read
<< endl;
check(cudaMemcpy(b, b_dev, SIZE, cudaMemcpyDeviceToHost) == cudaSuccess);
for (int i = 0; i < NELEM; ++i) {
check(a[i] == b[i]);
}
}
{
std::cout << std::endl;
Timer timer("Reader buffer registered data");
kvikio::FileHandle f("/tmp/test-file", "r+", kvikio::FileHandle::m644);
kvikio::buffer_register(c_dev, SIZE);
size_t read = f.pread(c_dev, SIZE).get();
Expand All @@ -129,6 +160,8 @@ int main()
cout << "Read buffer registered data: " << read << endl;
}
{
std::cout << std::endl;
Timer timer("Parallel POSIX write");
kvikio::FileHandle f("/tmp/test-file", "w");
size_t written = f.pwrite(a, SIZE).get();
check(written == SIZE);
Expand All @@ -137,6 +170,8 @@ int main()
<< " threads): " << written << endl;
}
{
std::cout << std::endl;
Timer timer("Parallel POSIX read");
kvikio::FileHandle f("/tmp/test-file", "r");
size_t read = f.pread(b, SIZE).get();
check(read == SIZE);
Expand All @@ -148,6 +183,8 @@ int main()
<< " threads): " << read << endl;
}
if (kvikio::is_batch_and_stream_available() && !kvikio::defaults::compat_mode()) {
std::cout << std::endl;
Timer timer("Batch read");
// Here we use the batch API to read "/tmp/test-file" into `b_dev` by
// submitting 4 batch operations.
constexpr int num_ops_in_batch = 4;
Expand Down Expand Up @@ -198,6 +235,8 @@ int main()
cout << "The batch API isn't available, requires CUDA 12.2+" << endl;
}
{
std::cout << std::endl;
Timer timer("Async IO by reference");
cout << "Performing async I/O using by-reference arguments" << endl;
off_t f_off{0};
off_t d_off{0};
Expand Down Expand Up @@ -231,6 +270,8 @@ int main()
check(cudaFreeHost((void*)bytes_done_p) == cudaSuccess);
}
{
std::cout << std::endl;
Timer timer("Async IO by-value");
cout << "Performing async I/O using by-value arguments" << endl;

// Let's create a new stream and submit an async write
Expand Down

0 comments on commit c4dad0c

Please sign in to comment.