Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Backport release-1.5] [r] Replace three local utility functions with use of RcppInt64 #1724

Merged
merged 1 commit into from
Sep 27, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 2 additions & 1 deletion apis/r/DESCRIPTION
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,8 @@ Imports:
tibble
LinkingTo:
Rcpp,
RcppSpdlog
RcppSpdlog,
RcppInt64
Additional_repositories: https://ghrr.github.io/drat
Roxygen: list(markdown = TRUE)
RoxygenNote: 7.2.3
Expand Down
3 changes: 2 additions & 1 deletion apis/r/src/rinterface.cpp
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
#include <Rcpp.h> // for R interface to C++
#include <nanoarrow.h> // for C interface to Arrow
#include <RcppInt64> // for fromInteger64

// we currently get deprecation warnings by default which are noisy
#ifndef TILEDB_NO_API_DEPRECATION_WARNINGS
Expand Down Expand Up @@ -233,5 +234,5 @@ bool check_arrow_array_tag(Rcpp::XPtr<ArrowArray> xp) {
Rcpp::NumericVector shape(const std::string& uri,
Rcpp::Nullable<Rcpp::CharacterVector> config = R_NilValue) {
auto sr = tdbs::SOMAArray::open(OpenMode::read, uri, "unnamed", config_vector_to_map(Rcpp::wrap(config)));
return makeInteger64(sr->shape());
return Rcpp::toInteger64(sr->shape());
}
13 changes: 7 additions & 6 deletions apis/r/src/rutilities.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@

#include <Rcpp.h> // for R interface to C++
#include <nanoarrow.h> // for C interface to Arrow
#include <RcppInt64> // for fromInteger64

// We get these via nanoarrow and must cannot include carrow.h again
#define ARROW_SCHEMA_AND_ARRAY_DEFINED 1
Expand All @@ -26,7 +27,7 @@ void apply_dim_points(tdbs::SOMAArray *sr,
bool suitable = false;
if (tp == TILEDB_UINT64) {
Rcpp::NumericVector payload = lst[nm];
std::vector<int64_t> iv = getInt64Vector(payload);
std::vector<int64_t> iv = Rcpp::fromInteger64(payload, false);
std::vector<uint64_t> uv(iv.size());
const std::pair<uint64_t,uint64_t> pr = dm->domain<uint64_t>();
for (size_t i=0; i<iv.size(); i++) {
Expand All @@ -39,7 +40,7 @@ void apply_dim_points(tdbs::SOMAArray *sr,
}
} else if (tp == TILEDB_INT64) {
Rcpp::NumericVector payload = lst[nm];
std::vector<int64_t> iv = getInt64Vector(payload);
std::vector<int64_t> iv = Rcpp::fromInteger64(payload, false);
const std::pair<int64_t,int64_t> pr = dm->domain<int64_t>();
for (size_t i=0; i<iv.size(); i++) {
if (iv[i] >= pr.first && iv[i] <= pr.second) {
Expand Down Expand Up @@ -103,17 +104,17 @@ void apply_dim_ranges(tdbs::SOMAArray* sr,
std::vector<std::pair<uint64_t, uint64_t>> vp(mm.nrow());
const std::pair<uint64_t,uint64_t> pr = dm->domain<uint64_t>();
for (int i=0; i<mm.nrow(); i++) {
uint64_t l = static_cast<uint64_t>(makeScalarInteger64(lo[i]));
uint64_t h = static_cast<uint64_t>(makeScalarInteger64(hi[i]));
uint64_t l = static_cast<uint64_t>(Rcpp::fromInteger64(lo[i]));
uint64_t h = static_cast<uint64_t>(Rcpp::fromInteger64(hi[i]));
vp[i] = std::make_pair(std::max(l,pr.first), std::min(h, pr.second));
spdl::info("[apply_dim_ranges] Applying dim point {} on {} with {} - {}", i, nm, l, h) ;
suitable = l < pr.second && h > pr.first; // lower must be less than max, higher more than min
}
if (suitable) sr->set_dim_ranges<uint64_t>(nm, vp);
} else if (tp == TILEDB_INT64) {
Rcpp::NumericMatrix mm = lst[nm];
std::vector<int64_t> lo = getInt64Vector(mm.column(0));
std::vector<int64_t> hi = getInt64Vector(mm.column(1));
std::vector<int64_t> lo = Rcpp::fromInteger64(mm.column(0), false);
std::vector<int64_t> hi = Rcpp::fromInteger64(mm.column(1), false);
std::vector<std::pair<int64_t, int64_t>> vp(mm.nrow());
const std::pair<int64_t,int64_t> pr = dm->domain<int64_t>();
for (int i=0; i<mm.nrow(); i++) {
Expand Down
42 changes: 3 additions & 39 deletions apis/r/src/rutilities.h
Original file line number Diff line number Diff line change
Expand Up @@ -12,45 +12,9 @@ namespace tdbs = tiledbsoma;
#define TileDB_Version(v, m, p) (((v)*65536) + ((m)*256) + (p))

// current build is encoded in TILEDB_VERSION
#define TILEDB_VERSION \
TileDB_Version( \
TILEDB_VERSION_MAJOR, TILEDB_VERSION_MINOR, TILEDB_VERSION_PATCH)

// Create a integer64 object
//
// Integer64 is an S3 class. Integers in R are 32-bits. To handle C++
// signed 64-bit integers (int64_t), the full bits may be stored using double '
// as an intermediary which then can be coereced to Integer64.
// For more on this see e.g.
// https://gallery.rcpp.org/articles/creating-integer64-and-nanotime-vectors/
//
inline Rcpp::NumericVector makeInteger64(const std::vector<int64_t>& vec) {
size_t n = vec.size();

Rcpp::NumericVector num(n);
std::memcpy(&(num[0]), vec.data(), n * sizeof(double));

num.attr("class") = "integer64";
return (num);
}

// Convert to a scalar int64_t
//
inline int64_t makeScalarInteger64(const double val) {
int64_t newval;
memcpy(&newval, &val, sizeof(double));
return newval;
}

// Create a int64_t vector from a NumericVector
//
inline std::vector<int64_t> getInt64Vector(Rcpp::NumericVector vec) {
size_t n = vec.size();
std::vector<int64_t> num(n);
std::memcpy(&(num[0]), &(vec[0]), n * sizeof(double));
return num;
}

#define TILEDB_VERSION TileDB_Version(TILEDB_VERSION_MAJOR, \
TILEDB_VERSION_MINOR, \
TILEDB_VERSION_PATCH)

// Applies (named list of) vectors of points to the named dimensions
void apply_dim_points(
Expand Down