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

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

?? demo12_7_16b.cpp

?? 一本外國人寫的關于3D游戲編程的書的源碼
?? CPP
?? 第 1 頁 / 共 5 頁
字號:
                          // scan for a "hot" cell
                          float max_energy = 0;
                          int cell_x = 0, cell_y = 0;
                        
                          for (int index_x = 0; index_x < 16; index_x++)
                              for (int index_y = 0; index_y < 16; index_y++)
                                  // does this cell have more food?
                                  if (ants_mem[index].cell[index_x][index_y] > max_energy)
                                     {
                                     // update new max
                                     max_energy = ants_mem[index].cell[index_x][index_y]; 
                                     cell_x = index_x; cell_y = index_y;

                                     } // end if

                          // test max and see if we have a winner?
                          if (max_energy > 0)
                             {
                             // vector to this cell
                            ants[index].varsI[ANT_INDEX_AI_SUBSTATE] = ANT_SEARCH_FOOD_S3_VECTOR_2CELL;

                            // send to cell center
                            ants[index].varsI[ANT_INDEX_FOOD_TARGET_X] = 30*cell_x+15;
                            ants[index].varsI[ANT_INDEX_FOOD_TARGET_Y] = 30*cell_y+15;                              

                            // set counters to 0
                            ants[index].counter_1 = ants[index].counter_2 = 0;                           

                             } // end if
                           else
                              { 
                              // go into wander mode, no knowledge of food
                              // vector to this cell
                              ants[index].varsI[ANT_INDEX_AI_SUBSTATE] = ANT_SEARCH_FOOD_S2_WANDER;

                              // set counters 
                              ants[index].counter_1 = RAND_RANGE(100,150);
                              ants[index].counter_2 = 0;  

                              } // end else

                          } break;

                     case ANT_SEARCH_FOOD_S2_WANDER:
                          {
                          // wander and look for food, when done wandering go back and scan
                             
                          // burn food
                          ants[index].varsI[ANT_INDEX_HUNGER_LEVEL]+=1; 

                          // move the ant
                          ants[index].x+=ant_movements_x[ants[index].varsI[ANT_INDEX_DIRECTION]];
                          ants[index].y+=ant_movements_y[ants[index].varsI[ANT_INDEX_DIRECTION]];

                          // test if ant is done with direction and needs a new one
                          if (--ants[index].counter_2 < 0)
                             {
                             // set direction
                             ants[index].varsI[ANT_INDEX_DIRECTION] = RAND_RANGE(ANT_ANIM_UP, ANT_ANIM_LEFT);
    
                             // time in this new direction
                             ants[index].counter_2 = RAND_RANGE(10, 100);

                             // start animation
                             Set_Animation_BOB(&ants[index], ants[index].varsI[ANT_INDEX_DIRECTION]);

                             } // end if new direction

                            // update memory with presence of food
                            int ant_cell_x = ants[index].x / 30;
                            int ant_cell_y = ants[index].y / 30;

                            // this updates the i,jth memory cell in ant with info about food
                            float food_near_ant = Food_Near_Ant(ant_cell_x, ant_cell_y);
                            
                            ants_mem[index].cell[ant_cell_x][ant_cell_y] =
                                 ANT_MEMORY_RESIDUAL_RATE*ants_mem[index].cell[ant_cell_x][ant_cell_y] + 
                                 (1-ANT_MEMORY_RESIDUAL_RATE)*food_near_ant;

                            // test if we just bumped into some food
                            if (food_near_ant > 0)
                               {
                               // find highest source of food
                               int food_x = -1;
                               int food_y = -1;

                               // find the highest food source in cell
                               int food_id = Max_Food_In_Cell(ant_cell_x, ant_cell_y, &food_x, &food_y);
                                                         
                               // pre-empt into vector 2 food
                               ants[index].varsI[ANT_INDEX_AI_SUBSTATE] = 
                                                                   ANT_SEARCH_FOOD_S4_VECTOR_2FOOD;

                               // send to exact position
                               ants[index].varsI[ANT_INDEX_FOOD_TARGET_X] = food_x;
                               ants[index].varsI[ANT_INDEX_FOOD_TARGET_Y] = food_y;
                                                                  
                               // set target id of food
                               ants[index].varsI[ANT_INDEX_FOOD_TARGET_ID] = food_id;

                               // set counters to 0
                               ants[index].counter_1 = ants[index].counter_2 = 0;

                               } // end if
                            
                            // test if we are done with this state and need to go back to scan
                            else
                            if (--ants[index].counter_1 < 0)                                        
                               {
                               // go back to scan state                            
                               ants[index].varsI[ANT_INDEX_AI_SUBSTATE] = ANT_SEARCH_FOOD_S1_SCAN;                            

                               } // end if
             

                          } break;

                     case ANT_SEARCH_FOOD_S3_VECTOR_2CELL: 
                          {
                          // this substate vectors the ant to the center of the cell, once
                          // there the ant "looks" to see if there actually is any food, if so
                          // vectors to it, else goes back and scans

                          // burn food
                          ants[index].varsI[ANT_INDEX_HUNGER_LEVEL]+=2;

                          // pick direction
                          int dx = ants[index].varsI[ANT_INDEX_FOOD_TARGET_X] - ants[index].x;
                          int dy = ants[index].varsI[ANT_INDEX_FOOD_TARGET_Y] - ants[index].y;
                   
                         // pick maxium delta to move in
                         if (abs(dx) >= abs(dy))
                            {
                            // x dominate
                            if (dx > 0)
                               {
                               // move right 
                               if (ants[index].varsI[ANT_INDEX_DIRECTION] != ANT_ANIM_RIGHT)
                                  {
                                  // start animation right
                                  ants[index].varsI[ANT_INDEX_DIRECTION] = ANT_ANIM_RIGHT;
                                  Set_Animation_BOB(&ants[index], ants[index].varsI[ANT_INDEX_DIRECTION]);
                                  } // end if
                               ants[index].x+=ant_movements_x[ants[index].varsI[ANT_INDEX_DIRECTION]];
                               } // end if                             
                            else
                            if (dx < 0)
                               {
                               // move left
                               if (ants[index].varsI[ANT_INDEX_DIRECTION] != ANT_ANIM_LEFT)
                                  {
                                  // start animation left
                                  ants[index].varsI[ANT_INDEX_DIRECTION] = ANT_ANIM_LEFT;
                                  Set_Animation_BOB(&ants[index], ants[index].varsI[ANT_INDEX_DIRECTION]);
                                  } // end if
                                  ants[index].x+=ant_movements_x[ants[index].varsI[ANT_INDEX_DIRECTION]];

                               } // end else

                            } // end if x
                         else
                            {
                            // y dominate
                            if (dy > 0)
                               {
                               // move down
                               if (ants[index].varsI[ANT_INDEX_DIRECTION] != ANT_ANIM_DOWN)
                                  {
                                  // start animation down
                                  ants[index].varsI[ANT_INDEX_DIRECTION] = ANT_ANIM_DOWN;
                                  Set_Animation_BOB(&ants[index], ants[index].varsI[ANT_INDEX_DIRECTION]);
                                  } // end if

                               ants[index].y+=ant_movements_y[ants[index].varsI[ANT_INDEX_DIRECTION]];
                               } // end if                             
                            else
                            if (dy < 0)
                               {
                               // move up
                               if (ants[index].varsI[ANT_INDEX_DIRECTION] != ANT_ANIM_UP)
                                  {
                                  // start animation down
                                  ants[index].varsI[ANT_INDEX_DIRECTION] = ANT_ANIM_UP;
                                  Set_Animation_BOB(&ants[index], ants[index].varsI[ANT_INDEX_DIRECTION]);
                                  } // end if

                                 ants[index].y+=ant_movements_y[ants[index].varsI[ANT_INDEX_DIRECTION]];
                               } // end else

                            } // end else

                          // update memory image ????

                            // update memory with presence of food
                            int ant_cell_x = ants[index].x / 30;
                            int ant_cell_y = ants[index].y / 30;

                            // this updates the i,jth memory cell in ant with info about food
                            float food_near_ant = Food_Near_Ant(ant_cell_x, ant_cell_y);
                            
                            ants_mem[index].cell[ant_cell_x][ant_cell_y] =
                                 ANT_MEMORY_RESIDUAL_RATE*ants_mem[index].cell[ant_cell_x][ant_cell_y] + 
                                 (1-ANT_MEMORY_RESIDUAL_RATE)*food_near_ant;

                          // now test if target reached
                          if (abs(ants[index].x - ants[index].varsI[ANT_INDEX_FOOD_TARGET_X]) < 4 &&
                              abs(ants[index].y - ants[index].varsI[ANT_INDEX_FOOD_TARGET_Y]) < 4)
                             {
                             // center of cell reached, now find the biggest piece of food and
                             // vector to it, if none exist then go back to scan

                            // compute cell position
                            int ant_cell_x = ants[index].x / 30;
                            int ant_cell_y = ants[index].y / 30;

                            // this updates the i,jth memory cell in ant with info about food
                            float food_near_ant = Food_Near_Ant(ant_cell_x, ant_cell_y);
                            
                            // test if we just bumped into some food
                            if (food_near_ant > 0)
                               {
                               // find highest source of food
                               int food_x = -1;
                               int food_y = -1;

                               // find the highest food source in cell
                               int food_id = Max_Food_In_Cell(ant_cell_x, ant_cell_y, &food_x, &food_y);
                                                         
                               // pre-empt into vector 2 food
                               ants[index].varsI[ANT_INDEX_AI_SUBSTATE] = 
                                                      ANT_SEARCH_FOOD_S4_VECTOR_2FOOD;

                               // send to exact position
                               ants[index].varsI[ANT_INDEX_FOOD_TARGET_X] = food_x;
                               ants[index].varsI[ANT_INDEX_FOOD_TARGET_Y] = food_y;
                                                                  
                               // set target id of food
                               ants[index].varsI[ANT_INDEX_FOOD_TARGET_ID] = food_id;

                               // set counters to 0
                               ants[index].counter_1 = ants[index].counter_2 = 0;

                               } // end if
                            else
                               {
                               // set mode to scan
                               ants[index].varsI[ANT_INDEX_AI_SUBSTATE] = ANT_SEARCH_FOOD_S1_SCAN;                            
                               } // end else
 
                             } // end if

                          } break;


                     case ANT_SEARCH_FOOD_S4_VECTOR_2FOOD:
                          {
                          // this substate vectors the ant to the exact x,y of the food 
                          // once there, tests to see if there is food there, if so eats it,
                          // else go to scan
                             
                          // burn food
                          ants[index].varsI[ANT_INDEX_HUNGER_LEVEL]+=2;

                          // pick direction
                          int dx = ants[index].varsI[ANT_INDEX_FOOD_TARGET_X] - ants[index].x;
                          int dy = ants[index].varsI[ANT_INDEX_FOOD_TARGET_Y] - ants[index].y;
                   
                         // pick maxium delta to move in
                         if (abs(dx) >= abs(dy))
                            {
                            // x dominate
                            if (dx > 0)
                               {
                               // move right 
                               if (ants[index].varsI[ANT_INDEX_DIRECTION] != ANT_ANIM_RIGHT)
                                  {
                                  // start animation right
                                  ants[index].varsI[ANT_INDEX_DIRECTION] = ANT_ANIM_RIGHT;
                                  Set_Animation_BOB(&ants[index], ants[index].varsI[ANT_INDEX_DIRECTION]);
                                  } // end if

                               ants[index].x+=ant_movements_x[ants[index].varsI[ANT_INDEX_DIRECTION]];

                               } // end if                             
                            else
                            if (dx < 0)
                               {
                               // move left
                               if (ants[index].varsI[ANT_INDEX_DIRECTION] != ANT_ANIM_LEFT)
                                  {
                                  // start animation left
                                  ants[index].varsI[ANT_INDEX_DIRECTION] = ANT_ANIM_LEFT;
                                  Set_Animation_BOB(&ants[index], ants[index].varsI[ANT_INDEX_DIRECTION]);
                                  } // end if

                                ants[index].x+=ant_movements_x[ants[index].varsI[ANT_INDEX_DIRECTION]];

                               } // end else

                            } // end if x
                         else
                            {
                            // y dominate
                            if (dy > 0)
                               {
                               // move down
                               if (ants[index].varsI[ANT_INDEX_DIRECTION] != ANT_ANIM_DOWN)
                                  {
                                  // start animation down
                                  ants[index].varsI[ANT_INDEX_DIRECTION] = ANT_ANIM_DOWN;
                                  Set_Animation_BOB(&ants[index], ants[index].varsI[ANT_INDEX_DIRECTION]);
                                  } // end if

                               ants[index].y+=ant_movements_y[ants[index].varsI[ANT_INDEX_DIRECTION]];

                               } // end if                             
                            else
                             if (dy < 0)   
                               {
                               // move up
                               if (ants[index].varsI[ANT_INDEX_DIRECTION] != ANT_ANIM_UP)
                                  {
                                  // start animation down
                                  ants[index].varsI[ANT_INDEX_DIRECTION] = ANT_ANIM_UP;
                                  Set_Animation_BOB(&ants[index], ants[index].varsI[ANT_INDEX_DIRECTION]);
                                  } // end if

                                ants[index].y+=ant_movements_y[ants[index].varsI[ANT_INDEX_DIRECTION]];

                               } // end else

                            } // end else

                          // update memory image ????

                            // update memory with presence of food
                            int ant_cell_x = ants[index].x / 30;
                            int ant_cell_y = ants[index].y / 30;

                            // this updates the i,jth memory cell in ant with info about food
                            float food_near_ant = Food_Near_Ant(ant_cell_x, ant_cell_y);
                            
                            ants_mem[index].cell[ant_cell_x][ant_cell_y] =
                                 ANT_MEMORY_RESIDUAL_RATE*ants_mem[index].cell[ant_cell_x][ant_cell_y] + 
                                 (1-ANT_MEMORY_RESIDUAL_RATE)*food_near_ant;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
美腿丝袜亚洲一区| 日本不卡的三区四区五区| 91麻豆免费观看| 亚洲日本免费电影| 欧美久久久久久久久久| 蜜桃视频在线观看一区| 久久久久综合网| 成人av在线电影| 亚洲自拍偷拍综合| 欧美一卡二卡三卡| 成人丝袜18视频在线观看| 亚洲最快最全在线视频| 91精品国产色综合久久不卡电影 | 亚洲一区视频在线观看视频| 欧美日韩国产综合一区二区三区 | 亚洲精品乱码久久久久久久久| 欧美三级视频在线| 精品无人码麻豆乱码1区2区 | 欧美日韩国产电影| 国产乱码精品一区二区三| 亚洲精品高清在线观看| 日韩免费观看高清完整版在线观看| 成人免费视频caoporn| 无码av中文一区二区三区桃花岛| 久久久国产精华| 欧美猛男超大videosgay| 国产成人自拍在线| 午夜精品福利一区二区蜜股av| 国产网站一区二区| 欧美精品久久一区| 99国内精品久久| 精品亚洲国内自在自线福利| 亚洲最快最全在线视频| 国产视频一区在线播放| 欧美一区二区成人6969| 在线一区二区三区四区五区| 国产精品亚洲综合一区在线观看| 亚洲成av人综合在线观看| 国产精品视频看| 欧美成人官网二区| 欧美日韩第一区日日骚| 99精品热视频| 高清不卡一二三区| 精品中文字幕一区二区小辣椒| 亚洲永久精品国产| 最新日韩在线视频| 久久久国产精华| 日韩欧美区一区二| 3d动漫精品啪啪| 欧美综合久久久| 91视频国产观看| 成人小视频免费在线观看| 蜜臀久久99精品久久久画质超高清| 亚洲夂夂婷婷色拍ww47| 亚洲人午夜精品天堂一二香蕉| 国产欧美一区二区精品性| 精品国产乱码91久久久久久网站| 欧美美女网站色| 欧美日韩国产高清一区二区| 欧美性大战久久久久久久| 色狠狠桃花综合| 色综合欧美在线| 色综合久久久久久久久| 91麻豆免费视频| 色综合久久久久综合99| 91啦中文在线观看| 日本高清视频一区二区| 色婷婷激情久久| 欧美私人免费视频| 欧美日韩中文另类| 欧美精品第一页| 91精品一区二区三区在线观看| 欧美日韩成人一区| 欧美一区国产二区| 欧美成人欧美edvon| xfplay精品久久| 久久久一区二区三区捆绑**| 国产欧美日韩综合精品一区二区 | 久久久久久一二三区| 久久男人中文字幕资源站| 国产午夜精品一区二区三区视频 | 亚洲在线视频网站| 天天综合色天天综合色h| 免费精品视频最新在线| 黄页视频在线91| 丁香另类激情小说| 色婷婷激情久久| 欧美高清视频一二三区| 日韩一卡二卡三卡国产欧美| 久久综合色天天久久综合图片| 国产日韩欧美一区二区三区乱码 | 亚洲欧美日韩在线| 亚洲国产一区二区三区| 日本v片在线高清不卡在线观看| 久久精品免费观看| 成人中文字幕电影| 精品视频在线视频| 亚洲精品在线免费播放| 国产精品国产三级国产有无不卡| 亚洲欧美色综合| 人禽交欧美网站| 粉嫩av一区二区三区| 欧美色综合天天久久综合精品| 欧美一级高清片在线观看| 欧美韩日一区二区三区| 一级做a爱片久久| 激情久久五月天| 91论坛在线播放| 欧美大片一区二区三区| 亚洲欧洲日韩综合一区二区| 午夜精品一区二区三区电影天堂 | 亚洲香肠在线观看| 韩国一区二区三区| 一本高清dvd不卡在线观看| 精品少妇一区二区| 亚洲另类在线制服丝袜| 狠狠狠色丁香婷婷综合激情| 在线观看免费亚洲| 国产午夜久久久久| 日韩av在线播放中文字幕| 9l国产精品久久久久麻豆| 在线播放日韩导航| 国产精品视频观看| 免费xxxx性欧美18vr| 91久久精品网| 国产欧美日韩激情| 青青国产91久久久久久| 欧洲另类一二三四区| 中文字幕精品一区二区三区精品| 人人精品人人爱| 欧美在线视频全部完| 中文字幕在线不卡一区| 国产精品99久| 日韩欧美123| 偷窥少妇高潮呻吟av久久免费| 91视频你懂的| 国产精品嫩草久久久久| 黄页视频在线91| 日韩一区二区视频| 五月婷婷久久综合| 在线观看亚洲专区| 亚洲男人的天堂网| 成人精品国产一区二区4080| 久久久久久久久久美女| 久久成人综合网| 91精品国产综合久久久久久久| 一区二区视频在线看| 99综合电影在线视频| 国产精品无人区| 国产a精品视频| 26uuu亚洲综合色| 韩国中文字幕2020精品| 精品国产a毛片| 狠狠色狠狠色综合系列| 欧美videos中文字幕| 日韩国产精品91| 欧美精品18+| 男女男精品视频网| 日韩欧美二区三区| 韩国三级中文字幕hd久久精品| 欧美一级xxx| 激情五月婷婷综合| 久久久久久久久岛国免费| 国产精品1区2区| 日本一区二区免费在线观看视频| 国产精品原创巨作av| 中文字幕免费不卡| 91天堂素人约啪| 一二三区精品福利视频| 欧美日韩三级一区| 蜜桃av一区二区在线观看| 欧美mv日韩mv国产| 国产成人综合在线播放| 国产精品国产自产拍高清av王其 | 久久精品视频网| 国v精品久久久网| 亚洲女人的天堂| 欧美天堂一区二区三区| 日韩国产欧美在线播放| 久久综合国产精品| 99久久国产免费看| 亚洲国产视频网站| 日韩三级高清在线| 国产成人免费视| 亚洲精品伦理在线| 欧美一级久久久久久久大片| 国产最新精品精品你懂的| 国产精品全国免费观看高清| 色婷婷综合五月| 另类专区欧美蜜桃臀第一页| 日本一区二区免费在线观看视频 | 日韩小视频在线观看专区| 国产专区综合网| 亚洲精品综合在线| 日韩一区二区免费在线观看| 国产成人综合亚洲网站| 亚洲一区二区三区四区不卡| 日韩欧美三级在线| 色综合天天在线| 美美哒免费高清在线观看视频一区二区 |