1200plc滤波均值怎么写程序

1200plc滤波均值怎么写程序,第1张

当我们使用1200PLC进行滤波均值计算时,可以采用以下步骤进行程序编写:

1. 首毕培肆先,我们需要将采集到的原始数据存储至一个数组中,以便后续的计算。

2. 接着,我们需要定义一个变量来存储滑动窗口的大小,通常情况下,一个合适的窗口大小是根据实际应用场景来确定的。

3. 然后,我们可以通过循环语句将窗口内的数据进行累加,并计算出中侍平均值。在每次循环中,我们需要将最早加入窗口的数据删除,并将最新采集到的数据添加至窗口中。

4. 最后,我们需要将计算出的均值结果输出或存储至某个寄存器、数据存储器、或者其他设备中供后续使用。

比如,下面是一个示例程序:

```LD M100开始存储原始数据

LD D100将D100的值存储到M100中

ADD X0 将X0中的值加1

MOV D100, M[X0] 将M[X0]的值存储到D100中

CMP X0, K1N10 判断X0是否大于等于K1N10

JMPE ELSE如果是,则跳转至ELSE

AVG: 均值计算过程

MOV D10, D100 将D100的值存储到D10中

ADD D20, D10 将D10加到D20中

ADD X1, K1将X1加1

CMP X1, K2N10 判断X1是否大于等于K2N10

JMPE OUTPUT 如果是,手轿则跳转至OUTPUT

MOV D100, M[X1] 将新采集的数据存储到D100中

SUB D20, D[K1] 将最早加入窗口的数据删除

JMP AVG 重复执行均值计算过程

OUTPUT:

DIV D20, K1N10 计算出平均值

ST D30, M[100] 将结果存储至M100寄存器中

JMP START 回到程序开始处

ELSE:

MOV X0, K1 将X0重置为窗口大小

MOV D20, K0 将累加器清零

JMP AVG 执行均值计算

方法一:filter2

clear all

I=imread('lena.bmp')

%读入预处理图像

imshow(I)

%显示预处理图像

K1=filter2(fspecial('神悉average',3),I)/255

%进行3*3均值滤波

K2=filter2(fspecial('average',5),I)/255

%进行5*5均正瞎春值滤波

K3=filter2(fspecial('average',7),I)/255

%进行7*7均值滤波

figure,imshow(K1)

figure,imshow(K2)

figure,imshow(K3)

方法二:双循环举耐语句,移动平均法

%均值滤波

clc,clear

f=imread('lena.bmp')

subplot(121),imshow(f),title('原图')

f1=imnoise(f,'gaussian',0.002,0.0008)

%subplot(222),imshow(f1),title('添加高斯噪声图')

k1=floor(3/2)+1

k2=floor(3/2)+1

X=f1

[M,N]=size(X)

uint8 Y=zeros(M,N)

funBox=zeros(3,3)

for i=1:M-3

for j=1:N-3

funBox=X(i:i+3,j:j+3)

s=sum(funBox(:))

h=s/9

Y(i+k1,j+k2)=h

end

end

Y=Y/255

subplot(122),imshow(Y),title('均值滤波')

实现图:

imageData(y,x,1) = (sum (y1,x1,1))/9

imageData(y,x,2) = (sum (y1,x1,2))/9

imageData(y,x,3) = (sum (y1,x1,3))/9

这一部分没有进行求和的 *** 作啊,根本没有imageData这个量。。。if后边的循环没有实现对3*3的块求和,而是碰带每次赋一个值而已。还有for后边不能加分号,if后边不能加分号,1<x<imageWidth这种语句尽量分成两袭历句:x>1 &&x<imageWidth。另建议笑禅芦新建一个矩阵进行存储,可修改如下:

imageData = imread ('file.png')

imageSize = size(imageData)

imageHeight = imageSize(1)

imageWidth = imageSize(2)

Result = imageData

for y = 1:imageHeight

for x = 1:imageWidth

if (y>1 &&y <imageHeight &&x>1 &&x <imageWidth)

Result(y,x,1) = sum(sum(imageData(y-1:y+1,x-1:x+1,1)))/9

Result(y,x,2) = sum(sum(imageData(y-1:y+1,x-1:x+1,2)))/9

Result(y,x,3) = sum(sum(imageData(y-1:y+1,x-1:x+1,3)))/9

end

end

end

imwrite (Result,'final.png')

有问题可以继续问我,望采纳~


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12400363.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-25
下一篇 2023-05-25

发表评论

登录后才能评论

评论列表(0条)

保存