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

控制对象的执行机构可能存在多个,举例,压力通过变频和翻板这两个执行机构调节。默认调节翻板。这里定义一个全局布尔变量 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;
}
相关推荐
Gyoku Mint37 分钟前
深度学习×第4卷:Pytorch实战——她第一次用张量去拟合你的轨迹
人工智能·pytorch·python·深度学习·神经网络·算法·聚类
葫三生2 小时前
如何评价《论三生原理》在科技界的地位?
人工智能·算法·机器学习·数学建模·量子计算
拓端研究室4 小时前
视频讲解:门槛效应模型Threshold Effect分析数字金融指数与消费结构数据
前端·算法
随缘而动,随遇而安6 小时前
第八十八篇 大数据中的递归算法:从俄罗斯套娃到分布式计算的奇妙之旅
大数据·数据结构·算法
IT古董6 小时前
【第二章:机器学习与神经网络概述】03.类算法理论与实践-(3)决策树分类器
神经网络·算法·机器学习
水木兰亭9 小时前
数据结构之——树及树的存储
数据结构·c++·学习·算法
Jess0710 小时前
插入排序的简单介绍
数据结构·算法·排序算法
老一岁10 小时前
选择排序算法详解
数据结构·算法·排序算法
xindafu10 小时前
代码随想录算法训练营第四十二天|动态规划part9
算法·动态规划
xindafu10 小时前
代码随想录算法训练营第四十五天|动态规划part12
算法·动态规划