#include "concat.cuh" #include #include #include TEST(ConcatLayerTest, Init) { std::vector inputA = {0.573f, 0.619f, 0.732f, 0.055f, 0.243f}; std::vector inputB = {0.123f, 0.321f, 0.456f, 0.789f, 0.654f, 0.123f}; CUDANet::Layers::Concat concat(5, 6); float* d_inputA; float* d_inputB; cudaMalloc((void**)&d_inputA, sizeof(float) * 5); cudaMalloc((void**)&d_inputB, sizeof(float) * 6); cudaMemcpy( d_inputA, inputA.data(), sizeof(float) * 5, cudaMemcpyHostToDevice ); cudaMemcpy( d_inputB, inputB.data(), sizeof(float) * 6, cudaMemcpyHostToDevice ); float* d_output = concat.forward(d_inputA, d_inputB); std::vector output(11); cudaMemcpy( output.data(), d_output, sizeof(float) * 11, cudaMemcpyDeviceToHost ); for (int i = 0; i < 5; ++i) { EXPECT_EQ(output[i], inputA[i]); } for (int i = 0; i < 6; ++i) { EXPECT_EQ(output[i + 5], inputB[i]); } cudaFree(d_output); cudaDeviceReset(); }