edu.cmu.tetradapp.editor.DirichletBayesImProbsWizard Maven / Gradle / Ivy
The newest version!
///////////////////////////////////////////////////////////////////////////////
// For information as to what this class does, see the Javadoc, below. //
// Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, //
// 2007, 2008, 2009, 2010, 2014, 2015, 2022 by Peter Spirtes, Richard //
// Scheines, Joseph Ramsey, and Clark Glymour. //
// //
// 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA //
///////////////////////////////////////////////////////////////////////////////
package edu.cmu.tetradapp.editor;
import edu.cmu.tetrad.bayes.DirichletBayesIm;
import edu.cmu.tetrad.graph.Graph;
import edu.cmu.tetrad.graph.Node;
import edu.cmu.tetradapp.workbench.GraphWorkbench;
import javax.swing.*;
import javax.swing.border.MatteBorder;
import javax.swing.table.TableCellEditor;
import java.awt.*;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
/**
* Allows the user to choose a variable in a Bayes net and edit the parameters associated with that variable. Parameters
* are of the form P(Node=value1|Parent1=value2, Parent2=value2,...); values for these parameters are probabilities
* ranging from 0.0 to 1.0. For a given combination of parent values for node N, the probabilities for the values of N
* conditional on that combination of parent values must sum to 1.0
*
* @author josephramsey
*/
final class DirichletBayesImProbsWizard extends JPanel {
private static final long serialVersionUID = -1170540204903006651L;
private final DirichletBayesIm bayesIm;
private final JComboBox varNamesComboBox;
private final GraphWorkbench workbench;
private final JPanel tablePanel;
private DirichletBayesImNodeProbsTable editingTable;
private boolean enableEditing = true;
/**
* Constructor for DirichletBayesImProbsWizard.
*
* @param bayesIm a {@link edu.cmu.tetrad.bayes.DirichletBayesIm} object
* @param workbench a {@link edu.cmu.tetradapp.workbench.GraphWorkbench} object
*/
public DirichletBayesImProbsWizard(DirichletBayesIm bayesIm, GraphWorkbench workbench) {
if (bayesIm == null) {
throw new NullPointerException();
}
if (workbench == null) {
throw new NullPointerException();
}
workbench.setAllowDoubleClickActions(false);
setBorder(new MatteBorder(10, 10, 10, 10, getBackground()));
setLayout(new BoxLayout(this, BoxLayout.Y_AXIS));
setFont(new Font("SanSerif", Font.BOLD, 12));
// Set up components.
this.varNamesComboBox = createVarNamesComboBox(bayesIm);
workbench.scrollWorkbenchToNode((Node) this.varNamesComboBox.getSelectedItem());
JButton nextButton = new JButton("Next");
nextButton.setMnemonic('N');
Node node = (Node) (this.varNamesComboBox.getSelectedItem());
this.editingTable = new DirichletBayesImNodeProbsTable(node, bayesIm);
this.editingTable.addPropertyChangeListener((evt) -> {
if ("editorValueChanged".equals(evt.getPropertyName())) {
firePropertyChange("editorValueChanged", null, null);
}
});
JScrollPane scroll = new JScrollPane(this.editingTable);
scroll.setPreferredSize(new Dimension(0, 150));
this.tablePanel = new JPanel();
this.tablePanel.setLayout(new BorderLayout());
this.tablePanel.add(scroll, BorderLayout.CENTER);
this.editingTable.grabFocus();
// Do Layout.
Box b1 = Box.createHorizontalBox();
b1.add(new JLabel("Table of expected values of probabilities for "));
b1.add(this.varNamesComboBox);
b1.add(new JLabel(" conditional "));
b1.add(Box.createHorizontalGlue());
add(b1);
add(Box.createVerticalStrut(1));
Box b2 = Box.createHorizontalBox();
b2.add(new JLabel(
"on combinations of its parent values (with total pseudocount"));
b2.add(Box.createHorizontalGlue());
add(b2);
add(Box.createVerticalStrut(5));
Box b3 = Box.createHorizontalBox();
b3.add(new JLabel("in row shown):"));
b3.add(Box.createHorizontalGlue());
add(b3);
add(Box.createVerticalStrut(10));
Box b4 = Box.createHorizontalBox();
b4.add(this.tablePanel, BorderLayout.CENTER);
add(b4);
// Add listeners.
this.varNamesComboBox.addActionListener((e) -> {
Node n = (Node) this.varNamesComboBox.getSelectedItem();
getWorkbench().scrollWorkbenchToNode(n);
setCurrentNode(n);
});
nextButton.addActionListener((e) -> {
int current = this.varNamesComboBox.getSelectedIndex();
int max = this.varNamesComboBox.getItemCount();
++current;
if (current == max) {
JOptionPane.showMessageDialog(
this,
"There are no more variables.");
}
int set = (current < max) ? current : 0;
this.varNamesComboBox.setSelectedIndex(set);
});
workbench.addPropertyChangeListener((evt) -> {
if (evt.getPropertyName().equals("selectedNodes")) {
List selection = (List) (evt.getNewValue());
if (selection.size() == 1) {
this.varNamesComboBox.setSelectedItem(selection.get(0));
}
}
});
this.bayesIm = bayesIm;
this.workbench = workbench;
}
private JComboBox createVarNamesComboBox(DirichletBayesIm bayesIm) {
JComboBox varNameComboBox = new JComboBox<>();
varNameComboBox.setBackground(Color.white);
Graph graph = bayesIm.getBayesPm().getDag();
List nodes = new ArrayList<>(graph.getNodes());
Collections.sort(nodes);
nodes.forEach(varNameComboBox::addItem);
if (varNameComboBox.getItemCount() > 0) {
varNameComboBox.setSelectedIndex(0);
}
return varNameComboBox;
}
/**
* Sets the getModel display to reflect the stored values of the getModel node.
*/
private void setCurrentNode(Node node) {
TableCellEditor cellEditor = this.editingTable.getCellEditor();
if (cellEditor != null) {
cellEditor.cancelCellEditing();
}
this.editingTable = new DirichletBayesImNodeProbsTable(node, getBayesIm());
this.editingTable.addPropertyChangeListener((evt) -> {
if ("editorValueChanged".equals(evt.getPropertyName())) {
firePropertyChange("editorValueChanged", null, null);
}
});
JScrollPane scroll = new JScrollPane(this.editingTable);
scroll.setPreferredSize(new Dimension(0, 150));
this.tablePanel.removeAll();
this.tablePanel.add(scroll, BorderLayout.CENTER);
this.tablePanel.revalidate();
this.tablePanel.repaint();
this.editingTable.grabFocus();
}
private DirichletBayesIm getBayesIm() {
return this.bayesIm;
}
private GraphWorkbench getWorkbench() {
return this.workbench;
}
/**
* isEnableEditing.
*
* @return a boolean
*/
public boolean isEnableEditing() {
return this.enableEditing;
}
/**
* enableEditing.
*
* @param enableEditing a boolean
*/
public void enableEditing(boolean enableEditing) {
this.enableEditing = enableEditing;
if (this.workbench != null) {
this.workbench.setEnableEditing(enableEditing);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy