亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? genetic_programming.m

?? duda模式分類第二版的分類器工具箱
?? M
字號:
function [test_targets, best_fun] = genetic_programming(train_patterns, train_targets, test_patterns, params)

% A genetic programming algorithm for classification
%
% 	train_patterns	- Train patterns
%	train_targets	- Train targets
%   test_patterns   - Test  patterns
%	params  		- [Initial function length, Number of generations, Number of solutions]
%
%Outputs
%	test_targets	- Predicted targets
%   func			- The best solution found

IterDisp  = 10;

[Ni, M]   = size(train_patterns);
x		  = train_patterns;
Uc        = unique(train_targets);

%Find parameters
[Flength, Ngenerations, Nsol] = process_params(params);

if (Flength) > 20,
   warning('This may take some time!')
end

%Define basic operators. If division by zero is unwanted, remove the devision operator
warning off %To suppress all those divide by zero warnings
operators	 = [' +'; ' -'; '.*'; './'];
base			 = size(operators,1);
for i = 1:Ni,
   operators(base+i,:) = ['X' num2str(i)];
end

%Define the basic tree shape
leafs = [];
solutions = zeros(1,Nsol); %Pointer to the first leaf in the solution

for i = 1:Nsol;
   solutions(i) = length(leafs) + 1;
   leafs			 = foliage(leafs, operators, Flength);
end

disp(['Starting with ' num2str(Nsol) ' solutions, totaling ' num2str(length(leafs)) ' leaves.'])

best = 0;

%Start doing the mutations
for i = 1:Ngenerations,
   %Rank each solution
   ranking = zeros(1,Nsol);
   for j = 1:Nsol,
      func    = collect_tree(solutions(j), leafs);
      for k = 1:Ni,
         func = strrep(func, ['X' num2str(k)], ['x(' num2str(k) ',:)']);
      end
      
      %Check if this string is a valid solution, and if so, put the ranking into place
      try
         t = eval(func);
         if (length(Uc) == 2)
             t = t > 0;
         else
             t = round(t);
         end
         ranking(j) = sum(t == train_targets) / length(train_targets);
      catch
      end
      
   end
   
   %Display
   if (i/IterDisp == floor(i/IterDisp)),
      disp(['Iteration ' num2str(i) ': Best solution has ' num2str(max(ranking)*100) '% correct (The best so far was ' num2str(best*100) '% correct).'])
   end
      
   %Sort the solutions according to rank
   [m, indices] = sort(ranking);
   indices		 = fliplr(indices);
   
   %It is sometimes good to save the best solution so far, in case the mutations ruin it!
   if (max(ranking) > best),
      best 		= max(ranking);
      best_fun = collect_tree(solutions(indices(1)), leafs);
   end
   
   %Start the genetic operations
   for j = 1:floor(Nsol/2),
      %Select two solutions according to their rank
      s1	= indices(j*2-1);
      s2 = indices(j*2);
      
      %Now do the genetic operators
      %There is no insertion in this implementation, as it generates too many impossible solutions
      
      k	= 1 + floor(3*rand(1));
      switch k,
      case 1,
         %Replications
         %Replicate from 2 to 1 or vice versa?
         if rand(1) > .5,
            temp = s1;
            s1   = s2;
            s2   = temp;
         end
         
         %Find where from to replicate
         node_number1 = walk_along(solutions(s1), leafs);
         node_number2 = walk_along(solutions(s2), leafs);
         [new_node, leafs] = copy(node_number1, leafs);
         
         %Put on left or right?
         if rand(1) > .5,
            %Put on left
            leafs(node_number2).left = new_node;
         else
            leafs(node_number2).right = new_node;
         end
         
      case 2,
         %Crossover
         %First, decide where to do the crossover
         node_number1 = walk_along(solutions(s1), leafs);
         node_number2 = walk_along(solutions(s2), leafs);
         
         %Change pointers by finding which leaf points to each of the leafs to change
         l1 = []; l2 = []; r1 = []; r2 = [];
         for m = 1:length(leafs),
            if ~isempty(leafs(m).left),
               if leafs(m).left == node_number1,
                  l1 = m;
               end
               if leafs(m).left == node_number2,
                  l2 = m;
               end
            end
            if ~isempty(leafs(m).right),
               if leafs(m).right == node_number1,
	               r1 = m;
   	         end
      	      if leafs(m).right == node_number2,
         	      r2 = m;
               end
            end            
         end
         
         if ~isempty([l1 r1]) & ~isempty([l2 r2]),
            if isempty(l1),
               %It is on the right of 1
               if isempty(l2),
                  leafs(r2).right = node_number1;
                  leafs(r1).right = node_number2;
               else
                  leafs(l2).left  = node_number1;
                  leafs(r1).right = node_number2;
               end
            else
               if isempty(l2),
                  leafs(r2).right = node_number1;
                  leafs(l1).right = node_number2;
               else
                  leafs(l2).left  = node_number1;
                  leafs(l1).right = node_number2;
               end
            end
         end
         
      case 3,
         %Mutation
         %Mutate s1 or s2? 
         if rand(1) > .5,
            temp = s1;
            s1   = s2;
            s2   = temp;
         end
         
         %First, decide where to do the mutation
         node_number1 = walk_along(solutions(s1), leafs);
         
         %Choose the new operator
         o1	= 1 + floor(rand(1)*size(operators,1));
         
         %Mutate!
         leafs(node_number1).operator = operators(o1,:);
         
         if strcmp(operators(o1,1),'X'),
            leafs(node_number1).left  = [];
            leafs(node_number1).right = [];
         end
         
      end
      
   end
   
   
end


%Classify test patterns
disp(['Will use a solution with ' num2str(best*100) '% correct for the test patterns'])

dfun    = best_fun;

for k = 1:Ni,
    dfun = strrep(dfun, ['X' num2str(k)], ['test_patterns(' num2str(k) ',:)']);
end

test_targets = eval(dfun);

if (length(Uc) == 2)
    test_targets = test_targets > 0;
end

%END

function [root, leafs] = copy(start_point, leafs)
%Make a copy of a branch, from the start point until its end. Return a pointer to the copy
N	= length(leafs) + 1;
leafs(N).operator = leafs(start_point).operator;

if ~isempty(leafs(start_point).left),
   [root, leafs] = copy(leafs(start_point).left, leafs);
   leafs(N).left = root;
end
if ~isempty(leafs(start_point).right),
   [root, leafs]  = copy(leafs(start_point).right, leafs);
   leafs(N).right = root;
end

root = N;

%END


function node = walk_along(start_point, leafs);
%Find where to mutate a solution along a tree. This is recursive
r = 1 + floor(rand(1)*4);

switch r,
case {1,2},
   %Go no further
   node = start_point;
case 3,
   %If possible, go right
   if ~isempty(leafs(start_point).right),
      node = walk_along(leafs(start_point).right, leafs);
   else
      node = start_point;
   end
case 4,
   %If possible, go left
   if ~isempty(leafs(start_point).left),
      node = walk_along(leafs(start_point).left, leafs);
   else
      node = start_point;
   end
end

%END


function s = collect_tree(pointer, leafs)
%Find the tree function recursively
if ~isempty(leafs(pointer).left),
   s = ['(' collect_tree(leafs(pointer).left, leafs) ')'];
else
	s = [];   
end

s = [s leafs(pointer).operator];

if ~isempty(leafs(pointer).right),
   s = [s '(' collect_tree(leafs(pointer).right, leafs) ')'];
end

%END

function [leafs, N] = foliage(leafs, operators, remaining_depth)
%Recursively add leafs in order to build the initial tree
N			= length(leafs)+1;

if (remaining_depth > 0),
	r		= floor(rand(1)*size(operators,1)) + 1;
   leafs(N).operator = operators(r,:);
   if ~strcmp(leafs(N).operator(1), 'X'),
      %The operator is numeric, so more leafs are needed
      [leafs, added] = foliage(leafs, operators, remaining_depth-1);	      
      leafs(N).left  = added;
      [leafs, added] = foliage(leafs, operators, remaining_depth-1);	      
      leafs(N).right = added;
   else
      leafs(N).left     = [];
	   leafs(N).right    = [];
   end
else
   in = find(operators(:,1) == 'X');
	r	= floor(rand(1)*length(in)) + 1;
   leafs(N).operator = ['X' num2str(r)];
   leafs(N).left     = [];
   leafs(N).right    = [];
end

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲婷婷综合久久一本伊一区| 色婷婷综合五月| 亚洲精品在线观| 国内偷窥港台综合视频在线播放| 日韩免费一区二区| 黄色小说综合网站| 国产女人18毛片水真多成人如厕| 国产精品2024| 中文字幕日本不卡| 欧美色视频一区| 久久精工是国产品牌吗| 国产午夜精品一区二区| 91亚洲精品乱码久久久久久蜜桃| 亚洲欧美电影一区二区| 欧美精品丝袜中出| 国产精品99久久不卡二区| 亚洲欧美一区二区三区孕妇| 91麻豆精品久久久久蜜臀| 国产精品一区二区男女羞羞无遮挡| 中文字幕不卡在线| 欧美影院午夜播放| 久久精品国产在热久久| 日韩av不卡在线观看| 日韩视频免费观看高清完整版 | 欧美国产视频在线| 91年精品国产| 免费成人美女在线观看| 中文字幕一区二区三区不卡| 9191久久久久久久久久久| 国产精品一区二区在线观看不卡 | 色一区在线观看| 日韩av网站免费在线| 中文字幕精品三区| 91精品午夜视频| 99在线热播精品免费| 日韩一区欧美二区| 日韩久久一区二区| 26uuu精品一区二区| 91福利资源站| 国产v日产∨综合v精品视频| 亚洲成人高清在线| 国产精品乱码久久久久久| 666欧美在线视频| 91看片淫黄大片一级| 经典三级在线一区| 亚洲成av人片| 亚洲色图视频免费播放| 亚洲精品一区二区精华| 欧美日韩国产小视频在线观看| 国产精华液一区二区三区| 日日摸夜夜添夜夜添精品视频| 亚洲三级电影全部在线观看高清| 精品国产一区久久| 在线成人午夜影院| 日本高清不卡视频| 成人精品一区二区三区四区| 久久精品国产秦先生| 亚洲va欧美va人人爽| 一区二区在线免费| 中文字幕在线不卡视频| 国产丝袜欧美中文另类| www激情久久| 久久综合给合久久狠狠狠97色69| 91精品欧美久久久久久动漫| 欧美色图免费看| 91精品办公室少妇高潮对白| 99久久精品免费观看| 高清不卡在线观看av| 国产精品一区免费在线观看| 久久99国产精品成人| 蜜臀精品久久久久久蜜臀| 性做久久久久久久免费看| 亚洲一区二区四区蜜桃| 一区二区三区免费| 亚洲精品ww久久久久久p站| 国产精品国产精品国产专区不片 | 成人av一区二区三区| 国产精品99久久久久久有的能看 | 天天综合日日夜夜精品| 一区二区三区不卡视频| 一区二区三区中文字幕精品精品| 亚洲欧美一区二区三区国产精品| 亚洲啪啪综合av一区二区三区| 亚洲伦在线观看| 亚洲欧洲综合另类在线| 亚洲国产视频一区| 日韩激情av在线| 久久99精品久久久久久久久久久久| 奇米色777欧美一区二区| 久久99精品视频| 国产91综合网| 91在线小视频| 精品视频在线看| 欧美一卡2卡三卡4卡5免费| 欧美videos大乳护士334| 久久婷婷国产综合精品青草| 亚洲国产成人在线| 亚洲女同女同女同女同女同69| 亚洲一区二区三区影院| 日韩精品电影在线| 激情图片小说一区| 99re这里只有精品6| 欧美日韩亚洲综合一区二区三区| 欧美一级爆毛片| 国产亚洲成年网址在线观看| 亚洲免费观看高清完整版在线观看 | 亚洲一本大道在线| 麻豆91在线播放免费| 国产盗摄精品一区二区三区在线| 99国产欧美久久久精品| 欧美日高清视频| 久久婷婷色综合| 亚洲美女精品一区| 国产综合色精品一区二区三区| 97se亚洲国产综合自在线不卡 | 综合久久久久综合| 蜜臀av性久久久久蜜臀aⅴ流畅| 成人综合激情网| 欧美日韩在线播放三区四区| 久久婷婷国产综合国色天香| 伊人夜夜躁av伊人久久| 国产麻豆精品久久一二三| 色综合久久综合| 精品剧情v国产在线观看在线| 亚洲美女偷拍久久| 国产高清亚洲一区| 欧美久久久久免费| 亚洲欧洲精品天堂一级| 久久精品99国产国产精| 欧洲亚洲精品在线| 国产精品丝袜久久久久久app| 午夜av区久久| 色妞www精品视频| 国产亚洲一区二区在线观看| 亚洲第四色夜色| 99久久精品国产毛片| 精品国一区二区三区| 五月婷婷欧美视频| 一本高清dvd不卡在线观看| 久久一留热品黄| 日本女人一区二区三区| 欧美曰成人黄网| 成人免费小视频| 国产超碰在线一区| 亚洲精品一线二线三线无人区| 亚洲国产一区视频| 在线观看区一区二| 亚洲色图在线播放| 国产成人精品一区二| 久久久久久毛片| 麻豆91精品视频| 91精品国产麻豆国产自产在线| 亚洲精品成人在线| 91麻豆免费观看| 成人免费小视频| gogogo免费视频观看亚洲一| 久久久高清一区二区三区| 久久爱另类一区二区小说| 日韩一区二区在线免费观看| 亚洲成av人片一区二区| 欧美疯狂性受xxxxx喷水图片| 玉足女爽爽91| 日本韩国欧美在线| 一区二区三区美女视频| 91搞黄在线观看| 亚洲午夜久久久久中文字幕久| 色视频欧美一区二区三区| 亚洲美女屁股眼交3| 日本韩国一区二区| 亚洲午夜一二三区视频| 欧美日韩一区在线观看| 亚洲国产精品一区二区www在线| 欧美视频在线不卡| 视频一区二区三区中文字幕| 91精品国产综合久久香蕉麻豆| 青青草成人在线观看| 日韩欧美在线不卡| 国产在线不卡视频| 国产精品久久久久久久午夜片| 97成人超碰视| 天天综合色天天综合| 欧美mv日韩mv国产网站app| 国产精品一品二品| 一区在线观看免费| 欧美在线影院一区二区| 日本欧美一区二区| 久久久久久久久久久久电影| 国产成人精品亚洲午夜麻豆| 自拍偷拍欧美激情| 欧美精品色一区二区三区| 久久成人羞羞网站| 国产精品视频观看| 欧美调教femdomvk| 国产一区二区成人久久免费影院| 日本一区二区视频在线| 在线观看精品一区| 精品一区二区三区免费| 亚洲视频在线一区| 91精品欧美综合在线观看最新| 国产精品18久久久久久久久|