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

📄 attributeselectionpanel.java

📁 wekaUT是 university texas austin 开发的基于weka的半指导学习(semi supervised learning)的分类器
💻 JAVA
📖 第 1 页 / 共 2 页
字号:
    gbC.gridheight = 3;    gbC.weightx = 100; gbC.weighty = 100;    gbL.setConstraints(p3, gbC);    mondo.add(p3);    setLayout(new BorderLayout());    add(p_new, BorderLayout.NORTH);    add(mondo, BorderLayout.CENTER);  }    /**   * Updates the enabled status of the input fields and labels.   */  protected void updateRadioLinks() {    m_CVBut.setEnabled(true);    m_CVText.setEnabled(m_CVBut.isSelected());    m_CVLab.setEnabled(m_CVBut.isSelected());    m_SeedText.setEnabled(m_CVBut.isSelected());    m_SeedLab.setEnabled(m_CVBut.isSelected());        if (m_AttributeEvaluatorEditor.getValue() 	instanceof AttributeTransformer) {      m_CVBut.setSelected(false);      m_CVBut.setEnabled(false);      m_CVText.setEnabled(false);      m_CVLab.setEnabled(false);      m_SeedText.setEnabled(false);      m_SeedLab.setEnabled(false);      m_TrainBut.setSelected(true);    }  }    /**   * 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 = "(???) ";      }      String attnm = m_Instances.attribute(i).name();           attribNames[i] = type + attnm;    }    m_StartBut.setEnabled(m_RunThread == null);    m_StopBut.setEnabled(m_RunThread != null);    m_ClassCombo.setModel(new DefaultComboBoxModel(attribNames));    m_ClassCombo.setSelectedIndex(attribNames.length - 1);    m_ClassCombo.setEnabled(true);  }    /**   * Starts running the currently configured attribute evaluator and   * search method. This is run in a separate thread, and will only start if   * there is no attribute selection  already running. The attribute selection   * output is sent to the results history panel.   */  protected void startAttributeSelection() {    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);	  int testMode = 0;	  int numFolds = 10;	  int seed = 1;	  int classIndex = m_ClassCombo.getSelectedIndex();	  ASEvaluation evaluator = 	     (ASEvaluation) m_AttributeEvaluatorEditor.getValue();	  ASSearch search = (ASSearch) m_AttributeSearchEditor.getValue();	  StringBuffer outBuff = new StringBuffer();	  String name = (new SimpleDateFormat("HH:mm:ss - "))	  .format(new Date());	  String sname = search.getClass().getName();	  if (sname.startsWith("weka.attributeSelection.")) {	    name += sname.substring("weka.attributeSelection.".length());	  } else {	    name += sname;	  }	  String ename = evaluator.getClass().getName();	  if (ename.startsWith("weka.attributeSelection.")) {	    name += (" + "		     +ename.substring("weka.attributeSelection.".length()));	  } else {	    name += (" + "+ename);	  }	  try {	    if (m_CVBut.isSelected()) {	      testMode = 1;	      numFolds = Integer.parseInt(m_CVText.getText());	      seed = Integer.parseInt(m_SeedText.getText());	      if (numFolds <= 1) {		throw new Exception("Number of folds must be greater than 1");	      }	    } 	    inst.setClassIndex(classIndex);	    // Output some header information	    m_Log.logMessage("Started " + ename);	    if (m_Log instanceof TaskLogger) {	      ((TaskLogger)m_Log).taskStarted();	    }	    outBuff.append("=== Run information ===\n\n");	    outBuff.append("Evaluator:    " + ename);	    if (evaluator instanceof OptionHandler) {	      String [] o = ((OptionHandler) evaluator).getOptions();	      outBuff.append(" " + Utils.joinOptions(o));	    }	    outBuff.append("\nSearch:       " + sname);	    if (search instanceof OptionHandler) {	      String [] o = ((OptionHandler) search).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");	    }	    outBuff.append("Evaluation mode:    ");	    switch (testMode) {	      case 0: // select using all training	      outBuff.append("evaluate on all training data\n");	      break;	      case 1: // CV mode	      outBuff.append("" + numFolds + "-fold cross-validation\n");	      break;	    }	    outBuff.append("\n");	    m_History.addResult(name, outBuff);	    m_History.setSingle(name);	    	    // Do the feature selection and output the results.	    m_Log.statusMessage("Doing feature selection...");	    m_History.updateResult(name);	    	    AttributeSelection eval = new AttributeSelection();	    eval.setEvaluator(evaluator);	    eval.setSearch(search);	    eval.setFolds(numFolds);	    eval.setSeed(seed);	    if (testMode == 1) {	      eval.setXval(true);	    }	    	    	    switch (testMode) {	      case 0: // select using training	      m_Log.statusMessage("Evaluating on training data...");	      eval.SelectAttributes(inst);	      break;	      case 1: // CV mode	      m_Log.statusMessage("Randomizing instances...");	      inst.randomize(new Random(seed));	      if (inst.attribute(classIndex).isNominal()) {		m_Log.statusMessage("Stratifying instances...");		inst.stratify(numFolds);	      }	      for (int fold = 0; fold < numFolds;fold++) {		m_Log.statusMessage("Creating splits for fold "				    + (fold + 1) + "...");		Instances train = inst.trainCV(numFolds, fold);		m_Log.statusMessage("Selecting attributes using all but fold "				    + (fold + 1) + "...");				eval.selectAttributesCVSplit(train);	      }	      break;	      default:	      throw new Exception("Test mode not implemented");	    }	    if (testMode == 0) {	      outBuff.append(eval.toResultsString());	    } else {	      outBuff.append(eval.CVResultsString());	    }	  	    outBuff.append("\n");	    m_History.updateResult(name);	    m_Log.logMessage("Finished " + ename+" "+sname);	    m_Log.statusMessage("OK");	  } catch (Exception ex) {	    m_Log.logMessage(ex.getMessage());	    m_Log.statusMessage("See error log");	  } finally {	    if (evaluator instanceof AttributeTransformer) {	      m_CurrentVis = new VisualizePanel();	      try {		Instances transformed = 		  ((AttributeTransformer)evaluator).transformedData();		PlotData2D tempd = new PlotData2D(transformed);		tempd.setPlotName(name+" ("+transformed.relationName()+")");		tempd.addInstanceNumberAttribute();		m_CurrentVis.setLog(m_Log);		try {		  m_CurrentVis.addPlot(tempd);		  m_CurrentVis.setColourIndex(transformed.classIndex()+1);		} catch (Exception ex) {		  ex.printStackTrace();		}		m_CurrentVis.setName(name+" ("+transformed.relationName()+")");		FastVector vv = new FastVector();		vv.addElement(m_CurrentVis);		m_History.addObject(name, vv);	      } catch (Exception ex) {		System.err.println(ex);		ex.printStackTrace();	      }	    }	    if (isInterrupted()) {	      m_Log.logMessage("Interrupted " + ename+" "+sname);	      m_Log.statusMessage("See error log");	    }	    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 attribute selection (if any).   */  protected void stopAttributeSelection() {    if (m_RunThread != null) {      m_RunThread.interrupt();            // This is deprecated (and theoretically the interrupt should do).      m_RunThread.stop();          }  }    /**   * Save the named buffer to a file.   * @param name the name of the buffer to be saved.   */  protected void saveBuffer(String name) {    StringBuffer sb = m_History.getNamedBuffer(name);    if (sb != null) {      if (m_SaveOut.save(sb)) {	m_Log.logMessage("Save succesful.");      }    }  }  /**   * Popup a visualize panel for viewing transformed data   * @param sp the VisualizePanel to display   */  protected void visualizeTransformedData(VisualizePanel sp) {    if (sp != null) {      String plotName = sp.getName();      final javax.swing.JFrame jf = 	new javax.swing.JFrame("Weka Attribute Selection Visualize: "			       +plotName);      jf.setSize(500,400);      jf.getContentPane().setLayout(new BorderLayout());      jf.getContentPane().add(sp, BorderLayout.CENTER);      jf.addWindowListener(new java.awt.event.WindowAdapter() {	  public void windowClosing(java.awt.event.WindowEvent e) {	    jf.dispose();	  }	});      jf.setVisible(true);    }  }  /**   * Handles constructing a popup menu with visualization options   * @param name the name of the result history list entry clicked on by   * the user.   * @param x the x coordinate for popping up the menu   * @param y the y coordinate for popping up the menu   */  protected void visualize(String name, int x, int y) {    final String selectedName = name;    JPopupMenu resultListMenu = new JPopupMenu();    JMenuItem visMainBuffer = new JMenuItem("View in main window");    if (selectedName != null) {      visMainBuffer.addActionListener(new ActionListener() {	  public void actionPerformed(ActionEvent e) {	    m_History.setSingle(selectedName);	  }	});    } else {      visMainBuffer.setEnabled(false);    }    resultListMenu.add(visMainBuffer);    JMenuItem visSepBuffer = new JMenuItem("View in separate window");    if (selectedName != null) {    visSepBuffer.addActionListener(new ActionListener() {	public void actionPerformed(ActionEvent e) {	  m_History.openFrame(selectedName);	}      });    } else {      visSepBuffer.setEnabled(false);    }    resultListMenu.add(visSepBuffer);    JMenuItem saveOutput = new JMenuItem("Save result buffer");    if (selectedName != null) {    saveOutput.addActionListener(new ActionListener() {	public void actionPerformed(ActionEvent e) {	  saveBuffer(selectedName);	}      });    } else {      saveOutput.setEnabled(false);    }    resultListMenu.add(saveOutput);        resultListMenu.addSeparator();    FastVector o = null;    if (selectedName != null) {      o = (FastVector)m_History.getNamedObject(selectedName);    }        VisualizePanel temp_vp = null;         if (o != null) {      for (int i = 0; i < o.size(); i++) {	Object temp = o.elementAt(i);	if (temp instanceof VisualizePanel) {	  temp_vp = (VisualizePanel)temp;	}       }    }        final VisualizePanel vp = temp_vp;        JMenuItem visTrans = new JMenuItem("Visualize transformed data");    if (vp != null) {      visTrans.addActionListener(new ActionListener() {	  public void actionPerformed(ActionEvent e) {	    visualizeTransformedData(vp);	  }	});    } else {      visTrans.setEnabled(false);    }    resultListMenu.add(visTrans);        resultListMenu.show(m_History.getList(), x, y);  }  /**   * Tests out the attribute selection 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: Select attributes");      jf.getContentPane().setLayout(new BorderLayout());      final AttributeSelectionPanel sp = new AttributeSelectionPanel();      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 + -