OPenCV中累加一个三通道矩阵中的所有元素:
程序为:floatsum(constCvMat*mat){floats=0.0f;for(introw=0;row<mat->rows;row++){constfloat...
程序为:
float sum( const CvMat* mat )
{
float s = 0.0f;
for(int row=0; row<mat->rows; row++ )
{
const float* ptr=(const float*)(mat->data.ptr + row * mat->step);
for( col=0; col<mat->cols; col++ )
{
s += *ptr++;
}
}
return( s );
}
我想问const float* ptr=(const float*)(mat->data.ptr + row * mat->step); 这句程序的详细意思,看不懂 展开
float sum( const CvMat* mat )
{
float s = 0.0f;
for(int row=0; row<mat->rows; row++ )
{
const float* ptr=(const float*)(mat->data.ptr + row * mat->step);
for( col=0; col<mat->cols; col++ )
{
s += *ptr++;
}
}
return( s );
}
我想问const float* ptr=(const float*)(mat->data.ptr + row * mat->step); 这句程序的详细意思,看不懂 展开
展开全部
mat->data.ptr 是指向 mat中数据的指针,是char 的
而mat中的数据,是float的
所以,在前面进行了强制转换 (const float*)
mat->step,是mat中,每行数据的长度
不过,感觉这里这么用不对头,因为 step,也是以byte为单位的,而前面已经强制成float了,所以就被人为放大了
先定义一个中间指针
char *ptr1;
ptr1 = mat->data.ptr + row * mat->step;
ptr = =(const float*)ptr1;
这样就可以了
还有可改进的地方,循环内
每次指针
ptr1 += mat->step;
就可以,不用乘row了
而mat中的数据,是float的
所以,在前面进行了强制转换 (const float*)
mat->step,是mat中,每行数据的长度
不过,感觉这里这么用不对头,因为 step,也是以byte为单位的,而前面已经强制成float了,所以就被人为放大了
先定义一个中间指针
char *ptr1;
ptr1 = mat->data.ptr + row * mat->step;
ptr = =(const float*)ptr1;
这样就可以了
还有可改进的地方,循环内
每次指针
ptr1 += mat->step;
就可以,不用乘row了
追问
加一个中间指针,把const float* ptr=(const float*)(mat->data.ptr + row * mat->step); 分成两句有本质的区别吗?不太清楚哦,请指教!!
追答
分开后 step 就是按 char 的长度增加指针
不分,就是按 float 的长度
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询