- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我正在使用 C++ ublas 库编写 Matlab 扩展,我希望能够从 Matlab interpeter 传递的 C 数组初始化我的 ublas vector 。如何在不(为了提高效率)显式复制数据的情况下从 C 数组初始化 ublas vector 。我正在寻找以下代码行的内容:
using namespace boost::numeric::ublas;
int pv[10] = { 5, 5, 5, 5, 5, 5, 5, 5, 5, 5 };
vector<int> v (pv);
一般来说,是否可以从数组初始化 C++ std::vector
?像这样:
#include <iostream>
#include <vector>
using namespace std;
int main()
{
int pv[4] = { 4, 4, 4, 4};
vector<int> v (pv, pv+4);
pv[0] = 0;
cout << "v[0]=" << v[0] << " " << "pv[0]=" << pv[0] << endl;
return 0;
}
但是初始化的地方不会复制数据。在这种情况下,输出是
v[0]=4 pv[0]=0
但我希望输出相同,更新 C 数组会更改 C++ vector 指向的数据
v[0]=0 pv[0]=0
最佳答案
我不确定您的问题与 MATLAB/MEX 有什么关系,但附带说明一下,您可能想知道 MATLAB 实现了写时复制策略。
这意味着当你复制一个数组时,实际上只复制了一些标题,而数据本身在两个数组之间共享。一旦其中一个被修改,实际上就制作了一份数据。
以下是对引擎盖下可能发生的事情的模拟(借自此 old post ):
-----------------------------------------
>> a = [35.7 100.2 1.2e7];
mxArray a
pdata -----> 35.7 100.2 1.2e7
crosslink=0
-----------------------------------------
>> b = a;
mxArray a
pdata -----> 35.7 100.2 1.2e7
crosslink / \
| / \ |
| | |
| | |
\ / | |
crosslink |
mxArray b |
pdata --------
-----------------------------------------
>> a(1) = 1;
mxArray a
pdata -----> (1) 100.2 1.2e7
crosslink=0
crosslink=0
mxArray b
pdata ------> 35.7 100.2 1.2e7 ...
我知道这并不能真正回答您的问题,我只是认为您可能会发现这个概念有帮助。
关于c++ - 从 C 数组初始化 ublas vector ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1735841/
我是 Boost::uBLAS 的菜鸟。 我有一个接受 ublas::matrix_expression 的函数作为输入: namespace ublas = boost::numeric::ubla
我正在寻找一种优雅的方式来实现它。基本上我有一个 m x n 矩阵。其中每个单元格代表像素值,行和列代表图像的像素行和像素列。 因为我基本上是从 HDF 文件映射点及其对应的像素值。我们基本上有很多空
我有一个 uBLAS 矩阵,像这样: boost::numeric::ublas::matrix mat(50000,50000); 完成矩阵的一组计算后,我希望释放它的内存。 我一直在使用 mat.
我正在尝试通过在我的 .h 文件中定义 vector 来初始化/分配值给 ublas vector : someClass{ ublas::vector *L; } ; 然后在我的 .cpp
我读了一篇关于使用动态规划优化矩阵嵌套乘积的文章,我想看看它是如何在 boost::uBLAS 中实现的。 我不确定我是否理解 the documentation (他们在页面的最后谈论它),但似乎他
根据 this page ublas 中应该有一个 sum 函数,但我无法编译以下内容: boost::numeric::ublas::matrix mymatrix; std::cout #inc
有没有办法 boost boost ublas 产品的性能? 我有两个矩阵 A,B,我想对其进行多重/添加/子/... 在 MATLAB 与 C++ 中,对于 2000x2000 矩阵运算,我得到以下
我有以下包含 O(N) 元素的稀疏矩阵 boost::numeric::ublas::compressed_matrix adjacency (N, N); 我可以像下面这样在 O(N^2) 时间内编
尝试在最初未指定大小的矩阵中插入元素时出现运行时错误。 下面的代码为 m1 运行 finr 但为 m2 抛出错误。 #include #include #include int main
我正在尝试计算 Boost Ublas 矩阵的所有元素的平方根。到目前为止,我有这个,而且它有效。 #include #include "boost\numeric\ublas\matrix.hpp
我想知道是否有可能获取 Boost uBLAS 矩阵的单个元素的地址? 也就是 boost::numeric::ublas::matrix bob(3,3); some_function(&bob[2
我是 C++ Boost uBLAS 库的新手,所以我有一个菜鸟问题 - 如何使用这个库转置矩阵?我在这里找不到问题: http://www.boost.org/doc/libs/1_44_0/lib
我正在尝试实现某些矩阵运算,但我迷失在 ublas 库的内部。是否有关于如何实现新的 ublas 矩阵表达式的教程或示例等资源? 谢谢 最佳答案 不知道它是否会有所帮助,但有一个关于扩展 uBlas
我正在用 C++ 编写一个用于双曲偏微分方程的软件。几乎所有的符号都是 vector 和矩阵的。最重要的是,我需要线性代数求解器。是的, vector 和矩阵的大小可以有很大差异(从 1000 到只能
我正在调试一个大量使用 uBLAS vector 和矩阵的应用程序。我想打印它们以使用类似以下内容的控制台: boost::numeric::ublas::vector v; // ...fillin
我在使用 boost::ublas 矩阵时需要虚拟析构函数吗? 顺便说一下,我的类是一个模板类。 最佳答案 你是说你有这个吗? template struct my_class { // .
我目前正在研究一种算法,该算法需要找到矩阵中某项的所有相同出现次数。我决定使用来自 boost 的 uBLAS 矩阵。所以我的问题是: 我有一个 ublas::matrix 看起来像: 1 2 3 4
我收到一个编译器错误 /Developer/boost/boost/numeric/ublas/expression_types.hpp:184:16: fatal error: recursive
我想将特定的 boost ublas vector 声明为全局变量。问题是函数外的声明总是会导致错误。 这是一个具体的例子: 以下代码将给出多个错误:( error C2143: syntax err
我正在尝试做这样的事情 #include using namespace boost::numeric::ublas; class A{ protected: vector a_; pu
我是一名优秀的程序员,十分优秀!