edu.cmu.tetradapp.editor.StandardizedSemImEditor Maven / Gradle / Ivy
///////////////////////////////////////////////////////////////////////////////
// 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.data.Knowledge;
import edu.cmu.tetrad.graph.Graph;
import edu.cmu.tetrad.graph.SemGraph;
import edu.cmu.tetrad.sem.StandardizedSemIm;
import edu.cmu.tetradapp.model.StandardizedSemImWrapper;
import edu.cmu.tetradapp.util.LayoutEditable;
import edu.cmu.tetradapp.workbench.LayoutMenu;
import javax.swing.*;
import javax.swing.border.TitledBorder;
import java.awt.*;
import java.util.ArrayList;
import java.util.Map;
/**
* Edits a standardized SEM model in which (a) all means are zero, (b) all variances are equal to 1, and (c) the error
* covariance matrix is always positive definite. Simulations produce standardized data.
*
* @author josephramsey
*/
public final class StandardizedSemImEditor extends JPanel implements LayoutEditable {
private static final long serialVersionUID = 23L;
/**
* The SemIm being edited.
*/
private final StandardizedSemIm semIm;
/**
* The menu item that lets the user either show or hide error terms.
*/
private final JMenuItem errorTerms;
/**
* The graphical editor for the SemIm.
*/
private StandardizedSemImGraphicalEditor standardizedSemImGraphicalEditor;
private StandardizedSemImImpliedMatricesPanel impliedMatricesPanel;
//========================CONSTRUCTORS===========================//
/**
* Constructs a new SemImEditor from the given OldSemEstimateAdapter.
*/
public StandardizedSemImEditor(StandardizedSemImWrapper wrapper) {
StandardizedSemIm semIm = wrapper.getStandardizedSemIm();
if (semIm == null) {
throw new NullPointerException("The SEM IM has not been specified.");
}
this.semIm = semIm;
setLayout(new BorderLayout());
JTabbedPane tabbedPane = new JTabbedPane();
tabbedPane.add("Graph", graphicalEditor());
tabbedPane.add("Implied Matrices", impliedMatricesPanel());
add(tabbedPane, BorderLayout.CENTER);
JMenuBar menuBar = new JMenuBar();
JMenu file = new JMenu("File");
menuBar.add(file);
file.add(new SaveComponentImage(this.standardizedSemImGraphicalEditor.getWorkbench(),
"Save Graph Image..."));
this.errorTerms = new JMenuItem();
// By default, hide the error terms.
// getSemGraph().setShowErrorTerms(false);
SemGraph graph = (SemGraph) graphicalEditor().getWorkbench().getGraph();
boolean shown = wrapper.isShowErrors();
graph.setShowErrorTerms(shown);
this.errorTerms.addActionListener(e -> {
JMenuItem menuItem = (JMenuItem) e.getSource();
if ("Hide Error Terms".equals(menuItem.getText())) {
menuItem.setText("Show Error Terms");
SemGraph graph1 = (SemGraph) graphicalEditor().getWorkbench().getGraph();
graph1.setShowErrorTerms(false);
wrapper.setShowErrors(false);
graphicalEditor().resetLabels();
} else if ("Show Error Terms".equals(menuItem.getText())) {
menuItem.setText("Hide Error Terms");
SemGraph graph1 = (SemGraph) graphicalEditor().getWorkbench().getGraph();
graph1.setShowErrorTerms(true);
wrapper.setShowErrors(true);
graphicalEditor().resetLabels();
}
});
menuBar.add(new LayoutMenu(this));
add(menuBar, BorderLayout.NORTH);
}
/**
* @return the graph currently in the workbench.
*/
public Graph getGraph() {
return this.standardizedSemImGraphicalEditor.getWorkbench().getGraph();
}
@Override
public Map getModelEdgesToDisplay() {
return this.standardizedSemImGraphicalEditor.getWorkbench().getModelEdgesToDisplay();
}
public Map getModelNodesToDisplay() {
return this.standardizedSemImGraphicalEditor.getWorkbench().getModelNodesToDisplay();
}
/**
* @return the knowledge currently stored in the workbench. Required for and interface.
*/
public Knowledge getKnowledge() {
return this.standardizedSemImGraphicalEditor.getWorkbench().getKnowledge();
}
/**
* @return the source graph currently stored in the workbench. Required for an interface.
*/
public Graph getSourceGraph() {
return this.standardizedSemImGraphicalEditor.getWorkbench().getSourceGraph();
}
/**
* Lays out the graph in the workbench.
*
* @param graph The graph whose layout is to be mimicked.
*/
public void layoutByGraph(Graph graph) {
SemGraph _graph = (SemGraph) this.standardizedSemImGraphicalEditor.getWorkbench().getGraph();
_graph.setShowErrorTerms(false);
this.standardizedSemImGraphicalEditor.getWorkbench().layoutByGraph(graph);
_graph.resetErrorPositions();
// standardizedSemImGraphicalEditor.getWorkbench().setGraph(_graph);
this.errorTerms.setText("Show Error Terms");
}
/**
* Lays the workbench graph out using knowledge tiers.
*/
public void layoutByKnowledge() {
SemGraph _graph = (SemGraph) this.standardizedSemImGraphicalEditor.getWorkbench().getGraph();
_graph.setShowErrorTerms(false);
this.standardizedSemImGraphicalEditor.getWorkbench().layoutByKnowledge();
_graph.resetErrorPositions();
this.standardizedSemImGraphicalEditor.getWorkbench().setGraph(_graph);
this.errorTerms.setText("Show Error Terms");
}
private StandardizedSemIm getSemIm() {
return this.semIm;
}
private StandardizedSemImGraphicalEditor graphicalEditor() {
if (this.standardizedSemImGraphicalEditor == null) {
this.standardizedSemImGraphicalEditor = new StandardizedSemImGraphicalEditor(getSemIm());
this.standardizedSemImGraphicalEditor.addPropertyChangeListener(
evt -> firePropertyChange(evt.getPropertyName(), null,
null));
this.standardizedSemImGraphicalEditor.enableEditing(false);
}
return this.standardizedSemImGraphicalEditor;
}
private StandardizedSemImImpliedMatricesPanel impliedMatricesPanel() {
if (this.impliedMatricesPanel == null) {
final int matrixSelection = 0;
this.impliedMatricesPanel
= new StandardizedSemImImpliedMatricesPanel(getSemIm(), matrixSelection);
}
return this.impliedMatricesPanel;
}
}
/**
* Dispays the implied covariance and correlation matrices for the given SemIm.
*/
class StandardizedSemImImpliedMatricesPanel extends JPanel {
private final StandardizedSemIm semIm;
private JTable impliedJTable;
private JComboBox selector;
public StandardizedSemImImpliedMatricesPanel(StandardizedSemIm semIm, int matrixSelection) {
this.semIm = semIm;
setLayout(new BoxLayout(this, BoxLayout.Y_AXIS));
add(selector());
add(Box.createVerticalStrut(10));
add(new JScrollPane(impliedJTable()));
add(Box.createVerticalGlue());
setBorder(new TitledBorder("Select Implied Matrix to View"));
setMatrixSelection(matrixSelection);
}
private static java.util.List getImpliedSelections() {
java.util.List list = new ArrayList<>();
list.add("Implied covariance matrix (all variables)");
list.add("Implied covariance matrix (measured variables only)");
list.add("Implied correlation matrix (all variables)");
list.add("Implied correlation matrix (measured variables only)");
return list;
}
private JTable impliedJTable() {
if (this.impliedJTable == null) {
this.impliedJTable = new JTable();
this.impliedJTable.setTableHeader(null);
}
return this.impliedJTable;
}
private JComboBox selector() {
if (this.selector == null) {
this.selector = new JComboBox();
java.util.List selections = StandardizedSemImImpliedMatricesPanel.getImpliedSelections();
for (Object selection : selections) {
this.selector.addItem(selection);
}
this.selector.addItemListener(e -> {
String item = (String) e.getItem();
setMatrixSelection(StandardizedSemImImpliedMatricesPanel.getImpliedSelections().indexOf(item));
});
}
return this.selector;
}
private void setMatrixSelection(int index) {
selector().setSelectedIndex(index);
switchView(index);
}
private void switchView(int index) {
if (index < 0 || index > 3) {
throw new IllegalArgumentException(
"Matrix selection must be 0, 1, 2, or 3.");
}
switch (index) {
case 0:
switchView(false, false);
break;
case 1:
switchView(true, false);
break;
case 2:
switchView(false, true);
break;
case 3:
switchView(true, true);
break;
}
}
private void switchView(boolean a, boolean b) {
try {
impliedJTable().setModel(new StandardizedSemImImpliedCovTable(getSemIm(), a, b));
// impliedJTable().getTableHeader().setReorderingAllowed(false);
impliedJTable().setAutoResizeMode(JTable.AUTO_RESIZE_OFF);
impliedJTable().setRowSelectionAllowed(false);
impliedJTable().setCellSelectionEnabled(false);
impliedJTable().doLayout();
} catch (IllegalArgumentException ignored) {
}
}
private StandardizedSemIm getSemIm() {
return this.semIm;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy