org.omscentral.modules.analysis.esp.ESPToolPanel Maven / Gradle / Ivy
/*
* $Id: ESPToolPanel.java 7cba5ba59d73 2018-11-29 [email protected] $
*
* This file is part of the Object Modeling System (OMS),
* 2007-2012, Olaf David and others, Colorado State University.
*
* OMS is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, version 2.1.
*
* OMS 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 Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with OMS. If not, see .
*/
package org.omscentral.modules.analysis.esp;
import java.io.*;
import java.util.*;
import javax.swing.*;
/**
*
* @author od
*/
public class ESPToolPanel extends JPanel {
private static final long serialVersionUID = 389026251362838555L;
//
static double CFS2ACFT = 86400.0 / 43560.0;
private ModelDateTime analysisStart = new ModelDateTime();
private ModelDateTime analysisEnd = new ModelDateTime();
private EnsembleData ensembleData;
private TimeSeriesPlotter plotter;
private DefaultListModel listModel = new DefaultListModel();
private String result;
String[] obs;
/**
* Creates new form ESPPanel
*
* @param ed the ensemble data object
* @param obs the observed data set
*/
public ESPToolPanel(EnsembleData ed, String[] obs) {
this.ensembleData = ed;
this.obs = obs;
initComponents();
traceListList.setModel(listModel);
// Add the plotter
plotter = new TimeSeriesPlotter(ed.getName(), "Date", "Flow");
rightPanel.add(plotter.getPanel());
// Plot the data for the init period
plotData(ed.getInitialization());
// Forecast period id the default analysis period.
ArrayList forecasts = ed.getForecasts();
TimeSeriesCookie forecastTS = (TimeSeriesCookie) (forecasts.get(0));
analysisStart = (ModelDateTime) forecastTS.getStart().clone();
analysisEnd = (ModelDateTime) forecastTS.getEnd().clone();
setDefaultDates();
ed.setAnalysisPeriod(analysisStart, analysisEnd);
loadList();
}
public void plotData(TimeSeriesCookie tsc) {
plotter.addTrace(tsc);
}
public void plotData(TimeSeriesCookie[] tscs) {
for (int i = 0; i < tscs.length; i++) {
plotData(tscs[i]);
}
}
private void setDefaultDates() {
ModelDateTime initStart = ensembleData.getInitializationStart();
ModelDateTime initEnd = ensembleData.getInitializationEnd();
ModelDateTime forecastStart = ensembleData.getForecastStart();
ModelDateTime forecastEnd = ensembleData.getForecastEnd();
initStartLabel.setText(initStart.getJDBCDate().toString());
initEndLabel.setText(initEnd.getJDBCDate().toString());
ensembleStartLabel.setText(forecastStart.getJDBCDate().toString());
ensembleEndLabel.setText(forecastEnd.getJDBCDate().toString());
analysisStartSpinner.setModel(new SpinnerDateModel(analysisStart.getTime(),
initStart.getTime(), forecastEnd.getTime(), Calendar.DAY_OF_MONTH));
analysisStartSpinner.setEditor(new JSpinner.DateEditor(analysisStartSpinner, "yyyy-MM-dd"));
analysisEndSpinner.setModel(new SpinnerDateModel(analysisEnd.getTime(),
initStart.getTime(), forecastEnd.getTime(), Calendar.DAY_OF_MONTH));
analysisEndSpinner.setEditor(new JSpinner.DateEditor(analysisEndSpinner, "yyyy-MM-dd"));
}
private void loadList() {
listModel.clear();
ArrayList order;
if (ensembleData.getSortOrder() == EnsembleData.VOLUME) {
order = ensembleData.getStatsInVolumeOrder();
} else if (ensembleData.getSortOrder() == EnsembleData.PEAK) {
order = ensembleData.getStatsInPeakOrder();
} else {
order = ensembleData.getStats();
}
for (int i = 0; i < order.size(); i++) {
EnsembleListLabel tsi = (EnsembleListLabel) (order.get(i));
listModel.addElement(tsi);
}
}
public void setResult(String resultFile) {
result = resultFile;
}
public String getResult() {
return result;
}
public EnsembleData getEnsembleData() {
return this.ensembleData;
}
public void setEnsembleData(EnsembleData ensembleData) {
this.ensembleData = ensembleData;
setDefaultDates();
}
public JList getTraceListList() {
return this.traceListList;
}
public void setTraceListList(JList traceListList) {
this.traceListList = traceListList;
}
public ModelDateTime getAnalysisStart() {
return this.analysisStart;
}
public void setAnalysisStart(ModelDateTime analysisStart) {
this.analysisStart = analysisStart;
analysisStartSpinner.setValue(analysisStart.getJDBCDate().toString());
}
public ModelDateTime getAnalysisEnd() {
return this.analysisEnd;
}
public void setAnalysisEnd(ModelDateTime analysisEnd) {
this.analysisEnd = analysisEnd;
analysisEndSpinner.setValue(analysisEnd.getJDBCDate().toString());
}
static void writeReport(ESPToolPanel top, Writer out) {
Format f1 = new Format("%11.1f");
Format f2 = new Format("%3i");
Format f3 = new Format("%8.1f");
Format f4 = new Format("%4.1f");
EnsembleData ed = top.getEnsembleData();
ArrayList stats = ed.getStats();
ModelDateTime mdt = new ModelDateTime();
try {
out.write("Report for '" + ed.getName() + "'\n");
out.write(" Analysis Period: " + top.getAnalysisStart() + " to " + top.getAnalysisEnd() + "\n");
out.write(" Initialization Period: " + ed.getInitializationStart() + " to " + ed.getInitializationEnd() + "\n");
out.write(" Forecast Period: " + ed.getForecastStart() + " to " + ed.getForecastEnd() + "\n\n\n");
/*
** Write the report for all traces.
*/
out.write(" Summary of All Traces for Analysis Period\n\n");
out.write("Historic Volume Volume Volume Volume Peak Peak Peak\n");
out.write(" Year (cfs-days) (acre-ft) Rank Exceedance (cfs) Rank Exceedance Date of Peak\n");
out.write("-------- ---------- --------- ------ ---------- ---- ---- ---------- ------------\n");
for (EnsembleListLabel ell : stats) {
mdt.setJul2Greg(ell.getTimeToPeak());
out.write(" " + ell.getTraceYear() + " "
+ f1.form(ell.getTraceVolume()) + ""
+ f1.form(ell.getTraceVolume() * CFS2ACFT) + " "
+ f2.form(ell.getVolumeRank()) + " "
+ f4.form(ell.getActVolumeProb()) + " "
+ f3.form(ell.getTracePeak()) + " "
+ f2.form(ell.getPeakRank()) + " "
+ f4.form(ell.getActPeakProb()) + " "
+ mdt + "\n");
}
/*
* Write the report for selected traces.
*/
Object[] sel = top.getTraceListList().getSelectedValues();
ArrayList selStatsInVolumeOrder = new ArrayList(sel.length);
ArrayList selStatsInPeakOrder = new ArrayList(sel.length);
ArrayList selYearOrder = new ArrayList(sel.length);
/*
* Make copies
*/
for (int i = 0; i < sel.length; i++) {
EnsembleListLabel tsi = new EnsembleListLabel((EnsembleListLabel) (sel[i]));
selStatsInVolumeOrder.add(i, tsi);
selStatsInPeakOrder.add(i, tsi);
selYearOrder.add(i, tsi);
}
EnsembleData.sort(selStatsInVolumeOrder, selStatsInPeakOrder);
ArrayList order;
if (sel.length > 0) {
if (ed.getSortOrder() == EnsembleData.VOLUME) {
order = selStatsInVolumeOrder;
out.write("\n\n\n Summary of Selected Traces for Analysis Period (by Volume)\n\n");
} else if (ed.getSortOrder() == EnsembleData.PEAK) {
order = selStatsInPeakOrder;
out.write("\n\n\n Summary of Selected Traces for Analysis Period (by Peak)\n\n");
} else {
order = selYearOrder;
out.write("\n\n\n Summary of Selected Traces for Analysis Period (by Year)\n\n");
}
out.write("Historic Volume Volume Volume Volume Peak Peak Peak\n");
out.write(" Year (cfs-days) (acre-ft) Rank Exceedance (cfs) Rank Exceedance Date of Peak\n");
out.write("-------- ---------- --------- ------ ---------- ---- ---- ---------- ------------\n");
/*
** Sort peak (if report by volume) or volume (if report by
* peak) of * the selected traces.
*/
Iterator it = order.iterator();
while (it.hasNext()) {
EnsembleListLabel ell = (EnsembleListLabel) (it.next());
mdt.setJul2Greg(ell.getTimeToPeak());
out.write(" " + ell.getTraceYear() + " "
+ f1.form(ell.getTraceVolume()) + ""
+ f1.form(ell.getTraceVolume() * CFS2ACFT) + " "
+ f2.form(ell.getVolumeRank()) + " "
+ f4.form(ell.getActVolumeProb()) + " "
+ f3.form(ell.getTracePeak()) + " "
+ f2.form(ell.getPeakRank()) + " "
+ f4.form(ell.getActPeakProb()) + " "
+ mdt + "\n");
}
}
out.flush();
} catch (IOException e) {
e.printStackTrace();
}
}
public void writeReport(String report) throws IOException {
System.out.println("Writing report '" + report + "'");
FileWriter w = new FileWriter(report);
EspUtils.writeReport(w, ensembleData, obs, new File(getResult()));
w.close();
}
/**
* This method is called from within the constructor to initialize the form.
* WARNING: Do NOT modify this code. The content of this method is always
* regenerated by the Form Editor.
*/
@SuppressWarnings("unchecked")
// //GEN-BEGIN:initComponents
private void initComponents() {
buttonGroup1 = new javax.swing.ButtonGroup();
rightPanel = new javax.swing.JPanel();
reportButton = new javax.swing.JButton();
jLabel2 = new javax.swing.JLabel();
selectYearsCombo = new javax.swing.JComboBox();
jLabel3 = new javax.swing.JLabel();
jRadioButton1 = new javax.swing.JRadioButton();
jRadioButton2 = new javax.swing.JRadioButton();
jRadioButton3 = new javax.swing.JRadioButton();
jScrollPane1 = new javax.swing.JScrollPane();
traceListList = new javax.swing.JList();
jLabel4 = new javax.swing.JLabel();
initStartLabel = new javax.swing.JLabel();
initEndLabel = new javax.swing.JLabel();
jLabel7 = new javax.swing.JLabel();
ensembleStartLabel = new javax.swing.JLabel();
ensembleEndLabel = new javax.swing.JLabel();
jLabel11 = new javax.swing.JLabel();
analysisStartSpinner = new javax.swing.JSpinner();
analysisEndSpinner = new javax.swing.JSpinner();
exportButton = new javax.swing.JButton();
rightPanel.setBorder(javax.swing.BorderFactory.createEtchedBorder());
rightPanel.setLayout(new java.awt.BorderLayout());
reportButton.setText("Save Statistics");
reportButton.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
reportButtonActionPerformed(evt);
}
});
jLabel2.setText("Traces: ");
selectYearsCombo.setModel(new javax.swing.DefaultComboBoxModel(new String[] { "La Nina", "El Nino ", "ENSO Neutral", "PDO < -0.5", "PDO > 0.5", "PDO Neutral" }));
selectYearsCombo.addItemListener(new java.awt.event.ItemListener() {
public void itemStateChanged(java.awt.event.ItemEvent evt) {
selectYearsComboItemStateChanged(evt);
}
});
jLabel3.setText("Sort by:");
buttonGroup1.add(jRadioButton1);
jRadioButton1.setSelected(true);
jRadioButton1.setText("Volume");
jRadioButton1.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
jRadioButton1ActionPerformed(evt);
}
});
buttonGroup1.add(jRadioButton2);
jRadioButton2.setText("Peak");
jRadioButton2.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
jRadioButton2ActionPerformed(evt);
}
});
buttonGroup1.add(jRadioButton3);
jRadioButton3.setText("Year");
jRadioButton3.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
jRadioButton3ActionPerformed(evt);
}
});
traceListList.addListSelectionListener(new javax.swing.event.ListSelectionListener() {
public void valueChanged(javax.swing.event.ListSelectionEvent evt) {
traceListListValueChanged(evt);
}
});
jScrollPane1.setViewportView(traceListList);
jLabel4.setText("Init:");
initStartLabel.setText("jLabel5");
initEndLabel.setText("jLabel6");
jLabel7.setText("Forecast:");
ensembleStartLabel.setText("jLabel8");
ensembleEndLabel.setText("jLabel9");
jLabel11.setText("Analysis");
exportButton.setText("Save Data and Results ");
exportButton.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
exportButtonActionPerformed(evt);
}
});
javax.swing.GroupLayout layout = new javax.swing.GroupLayout(this);
this.setLayout(layout);
layout.setHorizontalGroup(
layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addGroup(layout.createSequentialGroup()
.addContainerGap()
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addGroup(layout.createSequentialGroup()
.addComponent(jLabel11)
.addGap(18, 18, 18)
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addComponent(analysisStartSpinner, javax.swing.GroupLayout.PREFERRED_SIZE, 140, javax.swing.GroupLayout.PREFERRED_SIZE)
.addComponent(analysisEndSpinner, javax.swing.GroupLayout.PREFERRED_SIZE, 140, javax.swing.GroupLayout.PREFERRED_SIZE)))
.addComponent(jScrollPane1, javax.swing.GroupLayout.PREFERRED_SIZE, 205, javax.swing.GroupLayout.PREFERRED_SIZE)
.addGroup(layout.createSequentialGroup()
.addComponent(jRadioButton1)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.UNRELATED)
.addComponent(jRadioButton2)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.UNRELATED)
.addComponent(jRadioButton3))
.addComponent(jLabel3)
.addGroup(layout.createSequentialGroup()
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addComponent(jLabel4, javax.swing.GroupLayout.PREFERRED_SIZE, 58, javax.swing.GroupLayout.PREFERRED_SIZE)
.addComponent(jLabel7))
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.TRAILING, false)
.addComponent(ensembleEndLabel, javax.swing.GroupLayout.Alignment.LEADING, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
.addComponent(ensembleStartLabel, javax.swing.GroupLayout.Alignment.LEADING, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
.addComponent(initEndLabel, javax.swing.GroupLayout.Alignment.LEADING, javax.swing.GroupLayout.DEFAULT_SIZE, 92, Short.MAX_VALUE)
.addComponent(initStartLabel, javax.swing.GroupLayout.Alignment.LEADING, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)))
.addGroup(layout.createSequentialGroup()
.addComponent(jLabel2)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addComponent(selectYearsCombo, javax.swing.GroupLayout.PREFERRED_SIZE, 141, javax.swing.GroupLayout.PREFERRED_SIZE)))
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addGroup(layout.createSequentialGroup()
.addComponent(reportButton)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addComponent(exportButton)
.addGap(0, 116, Short.MAX_VALUE))
.addComponent(rightPanel, javax.swing.GroupLayout.Alignment.TRAILING, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
.addContainerGap())
);
layout.setVerticalGroup(
layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addGroup(layout.createSequentialGroup()
.addContainerGap()
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addGroup(layout.createSequentialGroup()
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
.addComponent(jLabel2)
.addComponent(selectYearsCombo, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
.addGap(12, 12, 12)
.addComponent(jLabel3)
.addGap(3, 3, 3)
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
.addComponent(jRadioButton1)
.addComponent(jRadioButton2)
.addComponent(jRadioButton3))
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addComponent(jScrollPane1)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.UNRELATED)
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
.addComponent(jLabel4)
.addComponent(initStartLabel))
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addComponent(initEndLabel)
.addGap(9, 9, 9)
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.TRAILING)
.addComponent(jLabel7)
.addComponent(ensembleStartLabel))
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addComponent(ensembleEndLabel)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addComponent(jLabel11)
.addComponent(analysisStartSpinner, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)))
.addComponent(rightPanel, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
.addComponent(analysisEndSpinner, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
.addComponent(reportButton)
.addComponent(exportButton))
.addContainerGap())
);
}// //GEN-END:initComponents
private void reportButtonActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_reportButtonActionPerformed
// Writer w = new PrintWriter(System.out);
// writeReport(this, w);
JFileChooser fc = new JFileChooser(getResult());
fc.setDialogTitle("Save ESP Statistics Report");
fc.setSelectedFile(new File("esp-report.txt"));
int r = fc.showSaveDialog(this);
if (r == JFileChooser.APPROVE_OPTION) {
FileWriter w = null;
try {
w = new FileWriter(fc.getSelectedFile());
writeReport(this, w);
} catch (IOException ex) {
ex.printStackTrace(System.err);
} finally {
try {
w.close();
} catch (IOException ex) {
}
}
}
}//GEN-LAST:event_reportButtonActionPerformed
private void selectYearsComboItemStateChanged(java.awt.event.ItemEvent evt) {//GEN-FIRST:event_selectYearsComboItemStateChanged
int sel = selectYearsCombo.getSelectedIndex();
int flag = ElNino.UNKNOWN;
switch (sel) {
case 0:
flag = ElNino.LA_NINA;
break;
case 1:
flag = ElNino.EL_NINO;
break;
case 2:
flag = ElNino.NEUTRAL;
break;
case 3:
flag = ElNino.NEG_PDO;
break;
case 4:
flag = ElNino.POS_PDO;
break;
case 5:
flag = ElNino.NEU_PDO;
break;
default:
throw new IllegalArgumentException("combo");
}
selectListItems(flag);
/*
** Definition of categories: * LA_NINA - Water Year NINO3.4 SSTs <
* -0.5 C * EL_NINO - Water Year NINO3.4 SSTs > 0.5 C * NEUTRAL - Water
* Year NINO3.4 SSTs < 0.5 and > -0.5 C * NEG_PDO - PDO < -0.5 * POS_PDO
* - PDO > 0.5 * NEU_PDO - PDO Neutral
*/
}//GEN-LAST:event_selectYearsComboItemStateChanged
private void jRadioButton1ActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_jRadioButton1ActionPerformed
ensembleData.setSortOrder(EnsembleData.VOLUME);
loadList();
}//GEN-LAST:event_jRadioButton1ActionPerformed
private void jRadioButton2ActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_jRadioButton2ActionPerformed
ensembleData.setSortOrder(EnsembleData.PEAK);
loadList();
}//GEN-LAST:event_jRadioButton2ActionPerformed
private void jRadioButton3ActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_jRadioButton3ActionPerformed
ensembleData.setSortOrder(EnsembleData.YEAR);
loadList();
}//GEN-LAST:event_jRadioButton3ActionPerformed
private void traceListListValueChanged(javax.swing.event.ListSelectionEvent evt) {//GEN-FIRST:event_traceListListValueChanged
if (!evt.getValueIsAdjusting()) {
/*
* Clear the ensemble traces in the plot
*/
Iterator it = ensembleData.getStats().iterator();
while (it.hasNext()) {
EnsembleListLabel ell = (EnsembleListLabel) (it.next());
plotter.clearTrace(ell.getTraceName());
}
if (traceListList.getSelectedIndex() != -1) {
Object[] sel = traceListList.getSelectedValues();
for (int i = 0; i < sel.length; i++) {
EnsembleListLabel ell = (EnsembleListLabel) (sel[i]);
plotData(ell.getForecast());
}
}
}
}//GEN-LAST:event_traceListListValueChanged
private void exportButtonActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_exportButtonActionPerformed
// StringWriter w = new StringWriter();
// writeReport0(w);
JFileChooser fc = new JFileChooser(getResult());
fc.setDialogTitle("Save ESP Data, Traces, and Results");
fc.setSelectedFile(new File("esp-results.csv"));
int r = fc.showSaveDialog(this);
if (r == JFileChooser.APPROVE_OPTION) {
FileWriter w = null;
try {
w = new FileWriter(fc.getSelectedFile());
EspUtils.writeReport(w, ensembleData, obs, new File(getResult()));
} catch (IOException ex) {
ex.printStackTrace(System.err);
} finally {
try {
w.close();
} catch (IOException ex) {
}
}
}
}//GEN-LAST:event_exportButtonActionPerformed
public void selectListItems(int enso_code) {
int count = 0;
for (int j = 0; j < listModel.getSize(); j++) {
EnsembleListLabel label = (EnsembleListLabel) (listModel.getElementAt(j));
if (ElNino.lookUp(enso_code, label)) {
count++;
}
}
int[] sel = new int[count];
count = 0;
for (int j = 0; j < listModel.getSize(); j++) {
EnsembleListLabel label = (EnsembleListLabel) (listModel.getElementAt(j));
if (ElNino.lookUp(enso_code, label)) {
sel[count++] = j;
}
}
traceListList.setSelectedIndices(sel);
}
// Variables declaration - do not modify//GEN-BEGIN:variables
private javax.swing.JSpinner analysisEndSpinner;
private javax.swing.JSpinner analysisStartSpinner;
private javax.swing.ButtonGroup buttonGroup1;
private javax.swing.JLabel ensembleEndLabel;
private javax.swing.JLabel ensembleStartLabel;
private javax.swing.JButton exportButton;
private javax.swing.JLabel initEndLabel;
private javax.swing.JLabel initStartLabel;
private javax.swing.JLabel jLabel11;
private javax.swing.JLabel jLabel2;
private javax.swing.JLabel jLabel3;
private javax.swing.JLabel jLabel4;
private javax.swing.JLabel jLabel7;
private javax.swing.JRadioButton jRadioButton1;
private javax.swing.JRadioButton jRadioButton2;
private javax.swing.JRadioButton jRadioButton3;
private javax.swing.JScrollPane jScrollPane1;
private javax.swing.JButton reportButton;
private javax.swing.JPanel rightPanel;
private javax.swing.JComboBox selectYearsCombo;
private javax.swing.JList traceListList;
// End of variables declaration//GEN-END:variables
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy