1 How to access data using raw pointers
2 =====================================
4 One of the advantages of the ndarray wrapper is that the same data can be used in both Python and C++ and changes can be made to reflect at both ends.
5 The from_data method makes this possible.
7 Like before, first get the necessary headers, setup the namespaces and initialize the Python runtime and numpy module::
9 #include <boost/python/numpy.hpp>
12 namespace p = boost::python;
13 namespace np = boost::python::numpy;
15 int main(int argc, char **argv)
20 Create an array in C++ , and pass the pointer to it to the from_data method to create an ndarray::
22 int arr[] = {1,2,3,4,5};
23 np::ndarray py_array = np::from_data(arr, np::dtype::get_builtin<int>(),
25 p::make_tuple(sizeof(int)),
28 Print the source C++ array, as well as the ndarray, to check if they are the same::
30 std::cout << "C++ array :" << std::endl;
33 std::cout << arr[j] << ' ';
35 std::cout << std::endl
36 << "Python ndarray :" << p::extract<char const *>(p::str(py_array)) << std::endl;
38 Now, change an element in the Python ndarray, and check if the value changed correspondingly in the source C++ array::
41 std::cout << "Is the change reflected in the C++ array used to create the ndarray ? " << std::endl;
42 for (int j = 0; j < 5; j++)
44 std::cout << arr[j] << ' ';
47 Next, change an element of the source C++ array and see if it is reflected in the Python ndarray::
50 std::cout << std::endl
51 << "Is the change reflected in the Python ndarray ?" << std::endl
52 << p::extract<char const *>(p::str(py_array)) << std::endl;
55 As we can see, the changes are reflected across the ends. This happens because the from_data method passes the C++ array by reference to create the ndarray, and thus uses the same locations for storing data.