青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 12,  comments - 54,  trackbacks - 0
在基因交叉之后產生的子代個體,其變量可能以很小的概率或者步長發生轉變,這個過程稱為變異(Mutation)。
如果進化的目標函數極值是單峰值的,那么,將變異概率p設置為種群數量n的倒數是一個比較好的選擇。
如果變異概率很大,那么整個搜索過程就退化為一個隨機搜索過程。所以,比較穩妥的做法是,進化過程剛剛開始的時候,取p為一個比較大的概率,隨著搜索過程的進行,p逐漸縮小到0附近。
與交叉過程一樣,變異的算法也可以大致分為實數編碼和二進制編碼兩種。
(1) 實數變異
 <1>步長變異
即給數值加上或者減去一個值,這個數值稱為步長。大致如下:
X' = X + 0.5 Ld 或者
X' = X - 0.5 Ld
這里
L為變量的取值范圍 L = Upper - Lower
d= a(0)/2^0 + a(1)/2^1 + ... + a(m)/s^m
其中a(i)以1/m的概率取1,以 1-1/m的概率取0,一般m=20

C++ 代碼
 1 template< class GENE >
 2 class Real_Gene_Mutate_Algorithm
 3 {
 4     public:
 5         void operator()( GENE& gene ) const
 6         {
 7             const unsigned int M = 20;
 8 
 9             //claculate Delta
10             long double Delta = 0.0L;
11             for ( unsigned int i = 0; i < M; ++i )
12             {
13                 const long double Boundary =
14                         1.0L / static_cast<long double>(M);
15                 const long double Ran = ran();
16                 if ( Ran < Boundary )
17                 {
18                     const unsigned int Base = 1 << i;
19                     Delta += 1.0L / static_cast<long double>( Base );
20                 }
21             }
22 
23             //claculate Sig and L
24             const long double Ran = ran();
25             long double Sig = 0;
26             long double L = 0;
27             if ( Ran > 0.5L )
28             {
29                 Sig = 1.0L;
30                 L = gene.Upper - gene.Value;
31             }
32             else
33             {
34                 Sig = -1.0L;
35                 L = gene.Value - gene.Lower;
36             }
37 
38             gene.Value += Sig * L * Delta * 0.5L;
39         }
40 
41 };
42 

<2>高斯變異
這種變異的方法就是,產生一個服從高斯分布的隨機數,取代原先基因中的實數數值。這個算法產生的隨機數,數學期望當為當前基因的實數數值。
一個模擬產生的算法是,產生6個服從U(0,1)的隨機數,以他們的數學期望作為高斯分布隨機數的近似。

 1 template<class GENE>
 2 class Gauss_Mutate_Algorithm
 3 {
 4         public:
 5             void operator()( GENE& gene )const
 6             {
 7                 long double gauss = 0.0L;
 8                 for ( unsigned int i = 0; i < 6++i )
 9                     gauss += ran();
10                 gauss /= 6.0L;
11 
12                 long double upper;
13                 long double lower;
14                 const long double Upper = gene.Upper;
15                 const long double Lower = gene.Lower;
16                 const long double Value = gene.Value;
17 
18                 ( ( Value - Lower ) > ( Upper - Value ) ) ?
19                 ( upper = Upper, lower = Value * 2.0L - Upper ) :
20                 ( lower = Lower, upper = Value * 2.0L - Lower );
21 
22                 gauss *= ( upper - lower );
23                 guass += lower;
24
25                 gene.Value = gauss;
26             }
27 };
28


(2)二進制變異
對二進制編碼來講,變異就是變量的翻轉,如
10000111100001
10000101100001

c++代碼
 1 template< class GENE >
 2 class Binary_Gene_Mutate_Algorithm
 3 {
 4     public:
 5         void operator()( GENE& gene )const
 6         {
 7             encoding( gene );
 8 
 9             const unsigned int Size = gene.Binary_Array.size();
10             const long double Ran = ran();
11             const unsigned int Pos = static_cast<unsigned int>
12                     ( static_cast<long double>( Size ) * Ran );
13 
14             if ( gene.Binary_Array[Pos] )
15                 gene.Binary_Array[Pos] = 0;
16             else
17                 gene.Binary_Array[Pos] = 1;
18 
19             decoding( gene );
20         }
21 };

(3)一些相關算法或者函數
 1 template< class DATA, class ALGORITHM>
 2 void mutate( DATA& d, const ALGORITHM& a )
 3 {
 4     a( d );
 5 }
 6 
 7 template< class POPULATION, class GENE_MUTATE_ALGORITHM >
 8 class Population_Mutate_Algorithm
 9 {
10     public:
11         void operator()( POPULATION& p )const
12         {
13             //chromosome numbers in the population
14             const unsigned int C_Size = p.Chromosome_Array.size();
15             //gene numbers in a chromosome
16             const unsigned int G_Size = p.Chromosome_Array[0].Gene_Array.size();
17 
18             for( unsigned int i = 0; i < C_Size; ++i )
19             {
20                 for ( unsigned int j = 0; j < G_Size; ++j )
21                 {
22                     const long double Ran = ran();
23 
24                     if ( Ran > p.Mutation_Probability )
25                     return ;
26 
27                     mutate( p.Chromosome_Array[i].Gene_Array[j],
28                             GENE_MUTATE_ALGORITHM() );
29                 }
30             }
31         }
32 };
33 



posted on 2008-06-22 16:20 Wang Feng 閱讀(14497) 評論(0)  編輯 收藏 引用 所屬分類: Numerical C++

<2025年12月>
30123456
78910111213
14151617181920
21222324252627
28293031123
45678910

常用鏈接

留言簿(4)

隨筆分類

隨筆檔案

Link List

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美国产日韩在线| 亚洲国产精品小视频| 亚洲综合精品| 国产日韩欧美麻豆| 久久久人成影片一区二区三区观看 | 欧美精品在线一区二区| 亚洲精品永久免费| 亚洲视频一区二区在线观看| 国产精品成人v| 久久精品免费电影| 久久一区亚洲| 亚洲网站在线| 香蕉av福利精品导航| 亚洲国产精品va| 一区二区三区久久| 国模一区二区三区| 亚洲国产精品尤物yw在线观看| 欧美精品午夜| 久久久999精品视频| 女同性一区二区三区人了人一| 日韩一二三在线视频播| 亚洲欧美日韩国产一区| 在线看日韩av| 在线亚洲高清视频| 尤物网精品视频| 9人人澡人人爽人人精品| 国产综合精品| 一区二区不卡在线视频 午夜欧美不卡'| 国产精品一区二区三区四区| 欧美福利小视频| 国产精品一区二区你懂得| 欧美成人免费在线视频| 国产精品久久久久一区二区三区| 久久资源在线| 国产精品乱人伦一区二区 | 亚洲片国产一区一级在线观看| 99视频在线观看一区三区| 国模叶桐国产精品一区| 一区二区久久久久| 最新高清无码专区| 欧美一区二区视频免费观看| 一区二区欧美精品| 免费观看成人网| 久久久久九九九| 欧美日韩三区四区| 欧美激情亚洲国产| 国产一区二区三区在线观看免费 | 免费中文日韩| 国产日韩在线亚洲字幕中文| 亚洲美女中出| 亚洲久久一区二区| 久久综合电影| 欧美jjzz| 136国产福利精品导航网址| 欧美一区二视频| 欧美一区二区三区的| 国产精品草莓在线免费观看| 亚洲黄色有码视频| 亚洲欧洲精品一区二区三区不卡 | 99riav1国产精品视频| 麻豆成人精品| 欧美国产成人精品| 最近中文字幕mv在线一区二区三区四区 | 亚洲一区二区三区涩| 欧美全黄视频| 亚洲最新视频在线| 亚洲伊人伊色伊影伊综合网| 欧美色图一区二区三区| 日韩一区二区久久| 亚洲一区网站| 国产精品一区二区久久久久| 性8sex亚洲区入口| 久久精品国产精品亚洲综合| 国产亚洲精品aa午夜观看| 午夜精品久久久久久久久久久| 香蕉尹人综合在线观看| 国产热re99久久6国产精品| 亚洲欧美在线磁力| 久久综合久久久| 亚洲欧洲一区二区三区在线观看| 欧美韩国在线| 亚洲小说欧美另类婷婷| 久久av二区| 亚洲国产天堂久久国产91| 欧美成人免费小视频| 亚洲肉体裸体xxxx137| 亚洲视频网站在线观看| 国产精品入口66mio| 久久国产精品久久久| 亚洲二区在线观看| 亚洲手机在线| 韩国av一区二区| 欧美高清在线观看| 亚洲永久在线观看| 男女av一区三区二区色多| 亚洲精品久久久久久下一站| 欧美亚洲不卡| 久久久水蜜桃av免费网站| 亚洲日本无吗高清不卡| 欧美一区久久| 亚洲激情电影在线| 国产精品女人毛片| 欧美va天堂va视频va在线| 亚洲性感美女99在线| 欧美成人精品激情在线观看 | 国产一区二区电影在线观看| 欧美a级理论片| 亚洲一区免费观看| 欧美国产一区在线| 午夜精品久久久久久99热| 亚洲激情第一区| 国产日韩欧美综合| 欧美日韩一区免费| 久久亚洲一区| 亚洲欧美中文日韩在线| 亚洲国产一区二区三区在线播| 午夜精品区一区二区三| 亚洲黄色在线视频| 国内精品久久久久影院色| 欧美日韩亚洲精品内裤| 六月天综合网| 久久国产精品免费一区| 中文av一区二区| 日韩性生活视频| 亚洲成在人线av| 免费人成精品欧美精品| 久久国产精品一区二区| 亚洲一区在线看| 一本色道**综合亚洲精品蜜桃冫| 在线电影国产精品| 国语自产精品视频在线看| 国产欧美日韩不卡免费| 欧美性开放视频| 欧美日韩在线免费视频| 欧美精品一区二区三区很污很色的| 久久爱www.| 欧美在线视频一区二区三区| 亚洲欧美乱综合| 午夜精品成人在线| 亚洲先锋成人| 亚洲欧美视频在线观看| 亚洲男人天堂2024| 西西裸体人体做爰大胆久久久| 一区二区三区蜜桃网| 中文亚洲免费| 亚洲综合99| 欧美一区2区视频在线观看 | 日韩视频精品| 日韩亚洲欧美高清| 日韩一区二区免费看| 99天天综合性| 一区二区三区精品视频| 亚洲一区二区三区精品视频| 亚洲字幕一区二区| 欧美主播一区二区三区美女 久久精品人| 亚洲午夜在线观看| 欧美影院在线播放| 久久天天躁狠狠躁夜夜av| 蜜臀a∨国产成人精品| 欧美精品一区二区三区四区| 欧美日韩三级| 国产午夜精品理论片a级探花| 韩国精品主播一区二区在线观看| 永久域名在线精品| 日韩视频免费在线| 亚洲一区欧美二区| 久久久久久久综合日本| 欧美电影免费观看高清完整版| 亚洲国产精品久久久久久女王| 日韩亚洲欧美成人一区| 亚洲欧美日韩网| 美女91精品| 国产精品成人av性教育| 黄色成人片子| 在线视频一区观看| 久久经典综合| 亚洲国产另类久久精品| 亚洲一二三区精品| 久久综合久久综合久久综合| 欧美精品一区三区| 国内外成人免费视频| 一区二区av| 久久久一区二区三区| 亚洲剧情一区二区| 欧美在线免费视屏| 欧美午夜一区二区福利视频| 精品成人一区二区三区| 国产精品99久久不卡二区| 久久中文字幕一区二区三区| 99成人在线| 噜噜噜噜噜久久久久久91 | 国产欧美91| av不卡在线看| 久久综合久久综合这里只有精品| 亚洲国产美女| 久久综合电影| 国语自产在线不卡| 欧美亚洲一区二区三区| 亚洲精品一区二区三区婷婷月 | 欧美在线观看一区二区|