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

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

?? cneuralnet.cpp

?? 開發(fā)游戲人工智能的王道書
?? CPP
字號:
#include "CNeuralNet.h"



//*************************** methods for Neuron **********************
//
//---------------------------------------------------------------------
SNeuron::SNeuron(int NumInputs): m_NumInputs(NumInputs+1)
											
{
	//we need an additional weight for the bias hence the +1
	for (int i=0; i<NumInputs+1; ++i)
	{
		//set up the weights with an initial random value
		m_vecWeight.push_back(RandomClamped());
	}
}




//************************ methods for NeuronLayer **********************

//-----------------------------------------------------------------------
//	ctor creates a layer of neurons of the required size by calling the 
//	SNeuron ctor the rqd number of times
//-----------------------------------------------------------------------
SNeuronLayer::SNeuronLayer(int NumNeurons, 
                           int NumInputsPerNeuron):	m_NumNeurons(NumNeurons)
{
	for (int i=0; i<NumNeurons; ++i)

		m_vecNeurons.push_back(SNeuron(NumInputsPerNeuron));
}




//************************ methods forCNeuralNet ************************

//------------------------------default ctor ----------------------------
//
//	creates a ANN based on the default values in defines.h
//-----------------------------------------------------------------------
CNeuralNet::CNeuralNet() 
{
	m_NumInputs	          =	CParams::iNumInputs;
	m_NumOutputs		      =	CParams::iNumOutputs;
	m_NumHiddenLayers	    =	CParams::iNumHidden;
	m_NeuronsPerHiddenLyr =	CParams::iNeuronsPerHiddenLayer;

	CreateNet();

}


//------------------------------createNet()------------------------------
//
//	this method builds the ANN. The weights are all initially set to 
//	random values -1 < w < 1
//------------------------------------------------------------------------
void CNeuralNet::CreateNet()
{
	//create the layers of the network
	if (m_NumHiddenLayers > 0)
	{
		//create first hidden layer
	  m_vecLayers.push_back(SNeuronLayer(m_NeuronsPerHiddenLyr, m_NumInputs));
    
    for (int i=0; i<m_NumHiddenLayers-1; ++i)
    {

			m_vecLayers.push_back(SNeuronLayer(m_NeuronsPerHiddenLyr,
                                         m_NeuronsPerHiddenLyr));
    }

    //create output layer
	  m_vecLayers.push_back(SNeuronLayer(m_NumOutputs, m_NeuronsPerHiddenLyr));
	}

  else
  {
	  //create output layer
	  m_vecLayers.push_back(SNeuronLayer(m_NumOutputs, m_NumInputs));
  }
}

//---------------------------------GetWeights-----------------------------
//
//	returns a vector containing the weights
//
//------------------------------------------------------------------------
vector<double> CNeuralNet::GetWeights() const
{
	//this will hold the weights
	vector<double> weights;
	
	//for each layer
	for (int i=0; i<m_NumHiddenLayers + 1; ++i)
	{

		//for each neuron
		for (int j=0; j<m_vecLayers[i].m_NumNeurons; ++j)
		{
			//for each weight
			for (int k=0; k<m_vecLayers[i].m_vecNeurons[j].m_NumInputs; ++k)
			{
				weights.push_back(m_vecLayers[i].m_vecNeurons[j].m_vecWeight[k]);
			}
		}
	}

	return weights;
}

//-----------------------------------PutWeights---------------------------
//
//	given a vector of doubles this function replaces the weights in the NN
//  with the new values
//
//------------------------------------------------------------------------
void CNeuralNet::PutWeights(vector<double> &weights)
{
	int cWeight = 0;
	
	//for each layer
	for (int i=0; i<m_NumHiddenLayers + 1; ++i)
	{

		//for each neuron
		for (int j=0; j<m_vecLayers[i].m_NumNeurons; ++j)
		{
			//for each weight
			for (int k=0; k<m_vecLayers[i].m_vecNeurons[j].m_NumInputs; ++k)
			{
				m_vecLayers[i].m_vecNeurons[j].m_vecWeight[k] = weights[cWeight++];
			}
		}
	}

	return;
}

//---------------------------------GetNumberOfWeights---------------------
//
//	returns the total number of weights needed for the net
//
//------------------------------------------------------------------------
int CNeuralNet::GetNumberOfWeights() const
{
	int weights = 0;
	
	//for each layer
	for (int i=0; i<m_NumHiddenLayers + 1; ++i)
	{

		//for each neuron
		for (int j=0; j<m_vecLayers[i].m_NumNeurons; ++j)
		{
			//for each weight
			for (int k=0; k<m_vecLayers[i].m_vecNeurons[j].m_NumInputs; ++k)
			
				weights++;			
		}
	}

	return weights;
}

//--------------------------- CalculateSplitPoints -----------------------
//
//  this method calculates all points in the vector of weights which 
//  represent the start and end points of individual neurons
//------------------------------------------------------------------------
vector<int> CNeuralNet::CalculateSplitPoints() const
{
	vector<int> SplitPoints;

  int WeightCounter = 0;
	
	//for each layer
	for (int i=0; i<m_NumHiddenLayers + 1; ++i)
	{
		//for each neuron
		for (int j=0; j<m_vecLayers[i].m_NumNeurons; ++j)
		{
			//for each weight
			for (int k=0; k<m_vecLayers[i].m_vecNeurons[j].m_NumInputs; ++k)
      {
				++WeightCounter;			
      }

      SplitPoints.push_back(WeightCounter - 1);
		}
	}

	return SplitPoints;
}

//-------------------------------Update-----------------------------------
//
//	given an input vector this function calculates the output vector
//
//------------------------------------------------------------------------
vector<double> CNeuralNet::Update(vector<double> &inputs)
{
	//stores the resultant outputs from each layer
	vector<double> outputs;

	int cWeight = 0;
	
	//first check that we have the correct amount of inputs
	if (inputs.size() != m_NumInputs)
  {
		//just return an empty vector if incorrect.
		return outputs;
  }
	
	//For each layer....
	for (int i=0; i<m_NumHiddenLayers + 1; ++i)
	{
		if ( i > 0 )
    {
			inputs = outputs;
    }

		outputs.clear();
		
		cWeight = 0;

		//for each neuron sum the (inputs * corresponding weights).Throw 
		//the total at our sigmoid function to get the output.
		for (int j=0; j<m_vecLayers[i].m_NumNeurons; ++j)
		{

			double netinput = 0.0f;

			int	NumInputs = m_vecLayers[i].m_vecNeurons[j].m_NumInputs;
			
			//for each weight
			for (int k=0; k<NumInputs - 1; ++k)
			{
				//sum the weights x inputs
				netinput += m_vecLayers[i].m_vecNeurons[j].m_vecWeight[k] * 
                    inputs[cWeight++];
			}

			//add in the bias
			netinput += m_vecLayers[i].m_vecNeurons[j].m_vecWeight[NumInputs-1] * 
                  CParams::dBias;

			//we can store the outputs from each layer as we generate them. 
      //The combined activation is first filtered through the sigmoid 
      //function
			outputs.push_back(Sigmoid(netinput, CParams::dActivationResponse));

			cWeight = 0;
		}
	}

	return outputs;
}

//-------------------------------Sigmoid function-------------------------
//
//------------------------------------------------------------------------
double CNeuralNet::Sigmoid(double netinput, double response)
{
	return ( 1 / ( 1 + exp(-netinput / response)));
}


?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美色欧美亚洲另类二区| 亚洲国产一区视频| 日本丶国产丶欧美色综合| 国产一区二区91| 亚洲一区电影777| 亚洲欧美日韩中文字幕一区二区三区| 精品久久五月天| 日韩免费在线观看| 精品国产一二三| 日韩欧美一级二级三级| 精品国产一区二区三区四区四| 欧美乱妇23p| 亚洲人成网站在线| 亚洲免费在线视频一区 二区| 亚洲欧美一区二区三区孕妇| 一区二区三区四区不卡在线| 国产精品福利av| 亚洲精品成人少妇| 午夜欧美在线一二页| 日本成人中文字幕| 国产精品456| 91黄视频在线| 这里只有精品99re| 国产亚洲短视频| 亚洲日本韩国一区| 亚洲高清不卡在线观看| 国内成+人亚洲+欧美+综合在线| 成人一区二区三区视频 | 久久日一线二线三线suv| 欧美成人精精品一区二区频| 中文字幕欧美日韩一区| 日韩精品国产欧美| 成人黄页毛片网站| 欧美视频自拍偷拍| 国产日韩欧美精品综合| 日日噜噜夜夜狠狠视频欧美人| 国产精品一区二区三区四区| 欧美色综合网站| 欧美国产欧美综合| 毛片基地黄久久久久久天堂| gogo大胆日本视频一区| 精品久久一区二区三区| 国产精品久久久久久福利一牛影视 | 一区二区三区四区中文字幕| 激情小说亚洲一区| 欧美日本在线一区| 亚洲免费在线视频| 丰满亚洲少妇av| 亚洲精品一区二区三区在线观看| 亚洲一区二区三区三| 成人app网站| 国产亚洲精品福利| 蜜桃一区二区三区在线观看| 欧美日韩精品一区二区天天拍小说 | 国内成人自拍视频| 美女一区二区视频| 欧洲一区在线电影| 18涩涩午夜精品.www| 国产不卡视频一区二区三区| 久久网站最新地址| 久久99精品一区二区三区三区| 欧美精品丝袜久久久中文字幕| 日韩美女久久久| 色综合久久99| 亚洲福利视频三区| 欧美精品在线观看播放| 午夜欧美视频在线观看| 欧美精品久久一区二区三区| 视频一区欧美精品| 欧美精品一区二区不卡| 亚洲电影欧美电影有声小说| 欧美精品日韩综合在线| 午夜亚洲国产au精品一区二区| 91福利在线免费观看| 午夜精品一区在线观看| 日韩欧美高清一区| 国产69精品一区二区亚洲孕妇| 国产婷婷色一区二区三区 | va亚洲va日韩不卡在线观看| 亚洲一区在线观看视频| 欧美一区二区三区免费大片| 国产一本一道久久香蕉| 亚洲男人天堂av网| 欧美本精品男人aⅴ天堂| 从欧美一区二区三区| 欧美一区三区二区| 韩国女主播成人在线| 亚洲色图视频网站| 日韩精品一区二区三区在线| 91偷拍与自偷拍精品| 麻豆91在线观看| 亚洲美女免费在线| 久久综合久久综合久久| 欧美三级电影在线看| 国产高清在线精品| 蜜桃视频一区二区三区在线观看| 亚洲青青青在线视频| 欧美极品xxx| 国产亚洲综合在线| 欧美一区二区日韩| 91片在线免费观看| 成人av网站在线观看| 经典三级在线一区| 久久精品国产亚洲一区二区三区| 久久男人中文字幕资源站| 中文字幕一区二区三中文字幕| 欧美一区二区三区日韩| 在线观看www91| 国产成人精品在线看| 精品在线一区二区| 日本不卡的三区四区五区| 亚洲国产日韩综合久久精品| 国产精品第五页| 久草中文综合在线| 麻豆高清免费国产一区| 国产一区二区精品在线观看| 狠狠色丁香九九婷婷综合五月| 天天亚洲美女在线视频| 免费成人av资源网| 极品少妇xxxx精品少妇偷拍| 国产又黄又大久久| 国产精品18久久久久久久久久久久 | 久久精品国产999大香线蕉| 久久97超碰国产精品超碰| 精品一区二区成人精品| 国产伦理精品不卡| www.日韩精品| 欧美日韩国产综合一区二区三区| 国产精品欧美一区喷水| 亚洲欧美色综合| 日本不卡中文字幕| 风间由美中文字幕在线看视频国产欧美| 国产成人精品1024| 色综合激情久久| 欧美日韩成人在线| 久久久久久久综合色一本| 国产精品久久毛片av大全日韩| 国产成人精品免费视频网站| 亚洲国产欧美另类丝袜| 日日摸夜夜添夜夜添亚洲女人| 国产91精品一区二区麻豆亚洲| 91麻豆视频网站| 久久这里都是精品| 亚洲第一av色| 波多野结衣中文字幕一区| 欧美日韩免费不卡视频一区二区三区| 欧美v日韩v国产v| 亚洲成人免费在线| 97久久久精品综合88久久| 久久综合精品国产一区二区三区 | 视频一区二区三区入口| 精品剧情v国产在线观看在线| 亚洲国产精品视频| 色综合久久天天| 欧美高清在线一区| 国产精品1区2区3区在线观看| 国产福利91精品一区| 欧美大片一区二区三区| 亚洲成人自拍网| 色爱区综合激月婷婷| 1024成人网| 99国产精品久久久久久久久久| 中文字幕不卡一区| 国产91综合一区在线观看| 日韩欧美国产wwwww| 久久激情综合网| 国产农村妇女精品| 成人av电影观看| 亚洲天堂精品视频| 色婷婷av一区二区三区gif | 国产老妇另类xxxxx| 久久精品一区二区三区不卡| 精品午夜久久福利影院| 久久色视频免费观看| av不卡一区二区三区| 亚洲婷婷国产精品电影人久久| 91伊人久久大香线蕉| 亚洲成人综合视频| 精品不卡在线视频| 成人午夜在线视频| 亚洲国产综合视频在线观看| 欧美猛男男办公室激情| 日本在线不卡视频| 国产欧美日韩在线观看| 色偷偷成人一区二区三区91| 五月天激情综合网| 欧美激情一区二区三区在线| 91在线你懂得| 秋霞午夜av一区二区三区| 欧美一区二区三级| 丁香一区二区三区| 视频一区二区中文字幕| 国产日韩欧美精品综合| 欧美影院一区二区三区| 精品一区二区三区在线播放| 亚洲精品中文字幕在线观看| 日韩欧美综合在线| jvid福利写真一区二区三区| 日韩国产欧美在线视频| 亚洲欧美日韩人成在线播放|