# autoplot2023.py v4.00 # do not edit this file, changes will be lost.
# See "4.00" below, and in org.autoplot.jythonsupport.JythonUtil
# This version appears in JythonUtil as well!
# This is copied into each enduser's autoplot_data/jython folder to be picked up
# along with all the other python codes.
from org.das2.qds.ops.Ops import *
from org.autoplot.jythonsupport.JythonOps import *
from org.autoplot.jythonsupport.Util import *
from org.das2.qds import QDataSet
from org.das2.qds.util.BinAverage import *
from org.das2.qds.util import DataSetBuilder
_autoplot_jython_version= 4.0
#_autoplot_jython_version= float(getAutoplotScriptingVersion()[1:])
from org.das2.datum import DatumRange, Units, DatumRangeUtil, TimeUtil
from java.net import URL, URI
from org.das2.datum import TimeParser
# security concerns
from org.autoplot.datasource.DataSetURI import getFile
from org.autoplot.datasource.DataSetURI import downloadResourceAsTempFile
# end, security concerns.
# Jython is tricky with single-jar releases, and using star imports to find classes doesn't work.
params= dict()
_paramMap= dict()
_paramSort= []
_scriptTitle= ""
_scriptDescription= ""
_scriptLabel= ""
_scriptIcon= ""
import operator.isNumberType
# name is the name of the input parameter.
# deflt is the default value for the input parameter.
# doc is any documentation for the parameter.
# constraint is used to declare any constraints, presently one of: a list of enumerated values, or a dictionary with any of min, max, examples, values, and regex.
def getParam( name, deflt, doc='', constraint='' ):
"""get the parameter from the URI
- name is the name of the input parameter.
- deflt is the default value for the input parameter.
- doc is any documentation for the parameter.
- constraint is used to declare any constraints, presently one of: a list of enumerated values, or a dictionary with any of
min, max, examples, values, and regex.
"""
if type(name).__name__ == 'int':
name = 'arg_%d' % name
_paramMap[name] = [name, deflt, doc, constraint]
_paramSort.append(name)
if type(params) is dict:
if name in params:
t = type(deflt) # Ed demonstrated this allows some pretty crazy things, e.g. open file, so be careful...
v = t(params[name])
if isinstance(constraint, list):
if v not in constraint:
raise Exception('value is not one of allowed values: %s %s' % (name, v))
if t==int:
for c in constraint:
if type(c)!=int:
raise Exception('value in example values list is not an int, but default value is: %s %s %s' % (name, c, deflt))
elif isinstance(constraint, dict):
v= validateParam( name, v, constraint )
return v
else:
return deflt
else:
print('in Jython script, variable params was overriden.')
return deflt
def setScriptTitle(title):
"""Set the title for the script."""
global _scriptTitle
_scriptTitle= title
def setScriptDescription(desc):
"""Set a short description for the script. This can be multiple lines, and maybe html."""
global _scriptDescription
_scriptDescription= desc
def setScriptLabel(label):
"""Set a concise identifying label for the script. This should be no more than a few words."""
global _scriptLabel
_scriptLabel= label
def setScriptIcon(icon):
"""Set to a URL which should be a small image file used for an image, representing an action for the script."""
global _scriptIcon
_scriptIcon= icon
outputParams= dict()
_outputParamMap= dict()
_outputParamSort= []
def validateParam(name, v, constraint):
"""validate the parameter value against the constraint. This will
raise an exception when the constraint is not met, or returns a modified
value conforming (with format). See https://github.com/autoplot/dev/blob/master/demos/2025/20250108/getParamsValidation.jy"""
t = type(v) # Ed demonstrated this allows some pretty crazy things, e.g. open file, so be careful...
if isinstance(constraint, list):
if v not in constraint:
raise Exception('value is not one of allowed values: %s %s' % (name, v))
if t == int:
for c in constraint:
if type(c) is int:
raise Exception('value in example values list is not an int, but value is: %s %s %s' % (name, c, v))
elif isinstance(constraint, dict):
if 'regex' in constraint:
import re as _re
if not _re.match(constraint['regex']+'$', v):
raise Exception('value does not match regular expression: %s %s' % (name, v))
if 'min' in constraint and v < constraint['min']:
raise Exception('value is less than minimum: %s %s' % (name, v))
if 'max' in constraint and v > constraint['max']:
raise Exception('value is greater than maximum: %s %s' % (name, v))
if 'format' in constraint:
spec = constraint['format']
if spec[0] == '$':
v = TimeParser.create(spec).format( datumRange(v).min() )
elif spec[0] == '%':
v = t(spec % v)
return v
# name is the name of the output parameter.
# value is the value of the output parameter.
# doc is any documentation for the output parameter.
# constraint is used to declare any constraints, presently one of: a list of enumerated values, or a dictionary with min, max, examples, values, and units.
def setOutputParam(name, value, doc='', constraint=''):
"""set the output parameter for use by those calling the script.
- name is the name of the output parameter.
- deflt is the value for the output parameter.
- doc is any documentation for the parameter.
- constraint is used to declare any constraints, presently one of: a list of enumerated values, or a dictionary with any of
min, max, examples, values, regex, and units. Validation of output parameter may be performed before passing it on to those calling
the script.
"""
global _outputParamMap, _outputParamSort, outputParams
_outputParamMap[ name ]= [ name, value, doc, constraint ]
_outputParamSort.append( name )
globals()[name]= value #TODO: this isn't working
if type(outputParams) is dict:
value= validateParam( name, value, constraint )
outputParams[name]= value
else:
raise Exception( 'in Jython script, variable outputParams was overriden.' )
# invokeLater command is a scientist-friendly way to define a function that
# is called on a different thread.
import java.lang.Thread as _Thread
import java.lang.Runnable as _Runnable
class InvokeLaterRunnable( _Runnable ):
def __init__( self, fun, args, kw ):
self.fun= fun
self.args= args
self.kw= kw
def run( self ):
self.fun( *self.args, **self.kw )
def invokeLater( functn, *args, **kw ):
"""invoke the function later. It should be followed by the parameters
passed to the function. See also runInParallel"""
r= InvokeLaterRunnable( functn, args, kw )
# Ed suggests this use ThreadPoolExecutor
_Thread(r,'invokeLater').start()