Source code for user_apps.acq400.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()

Some usage examples are included below:

1: Acquire files of size 1024kb up to a total of 4096kb::

    acq400_stream.py --verbose=1 --filesize=1M --totaldata=4M <uut hostname>

2: Acquire a single file of size 4096kb::

    acq400_stream.py --verbose=1 --filesize=4M --totaldata=4M <uut hostname>

3: Acquire files of size 1024 for 10 seconds::
    
    acq400_stream.py --verbose=1 --filesize=1M --runtime=10 <uut hostname>

4: Acquire data for 5 seconds and write the data all to a single file::
    
    acq400_stream.py --verbose=1 --filesize=9999M --runtime=5 <uut hostname>

.. rst-class:: hidden

    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


"""

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 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 if args.callback is not None and args.callback(): print("Callback says \"enough\"") break 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 get_parser(): parser = argparse.ArgumentParser(description='Stream data from UUT') #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', default=0x100000, action=acq400_hapi.intSIAction, decimal=False) parser.add_argument( '--totaldata', default=10000000000, 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('--callback', default=None, help="for client program use only. Assume object with __call_ method") parser.add_argument('uuts', nargs='+', help="uuts") return parser
if __name__ == '__main__': run_stream(get_parser().parse_args())