algorithms-for-computing-li.../LinearRegressionTool/src/main/java/de/wwwu/awolf/view/panels/EvaluationPanel.java

430 lines
14 KiB
Java
Raw Normal View History

2020-03-21 00:37:09 +00:00
package de.wwwu.awolf.view.panels;
2020-03-21 00:37:09 +00:00
import de.wwwu.awolf.model.Line;
import de.wwwu.awolf.presenter.Presenter;
import de.wwwu.awolf.view.MainFrame;
import de.wwwu.awolf.view.custom.ButtonGroupAtLeastTwo;
import de.wwwu.awolf.view.custom.ColorColumnRenderer;
import javax.swing.*;
import javax.swing.border.TitledBorder;
2017-09-08 19:23:02 +00:00
import javax.swing.filechooser.FileNameExtensionFilter;
import javax.swing.filechooser.FileSystemView;
2017-10-17 06:34:55 +00:00
import javax.swing.plaf.FontUIResource;
import javax.swing.table.DefaultTableCellRenderer;
import javax.swing.table.DefaultTableModel;
2017-09-08 19:23:02 +00:00
import javax.swing.table.JTableHeader;
import javax.swing.table.TableColumn;
import java.awt.*;
import java.io.File;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.LinkedList;
2020-03-21 00:37:09 +00:00
import java.util.List;
/**
2017-09-08 19:23:02 +00:00
* Created by
* Armin Wolf
* on 02.08.17.
*/
public class EvaluationPanel extends JPanel {
private final MainFrame view;
private JTable table;
2017-09-08 19:23:02 +00:00
private JTableHeader header;
private JButton start;
private JButton clearTable;
private JButton exportData;
2017-09-05 18:39:52 +00:00
private JRadioButton evalTypeOne; //1: Alg - N: Data
private JRadioButton evalTypeTwo; //N: Alg - 1: Data
private ButtonGroup radiobuttonGroup;
private ButtonGroup checkboxGroup;
private ButtonGroupAtLeastTwo checkboxAtLeastOne;
2017-09-05 18:39:52 +00:00
private JCheckBox lms; //1: Alg - N: Data
private JCheckBox rm; //N: Alg - 1: Data
private JCheckBox ts; //1: Alg - N: Data
private JPanel comp;
2017-09-05 18:39:52 +00:00
private JPanel algorithmPanel;
private JPanel leftSidePanel;
private JPanel datasetCount;
private JComboBox<Integer> datasetCountChoice;
2017-09-08 19:23:02 +00:00
private JComboBox<String> datasetType;
2017-09-05 18:39:52 +00:00
private JLabel datasetCountLabel;
private JSplitPane splitPane;
private DefaultTableModel model;
2017-09-08 19:23:02 +00:00
private int currentRowOfTypes;
private JPanel buttonPanel;
private PlotPanel plotPanel;
private String[] selections = {"Approximationsgüte", "Least Median of Squares", "Repeated-Median", "Theil-Sen"};
2017-10-17 06:34:55 +00:00
/**
* Konstruktor
2020-03-20 17:08:18 +00:00
*
2017-10-17 06:34:55 +00:00
* @param view View
*/
public EvaluationPanel(MainFrame view) {
super();
this.view = view;
this.setLayout(new BorderLayout());
2017-09-08 19:23:02 +00:00
this.currentRowOfTypes = 0;
2017-09-05 18:39:52 +00:00
init();
2017-09-08 19:23:02 +00:00
addListener();
addComponents();
2017-09-08 19:23:02 +00:00
}
2017-10-17 06:34:55 +00:00
/**
* Initialisiere die Komponenten
*/
private void init() {
datasetCountLabel = new JLabel("Größe des Datensatzes");
Integer[] choice = {50, 100, 200, 500, 1000, 1500};
2017-09-05 18:39:52 +00:00
datasetCountChoice = new JComboBox(choice);
String[] datatypes = {"Punktwolke", "Gerade", "Kreis und Gerade", "Import von CSV-Datei"};
2017-09-08 19:23:02 +00:00
datasetType = new JComboBox<>(datatypes);
start = new JButton("Start");
clearTable = new JButton("Löschen");
exportData = new JButton("Datenexport");
clearTable.setEnabled(false);
exportData.setEnabled(false);
2017-09-08 19:23:02 +00:00
evalTypeOne = new JRadioButton("Algorithmus evaluieren");
evalTypeTwo = new JRadioButton("Algorithmen vergleichen");
lms = new JCheckBox("Least Median of Squares");
rm = new JCheckBox("Repeated Median");
ts = new JCheckBox("Theil-Sen");
2017-09-05 18:39:52 +00:00
radiobuttonGroup = new ButtonGroup();
checkboxGroup = new ButtonGroup();
checkboxAtLeastOne = new ButtonGroupAtLeastTwo();
buttonPanel = new JPanel(new FlowLayout());
2017-09-05 18:39:52 +00:00
leftSidePanel = new JPanel(new BorderLayout());
comp = new JPanel(new GridLayout(0, 1));
plotPanel = new PlotPanel();
model = new DefaultTableModel() {
2017-09-05 18:39:52 +00:00
@Override
public boolean isCellEditable(int row, int column) {
//all cells false
return false;
}
};
table = new JTable(model);
2017-09-08 19:23:02 +00:00
UIManager.put("TableHeader.font", new Font("SansSerif", Font.BOLD, 14));
UIManager.put("TableHeader.foreground", Color.WHITE);
header = table.getTableHeader();
header.setBackground(Color.GRAY);
2017-09-05 18:39:52 +00:00
splitPane = new JSplitPane();
algorithmPanel = new JPanel(new FlowLayout(FlowLayout.LEFT));
datasetCount = new JPanel(new FlowLayout(FlowLayout.LEFT));
}
2017-10-17 06:34:55 +00:00
/**
* Hinzufügen der Komponenten zum ContentPane
*/
private void addComponents() {
2017-09-05 18:39:52 +00:00
evalTypeOne.setSelected(true);
2017-09-08 19:23:02 +00:00
lms.setSelected(true);
2017-09-05 18:39:52 +00:00
checkboxGroup.add(lms);
checkboxGroup.add(rm);
checkboxGroup.add(ts);
radiobuttonGroup.add(evalTypeOne);
radiobuttonGroup.add(evalTypeTwo);
2017-09-08 19:23:02 +00:00
buttonPanel.add(start);
buttonPanel.add(clearTable);
buttonPanel.add(exportData);
2017-09-05 18:39:52 +00:00
algorithmPanel.add(lms);
algorithmPanel.add(rm);
algorithmPanel.add(ts);
datasetCount.add(datasetCountLabel);
datasetCount.add(datasetCountChoice);
2017-09-08 19:23:02 +00:00
datasetCount.add(datasetType);
2017-09-05 18:39:52 +00:00
comp.add(evalTypeOne);
comp.add(evalTypeTwo);
comp.add(algorithmPanel);
comp.add(datasetCount);
2017-09-05 18:39:52 +00:00
comp.setBorder(new TitledBorder("Konfiguration"));
//Tabelle
model.setColumnIdentifiers(selections);
table.setDragEnabled(true);
JScrollPane scrollPane = new JScrollPane(table);
scrollPane.setWheelScrollingEnabled(true);
2017-09-05 18:39:52 +00:00
scrollPane.setBorder(new TitledBorder("Ergebnisse"));
//Plot
plotPanel.createPlot(new LinkedList<>());
plotPanel.setBorder(new TitledBorder("Plot"));
2017-09-05 18:39:52 +00:00
leftSidePanel.add(comp, BorderLayout.NORTH);
leftSidePanel.add(scrollPane, BorderLayout.CENTER);
//Splitpane
splitPane.setOrientation(JSplitPane.HORIZONTAL_SPLIT);
splitPane.setResizeWeight(.5d);
splitPane.setContinuousLayout(true);
splitPane.setLeftComponent(leftSidePanel);
splitPane.setRightComponent(plotPanel);
2017-09-05 18:39:52 +00:00
this.add(splitPane, BorderLayout.CENTER);
this.add(buttonPanel, BorderLayout.SOUTH);
2017-09-08 19:23:02 +00:00
TableColumn tm = table.getColumnModel().getColumn(0);
tm.setCellRenderer(new ColorColumnRenderer(Color.lightGray, Color.blue));
2020-03-20 17:08:18 +00:00
for (int i = 1; i < 4; i++) {
2017-10-17 06:34:55 +00:00
DefaultTableCellRenderer rightRenderer = new DefaultTableCellRenderer();
rightRenderer.setHorizontalAlignment(SwingConstants.RIGHT);
rightRenderer.setFont(new FontUIResource("Courier", Font.PLAIN, 12));
table.getColumnModel().getColumn(i).setCellRenderer(rightRenderer);
}
}
2017-10-17 06:34:55 +00:00
/**
* Hinzufügen der Listener
*/
private void addListener() {
2017-09-08 19:23:02 +00:00
start.addActionListener(e -> {
int type;
int alg;
int n;
if (radiobuttonGroup.isSelected(evalTypeOne.getModel())) {
2017-09-08 19:23:02 +00:00
type = 0;
} else {
type = 1;
}
alg = checkSelection();
n = (Integer) datasetCountChoice.getSelectedItem();
String datatyp = (String) datasetType.getSelectedItem();
2020-03-21 00:37:09 +00:00
if ("Import von CSV-Datei".equals(datatyp)) {
SwingUtilities.invokeLater(() -> {
File file = null;
JFileChooser chooser = new JFileChooser(FileSystemView.getFileSystemView().getHomeDirectory());
chooser.setPreferredSize(new Dimension(800, 700));
chooser.setFileFilter(new FileNameExtensionFilter("Comma-Separated Value, (*.csv)", "csv", "text"));
chooser.setMultiSelectionEnabled(false);
chooser.setFileSelectionMode(JFileChooser.FILES_ONLY);
if (chooser.showOpenDialog(this) == JFileChooser.APPROVE_OPTION) {
2020-03-21 00:37:09 +00:00
//Logging.logInfo ("Datei "+chooser.getSelectedFile()+ " ausgewählt.");
file = chooser.getSelectedFile();
final File input = file;
Thread t = new Thread(() -> ((Presenter) view.getPresenter()).startEvaluation(type, alg, input));
t.start();
}
});
} else {
((Presenter) view.getPresenter()).startEvaluation(type, n, alg, datatyp);
}
clearTable.setEnabled(true);
exportData.setEnabled(true);
2017-09-08 19:23:02 +00:00
});
evalTypeOne.addActionListener(e -> {
checkboxAtLeastOne.remove(lms);
checkboxAtLeastOne.remove(rm);
checkboxAtLeastOne.remove(ts);
lms.setSelected(true);
checkboxGroup.add(lms);
checkboxGroup.add(rm);
checkboxGroup.add(ts);
});
2017-09-05 18:39:52 +00:00
2017-09-08 19:23:02 +00:00
evalTypeTwo.addActionListener(e -> {
checkboxGroup.remove(lms);
checkboxGroup.remove(rm);
checkboxGroup.remove(ts);
checkboxAtLeastOne.addAll(lms, rm, ts);
2017-09-08 19:23:02 +00:00
lms.setSelected(true);
rm.setSelected(true);
});
clearTable.addActionListener(e -> {
SwingUtilities.invokeLater(() -> {
int n = model.getDataVector().size();
for (int i = 0; i < n; i++) {
model.removeRow(0);
currentRowOfTypes--;
}
this.revalidate();
clearTable.setEnabled(false);
exportData.setEnabled(false);
});
});
exportData.addActionListener(e -> {
SwingUtilities.invokeLater(() -> {
SwingUtilities.invokeLater(() -> {
File file = null;
JFileChooser chooser = new JFileChooser(FileSystemView.getFileSystemView().getHomeDirectory());
chooser.setPreferredSize(new Dimension(800, 700));
chooser.setFileFilter(new FileNameExtensionFilter("Comma-Separated Value, (*.csv)", "csv", "text"));
chooser.setMultiSelectionEnabled(false);
chooser.setFileSelectionMode(JFileChooser.FILES_ONLY);
if (chooser.showOpenDialog(this) == JFileChooser.APPROVE_OPTION) {
file = chooser.getSelectedFile();
String filename = file.getAbsolutePath().contains(".csv") ? file.getAbsolutePath() : file.getAbsolutePath().concat(".csv");
2020-03-21 00:37:09 +00:00
final File input = new File(filename);
2020-03-20 17:08:18 +00:00
Thread t = new Thread(() -> ((Presenter) view.getPresenter()).startDatasetExportEvaluation(input));
t.start();
}
});
});
});
2017-09-08 19:23:02 +00:00
}
2017-10-17 06:34:55 +00:00
/**
* Fügt der Tabelle eine Spalte hinzu
*
2020-03-20 17:08:18 +00:00
* @param data Daten der Spalte
* @param col Spalte
* @param isLabel <code>true</code>, falls es sich um die Approximations Überschriften handelt
2017-10-17 06:34:55 +00:00
*/
public void addColumn(Object[] data, int col, boolean isLabel) {
if (isLabel) {
2017-09-08 19:23:02 +00:00
addBlankRows(data.length);
}
for (int i = 0; i < data.length; i++) {
2017-09-08 19:23:02 +00:00
int row = currentRowOfTypes - data.length + i;
model.setValueAt(data[i], row, col);
2017-09-08 19:23:02 +00:00
}
this.repaint();
this.revalidate();
}
2017-09-05 18:39:52 +00:00
2017-10-17 06:34:55 +00:00
/**
* Fügt der Tabelle eine Zeile hinzu
2020-03-20 17:08:18 +00:00
*
2017-10-17 06:34:55 +00:00
* @param data Daten der Zeile
*/
public void addRow(Object[] data) {
2017-09-08 19:23:02 +00:00
addBlankRows(1);
for (int i = 0; i < 4; i++) {
model.setValueAt(data[i], currentRowOfTypes, i);
2017-09-08 19:23:02 +00:00
}
currentRowOfTypes++;
this.repaint();
this.revalidate();
}
2017-10-17 06:34:55 +00:00
/**
* Visualisierung der Ausgleichsgeraden
2020-03-20 17:08:18 +00:00
*
2017-10-17 06:34:55 +00:00
* @param alg Steigung und y-Achsenabschnitt der Geraden, bestimmt durch die Schätzer
*/
2020-03-21 00:37:09 +00:00
public void drawLines(List<Double[]> alg) {
2017-09-08 19:23:02 +00:00
Paint[] color = {Color.ORANGE, Color.RED, Color.MAGENTA};
String[] name = {"LMS", "RM", "TS"};
2017-09-08 19:23:02 +00:00
for (Double[] o : alg) {
int i = o[0].intValue();
Double m = o[1];
Double b = o[2];
plotPanel.addLineToPlot(m, b, color[i], name[i]);
2017-09-05 18:39:52 +00:00
}
}
2017-10-17 06:34:55 +00:00
/**
* Visualisierung der Ausgleichsgerade
2020-03-20 17:08:18 +00:00
*
* @param results Steigung und y-Achsenabschnitt der Gerade, bestimmt durch die Schätzer
* @param alg identifizierung des Alg.
2017-10-17 06:34:55 +00:00
*/
public void drawLines(Object[] results, int alg) {
String[] castedResults = Arrays.copyOf(results, results.length, String[].class);
2017-09-08 19:23:02 +00:00
Paint[] color = {Color.ORANGE, Color.RED, Color.MAGENTA};
String[] name = {"LMS", "RM", "TS"};
String[] nName = {"Brute-force LMS", "Brute-force RM", "Brute-force TS"};
2017-09-08 19:23:02 +00:00
2020-03-21 00:37:09 +00:00
double m = Double.parseDouble(castedResults[0]);
double b = Double.parseDouble(castedResults[1]);
plotPanel.addLineToPlot(m, b, color[alg], name[alg]);
2020-03-21 00:37:09 +00:00
double nM = Double.parseDouble(castedResults[2]);
double nB = Double.parseDouble(castedResults[3]);
plotPanel.addLineToPlot(nM, nB, Color.BLACK, nName[alg]);
2017-09-08 19:23:02 +00:00
}
2017-10-17 06:34:55 +00:00
/**
* Visualisierung der dualen Geraden (Eingabemenge)
2020-03-20 17:08:18 +00:00
*
2017-10-17 06:34:55 +00:00
* @param points Liste der Geraden
*/
2020-03-21 00:37:09 +00:00
public void setDualPoints(List<Line> points) {
plotPanel = new PlotPanel();
plotPanel.setBorder(new TitledBorder("Plot"));
splitPane.setRightComponent(plotPanel);
plotPanel.createPlot(points);
plotPanel.repaint();
plotPanel.revalidate();
2017-09-05 18:39:52 +00:00
}
2017-09-08 19:23:02 +00:00
2017-10-17 06:34:55 +00:00
/**
* Hilfsmethode
2020-03-20 17:08:18 +00:00
*
2017-10-17 06:34:55 +00:00
* @param n Anzahl der leeren Zeilen
*/
private void addBlankRows(int n) {
for (int i = 0; i < n; i++) {
String[] tmp = {"", "", "", "",};
2017-09-08 19:23:02 +00:00
model.addRow(tmp);
}
}
2017-10-17 06:34:55 +00:00
/**
* Hilfsmethode
2020-03-20 17:08:18 +00:00
*
2017-10-17 06:34:55 +00:00
* @param val Anzahl der Zeilen die noch hinzugefügt werden
*/
public void setCurrentRow(int val) {
2017-09-08 19:23:02 +00:00
this.currentRowOfTypes += val;
}
2017-10-17 06:34:55 +00:00
/**
* @return Kodierung welche Algorithmen ausgewählt wurden
*/
private int checkSelection() {
if (lms.isSelected() && rm.isSelected() && ts.isSelected()) {
2017-09-08 19:23:02 +00:00
return 6;
} else if (!lms.isSelected() && rm.isSelected() && ts.isSelected()) {
2017-09-08 19:23:02 +00:00
return 5;
} else if (lms.isSelected() && !rm.isSelected() && ts.isSelected()) {
2017-09-08 19:23:02 +00:00
return 4;
} else if (lms.isSelected() && rm.isSelected() && !ts.isSelected()) {
2017-09-08 19:23:02 +00:00
return 3;
} else if (!lms.isSelected() && !rm.isSelected() && ts.isSelected()) {
2017-09-08 19:23:02 +00:00
return 2;
} else if (!lms.isSelected() && rm.isSelected() && !ts.isSelected()) {
2017-09-08 19:23:02 +00:00
return 1;
} else if (lms.isSelected() && !rm.isSelected() && !ts.isSelected()) {
2017-09-08 19:23:02 +00:00
return 0;
} else {
throw new IllegalStateException("Mindestens ein Algortihmus muss selektiert werden");
}
}
}