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

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

?? c45modelselection.java

?? 一個(gè)數(shù)據(jù)挖掘系統(tǒng)的源碼
?? JAVA
字號:

/**
 *   
 *   AgentAcademy - an open source Data Mining framework for
 *   training intelligent agents
 *
 *   Copyright (C)   2001-2003 AA Consortium.
 *
 *   This library is open source software; you can redistribute it 
 *   and/or modify it under the terms of the GNU Lesser General 
 *   Public License as published by the Free Software Foundation;   
 *   either version 2.0 of the License, or (at your option) any later 
 *   version.
 *
 *   This library is distributed in the hope that it will be useful,
 *   but WITHOUT ANY WARRANTY; without even the implied warranty of
 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the    
 *   GNU General Public License for more details.
 *
 *   You should have received a copy of the GNU Lesser General Public
 *   License along with this library; if not, write to the Free 
 *   Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, 
 *   MA  02111-1307 USA
 * 
 */

package org.agentacademy.modules.dataminer.classifiers;

/**
 * <p>Title: The Data Miner prototype</p>
 * <p>Description: A prototype for the DataMiner (DM), the Agent Academy (AA) module responsible for performing data mining on the contents of the Agent Use Repository (AUR). The extracted knowledge is to be sent back to the AUR in the form of a PMML document.</p>
 * <p>Copyright: Copyright (c) 2002</p>
 * <p>Company: CERTH</p>
 * @author asymeon
 * @version 0.3
 */

import java.util.*;
import org.agentacademy.modules.dataminer.core.*;

/**
 * Class for selecting a C4.5-type split for a given dataset.
 *
 */
public class C45ModelSelection extends ModelSelection {

  /** Minimum number of objects in interval. */
  private int m_minNoObj;

  /** All the training data */
  private Instances m_allData; //

  /**
   * Initializes the split selection method with the given parameters.
   *
   * @param minNoObj minimum number of instances that have to occur in at least two
   * subsets induced by split
   * @param allData FULL training dataset (necessary for
   * selection of split points).
   */
  public C45ModelSelection(int minNoObj, Instances allData) {
    m_minNoObj = minNoObj;
    m_allData = allData;
  }

  /**
   * Sets reference to training data to null.
   */
  public void cleanup() {

    m_allData = null;
  }

  /**
   * Selects C4.5-type split for the given dataset.
   */
  public final ClassifierSplitModel selectModel(Instances data){

    double minResult;
    double currentResult;
    C45Split [] currentModel;
    C45Split bestModel = null;
    NoSplit noSplitModel = null;
    double averageInfoGain = 0;
    int validModels = 0;
    boolean multiVal = true;
    Distribution checkDistribution;
    Attribute attribute;
    double sumOfWeights;
    int i;

    try{

      // Check if all Instances belong to one class or if not
      // enough Instances to split.
      checkDistribution = new Distribution(data);
      noSplitModel = new NoSplit(checkDistribution);
      if (Utils.sm(checkDistribution.total(),2*m_minNoObj) ||
	  Utils.eq(checkDistribution.total(),
		   checkDistribution.perClass(checkDistribution.maxClass())))
	return noSplitModel;

      // Check if all attributes are nominal and have a
      // lot of values.
      if (m_allData != null) {
	Enumeration enum = data.enumerateAttributes();
	while (enum.hasMoreElements()) {
	  attribute = (Attribute) enum.nextElement();
	  if ((attribute.isNumeric()) ||
	      (Utils.sm((double)attribute.numValues(),
			(0.3*(double)m_allData.numInstances())))){
	    multiVal = false;
	    break;
	  }
	}
      }

      currentModel = new C45Split[data.numAttributes()];
      sumOfWeights = data.sumOfWeights();

      // For each attribute.
      for (i = 0; i < data.numAttributes(); i++){

	// Apart from class attribute.
	if (i != (data).classIndex()){

	  // Get models for current attribute.
	  currentModel[i] = new C45Split(i,m_minNoObj,sumOfWeights);
	  currentModel[i].buildClassifier(data);

	  // Check if useful split for current attribute
	  // exists and check for enumerated attributes with
	  // a lot of values.
	  if (currentModel[i].checkModel())
	    if (m_allData != null) {
	      if ((data.attribute(i).isNumeric()) ||
		  (multiVal || Utils.sm((double)data.attribute(i).numValues(),
					(0.3*(double)m_allData.numInstances())))){
		averageInfoGain = averageInfoGain+currentModel[i].infoGain();
		validModels++;
	      }
	    } else {
	      averageInfoGain = averageInfoGain+currentModel[i].infoGain();
	      validModels++;
	    }
	}else
	  currentModel[i] = null;
      }

      // Check if any useful split was found.
      if (validModels == 0)
	return noSplitModel;
      averageInfoGain = averageInfoGain/(double)validModels;

      // Find "best" attribute to split on.
      minResult = 0;
      for (i=0;i<data.numAttributes();i++){
	if ((i != (data).classIndex()) &&
	    (currentModel[i].checkModel()))

	  // Use 1E-3 here to get a closer approximation to the original
	  // implementation.
	  if ((currentModel[i].infoGain() >= (averageInfoGain-1E-3)) &&
	      Utils.gr(currentModel[i].gainRatio(),minResult)){
	    bestModel = currentModel[i];
	    minResult = currentModel[i].gainRatio();
	  }
      }

      // Check if useful split was found.
      if (Utils.eq(minResult,0))
	return noSplitModel;

      // Add all Instances with unknown values for the corresponding
      // attribute to the distribution for the model, so that
      // the complete distribution is stored with the model.
      bestModel.distribution().
	  addInstWithUnknown(data,bestModel.attIndex());

      // Set the split point analogue to C45 if attribute numeric.
      if (m_allData != null)
	bestModel.setSplitPoint(m_allData);
      return bestModel;
    }catch(Exception e){
      e.printStackTrace();
    }
    return null;
  }

  /**
   * Selects C4.5-type split for the given dataset.
   */
  public final ClassifierSplitModel selectModel(Instances train, Instances test) {

    return selectModel(train);
  }
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
夫妻av一区二区| 国产黑丝在线一区二区三区| 色狠狠综合天天综合综合| 亚洲视频一二三| 欧美日本乱大交xxxxx| 久久国产精品无码网站| 久久久www免费人成精品| 成人免费高清在线观看| 亚洲综合激情另类小说区| 欧美日韩色综合| 蜜桃视频在线观看一区二区| 蜜桃一区二区三区四区| 欧美日精品一区视频| 另类的小说在线视频另类成人小视频在线 | 欧美剧在线免费观看网站 | 激情综合五月天| 中文字幕国产精品一区二区| 91成人网在线| 蜜臀av一区二区三区| 国产精品久久免费看| 欧美日韩色一区| 国产乱色国产精品免费视频| 亚洲免费伊人电影| 欧美va亚洲va在线观看蝴蝶网| 国产精品综合二区| 樱花草国产18久久久久| 精品国产乱码久久久久久牛牛| 成人国产视频在线观看| 日本aⅴ亚洲精品中文乱码| 国产日产亚洲精品系列| 欧美日韩视频第一区| 高清不卡在线观看| 五月天激情综合网| 国产精品天干天干在线综合| 欧美图片一区二区三区| 风间由美一区二区三区在线观看 | 国产综合色在线视频区| 亚洲无线码一区二区三区| 久久久五月婷婷| 欧美日韩综合不卡| 成人av网站在线| 久久国产剧场电影| 亚洲sss视频在线视频| 国产三级一区二区三区| 欧美精品乱码久久久久久| 懂色一区二区三区免费观看| 日韩av网站在线观看| 亚洲精品欧美激情| 国产欧美一区二区三区在线看蜜臀| 欧美日韩精品高清| 色综合视频一区二区三区高清| 国产美女av一区二区三区| 日韩精品电影在线| 亚洲精品国产无套在线观| 中文字幕乱码久久午夜不卡| 欧美变态凌虐bdsm| 日韩一区二区在线看| 欧美日韩黄色影视| 在线免费观看一区| 99精品视频在线播放观看| 国产一区视频网站| 久久精品国产99| 日本午夜精品视频在线观看| 亚洲国产欧美另类丝袜| 亚洲欧美一区二区不卡| 国产精品福利影院| 国产精品久久精品日日| 国产欧美va欧美不卡在线 | 亚洲国产电影在线观看| 久久先锋影音av鲁色资源网| 精品久久久久久久久久久院品网| 欧美探花视频资源| 蜜臀av性久久久久蜜臀aⅴ | 91黄色免费看| 99久久综合狠狠综合久久| 国产91精品露脸国语对白| 国产一区三区三区| 九色porny丨国产精品| 蜜桃久久av一区| 精品综合久久久久久8888| 久久草av在线| 国产成人综合网| 成人综合在线观看| 91在线观看成人| 欧美伊人久久久久久午夜久久久久| 色偷偷88欧美精品久久久| 97久久超碰精品国产| 在线观看日韩精品| 欧美日韩精品一区视频| 欧美一级国产精品| 久久视频一区二区| 中文字幕亚洲一区二区av在线| 亚洲欧美另类图片小说| 亚洲成人手机在线| 老司机免费视频一区二区| 国产白丝网站精品污在线入口| 成人av资源站| 欧美少妇xxx| 精品国产免费一区二区三区四区| 国产亚洲欧美色| 中文字幕亚洲在| 亚洲第一精品在线| 国产露脸91国语对白| 99国产精品99久久久久久| 欧美午夜在线一二页| 欧美一区二区三区不卡| 久久精品无码一区二区三区| 一区二区三区在线视频免费观看| 亚洲一区二区精品久久av| 美女诱惑一区二区| 99v久久综合狠狠综合久久| 欧美精品v日韩精品v韩国精品v| 久久亚洲综合av| 亚洲免费观看高清在线观看| 日本不卡高清视频| jlzzjlzz欧美大全| 日韩欧美一区二区不卡| 中文字幕在线不卡国产视频| 日本美女视频一区二区| 不卡区在线中文字幕| 欧美丰满少妇xxxxx高潮对白| 久久久久久久久久电影| 午夜一区二区三区在线观看| 国产精品77777竹菊影视小说| 欧美四级电影网| 国产精品久久久久久久久免费樱桃 | 午夜精品久久久久久久蜜桃app| 免费看精品久久片| 色欲综合视频天天天| 欧美精品一区二区高清在线观看 | 欧美精品一区二区三区蜜桃| 亚洲丝袜美腿综合| 国产中文字幕精品| 欧美三级中文字| 亚洲国产精品t66y| 久久99精品国产.久久久久 | 蜜臀久久久久久久| 色综合天天综合在线视频| 日韩精品一区二区在线| 亚洲一二三区视频在线观看| 丰满少妇在线播放bd日韩电影| 欧美一区二区三区在线观看视频| 亚洲视频中文字幕| 国产精品自拍毛片| 精品国产乱码久久久久久图片| 亚洲成人中文在线| 91久久久免费一区二区| 中文字幕av在线一区二区三区| 国产一区二区三区在线看麻豆| 欧美日本一区二区在线观看| 悠悠色在线精品| 97aⅴ精品视频一二三区| 国产精品污污网站在线观看| 国产在线精品不卡| 久久影视一区二区| 激情文学综合网| 久久综合久久久久88| 蜜桃视频一区二区三区| 欧美一级免费观看| 青青草视频一区| 欧美精品一级二级三级| 亚洲电影一级黄| 在线不卡中文字幕播放| 亚洲制服丝袜av| 欧美三级在线看| 日韩精品三区四区| 日韩三级.com| 激情久久五月天| 久久久九九九九| 成人综合婷婷国产精品久久蜜臀| 国产欧美一区视频| 成人高清视频在线| 亚洲欧美日韩国产另类专区| 色悠悠亚洲一区二区| 亚洲曰韩产成在线| 欧美美女一区二区| 激情文学综合丁香| 国产三级欧美三级日产三级99| 国产成人亚洲精品青草天美| 亚洲国产成人在线| 色婷婷亚洲精品| 婷婷中文字幕一区三区| 欧美成人在线直播| 国产一区二区三区在线看麻豆| 中文字幕精品在线不卡| 成人av免费在线| 亚洲一区二区精品3399| 日韩欧美一级片| 成人性视频免费网站| 亚洲影院理伦片| 精品少妇一区二区三区在线播放| 国产麻豆精品在线| 亚洲精品一二三| 日韩欧美专区在线| 成人激情校园春色| 偷拍自拍另类欧美| 久久亚洲一级片| 色综合天天狠狠| 国内精品伊人久久久久av一坑| 中文字幕在线一区免费|