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

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

?? treeops.c

?? 遺傳算法工具
?? 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 treeops_c_rcsid[]="$Id: treeops.c,v 2.7 1993/04/22 07:39:12 gpc-avc Exp gpc-avc $";
#endif

/*
 *
 * $Log: treeops.c,v $
 * Revision 2.7  1993/04/22  07:39:12  gpc-avc
 * Removed old log messages
 *
 * Revision 2.6  1993/04/14  04:42:52  gpc-avc
 * Fixed side effect of read_tree() modifying the random seed.
 * replaced global references to POP by the arg pop
 *
 *
 */

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



#ifdef ANSI_FUNC

tree *create_tree_node(
  int pop,
  int nodetype,
  int id
  )
#else

tree *create_tree_node(pop, nodetype, id)
  int	pop;
  int	nodetype;
  int	id;
#endif
{
  tree	*t;
  
  if ((t = (tree *) malloc(sizeof(tree))) == NULL) {
    perror(" at point 1 in create_tree_node() <treeops.c>");
    exit(errno);
  }
  
  t->nodetype = nodetype;
  t->id = id;
  t->pop = pop;

  switch (nodetype) {
  case FUNCTION:
    init_function(t);
    break;
  case TERMINAL:
    init_terminal(t);
    break;
  default:
    fprintf(stderr,
	    "nodetype %d must be %d or %d in create_tree_node() <treeops.c>\n",
	    nodetype, FUNCTION, TERMINAL);
  }
  
  return t;
}

#ifdef ANSI_FUNC

VOID init_function(
  tree *t
  )
#else

VOID init_function(t)
  tree	*t;
#endif
{
  pop_struct *pop = POP;
 
  if ((t->id < 0) || (t->id >= pop[t->pop].function_table_size)) {
    fprintf(stderr,
	    "id %d must be >= 0 and < %d in init_function() <treeops.c>\n",
	    t->id, pop[t->pop].function_table_size);
  }

  
  if ((t->type.func = (function *) malloc(sizeof(function))) == NULL) {
    perror(" at point 1 in init_function() <treeops.c>");
    exit(errno);
  }
  
  if ((t->type.func->arg =
       (tree **) malloc(function_arity(t) * sizeof(tree *))) == NULL) {
    perror(" at point 2 in init_function() <treeops.c>");
    exit(errno);
  }
  
  if ((t->type.func->argvals =
       (GENERIC *) malloc(function_arity(t) * sizeof(GENERIC))) == NULL) {
    perror(" at point 3 in init_function() <treeops.c>");
    exit(errno);
  }
}

#ifdef ANSI_FUNC

VOID init_terminal(
  tree 	*t
)
#else

VOID init_terminal(t)
  tree	*t;
#endif
{
  pop_struct *pop = POP;
  GENERIC junk = -999999;

  /* t->id == terminal_table_size indicates that this terminal is a constant
     rather than a variable */

  if ((t->id < 0) || (t->id > pop[t->pop].terminal_table_size)) {
    fprintf(stderr,
	    "id %d must be >= 0 and <= %d in init_terminal() <treeops.c>\n",
	    t->id, pop[t->pop].terminal_table_size);
  }
  
  if ((t->type.term = (terminal *) malloc(sizeof(terminal))) == NULL) {
    perror(" at point 1 in init_terminal() <treeops.c>");
    exit(errno);
  }
  
  if (terminal_is_constant(t)) {
    if ((t->type.term->valptr = (GENERIC *) malloc(sizeof(GENERIC))) == NULL) {
      perror(" at point 2 in init_terminal() <treeops.c>");
      exit(errno);
    }
    /* stick a junk value into value pointer.  this may be replaced by the
       constant read from a file (if called by read_tree()) or the constant
       value of the leaf being copied (if called by copy_tree()) or
       by a random value if called form create_random_tree */
      *(t->type.term->valptr) = junk;
  } else {
    t->type.term->valptr = &(terminal_val(t));
  }
}

#ifdef ANSI_FUNC

tree *copy_tree(
	tree *t
	)
#else

tree *copy_tree(t)
tree   *t;
#endif
{
  switch (t->nodetype) {
  case FUNCTION:
    return copy_function(t);
  case TERMINAL:
    return copy_terminal(t);
  default:
    fprintf(stderr,
	    "nodetype %d must be %d or %d in copy_tree() <treeops.c>\n",
	    t->nodetype, FUNCTION, TERMINAL);
    return (tree *) NULL;
  }
}

#ifdef ANSI_FUNC

tree *copy_function(
  tree *t
  )
#else

tree *copy_function(t)
  tree *t;
#endif
{
  tree *nt;
  int  i;
  pop_struct *pop = POP;
  
  nt = create_tree_node(t->pop,t->nodetype, t->id);
  for (i=0; i < function_arity(t); i++ ) {
    nt->type.func->arg[i] = copy_tree(t->type.func->arg[i]);
  }
  return nt;
}


#ifdef ANSI_FUNC

tree *copy_terminal(
  tree *t
  )
#else

tree *copy_terminal(t)
  tree *t;
#endif
{
  tree *nt;
  pop_struct *pop = POP;
  
  nt = create_tree_node(t->pop,t->nodetype, t->id);
  if (terminal_is_constant(t)) {
    *(nt->type.term->valptr) = (*(t->type.term->valptr));
  }
  return nt;
}


#ifdef ANSI_FUNC

VOID free_tree(
  tree *t
  )
#else

VOID free_tree(t)
  tree   *t;
#endif
{
  switch (t->nodetype) {
  case FUNCTION:
    free_function(t);
    break;
  case TERMINAL:
    free_terminal(t);
    break;
  default:
    fprintf(stderr,
	    "nodetype %d must be %d or %d in free_tree() <treeops.c>\n",
	    t->nodetype, FUNCTION, TERMINAL);
  }
}

#ifdef ANSI_FUNC

VOID free_function(
  tree *t
  )
#else

VOID free_function(t)
  tree *t;
#endif
{
  int  i;
  pop_struct *pop = POP;
  
  for (i=0; i < function_arity(t); i++ ) {
    free_tree(t->type.func->arg[i]);
  }
  free(t->type.func->arg);
  free(t->type.func->argvals);
  free(t->type.func);
  free(t);
}

#ifdef ANSI_FUNC

VOID free_terminal(
  tree *t
  )
#else

VOID free_terminal(t)
  tree *t;
#endif
{
  pop_struct *pop = POP;

  if (terminal_is_constant(t)) {
    free(t->type.term->valptr);
  }
  free(t->type.term);
  free(t);
}
>type.func->argvals);
  free(t->type.func);
  free(t);
}

#ifdef ANSI_FUNC

VOID free_terminal(
  tree *t
  )
#else

VOID free_terminal(t)
  tree *t;
#endif
{
  pop_struct *pop = POP;

  if (terminal_is_constant(t)) {
    free(t->type.term->valptr);
  }
  free(t->type.term);
  free(t);
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一卡在线观看| 在线看日本不卡| 国产午夜亚洲精品不卡| 狠狠色丁香久久婷婷综| 337p日本欧洲亚洲大胆色噜噜| 久久精品国产在热久久| 日韩精品一区在线| 国产成人日日夜夜| 亚洲欧美激情插| 欧美精品在线一区二区| 韩国一区二区三区| 国产精品免费aⅴ片在线观看| 成人黄色一级视频| 亚洲欧美韩国综合色| 欧美日韩精品高清| 激情综合网天天干| 1024精品合集| 91精品在线免费| 国产suv精品一区二区三区| 亚洲品质自拍视频| 日韩欧美国产成人一区二区| 高清久久久久久| 性感美女极品91精品| 久久女同精品一区二区| 91福利资源站| 韩国v欧美v日本v亚洲v| 亚洲免费成人av| 欧美成人在线直播| 91女人视频在线观看| 免费视频一区二区| 国产精品高潮呻吟久久| 91精品国产免费| 成人a区在线观看| 免费人成精品欧美精品| 中文字幕中文在线不卡住| 6080午夜不卡| 99精品国产热久久91蜜凸| 日韩**一区毛片| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 精品视频在线免费看| 成人免费看的视频| 久久国产生活片100| 亚洲精品成人在线| 中文字幕精品一区| 日韩欧美在线网站| 在线观看日产精品| 成人av先锋影音| 国内偷窥港台综合视频在线播放| 亚洲国产精品麻豆| 中文字幕一区在线观看视频| 日韩精品中文字幕一区二区三区| 欧美午夜影院一区| 97久久精品人人爽人人爽蜜臀| 久久国产尿小便嘘嘘| 五月天视频一区| 亚洲精品网站在线观看| 国产精品免费aⅴ片在线观看| 欧美成人一区二区三区在线观看| 欧美日韩久久久一区| 91丝袜美腿高跟国产极品老师 | 成人sese在线| 国产一区欧美二区| 久久电影网电视剧免费观看| 同产精品九九九| 亚洲宅男天堂在线观看无病毒| 亚洲欧美一区二区在线观看| 久久久久青草大香线综合精品| 欧美一区二区福利在线| 欧美日韩在线亚洲一区蜜芽| 欧美在线免费视屏| 欧美亚洲国产一区二区三区 | 91色.com| 91蝌蚪porny| a美女胸又www黄视频久久| 粉嫩av一区二区三区在线播放| 精品一区二区三区av| 国产一区二区不卡老阿姨| 韩国女主播成人在线| 国产一区美女在线| 国产成人在线电影| 成人av电影在线网| 91国在线观看| 777色狠狠一区二区三区| 91精品国产综合久久久久| 制服丝袜亚洲色图| 欧美tickling网站挠脚心| 日韩精品一区二区三区视频播放 | 亚洲精品综合在线| 一区二区三区日韩精品| 亚洲一级不卡视频| 五月激情综合网| 喷水一区二区三区| 国产剧情一区在线| 97se亚洲国产综合自在线| 91成人免费在线| 日韩一区二区三区电影在线观看| 精品国产乱码久久久久久夜甘婷婷 | 亚洲自拍另类综合| 日韩av中文字幕一区二区三区| 麻豆视频一区二区| 粉嫩aⅴ一区二区三区四区五区| 不卡区在线中文字幕| 欧美日韩亚洲不卡| 精品国产1区二区| 亚洲欧洲美洲综合色网| 亚洲综合在线免费观看| 日本麻豆一区二区三区视频| 国产精品456| 欧美性一级生活| 欧美精品一区二区在线播放| 国产精品妹子av| 男人的天堂久久精品| 成人午夜av电影| 欧美日韩综合不卡| 国产性色一区二区| 亚洲v中文字幕| 成人中文字幕在线| 欧美日韩mp4| 亚洲国产电影在线观看| 亚洲成人精品一区二区| 懂色一区二区三区免费观看| 欧美亚州韩日在线看免费版国语版| 日韩天堂在线观看| 亚洲精品你懂的| 国产老肥熟一区二区三区| 在线观看网站黄不卡| 欧美激情一区二区三区四区| 性感美女久久精品| 91在线观看高清| 久久婷婷国产综合精品青草| 亚洲一区二区三区视频在线 | 国产精品亚洲成人| 欧美日韩高清一区| 亚洲视频小说图片| 国产一区高清在线| 欧美一二区视频| 夜夜操天天操亚洲| 成人av一区二区三区| 久久综合九色综合欧美就去吻| 五月婷婷综合在线| 色婷婷久久一区二区三区麻豆| 久久久三级国产网站| 日本sm残虐另类| 欧美三级视频在线| 亚洲嫩草精品久久| 不卡av免费在线观看| 久久综合狠狠综合久久激情 | 久久久精品黄色| 久久99久久99精品免视看婷婷 | 日韩欧美第一区| 五月开心婷婷久久| 欧美少妇一区二区| 综合精品久久久| 成人黄色小视频在线观看| 国产三级久久久| 国产在线国偷精品产拍免费yy| 制服视频三区第一页精品| 一区二区成人在线视频| 在线视频国内自拍亚洲视频| 亚洲欧洲另类国产综合| 不卡一卡二卡三乱码免费网站| 亚洲国产精品传媒在线观看| 国产裸体歌舞团一区二区| 欧美精品一区二区三区很污很色的| 秋霞国产午夜精品免费视频| 日韩一区二区三区免费看| 免费av网站大全久久| 日韩欧美中文字幕公布| 激情欧美一区二区| 久久婷婷国产综合精品青草| 国产精品一区二区免费不卡| 久久蜜桃一区二区| 不卡免费追剧大全电视剧网站| 中文字幕在线不卡国产视频| 91麻豆精东视频| 亚洲一区二区三区中文字幕| 欧美日韩一二三区| 蜜臀国产一区二区三区在线播放| 日韩精品一区国产麻豆| 国产精品99久久不卡二区| 国产精品色哟哟| 99re这里只有精品首页| 亚洲一区二区三区小说| 日韩欧美久久久| 国产精品1区2区| 综合久久久久久| 欧美男人的天堂一二区| 激情综合网最新| 国产精品不卡在线观看| 欧美午夜不卡在线观看免费| 蜜臀久久99精品久久久久久9| 2020日本不卡一区二区视频| 成人激情校园春色| 亚洲二区在线观看| 精品成人一区二区三区四区| 9久草视频在线视频精品| 亚洲第一主播视频| 久久久久亚洲综合| 欧美性猛片aaaaaaa做受| 国产一区二区不卡在线|