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

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

?? ccontroller.cpp

?? 基于遺傳算法和神經網絡的外星人游戲的vc++實現的程序
?? CPP
字號:
#include "CController.h"

                                      

//-----------------------------ctor---------------------------------------
//
//------------------------------------------------------------------------
CController::CController(int cxClient,
                         int cyClient):m_iNumSpawnedFromTheMultiset(0),
                                       m_cxClient(cxClient),
                                       m_cyClient(cyClient),
                                       m_iAliensCreatedSoFar(0),
                                       m_bFastRender(true)
                                     
                                       
{
  //create a gun
  m_pGunTurret = new CGun();

  //create the first few aliens
  for (int a=0; a<CParams::iNumOnScreen; ++a)
  {
    m_vecActiveAliens.push_back(CAlien());

    ++m_iAliensCreatedSoFar;
  }

  //setup the stars
  for (int star=0; star<NUM_STARS; ++star)
  {
    m_vecStarVB.push_back(SPoint(RandInt(0, cxClient), RandInt(0, cyClient)));
  }

  //create the custom pens 
  m_GreenPen = CreatePen(PS_SOLID, 1, RGB(0, 200, 0));
  m_RedPen   = CreatePen(PS_SOLID, 1, RGB(255, 0, 0));
  m_GunPen   = CreatePen(PS_SOLID, 1, RGB(200, 200, 100));
  m_BarPen   = CreatePen(PS_SOLID, 5, RGB(0, 0, 255));
}

//----------------------------------- dtor -------------------------------
//
//------------------------------------------------------------------------
CController::~CController()
{
  //clean up the pens
  DeleteObject(m_GreenPen);
  DeleteObject(m_RedPen);
  DeleteObject(m_GunPen);
  DeleteObject(m_BarPen);


  //delete the gun turret
  delete m_pGunTurret;
}

//---------------------------- Reset -------------------------------------
//
//  Resets ready for another go
//------------------------------------------------------------------------
void CController::Reset()
{
  //clear all current aliens
  m_vecActiveAliens.clear();
  m_setAliens.clear();

  //reset all variables
  m_iAliensCreatedSoFar        = 0;
  m_iNumSpawnedFromTheMultiset = 0;
  m_bFastRender                = true;
  
  m_pGunTurret->AutoGunOn();

  //create the first few aliens
  for (int a=0; a<CParams::iNumOnScreen; ++a)
  {
    m_vecActiveAliens.push_back(CAlien());

    ++m_iAliensCreatedSoFar;
  }
}


//-----------------------Render--------------------------------------
//
//-------------------------------------------------------------------
void CController::Render(HDC &surface)
{
  if (!m_bFastRender)
  {
    //change the mapping mode so that the origin is at the bottom left
    //of our window and so that the y axis increases as it goes from
    //bottom to top     
    SetMapMode( surface, MM_ANISOTROPIC );
    SetViewportExtEx( surface, 1, -1, NULL );
    SetWindowExtEx( surface, 1, 1, NULL );
    SetViewportOrgEx( surface, 0, m_cyClient, NULL );


    //-------------------first render the stars

    for (int i=0; i<m_vecStarVB.size(); ++i)
    {
      //make them twinkle
      if (RandFloat() > 0.1)
      {
        SetPixel(surface, m_vecStarVB[i].x, m_vecStarVB[i].y, RGB(255, 255, 255));
      }
    }


    //-------------------render the aliens

    for (i=0; i<m_vecActiveAliens.size(); ++i)
    {
      m_vecActiveAliens[i].Render(surface, m_GreenPen, m_RedPen);
    }

    //-------------------render the gun and any bullets

    m_pGunTurret->Render(surface, m_GunPen);


    //-------------------render additional information

    SetBkMode(surface, TRANSPARENT);
    SetTextColor(surface, RGB(0,0,255));
  
    string s = "Num Spawned " + itos(m_iNumSpawnedFromTheMultiset);
	  TextOut(surface, 5, m_cyClient-5, s.c_str(), s.size());
    
 
    //return the mapping mode to its default state so text is rendered
    //correctly
    SetMapMode( surface, MM_ANISOTROPIC );
    SetViewportExtEx( surface, 1, 1, NULL );
    SetWindowExtEx( surface, 1, 1, NULL );
    SetViewportOrgEx( surface, 0, 0, NULL );
    
  }

  else
  {
    SetBkMode(surface, TRANSPARENT);
    SetTextColor(surface, RGB(0,0,255));
  
	  string s = "PreSpawning";
	  TextOut(surface, 10, m_cyClient-45, s.c_str(), s.size());

    HPEN OldPen = (HPEN)SelectObject(surface, m_BarPen);

    MoveToEx(surface, 10, m_cyClient -20, NULL);
    LineTo(surface, (m_cxClient/(double)CParams::iPreSpawns)*m_iNumSpawnedFromTheMultiset-10, m_cyClient -20);

    SelectObject(surface, OldPen);

  }
}


//------------------------------- Update ---------------------------------
//
//  The workhorse of the program. Updates all the game objects and
//  spawns new aliens into the population.
//------------------------------------------------------------------------
bool CController::Update()
{
  
  //switch the autogun off if enough offspring have been
  //spawned
  if (m_iNumSpawnedFromTheMultiset > CParams::iPreSpawns)
  {
    m_pGunTurret->AutoGunOff();

    m_bFastRender = false;
  }
  
  //get update from player for the turret movement
  //and update any bullets that may have been fired
  m_pGunTurret->Update();
    
  //move the stars
  for (int str=0; str<m_vecStarVB.size(); ++str)
  {
    m_vecStarVB[str].y -= 0.2f;

    if (m_vecStarVB[str].y < 0)
    {
      //create a new star
      m_vecStarVB[str].x = RandInt(0, CParams::WindowWidth);
      m_vecStarVB[str].y = CParams::WindowHeight;
    }
  }


  //update the aliens
  for (int i=0; i<m_vecActiveAliens.size(); ++i)
  {

    //if alien has 'died' replace with a new one
    if (!m_vecActiveAliens[i].Update(m_pGunTurret->m_vecBullets,
                               m_pGunTurret->m_vPos))
    { 

      //first we need to re-insert into the breeding population so
      //that its fitness score and genes are recorded.
      m_setAliens.insert(m_vecActiveAliens[i]);

      //if the required population size has been reached, delete the 
      //worst performer from the multiset
      if (m_setAliens.size() >= CParams::iPopSize)
      {      
        m_setAliens.erase(--m_setAliens.end());        
      }

      ++m_iNumSpawnedFromTheMultiset;
                  
      //if early in the run then we are still trying out new aliens
      if (m_iAliensCreatedSoFar <= CParams::iPopSize)
      {
        m_vecActiveAliens[i] = CAlien();

        ++m_iAliensCreatedSoFar;          
      }

      //otherwise select from the multiset and apply mutation
      else
      {         
        m_vecActiveAliens[i] = TournamentSelection();

        m_vecActiveAliens[i].Reset();

        if (RandFloat() < 0.8)
        {
          m_vecActiveAliens[i].Mutate();
        }
      }
    }
  }//next alien

  return true;
}


//---------------------------- TournamentSelection -----------------------
//
//  performs standard tournament selection given a number of genomes to
//  sample from each try.
//------------------------------------------------------------------------
CAlien CController::TournamentSelection()
{
  double BestFitnessSoFar = 0;

  //this will hold the winner of the tournament
  AlienIterator ChosenAlien = NULL;  

  //Select N members from the population at random testing against 
  //the best found so far
  for (int i=0; i<CParams::iNumTourneyCompetitors; ++i)
  {
    //select an alien from the population at random
    AlienIterator curAlien = m_setAliens.begin();

    advance(curAlien, RandInt(0, (int)(m_setAliens.size()-1) * CParams::dPercentageBestToSelectFrom));

    //test it to see if it's fitter than any selected so far and that its not already active
    if ( curAlien->Fitness() > BestFitnessSoFar)
    {
      ChosenAlien = curAlien;

      BestFitnessSoFar = curAlien->Fitness();
    }
  }

  //return our champion
  return *ChosenAlien;
}
	


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久97超碰国产精品超碰| 99综合电影在线视频| 国产精品一区二区免费不卡| 99久久国产免费看| 精品国产乱码久久久久久久 | 久久奇米777| 亚洲欧美国产毛片在线| 国产原创一区二区| 欧美精品日日鲁夜夜添| 亚洲日本在线天堂| 国产精品伊人色| 91精品一区二区三区在线观看| 国产精品福利电影一区二区三区四区| 日韩国产在线一| 在线观看一区二区视频| 国产精品久久久久影视| 国产一区二区三区在线观看精品| 欧美一区二区三区电影| 午夜一区二区三区视频| 91视频免费观看| 亚洲视频网在线直播| 国产成人在线视频网站| 日韩免费在线观看| 日韩成人免费电影| 欧美一区二区三区喷汁尤物| 亚洲va欧美va人人爽午夜| 色老汉av一区二区三区| 最新日韩在线视频| 91在线国产观看| 亚洲欧洲性图库| 91丨porny丨首页| 亚洲欧美另类小说视频| 色综合久久88色综合天天免费| 国产精品不卡视频| 97久久人人超碰| 亚洲愉拍自拍另类高清精品| www.亚洲免费av| 亚洲人吸女人奶水| 91久久精品国产91性色tv| 一级做a爱片久久| 欧美日韩亚洲国产综合| 日韩精品电影在线| 欧美成人r级一区二区三区| 久久成人麻豆午夜电影| 久久久一区二区三区| 粉嫩蜜臀av国产精品网站| 亚洲色欲色欲www| 欧美丝袜丝交足nylons图片| 日韩电影免费在线看| 精品美女在线观看| 不卡视频在线观看| 亚洲美女视频一区| 91精品国产乱| 福利一区二区在线观看| 亚洲狠狠丁香婷婷综合久久久| 在线欧美日韩国产| 日韩二区在线观看| 中文字幕乱码久久午夜不卡| 一本一本大道香蕉久在线精品 | 91免费在线看| 午夜精品久久久| 久久久国产一区二区三区四区小说| 夫妻av一区二区| 亚洲v精品v日韩v欧美v专区| 精品福利视频一区二区三区| 成人av免费网站| 青青草成人在线观看| 亚洲国产成人一区二区三区| 欧美亚洲综合在线| 国产麻豆91精品| 天堂蜜桃一区二区三区| 国产日韩欧美不卡| 欧美日本一区二区| 懂色一区二区三区免费观看| 亚洲国产综合人成综合网站| 精品理论电影在线| 在线观看国产一区二区| 国产成人8x视频一区二区| 午夜在线电影亚洲一区| 欧美国产精品中文字幕| 日韩欧美一区二区免费| 色婷婷综合久久久中文一区二区| 精品一区二区三区av| 亚洲国产欧美一区二区三区丁香婷 | 91麻豆精品91久久久久久清纯 | 偷拍与自拍一区| 国产精品国产a| 日韩免费福利电影在线观看| 色菇凉天天综合网| 国产一区二区三区久久久| 图片区小说区区亚洲影院| 亚洲人吸女人奶水| 国产精品免费丝袜| 久久奇米777| 日韩免费一区二区| 欧美日韩国产一二三| 91丝袜美腿高跟国产极品老师 | 久久精品国产亚洲aⅴ| 亚洲一区二区成人在线观看| 亚洲欧洲精品一区二区三区| 久久久午夜电影| 亚洲精品一区二区精华| 欧美一级淫片007| 这里只有精品视频在线观看| 日本福利一区二区| 色婷婷久久久亚洲一区二区三区 | 日韩成人av影视| 亚洲18色成人| 亚洲成人激情av| 一片黄亚洲嫩模| 亚洲综合色自拍一区| 亚洲欧美日韩综合aⅴ视频| 欧美韩日一区二区三区| 国产日韩三级在线| 2020国产精品| 久久九九久久九九| 久久精品在线观看| 中文字幕第一页久久| 国产精品青草久久| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 欧美极品另类videosde| 国产精品理论在线观看| 中文字幕亚洲区| 一区二区激情视频| 日韩 欧美一区二区三区| 日本人妖一区二区| 国产精品自拍在线| 成人黄色软件下载| 色妹子一区二区| 欧美日韩三级一区| 91精品免费在线观看| 精品国产区一区| 国产精品无人区| 亚洲午夜成aⅴ人片| 人人精品人人爱| 国产成人免费视频一区| 91色视频在线| 欧美日韩国产成人在线免费| 日韩一区二区免费高清| 国产亚洲一本大道中文在线| 中文字幕欧美一区| 婷婷久久综合九色综合伊人色| 免费高清不卡av| 成人精品一区二区三区四区| 色欧美片视频在线观看在线视频| 91精品国产综合久久蜜臀| www久久久久| 亚洲男女一区二区三区| 奇米精品一区二区三区四区 | 欧美三区在线观看| 精品乱码亚洲一区二区不卡| 一区二区中文视频| 六月丁香婷婷色狠狠久久| 成人免费看视频| 欧美精选午夜久久久乱码6080| 精品国精品自拍自在线| 亚洲欧美日韩电影| 另类成人小视频在线| 91看片淫黄大片一级在线观看| 日韩欧美在线影院| 亚洲视频免费看| 国产电影一区二区三区| 欧美日韩国产精选| 国产精品美女一区二区| 青娱乐精品在线视频| 91麻豆文化传媒在线观看| 欧美不卡视频一区| 亚洲一区二区三区美女| 国产成人精品影视| 欧美一激情一区二区三区| 日韩美女精品在线| 国内久久婷婷综合| 在线播放亚洲一区| 亚洲欧美另类久久久精品| 国产九色精品成人porny| 欧美日韩久久久一区| 亚洲天堂成人网| 高清国产午夜精品久久久久久| 欧美成人女星排名| 午夜精品久久久| 欧美色网站导航| 中文字幕综合网| 99综合电影在线视频| 国产午夜三级一区二区三| 激情久久五月天| 91精品国产综合久久久久久漫画| 亚洲已满18点击进入久久| av在线不卡网| 国产精品电影一区二区三区| 国产成人综合视频| 国产香蕉久久精品综合网| 激情欧美一区二区三区在线观看| 3atv在线一区二区三区| 亚洲成人www| 欧美日韩在线观看一区二区 | 免费看日韩精品| 这里是久久伊人| 日韩av电影免费观看高清完整版 | 中文字幕一区在线| 成人av网站在线观看免费|