2019-12-26 16:04:49 +01:00
|
|
|
#!/usr/bin/python3
|
|
|
|
import numpy as np
|
2021-05-05 19:48:04 +02:00
|
|
|
import sys, logging, os, argparse
|
2021-05-08 15:06:11 +02:00
|
|
|
|
|
|
|
parser = argparse.ArgumentParser(
|
|
|
|
description='Play a sine wave'
|
|
|
|
)
|
|
|
|
|
|
|
|
parser.add_argument('--freq', '-f', help='Sine frequency [Hz]', type=float,
|
|
|
|
default=1000.)
|
|
|
|
|
|
|
|
parser.add_argument('--log', '-l',
|
|
|
|
help='Specify log level [info, debug, warning, ...]',
|
|
|
|
type=str, default='info')
|
|
|
|
|
|
|
|
args = parser.parse_args()
|
|
|
|
|
|
|
|
numeric_level = getattr(logging, args.log.upper(), None)
|
|
|
|
if not isinstance(numeric_level, int):
|
|
|
|
raise ValueError('Invalid log level: %s' % args.loglevel)
|
|
|
|
|
|
|
|
FORMAT = "[%(levelname)s %(filename)s:%(lineno)s - %(funcName)20s() ] %(message)s"
|
|
|
|
logging.basicConfig(format=FORMAT, level=numeric_level)
|
|
|
|
|
2021-05-05 19:48:04 +02:00
|
|
|
import multiprocessing
|
2021-05-08 15:06:11 +02:00
|
|
|
from lasp import (StreamManager, AvType, Siggen, SignalType, SiggenData)
|
2021-05-05 19:48:04 +02:00
|
|
|
from lasp.device import DaqConfigurations
|
2019-12-26 16:04:49 +01:00
|
|
|
|
|
|
|
|
2021-05-05 19:48:04 +02:00
|
|
|
if __name__ == '__main__':
|
|
|
|
multiprocessing.set_start_method('forkserver', force=True)
|
2021-05-08 15:06:11 +02:00
|
|
|
logging.info(f'Playing frequency {args.freq} [Hz]')
|
2019-12-26 16:04:49 +01:00
|
|
|
|
2021-05-14 11:24:07 +02:00
|
|
|
configs = DaqConfigurations.loadAllConfigs()
|
2021-05-05 19:48:04 +02:00
|
|
|
|
|
|
|
config_keys = [key for key in configs.keys()]
|
|
|
|
for i, key in enumerate(config_keys):
|
|
|
|
print(f'{i:2} : {key}')
|
|
|
|
|
|
|
|
choosen_index = input('Number of configuration to use: ')
|
|
|
|
try:
|
|
|
|
daqindex = int(choosen_index)
|
|
|
|
except:
|
2021-05-08 15:06:11 +02:00
|
|
|
print('Invalid configuration number. Exiting.')
|
2021-05-05 19:48:04 +02:00
|
|
|
sys.exit(0)
|
|
|
|
|
2019-12-26 16:04:49 +01:00
|
|
|
|
2021-05-05 19:48:04 +02:00
|
|
|
choosen_key = config_keys[daqindex]
|
2021-05-07 22:53:29 +02:00
|
|
|
daqconfig = configs[choosen_key].output_config
|
2019-12-26 16:04:49 +01:00
|
|
|
|
2021-05-05 19:48:04 +02:00
|
|
|
print(f'Choosen configuration: {choosen_key}')
|
2019-12-26 16:04:49 +01:00
|
|
|
|
2021-05-05 19:48:04 +02:00
|
|
|
try:
|
2021-05-07 22:53:29 +02:00
|
|
|
streammgr = StreamManager()
|
|
|
|
outq = streammgr.getOutputQueue()
|
|
|
|
|
2021-05-05 19:48:04 +02:00
|
|
|
siggendata = SiggenData(
|
|
|
|
fs=48e3,
|
2021-05-08 15:06:11 +02:00
|
|
|
nframes_per_block=1024,
|
2021-05-05 19:48:04 +02:00
|
|
|
dtype=np.dtype(np.int16),
|
|
|
|
eqdata=None,
|
|
|
|
level_dB=-20,
|
|
|
|
signaltype=SignalType.Periodic,
|
2021-05-08 15:06:11 +02:00
|
|
|
signaltypedata=(args.freq,)
|
2021-05-05 19:48:04 +02:00
|
|
|
)
|
2021-05-07 22:53:29 +02:00
|
|
|
siggen = Siggen(outq, siggendata)
|
2019-12-26 16:04:49 +01:00
|
|
|
|
2021-05-07 22:53:29 +02:00
|
|
|
streammgr.activateSiggen()
|
2019-12-26 16:04:49 +01:00
|
|
|
|
2021-05-07 22:53:29 +02:00
|
|
|
streammgr.startStream(AvType.audio_output, daqconfig)
|
2019-12-26 16:04:49 +01:00
|
|
|
|
2021-05-05 19:48:04 +02:00
|
|
|
input('Press any key to stop...')
|
2021-05-07 22:53:29 +02:00
|
|
|
streammgr.stopStream(AvType.audio_output)
|
2021-05-05 19:48:04 +02:00
|
|
|
finally:
|
2021-05-07 22:53:29 +02:00
|
|
|
siggen.cleanup()
|
|
|
|
streammgr.cleanup()
|
2019-12-26 16:04:49 +01:00
|
|
|
|
|
|
|
|