C++| 一维线性插值、imadjust函数

2024-06-08 13:20

本文主要是介绍C++| 一维线性插值、imadjust函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言:最近要从Matlab代码改C++代码,不能直接用Matlab生成的C代码,因为需要嵌入到已有项目中。Matlab本身有很多很方便的数学公式,但是在C++里没有相关的库的话,需要自己实现。

一维线性插值、imadjust函数

  • 一维线性插值
    • 原理
    • C++代码
  • imadjust函数图像灰度调整
    • 原理
    • C++代码
  • 思路:Matlab代码转C++

一维线性插值

原理

Matlab中的interp1函数插值类型有很多:

  • nearest(最邻近插值法)
  • linear(线性插值)
  • spline(三次样条插值)
  • cubic(三次立方插值)
  • pchip(三次Hermite插值)

本文编写的是linear线性插值,其实是分段线性插值,分段线性插值就是线性插值的原理。

在这里插入图片描述

从分段线性插值图像结果来看,其实就是分别对相邻两个点进行线性插值。新的x点如果落在了相邻两个点之间就用对应的线性插值计算,但是如果新的x点落在了最大和最小以外,这个可以用离得最近的两个相邻点作为线性插值的斜率计算。

C++代码

x和y是分段插值的点坐标,然后new_x是需要插值获得x坐标,new_y是插值对应的y坐标。

double* linear(double* x, double* y, int n, double* new_x, int new_n) {double* new_y;new_y = new double[new_n];double last_x = 0, last_y = 0, next_x = 0, next_y = 0;int p = 0;for (int i = 0; i < new_n; i++) {while (p < n&& new_x[i] < x[p]) {p++;if (p == n)break;}// 考虑落在最小和最大范围外的点,做特殊处理,取最近相邻的点作为线性插值的计算if (p == 0) {last_x = x[0];last_y = y[0];next_x = x[1];next_y = y[1];}else if (p == n) {last_x = x[n-2];last_y = y[n-2];next_x = x[n-1];next_y = y[n-1];}else {last_x = x[p-1];last_y = y[p-1];next_x = x[p];next_y = y[p];}new_y[i] = (new_x[i]-last_x)*((next_y - last_y) / (next_x - last_x))+last_x;}return new_y;
}

imadjust函数图像灰度调整

原理

Matlab中的imadjust函数可以对图像进行灰度调整,调用格式如下:

J=imadjust( I,[low_in;high_in],[low_out;high_out],gamma);

该函数的功能,输入图像数据I:

  • 灰度小于low_in:low_out。
  • 灰度大于low_in且小于high_in:灰度线性变换后,进行gamma变换。
  • 灰度大于high_in:high_out。

结合图像来理解更为直观:
在这里插入图片描述
其中gamma变换,是一个固定的公式 s = c r γ s=cr^γ s=crγ,在gamma为1的时候是线性变换,函数图像如下图:
在这里插入图片描述

C++代码

void imadjust2(unsigned char**Image,int rows,int cols, int low_in, int high_in, int low_out, int high_out, double gamma) {// gamma变换公式unsigned char gammaLut[256];double c = 1.0;for (int i = 0; i < 256; i++)gammaLut[i] = (unsigned char)(c * pow((double)i / 255.0, gamma) * 255.0);// 灰度调整double k = ((double)high_out - low_out) / (high_in - low_in);double result = 0.0;for (int i = 0; i < rows;i++) {for (int j = 0; j < cols;j++) {if (Image[i][j] <= low_in) {Image[i][j] = low_out % 255;}else if (Image[i][j] >= high_in) {Image[i][j] = high_out % 255;}else {result = k * ((double)Image[i][j] - low_in) + low_in;Image[i][j] = gammaLut[(unsigned char)result]%255;}}}
}

思路:Matlab代码转C++

  1. 搜C++有没有现成的库,例如Matlab中傅里叶变换,在C++中就有fftw3.h(CPU)或者cufft.h(GPU)能够实现。
  2. 上网搜有没有别人已经写好的相同功能的,直接搬砖改写。
  3. 在Matlab中右键函数“打开xxx函数”,就会出现该函数使用帮助、原理和源码(有些有 有些没有),这些辅助转写C++代码。

这篇关于C++| 一维线性插值、imadjust函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1042304

相关文章

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客

Python函数作用域示例详解

《Python函数作用域示例详解》本文介绍了Python中的LEGB作用域规则,详细解析了变量查找的四个层级,通过具体代码示例,展示了各层级的变量访问规则和特性,对python函数作用域相关知识感兴趣... 目录一、LEGB 规则二、作用域实例2.1 局部作用域(Local)2.2 闭包作用域(Enclos

从入门到精通C++11 <chrono> 库特性

《从入门到精通C++11<chrono>库特性》chrono库是C++11中一个非常强大和实用的库,它为时间处理提供了丰富的功能和类型安全的接口,通过本文的介绍,我们了解了chrono库的基本概念... 目录一、引言1.1 为什么需要<chrono>库1.2<chrono>库的基本概念二、时间段(Durat

MySQL count()聚合函数详解

《MySQLcount()聚合函数详解》MySQL中的COUNT()函数,它是SQL中最常用的聚合函数之一,用于计算表中符合特定条件的行数,本文给大家介绍MySQLcount()聚合函数,感兴趣的朋... 目录核心功能语法形式重要特性与行为如何选择使用哪种形式?总结深入剖析一下 mysql 中的 COUNT

C++20管道运算符的实现示例

《C++20管道运算符的实现示例》本文简要介绍C++20管道运算符的使用与实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录标准库的管道运算符使用自己实现类似的管道运算符我们不打算介绍太多,因为它实际属于c++20最为重要的

Visual Studio 2022 编译C++20代码的图文步骤

《VisualStudio2022编译C++20代码的图文步骤》在VisualStudio中启用C++20import功能,需设置语言标准为ISOC++20,开启扫描源查找模块依赖及实验性标... 默认创建Visual Studio桌面控制台项目代码包含C++20的import方法。右键项目的属性:

MySQL 中 ROW_NUMBER() 函数最佳实践

《MySQL中ROW_NUMBER()函数最佳实践》MySQL中ROW_NUMBER()函数,作为窗口函数为每行分配唯一连续序号,区别于RANK()和DENSE_RANK(),特别适合分页、去重... 目录mysql 中 ROW_NUMBER() 函数详解一、基础语法二、核心特点三、典型应用场景1. 数据分

c++中的set容器介绍及操作大全

《c++中的set容器介绍及操作大全》:本文主要介绍c++中的set容器介绍及操作大全,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录​​一、核心特性​​️ ​​二、基本操作​​​​1. 初始化与赋值​​​​2. 增删查操作​​​​3. 遍历方

解析C++11 static_assert及与Boost库的关联从入门到精通

《解析C++11static_assert及与Boost库的关联从入门到精通》static_assert是C++中强大的编译时验证工具,它能够在编译阶段拦截不符合预期的类型或值,增强代码的健壮性,通... 目录一、背景知识:传统断言方法的局限性1.1 assert宏1.2 #error指令1.3 第三方解决