C++ - 算法(algorithm) 的 谓词(predicate) 详解

算法(algorithm) 的 谓词(predicate) 详解

 

版权所有, 禁止转载, 如有需要, 请站内联系. 

本文地址: http://blog.csdn.net/caroline_wendy/article/details/15378055

 

算法谓词, 即标准库算法传递的参数, 可以指定算法的操作, 如std::sort, 默认是从小到大, 通过谓词可以修改从大到小.

本文包含基本的5种谓词模式: 函数,函数指针,lambda表达式,函数对象,库定义的函数对象.

 

1. 函数(function)谓词

通过传递函数名, 匹配二元谓词(binary predicates), 根据函数提供的策略, 输出值;

代码:

/*Function Predicate*/
bool isLarger (const std::string &s1, const std::string &s2) {
	return s1.size() > s2.size();
}
......
std::stable_sort(sv.begin(), sv.end(), isLarger);


 

2. 函数指针(function pointer)谓词

建立一个函数指针, 传入算法, 使用指针代替函数名, 用法类似函数谓词.

代码:

bool (*pf) (const std::string &s1, const std::string &s2);
	pf = &isLarger;
	std::stable_sort(sv.begin(), sv.end(), *pf);


 

3. Lambda表达式(lambda expression)谓词

Lambda表达式格式: [capture list] (parameter list) -> return type { function body }

需要匹配谓词数, 一元(unary) 或 二元(binary), 也可以通过[capture list]传递函数的变量;

代码:

std::stable_sort(sv.begin(), sv.end(),
	[](const std::string& s1, const std::string& s2){ return s1.size()>s2.size(); });


 

4. 函数对象(Function Object)谓词

中重载函数的调用"()", 使类可以被调用, 并且传入算法谓词中, 进行使用.

代码:

/*Function Object*/
class LargerString {
public:
	bool operator() (const std::string& a, const std::string& b) {
		return a.size() > b.size();
	}
};
......
std::stable_sort(sv.begin(), sv.end(), LargerString());


 

 

5. 库定义的函数对象(Library-Defined Function Object)谓词

使用标准库定义的函数对象, 充当算法中的谓词, 包含在#include<functional>,包含基本的算法和逻辑操作.

代码:

std::stable_sort(sv.begin(), sv.end(), std::less<std::string>());


 

所有方法代码(Eclipse CDT; GCC 4.7.1):

/*
 * CppPrimer.cpp
 *
 *  Created on: 2013.11.11
 *      Author: Caroline
 */

/*eclipse cdt*/

#include <iostream>
#include <string>
#include <vector>
#include <algorithm>
#include <functional>

using namespace std;

class PrintString {
public:
	PrintString (std::ostream &o = std::cout, char c = ' ') : os(o), sep(c) { }
	void operator() (const std::string &s) const { os << s << sep; }
private:
	std::ostream &os;
	char sep;
};

/*Function Predicate*/
bool isLarger (const std::string &s1, const std::string &s2) {
	return s1.size() > s2.size();
}

/*Function Object*/
class LargerString {
public:
	bool operator() (const std::string& a, const std::string& b) {
		return a.size() > b.size();
	}
};

int main (void) {

	std::vector<std::string> sv = {"Beauty", "Girl", "Lady", "Women", "Pretty"};

	std::stable_sort(sv.begin(), sv.end(), isLarger);
	std::cout << "Function Predicate : ";
	std::for_each(sv.begin(), sv.end(), PrintString(std::cout));
	std::cout << std::endl;

	std::stable_sort(sv.begin(), sv.end(),
			[](const std::string& s1, const std::string& s2){ return s1.size()>s2.size(); });
	std::cout << "Lambda Expression Predicate : ";
	std::for_each(sv.begin(), sv.end(), PrintString(std::cout));
	std::cout << std::endl;

	bool (*pf) (const std::string &s1, const std::string &s2);
	pf = &isLarger;
	std::stable_sort(sv.begin(), sv.end(), *pf);
	std::cout << "Function Pointer Predicate : ";
	std::for_each(sv.begin(), sv.end(), PrintString(std::cout));
	std::cout << std::endl;

	std::stable_sort(sv.begin(), sv.end(), LargerString());
	std::cout << "Function Object Predicate : ";
	std::for_each(sv.begin(), sv.end(), PrintString(std::cout));
	std::cout << std::endl;


	std::stable_sort(sv.begin(), sv.end(), std::larger<std::string>());
	std::cout << "Library-Defined Function Object Predicate : ";
	std::for_each(sv.begin(), sv.end(), PrintString(std::cout));
	std::cout << std::endl;

    return 0;

}


输出:

Function Predicate : Beauty Pretty Women Girl Lady 
Lambda Expression Predicate : Beauty Pretty Women Girl Lady 
Function Pointer Predicate : Beauty Pretty Women Girl Lady 
Function Object Predicate : Beauty Pretty Women Girl Lady 
Library-Defined Function Object Predicate : Women Pretty Lady Girl Beauty 



  • 36
    点赞
  • 103
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
自动对焦是工业图像测量中一个重要的算法。工业图像测量设备通常包含高分辨率相机,用于捕捉工件表面的图像以进行测量分析。然而,由于工件表面形状和距离的变化,工件图像可能会出现模糊或不清晰的情况,这会影响测量的准确性和可靠性。 图像自动对焦算法的目标是通过调整相机镜头的焦距来使工件图像达到最佳清晰度。算法的实现通常包括以下步骤: 首先,算法需要获取图像的焦度度量。常用的度量方法包括图像梯度、傅里叶变换、方差等。这些度量方法可以从图像的内容和特征中推断出图像的清晰度。 接下来,算法根据当前的焦度度量和预设的清晰度标准,评估图像的清晰程度。如果图像的清晰程度低于预设标准,算法将自动调整相机镜头的焦距。 调整焦距的方法可以分为开环和闭环两种。开环方法是根据预设的清晰度标准,通过逐步调整焦距直到符合要求。闭环方法则利用反馈机制,在连续捕捉图像的过程中不断调整焦距,直到图像清晰度满足要求。 在实际应用中,自动对焦算法还需要考虑各种干扰因素,例如光照条件的变化、噪声干扰等。为了提高算法的鲁棒性和稳定性,可以采用多帧图像融合的方法,通过组合多个图像来获取更准确的焦度度量。 总而言之,自动对焦算法对于工业图像测量至关重要。它能够确保工件图像的清晰度,从而提高测量的准确性和可靠性。通过合理选择度量方法和调整策略,可以优化算法的性能并适应不同的工况。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SpikeKing

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值