-
Notifications
You must be signed in to change notification settings - Fork 50
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #55 from rpanderson/example_IMAQdx_remote
Example labscript and analysis scripts for IMAQdxCamera and RemoteBLACS
- Loading branch information
Showing
3 changed files
with
137 additions
and
0 deletions.
There are no files selected for viewing
46 changes: 46 additions & 0 deletions
46
...pt_profile/default_profile/userlib/analysislib/example_apparatus/example_IMAQdx_remote.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,46 @@ | ||
import lyse | ||
from pathlib import Path | ||
import matplotlib.pyplot as plt | ||
|
||
# Is this script being run from within an interactive lyse session? | ||
if lyse.spinning_top: | ||
# If so, use the filepath of the current shot | ||
h5_path = lyse.path | ||
else: | ||
# If not, get the filepath of the last shot of the lyse DataFrame | ||
df = lyse.data() | ||
h5_path = df.filepath.iloc[-1] | ||
|
||
# Instantiate a lyse.Run object for this shot | ||
run = lyse.Run(h5_path) | ||
|
||
# Get a dictionary of the global variables used in this shot | ||
run_globals = run.get_globals() | ||
|
||
# Extract the images 'before' and 'after' generated from camera.expose | ||
before, after = run.get_images('camera', 'comparison', 'before', 'after') | ||
|
||
# Compute the difference of the two images, after casting them to signed integers | ||
# (otherwise negative differences wrap to 2**16 - 1 - diff) | ||
diff = after.astype('int16') - before.astype('int16') | ||
|
||
# Plot the row-wise mean of each image | ||
plt.plot(before.mean(axis=0), label='before') | ||
plt.plot(after.mean(axis=0), label='after') | ||
plt.xlabel('pixel coordinate (column)') | ||
plt.ylabel('counts') | ||
|
||
# Label the plot with a unique string representing the shot | ||
plt.title(Path(run.h5_path).name) | ||
|
||
# Plot adornments | ||
plt.legend(loc='lower left') | ||
plt.grid() | ||
|
||
# Show the plot | ||
plt.show() | ||
|
||
# Compute a result based on the image processing and save it to the 'results' group of | ||
# the shot file | ||
result = diff.std() | ||
run.save_result('foobar', result) |
40 changes: 40 additions & 0 deletions
40
.../default_profile/userlib/labscriptlib/example_apparatus/connection_table_IMAQdx_remote.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,40 @@ | ||
from labscript import start, stop, add_time_marker, Trigger, RemoteBLACS | ||
from labscript_devices.DummyPseudoclock.labscript_devices import DummyPseudoclock | ||
from labscript_devices.DummyIntermediateDevice import DummyIntermediateDevice | ||
from labscript_devices.IMAQdxCamera.labscript_devices import IMAQdxCamera | ||
|
||
# Use a virtual ('dummy') device for the psuedoclock | ||
DummyPseudoclock(name='pseudoclock') | ||
|
||
# An output of this DummyPseudoclock is its 'clockline' attribute, which we use | ||
# to trigger children devices | ||
DummyIntermediateDevice(name='intermediate_device', parent_device=pseudoclock.clockline) | ||
|
||
# Instantiate a labscript.Trigger instance used to trigger the camera exposure | ||
# This will be specified as the camera's parent device later | ||
Trigger( | ||
name='camera_trigger', parent_device=intermediate_device, connection='port0/line0' | ||
) | ||
|
||
# On the host specified below, start the RemoteBLACS server by running the following: | ||
# $ python - m labscript_utils.remote | ||
RemoteBLACS(name='test_remote', host='localhost') | ||
|
||
# We then initiate an IMAQdxCamera using this RemoteBLACS instance | ||
# using mock=True to bypass any attempts to commmunicate with an | ||
# actual camera, and generate fake data at the end of the shot | ||
IMAQdxCamera( | ||
name='camera', | ||
parent_device=camera_trigger, | ||
connection='trigger', | ||
serial_number=0xDEADBEEF, | ||
worker=test_remote, | ||
mock=True, | ||
) | ||
|
||
# Begin issuing labscript primitives | ||
# start() elicits the commencement of the shot | ||
start() | ||
|
||
# Stop the experiment shot with stop() | ||
stop(1.0) |
51 changes: 51 additions & 0 deletions
51
...t_profile/default_profile/userlib/labscriptlib/example_apparatus/example_IMAQdx_remote.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,51 @@ | ||
from labscript import start, stop, add_time_marker, Trigger, RemoteBLACS | ||
from labscript_devices.DummyPseudoclock.labscript_devices import DummyPseudoclock | ||
from labscript_devices.DummyIntermediateDevice import DummyIntermediateDevice | ||
from labscript_devices.IMAQdxCamera.labscript_devices import IMAQdxCamera | ||
|
||
# Use a virtual ('dummy') device for the psuedoclock | ||
DummyPseudoclock(name='pseudoclock') | ||
|
||
# An output of this DummyPseudoclock is its 'clockline' attribute, which we use | ||
# to trigger children devices | ||
DummyIntermediateDevice(name='intermediate_device', parent_device=pseudoclock.clockline) | ||
|
||
# Instantiate a labscript.Trigger instance used to trigger the camera exposure | ||
# This will be specified as the camera's parent device later | ||
Trigger( | ||
name='camera_trigger', parent_device=intermediate_device, connection='port0/line0' | ||
) | ||
|
||
# On the host specified below, start the RemoteBLACS server by running the following: | ||
# $ python - m labscript_utils.remote | ||
RemoteBLACS(name='test_remote', host='localhost') | ||
|
||
# We then initiate an IMAQdxCamera using this RemoteBLACS instance | ||
# using mock=True to bypass any attempts to commmunicate with an | ||
# actual camera, and generate fake data at the end of the shot | ||
IMAQdxCamera( | ||
name='camera', | ||
parent_device=camera_trigger, | ||
connection='trigger', | ||
serial_number=0xDEADBEEF, | ||
worker=test_remote, | ||
mock=True, | ||
) | ||
|
||
# Begin issuing labscript primitives | ||
# A timing variable t is used for convenience | ||
# start() elicits the commencement of the shot | ||
t = 0 | ||
add_time_marker(t, "Start", verbose=True) | ||
start() | ||
|
||
t += 1 | ||
add_time_marker(t, "Exposure: 'before' image", verbose=True) | ||
camera.expose(t, name='comparison', frametype='before', trigger_duration=0.2) | ||
|
||
t += 0.5 | ||
add_time_marker(t, "Exposure: 'after' image", verbose=True) | ||
camera.expose(t, name='comparison', frametype='after', trigger_duration=0.2) | ||
|
||
t += 0.5 | ||
stop(t) |