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

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

?? backprop.pas

?? ANN And Hopfield Neural Network
?? PAS
?? 第 1 頁 / 共 2 頁
字號:
//Copyright Ramesh Sabeti - sabeti@reazon.com

unit Backprop;

interface

uses
  Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
  StdCtrls, Grids, ExtCtrls, TeEngine, Series, TeeProcs, Chart, Clipbrd,
  Printers, ANN, ComCtrls;

const
  CLASS1COUNT = 1000;
  CLASS2COUNT = 50;
  CLASS3COUNT = 100;
  CLASS4COUNT = 500;


type
  TFormBackpropTest = class(TForm)
    ButtonGRandom: TButton;
    Shape1: TShape;
    Shape2: TShape;
    Shape3: TShape;
    Shape0: TShape;
    ButtonSaveData: TButton;
    StringGrid1: TStringGrid;
    Chart1: TChart;
    Series1: TBarSeries;
    ButtonSaveGraph: TButton;
    ButtonPrint: TButton;
    ButtonCreateANN: TButton;
    EditTrials: TEdit;
    Label1: TLabel;
    ButtonTrainOne: TButton;
    ButtonRecall: TButton;
    ButtonTrainAll: TButton;
    Label2: TLabel;
    EditError: TEdit;
    ProgressBar1: TProgressBar;
    Button7: TButton;
    Button8: TButton;
    LabelTrials: TLabel;
    LabelLegend1: TLabel;
    LabelLegend2: TLabel;
    LabelLegend3: TLabel;
    LabelLegend4: TLabel;
    Label3: TLabel;
    Label4: TLabel;
    Label5: TLabel;
    Label6: TLabel;
    Label7: TLabel;
    procedure ButtonGRandomClick(Sender: TObject);
    procedure ButtonSaveDataClick(Sender: TObject);
    procedure ButtonSaveGraphClick(Sender: TObject);
    procedure ButtonPrintClick(Sender: TObject);
    procedure FormCreate(Sender: TObject);
    procedure ButtonCreateANNClick(Sender: TObject);
    procedure FormDestroy(Sender: TObject);
    procedure ButtonTrainOneClick(Sender: TObject);
    procedure ButtonRecallClick(Sender: TObject);
    procedure ButtonTrainAllClick(Sender: TObject);
    procedure Button8Click(Sender: TObject);
    procedure Button7Click(Sender: TObject);
  private
    { Private declarations }
    CurClassifier: Integer;
    Converged : Boolean;
    Class1: array[0..CLASS1COUNT - 1] of TFeature;
    Class2: array[0..CLASS2COUNT - 1] of TFeature;
    Class3: array[0..CLASS3COUNT - 1] of TFeature;
    Class4: array[0..CLASS4COUNT - 1] of TFeature;

    Colors: array[0..3] of TColor;
    Classifications: array[0..3] of TAnalysis;

    CenterShapes: array [0..10] of TShape;
    CummSet: array
                 [0..CLASS1COUNT + CLASS2COUNT + CLASS3COUNT + CLASS4COUNT - 1]
                 of TFeature;

    TrainingSet, UnknownSet: array
                 [0..(CLASS1COUNT + CLASS2COUNT + CLASS3COUNT + CLASS4COUNT)
                      div 2 - 1]
                 of TFeature;


    NewCentroids,
    Centroids: array [0..10] of TFeature;
    XOrig, YOrig, XScale, YScale: Integer;
    Steps,
    NumCentroids,
    NumClasses : Integer;
    procedure DisplayNet;
    procedure DisplaySet( Samples: array of TFeature; ShowErrors: Boolean);
    procedure PrintSet( var P: TPrinter;
                           Samples: array of TFeature;
                           ShowErrors: Boolean);
    procedure PrintSample( var P: TPrinter; Sample: TFeature; ShowError: Boolean);
    procedure BuildDataSets;
    procedure DisplaySample(Sample: TFeature; ShowError: Boolean);
    procedure ClearCanvas;
    procedure GenerateSamples;
    procedure DisplayResults(Samples: array of TFeature);
    procedure DisplayNetwork;
    procedure Train;
    function TrainEvenly(ErrorTolerance: Extended; Indx: Integer): Boolean;
    function TrainAgent(ErrorTolerance: Extended; Indx: Integer): Boolean;
    procedure Recall;
  public
    { Public declarations }
  end;

var
  FormBackpropTest: TFormBackpropTest;
  FeedForward: TFeedForward;

implementation

{$R *.DFM}

procedure TFormBackpropTest.ButtonGRandomClick(Sender: TObject);
var
  i: integer;
begin
  for i:= 0 to Chart1.SeriesCount -1 do
    Chart1.Series[i].Clear;

  GenerateSamples;
end;

procedure TFormBackpropTest.GenerateSamples;
begin
  ClearCanvas;

  ANN.InitClass(Class1, 0, [13.0, 76.0], [8.0, 12.0]);
  ANN.InitClass(Class2, 1, [34.0, 123.0], [13.0, 25.0]);
  ANN.InitClass(Class3, 2, [21.0, 24.0], [7.0, 8.0]);
  ANN.InitClass(Class4, 3, [18.0, 17.0], [7.0, 6.0]);

  DisplaySet(Class1, False);
  DisplaySet(Class2, False);
  DisplaySet(Class3, False);
  DisplaySet(Class4, False);

end;

procedure TFormBackpropTest.DisplaySet( Samples: array of TFeature;
                             ShowErrors: Boolean);
var
  i: Integer;
begin
  for i := Low(Samples) to High(Samples) do
    DisplaySample(Samples[i], ShowErrors);

end;

procedure TFormBackpropTest.DisplaySample(Sample: TFeature; ShowError: Boolean);
var
  X, Y: Integer;
begin
  X := XOrig + Trunc(Sample.Vector[0] * XScale);
  Y := YOrig  + Trunc(Sample.Vector[1] * YScale);

  if ShowError then
    //if misclassified, mark it...
    if (Sample.OrigClass <> Sample.CompClass) and
       (Sample.CompClass >= 0 ) then begin
      Self.Canvas.Pen.Color := Colors[Sample.OrigClass];
      Self.Canvas.Ellipse(X-1, Y-1, X + 5, Y + 5);
    end;

  if Sample.CompClass >= 0 then
    Self.Canvas.Pen.Color := Colors[Sample.CompClass]
  else
    Self.Canvas.Pen.Color := Colors[Sample.OrigClass];

  self.Canvas.Brush.Color := Self.Canvas.Pen.Color;
  Self.Canvas.Ellipse(X, Y, X + 4, Y + 4);

end;

procedure TFormBackpropTest.FormCreate(Sender: TObject);
var
  i: integer;
begin
  Show;
  XOrig := 200;
  YOrig := 30;
  XScale := 5;
  YSCale := 3;

  NumClasses := 4;

  Colors[0] := clRed;
  Colors[1] := clOlive;
  Colors[2] := clBlue;
  Colors[3] := clGreen;

  labelLegend1.Color := Colors[0];
  labelLegend2.Color := Colors[1];
  labelLegend3.Color := Colors[2];
  labelLegend4.Color := Colors[3];

  for i := 0 to 10 do begin
    if not Assigned(CenterShapes[i]) then begin
      CenterShapes[i] := TShape.Create(Self);
      CenterShapes[i].Width := 6;
      CenterShapes[i].Height := 6;
      CenterShapes[i].Brush.Color := clLime;
      CenterShapes[i].Shape := stCircle;
      CenterShapes[i].Parent := Self;
      CenterShapes[i].Visible := False;
    end;
  end;

  //initialize StringGrid headings
  for i := 1 to 4 do
    StringGrid1.Cells[i, 0] := 'Class ' + IntToStr(i);

  StringGrid1.Cells[0, 1] := 'Classified';
  StringGrid1.Cells[0, 2] := '% Classified';
  StringGrid1.Cells[0, 3] := 'Misclassified';
  StringGrid1.Cells[0, 4] := '% Misclassified';
  StringGrid1.Cells[0, 5] := '# Members';




end;


procedure TFormBackpropTest.ClearCanvas;
begin
  Self.Canvas.Brush.Color := clSilver;
  Refresh;
end;
procedure TFormBackpropTest.ButtonSaveDataClick(Sender: TObject);
var
  i: Integer;
  F: TextFile;
begin
  AssignFile(F, 'Data.txt');
  Rewrite(F);
  Writeln(F, 'Training Set');
  for i := Low(CummSet) to High(CummSet) do
    Writeln(F, FloatToStr(CummSet[i].Vector[0]) + ', ' +
               FloatToStr(CummSet[i].Vector[1]) + '  class ' +
               IntToStr(CummSet[i].OrigClass)
            );

  CloseFile(F);
end;

procedure TFormBackpropTest.BuildDataSets;
var
  i : Integer;
  C1, C2, C3, C4: Integer;
begin
  C1 := CLASS1COUNT div 2;
  C2 := CLASS2COUNT div 2;
  C3 := CLASS3COUNT div 2;
  C4 := CLASS4COUNT div 2;

  //build the training set
  for i := 0 to C1 - 1 do begin
     TrainingSet[i] := Class1[i];
  end;

  for i := 0 to C2 -1 do begin
    TrainingSet[i + C1] := Class2[i];
  end;

  for i := 0 to C3 - 1 do begin
    TrainingSet[i + C1 + C2] := Class3[i];
  end;

  for i := 0 to C4 -1  do begin
    TrainingSet[i + C1 + C2 + C3] := Class4[i];
  end;

  Refresh;  //Clear screen
  DisplaySet(TrainingSet, False);

  //build the unknown set
  for i := 0 to C1 - 1 do begin
     UnknownSet[i] := Class1[i + C1];
     UnknownSet[i].CompClass := -1;
  end;

  for i := 0 to C2 - 1 do begin
    UnknownSet[i + C1] := Class2[i + C2];
    UnknownSet[i + C1].CompClass := -1;
  end;

  for i := 0 to C3 - 1 do begin
    UnknownSet[i + C1 + C2] := Class3[i + C3];
    UnknownSet[i + C1 + C2].CompClass := -1;
  end;

  for i := 0 to C4 - 1 do begin
    UnknownSet[i + C1 + C2 + C3] := Class4[i + C4];
    UnknownSet[i + C1 + C2 + C3].CompClass := -1;
  end;

end;


procedure TFormBackpropTest.DisplayResults(Samples: array of TFeature);
var
  i, j: Integer;
  C : array [0..3] of Integer;
  F: TextFile;
begin

  C[0] := CLASS1COUNT div 2;
  C[1] := CLASS2COUNT div 2;
  C[2] := CLASS3COUNT div 2;
  C[3] := CLASS4COUNT div 2;


  ResultAnalysis(Samples, Classifications, C);
  for i := 0 to 3 do begin
    StringGrid1.Cells[i + 1, 1] := IntToStr(Classifications[i].Classified);
    StringGrid1.Cells[i + 1, 2] := FloatToStr(Classifications[i].percentClassified
                                              ) + '%';
    StringGrid1.Cells[i + 1, 3] := IntToStr(Classifications[i].Misclassified);
    StringGrid1.Cells[i + 1, 4] := FloatToStr(Classifications[i].PercentMisclassified
                                              ) + '%';
    StringGrid1.Cells[i + 1, 5] := IntToStr(Classifications[i].Total);
  end;
    StringGrid1.Cells[5, 2] :=FloatToStr(
                              (Classifications[0].Classified +
                               Classifications[1].Classified +
                               Classifications[2].Classified +
                               Classifications[3].Classified) /
                               8.25) + '%';

  if CurClassifier < 10 then begin
    with  Chart1.Series[ CurClassifier ] do begin
      Clear;
      for j := 0 to NumClasses - 1 do begin
        AddY( Classifications[j].PercentClassified,
              'Class ' + IntToStr(j + 1),
              clTeeColor);
      end;

      //Show the overall classification
      AddY((Classifications[0].Classified +
            Classifications[1].Classified +
            Classifications[2].Classified +
            Classifications[3].Classified) /
            8.25,
            'Overall',
            clTeeColor);

    end;
  end;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人性生交大片免费看视频在线| 久久精品一二三| 国产成人av电影在线| 久久电影网站中文字幕| 亚洲国产视频一区| 亚洲 欧美综合在线网络| 亚洲国产日韩精品| 性欧美疯狂xxxxbbbb| 日韩高清欧美激情| 日本伊人色综合网| 极品少妇xxxx精品少妇| 国产乱子轮精品视频| 懂色av噜噜一区二区三区av| 成人自拍视频在线| 91免费看视频| 欧美三级中文字| 欧美精品成人一区二区三区四区| 欧美精品在线一区二区| 欧美xxx久久| 国产欧美一区二区三区在线看蜜臀| 国产欧美一二三区| 亚洲永久精品国产| 蜜桃免费网站一区二区三区| 精品一区二区三区在线播放视频| 国产一区二区伦理| 色猫猫国产区一区二在线视频| 色综合婷婷久久| 日韩女优av电影在线观看| 久久久久久久免费视频了| 综合久久一区二区三区| 日韩高清在线一区| 成人黄色777网| 制服丝袜亚洲网站| 国产精品嫩草久久久久| 亚洲bt欧美bt精品777| 韩国欧美一区二区| 在线精品亚洲一区二区不卡| 精品久久久久香蕉网| 亚洲三级免费电影| 国精产品一区一区三区mba桃花| 99久久综合国产精品| 欧美一区二区视频观看视频| 国产精品丝袜久久久久久app| 丝袜美腿亚洲一区二区图片| 国产99一区视频免费| 91精品国模一区二区三区| 日韩一区中文字幕| 精品无人区卡一卡二卡三乱码免费卡| 91网站在线播放| 久久综合九色综合97婷婷女人| 亚洲一区二区欧美| 成人app网站| 精品国产麻豆免费人成网站| 一区二区三区欧美亚洲| 成人午夜精品在线| 久久久午夜精品| 日本欧洲一区二区| 欧美日韩激情在线| 一区二区三区蜜桃| 99精品欧美一区二区蜜桃免费| 久久免费看少妇高潮| 麻豆91免费看| 日韩视频免费观看高清完整版在线观看 | 国产精品美女久久久久av爽李琼 | 99久久综合精品| 久久久久久久一区| 国产主播一区二区三区| 日韩一级完整毛片| 日韩avvvv在线播放| 欧美自拍偷拍一区| 一卡二卡欧美日韩| 欧美日韩免费不卡视频一区二区三区| 中文字幕一区二区三区视频| 丰满岳乱妇一区二区三区| 国产欧美一区二区三区在线看蜜臀| 精品一区二区三区香蕉蜜桃 | 成人免费视频视频| 日本一区二区在线不卡| 久久国产麻豆精品| 日韩精品一区二区三区中文不卡| 日韩国产欧美在线播放| 欧美色大人视频| 亚洲乱码精品一二三四区日韩在线| 成人精品高清在线| 亚洲色图丝袜美腿| 欧美中文字幕一区二区三区| 一区二区三区在线免费视频| 91黄色激情网站| 亚洲国产一区二区三区| 欧美日韩国产在线观看| 日韩av电影天堂| 日韩一区二区在线看| 九一久久久久久| 亚洲国产高清不卡| 在线视频观看一区| 日本欧洲一区二区| 国产欧美一区二区三区在线看蜜臀| 成人av网站在线观看| 亚洲免费高清视频在线| 91精品国产入口| 国产一区在线观看视频| 国产精品福利一区二区三区| 欧美综合亚洲图片综合区| 欧美aaaaaa午夜精品| 久久久综合视频| 色婷婷综合视频在线观看| 午夜视频在线观看一区| 久久色成人在线| 91黄视频在线| 国产在线精品不卡| 亚洲精品美腿丝袜| 精品噜噜噜噜久久久久久久久试看 | 欧美日本一区二区| 激情综合色综合久久| 自拍av一区二区三区| 欧美男男青年gay1069videost| 国产精一品亚洲二区在线视频| 亚洲精品国产一区二区精华液 | 成人综合在线观看| 亚洲国产欧美一区二区三区丁香婷| 欧美成人a∨高清免费观看| 91免费观看国产| 国内一区二区视频| 亚洲一二三专区| 亚洲国产精品成人综合色在线婷婷| 欧美日韩国产高清一区二区| 国产福利一区在线观看| 日韩黄色片在线观看| 亚洲欧美自拍偷拍色图| 精品国产百合女同互慰| 精品污污网站免费看| 波多野结衣在线一区| 美女脱光内衣内裤视频久久网站 | 精品国产一区二区三区四区四| 色先锋资源久久综合| 成人免费观看视频| 国产一区二区三区四区在线观看| 亚洲综合一二区| 亚洲色大成网站www久久九九| 国产日韩精品一区二区三区在线| 欧美一区二区视频免费观看| 91久久免费观看| 色综合色狠狠综合色| 久久精品国产免费| 日韩成人精品在线观看| 亚洲黄色片在线观看| 亚洲色欲色欲www| 国产精品黄色在线观看| 国产三级一区二区三区| 久久精品综合网| 精品99一区二区| 精品国产不卡一区二区三区| 日韩欧美激情四射| 日韩免费一区二区三区在线播放| 欧美图片一区二区三区| 欧洲精品视频在线观看| 91高清在线观看| 欧美色精品在线视频| 欧美日韩精品欧美日韩精品| 欧美日韩一二区| 91精品国产综合久久精品图片| 欧美日韩午夜在线| 91麻豆精品国产91久久久使用方法 | 成人av免费在线观看| 成人高清视频免费观看| 成人av在线网站| 色婷婷精品久久二区二区蜜臀av | 激情偷乱视频一区二区三区| 久久精品国产精品亚洲综合| 国产一区二区三区在线观看免费 | 亚洲欧洲性图库| 亚洲免费毛片网站| 亚洲成人www| 久久精品国产成人一区二区三区| 久久99国产精品麻豆| 国产精品夜夜嗨| 色婷婷香蕉在线一区二区| 欧美日韩精品一区二区天天拍小说| 91精品国产手机| 国产午夜精品久久久久久免费视 | 国产视频一区二区在线| 亚洲欧美欧美一区二区三区| 伊人色综合久久天天| 手机精品视频在线观看| 国产精品一级片| 欧美亚洲日本国产| 精品三级在线观看| 亚洲免费av在线| 国内精品自线一区二区三区视频| 成人午夜视频网站| 欧美精品777| 国产精品免费aⅴ片在线观看| 亚洲国产欧美在线| 国产成人精品免费| 欧美三级韩国三级日本一级| 精品国产乱码久久久久久久| 亚洲欧洲精品一区二区三区不卡| 秋霞国产午夜精品免费视频| 99精品视频中文字幕| 日韩欧美在线影院|