⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 associationspanel.java

📁 :<<数据挖掘--实用机器学习技术及java实现>>一书的配套源程序
💻 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. *//* *    AssociationsPanel.java *    Copyright (C) 1999 Eibe Frank * */package weka.gui.explorer;import weka.core.Instances;import weka.core.OptionHandler;import weka.core.Attribute;import weka.core.Utils;import weka.associations.Associator;import weka.filters.Filter;import weka.gui.Logger;import weka.gui.TaskLogger;import weka.gui.SysErrLog;import weka.gui.GenericObjectEditor;import weka.gui.PropertyPanel;import weka.gui.ResultHistoryPanel;import weka.gui.SetInstancesPanel;import weka.gui.SaveBuffer;import java.util.Random;import java.util.Date;import java.text.SimpleDateFormat;import java.awt.FlowLayout;import java.awt.BorderLayout;import java.awt.GridLayout;import java.awt.GridBagLayout;import java.awt.GridBagConstraints;import java.awt.Insets;import java.awt.Font;import java.awt.event.ActionListener;import java.awt.event.ActionEvent;import java.awt.event.InputEvent;import java.awt.event.MouseAdapter;import java.awt.event.MouseEvent;import java.beans.PropertyChangeListener;import java.beans.PropertyChangeEvent;import java.beans.PropertyChangeSupport;import java.io.File;import java.io.FileWriter;import java.io.Writer;import java.io.BufferedWriter;import java.io.PrintWriter;import javax.swing.JFileChooser;import javax.swing.JPanel;import javax.swing.JLabel;import javax.swing.JButton;import javax.swing.BorderFactory;import javax.swing.JTextArea;import javax.swing.JScrollPane;import javax.swing.JRadioButton;import javax.swing.ButtonGroup;import javax.swing.JOptionPane;import javax.swing.JComboBox;import javax.swing.DefaultComboBoxModel;import javax.swing.JTextField;import javax.swing.SwingConstants;import javax.swing.JFrame;import javax.swing.event.ChangeListener;import javax.swing.event.ChangeEvent;import javax.swing.JViewport;import java.awt.Point;/**  * This panel allows the user to select, configure, and run a scheme * that learns associations. * * @author Eibe Frank (eibe@cs.waikato.ac.nz) * @version $Revision: 1.13.2.1 $ */public class AssociationsPanel extends JPanel {  /** Lets the user configure the associator */  protected GenericObjectEditor m_AssociatorEditor =    new GenericObjectEditor();  /** The panel showing the current associator selection */  protected PropertyPanel m_CEPanel = new PropertyPanel(m_AssociatorEditor);    /** The output area for associations */  protected JTextArea m_OutText = new JTextArea(20, 40);  /** The destination for log/status messages */  protected Logger m_Log = new SysErrLog();  /** The buffer saving object for saving output */  protected SaveBuffer m_SaveOut = new SaveBuffer(m_Log, this);  /** A panel controlling results viewing */  protected ResultHistoryPanel m_History = new ResultHistoryPanel(m_OutText);  /** Click to start running the associator */  protected JButton m_StartBut = new JButton("Start");  /** Click to stop a running associator */  protected JButton m_StopBut = new JButton("Stop");    /** Click to save the output associated with the currently selected result */  protected JButton m_SaveOutBut = new JButton("Save Output");    /** The main set of instances we're playing with */  protected Instances m_Instances;  /** The user-supplied test set (if any) */  protected Instances m_TestInstances;    /** A thread that associator runs in */  protected Thread m_RunThread;  /* Register the property editors we need */  static {    java.beans.PropertyEditorManager      .registerEditor(weka.core.SelectedTag.class,		      weka.gui.SelectedTagEditor.class);    java.beans.PropertyEditorManager      .registerEditor(weka.filters.Filter.class,		      weka.gui.GenericObjectEditor.class);    java.beans.PropertyEditorManager      .registerEditor(weka.associations.Associator.class,		      weka.gui.GenericObjectEditor.class);  }    /**   * Creates the associator panel   */  public AssociationsPanel() {    // Connect / configure the components    m_OutText.setEditable(false);    m_OutText.setFont(new Font("Monospaced", Font.PLAIN, 12));    m_OutText.setBorder(BorderFactory.createEmptyBorder(5, 5, 5, 5));    m_OutText.addMouseListener(new MouseAdapter() {      public void mouseClicked(MouseEvent e) {	if ((e.getModifiers() & InputEvent.BUTTON1_MASK)	    != InputEvent.BUTTON1_MASK) {	  m_OutText.selectAll();	}      }    });    m_History.setBorder(BorderFactory.createTitledBorder("Result list"));    m_AssociatorEditor.setClassType(Associator.class);    m_AssociatorEditor.setValue(new weka.associations.Apriori());    m_AssociatorEditor.addPropertyChangeListener(new PropertyChangeListener() {      public void propertyChange(PropertyChangeEvent e) {	repaint();      }    });    m_StartBut.setToolTipText("Starts the associator");    m_StopBut.setToolTipText("Stops the associator");    m_SaveOutBut.setToolTipText("Save the selected associator output to a file");    m_StartBut.setEnabled(false);    m_StopBut.setEnabled(false);    m_SaveOutBut.setEnabled(false);    m_StartBut.addActionListener(new ActionListener() {      public void actionPerformed(ActionEvent e) {	startAssociator();      }    });    m_StopBut.addActionListener(new ActionListener() {      public void actionPerformed(ActionEvent e) {	stopAssociator();      }    });    m_SaveOutBut.addActionListener(new ActionListener() {	public void actionPerformed(ActionEvent e) {	  saveBuffer();	}      });    // Layout the GUI    JPanel p1 = new JPanel();    p1.setBorder(BorderFactory.createCompoundBorder(		 BorderFactory.createTitledBorder("Associator"),		 BorderFactory.createEmptyBorder(0, 5, 5, 5)		 ));    p1.setLayout(new BorderLayout());    p1.add(m_CEPanel, BorderLayout.NORTH);    JPanel buttons = new JPanel();    buttons.setLayout(new GridLayout(2,2));    JPanel ssButs = new JPanel();    ssButs.setBorder(BorderFactory.createEmptyBorder(5, 5, 5, 5));    ssButs.setLayout(new GridLayout(1, 2, 5, 5));    ssButs.add(m_StartBut);    ssButs.add(m_StopBut);    buttons.add(ssButs);    JPanel vPl = new JPanel();    vPl.setBorder(BorderFactory.createEmptyBorder(5, 5, 5, 5));    vPl.setLayout(new GridLayout(1,1,5,5));    vPl.add(m_SaveOutBut);    buttons.add(vPl);        JPanel p3 = new JPanel();    p3.setBorder(BorderFactory.createTitledBorder("Associator output"));    p3.setLayout(new BorderLayout());    final JScrollPane js = new JScrollPane(m_OutText);    p3.add(js, BorderLayout.CENTER);    js.getViewport().addChangeListener(new ChangeListener() {      private int lastHeight;      public void stateChanged(ChangeEvent e) {	JViewport vp = (JViewport)e.getSource();	int h = vp.getViewSize().height; 	if (h != lastHeight) { // i.e. an addition not just a user scrolling	  lastHeight = h;	  int x = h - vp.getExtentSize().height;	  vp.setViewPosition(new Point(0, x));	}      }    });        GridBagLayout gbL = new GridBagLayout();    GridBagConstraints gbC = new GridBagConstraints();    JPanel mondo = new JPanel();    gbL = new GridBagLayout();    mondo.setLayout(gbL);    gbC = new GridBagConstraints();    gbC.anchor = GridBagConstraints.NORTH;    gbC.fill = GridBagConstraints.HORIZONTAL;    gbC.gridy = 1;     gbC.gridx = 0;    gbL.setConstraints(buttons, gbC);    mondo.add(buttons);    gbC = new GridBagConstraints();    gbC.fill = GridBagConstraints.BOTH;    gbC.gridy = 2;     gbC.gridx = 0; gbC.weightx = 0;    gbL.setConstraints(m_History, gbC);    mondo.add(m_History);    gbC = new GridBagConstraints();    gbC.fill = GridBagConstraints.BOTH;    gbC.gridy = 0;     gbC.gridx = 1;    gbC.gridheight = 3;    gbC.weightx = 100; gbC.weighty = 100;    gbL.setConstraints(p3, gbC);    mondo.add(p3);    setLayout(new BorderLayout());    add(p1, BorderLayout.NORTH);    add(mondo, BorderLayout.CENTER);  }    /**   * Sets the Logger to receive informational messages   *   * @param newLog the Logger that will now get info messages   */  public void setLog(Logger newLog) {    m_Log = newLog;  }    /**   * Tells the panel to use a new set of instances.   *   * @param inst a set of Instances   */  public void setInstances(Instances inst) {        m_Instances = inst;    String [] attribNames = new String [m_Instances.numAttributes()];    for (int i = 0; i < attribNames.length; i++) {      String type = "";      switch (m_Instances.attribute(i).type()) {      case Attribute.NOMINAL:	type = "(Nom) ";	break;      case Attribute.NUMERIC:	type = "(Num) ";	break;      case Attribute.STRING:	type = "(Str) ";	break;      default:	type = "(???) ";      }      attribNames[i] = type + m_Instances.attribute(i).name();    }    m_StartBut.setEnabled(m_RunThread == null);    m_StopBut.setEnabled(m_RunThread != null);  }    /**   * Starts running the currently configured associator with the current   * settings. This is run in a separate thread, and will only start if   * there is no associator already running. The associator output is sent   * to the results history panel.   */  protected void startAssociator() {    if (m_RunThread == null) {      m_StartBut.setEnabled(false);      m_StopBut.setEnabled(true);      m_RunThread = new Thread() {	public void run() {	  // Copy the current state of things	  m_Log.statusMessage("Setting up...");	  Instances inst = new Instances(m_Instances);	  Associator associator = (Associator) m_AssociatorEditor.getValue();	  StringBuffer outBuff = new StringBuffer();	  String name = (new SimpleDateFormat("HH:mm:ss - "))	  .format(new Date());	  String cname = associator.getClass().getName();	  if (cname.startsWith("weka.associations.")) {	    name += cname.substring("weka.associations.".length());	  } else {	    name += cname;	  }	  try {	    // Output some header information	    m_Log.logMessage("Started " + cname);	    if (m_Log instanceof TaskLogger) {	      ((TaskLogger)m_Log).taskStarted();	    }	    outBuff.append("=== Run information ===\n\n");	    outBuff.append("Scheme:       " + cname);	    if (associator instanceof OptionHandler) {	      String [] o = ((OptionHandler) associator).getOptions();	      outBuff.append(" " + Utils.joinOptions(o));	    }	    outBuff.append("\n");	    outBuff.append("Relation:     " + inst.relationName() + '\n');	    outBuff.append("Instances:    " + inst.numInstances() + '\n');	    outBuff.append("Attributes:   " + inst.numAttributes() + '\n');	    if (inst.numAttributes() < 100) {	      for (int i = 0; i < inst.numAttributes(); i++) {		outBuff.append("              " + inst.attribute(i).name()			       + '\n');	      }	    } else {	      outBuff.append("              [list of attributes omitted]\n");	    }	    m_History.addResult(name, outBuff);	    m_History.setSingle(name);	    	    // Build the model and output it.	    m_Log.statusMessage("Building model on training data...");	    associator.buildAssociations(inst);	    outBuff.append("=== Associator model (full training set) ===\n\n");	    outBuff.append(associator.toString() + '\n');	    m_History.updateResult(name);	    m_Log.logMessage("Finished " + cname);	    m_Log.statusMessage("OK");	  } catch (Exception ex) {	    m_Log.logMessage(ex.getMessage());	    m_Log.statusMessage("See error log");	  } finally {	    if (isInterrupted()) {	      m_Log.logMessage("Interrupted " + cname);	      m_Log.statusMessage("See error log");	    }	    m_SaveOutBut.setEnabled(true);	    m_RunThread = null;	    m_StartBut.setEnabled(true);	    m_StopBut.setEnabled(false);	    if (m_Log instanceof TaskLogger) {	      ((TaskLogger)m_Log).taskFinished();	    }	  }	}      };      m_RunThread.setPriority(Thread.MIN_PRIORITY);      m_RunThread.start();    }  }    /**   * Stops the currently running Associator (if any).   */  protected void stopAssociator() {    if (m_RunThread != null) {      m_RunThread.interrupt();            // This is deprecated (and theoretically the interrupt should do).      m_RunThread.stop();          }  }  /**   * Save the currently selected associator output to a file.   */  protected void saveBuffer() {    StringBuffer sb = m_History.getSelectedBuffer();    if (sb != null) {      if (m_SaveOut.save(sb)) {	m_Log.logMessage("Save succesful.");      }    }  }      /**   * Tests out the Associator panel from the command line.   *   * @param args may optionally contain the name of a dataset to load.   */  public static void main(String [] args) {    try {      final javax.swing.JFrame jf =	new javax.swing.JFrame("Weka Knowledge Explorer: Associator");      jf.getContentPane().setLayout(new BorderLayout());      final AssociationsPanel sp = new AssociationsPanel();      jf.getContentPane().add(sp, BorderLayout.CENTER);      weka.gui.LogPanel lp = new weka.gui.LogPanel();      sp.setLog(lp);      jf.getContentPane().add(lp, BorderLayout.SOUTH);      jf.addWindowListener(new java.awt.event.WindowAdapter() {	public void windowClosing(java.awt.event.WindowEvent e) {	  jf.dispose();	  System.exit(0);	}      });      jf.pack();      jf.setVisible(true);      if (args.length == 1) {	System.err.println("Loading instances from " + args[0]);	java.io.Reader r = new java.io.BufferedReader(			   new java.io.FileReader(args[0]));	Instances i = new Instances(r);	sp.setInstances(i);      }    } catch (Exception ex) {      ex.printStackTrace();      System.err.println(ex.getMessage());    }  }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -