⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 decodeb.m

📁 一种标准的遗传算法实例
💻 M
字号:
function vars = decodeb(pop,nvar,maxval,minval)
% DECODEB -- converts a binary coded chromosome to
% real number values for each variable
% Author:	Ron Shaffer
%		Naval Reseach Laboratory
% Version	1.0 1/24/96
%		1.1 5/2/96 Renamed DECODEB
%		Fixed bug in conversion of binary number to integer
%
% pop:		population of binary coded chromosomes
% nvar:		number of real valued variables to be decoded
% maxval:	maximum real number value for each variable
% minval:	minimum real number value for each variable
% vars:		matrix of decoded real number variable settings (popsize,nvar)

[popsize,lchrome] = size(pop);
%
%	Split chromosome into sections for each variable
%
varchrome = lchrome/nvar;
pow_two = 2.^(0:varchrome)';
maxintval = ((2^varchrome))-1;
range = maxval-minval;
for i = 1:popsize
	start = 1;
	fin = varchrome;
	for j = 1:nvar
		tvars(1:varchrome) = pop(i,start:fin);
		start = start + varchrome;
		fin = fin + varchrome;
%
%		now decode binary number to real number (scale maxval to minval)
%
		temp1 = 0;
		for k = 1:varchrome
			temp1 = temp1 + pow_two(k)*tvars(varchrome-k+1);
		end
%
%		Takes integer value and converts to a real number 
%	
		vars(i,j) = (range*(temp1/maxintval)) + minval;	
	end
end

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -