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

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

?? knnsourcecode.java

?? 用KNN實現(xiàn)資源分類
?? JAVA
字號:
// kNN demo
// Jerry Zhu, Carnegie Mellon University, 2000/12
// My first Java program.

import java.applet.Applet;
import java.awt.*;
import java.awt.event.ActionListener;
import java.awt.event.ActionEvent;
                                    
    
public class KNN extends Applet implements ActionListener
{
    private TextField inputN, inputComplexity, inputK, inputKNN;
    private Button Step1Button, Step2Button, Step3Button;
	private Label errLabel; 
    private KNNCanvas theKNNCanvas;
	private Canvas theTruthCanvas;
    
    private int n, complexity, k, knn;
    private boolean[][] truth;
    private class Sample {
        int x;
        int y;
        boolean label;
    } 
    Sample[] samples;
    
    private class Distance {
        double d;
        boolean label;
    } 
    Distance[] distances;
    
    public void init()
    {
		GridBagLayout bag = new GridBagLayout();
		GridBagConstraints c = new GridBagConstraints();
        this.setLayout(bag);

		// create input fields for 
        // N: the size of the area is N*N
		Label label = new Label("Step 1: Field size(10--80):");
		bag.setConstraints(label, c);
		this.add(label);
        inputN = new TextField("80", 2);
		bag.setConstraints(inputN, c);
        this.add(inputN);
		// Complexity: of the true distribution
		label = new Label("      complexity(1--100):");
		bag.setConstraints(label, c);
		this.add(label);
        inputComplexity = new TextField("5", 2);
		bag.setConstraints(inputComplexity, c);
        this.add(inputComplexity);
        Step1Button = new Button("Create Truth");
		Step1Button.addActionListener(this);
		c.anchor = GridBagConstraints.WEST;
		c.gridwidth = GridBagConstraints.REMAINDER; // last component in a row
		bag.setConstraints(Step1Button, c);
		c.anchor = GridBagConstraints.CENTER;
		this.add(Step1Button);
		
        // k: number of positive or negative examples
		label = new Label("Step 2: samples(1--2000):");
		c.gridwidth = 1; // reset to default
		bag.setConstraints(label, c);
		this.add(label);
        inputK = new TextField("10", 2);
		bag.setConstraints(inputK, c);
		this.add(inputK);
        Step2Button = new Button("Generate Samples");
		Step2Button.addActionListener(this);
		c.anchor = GridBagConstraints.WEST;
		c.gridwidth = GridBagConstraints.REMAINDER; // last component in a row
		bag.setConstraints(Step2Button, c);
		c.anchor = GridBagConstraints.CENTER;
		this.add(Step2Button);
		
		// kNN: the number of neighbors considered in kNN.
		label = new Label("Step 3: kNN(1--100):");
		c.anchor = GridBagConstraints.WEST;
		c.gridwidth = 1; // reset to default
		bag.setConstraints(label, c);
		c.anchor = GridBagConstraints.CENTER;
		this.add(label);
        inputKNN = new TextField("1", 2);
		bag.setConstraints(inputKNN, c);
		this.add(inputKNN);
        Step3Button = new Button("Classify");
		Step3Button.addActionListener(this);
		this.add(Step3Button);
		errLabel = new Label(" ");
		c.anchor = GridBagConstraints.WEST;
		c.fill = GridBagConstraints.BOTH;
		c.gridwidth = GridBagConstraints.REMAINDER; // last component in a row
		bag.setConstraints(errLabel, c);
		this.add(errLabel);
		
		// the truth canvas
		theTruthCanvas = new TruthCanvas();
		theTruthCanvas.setSize(404, 404);
		c.fill = GridBagConstraints.BOTH;
		c.weightx = 0;
		c.weighty = 1;
		c.gridwidth = 1;
		c.gridwidth = GridBagConstraints.RELATIVE; // last component in a row
		c.gridheight = GridBagConstraints.REMAINDER; // last component in a column
		bag.setConstraints(theTruthCanvas, c);
		this.add(theTruthCanvas);
		// the KNN canvas
		theKNNCanvas = new KNNCanvas();
		theKNNCanvas.setSize(404, 404);
		c.fill = GridBagConstraints.BOTH;
		c.weightx = 1;
		c.weighty = 1;
		c.gridwidth = GridBagConstraints.REMAINDER; // last component in a row
		c.gridheight = GridBagConstraints.REMAINDER; // last component in a column
		bag.setConstraints(theKNNCanvas, c);
		this.add(theKNNCanvas);

	}
    
    public void actionPerformed(ActionEvent e)
	{
	 if (e.getSource() == Step1Button)
		{
		 n = new Integer(inputN.getText()).intValue();
 		 complexity = new Integer(inputComplexity.getText()).intValue();
		 k=0; // remove previous samples
		 truth = new boolean[n][n];
		 int x, y;
		 for (x=0; x<n; x++)
			 for (y=0; y<n; y++)
				 truth[x][y] = true;
		 for (int i=0; i<complexity; i++)
			{double w1, w2, b;
			 w1 = Math.random()*2 - 1;
			 w2 = Math.random()*2 - 1;
			 b = Math.random()*n/2;
 			 for (x=0; x<n; x++)
				 for (y=0; y<n; y++)
					 if (w1*(x-n/2)+w2*(y-n/2)+b>0)
						 truth[x][y] = !truth[x][y];
			}
		 theTruthCanvas.repaint();
		}
	 else if (e.getSource() == Step2Button)
		{
		 k = new Integer(inputK.getText()).intValue();
		 samples = new Sample[k];
		 int i;
		 for (i=0; i<k; i++)
		 {   samples[i] = new Sample();
		     samples[i].x = (int)(Math.random()*n);
		     samples[i].y = (int)(Math.random()*n);
		     samples[i].label = truth[samples[i].x][samples[i].y];
		 }
 		 theTruthCanvas.repaint();
		}
	 else if (e.getSource() == Step3Button)
		{int i;	
		 knn = new Integer(inputKNN.getText()).intValue();
		 distances = new Distance[knn];
		 for (i=0; i<knn; i++)
		 {   distances[i] = new Distance();
		 }
		 theKNNCanvas.repaint();
		}
	}    

    public void start()
    {
    }
    
    class KNNCanvas extends Canvas {
        
        public void paint(Graphics g) {
            int m=5; // m*m 'pixel'
            
            // draw bounding box
            g.setColor(Color.black);
            System.out.println(n);            
            g.drawRect(0, 0, n*m+1, n*m+1);
            
             // for each point, classify it with kNN.
			 int error = 0; // number of misclassified points
             for (int x=0; x<n; x++)
                 for (int y=0; y<n; y++)
                    {
                     // find the knn
                     for (int i=0; i<k; i++){
                         double dist = (samples[i].x-x)*(samples[i].x-x)+(samples[i].y-y)*(samples[i].y-y);
                         if (i<knn)
                            {distances[i].d = dist;
                             distances[i].label = samples[i].label;
                            }
                         else
                            {// go through the knn list and replace the biggest one if possible
                             double biggestd = distances[0].d;
                             int biggestindex = 0;
                             for (int a=1; a<knn; a++)
                                 if (distances[a].d > biggestd)
                                 {biggestd = distances[a].d;
                                  biggestindex = a;
                                 }
                             if (dist < biggestd)
                                {distances[biggestindex].d = dist;
                                 distances[biggestindex].label = samples[i].label;
                                }
                            }
                     }
                     // count which label in knn occurs most, this is the classification of (x,y)
                     int nT=0, nF=0;
					 boolean classification;
                     for (int i=0; i<knn; i++)
                         if (distances[i].label == true)
                             nT++;
                         else
                             nF++;
					 if (nT<nF)
						 classification = false;
					 else if (nT>nF)
						 classification = true;
					 else
						 classification = Math.random() < 0.5; // if tie, randomly break it
					 
                     if (classification == false)
                         g.setColor(Color.white);
                     else
                         g.setColor(Color.green);
                     g.fillRect(m*x+1, m*y+1, m, m);
					 
					 // count classification errors
					 if (classification != truth[x][y])
						 error ++;
                    }
			 // update error label
			 if (n>0)
				errLabel.setText("    Error rate = " + (float)error/n/n*100 + "%");

             // draw labeled samples 
            g.setColor(Color.black);
            for (int i=0; i<k; i++)
            {if (samples[i].label == true)
                 g.drawOval(samples[i].x*m+1, samples[i].y*m+1, m, m);
             else
                {g.drawLine(samples[i].x*m+(m+1)/2, samples[i].y*m+1, samples[i].x*m+(m+1)/2, samples[i].y*m+m);
                 g.drawLine(samples[i].x*m+1, samples[i].y*m+(m+1)/2, samples[i].x*m+m, samples[i].y*m+(m+1)/2);
                }
            }

        }
    }

    class TruthCanvas extends Canvas {
        
        public void paint(Graphics g) {
            int m=5; // m*m 'pixel'
            
            // draw bounding box
            g.setColor(Color.black);
            System.out.println(n);            
            g.drawRect(0, 0, n*m+1, n*m+1);
            
        
             // for each point, draw its true classification
             for (int x=0; x<n; x++)
                 for (int y=0; y<n; y++)
                    {
                     if (truth[x][y] == false)
                         g.setColor(Color.white);
                     else
                         g.setColor(Color.green);
                     g.fillRect(m*x+1, m*y+1, m, m);
                    }
            // draw labeled samples
            g.setColor(Color.black);
            for (int i=0; i<k; i++)
            {if (samples[i].label == true)
                 g.drawOval(samples[i].x*m+1, samples[i].y*m+1, m, m);
             else
                {g.drawLine(samples[i].x*m+(m+1)/2, samples[i].y*m+1, samples[i].x*m+(m+1)/2, samples[i].y*m+m);
                 g.drawLine(samples[i].x*m+1, samples[i].y*m+(m+1)/2, samples[i].x*m+m, samples[i].y*m+(m+1)/2);
                }
            }
            
		}
    }

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本麻豆一区二区三区视频| 日韩美女久久久| 久久91精品国产91久久小草| 欧美一卡在线观看| 久久国产精品免费| 久久精品亚洲乱码伦伦中文 | 粉嫩av亚洲一区二区图片| 欧美精品一区二区三区久久久 | 久久色中文字幕| 国产激情视频一区二区在线观看| 国产精品久久久久aaaa樱花| 色中色一区二区| 久久国产三级精品| 中文字幕在线免费不卡| 欧美人体做爰大胆视频| 激情欧美一区二区三区在线观看| 久久久久9999亚洲精品| 96av麻豆蜜桃一区二区| 亚洲高清一区二区三区| 2020日本不卡一区二区视频| 91免费精品国自产拍在线不卡| 一区二区三区 在线观看视频| 欧美精品乱人伦久久久久久| 国内精品国产成人国产三级粉色| 亚洲欧洲美洲综合色网| 欧美日韩一区二区三区四区五区 | 亚洲国产aⅴ成人精品无吗| 欧美精品日韩综合在线| 国产.欧美.日韩| 五月天亚洲婷婷| 中文字幕在线观看一区| 欧美一区二区在线视频| 99精品欧美一区二区蜜桃免费| 亚洲第一激情av| 亚洲国产毛片aaaaa无费看| 欧美白人最猛性xxxxx69交| 一本一道久久a久久精品| 麻豆91小视频| 亚洲综合999| 欧美国产一区二区| 91精品国产免费| 色偷偷一区二区三区| 国产一区不卡在线| 日韩制服丝袜av| 亚洲精品欧美综合四区| 国产日韩欧美在线一区| 日韩三级高清在线| 精品视频在线免费看| 97久久精品人人爽人人爽蜜臀| 韩国女主播一区| 青椒成人免费视频| 亚洲高清免费在线| 亚洲图片激情小说| 久久精品人人做人人爽人人 | 日韩视频免费观看高清完整版在线观看| 国产一区二区在线视频| 日韩中文字幕91| 午夜在线成人av| 亚洲欧美偷拍三级| 日本一区二区成人在线| 久久久久久久久久久电影| 日韩一级片在线观看| 欧美私人免费视频| 色视频一区二区| av一二三不卡影片| 99久久久免费精品国产一区二区| 国产精品一二一区| 国产精品自拍av| 激情另类小说区图片区视频区| 麻豆免费精品视频| 日本伊人色综合网| 男女激情视频一区| 老司机一区二区| 精品一区二区三区在线观看国产| 日本亚洲三级在线| 久久精品久久久精品美女| 欧美综合久久久| 91视视频在线直接观看在线看网页在线看| 国产福利一区二区三区| 大胆欧美人体老妇| 成人福利在线看| 91在线视频网址| 日本高清无吗v一区| 欧美色欧美亚洲另类二区| 欧美性高清videossexo| 欧美精品aⅴ在线视频| 欧美一区二区免费视频| 日韩欧美国产麻豆| 久久久久久久久久久久电影| 国产精品伦一区| 一区二区三区中文字幕在线观看| 亚洲一区免费在线观看| 日韩国产精品大片| 另类成人小视频在线| 福利视频网站一区二区三区| 91亚洲大成网污www| 欧美日韩黄色一区二区| 欧美电影免费观看高清完整版在线| 精品免费视频.| 国产精品久久毛片| 亚洲aⅴ怡春院| 国产精品中文字幕欧美| av网站免费线看精品| 91福利在线播放| 日韩欧美在线综合网| 国产精品久久久久久户外露出| 亚洲精品久久久蜜桃| 蜜桃91丨九色丨蝌蚪91桃色| 国产一区二区三区免费观看| 97成人超碰视| 91精品综合久久久久久| 国产午夜精品福利| 亚洲午夜免费电影| 国产一区二区毛片| 欧美系列在线观看| 337p粉嫩大胆噜噜噜噜噜91av | 亚洲精选视频免费看| 天堂va蜜桃一区二区三区漫画版| 国产精品小仙女| 欧美日韩视频一区二区| 久久综合色鬼综合色| 亚洲精品视频免费观看| 国模一区二区三区白浆| 91成人免费在线| 久久精品亚洲乱码伦伦中文| 亚洲第一激情av| www.性欧美| 久久精品一区二区三区不卡 | 91美女视频网站| 日韩精品一区二区三区老鸭窝| 亚洲欧美日韩国产成人精品影院| 麻豆精品国产传媒mv男同| 在线观看一区不卡| 国产精品每日更新在线播放网址| 免费成人你懂的| 欧美体内she精视频| 亚洲视频免费观看| 国产乱码精品一区二区三区五月婷| 欧美视频日韩视频| 国产精品黄色在线观看| 国产一二三精品| 欧美一卡2卡3卡4卡| 亚洲最大成人综合| 成人免费毛片片v| 精品第一国产综合精品aⅴ| 亚洲超碰精品一区二区| 91丝袜美女网| 国产精品欧美精品| 国产精品一二三四| 精品国精品自拍自在线| 婷婷国产在线综合| 欧美亚一区二区| 亚洲人成在线播放网站岛国| 岛国av在线一区| 国产日韩欧美精品一区| 国产精品系列在线播放| 国产亚洲精品7777| 国产一区二区在线免费观看| 精品久久一区二区| 久久99精品久久久久久久久久久久| 欧美高清视频www夜色资源网| 亚洲一区日韩精品中文字幕| 欧美四级电影网| 天天色综合天天| 日韩一级成人av| 久久99深爱久久99精品| 日韩欧美一级二级| 激情五月激情综合网| 2023国产精品自拍| 国产不卡一区视频| 国产精品午夜在线| 97久久精品人人爽人人爽蜜臀| 亚洲欧洲一区二区在线播放| 色综合一个色综合| 一区二区三区高清| 欧美日韩国产在线观看| 日韩1区2区3区| 精品99一区二区三区| 懂色一区二区三区免费观看| 中文字幕第一区二区| 色婷婷国产精品综合在线观看| 亚洲成人av在线电影| 欧美日韩你懂得| 久久99国产精品尤物| 中文字幕av一区 二区| 99视频一区二区| 五月综合激情日本mⅴ| 2021中文字幕一区亚洲| 成人av在线资源| 午夜精品福利在线| 7777精品久久久大香线蕉| 六月丁香综合在线视频| 国产色91在线| 一本到三区不卡视频| 免费观看成人av| 欧美韩国日本综合| 欧美久久久久久蜜桃| 国产乱人伦精品一区二区在线观看| 亚洲天堂成人网| 日韩一级黄色片|