优先调节阀位,条件调节阀位

控制对象的执行机构可能存在多个,举例,压力通过变频和翻板这两个执行机构调节。默认调节翻板。这里定义一个全局布尔变量 bfgflag 初始默认为0;优先调节翻板,当翻板处于极限阀位时,bfgflag 赋值为1,开始调节变频,同样,当变频处于极限阀位时,bfgflag 赋值为0。当偏差特别大时,翻板和变频一起调节。

x表示阀位开度值数组

y表示阀位投切位数组

e表示偏差

em表示偏差最大值

xl表示阀位下限数组

xh表示阀位上限数组

复制代码
//选主阀组
//数组返回值函数:返回值要么是全局变量,要么是静态变量。
BOOL bfgflag=0;//
double out2[2];//动作函数中无需定义变量接收数组元素
double* BFGV2Sel(double *x,BOOL *y,int n,double e,double em,double lmn,double *xl,double *xh)
{
	int model;
	//double out2[2];//动作函数中需要定义变量接收数组元素
	int i;
	//C++写法
	//double *rangefloat = NULL;
	//BOOL *rangebool = NULL;
	//double *rangenumbers = NULL;
	//double *out = NULL;
	//C++写法和WinCC写法
	double rangefloat[2]={0,0};//
	BOOL rangebool[2]={0,0};
	double xlfloat[2]={0,0};//
	double xhfloat[2]={0,0};//
	for(i=0; i<n;i++)
	{
		rangefloat[i]=x[i];
		rangebool[i]=y[i];
		xlfloat[i]=xl[i];
		xhfloat[i]=xh[i];

	}

	if( rangebool[0] && !rangebool[1]) model=1;
	if(!rangebool[0] &&  rangebool[1]) model=2;
	if(!rangebool[0] && !rangebool[1]) model=3;
	if( rangebool[0] &&  rangebool[1]) model=4;

	switch(model)
	{
		case 1:out2[0]=x[0]+lmn;out2[1]=x[1];break;
		case 2:out2[0]=x[0];out2[1]=x[1]+lmn;break;
		case 3:out2[0]=x[0];out2[1]=x[1];break;
		case 4:
		if(!bfgflag){
			
			if(fabs(e)>=em)
			{out2[0]=x[0]+lmn;out2[1]=x[1]+lmn;}
			else {out2[0]=x[0]+lmn;out2[1]=x[1];}

			if(out2[0]>=xh[0] && out2[0]<=xl[0]){bfgflag=1;}else{bfgflag=0;}
		}
		else{
			if(fabs(e)>=em)
			{out2[0]=x[0]+lmn;out2[1]=x[1]+lmn;}
			else {out2[0]=x[0];out2[1]=x[1]+lmn;}

			if(out2[0]>=xh[1] && out2[0]<=xl[1]){bfgflag=0;}else{bfgflag=1;}
		}
      	break;

	default:
        out2[0]=x[0]+lmn;out2[1]=x[1]+lmn;bfgflag=0;
}

	//printf("%4.4f------%4.4f\r\n", out2[0], out2[1]);

	return out2;
}
相关推荐
健忘的派大星1 小时前
需求激增800%!2025年第一硬通货:懂大模型、云计算和硬件的“前沿部署工程师”!
人工智能·算法·架构·langchain·云计算·大模型学习·大模型教程
ShineWinsu7 小时前
对于C++:继承的解析—上
开发语言·数据结构·c++·算法·面试·笔试·继承
pp起床7 小时前
动态规划 | part05
算法·动态规划
GuangHeAI_ATing8 小时前
国密算法SSD怎么选?这3款国产固态硬盘安全又高速
算法
雨泪丶8 小时前
代码随想录算法训练营-Day34
算法
Yzzz-F8 小时前
牛客寒假算法训练营2
算法
甄心爱学习9 小时前
【python】获取所有长度为 k 的二进制字符串
python·算法
iAkuya9 小时前
(leetcode)力扣100 76数据流的中位数(堆)
算法·leetcode·职场和发展
键盘鼓手苏苏9 小时前
Flutter for OpenHarmony: Flutter 三方库 ntp 精准同步鸿蒙设备系统时间(分布式协同授时利器)
android·分布式·算法·flutter·华为·中间件·harmonyos
董董灿是个攻城狮9 小时前
AI 视觉连载5:传统 CV 之均值滤波
算法