opecv c++计算图像的曲率

公式

κ = z x x ⋅ z y 2 − 2 ⋅ z x ⋅ z y ⋅ z x y + z y y ⋅ z x 2 ( z x 2 + z y 2 + 1 ) 3 / 2 \kappa = \frac{z_{xx} \cdot z_y^2 - 2 \cdot z_x \cdot z_y \cdot z_{xy} + z_{yy} \cdot z_x^2}{(z_x^2 + z_y^2 + 1)^{3/2}}\newline κ=(zx2+zy2+1)3/2zxx⋅zy2−2⋅zx⋅zy⋅zxy+zyy⋅zx2

其中:
z x = ∂ z ∂ x z_x = \frac{\partial z}{\partial x}\newline zx=∂x∂z
z y = ∂ z ∂ y z_y = \frac{\partial z}{\partial y}\newline zy=∂y∂z
z x x , z y y , z x y z_{xx}, z_{yy}, z_{xy} zxx,zyy,zxy 分别为 ( z ) 关于 ( x ) 和 ( y ) 的二阶导数和交叉导数。

代码

cpp 复制代码
void computeCurvature(const cv::Mat& depth_map, cv::Mat& curvature_map)
{
	cv::Mat gradient_x, gradient_y;
	cv::Mat gradient_xx, gradient_yy, gradient_xy;

	// 计算一阶导数
	Sobel(depth_map, gradient_x, CV_64F, 1, 0, 3);
	Sobel(depth_map, gradient_y, CV_64F, 0, 1, 3);

	// 计算二阶导数
	Sobel(gradient_x, gradient_xx, CV_64F, 1, 0, 3);
	Sobel(gradient_y, gradient_yy, CV_64F, 0, 1, 3);
	Sobel(gradient_x, gradient_xy, CV_64F, 0, 1, 3);

	// 计算曲率
	cv::Mat denominator = gradient_x.mul(gradient_x) + gradient_y.mul(gradient_y) + 
		cv::Mat::ones(depth_map.size(), CV_64F);
	cv::pow(denominator, 1.5, denominator);

	curvature_map = (gradient_xx.mul(gradient_y.mul(gradient_y)) - 2.0 * gradient_x.mul(gradient_y.mul(gradient_xy)) + gradient_yy.mul(gradient_x.mul(gradient_x))) / denominator;
}
相关推荐
2401_8920709815 小时前
【Linux C++ 日志系统实战】LogFile 日志文件管理核心:滚动策略、线程安全与方法全解析
linux·c++·日志系统·日志滚动
yuzhuanhei16 小时前
Visual Studio 配置C++opencv
c++·学习·visual studio
不爱吃炸鸡柳16 小时前
C++ STL list 超详细解析:从接口使用到模拟实现
开发语言·c++·list
十五年专注C++开发16 小时前
RTTR: 一款MIT 协议开源的 C++ 运行时反射库
开发语言·c++·反射
‎ദ്ദിᵔ.˛.ᵔ₎16 小时前
STL 栈 队列
开发语言·c++
2401_8920709817 小时前
【Linux C++ 日志系统实战】高性能文件写入 AppendFile 核心方法解析
linux·c++·日志系统·文件写对象
郭涤生17 小时前
STL vector 扩容机制与自定义内存分配器设计分析
c++·算法
༾冬瓜大侠༿17 小时前
vector
c语言·开发语言·数据结构·c++·算法
cccyi717 小时前
【C++ 脚手架】etcd 的介绍与使用
c++·服务发现·etcd·服务注册
liu****17 小时前
第16届省赛蓝桥杯大赛C/C++大学B组(京津冀)
开发语言·数据结构·c++·算法·蓝桥杯