从双指针构建箭头双环

Construct an Arrow DoubleArray from double pointer

本文关键字:构建 指针      更新时间:2023-10-16

我有一个二维双阵列指针。我可以将其施放到u_int8_t,将其获取到箭头池缓冲区的mutable_data(),然后构造箭头Doublearray。但是,当我从数组的Value()raw_values()获得值时,我无法获得正确的数字。有人请查看我的代码并帮助我:

double* generateDoubleArray() {
    int totalColumns = 200;
    int totalRows = 200;
    std::random_device r;
    std::default_random_engine e1(r());
    std::normal_distribution<double> nor_dist(-1, 1);
    double *A = static_cast<double *>(malloc(totalColumns * totalRows * sizeof(double *)));
    for (int i = 0; i < totalRows; i++) {
        for (int j = 0; j < totalColumns; j++) {
            A[i*totalColumns + j] = sin(nor_dist(e1)) + exp(sin(nor_dist(e1)) + cos(nor_dist(e1)));
        }
    }
    return A;
}
int main()
{
    double* generatedDouble = generateDoubleArray();
    uint8_t *ui_generatedDouble = (uint8_t*)generatedDouble;
    arrow::MemoryPool* pool_;
    pool_ = arrow::default_memory_pool();
    auto data = std::make_shared<arrow::PoolBuffer>(pool_);
    size_t length = 200 * 200;
    const size_t data_nbytes = length * sizeof(double *);
    data->Resize(data_nbytes);
    *data->mutable_data() = *ui_generatedDouble;
    auto out = std::make_shared<arrow::DoubleArray>(data_nbytes, data);
    double test_value = out->Value(0); // The returned value is not correct
    return 0;
}

谢谢

以下行不执行您的想法:

*data->mutable_data() = *ui_generatedDouble;

它仅复制数据的第一个字节。您想组成整个缓冲区:

std::memcpy(data->mutable_data(), ui_generatedDouble, data_nbytes);