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

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

?? fitness.c

?? 簡單遺傳算法經典例子!! SGPC: Simple Genetic Programming in C by Walter Alden Tackett and Aviram Carmi
?? C
字號:
/*
SGPC: Simple Genetic Programming in C
(c) 1993 by Walter Alden Tackett and Aviram Carmi
 
 This code and documentation is copyrighted and is not in the public domain.
 All rights reserved. 
 
 - This notice may not be removed or altered.
 
 - You may not try to make money by distributing the package or by using the
   process that the code creates.
 
 - You may not distribute modified versions without clearly documenting your
   changes and notifying the principal author.
 
 - The origin of this software must not be misrepresented, either by
   explicit claim or by omission.  Since few users ever read sources,
   credits must appear in the documentation.
 
 - Altered versions must be plainly marked as such, and must not be
   misrepresented as being the original software.  Since few users ever read
   sources, credits must appear in the documentation.
 
 - The authors are not responsible for the consequences of use of this 
   software, no matter how awful, even if they arise from flaws in it.
 
If you make changes to the code, or have suggestions for changes,
let us know!  (gpc@ipld01.hac.com)
*/

#ifndef lint
static char fitness_c_rcsid[]="$Id: fitness.c,v 2.8 1993/04/30 05:08:38 gpc-avc Exp gpc-avc $";
#endif

/*
 *
 * $Log: fitness.c,v $
 * Revision 2.8  1993/04/30  05:08:38  gpc-avc
 * Restructured directories and Makefile
 *
 * Revision 2.6  1993/04/17  03:03:01  gpc-avc
 * Added a test to check if the fitness file exists
 *
 *
 */

#include <stdio.h>
#include <malloc.h>
#include <errno.h>
#include <stdlib.h>
#include "gpc.h"
#include "prob.h"

VOID sort_fitness_cases P_((
	int num,
	GENERIC *vals,
	int *index
	));

VOID load_fitness_file P_((
	char *fn,
	int *num,
	int **labels,
	GENERIC ***table,
	GENERIC **tval,
	GENERIC **cval,
	int **tindex,
	int **cindex,
	int *numt,
	int *numc
	));

#define DIMENSION 7
GENERIC **fitness_cases_table;
GENERIC **test_cases_table;
int *fclabels;
int *tclabels;
int numfc;
int numtc;

GENERIC *fctval;
GENERIC *fccval;
GENERIC *tctval;
GENERIC *tccval;
GENERIC *sortval;
int *fct_sort_index;
int *fcc_sort_index;
int *tct_sort_index;
int *tcc_sort_index;
int numfct;
int numfcc;
int numtct;
int numtcc;

#define pd 0.96
#define xabs(x) ((x)>0?(x):(-(x)))
#ifdef ANSI_FUNC

VOID evaluate_fitness_of_populations(
     int 	numpops,
     int 	numgens,
     pop_struct	*pop,
     int	p
     )
#else

VOID evaluate_fitness_of_populations(numpops,numgens,pop,p)
     int 	numpops;
     int 	numgens;
     pop_struct	*pop;
     int	p;
#endif
{
  int		i;

  for (i=0; i<pop[p].population_size; i++) {
    pop[p].standardized_fitness[i] = 
      evaluate_fitness_of_individual(pop,p,pop[p].population[i],i);
  }
}

#ifdef ANSI_FUNC

float evaluate_fitness_of_individual(
     pop_struct	*pop,
     int	p,
     tree	*t,
     int	i
     )
#else

float evaluate_fitness_of_individual(pop, p, t, i)
     pop_struct	*pop;
     int	p;
     tree	*t;
     int	i;
#endif
{
  int		j, ccount, tcount;
  GENERIC	pdval;

  ccount = tcount = 0;
  for (j=0; j<numfc; j++) {
    load_terminal_set_values(pop,p,fitness_cases_table[j]);
    if (fclabels[j]) fctval[tcount++] = eval(pop[p].population[i]);
    else fccval[ccount++] = eval(pop[p].population[i]);
  }
  sort_fitness_cases(tcount, fctval, fct_sort_index);
  sort_fitness_cases(ccount, fccval, fcc_sort_index);
  pdval = fctval[fct_sort_index[(int)((pd*((GENERIC)(tcount-1)))+0.5)]];
  for (j=0; ((j<ccount) && (fccval[fcc_sort_index[j]] >= pdval)); j++);
  return ((float)j)/(float)ccount;
}

#ifdef ANSI_FUNC

float validate_fitness_of_tree(
     int	numpops,
     int	numgens,
     pop_struct *pop,
     int	p,
     tree 	*t
     )
#else

float validate_fitness_of_tree(numpops, numgens, pop, p, t)
  int		numpops;
  int		numgens;
  pop_struct	*pop;
  int		p;
  tree		*t;
#endif
{
  int	        j, ccount, tcount;
  GENERIC	pdval;

  ccount = tcount = 0;
  for (j=0; j<numtc; j++) {
    load_terminal_set_values(pop,p,test_cases_table[j]);
    if (tclabels[j]) tctval[tcount++] = eval(t);
      else tccval[ccount++] = eval(t);
    }
  sort_fitness_cases(tcount, tctval, tct_sort_index);
  sort_fitness_cases(ccount, tccval, tcc_sort_index);
  pdval = tctval[tct_sort_index[(int)((pd*((GENERIC)(tcount-1)))+0.5)]];
  for (j=0; ((j<ccount) && (tccval[tcc_sort_index[j]] >= pdval)); j++);
  printf("Validation Fitness:\np(D)= %f p(FA)= %f\n", pd, ((float)j)/(float)ccount);
  return ((float)j)/(float)ccount;
}
  
#ifdef ANSI_FUNC

static int fcpr(
	int *i,
	int *j
	)
#else

static int fcpr(i, j)
int	*i, *j;
#endif
{
  if (sortval[*j] > sortval[*i]) return 1;
  else if (sortval[*j] < sortval[*i]) return -1;
  else return 0;
}

#ifdef ANSI_FUNC

VOID sort_fitness_cases(
	int num,
	GENERIC *vals,
	int *index
	)
#else

VOID sort_fitness_cases(num, vals, index)
int	num;
GENERIC *vals;
int	*index;
#endif
{
  int	i;

  for (i=0; i<num;i++) {
    index[i] = i;
  }
  sortval = vals;
  qsort(index, num, sizeof(int), fcpr);
}

#ifdef ANSI_FUNC

int terminate_early(
  int 		numpops,
  int 		numgens,
  pop_struct 	*pop
  )
#else

int terminate_early(numpops,numgens,pop)
  int		numpops;
  int		numgens;
  pop_struct 	*pop;
#endif
{
  return 0;
}

#ifdef ANSI_FUNC

VOID define_fitness_cases(
  int 		numpops,
  int 		numgens,
  pop_struct	*pop
     )
#else

VOID define_fitness_cases(numpops,numgens,pop)
  int 		numpops;
  int 		numgens;
  pop_struct	*pop;
#endif
{
  int	p,i;
  char	ffn[132],tfn[132];
  FILE	*f;

  printf("Enter name of fitness cases file: ");
  scanf("%s",ffn);
  printf("%s\n",ffn);
  printf("Enter name of validation test cases file: ");
  scanf("%s",tfn);
  printf("%s\n",tfn);
  load_fitness_file(ffn,&numfc,&fclabels,&fitness_cases_table,
		    &fctval, &fccval, &fct_sort_index, &fcc_sort_index,
		    &numfct, &numfcc);
  load_fitness_file(tfn,&numtc,&tclabels,&test_cases_table,
		    &tctval, &tccval, &tct_sort_index, &tcc_sort_index,
		    &numtct, &numtcc);
}

#ifdef ANSI_FUNC

VOID load_fitness_file(
	char *fn,
	int *num,
	int **labels,
	GENERIC ***table,
	GENERIC **tval,
	GENERIC **cval,
	int **tindex,
	int **cindex,
	int *numt,
	int *numc
	)
#else

VOID load_fitness_file(fn,num,labels,table,tval,cval,tindex, cindex,numt,numc)
char	*fn;
int	*num;
int	**labels;
GENERIC ***table;
GENERIC **tval, **cval;
int	**tindex, **cindex;
int	*numt, *numc;
#endif
{
  FILE	*f;
  int	i,j;

  if ((f=fopen(fn,"r")) == (FILE *) NULL) {
    fprintf(stderr,"Error: fitness file not found: %s\n",fn);
    exit(1);
  }
  fscanf(f,"%d",num);
  (*labels) = (int *) malloc(*num*sizeof(int));
  (*table) = (GENERIC **) malloc(*num*sizeof(GENERIC *));
  for ((*numt) = (*numc) = i = 0; i<*num; i++) {
    (*table)[i] = (GENERIC *) malloc(DIMENSION*sizeof(GENERIC));
    fscanf(f,"%d",&((*labels)[i]));
    (((*labels)[i]) ? (*numt)++ : (*numc)++);
    for (j=0;j<DIMENSION;j++) fscanf(f,FORMAT,&((*table)[i][j]));
  }
  (*tval) = (GENERIC *) malloc(*numt*sizeof(GENERIC));
  (*cval) = (GENERIC *) malloc(*numc*sizeof(GENERIC));
  (*tindex) = (int *) malloc(*numt*sizeof(int));
  (*cindex) = (int *) malloc(*numc*sizeof(int));
  fclose(f);
}

 ? (*numt)++ : (*numc)++);
    for (j=0;j<DIMENSION;j++) fscanf(f,FORMAT,&((*table)[i][j]));
  }
  (*tval) = (GENERIC *) malloc(*numt*sizeof(GENERIC));
  (*cval) = (GENERIC *) malloc(*numc*sizeof(GENERIC));
  (*tindex) = (int *) malloc(*numt*sizeof(int));
  (*cindex) = (int *) malloc(*numc*sizeof(int));
  fclose(f);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
av电影天堂一区二区在线| 亚洲韩国精品一区| www日韩大片| 国产精品网站在线| 日韩av一区二| 色天使久久综合网天天| 精品国产乱码久久久久久图片| 亚洲三级小视频| 国产在线精品不卡| 欧美日韩aaa| 一区二区三区在线高清| 国产精品77777竹菊影视小说| 欧美日韩黄色影视| 亚洲乱码一区二区三区在线观看| 国产在线麻豆精品观看| 欧美疯狂做受xxxx富婆| 亚洲另类在线一区| 成人国产精品免费观看视频| 精品国产免费人成在线观看| 日韩av高清在线观看| 欧美日韩视频第一区| 亚洲制服丝袜av| 99久久精品国产网站| 国产精品―色哟哟| 成人免费看视频| 中文字幕免费观看一区| 国产在线一区观看| 欧美zozo另类异族| 日本 国产 欧美色综合| 欧美日韩国产在线观看| 亚洲风情在线资源站| 91.成人天堂一区| 日韩中文字幕av电影| 欧美日韩精品一二三区| 亚洲成av人片www| 欧美色老头old∨ideo| 亚洲成人精品一区二区| 欧美精品xxxxbbbb| 日本美女视频一区二区| 日韩欧美123| 国产成人综合自拍| 国产精品久久久久影视| 色综合久久99| 日韩成人午夜电影| 精品粉嫩aⅴ一区二区三区四区 | 欧美日韩精品免费| 亚洲gay无套男同| 欧美一级精品在线| 国产做a爰片久久毛片| 中文欧美字幕免费| 91看片淫黄大片一级| 亚洲国产精品久久人人爱| 欧美精品自拍偷拍| 精品在线一区二区三区| 中文字幕巨乱亚洲| 在线一区二区观看| 午夜久久久久久久久| 亚洲线精品一区二区三区八戒| 亚洲欧美另类图片小说| 91麻豆产精品久久久久久| 亚洲综合999| 日韩视频免费观看高清完整版| 国产精品一区二区在线播放 | 精品视频资源站| 久久精品99国产国产精| 国产精品日日摸夜夜摸av| 欧美伊人久久久久久久久影院| 人人爽香蕉精品| 国产精品久久久久久久浪潮网站| 欧美亚洲国产一卡| 国内精品国产成人国产三级粉色| 成人免费在线视频| 91精品国产综合久久精品app| 国产精品影视天天线| 亚洲午夜在线视频| 中文字幕不卡在线播放| 精品视频色一区| 成人国产精品免费网站| 青青草成人在线观看| 中文字幕永久在线不卡| 欧美va亚洲va| 精品视频免费在线| 不卡一区在线观看| 精品伊人久久久久7777人| 亚洲精品一卡二卡| 国产日韩欧美精品综合| 91精品国产色综合久久不卡蜜臀| caoporn国产精品| 久久99精品久久久久久久久久久久 | 国产福利一区二区三区视频在线| 亚洲精品成a人| 国产女同性恋一区二区| 欧美一区二区三区男人的天堂 | 久久9热精品视频| 一级女性全黄久久生活片免费| 久久久91精品国产一区二区精品| 欧美日韩国产123区| 91在线观看成人| 国产精品69毛片高清亚洲| 男女激情视频一区| 丝袜脚交一区二区| 一区二区三区波多野结衣在线观看| 久久欧美一区二区| 精品久久久久香蕉网| 91精品国产综合久久久蜜臀粉嫩| 欧美午夜精品久久久久久超碰 | 欧美乱熟臀69xxxxxx| 日本乱码高清不卡字幕| 99久精品国产| 色呦呦国产精品| 91毛片在线观看| 91在线无精精品入口| 成人黄色a**站在线观看| 成人精品亚洲人成在线| 成人爽a毛片一区二区免费| 国产福利一区二区三区视频在线 | 天天综合色天天综合色h| 午夜电影网一区| 日日嗨av一区二区三区四区| 日韩中文字幕不卡| 免费高清成人在线| 激情五月激情综合网| 成人做爰69片免费看网站| 国产高清亚洲一区| 99久久久精品免费观看国产蜜| 99精品欧美一区二区蜜桃免费| av电影在线观看一区| 91久久精品一区二区| 欧美巨大另类极品videosbest | 7777精品伊人久久久大香线蕉完整版 | 欧美成人伊人久久综合网| 日韩一区二区三区免费观看| 日韩免费在线观看| 久久女同性恋中文字幕| 中文字幕亚洲精品在线观看| 亚洲欧美影音先锋| 亚洲第一福利视频在线| 全部av―极品视觉盛宴亚洲| 久久99国产精品麻豆| 不卡视频一二三四| 欧美日韩精品一区二区在线播放| 欧美成人一区二区三区| 欧美激情一区二区三区在线| 亚洲女性喷水在线观看一区| 亚洲第一主播视频| 久久99久久精品欧美| 丰满少妇久久久久久久| 在线观看视频一区| 日韩欧美国产小视频| 亚洲国产精品99久久久久久久久 | 欧美精彩视频一区二区三区| 亚洲码国产岛国毛片在线| 天天操天天综合网| 国产精品18久久久| 欧美日韩国产一区二区三区地区| 久久久久免费观看| 一区二区三区成人| 国产精品一区三区| 欧美精品v日韩精品v韩国精品v| 欧美激情一区在线观看| 亚洲成av人片一区二区三区 | 国内精品视频一区二区三区八戒| 色综合天天综合色综合av | 欧美色综合天天久久综合精品| 精品处破学生在线二十三| 玉足女爽爽91| 国产成人综合网站| 91精品国产福利在线观看| 一区免费观看视频| 精品伊人久久久久7777人| 精品视频全国免费看| 亚洲图片激情小说| 国产精品99久久久久久似苏梦涵 | 首页国产欧美久久| 99国产精品久久久| 久久亚洲二区三区| 奇米精品一区二区三区在线观看一| 99精品国产一区二区三区不卡| 久久麻豆一区二区| 蜜臀久久99精品久久久画质超高清 | 日韩一区二区在线播放| 亚洲精品日日夜夜| 成人免费视频视频在线观看免费| 日韩午夜av一区| 一区二区在线观看免费| bt欧美亚洲午夜电影天堂| 久久久亚洲精华液精华液精华液| 丝袜诱惑亚洲看片| 欧美探花视频资源| 亚洲美女精品一区| 91色乱码一区二区三区| 中文字幕的久久| www.亚洲人| 国产精品美日韩| 成人激情动漫在线观看| 中文字幕欧美国产| av中文字幕亚洲| 亚洲天堂久久久久久久| 99久久综合国产精品| 亚洲图片激情小说|