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

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

?? som.class.cpp

?? 人工神經網絡BP算法 1、動態改變學習速率 2、加入動量項 3、運用了Matcom4.5的矩陣運算庫(可免費下載,頭文件matlib.h)
?? CPP
字號:
#include <vector>
#include <iostream>
#include <math.h>
#include <stdlib.h>
#include "som.class.const.cpp"

#include "Unit1.h"

using namespace std;
// -----------------------------------------------------------------------
class som_Node
{
    private:
        //
    public:
     vector <double> l_weights;
     som_Node(int,int,int);
     float distance (const vector <double> &);
     void  update(const vector <double> &, const double, const double);
     double color;

     int X;
     int Y;
};

som_Node::som_Node(int numWeights,int n_col,int n_row)
{
  for (int i = 0; i < numWeights; ++i)
     l_weights.push_back(RandFloat());

      X = n_col;
      Y = n_row;
  
}

float som_Node::distance(const vector <double> &Input)
{
    double dist = 0;
    
    for (unsigned int i = 0; i < l_weights.size(); ++i)
     {
          dist += (Input[i] - l_weights[i]) * (Input[i] - l_weights[i]);
     }    
    return dist;
}

void  som_Node::update(const vector <double> &Input, const double LearningRate, const double Influence)
{
    for (unsigned int i = 0; i < l_weights.size(); ++i)
    {
       l_weights[i] += LearningRate * Influence * (Input[i] - l_weights[i]);
    }
}
// ------------------------------------------------------------
class SOM
{
  public:
   SOM(int,int,int,int);
   int Epoch(vector <vector <double> > );
   som_Node* SOM::FindWinner(const vector <double> &);
   int complete();
   double getErrorValue(int,int);
   som_Node **Latice;


   int     s_cols;
   int     s_rows;
   int     Iteration;

  private:
     int     doneTraining;
     int     maxIter;
     int     numIterations;
     double  Radius;
     double  timeConst;
     double  mapRadius;
     double  influence;
     double  learningRate;

     som_Node *winner;
};

SOM::SOM(int rows, int cols,int inputs,int maxI)
{
   Latice = (som_Node **)calloc(rows,sizeof(som_Node *));
   for (int row = 0; row < rows; row++)
   {
     Latice[row] = (som_Node *)calloc(cols,sizeof(som_Node));
      for (int col = 0; col < cols; col++)
         {

            Latice[row][col] = som_Node(
                                    inputs,
                                    row,
                                    col
                             );
         }
    }

   doneTraining = FALSE;
   maxIter = maxI;
   learningRate = constStartLearningRate;
   numIterations = constNumIterations;
   Iteration = 0;
   mapRadius = max(cols, rows)/2;
   timeConst = (double) maxI/log(mapRadius);
   s_cols = cols;
   s_rows = rows;
}

int SOM::Epoch(vector <vector<double> > Input)
{
    if (doneTraining) return 1;

    if (maxIter--)
    {
        int selectPattern = RandInt(0, Input.size()-1);
        winner = FindWinner(Input[selectPattern]);
        Radius = mapRadius * exp(-(double)Iteration/timeConst);

        for (int j = 0; j < s_rows; j++)
         for (int i = 0; i < s_cols; i++)
           {
              double dist = (winner->X - Latice[j][i].X)*(winner->X - Latice[j][i].X) +
                              (winner->Y - Latice[j][i].Y)*(winner->Y - Latice[j][i].Y);

                if (dist < Radius*Radius)
                {
                   influence = exp(-(dist) / (2*Radius*Radius));
                   Latice[j][i].update(Input[selectPattern],learningRate,influence);
                }
           }


       Iteration++;  
       learningRate = constStartLearningRate * exp(-(double)Iteration/numIterations);  
    }  
    else
    {
      doneTraining = 1;
    }

    return 1;
}

double SOM::getErrorValue(int y,int x)     
 {
    double max = 0;

        for (int j = -1; j <= 1; j++)
                for (int i = -1; i <=1; i++)
                   {
                      if  ( (x+i>=0) && (y+j >= 0) && (x + i < s_cols) && (y+j < s_cols) )
                      {
                   
                        if ( (abs(Latice[y][x].X - Latice[y+j][x+i].X) <= 1) &&
                              (abs(Latice[y][x].Y - Latice[y+j][x+i].Y) <= 1) )
                           {
                             if (Latice[y][x].distance(Latice[y+j][x+i].l_weights) > max)
                                     max =  Latice[y][x].distance(Latice[y+j][x+i].l_weights); 
                           } 
                     }

                } 
    return  max;
 }

som_Node* SOM::FindWinner(const vector <double> &pattern)
{
  som_Node *temp_Winner;
  double min = 9999999;
  double dist = 0;


     for (int j = 0; j < s_rows; j++)
      for (int i = 0; i < s_cols; i++)
       {
         dist = Latice[j][i].distance(pattern);
          if (dist < min)
           {
                      min = dist;
                      temp_Winner = &Latice[j][i];
           }
       }
       
    return temp_Winner;
}

int SOM::complete()
{
    return doneTraining;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩亚洲国产综合| 亚洲欧洲精品一区二区三区 | 日韩一区二区三区视频在线观看| 亚洲激情网站免费观看| 在线视频国内自拍亚洲视频| 一区二区久久久久久| 日韩一级免费观看| 国产在线精品不卡| 日本一区二区免费在线观看视频| 成人国产精品免费观看视频| 国产精品美女一区二区三区| 色94色欧美sute亚洲线路二 | 欧美美女一区二区| 免费成人在线网站| 久久久91精品国产一区二区三区| 国产99久久久国产精品潘金| 亚洲卡通动漫在线| 欧美一级精品大片| 国产成a人亚洲| 亚洲狠狠丁香婷婷综合久久久| 在线成人午夜影院| 国产一区二区中文字幕| 亚洲欧美aⅴ...| 日韩一区二区中文字幕| 国产99久久久国产精品| 一区二区三区四区不卡在线| 日韩你懂的在线观看| 成人av片在线观看| 日韩精品一级中文字幕精品视频免费观看 | 欧洲一区二区av| 三级成人在线视频| 久久无码av三级| 欧美在线一区二区| 国产精品主播直播| 婷婷中文字幕综合| 偷拍与自拍一区| 国产清纯在线一区二区www| 色视频一区二区| 精品在线观看视频| 亚洲国产日韩一区二区| 久久精品人人做人人爽97| 欧美日韩在线免费视频| 丁香亚洲综合激情啪啪综合| 日韩精品亚洲一区二区三区免费| 中文字幕一区二区三区在线观看| 日韩欧美一二区| 欧美日韩亚洲高清一区二区| 国产成a人无v码亚洲福利| 秋霞电影一区二区| 亚洲综合色婷婷| 国产福利一区在线观看| 678五月天丁香亚洲综合网| 亚洲精品中文字幕乱码三区| 午夜欧美电影在线观看| 久久影视一区二区| 91精品国产综合久久蜜臀| 色综合久久久久综合| 懂色一区二区三区免费观看| 琪琪久久久久日韩精品| 亚洲第一在线综合网站| 综合久久久久久久| 国产欧美日韩在线视频| xfplay精品久久| 欧美成人精品福利| 日韩欧美中文字幕一区| 精品视频1区2区3区| 欧美性极品少妇| 色婷婷国产精品| 99久久综合色| 波多野结衣亚洲| 风间由美一区二区av101| 紧缚奴在线一区二区三区| 视频在线在亚洲| 亚洲一二三区在线观看| 亚洲精品美国一| 中文字幕一区二区在线观看| 中文字幕av不卡| 国产人久久人人人人爽| 国产日韩亚洲欧美综合| 久久久精品天堂| 国产亚洲成aⅴ人片在线观看| 欧美不卡一区二区| 久久这里只有精品6| 久久久美女毛片| 国产欧美va欧美不卡在线| 久久久久久99久久久精品网站| 欧美精品一区二区三区四区| 欧美videossexotv100| 精品国产一区二区三区久久影院 | 欧美一区二区三区四区在线观看| 欧美日本视频在线| 欧美一区永久视频免费观看| 日韩欧美在线123| 久久精品在这里| 国产精品色一区二区三区| 亚洲视频香蕉人妖| 性欧美疯狂xxxxbbbb| 日韩成人免费电影| 国产一区二区精品久久| 成人av网站在线观看免费| 日韩午夜小视频| 久久免费精品国产久精品久久久久| 久久精品亚洲麻豆av一区二区 | 国产精品水嫩水嫩| 久久久久久久网| 中文字幕不卡在线观看| 中文字幕一区二区不卡| 一区二区三区在线观看欧美| 亚洲大片在线观看| 秋霞午夜av一区二区三区| 国产成人午夜视频| 91精品办公室少妇高潮对白| 69av一区二区三区| 亚洲国产高清在线观看视频| 一区二区三区电影在线播| 蜜臀av性久久久久蜜臀aⅴ四虎 | 91精品国产综合久久精品性色| 久久久亚洲高清| 亚洲免费在线播放| 久久精品国产一区二区三区免费看| 国产精品12区| 欧美午夜电影网| 久久女同精品一区二区| 亚洲男同性视频| 激情成人综合网| 在线观看成人小视频| 欧美精品一区二区不卡| 亚洲人成精品久久久久久| 蜜桃视频一区二区三区在线观看| 国产乱码精品一区二区三区五月婷 | av网站一区二区三区| 91精品国产一区二区| 中文字幕一区二区三区蜜月| 美脚の诱脚舐め脚责91| 在线影视一区二区三区| 久久久久九九视频| 日本亚洲最大的色成网站www| 成人黄色在线网站| 精品国产亚洲在线| 亚洲成人久久影院| aaa亚洲精品| 久久九九影视网| 日韩av一区二区在线影视| 99久久精品免费看| 久久久久久久性| 久久精品国产精品亚洲精品| 欧美怡红院视频| 综合久久一区二区三区| 国产91精品免费| 久久亚洲综合色| 麻豆精品在线视频| 欧美喷潮久久久xxxxx| 天堂影院一区二区| 一本大道久久a久久精品综合| 久久蜜桃av一区精品变态类天堂| 日韩精品成人一区二区在线| 色妹子一区二区| 亚洲品质自拍视频网站| 福利一区二区在线| 久久精品一区二区| 国产一区二区久久| 精品久久久久久久久久久久久久久| 亚洲地区一二三色| 欧美日韩高清在线| 午夜精品免费在线| 欧美男同性恋视频网站| 久久久.com| 欧美一级高清大全免费观看| 欧美bbbbb| 欧美一区二区三区影视| 亚洲国产成人av网| 欧美吻胸吃奶大尺度电影| 亚洲欧美日韩在线不卡| 91网上在线视频| 亚洲色图一区二区| 一本久久精品一区二区| 一区二区三区中文字幕精品精品| 色综合中文字幕| 一区二区免费视频| 欧美日产在线观看| 免费日本视频一区| 欧美精品一区二区三区很污很色的| 美女精品一区二区| 精品国产凹凸成av人导航| 国产乱码精品一品二品| 国产午夜精品一区二区三区视频| 成人一级黄色片| 亚洲欧美另类在线| 欧美日本乱大交xxxxx| 麻豆成人久久精品二区三区小说| 精品日韩在线观看| 国产成人a级片| 综合久久久久综合| 在线不卡欧美精品一区二区三区| 青青草伊人久久| 国产欧美日韩久久| 欧美丝袜第三区| 在线一区二区三区四区五区| 777奇米四色成人影色区| 欧美区视频在线观看|