Source code for acq400_stream
#!/usr/bin/env python
"""
This is a script intended to connect to a UUT and stream data from port 4210.
The data that has been streamed is not demuxed and so if it is to be used then it has to be demuxed first.
Something like:
>>> data = numpy.fromfile("0000", dtype="<datatype>")
>>> plt.plot(data[::<number of channels>])
>>> plt.show()
usage::
acq400_stream.py [-h] [--filesize FILESIZE] [--totaldata TOTALDATA]
[--root ROOT] [--runtime RUNTIME] [--verbose VERBOSE]
uuts [uuts ...]
acq400 stream
positional arguments:
uuts uuts
optional arguments:
-h, --help show this help message and exit
--filesize FILESIZE Size of file to store in KB. If filesize > total data
then no data will be stored.
--totaldata TOTALDATA
Total amount of data to store in KB
--root ROOT Location to save files
--runtime RUNTIME How long to stream data for
--verbose VERBOSE Prints status messages as the stream is running
Some usage examples are included below:
1: Acquire files of size 1024kb up to a total of 4096kb:
>>> python acq400_stream.py --verbose=1 --filesize=1M --totaldata=4M <module ip or name>
2: Acquire a single file of size 4096kb:
>>> python acq400_stream.py --verbose=1 --filesize=4M --totaldata=4M <module ip or name>
3: Acquire files of size 1024 for 10 seconds:
>>> python acq400_stream.py --verbose=1 --filesize=1M --runtime=10 <module ip or name>
4: Acquire data for 5 seconds and write the data all to a single file:
>>> python acq400_stream.py --verbose=1 --filesize=9999M --runtime=5 <module ip or name>
"""
import acq400_hapi
import numpy as np
import os
import time
import argparse
import socket
import sys
[docs]def make_data_dir(directory, verbose):
try:
os.makedirs(directory)
except Exception:
if verbose:
print("Directory already exists")
pass
[docs]def run_stream(args):
RXBUF_LEN = 4096
cycle = 1
root = args.root + args.uuts[0] + "/" + "{:06d}".format(cycle)
data = bytes()
num = 0
uuts = [acq400_hapi.Acq400(u) for u in args.uuts]
for uut in uuts:
try:
if int(uut.s0.data32):
wordsizetype = "<i4" # 32 bit little endian
else:
wordsizetype = "<i2" # 16 bit little endian
except AttributeError:
print("Attribute error detected. No data32 attribute - defaulting to 16 bit")
wordsizetype = "<i2" # 16 bit little endian
skt = socket.socket()
skt.connect((args.uuts[0], 4210))
make_data_dir(root, args.verbose)
start_time = time.time()
upload_time = time.time()
data_length = 0
if args.filesize > args.totaldata:
args.filesize = args.totaldata
bytestogo = args.filesize
while time.time() < (start_time + args.runtime) and data_length < args.totaldata:
rxbuf = RXBUF_LEN if bytestogo > RXBUF_LEN else bytestogo
loop_time = time.clock()
data += skt.recv(rxbuf)
bytestogo = args.filesize - len(data)
if len(data) >= args.filesize:
data_length += len(data)
if num > 99:
num = 0
cycle += 1
root = args.root + args.uuts[0] + "/" + "{:06d}".format(cycle)
make_data_dir(root, args.verbose)
data_file = open("{}/{:04d}".format(root, num), "wb")
data = np.frombuffer(data, dtype="<i2")
data = np.asarray(data)
data.tofile(data_file, '')
if args.verbose == 1:
print("New data file written.")
print("Data Transferred: ", data_length, "KB")
print("Streaming time remaining: ", -1*(time.time() - (start_time + args.runtime)))
print("")
print("")
num += 1
data_file.close()
data = bytes() # Remove data from variable once it has been written
upload_time = time.time() # Reset upload time
data_written_flag = 1
try:
data_written_flag
except NameError:
data_file = open("{}/{:04d}".format(root, num), "wb")
data = np.frombuffer(data, dtype="<i2")
data = np.asarray(data)
data.tofile(data_file, '')
print("runtime exceeded: all stream data written to single file")
[docs]def run_main():
parser = argparse.ArgumentParser(description='acq400 stream')
#parser.add_argument('--filesize', default=1048576, type=int,
# help="Size of file to store in KB. If filesize > total data then no data will be stored.")
parser.add_argument('-filesize', '--filesize', default=0x100000, action=acq400_hapi.intSIAction, decimal=False)
parser.add_argument('-totaldata', '--totaldata', default=sys.maxint, action=acq400_hapi.intSIAction, decimal = False)
#parser.add_argument('--totaldata', default=4194304, type=int, help="Total amount of data to store in KB")
parser.add_argument('--root', default="", type=str, help="Location to save files. Default dir is UUT name.")
parser.add_argument('--runtime', default=1000000, type=int, help="How long to stream data for")
parser.add_argument('--verbose', default=0, type=int, help='Prints status messages as the stream is running')
parser.add_argument('uuts', nargs='+', help="uuts")
run_stream(parser.parse_args())
if __name__ == '__main__':
run_main()