Up | Example 01 - Calculate Area | Example 02 - Calculate mean value | Example 03 - Manipulate the results from two LineFinders | Example 04 - Dynamic threshold | Example 05 - Auto Exposure | Example 06 - DrawLine | Example 07 - Overlays | Example 08 - Python Objects | Example 09 - Timing | Example 10 - Image Averaging | Example 11 - Image Resampling | Example 12 - Constant Contrast | Example 13 - Serial Communication | Example 14 - Python results | Example 15 - Making a result string | Example 16 - Running tools from a script | Example 17 - Image Manipulation using Python Scripting | Example 18 - Calculating the median angle | Example 19 - Iterating objects located by a blob | Example 20 - Resampling using non-linear calibration | Example 21 - Custom Scorpion Python extension | Example 22 - Accessing Image Pixels | Example 23 - Implementing a tcp/ip Socket Server | Example 24 - Setting ExternalReference from calculated four points | Example 25 - Rotating a reference around in a circle | Example 26 - Grabbing an image from an MOXA Video IP Server | Example 27 - Toolbox Switch | Example 28 - Color Matcher Iteration | Example 29 - Audio Notification | Example 30 - Windows MessageBox | Example 31 -  Client to tcp Socket Server | Example 32 -  Read / Write External Data from / to file | Example 33 - Changing a tool's ROI | Example 34 - Histogram Equalization | Example 35 - Robust Adam 6060 scripts | Example 36 - Bubblesort | Example 37 - Element Statistics | Example 38 - Saving 3D Image | Example 39 - Disabling Zoom in Image Windows | Example 40 - Filtering timeseries | Example 41 - Scorpion Watchdog keep system running | Example 42 - Binary Search | Example 43 - Creating an ordered pointcloud | Example 44 - UDP Socket Communication

 

  

 
Example 16 - Running tools from a script

A very powerful feature in Scorpion is to run the tools from a script.

Example - Process sixteen candles with four tools

img=GetImageMatr('Image') #get the image
ref=GetTool('Reference') #get the reference

org=ref.result #store the origin
blob=GetTool('Blob')
line=GetTool('Line')
res=GetTool('Count')
distance = GetTool('Distance')

no = 0
y0 = -50
dSum = 0
for i in range(16):
  blob.execute(img) #execute blob at first candle

  y = ref.getValue('Value_y')
  cnt=blob.result['Count'] #get result cnt
  if (cnt >= 1) :
    no = no +1
    line.execute(img)
    distance.execute(img)
    d = distance.getValue('Distance')
    dSum = dSum +d
  cx=blob.result['CenterOfGravity_x'] #get result x
  y1=blob.result['CenterOfGravity_y'] #get result y
  #print 'y1 : ',y1
  res.setValue('Value',no) #update blobs found

  ref.setValue('Value_y',y+50+y1) #offset to next candle
  #offset to next candle
  ref.execute(img) #recalculates reference
  print i,y,cx,y1
  y0 = y1

ref.result=org #restore origin result
meanDistance = GetTool('MeanDistance')
meanDistance.setValue('Value',dSum/no)

 

Scorpion Vision Version XII : Build 646 - Date: 20170225
Scorpion Vision Software® is a registered trademark of Tordivel AS.
Copyright © 2000 - 2017 Tordivel AS.