我在opencv中乘以2个矩阵(Mat对象)。
以下是第一个Mat的生成方式:
cv::Mat R(m, k, CV_8UC1);
rm.generateRandomMatrix(m, k, 255, R);
以下是如何生成第二个:
for (int i=0; i<=n; i++)
{
randomMatrix_Xi rm;
cv::Mat Xi(k, 1, CV_8UC1);
rm.generateRandomMatrix(k, 1, 255, Xi);
random_Xi_Vectors.push_back(Xi);
sleep(2);
}
这是我在两个地方使用的generateRandomMatrix()函数定义:
int randomMatrix_Xi::generateRandomMatrix(int m, int k, int range, cv::Mat R)
{
typedef boost::mt19937 RNGType;
RNGType rng(std::time(0));
boost::uniform_int<> one_to_range( 1, range);
boost::variate_generator< RNGType, boost::uniform_int<> > number_generator(rng, one_to_range);
for (int j=0; j<k; j++)
{
for ( int i = 0; i < m; i++ )
{
int n = number_generator();
R.at<uchar>(i,j) = n;
//std::cout<<"Putting "<<n<<" at"<<i<<", "<<j<<std::endl;
}
}
}
最后,这里是我正在进行两个Mat的乘法运算的地方:
for (int i = 0; i < n; i++)
{
std::cout<<" Sizes of matrices to be multiplied: "<<std::endl;
cv::Size Xi_size = random_Xi_Vectors[i].size();
cv::Size A_size = R.size();
std::cout<<"R : "<<A_size.height<<" "<<A_size.width<<std::endl;
std::cout<<"Xi : "<<Xi_size.height<<" "<<Xi_size.width<<std::endl;
cv::Mat temp(960,1, CV_8UC1);
cv::Mat temp = random_Xi_Vectors[i] * R;
shares.push_back(temp);
}
这是我得到的错误:
r@r-HP-Mini-110:~/l33t/Secret Sharing$ ./mainProgram Sizes of matrices to be multiplied:
R : 960 2
Xi : 2 1
OpenCV Error: Assertion failed (type == B.type() && (type == CV_32FC1 || type == CV_64FC1 || type == CV_32FC2 || type == CV_64FC2)) in gemm, file /build/buildd/opencv-2.3.1/modules/core/src/matmul.cpp, line 701
terminate called after throwing an instance of 'cv::Exception'
what(): /build/buildd/opencv-2.3.1/modules/core/src/matmul.cpp:701: error: (-215) type == B.type() && (type == CV_32FC1 || type == CV_64FC1 || type == CV_32FC2 || type == CV_64FC2) in function gemm
Aborted (core dumped)
r@r-HP-Mini-110:~/l33t/Secret Sharing$
如您所见,第一个Mat中的列数与第二个Mat中的行数相匹配。此外,Mat的类型相同,即CV_8UC1
。那么为什么我会收到这个错误。请帮忙。
答案 0 :(得分:6)
(type == CV_32FC1 || type == CV_64FC1 || type == CV_32FC2 || type == CV_64FC2)
清楚地说,你只能乘以浮点Mat的
所以使用CV_32FC1
(浮点)或CV_64FC1
(双)垫而不是CV_8UC1
(代码如下:
boost::variate_generator<RNGType,boost::uniform_int<>> number_generator(rng,one_to_range);
也可能需要改变,不确定)