diff --git a/config/config.properties b/config/config.properties
index 34c41ff..f1fca51 100644
--- a/config/config.properties
+++ b/config/config.properties
@@ -1,34 +1,34 @@
-#Thu Jan 16 14:47:12 CET 2020
-autoSaveScanData=true
-simulation=false
-commandExecutionEvents=false
-logDaysToLive=30
-userAuthenticator=ch.psi.pshell.security.LdapAuthenticator | ldap\\\\\\\://d.psi.ch | d.psi.ch | users.psi
-logLevelConsole=Off
-scanStreamerPort=-1
-parallelInitialization=false
-versionTrackingManual=true
-hostName=null
-userManagement=false
-instanceName=NanoXAS
-dataServerPort=-1
-hideServerMessages=false
-serverPort=8080
-versionTrackingEnabled=true
-dataPath={data}/{year}_{month}/{date}/{date}_{time}_{name}
-serverEnabled=false
-depthDimension=0
-dataScanReleaseRecords=false
-dataScanPreserveTypes=true
-logLevel=Fine
-dataScanFlushRecords=false
-logPath={logs}/{date}_{time}
-dataLayout=fda
-terminalEnabled=false
-notificationLevel=Off
-terminalPort=3579
-createSessionFiles=false
-versionTrackingLogin={context}/svcusr-hlapp_robot
-versionTrackingRemote=git@git.psi.ch\:pshell_config/x07db.git
-dataProvider=fda
-saveCommandStatistics=false
+#Fri Jan 17 13:58:28 CET 2020
+autoSaveScanData=true
+commandExecutionEvents=false
+createSessionFiles=false
+dataLayout=fda
+dataPath={data}/{year}_{month}/{date}/{date}_{time}_{name}
+dataProvider=fda
+dataScanFlushRecords=false
+dataScanPreserveTypes=true
+dataScanReleaseRecords=false
+dataServerPort=-1
+depthDimension=0
+hideServerMessages=false
+hostName=null
+instanceName=NanoXAS
+logDaysToLive=30
+logLevel=Fine
+logLevelConsole=Off
+logPath={logs}/{date}_{time}
+notificationLevel=Off
+parallelInitialization=false
+saveCommandStatistics=false
+scanStreamerPort=-1
+serverEnabled=false
+serverPort=8080
+simulation=false
+terminalEnabled=false
+terminalPort=3579
+userAuthenticator=ch.psi.pshell.security.LdapAuthenticator | ldap\\\\\\\://d.psi.ch | d.psi.ch | users.psi
+userManagement=false
+versionTrackingEnabled=true
+versionTrackingLogin={context}/svcusr-hlapp_robot
+versionTrackingManual=true
+versionTrackingRemote=git@git.psi.ch\:pshell_config/x07db.git
diff --git a/config/plugins.properties b/config/plugins.properties
index 067f836..435c38c 100644
--- a/config/plugins.properties
+++ b/config/plugins.properties
@@ -1,3 +1 @@
-Scienta.java=enabled
-ScientaPanel.java=enabled
EnergyScan.java=enabled
diff --git a/config/variables.properties b/config/variables.properties
index 4b18f8a..66f8fbb 100644
--- a/config/variables.properties
+++ b/config/variables.properties
@@ -1,2 +1,2 @@
-#Thu Jan 16 15:22:14 CET 2020
-FileSequentialNumber=38
+#Fri Jan 17 16:44:03 CET 2020
+FileSequentialNumber=52
diff --git a/devices/dp1.properties b/devices/dp1.properties
new file mode 100644
index 0000000..632e4ea
--- /dev/null
+++ b/devices/dp1.properties
@@ -0,0 +1,11 @@
+#Fri Jan 17 16:47:14 CET 2020
+motor1=0.0|4.0|8.0|0.0
+motor2=0.0|5.0|3.0|NaN
+motor3=null
+motor4=null
+motor5=null
+motor6=null
+motor7=null
+motor8=null
+positions=Park|Ready|Out|Clear
+precision=-1
diff --git a/devices/m1.properties b/devices/m1.properties
new file mode 100644
index 0000000..91817b7
--- /dev/null
+++ b/devices/m1.properties
@@ -0,0 +1,16 @@
+#Fri Jan 17 16:47:13 CET 2020
+defaultSpeed=1.0
+estbilizationDelay=0
+maxSpeed=10.0
+maxValue=10.0
+minSpeed=0.1
+minValue=-10.0
+monitorByPosition=false
+offset=0.0
+precision=2
+resolution=NaN
+rotation=false
+scale=1.0
+sign_bit=0
+startRetries=1
+unit=mm
diff --git a/devices/m2.properties b/devices/m2.properties
new file mode 100644
index 0000000..91817b7
--- /dev/null
+++ b/devices/m2.properties
@@ -0,0 +1,16 @@
+#Fri Jan 17 16:47:13 CET 2020
+defaultSpeed=1.0
+estbilizationDelay=0
+maxSpeed=10.0
+maxValue=10.0
+minSpeed=0.1
+minValue=-10.0
+monitorByPosition=false
+offset=0.0
+precision=2
+resolution=NaN
+rotation=false
+scale=1.0
+sign_bit=0
+startRetries=1
+unit=mm
diff --git a/devices/p1.properties b/devices/p1.properties
new file mode 100644
index 0000000..d52c3ee
--- /dev/null
+++ b/devices/p1.properties
@@ -0,0 +1,10 @@
+#Fri Jan 17 16:47:14 CET 2020
+maxValue=1000.0
+minValue=0.0
+offset=0.0
+precision=-1
+resolution=NaN
+rotation=false
+scale=1.0
+sign_bit=0
+unit=mm
diff --git a/devices/src1.properties b/devices/src1.properties
new file mode 100644
index 0000000..7dc5a54
--- /dev/null
+++ b/devices/src1.properties
@@ -0,0 +1,25 @@
+#Fri Jan 17 16:47:30 CET 2020
+colormap=Temperature
+colormapAutomatic=true
+colormapLogarithmic=false
+colormapMax=NaN
+colormapMin=NaN
+flipHorizontally=false
+flipVertically=false
+grayscale=false
+invert=false
+rescaleFactor=1.0
+rescaleOffset=0.0
+roiHeight=-1
+roiWidth=-1
+roiX=0
+roiY=0
+rotation=0.0
+rotationCrop=false
+scale=1.0
+spatialCalOffsetX=NaN
+spatialCalOffsetY=NaN
+spatialCalScaleX=NaN
+spatialCalScaleY=NaN
+spatialCalUnits=mm
+transpose=false
diff --git a/devices/src2.properties b/devices/src2.properties
new file mode 100644
index 0000000..5197a73
--- /dev/null
+++ b/devices/src2.properties
@@ -0,0 +1,25 @@
+#Fri Jan 17 16:47:30 CET 2020
+colormap=Grayscale
+colormapAutomatic=true
+colormapLogarithmic=false
+colormapMax=NaN
+colormapMin=NaN
+flipHorizontally=false
+flipVertically=false
+grayscale=false
+invert=false
+rescaleFactor=1.0
+rescaleOffset=0.0
+roiHeight=-1
+roiWidth=-1
+roiX=0
+roiY=0
+rotation=0.0
+rotationCrop=false
+scale=1.0
+spatialCalOffsetX=NaN
+spatialCalOffsetY=NaN
+spatialCalScaleX=NaN
+spatialCalScaleY=NaN
+spatialCalUnits=mm
+transpose=false
diff --git a/plugins/EnergyScan.form b/plugins/EnergyScan.form
index 864b4f4..e85c425 100644
--- a/plugins/EnergyScan.form
+++ b/plugins/EnergyScan.form
@@ -31,11 +31,16 @@
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
@@ -43,12 +48,14 @@
-
+
+
+
-
+
@@ -71,33 +78,48 @@
+
+
+
+
+
+
+
-
+
+
+
+
+
+
+
+
+
+
+
+
-
-
-
-
-
-
-
-
+
+
+
+
+
@@ -141,7 +163,28 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/plugins/EnergyScan.java b/plugins/EnergyScan.java
index 5dd94f0..a70f957 100644
--- a/plugins/EnergyScan.java
+++ b/plugins/EnergyScan.java
@@ -1,7 +1,21 @@
+import ch.psi.pshell.core.JsonSerializer;
+import ch.psi.pshell.epics.Positioner;
import ch.psi.pshell.ui.Panel;
+import ch.psi.utils.IO;
import ch.psi.utils.State;
+import ch.psi.utils.Sys;
+import ch.psi.utils.swing.SwingUtils;
+import java.io.File;
+import java.io.IOException;
+import java.nio.file.Files;
+import java.nio.file.Path;
+import java.nio.file.Paths;
import java.util.ArrayList;
import java.util.HashMap;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+import javax.swing.JFileChooser;
+import javax.swing.filechooser.FileNameExtensionFilter;
import javax.swing.table.DefaultTableModel;
/**
@@ -10,6 +24,11 @@ import javax.swing.table.DefaultTableModel;
public class EnergyScan extends Panel {
final DefaultTableModel model;
+ Positioner energy;
+ File currentFile;
+ public static final String FILE_EXTENSION = "ens";
+ public static final String DEFAULT_FOLDER = "{data}";
+
public EnergyScan() {
initComponents();
model = (DefaultTableModel) table.getModel();
@@ -18,7 +37,7 @@ public class EnergyScan extends Panel {
//Overridable callbacks
@Override
public void onInitialize(int runCount) {
-
+ energy = (Positioner) this.getDevice("energy");
}
@Override
@@ -36,6 +55,103 @@ public class EnergyScan extends Panel {
@Override
protected void doUpdate() {
}
+
+ void checkValues(){
+ if (model.getRowCount() == 0){
+ throw new IllegalArgumentException();
+ }
+ for (int i=0; i< model.getRowCount(); i++){
+ Double start = (Double) model.getValueAt(i, 0);
+ Double stop = (Double) model.getValueAt(i, 1);
+ Double step = (Double) model.getValueAt(i, 2);
+ if ( Double.isNaN(start) || Double.isNaN(stop) || Double.isNaN(step) ||
+ (start >= stop) || (step<0) ||
+ (start < energy.getMinValue()) ||
+ (stop > energy.getMaxValue()) ){
+ throw new IllegalArgumentException();
+ }
+ }
+ }
+
+ void start() throws Exception{
+ checkValues();
+ String lastOutput = getContext().getDataManager().getLastOutput();
+
+ HashMap args = new HashMap();
+ ArrayList regions = new ArrayList();
+ for (int i=0; i< model.getRowCount(); i++){
+ ArrayList region = new ArrayList();
+ region.add(model.getValueAt(i, 0));
+ region.add(model.getValueAt(i, 1));
+ region.add(model.getValueAt(i, 2));
+ regions.add(region);
+ }
+
+ args.put("REGIONS", regions);
+ this.runAsync("templates/EnergyScan", args).handle((ret,ex)->{
+ if (ex!=null){
+ }
+ if (checkAutoSaveArgs.isSelected()){
+ //Save scan attributes
+ String output = getContext().getDataManager().getLastOutput();
+ if ((output!=null) && !output.isEmpty() &&!output.equals(lastOutput)){
+ try {
+ save(Paths.get(output + "." + FILE_EXTENSION));
+ } catch (IOException e) {
+ Logger.getLogger(EnergyScan.class.getName()).log(Level.WARNING, null, e);
+ }
+ }
+ }
+ return ret;
+ });
+ }
+
+
+ public void save() throws IOException {
+ JFileChooser chooser = new JFileChooser(getContext().getSetup().expandPath(DEFAULT_FOLDER));
+ FileNameExtensionFilter filter = new FileNameExtensionFilter("Energy scan definition file", FILE_EXTENSION);
+ chooser.setFileFilter(filter);
+ chooser.setFileHidingEnabled(false);
+ if (currentFile != null) {
+ try {
+ chooser.setSelectedFile(currentFile);
+ } catch (Exception ex) {
+ }
+ }
+ int rVal = chooser.showSaveDialog(this);
+ if (rVal == JFileChooser.APPROVE_OPTION) {
+ String fileName = chooser.getSelectedFile().getAbsolutePath();
+ if (IO.getExtension(chooser.getSelectedFile().getAbsolutePath()).isEmpty()) {
+ fileName += "." + FILE_EXTENSION;
+ }
+ save(Paths.get(fileName));
+ }
+ }
+
+ public void save(Path path) throws IOException {
+ currentFile = path.toFile();
+ String json = JsonSerializer.encode(model.getDataVector(), true);
+ Files.write(path, json.getBytes());
+ }
+
+ public void open() throws IOException {
+ JFileChooser chooser = new JFileChooser(getContext().getSetup().expandPath(DEFAULT_FOLDER));
+ FileNameExtensionFilter filter = new FileNameExtensionFilter("Energy scan definition file", FILE_EXTENSION);
+ chooser.setFileFilter(filter);
+ chooser.setFileHidingEnabled(true);
+
+ int rVal = chooser.showOpenDialog(this);
+ if (rVal == JFileChooser.APPROVE_OPTION) {
+ open(chooser.getSelectedFile().toPath());
+ }
+ }
+
+ public void open(Path path) throws IOException {
+ String json = new String(Files.readAllBytes(path));
+ currentFile = path.toFile();
+ Object[][]vector = (Object[][]) JsonSerializer.decode(json, Object[][].class);
+ model.setDataVector(vector, SwingUtils.getTableColumnNames(table));
+ }
@SuppressWarnings("unchecked")
// //GEN-BEGIN:initComponents
@@ -50,6 +166,9 @@ public class EnergyScan extends Panel {
table = new javax.swing.JTable();
buttonAdd = new javax.swing.JButton();
buttonDelete = new javax.swing.JButton();
+ buttonOpen = new javax.swing.JButton();
+ buttonSave = new javax.swing.JButton();
+ checkAutoSaveArgs = new javax.swing.JCheckBox();
jScrollPane2.setViewportView(jEditorPane1);
@@ -67,6 +186,8 @@ public class EnergyScan extends Panel {
}
});
+ jPanel1.setBorder(javax.swing.BorderFactory.createTitledBorder("Regions"));
+
table.setModel(new javax.swing.table.DefaultTableModel(
new Object [][] {
@@ -99,47 +220,73 @@ public class EnergyScan extends Panel {
}
});
+ buttonOpen.setText("Open");
+ buttonOpen.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonOpenActionPerformed(evt);
+ }
+ });
+
+ buttonSave.setText("Save");
+ buttonSave.addActionListener(new java.awt.event.ActionListener() {
+ public void actionPerformed(java.awt.event.ActionEvent evt) {
+ buttonSaveActionPerformed(evt);
+ }
+ });
+
javax.swing.GroupLayout jPanel1Layout = new javax.swing.GroupLayout(jPanel1);
jPanel1.setLayout(jPanel1Layout);
jPanel1Layout.setHorizontalGroup(
jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addGroup(jPanel1Layout.createSequentialGroup()
.addContainerGap()
- .addComponent(jScrollPane1, javax.swing.GroupLayout.PREFERRED_SIZE, 0, Short.MAX_VALUE)
+ .addGroup(jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
+ .addComponent(jScrollPane1, javax.swing.GroupLayout.PREFERRED_SIZE, 0, Short.MAX_VALUE)
+ .addGroup(jPanel1Layout.createSequentialGroup()
+ .addComponent(buttonAdd)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addComponent(buttonDelete)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, 15, Short.MAX_VALUE)
+ .addComponent(buttonOpen)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addComponent(buttonSave)))
.addContainerGap())
- .addGroup(jPanel1Layout.createSequentialGroup()
- .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addComponent(buttonAdd)
- .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addComponent(buttonDelete)
- .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
);
- jPanel1Layout.linkSize(javax.swing.SwingConstants.HORIZONTAL, new java.awt.Component[] {buttonAdd, buttonDelete});
+ jPanel1Layout.linkSize(javax.swing.SwingConstants.HORIZONTAL, new java.awt.Component[] {buttonAdd, buttonDelete, buttonOpen, buttonSave});
jPanel1Layout.setVerticalGroup(
jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addGroup(jPanel1Layout.createSequentialGroup()
.addContainerGap()
- .addComponent(jScrollPane1, javax.swing.GroupLayout.DEFAULT_SIZE, 177, Short.MAX_VALUE)
+ .addComponent(jScrollPane1, javax.swing.GroupLayout.DEFAULT_SIZE, 138, Short.MAX_VALUE)
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
.addGroup(jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
.addComponent(buttonAdd)
- .addComponent(buttonDelete))
+ .addComponent(buttonDelete)
+ .addGroup(jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
+ .addComponent(buttonOpen)
+ .addComponent(buttonSave)))
.addContainerGap())
);
+ checkAutoSaveArgs.setText("Auto save scan parameters");
+
javax.swing.GroupLayout layout = new javax.swing.GroupLayout(this);
this.setLayout(layout);
layout.setHorizontalGroup(
layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addComponent(jPanel1, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
.addGroup(layout.createSequentialGroup()
- .addContainerGap(79, Short.MAX_VALUE)
- .addComponent(buttonStart)
- .addGap(45, 45, 45)
+ .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
+ .addComponent(buttonStart, javax.swing.GroupLayout.PREFERRED_SIZE, 150, javax.swing.GroupLayout.PREFERRED_SIZE)
+ .addGap(33, 33, 33)
.addComponent(buttonAbort)
- .addContainerGap(79, Short.MAX_VALUE))
+ .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
+ .addGroup(layout.createSequentialGroup()
+ .addContainerGap()
+ .addComponent(checkAutoSaveArgs)
+ .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
);
layout.linkSize(javax.swing.SwingConstants.HORIZONTAL, new java.awt.Component[] {buttonAbort, buttonStart});
@@ -148,33 +295,19 @@ public class EnergyScan extends Panel {
layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
.addGroup(javax.swing.GroupLayout.Alignment.TRAILING, layout.createSequentialGroup()
.addComponent(jPanel1, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
- .addGap(18, 18, 18)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
+ .addComponent(checkAutoSaveArgs)
+ .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.UNRELATED, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
.addComponent(buttonStart)
.addComponent(buttonAbort))
- .addGap(4, 4, 4))
+ .addContainerGap())
);
}// //GEN-END:initComponents
private void buttonStartActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonStartActionPerformed
- HashMap args = new HashMap();
- ArrayList regions = new ArrayList();
- for (int i=0; i< model.getRowCount(); i++){
- ArrayList region = new ArrayList();
- region.add(model.getValueAt(i, 0));
- region.add(model.getValueAt(i, 1));
- region.add(model.getValueAt(i, 2));
- regions.add(region);
- }
-
- args.put("REGIONS", regions);
try{
- this.runAsync("templates/EnergyScan", args).handle((ret,ex)->{
- if (ex!=null){
-
- }
- return ret;
- });
+ start();
} catch (Exception ex){
showException(ex);
}
@@ -189,20 +322,48 @@ public class EnergyScan extends Panel {
}//GEN-LAST:event_buttonAbortActionPerformed
private void buttonAddActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonAddActionPerformed
- model.addRow(new Object[]{Double.NaN, Double.NaN, Double.NaN});
+ try{
+ //model.addRow(new Object[]{energy.getMinValue(), energy.getMaxValue(), 10.0});
+ model.addRow(new Object[]{500.0, 1000.0, 10.0});
+ } catch (Exception ex){
+ showException(ex);
+ }
}//GEN-LAST:event_buttonAddActionPerformed
private void buttonDeleteActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonDeleteActionPerformed
- if ((model.getRowCount()>0) && (table.getSelectedRow()>=0)){
- model.removeRow(table.getSelectedRow());
- }
+ try{
+ if ((model.getRowCount()>0) && (table.getSelectedRow()>=0)){
+ model.removeRow(table.getSelectedRow());
+ }
+ } catch (Exception ex){
+ showException(ex);
+ }
}//GEN-LAST:event_buttonDeleteActionPerformed
+ private void buttonOpenActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonOpenActionPerformed
+ try{
+ open();
+ } catch (Exception ex){
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonOpenActionPerformed
+
+ private void buttonSaveActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_buttonSaveActionPerformed
+ try{
+ save();
+ } catch (Exception ex){
+ showException(ex);
+ }
+ }//GEN-LAST:event_buttonSaveActionPerformed
+
// Variables declaration - do not modify//GEN-BEGIN:variables
private javax.swing.JButton buttonAbort;
private javax.swing.JButton buttonAdd;
private javax.swing.JButton buttonDelete;
+ private javax.swing.JButton buttonOpen;
+ private javax.swing.JButton buttonSave;
private javax.swing.JButton buttonStart;
+ private javax.swing.JCheckBox checkAutoSaveArgs;
private javax.swing.JEditorPane jEditorPane1;
private javax.swing.JPanel jPanel1;
private javax.swing.JScrollPane jScrollPane1;
diff --git a/script/templates/EnergyScan.py b/script/templates/EnergyScan.py
index 605a42f..193239b 100644
--- a/script/templates/EnergyScan.py
+++ b/script/templates/EnergyScan.py
@@ -10,8 +10,8 @@ capture.write(1)
def trigger(position, scan):
scienta.start()
- scienta.waitNewImage(-1)
-
+ cienta.waitNewImage(-1)
+
try:
rscan(energy, sensors, REGIONS, latency = 0.0, before_read=trigger)