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

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

?? genera~1.c

?? 簡(jiǎn)單遺傳算法經(jīng)典例子!! SGPC: Simple Genetic Programming in C by Walter Alden Tackett and Aviram Carmi
?? C
字號(hào):
/*
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 generations_c_rcsid[]="$Id: generations.c,v 2.13 1993/04/22 07:39:12 gpc-avc Exp gpc-avc $";
#endif

/*
 *
 * $Log: generations.c,v $
 * Revision 2.13  1993/04/22  07:39:12  gpc-avc
 * Removed old log messages
 *
 * Revision 2.12  1993/04/15  09:10:10  gpc-avc
 * Added bsd_qsort()
 *
 *
 */

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

#ifdef ANSI_FUNC

VOID generations(
  int		numpops,
  int		numgens,
  int		start_gen,
  pop_struct	*pop,
  int		demes,
  pop_struct	***grid,
  int		demerows,
  int		demecols
  )
#else

VOID generations(numpops,numgens,start_gen,pop,demes,grid,demerows,demecols)
  int		numpops;
  int		numgens;
  int		start_gen;
  pop_struct	*pop;
  int		demes;
  pop_struct	***grid;
  int		demerows;
  int		demecols;
#endif
{
  int	g, p, i, j;
  float valperf;

  for (g=start_gen; g<numgens; g++) {

    if (g) {
      for (p = 0; p<numpops; p++) {
	if (demes) {
	  for (i=0;i<demerows;i++) {
	    for (j=0;j<demecols;j++) {
	      if (pop[p].steady_state) {
		/* not strictly necessary, really, but removes what
		   i think would otherwise be a trend for the upper
		   left hand of the grid to have much lower fitness
		   than the lower right */
		breed_new_population(grid[random_int(demerows)]
				         [random_int(demecols)],
				     p,demes,demerows,demecols,
				     pop[p].steady_state);
	      } else  {
		breed_new_population(grid[i][j],p,demes,demerows,demecols,
				   pop[p].steady_state);
	      }
	    }
	  }
	} else {

	  breed_new_population(pop,p,0,0,0,pop[p].steady_state);
	}
	if (!(pop[p].steady_state)) {
	  free_population(pop,p);
	  load_new_population(pop,p);
	}
      }
    } else {
      /* generation 0 is random */
      initialize_populations(numpops,pop);
      for (p = 0; p<numpops; p++) {
	if (pop[p].steady_state) {
	  evaluate_fitness_of_populations(numpops,numgens,pop,p);
	  if (pop[p].parsimony_factor > 0.0) add_parsimony_to_fitness(pop,p);
	}
      }
    }

    /* NOTE that we breed ALL populations before we evaluate their fitness
       (except in the case of steady-state).  This is done to support
       co-evolution where there are multiple interacting populations
       who are co-evaluated at each generation */

    for (p = 0; p<numpops; p++) {

      if (!(pop[p].steady_state)) {
	zero_fitness_of_populations(numpops,pop,p);
	evaluate_fitness_of_populations(numpops,numgens,pop,p);
	if (pop[p].parsimony_factor > 0.0) add_parsimony_to_fitness(pop,p);
      }

      normalize_fitness_of_population(pop,p);

      sort_population_by_fitness(pop,p);

      pop[p].best_of_gen_fitness =
	pop[p].standardized_fitness[pop[p].fitness_sort_index[0]];

      pop[p].best_of_generation =
	copy_tree(pop[p].population[pop[p].fitness_sort_index[0]]);

#if REP_ON_GEN == 1
      report_on_generation(g,pop,p);
#endif

#if ((DEBUG == 1)||(DBSS == 1))
      dump_population(pop,p);
#endif      
#if ((DBDEMES == 1)||(DBSS == 1))
      if (demes) { /* this should alway be true, but still.... */
	for (i=0;i<demerows;i++) {
	  for (j=0;j<demecols;j++) {
	    printf("\nDUMPING DEME row=%d col=%d\n",i,j);
	    dump_population(grid[i][j],p);
	  }
	}
      }
#endif

      valperf =
	validate_fitness_of_tree(numpops, numgens, pop, p,
				 pop[p].population[pop[p].fitness_sort_index[0]]);

#if REP_ON_GEN == 1
      printf("\nValidation Fitness= %f\n", valperf);
#endif

      if (!g) {
	pop[p].best_of_run_fitness = valperf;
	pop[p].best_of_run = copy_tree(pop[p].population[pop[p].fitness_sort_index[0]]);
	pop[p].best_of_run_gen = 0;
      }
      else if (valperf < pop[p].best_of_run_fitness) {
	pop[p].best_of_run_fitness = valperf;
	free((char *)pop[p].best_of_run);
	pop[p].best_of_run = copy_tree(pop[p].best_of_generation);
	pop[p].best_of_run_gen = g;
      }
      
      free_tree(pop[p].best_of_generation);

    }

    if (CHECKPOINT_FREQUENCY) {
      if (g && !(g % CHECKPOINT_FREQUENCY)) {
	checkpoint(numpops, numgens, demes, demerows, demecols, pop, g);
      }
    }

    if (terminate_early(numpops,numgens,pop)) break;
  }

  /* checkpoint the last generation, if it was not just saved */
  if (CHECKPOINT_FREQUENCY) {
    if ((numgens-1) % CHECKPOINT_FREQUENCY) {
      checkpoint(numpops,numgens,demes,demerows,demecols,pop,numgens-1);
    }
  }
}


#ifdef ANSI_FUNC
VOID dump_population(
  pop_struct 	*pop,
  int 		p
  )
#else
VOID dump_population(pop,p)
  pop_struct	*pop;
  int		p;
#endif
{
  int	i, index;

  for (i=0; i<pop[p].population_size; i++) {
    index = (DEMES? i : pop[p].fitness_sort_index[i]);
    printf("pop= %d standardized = %f, adjusted = %f, norm = %f\n",
	   p,
	   pop[p].standardized_fitness[index],
	   pop[p].adjusted_fitness[index],
	   pop[p].normalized_fitness[index]);
    write_tree(pop,pop[p].population[index],pop[p].ckpt_format,stdout);
  }
}

#ifdef ANSI_FUNC

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

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

  for (i=0; i<pop[p].population_size; i++) {
    pop[p].standardized_fitness[i] 	= 0.0;
    pop[p].adjusted_fitness[i] 		= 0.0;
    pop[p].normalized_fitness[i] 	= 0.0;
  }
}

int	global_p;

#ifdef ANSI_FUNC
static int fitness_compare(
  int *i,
  int *j
)
#else
static int fitness_compare(i,j)
  int	*i;
  int	*j;
#endif
{
  pop_struct *pop = POP;

  if (pop[global_p].normalized_fitness[*j] > pop[global_p].normalized_fitness[*i]) {
    return 1;
  } else if (pop[global_p].normalized_fitness[*j] < pop[global_p].normalized_fitness[*i]) {
    return -1;
  } else return 0;
}
    
#ifdef ANSI_FUNC
VOID sort_population_by_fitness(
  pop_struct	*pop,
  int 	p
  )
#else
VOID sort_population_by_fitness(pop,p)
  pop_struct	*pop;
  int		p;
#endif
{
  int	i;

  global_p = p; /* kludge for fitness_compare */
  for (i=0; i<pop[p].population_size; i++) {
    pop[p].fitness_sort_index[i] = i;
  }

#ifdef STD_QSORT
  qsort(pop[p].fitness_sort_index, pop[p].population_size, sizeof(int),
	fitness_compare);
#else
  bsd_qsort(pop[p].fitness_sort_index, pop[p].population_size, sizeof(int),
	fitness_compare);
#endif
}

#ifdef ANSI_FUNC
VOID add_parsimony_to_fitness(
  pop_struct 	*pop,
  int 		p
  )
#else
VOID add_parsimony_to_fitness(pop,p)
  pop_struct 	*pop;
  int		p;
#endif
{
  int	i;

  for (i=0; i<pop[p].population_size; i++) {
    pop[p].standardized_fitness[i] += 
      ((float) count_crossover_pts(pop[p].population[i]))*pop[p].parsimony_factor;
  }
}

#ifdef ANSI_FUNC
VOID normalize_fitness_of_population(
  pop_struct	*pop,
  int 		p
)
#else
VOID normalize_fitness_of_population(pop,p)
  pop_struct	*pop;
  int	       	p;
#endif
{
  float	sum = 0.0;
  int	i;

  for (i=0; i<pop[p].population_size; i++) {
    sum += (pop[p].adjusted_fitness[i] = 1.0/(1.0 + pop[p].standardized_fitness[i]));
  }

  for (i=0; i<pop[p].population_size; i++) {
    pop[p].normalized_fitness[i] = (pop[p].adjusted_fitness[i]/sum);
  }
}

#ifdef ANSI_FUNC

VOID report_on_generation(
  int 		g,
  pop_struct	*pop,
  int 		p
  )
#else

VOID report_on_generation(g,pop,p)
  int		g;
  pop_struct	*pop;
  int		p;
#endif
{
  int	i;
  float	sum = 0.0;

  sum = 0.0;

  for (i=0; i<pop[p].population_size; i++) {
    sum += pop[p].standardized_fitness[i];
  }
  
  printf("\nGeneration %d Population %d   Avg Std Fitness: %f\n",
	 g, p, sum/(float)pop[p].population_size);
  printf("Best-of-gen fitness: %f\nBest-of-gen tree:\n",
	 pop[p].best_of_gen_fitness);
  write_tree(pop,pop[p].best_of_generation,pop[p].format,stdout);
}

#ifdef ANSI_FUNC
VOID report_on_run(
  int		numpops,
  pop_struct	*pop
  )
#else
VOID report_on_run(numpops,pop)
  int		numpops;
  pop_struct	*pop;
#endif
{
  int	p;

  for (p=0; p<numpops; p++) {
    printf("Best tree for pop#%d found on gen %d, VALIDATED fitness = %f:\n",
	   p, pop[p].best_of_run_gen, pop[p].best_of_run_fitness);
    write_tree(pop, pop[p].best_of_run, pop[p].format, stdout);
  }
}
on_run(
  int		numpops,
  pop_struct	*pop
  )
#else
VOID report_on_run(numpops,pop)
  int		numpops;
  pop_struct	*pop;
#endif
{
  int	p;

  for (p=0; p<numpops; p++) {
    printf("Best tree for pop#%d found on gen %d, VALIDATED fitness = %f:\n",
	   p, pop[p].best_of_run_gen, pop[p].best_of_run_fitness);
    write_tree(pop, pop[p].best_of_run, pop[p].format, stdout);
  }
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国内精品嫩模私拍在线| 91蝌蚪porny成人天涯| 亚洲视频在线观看三级| 日韩一级片网站| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 日日夜夜精品免费视频| 国产精品女同一区二区三区| 日韩一区二区三区观看| 欧美在线一区二区| 成人aaaa免费全部观看| 韩国毛片一区二区三区| 免费成人性网站| 亚洲一区二区视频| 中文字幕日韩av资源站| 久久久久久久久久久黄色| 欧美放荡的少妇| 色一区在线观看| 99精品欧美一区二区三区综合在线| 久久99久久久欧美国产| 水野朝阳av一区二区三区| 亚洲精品第1页| 亚洲欧美另类久久久精品| 国产亚洲欧美在线| 欧美精品一区二| 日韩亚洲欧美在线观看| 欧美日韩国产高清一区二区| 欧美在线不卡视频| 色88888久久久久久影院野外| 国产成人免费av在线| 国产一区在线观看麻豆| 九九九精品视频| 看电视剧不卡顿的网站| 日韩成人一级大片| 日韩高清一区在线| 日韩成人午夜电影| 美女国产一区二区三区| 日韩—二三区免费观看av| 日韩电影在线免费看| 日韩av午夜在线观看| 免费成人在线视频观看| 美女一区二区三区| 韩日av一区二区| 国产成人av电影免费在线观看| 国产在线视频不卡二| 国产在线国偷精品产拍免费yy | 日本大胆欧美人术艺术动态| 日韩和欧美一区二区| 欧美96一区二区免费视频| 免费亚洲电影在线| 国产在线精品一区二区三区不卡 | 欧美视频一二三区| 51精品国自产在线| 精品剧情在线观看| 日本一区二区电影| 亚洲精品国产品国语在线app| 一区二区三区视频在线看| 亚洲综合精品自拍| 日本在线不卡视频一二三区| 九九九久久久精品| 成人黄色在线视频| 欧美三区在线观看| 欧美一级高清大全免费观看| 久久在线免费观看| 亚洲色大成网站www久久九九| 亚洲最新在线观看| 麻豆精品一区二区三区| 成人午夜又粗又硬又大| 日本韩国一区二区| 日韩欧美高清dvd碟片| 国产婷婷色一区二区三区四区| 亚洲视频你懂的| 美女视频黄频大全不卡视频在线播放 | 国产精品成人在线观看| 亚洲精品日韩综合观看成人91| 午夜影院在线观看欧美| 国产精品一品视频| 欧美优质美女网站| 久久久久久一二三区| 亚洲黄色av一区| 久久精品久久综合| 99re在线精品| 精品国产乱码久久久久久牛牛| 国产精品蜜臀av| 美女网站一区二区| 91黄色小视频| 2021国产精品久久精品| 亚洲国产日产av| 国产激情91久久精品导航| 欧美探花视频资源| 中文字幕av不卡| 玖玖九九国产精品| 欧美午夜电影网| 中文字幕av免费专区久久| 日本麻豆一区二区三区视频| 91丨九色porny丨蝌蚪| 欧美成人女星排名| 亚洲国产精品久久一线不卡| 国产成人免费在线视频| 欧美另类变人与禽xxxxx| 中文乱码免费一区二区 | 99久久国产免费看| 精品国产第一区二区三区观看体验 | 欧美在线视频不卡| 国产精品乱人伦中文| 久久99精品久久久久久动态图| 欧美亚洲高清一区二区三区不卡| 亚洲国产成人午夜在线一区| 蜜臀久久久99精品久久久久久| 欧美影院午夜播放| 成人免费在线视频观看| 成人一区二区三区视频在线观看| 欧美成人激情免费网| 亚洲成人先锋电影| 欧美在线观看一区二区| 成人免费小视频| av在线综合网| 国产婷婷色一区二区三区| 狠狠色狠狠色综合系列| 日韩午夜在线影院| 日本aⅴ免费视频一区二区三区 | 日本一区二区免费在线观看视频 | 精品少妇一区二区三区视频免付费 | 国产精品久久毛片| 国产伦精一区二区三区| 欧美xxxxxxxx| 麻豆一区二区99久久久久| 91精品国产综合久久蜜臀| 亚洲午夜精品网| 欧美日韩一级二级| 亚洲一区二区视频在线| 欧美午夜精品久久久| 亚洲国产精品久久不卡毛片| 欧美亚洲动漫制服丝袜| 亚洲综合另类小说| 欧美日韩国产区一| 天涯成人国产亚洲精品一区av| 在线观看日韩高清av| 亚洲一区二区三区四区在线免费观看 | 欧美丝袜丝交足nylons图片| 亚洲综合免费观看高清完整版在线| 欧美亚洲综合色| 亚洲高清免费观看高清完整版在线观看| 欧洲一区二区av| 天天av天天翘天天综合网| 欧美日本免费一区二区三区| 日本欧美一区二区三区| 日韩免费看的电影| 国产乱妇无码大片在线观看| 国产欧美日韩在线| 91在线免费播放| 亚洲一区二区高清| 欧美一区二区视频观看视频| 蜜桃视频第一区免费观看| 久久日韩粉嫩一区二区三区| 国产91对白在线观看九色| 国产精品电影院| 欧美午夜视频网站| 美女视频黄a大片欧美| 国产亚洲短视频| 91视频你懂的| 午夜成人免费电影| 久久婷婷国产综合国色天香| www.久久精品| 亚洲国产一区二区三区青草影视| 欧美一二三四区在线| 国产在线精品国自产拍免费| 亚洲少妇最新在线视频| 在线不卡的av| 国产剧情一区二区三区| 亚洲精选在线视频| 日韩精品一区二区三区在线| 成人av电影在线| 日本系列欧美系列| 国产精品第四页| 日韩一卡二卡三卡四卡| 成人av综合一区| 另类小说欧美激情| 亚洲欧洲制服丝袜| 欧美xxxxx牲另类人与| 日本精品一区二区三区四区的功能| 日本午夜精品视频在线观看| 国产精品美女久久久久久久| 欧美福利视频一区| 成人理论电影网| 奇米四色…亚洲| 亚洲精品国产精品乱码不99| 久久综合九色综合欧美98| 91久久精品一区二区三| 狠狠色综合色综合网络| 亚洲电影一级黄| 中文在线资源观看网站视频免费不卡| 欧美日韩一区二区在线视频| 国产经典欧美精品| 日本亚洲欧美天堂免费| 亚洲免费观看在线视频| 久久精品网站免费观看| 91精品在线免费观看| 91蝌蚪porny成人天涯| 高清国产午夜精品久久久久久| 偷窥国产亚洲免费视频|