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

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

?? bpa.java

?? 數(shù)據(jù)挖掘。數(shù)據(jù)倉庫
?? JAVA
字號:
package org.scut.DataMining.Algorithm.NeuralNetwork.BP;

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Date;
import java.util.Random;


import org.scut.DataMining.Core.MiningData;
import org.scut.DataMining.Core.MiningException;
import org.scut.DataMining.Core.MiningMetaData;
import org.scut.DataMining.Input.File.MiningArffStream;

public class BPA
{
    private int ni;
    private int nh;
    private int no;
    private double range = 0.01;
    private double enta = 0.5;
    private int maxEpoch = 2000;
    
    private double[][] wih;
    private double[][] dwih;
    private double[][] who;
    private double[][] dwho;
    
    private double[] bh;
    private double[] dbh;
    private double[] bo;
    private double[] dbo;
    
    private double[] oh;
    private double[] oo;
    private double[] so;
    private double[] sh;
	
    private ArrayList<double[]> inputSet;
    private ArrayList<double[]> targetSet;
    
    private Random r = new Random();
   
    public BPA()
	{
		super();
	}
    public void train() throws MiningException
    {
    	this.initialize();
    	if(this.inputSet == null || this.targetSet == null)
    		throw new MiningException("input or target set not set yet!");
    	int size = this.inputSet.size();
    	int epoch = 0;
    	while(epoch++ < this.maxEpoch)
    	{
    		for(int i=0;i<size;i++)
    		{
    			double[] input = this.inputSet.get(i);
    			double[] target = this.targetSet.get(i);
    			this.forward(input);
    			this.backward(input,target);
    		}
    		this.updateWeights();
    	}
    }
    
    public double[] work(double[] input)
    {
    	this.forward(input);
    	return this.oo;
    }
    private void check() throws MiningException
    {	
    	if(this.ni <= 0)
    		throw new MiningException("BP, input layer count<=0");
    	if(this.nh<=0)
    		throw new MiningException("BP, hidden layer count<=0");
    	if(this.no <= 0)
    		throw new MiningException("BP, output layer count<=0");
    	if(this.enta <= 0)
    		throw new MiningException("BP, learning rate<=0");
    }
    private double random()
    {
    	return (r.nextDouble()-0.5)*2*this.range;
    }
    /**
	 * Sets the parameter for the BP algorithm
	 * @param params
	 */
	public void setParameter(Parameter params)
	{
		this.ni = params.input; 
		this.nh = params.hidden; 
		this.no = params.output;
		this.maxEpoch = params.maxEpoch;
		this.enta = params.learningRate;
		this.range = params.randomRange;
	}
    /**
	 * Sets the input traning set
	 * @param inputSet
	 * @throws MiningException
	 */
	public void setInputSet(ArrayList<double[]> inputSet) throws MiningException
	{
		if(inputSet == null)
			throw new MiningException("inputSet passed into is null");
		this.check();
		this.inputSet = new ArrayList<double[]>();
		for(double[] input : inputSet)
		{
			if(input.length != this.ni)
				throw new MiningException("Training data input section data size not equal to the network input size");
			this.inputSet.add(input);
		}
		if(this.targetSet != null && this.targetSet.size() != this.inputSet.size())
			throw new MiningException("Traning data input and target count not equal");
	}
	/**
	 * Sets the target training set
	 * @param targetSet
	 * @throws MiningException
	 */
	public void setTargetSet(ArrayList<double[]> targetSet) throws MiningException
	{
		if(targetSet == null)
			throw new MiningException("targetSet passed into is null");
		this.check();
		this.targetSet = new ArrayList<double[]>();
		for(double[] target : targetSet)
		{
			if(target.length != this.no)
				throw new MiningException("Training data input section data size not equal to the network input size");
			this.targetSet.add(target);
		}
		if(this.inputSet != null && this.targetSet.size() != this.inputSet.size())
			throw new MiningException("Traning data target and input count not equal");
	}
	
    private void initialize() throws MiningException
    {
    	this.check();
    	this.oh = new double[this.nh];
    	this.oo = new double[this.no];
    	
    	this.sh = new double[this.nh];
    	this.so = new double[this.no];
    	
    	this.dwih = new double[this.ni][];
    	for(int i=0;i<this.ni;i++)
    		this.dwih[i] = new double[this.nh];
    	this.dwho = new double[this.nh][];
    	for(int j=0;j<this.nh;j++)
    		this.dwho[j] = new double[this.no];
    	
    	this.dbh = new double[this.nh];
    	this.dbo = new double[this.no];
    	
    	this.wih = new double[this.ni][];
    	for(int i=0;i<this.ni;i++)
    		this.wih[i] = new double[this.nh];
    	this.who = new double[this.nh][];
    	for(int j=0;j<this.nh;j++)
    		this.who[j] = new double[this.no];
    	
    	this.bh = new double[this.nh];
    	this.bo = new double[this.no];
    	for(int i=0;i<this.ni;i++)
    		for(int j=0;j<this.nh;j++)
    			this.wih[i][j] = this.random();
    	for(int j=0;j<this.nh;j++)
    		for(int k=0;k<this.no;k++)
    			this.who[j][k] = this.random();
    	for(int j=0;j<this.nh;j++)
    		this.bh[j] = this.random();
    	for(int k=0;k<this.no;k++)
    		this.bo[k] = this.random();
    	
    }
    private void forward(double[] input)
    {
    	for(int j=0;j<this.nh;j++)
    	{
    		double netj = this.bh[j];
    		for(int i=0;i<this.ni;i++)
    			netj += this.wih[i][j] * input[i];
    		this.oh[j] = this.squash(netj);
    	}
    	for(int k=0;k<this.no;k++)
    	{
    		double netk = this.bo[k];
    		for(int j=0;j<this.nh;j++)
    			netk += this.who[j][k] * this.oh[j];
    		this.oo[k] = this.squash(netk);
    	}
    }
    private void backward(double[] input,double[] target)
    {
    	for(int k=0;k<this.no;k++)
    		this.so[k] = (target[k]-this.oo[k])*this.oo[k]*(1-this.oo[k]);
    	for(int j=0;j<this.nh;j++)
    	{
    		double ss = 0;
    		for(int k=0;k<this.no;k++)
    			ss += this.who[j][k] * this.so[k];
    		this.sh[j] = this.oh[j]*(1-this.oh[j])*ss;
    	}
    	
    	//: computes the delta weights
    	for(int j=0;j<this.nh;j++)
    		for(int k=0;k<this.no;k++)
    			this.dwho[j][k] += this.enta * this.so[k] * this.oh[j];
    	for(int i=0;i<this.ni;i++)
    		for(int j=0;j<this.nh;j++)
    			this.dwih[i][j] += this.enta * this.sh[j] * input[i];
    	for(int k=0;k<this.no;k++)
    		this.dbo[k] += this.enta * this.so[k];
    	for(int j=0;j<this.nh;j++)
    		this.dbh[j] += this.enta * this.sh[j];
    	
    }
    private void updateWeights()
    {
    	//: weights
    	for(int j=0;j<this.nh;j++)
    		for(int k=0;k<this.no;k++)
    			this.who[j][k] += this.dwho[j][k];
    	for(int i=0;i<this.ni;i++)
    		for(int j=0;j<this.nh;j++)
    			this.wih[i][j] += this.dwih[i][j];
    	for(int k=0;k<this.no;k++)
    		this.bo[k] += this.dbo[k];
    	for(int j=0;j<this.nh;j++)
    		this.bh[j] += this.dbh[j];
    	//: delta weights
    	for(int j=0;j<this.nh;j++)
    		for(int k=0;k<this.no;k++)
    			this.dwho[j][k] = 0;
    	for(int i=0;i<this.ni;i++)
    		for(int j=0;j<this.nh;j++)
    			this.dwih[i][j] = 0;
    	for(int k=0;k<this.no;k++)
    		this.dbo[k] = 0;
    	for(int j=0;j<this.nh;j++)
    		this.dbh[j] = 0;
    }
   
    private double squash(double value)
    {
    	return 1.0/(1.0+Math.exp(-value));
    }
    public void save(String fileName)
    {
    	try
		{
			BufferedWriter bw = new BufferedWriter(new FileWriter(fileName));
			String siho =  this.ni+","+this.nh+","+this.no+"\n";
			StringBuilder swih = new StringBuilder();
			StringBuilder swho = new StringBuilder();
			StringBuilder sbh = new StringBuilder();
			StringBuilder sbo = new StringBuilder();
			for(int i=0;i<this.ni;i++)
			{
				for(int j=0;j<this.nh;j++)
					if( i == this.ni-1 && j == this.nh-1)
						swih.append(this.wih[i][j] + "\n");
					else
						swih.append(this.wih[i][j] + ",");
			}
			for(int j=0;j<this.nh;j++)
			{
				for(int k=0;k<this.no;k++)
					if( j == this.nh-1 && k == this.no -1)
						swho.append(this.who[j][k] + "\n");
					else
						swho.append(this.who[j][k] + ",");
			}
			for(int j=0;j<this.nh;j++)
			{
				if(j==this.nh-1)
					sbh.append(this.bh[j] + "\n");
				else
					sbh.append(this.bh[j] + ",");
			}
			for(int k=0;k<this.no;k++)
			{
				if(k==this.no-1)
					sbo.append(this.bo[k] + "\n");
				else
					sbo.append(this.bo[k] + ",");
			}
			bw.write(siho);
			bw.write(swih.toString());
			bw.write(swho.toString());
			bw.write(sbh.toString());
			bw.write(sbo.toString());
			bw.close();
		} 
    	catch (IOException e)
		{
			e.printStackTrace();
		}
    }
    public static BPA load(String fileName)
    {
    	BPA bp =  new BPA();
    	try
		{
			BufferedReader br = new BufferedReader(new FileReader(fileName));
			String iho = br.readLine();
			String wih = br.readLine();
			String who = br.readLine();
			String bh = br.readLine();
			String bo = br.readLine();
			
			String[] siho = iho.split("[,]");
			String[] swih = wih.split("[,]");
			String[] swho = who.split("[,]");
			String[] sbh =  bh.split("[,]");
			String[] sbo =  bo.split("[,]");
			
			bp.ni = Integer.valueOf(siho[0]);
			bp.nh = Integer.valueOf(siho[1]);
			bp.no = Integer.valueOf(siho[2]);
			
			bp.initialize();
	    	
	    	for(int i=0;i<swih.length;i++)
	    		bp.wih[i/bp.nh][i%bp.nh] = Double.valueOf(swih[i]);
	    	for(int i=0;i<swho.length;i++)
	    		bp.who[i/bp.nh][i%bp.nh] = Double.valueOf(swih[i]);
	    	for(int j=0;j<bp.nh;j++)
	    		bp.bh[j] = Double.valueOf(sbh[j]);
	    	for(int k=0;k<bp.no;k++)
	    		bp.bo[k] = Double.valueOf(sbo[k]);
	    	
	    	br.close();
		} 
    	catch (Exception e)
		{
			e.printStackTrace();
		}
    	return bp;
    }
    
	public static void main(String[] args)
	{
		long start = 0,end = 0; 
		start = new Date().getTime();
		try 
		{
			ArrayList<MiningData> data = new ArrayList<MiningData>();
			
			MiningArffStream arff = new MiningArffStream("arff//pm.arff");
			while(arff.next())
			{
				MiningData d = new MiningData(arff.getData());
				data.add(d);
				d.normalize();
				//System.out.println(d.toString());
			}
			MiningMetaData meta = arff.getMetaData();
			
			for(int i=6;i<18;i++) meta.addInput(i);
			for(int i=0;i<6;i++) meta.addTarget(i);
			
			ArrayList<double[]> inputSet = new ArrayList<double[]>();
			ArrayList<double[]> targetSet = new ArrayList<double[]>();
			for(MiningData d : data)
			{
				inputSet.add(d.getInput());
				targetSet.add(d.getTarget());
			}
			
			Parameter param = new Parameter();
			param.input = meta.getInputCount();
			param.output = meta.getTargetCount();
			param.hidden = (param.input+param.output)/2;
			
			param.maxEpoch = 200;
			param.learningRate = 0.1;
			param.randomRange = 0.01;
			BPA bp = new BPA();
			bp.setParameter(param);
			bp.setInputSet(inputSet);
			bp.setTargetSet(targetSet);
			
			bp.train();
			bp.save("tmp.txt");
		} 
		catch (MiningException e) 
		{
			e.printStackTrace();
		}
		end = new Date().getTime();
		System.out.println("Time eclipsed[s]: " + (end-start)/1000.0);
	}

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产不卡一区视频| 国产欧美日韩不卡免费| 9191久久久久久久久久久| 久久夜色精品国产欧美乱极品| 中文字幕一区二区三区不卡在线| 蜜桃免费网站一区二区三区| 波多野结衣精品在线| 欧美tk丨vk视频| 亚洲一区二区三区三| 福利电影一区二区三区| 日韩精品一区二区三区在线| 亚洲国产成人av网| 99久久精品免费看| 久久免费的精品国产v∧| 日韩经典一区二区| 在线观看亚洲专区| 亚洲国产精品v| 久久99久久99小草精品免视看| 日本韩国精品在线| 中文字幕一区三区| 成人网页在线观看| 国产天堂亚洲国产碰碰| 久久av资源站| 亚洲精品一线二线三线无人区| 日韩二区三区四区| 欧美日韩一区二区三区四区五区| 亚洲老司机在线| eeuss鲁片一区二区三区在线看| 国产午夜精品一区二区| 美女精品自拍一二三四| 日韩一区国产二区欧美三区| 日韩精品电影在线观看| 91精品国产手机| 男男gaygay亚洲| 日韩欧美高清在线| 久久www免费人成看片高清| 欧美成人bangbros| 国产一区亚洲一区| 日本一区二区成人在线| 国产乱国产乱300精品| 久久久精品国产免大香伊 | 亚洲免费视频中文字幕| 91一区一区三区| 亚洲乱码中文字幕综合| 91国在线观看| 香蕉久久夜色精品国产使用方法| 欧美在线综合视频| 婷婷久久综合九色国产成人 | 丝袜美腿成人在线| 日韩天堂在线观看| 国产麻豆精品视频| 国产精品视频在线看| 色诱亚洲精品久久久久久| 亚洲福中文字幕伊人影院| 日韩欧美一区二区久久婷婷| 国产福利精品一区| 亚洲特黄一级片| 欧美片在线播放| 国产一区二区女| 国产精品看片你懂得| 欧美午夜电影网| 精品亚洲成a人在线观看| 中文一区一区三区高中清不卡| 91丨九色丨蝌蚪富婆spa| 亚洲图片欧美色图| 久久先锋影音av| 91久久香蕉国产日韩欧美9色| 天天av天天翘天天综合网| 欧美刺激脚交jootjob| 99久久精品国产一区二区三区| 亚洲成人自拍网| 国产日产欧美一区二区三区| 在线一区二区三区| 激情av综合网| 亚洲综合成人在线| 26uuu国产日韩综合| 99vv1com这只有精品| 美女脱光内衣内裤视频久久网站 | 成人v精品蜜桃久久一区| 亚洲一本大道在线| 久久久国产精华| 7777精品伊人久久久大香线蕉完整版 | 亚欧色一区w666天堂| 国产亚洲精品精华液| 欧美日韩在线播放三区| 国产精品伊人色| 青青草精品视频| 亚洲人成影院在线观看| 26uuu欧美日本| 欧美一区日韩一区| 色播五月激情综合网| 国产成人丝袜美腿| 久久91精品国产91久久小草| 伊人色综合久久天天人手人婷| 国产人久久人人人人爽| 日韩视频在线你懂得| 欧美日韩国产小视频| 99精品视频在线免费观看| 国产一区视频网站| 精品影院一区二区久久久| 五月天丁香久久| 一区二区三区四区中文字幕| 中文字幕视频一区| 国产欧美精品区一区二区三区| 欧美mv日韩mv亚洲| 7777精品伊人久久久大香线蕉超级流畅| 91视频.com| 色综合一区二区三区| 成人黄色小视频| 粉嫩aⅴ一区二区三区四区| 韩国视频一区二区| 久久99精品国产麻豆婷婷洗澡| 日产欧产美韩系列久久99| 亚洲h动漫在线| 一区二区三区丝袜| 一区二区三区免费观看| 亚洲久草在线视频| 一区二区三区在线视频播放| 亚洲一区二区三区不卡国产欧美| 亚洲精品综合在线| 亚洲女同一区二区| 依依成人综合视频| 亚洲欧美日韩国产中文在线| 亚洲欧洲精品一区二区三区不卡| 国产精品久久久一区麻豆最新章节| 中文字幕 久热精品 视频在线| **网站欧美大片在线观看| 亚洲欧美在线视频观看| 亚洲人成伊人成综合网小说| 亚洲美女免费视频| 午夜精品免费在线| 日韩av高清在线观看| 久久av中文字幕片| 国产999精品久久| 91视频国产资源| 在线精品视频免费观看| 欧美精品乱人伦久久久久久| 日韩欧美一二区| 国产精品视频线看| 亚洲精品国产无天堂网2021| 首页国产欧美日韩丝袜| 久久国产夜色精品鲁鲁99| 国产成人精品亚洲日本在线桃色 | 石原莉奈在线亚洲三区| 奇米色一区二区| 国产成人精品影视| 欧美亚洲综合在线| 精品久久久久香蕉网| 国产精品欧美极品| 午夜精品久久久久久久久| 麻豆一区二区三区| av一二三不卡影片| 欧美日韩1234| 国产精品网站在线观看| 亚洲一二三四久久| 国产精一品亚洲二区在线视频| 97久久精品人人爽人人爽蜜臀| 3d动漫精品啪啪| 国产精品视频线看| 日韩高清一级片| 不卡的电视剧免费网站有什么| 在线不卡的av| 国产精品久线在线观看| 美女视频一区二区| 成人福利视频在线看| 91麻豆精品国产91久久久久久| 中文字幕一区二区视频| 美国十次了思思久久精品导航| 91免费在线看| 久久综合久久久久88| 天天免费综合色| 一本高清dvd不卡在线观看| www国产成人免费观看视频 深夜成人网| 亚洲女人的天堂| 高清免费成人av| 日韩精品一区国产麻豆| 亚洲aⅴ怡春院| 在线观看免费亚洲| 欧美国产日本韩| 久久爱另类一区二区小说| 欧美色图12p| 亚洲精品乱码久久久久久黑人| 国产大陆亚洲精品国产| 日韩欧美的一区二区| 首页国产欧美日韩丝袜| 欧美午夜电影网| 洋洋av久久久久久久一区| 不卡一卡二卡三乱码免费网站| 久久午夜电影网| 久久99精品久久久久婷婷| 日韩亚洲电影在线| 三级欧美韩日大片在线看| 精品视频在线免费观看| 亚洲精品久久久久久国产精华液| 波多野结衣视频一区| 国产精品二三区| 色综合中文字幕国产 | 亚洲欧美激情插| 成人18视频日本| 亚洲欧美国产三级|