forked from Sussex-Invisibles/AcquireTek
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsingle_acquisition_example.py
68 lines (64 loc) · 2.85 KB
/
single_acquisition_example.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
#!/usr/bin/env python
#
# single_acquisition_example.py
#
# Acquisition of single triggerred waveform data from a Tektronix scope.
# Data is saved to a hdf5 file.
#
# Author P G Jones - 2013-09-16 <[email protected]> : First revision
##################################################################################
import optparse
import scopes
import scope_connections
import utils
import datetime
import time
from pyvisa.vpp43 import visa_exceptions
def single_acquisition_example(name, n_events, trigger, trigger_channel):
""" Acquire a set of triggerred single acquisitions for two channels."""
tek_scope = scopes.Tektronix2000(scope_connections.VisaUSB())
# First setup the scope, lock the front panel
tek_scope.lock()
tek_scope.set_active_channel(1)
tek_scope.set_active_channel(2)
tek_scope.set_single_acquisition() # Single signal acquisition mode
tek_scope.set_edge_trigger(trigger, trigger_channel, True) # Falling edge trigger
tek_scope.set_data_mode(49500, 50500)
tek_scope.begin()
# Now create a HDF5 file and save the meta information
file_name = name + "_" + str(datetime.date.today())
results = utils.HDF5File(file_name, 2)
results.add_meta_data("trigger", trigger)
results.add_meta_data("trigger_channel", trigger_channel)
results.add_meta_data("ch1_timeform", tek_scope.get_timeform(1))
results.add_meta_data("ch2_timeform", tek_scope.get_timeform(2))
results.add_meta_dict(tek_scope.get_preamble(1), "ch1")
results.add_meta_dict(tek_scope.get_preamble(2), "ch2")
last_save_time = datetime.datetime.now()
print "Starting data taking at time", last_save_time.strftime("%Y-%m-%d %H:%M:%S")
for event in range(0, n_events):
tek_scope.acquire()
try:
results.add_data(tek_scope.get_waveform(1), 1)
results.add_data(tek_scope.get_waveform(2), 2)
except visa_exceptions.VisaIOError, e:
print "Serious death", e
time.sleep(10)
except Exception, e:
print "Scope died, acquisition lost.", e
time.sleep(10)
if datetime.datetime.now() - last_save_time > datetime.timedelta(seconds=60):
results.autosave()
last_save_time = datetime.datetime.now()
results.save()
print "Finished at", time.strftime("%Y-%m-%d %H:%M:%S")
if __name__ == "__main__":
parser = optparse.OptionParser(usage = "usage: %prog name n_events", version="%prog 1.0")
parser.add_option("-c", type="int", dest="channel", help="Trigger channel", default=2)
parser.add_option("-t", type="float", dest="trigger", help="Trigger level", default=-0.004)
(options, args) = parser.parse_args()
if len(args) != 2:
print "Incorrect number of arguments"
parser.print_help()
exit(0)
single_acquisition_example(args[0], int(args[1]), options.trigger, options.channel)