找答案的高端用户(找答案钻石及双钻级别的用户)将尽可能从此问题下的所有回
答中,为您推荐最佳答案。届时您可以根据推荐数采纳答案。
如果自提问时间起7天内您仍无法选出最佳答案,您可以选择“无满意答案”关闭此问题。
问题
取消精华
首页精华问答
取消推荐
高端用户推荐
申请置评
已申请置评
修改
修改标签
添加标签
官方认证
取消官方认证
修改标签
添加标签
转移分类
删除
{{itemCategory}}
收藏({{answerDetail.Q_FavoriteCounts}})
手机扫码追踪该问题,
觉得实用,立即去分享!
点击复制链接
专家建议
取消最佳答案
修改
建议可以通过西门子的间接寻址(在STL编辑器中实现)或者通过SCL编程语言实现
即通过指针的方式指向起始地址,然后通过改变指针指向下一个地址,进行数据的存储
我这里有一个数字滤波的程序,使用SCL写的,供参考(实现功能:取最近的十个数据,然后去掉最大值和最小值,然后剩下的八个数据相加后取平均值,其中的SCALE函数为模拟量线性转换函数,需要先在程序中添加FC105):
FUNCTION_BLOCK FB180
// Block Parameters
VAR_INPUT
PIW_IN: INT;
HI_LIM_IN: REAL :=100.0;
LO_LIM_IN: REAL :=0.0;// Input Parameters
BIPOLAR_IN: BOOL :=FALSE;
END_VAR
VAR_IN_OUT
// I/O Parameters
END_VAR
VAR_OUTPUT
// Output Parameters
SCALED_VAL: REAL;
SCALED_FILTED: REAL;
ERR: BOOL;
END_VAR
VAR_TEMP
RET_VAL_105: WORD; // Temporary Variables
LOOP_COUNT: INT;
MAX_DATA: REAL;
MIN_DATA: REAL;
TOTAL: REAL;
TOTAL_FILTERD: REAL;
END_VAR
VAR
DATA_STORE: ARRAY[0..9] OF REAL;
// Static Variables
END_VAR
RET_VAL_105:=SCALE(IN :=PIW_IN// IN: INT
,HI_LIM := HI_LIM_IN// IN: REAL
,LO_LIM := LO_LIM_IN // IN: REAL
,BIPOLAR := BIPOLAR_IN// IN: BOOL
,OUT := SCALED_VAL// OUT: REAL
); // WORD
IF RET_VAL_105<> 0 THEN ERR:=TRUE;
ELSE
ERR:=FALSE;
END_IF;
MAX_DATA:=DATA_STORE[0];
MIN_DATA:=DATA_STORE[0];
TOTAL:=0.0;
TOTAL_FILTERD:=0.0;
FOR LOOP_COUNT:= 0 TO 8 BY 1 DO
// Statement Section
DATA_STORE[LOOP_COUNT]:=DATA_STORE[LOOP_COUNT+1];
END_FOR;
DATA_STORE[9]:=SCALED_VAL;
FOR LOOP_COUNT:= 0 TO 9 BY 1 DO
// Statement Section
IF MAX_DATA < DATA_STORE[LOOP_COUNT] THEN MAX_DATA:=DATA_STORE[LOOP_COUNT];
END_IF;
IF MIN_DATA > DATA_STORE[LOOP_COUNT] THEN MIN_DATA:=DATA_STORE[LOOP_COUNT];
END_IF;
TOTAL:=TOTAL+DATA_STORE[LOOP_COUNT];
END_FOR;
TOTAL_FILTERD:=TOTAL- MIN_DATA- MAX_DATA;
SCALED_FILTED:=TOTAL_FILTERD/8.0;
END_FUNCTION_BLOCK
关于STL中的间接寻址,可以参考本网站下载中心文档编号为 F0215 的文章
等您来回答
换一换
{{item.CoinValue}}西币
{{item.VisitNum}}人想问
本版相关问题
换一换
专家置评
首次回答问题,获得
双倍西币积分!
立即成为技术知识分享的一员!
欢迎您访问支持中心!
丰富的视频,全方位的文档,大量的网友交流精华……
为了更好的完善这些内容,我们诚邀您在浏览结束后,花20秒左右的时间,完成一个用户在线调查!
感谢您的支持!

西门子商城