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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? scs.cpp

?? GA算法的c++源程序
?? CPP
?? 第 1 頁 / 共 3 頁
字號(hào):
/****************************************************************************/
/*                 基本遺傳學(xué)習(xí)分類系統(tǒng)  SCS.CPP                              */
/*        A  Simple Classifier System based on Genetic Learning             */
/*      developed from the Pascal SCS code presented by David E.Goldberg    */
/*             同濟(jì)大學(xué)計(jì)算技術(shù)研究所   王小平          2000年7月           */
/****************************************************************************/

#include <stdlib.h> 
#include <fstream.h>
#include <iostream.h>
#include <iomanip.h>
#include <math.h>
#include <string.h>

const int wildcard=-1;                /*  通配符#   */
const long iterationsperblock=10000;
const int fmaxmating=10;
int rndcalcflag;
double rndx2;

struct classtype                     /* 分類器 */
{
  int *c;                            /*  condition */
  int a;                             /*  action */
  float strength,bid,ebid;           /* 權(quán)值, 投標(biāo),有效投標(biāo)*/
  int matchflag;                     /* 匹配標(biāo)志*/
  int specificity;                   /* 非#碼長度 */
} ;
struct  classlist                    /* 匹配表 */
{
   int *clist;                       /* 當(dāng)前與環(huán)境消息匹配的分類器表 */
   int nactive;                      /* 當(dāng)前匹配數(shù)目 */
} ;
struct poptype                       /* 分類器表數(shù)據(jù) */
{
    struct classtype *classifier;    /*  分類器表  */
    int nclassifier,nposition;       /*  分類器數(shù)目, 條件碼長 */
    float pgeneral,cbid,bidsigma,bidtax,lifetax,bid1,bid2,ebid1,ebid2;  
    float sumstrength,fmaxstrength,avgstrength,fminstrength;
};
struct trecord                  /* 時(shí)間參數(shù) */
{
   int initialiteration,initialblock,iteration,block,reportperiod;
   int gaperiod,consolereportperiod,plotreportperiod,nextplotreport;
   int nextconsolereport,nextreport,nextga;
   int reportflag,gaflag,consolereportflag,plotreportflag;
};
struct erecord                 /* 環(huán)境參數(shù) */
{
   int laddress,ldata,lsignal,address,output,classifieroutput;
   int *signal;
};
struct crecord                /* 交易所參數(shù) */
{
   int winner,oldwinner;
   int bucketbrigadeflag;
};
struct rrecord               /* 增強(qiáng)參數(shù)(得分兌現(xiàn))  */
{
float reward,rewardcount,totalcount,count50,rewardcount50;
float proportionreward,proportionreward50;
int lastwinner;
};
struct mrecord               /*  交配參數(shù)  */
{
 int mate1,mate2,mort1,mort2,sitecross;
};
struct grecord              /* 遺傳算法參數(shù) */
{
float populationselect,pmutation,pcrossover;
long ncrossover,nmutation;
int crowdingfactor,crowdingsubpop,nselect;
struct mrecord *mating;
};

/* 全局變量 */
int *envmessage;                    /* 消息    */
struct poptype population;          /* 分類器表數(shù)據(jù) */  
struct classlist matchlist;         /* 匹配表  */
struct trecord timekeeprec;         /* 時(shí)間參數(shù)  */
struct erecord environrec;          /* 環(huán)境參數(shù) */  
struct crecord clearingrec;         /* 交易所參數(shù)  */ 
struct rrecord reinforcementrec;    /* 增強(qiáng)參數(shù)  */
struct grecord garec;               /* 遺傳算法參數(shù) */

struct poptype *pop=&population;
struct classlist *matchl=&matchlist;

ofstream rep("c:\\ga\\rep.txt");                        /* 結(jié)果報(bào)告文件 */
ofstream pfile("c:\\ga\\pfile.txt");                    /* 繪圖數(shù)據(jù)文件 */  
ifstream tfile("c:\\ga\\tfile.txt",ios::nocreate);      /* 時(shí)間參數(shù)文件 */
ifstream efile("c:\\ga\\efile.txt",ios::nocreate);      /* 環(huán)境參數(shù)文件 */
ifstream cfile("c:\\ga\\cfile.txt",ios::nocreate);      /* 分類器參數(shù)文件 */
ifstream rfile("c:\\ga\\rfile.txt",ios::nocreate);      /* 增強(qiáng)參數(shù)文件 */
ifstream gfile("c:\\ga\\gfile.txt",ios::nocreate);      /* 遺傳算法參數(shù)文件 */

void initrepheader();
void interactiveheader();
void initialization();  
void detectors(struct erecord *environrec,int *envmessage);  
void reportdetectors(int *envmessage,int nposition); 
void report();
void consolereport(struct rrecord *reinforcementrec);
void plotreport(struct rrecord *reinforcementrec);
int  addtime(int t,int dt,int &carryflag);
void inittimekeeper(struct trecord *timekeeprec);
void initreptimekeeper(struct trecord *timekeeprec);
void timekeeper(struct trecord *timekeeprec);
void reporttime(struct trecord *timekeeprec);
void generatesignal(struct erecord *environrec);
int  decode(int *mess,int start,int length);
void multiplexeroutput(struct erecord *environrec);
void environment(struct erecord *environrec);
void initenvironment(struct erecord *environrec);
void initrepenvironment(struct erecord *environrec);
void writesignal(int *signal,int lsignal);
void reportenvironment(struct erecord *environrec);
int  randomchar(double pgeneral);
void readcondition(int *c,float pgeneral,int nposition);
void readclassifier(struct classtype *Class,float pgeneral,int nposition);
int  counterspecificity(int *c, int nposition);
void initclassifiers(struct poptype *population);
void initrepclassifiers(struct poptype *population);
void writecondition(int c[],int nposition);
void writeclassifier(struct classtype *Class,int number,int nposition);
void reportclassifiers(struct poptype *population);
int  match(int *c,int *m, int nposition);
void matchclassifiers(struct poptype *population,int *emess,struct classlist *matchlist);
void  initaoc(struct crecord *clearingrec);
void initrepaoc(struct crecord *clearingrec);
int  auction(struct poptype *population,struct classlist *matchlist,int oldwinner);
void clearinghouse(struct poptype *population,struct crecord *clearingrec);
void taxcollector(struct poptype *population);
void reportaoc(struct crecord *clearingrec);
void aoc(struct poptype *population,struct classlist *matchlist,struct crecord *clearingrec);
void initreinforcement(struct rrecord *reinforcementrec);
void initrepreinforcement(struct rrecord *reinforcementrec);
int  criterion(struct rrecord *rrec,struct erecord *environrec);
void payreward(struct poptype *population,struct rrecord *rrec,struct crecord *clearingrec);
void reportreinforcement(struct rrecord *reinforcementrec);
void reinforcement(struct rrecord *reinforcementrec,struct poptype *population,
             struct crecord *clearingrec,struct erecord *environrec);
void advance(struct crecord *clearingrec);
void initga(struct grecord *garec,struct poptype *population);
void initrepga(struct grecord *garec);
int  select(struct poptype *population);
int  mutation(int positionvalue,float pmutation,long &nmutation );
int  bmutation(int positionvalue,float pmutation,long &nmutation );
void crossover(struct classtype *parent1,struct classtype *parent2,struct classtype *child1,struct classtype *child2,
       float pcrossover,float pmutation,int &sitecross,int nposition,long &ncrossover,long &nmutation);
int  worstofn(struct poptype *population, int n);
int  matchcount(struct classtype *classifier1,struct classtype *classifier2,int nposition);
int  crowding(struct classtype *child,struct poptype *population,int &crowdingfactor,int crowdingsubpop);
void statistics(struct poptype *population);
void ga(struct grecord *garec,struct poptype *population);
void reportga(struct grecord *garec,struct poptype *population );
float  rndreal(float lo ,float hi);
void initrandomnormaldeviate(); 
double randomnormaldeviate();
float  noise(float mu ,float sigma); 
void skip(int skipcount);
int  flip(float prob); 
int  rnd(int low,int high);
float fmax(float x,float y);
float fmin(float x,float y);
float avg(float x,float y);
int  halt();
void initmalloc(); 
void freeall();   


void initrepheader()
{
  rep<<"---------------------------------------------------------"<<endl;
  rep<<"                  基本遺傳學(xué)習(xí)分類系統(tǒng)                   "<<endl;
  rep<<" A  Simple Classifier System based on Genetic Learning   "<<endl;
  rep<<"---------------------------------------------------------"<<endl;
 
}
void interactiveheader()
{
  cout<<"---------------------------------------------------------"<<endl;
  cout<<"                  基本遺傳學(xué)習(xí)分類系統(tǒng)                   "<<endl;
  cout<<" A  Simple Classifier System based on Genetic Learning   "<<endl;
  cout<<"---------------------------------------------------------"<<endl;
 
}

void initialization()      /* 分類系統(tǒng)初始化  */
{
interactiveheader();
initrandomnormaldeviate();
initmalloc();
initrepheader();
initclassifiers(pop);
initrepclassifiers(pop);
initenvironment(&environrec);
initrepenvironment(&environrec);
initaoc(&clearingrec);
initrepaoc(&clearingrec);
initreinforcement(&reinforcementrec);
initrepreinforcement(&reinforcementrec);
inittimekeeper(&timekeeprec);
initreptimekeeper(&timekeeprec);
initga(&garec,pop);
initrepga(&garec);
}

void detectors(struct erecord *environrec,int *envmessage)    /* 檢測器  */
{
int j;
for(j=0;j<=environrec->lsignal-1; j++)
 envmessage[j]=environrec->signal[j];
}

void writemessage(int *mess,int lmessage)
{
 int j;
 j=lmessage-1;
   while(j>=0)  {
          rep<<mess[j];
         j--;
   }
}

void reportdetectors(int *envmessage,int nposition)        /* 輸出環(huán)境消息 */
{
 skip(1);
 rep<<" 環(huán)境消息:     ";
 writemessage(envmessage,nposition);
 skip(1);
}

void  reportheader()
{
 skip(1);
 rep<<"    詳細(xì)報(bào)告 "<<endl;
 rep<<"----------------"<<endl;
 
}

void report()
{
 reportheader();
 reporttime(&timekeeprec);
 reportenvironment(&environrec);
 reportdetectors(envmessage,pop->nposition);
 reportclassifiers(pop);
 reportaoc(&clearingrec);
 reportreinforcement(&reinforcementrec);
}

void consolereport(struct rrecord *reinforcementrec)
{
  cout<<"----------------------------"<<endl;
  cout<<"      次數(shù)="<<reinforcementrec->totalcount<<endl;
  cout<<"      P  ="<<reinforcementrec->proportionreward<<endl;
  cout<<"      P50 ="<<reinforcementrec->proportionreward50<<endl;
  cout<<"----------------------------"<<endl;
}

void plotreport(struct rrecord *reinforcementrec)
{
  pfile<<setw(12)<<reinforcementrec->totalcount<<setw(12)<<reinforcementrec->proportionreward<<
                  setw(10)<<reinforcementrec->proportionreward50<<endl;
}

int addtime(int t,int dt,int &carryflag)
{
 int tempadd;
 tempadd=t+dt;
 carryflag=(tempadd>=iterationsperblock);
 if(carryflag)
    tempadd=(int)fmod((double)tempadd,(double)iterationsperblock);
 return(tempadd);
}

void inittimekeeper(struct trecord *timekeeprec)
{
 int dummyflag;
  timekeeprec->iteration=0;timekeeprec->block=0;
  tfile>>timekeeprec->initialiteration;
  tfile>>timekeeprec->initialblock;
  tfile>>timekeeprec->reportperiod;
  tfile>>timekeeprec->consolereportperiod;
  tfile>>timekeeprec->plotreportperiod;
  tfile>>timekeeprec->gaperiod;
  timekeeprec->iteration=timekeeprec->initialiteration;
  timekeeprec->block=timekeeprec->initialblock;
  timekeeprec->nextga=addtime(timekeeprec->iteration,timekeeprec->gaperiod,dummyflag);
  timekeeprec->nextreport=addtime(timekeeprec->iteration,timekeeprec->reportperiod,dummyflag);
  timekeeprec->nextconsolereport=addtime(timekeeprec->iteration,timekeeprec->consolereportperiod,dummyflag);
  timekeeprec->nextplotreport=addtime(timekeeprec->iteration,timekeeprec->plotreportperiod,dummyflag);
}

void initreptimekeeper(struct trecord *timekeeprec)
{
 skip(1);
 rep<<"       時(shí)間參數(shù):    "<<endl;
 rep<<"------------------------------"<<endl;
 rep<<" 初始次數(shù)         = "<<timekeeprec->initialiteration<<endl;
 rep<<" 初始時(shí)間塊       = "<<timekeeprec->initialblock<<endl;
 rep<<" 結(jié)果數(shù)據(jù)輸出周期 = "<<timekeeprec->reportperiod<<endl;
 rep<<" 數(shù)據(jù)屏幕顯示周期 = "<<timekeeprec->consolereportperiod<<endl;
 rep<<" 繪圖數(shù)據(jù)輸出周期 = "<<timekeeprec->plotreportperiod<<endl;
 rep<<" 遺傳算法執(zhí)行周期 = "<<timekeeprec->gaperiod<<endl;
}

void timekeeper(struct trecord *timekeeprec)
{
  int carryflag,dummyflag;
  timekeeprec->iteration=addtime(timekeeprec->iteration,1,carryflag);
  if(timekeeprec->iteration>=iterationsperblock) timekeeprec->block=timekeeprec->block+1;
  timekeeprec->reportflag=(timekeeprec->nextreport==timekeeprec->iteration);
  if(timekeeprec->reportflag)
  timekeeprec->nextreport=addtime(timekeeprec->iteration,timekeeprec->reportperiod,carryflag);
  timekeeprec->consolereportflag=(timekeeprec->nextconsolereport==timekeeprec->iteration);
  if(timekeeprec->consolereportflag)
  timekeeprec->nextconsolereport=addtime(timekeeprec->iteration,timekeeprec->consolereportperiod,dummyflag);
  timekeeprec->plotreportflag=(timekeeprec->nextplotreport==timekeeprec->iteration);
  if(timekeeprec->plotreportflag)
  timekeeprec->nextplotreport=addtime(timekeeprec->iteration,timekeeprec->plotreportperiod, dummyflag);
  timekeeprec->gaflag=(timekeeprec->nextga==timekeeprec->iteration);
  if(timekeeprec->gaflag)
  timekeeprec->nextga=addtime(timekeeprec->iteration,timekeeprec->gaperiod,dummyflag);
 }

void reporttime(struct trecord *timekeeprec)
{
 rep<<" [塊:次數(shù)] = ["<< timekeeprec->block<<":"<<timekeeprec->iteration<<"]"<<endl;
}

void generatesignal(struct erecord *environrec)
{
int j;
for(j=0;j<=environrec->lsignal-1; j++)
 {
   if(flip(0.5))
      environrec->signal[j]=1;
   else
      environrec->signal[j]=0;
 }
}

int decode(int *mess,int start,int length)
{
int j,accum,powerof2;
accum=0;powerof2=1;
for(j=start;j<=start+length-1; j++)
 {
  accum=accum+powerof2*mess[j];
  powerof2=powerof2*2;
 }
return(accum);
}

void multiplexeroutput(struct erecord *environrec)
{

 environrec->address=decode(environrec->signal,0,environrec->laddress);
 environrec->output=environrec->signal[environrec->laddress+environrec->address];
}

void environment(struct erecord *environrec)
{
generatesignal(environrec);
multiplexeroutput(environrec);
}

void initenvironment(struct erecord *environrec)
{
int j;
efile>>environrec->laddress;
environrec->ldata=(int)ceil(pow(2.0,(double)environrec->laddress));
environrec->lsignal=environrec->laddress+environrec->ldata;
environrec->address=0;
environrec->output=0;
environrec->classifieroutput=0;
for(j=0;j<=environrec->lsignal-1; j++)
  environrec->signal[j]=1;
}

void initrepenvironment(struct erecord *environrec)
{
 skip(1);
 rep<<"  環(huán)境參數(shù)(多路復(fù)用器):    "<<endl;
 rep<<"------------------------------"<<endl;
 rep<<" 地址行數(shù) = "<< environrec->laddress<<endl;
 rep<<" 數(shù)據(jù)行數(shù) = "<< environrec->ldata<<endl;
 rep<<" 總行數(shù)   = "<< environrec->lsignal<<endl;
}

void writesignal(int *signal,int lsignal)
{
 int j;
 j=lsignal-1;
   while(j>=0)  {
          rep<<signal[j];
         j--;
   }
}

void reportenvironment(struct erecord *environrec)
{
 skip(1);
 rep<<"        當(dāng)前多路復(fù)用器狀態(tài):    "<<endl;
 rep<<"-----------------------------------"<<endl;
 rep<<" 信號(hào):  ";
 writesignal(environrec->signal,environrec->lsignal);  skip(1);
 rep<<" 解碼地址       = "<<environrec->address<<endl;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久久久亚洲综合影院红桃| 国产精品区一区二区三区| 欧美一级午夜免费电影| 久久久不卡网国产精品二区 | 亚洲高清不卡在线| 国产尤物一区二区在线| 色乱码一区二区三区88 | 欧美在线视频日韩| 国产婷婷色一区二区三区四区 | 日本一区二区三区国色天香 | 2024国产精品| 日本亚洲三级在线| 欧美四级电影网| **网站欧美大片在线观看| 国产主播一区二区| 欧美一三区三区四区免费在线看| 亚洲欧美电影一区二区| 国产精品亚洲综合一区在线观看| 91麻豆精品国产91久久久使用方法 | 欧美午夜理伦三级在线观看| 亚洲国产成人一区二区三区| 九九久久精品视频| 91精品国产乱| 奇米色777欧美一区二区| 69堂精品视频| 日韩不卡一区二区三区| 777午夜精品免费视频| 亚洲成人免费影院| 欧美日韩精品二区第二页| 亚洲一区二区四区蜜桃| 91九色最新地址| 一区二区三区四区不卡在线 | 日韩一区二区高清| 天天亚洲美女在线视频| 欧美日韩成人综合天天影院| 亚洲一卡二卡三卡四卡五卡| 色中色一区二区| 亚洲自拍偷拍欧美| 欧美日本一区二区三区四区 | 国产精品99精品久久免费| 久久天堂av综合合色蜜桃网 | 美国av一区二区| 精品日产卡一卡二卡麻豆| 国产一区二区三区在线观看精品 | 韩国三级在线一区| 久久久久成人黄色影片| 成人黄色av网站在线| 亚洲欧洲av色图| 欧美熟乱第一页| 日产国产高清一区二区三区| 精品国产亚洲一区二区三区在线观看| 久久精品久久综合| 久久九九影视网| 91蜜桃婷婷狠狠久久综合9色| 亚洲日本在线天堂| 欧美肥妇bbw| 蜜桃久久久久久| 国产精品久久久久久一区二区三区 | 蜜桃免费网站一区二区三区| 国产亚洲欧美激情| 色猫猫国产区一区二在线视频| 亚洲第一电影网| 久久久国产综合精品女国产盗摄| 99re视频这里只有精品| 无吗不卡中文字幕| 久久精品视频在线看| 91麻豆免费看片| 美脚の诱脚舐め脚责91| 日韩久久一区二区| 日韩三区在线观看| 91视视频在线直接观看在线看网页在线看 | 91精品国产日韩91久久久久久| 国产在线一区观看| 亚洲综合无码一区二区| 欧美大黄免费观看| 91亚洲国产成人精品一区二区三| 视频一区在线视频| 日韩一区有码在线| 日韩你懂的在线观看| 91丨九色丨黑人外教| 韩国av一区二区三区四区| 亚洲精品久久7777| 国产精品视频免费看| 在线成人高清不卡| 91在线云播放| 国产九色精品成人porny| 亚洲成年人网站在线观看| 国产精品久久久久久久久搜平片 | 国产精品天美传媒| 日韩一区二区三区免费看 | 日韩免费电影网站| 色国产精品一区在线观看| 国产在线精品不卡| 日本美女一区二区| 亚洲最新视频在线观看| 国产精品久久久久影视| 久久看人人爽人人| 欧美大片免费久久精品三p| 欧美精品在线视频| 欧美在线观看视频在线| 97aⅴ精品视频一二三区| 高清在线观看日韩| 国产精品一区二区视频| 精油按摩中文字幕久久| 蜜桃视频一区二区三区| 麻豆久久一区二区| 日本一道高清亚洲日美韩| 亚洲成va人在线观看| 亚洲成人综合视频| 亚洲精品乱码久久久久久| 中文字幕一区二区三区在线播放 | 粉嫩av一区二区三区粉嫩| 老司机精品视频导航| 久久精品999| 蜜桃视频一区二区| 国产在线视频一区二区三区| 麻豆91在线观看| 国产在线不卡一区| 国产精品1024| 丁香婷婷综合色啪| 99久久国产综合精品麻豆| 成人av在线一区二区| 99精品国产91久久久久久 | 日韩精品一区二| 日韩欧美你懂的| 久久婷婷国产综合精品青草| 国产视频一区二区三区在线观看| 久久久久国产精品麻豆| 国产精品久久久久久久久免费相片 | 奇米影视在线99精品| 日本美女一区二区| 国内精品视频一区二区三区八戒| 国产一区二区三区综合| 成人国产在线观看| 欧美影片第一页| 日韩精品中文字幕一区二区三区| 欧美大度的电影原声| 国产欧美日韩精品在线| 一区二区三区精品在线观看| 性做久久久久久| 国产曰批免费观看久久久| 丁香另类激情小说| 欧美少妇性性性| 精品成a人在线观看| 中文字幕一区二区三区不卡 | 亚洲人成在线观看一区二区| 亚洲国产精品影院| 精品一区二区三区免费| 99国产欧美另类久久久精品| 6080日韩午夜伦伦午夜伦| 日本一区二区三区四区| 亚洲成人综合在线| 成人一级黄色片| 欧美日韩一区三区| 国产亚洲精品久| 婷婷一区二区三区| 国产成人久久精品77777最新版本| 91久久线看在观草草青青| 精品国产一区久久| 亚洲欧美一区二区三区久本道91| 日产精品久久久久久久性色| 99综合影院在线| 日韩一级精品视频在线观看| 亚洲色图欧洲色图| 久久精品999| 欧美三级三级三级| 国产精品国产三级国产aⅴ原创 | 亚洲香肠在线观看| 从欧美一区二区三区| 欧美一级生活片| 一区二区理论电影在线观看| 国产一区二区0| 这里只有精品免费| 一区二区三区在线播放| 国产精品一区二区91| 欧美一区2区视频在线观看| 综合在线观看色| 成人免费不卡视频| 26uuuu精品一区二区| 秋霞午夜鲁丝一区二区老狼| 一本到高清视频免费精品| 国产清纯白嫩初高生在线观看91| 天天操天天色综合| 欧美午夜一区二区| 亚洲伦在线观看| www.av亚洲| 亚洲国产精品成人综合色在线婷婷 | 色综合天天性综合| 国产精品区一区二区三区| 精品写真视频在线观看| 欧美一区二区视频在线观看| 午夜影院久久久| 欧美亚洲国产一区二区三区 | 婷婷国产v国产偷v亚洲高清| 色婷婷国产精品| 亚洲激情在线播放| 91免费视频观看| 一区二区三区国产精华| 91蝌蚪porny| 一区二区三区波多野结衣在线观看|