三向比较运算符<=>

        三向比较符又称太空飞船操作符,可以用来确定一个值和另外一个值的大小关系,返回枚举类型,定义在<compare>头文件中。

例1:

int n1{ 10 };
int n2{ 20 };
auto result = n1 <=> n2;
if (std::strong_ordering::less == result) //判断n1是否小于n2
{
	cout << "n1 < n2" << endl;
}

if (std::strong_ordering::greater == result) //判断n1是否大于n2
{
	cout << "n1 > n2" << endl;
}

if (std::strong_ordering::equal == result) //判断n1是否等于n2
{
	cout << "n1 = n2" << endl;
}

if (std::strong_ordering::equivalent == result) //判断n1是有与n2等价
{
	cout << "n1 == n2" << endl;
}


//输出结果:n1<n2	

        result的类型为一个名为std::strong_ordering的枚举类型,因为n1 n2均为int,则该比较的结果为强排序,其中equal意为相等,equivalent意为等价,在strong ordering类型下这两个意思相同,以下是这两个值得源码定义:

…
enum class _Compare_eq : _Compare_t { equal = 0, equivalent = equal };
…
inline constexpr strong_ordering strong_ordering::equal{static_cast<_Compare_t>(_Compare_eq::equal)};
inline constexpr strong_ordering strong_ordering::equivalent{static_cast<_Compare_t>(_Compare_eq::equivalent)};
…

可见在源码层次,这两个值是完全一样的。

例2:

如果比较的类型是浮点型,那么返回的结果就是partial ordering

    double n1{ 10 };
	double n2{ 20 };
	auto result = n1 <=> n2;
	if (std::partial_ordering::less == result) //判断n1是否小于n2
	{
		cout << "n1 < n2" << endl;
	}

	if (std::partial_ordering::greater == result) //判断n1是否大于n2
	{
		cout << "n1 > n2" << endl;
	}

	if (std::partial_ordering::equivalent == result) //判断n1是否等于n2
	{
		cout << "n1 = n2" << endl;
	}
	if (std::partial_ordering::unordered == result) //
	{
		cout << "n1 or n2 is unordered" << endl;
	}
	//输出结果:n1<n2

例3:

对于自定义类型重载<=>我们需要弱排序weak_ordering

import <iostream>;
import <string>;
import <compare>;
using namespace std;

class testWeakOrdering
{
public:
	testWeakOrdering(int value):m_value(value)
	{

	}
	std::weak_ordering operator<=> (const testWeakOrdering& other)
	{
		if (m_value < other.m_value)
		{
			return weak_ordering::less;
		}
		else if (m_value == other.m_value)
		{
			return weak_ordering::equivalent;
		}
		else
		{
			return weak_ordering::greater;
		}
	}

private:
	int m_value;
};

int main()
{
	testWeakOrdering n1{ 10 };
	testWeakOrdering n2{ 20 };
	auto result = n1 <=> n2;
	if (std::weak_ordering::less == result) //判断n1是否小于n2
	{
		cout << "n1 < n2" << endl;
	}

	if (std::weak_ordering::greater == result) //判断n1是否大于n2
	{
		cout << "n1 > n2" << endl;
	}

	if (std::weak_ordering::equivalent == result) //判断n1是否等于n2
	{
		cout << "n1 = n2" << endl;
	}

	return 0;
}

### 相两电平逆变器的开关逻辑 对于相两电平逆变器而言,其核心在于如何通过控制六个功率开关(通常标记为 Q1 至 Q6),将直流电源转换成交流输出。这种类型的逆变器能够产生两种电压水平——正向最大值和负向最小值,在理想情况下对应于输入直流母线的一半。 #### 基础工作原理 当考虑一个简单的相两电平逆变器时,每个相位由两个串联连接的晶体管组成,形成一对上下桥臂。上桥臂负责提供正值电压,而下桥臂则用于生成零或负值电压。为了确保安全操作并防止短路发生,任何时候同一侧的两个相邻开关不会同时导通;即如果一侧开启,则另一侧必定关闭[^5]。 #### 调制策略 在实际应用中,最常用的调制方式是脉冲宽度调制 (PWM),它允许精确调整输出波形形状。具体来说: - **空间矢量调制(SVM)** 或者称为磁链轨迹跟踪法,是一种高效的 PWM 技术,能够在保持恒定频率的同时优化利用 DC 链接电压。 - **正弦脉宽调制(SPWM)** 是另一种广泛采用的方法,其中参考信号是一个标准正弦曲线,与高频角载波比较后得到一系列窄脉冲序列来驱动各个开关元件。 这两种方法都依赖于特定的时间安排规则以决定何时打开或关闭某个给定时刻下的某组开关组合。例如,在 SPWM 中,每当参考正弦波超过角波峰值时就会触发一次状态切换事件[^4]。 #### 开关模式 针对相系统内的每一相,存在四种可能的状态配置: - 当前相处于高电平时,对应的高端 MOSFET 导通; - 死区时间设置用来避免直通现象的发生,即不允许同一条支路上面的高低端开关在同一瞬间动作。 ```matlab % MATLAB/Simulink 示例代码片段展示了一个基础的SPWM实现过程 function pwm_signal = generate_spwm(carrier_freq, modulating_waveform) % carrier_freq - 载波频率 % modulating_waveform - 输入调制波形 time_vector = linspace(0, 1/carrier_freq, 1e3); % 时间轴定义 triangle_wave = sawtooth(time_vector * 2*pi*carrier_freq, 0.5); % 创建锯齿状载波 pwm_signal = abs(modulating_waveform) .> abs(triangle_wave); % 应用比较运算符获取PWM信号 end ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值