matlab里面的uint8函数,未定义与 'uint8' 类型的输入参数相对应的函数 'fitnessty'

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼

程序如下:

clear all

clc

tic

popsize=15;

lanti=10;

maxgen=50;

cross_rate=0.4;

mutation_rate=0.1;

a0=0.7;

zpopsize=5;

bestf=0;

nf=0;

number=0;

I=imread('C:\Users\Yu\Pictures\feiji.jpg');

if numel(I)>2

I=rgb2gray(I);

end

[m,n]=size(I);

p=imhist(I);

p=p';

p=p/(m*n);

figure(1);

subplot(1,2,1);

imshow(I);

title('yuantu');

hold on

pop=2*rand(popsize,lanti)-1;

pop=hardlim(pop);

for gen=1:maxgen

[fitness,yuzhi,number]=fitnessty(pop,lanti,I,popsize,m,n,number);

if max(fitness)>bestf

bestf=max(fitness);

nf=0;

for i=1:popsize

if fitness(1,i)==bestf

v=i;

end

end

yu=yuzhi(1,v);

elseif max(fitness)==bestf

nf=nf+1;

end

if nf>=20

break;

end

A=shontt(pop);

f=fit(A,fitness);

pop=select(pop,f);

pop=coss(pop,corss_rate,popsize,lanti);

pop=mutation_compute(pop,mutation_rate,lanti,popsize);

a=shonqt(pop);

if a>a0

zpop=2*rand(zpopsize,lanti)-1;

zpop=hardlim(zpop);

pop(popsize+1,popsize+zpopsize)=zpop(:,:);

[fitness,yuzhi,number]=fitnessty(pop,lanti,I,popsize,m,n,number);

A=shontt(pop);

f=fit(A,fitness);

pop=select(pop,f);

end

if gen==maxgen

[fitness,yuzhi,number]=fitnessty(pop,lanti,I,popsize,m,n,number);

end

end

imshow(I);

subplot(1,2,2);

fresult(I,yu);

title('fazhifengehou');

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值