Code/Resource
Windows Develop
Linux-Unix program
Internet-Socket-Network
Web Server
Browser Client
Ftp Server
Ftp Client
Browser Plugins
Proxy Server
Email Server
Email Client
WEB Mail
Firewall-Security
Telnet Server
Telnet Client
ICQ-IM-Chat
Search Engine
Sniffer Package capture
Remote Control
xml-soap-webservice
P2P
WEB(ASP,PHP,...)
TCP/IP Stack
SNMP
Grid Computing
SilverLight
DNS
Cluster Service
Network Security
Communication-Mobile
Game Program
Editor
Multimedia program
Graph program
Compiler program
Compress-Decompress algrithms
Crypt_Decrypt algrithms
Mathimatics-Numerical algorithms
MultiLanguage
Disk/Storage
Java Develop
assembly language
Applications
Other systems
Database system
Embeded-SCM Develop
FlashMX/Flex
source in ebook
Delphi VCL
OS Develop
MiddleWare
MPI
MacOS develop
LabView
ELanguage
Software/Tools
E-Books
Artical/Document
EntropyBasedSplitCrit.java
Package: Weka-3-2.rar [view]
Upload User: rhdiban
Upload Date: 2013-08-09
Package Size: 15085k
Code Size: 2k
Category:
Windows Develop
Development Platform:
Java
- /*
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program 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 General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
- */
- /*
- * EntropyBasedSplitCrit.java
- * Copyright (C) 1999 Eibe Frank
- *
- */
- package weka.classifiers.trees.j48;
- /**
- * "Abstract" class for computing splitting criteria
- * based on the entropy of a class distribution.
- *
- * @author Eibe Frank (eibe@cs.waikato.ac.nz)
- * @version $Revision: 1.5 $
- */
- public abstract class EntropyBasedSplitCrit extends SplitCriterion{
- /** The log of 2. */
- protected static double log2 = Math.log(2);
- /**
- * Help method for computing entropy.
- */
- public final double logFunc(double num) {
- // Constant hard coded for efficiency reasons
- if (num < 1e-6)
- return 0;
- else
- return num*Math.log(num)/log2;
- }
- /**
- * Computes entropy of distribution before splitting.
- */
- public final double oldEnt(Distribution bags) {
- double returnValue = 0;
- int j;
- for (j=0;j<bags.numClasses();j++)
- returnValue = returnValue+logFunc(bags.perClass(j));
- return logFunc(bags.total())-returnValue;
- }
- /**
- * Computes entropy of distribution after splitting.
- */
- public final double newEnt(Distribution bags) {
- double returnValue = 0;
- int i,j;
- for (i=0;i<bags.numBags();i++){
- for (j=0;j<bags.numClasses();j++)
- returnValue = returnValue+logFunc(bags.perClassPerBag(i,j));
- returnValue = returnValue-logFunc(bags.perBag(i));
- }
- return -returnValue;
- }
- /**
- * Computes entropy after splitting without considering the
- * class values.
- */
- public final double splitEnt(Distribution bags) {
- double returnValue = 0;
- int i;
- for (i=0;i<bags.numBags();i++)
- returnValue = returnValue+logFunc(bags.perBag(i));
- return logFunc(bags.total())-returnValue;
- }
- }