From 5e17bf94376d3e16266b8ae56630e707b5870e09 Mon Sep 17 00:00:00 2001 From: Haisam Ido Date: Thu, 3 Oct 2024 17:21:45 -0400 Subject: [PATCH 1/3] Update simulator.py with arguments python3 ./simulator.py --rate 11 python3 ./simulator.py -h python3 ./simulator.py --help --- simulator.py | 48 +++++++++++++++++++++++++++++++++++------------- 1 file changed, 35 insertions(+), 13 deletions(-) diff --git a/simulator.py b/simulator.py index cf0cc0a..d975b2b 100755 --- a/simulator.py +++ b/simulator.py @@ -4,15 +4,42 @@ import io import socket import sys +import argparse + from struct import unpack_from from threading import Thread from time import sleep -from argparse import ArgumentParser + +parser = argparse.ArgumentParser(description='Yamcs Simulator') +parser.add_argument('--testdata', type=str, default='testdata.ccsds', help='simulated testdata.ccsds data') + +# telemetry +parser.add_argument('--tm_host', type=str, default='127.0.0.1', help='TM host') +parser.add_argument('--tm_port', type=int, default=10015, help='TM port') +parser.add_argument('-r', '--rate', type=int, default=1, help='TM playback rate. 1 = 1Hz, 10 = 10Hz, etc.') + +# telecommand +parser.add_argument('--tc_host', type=str, default='127.0.0.1', help='TC host') +parser.add_argument('--tc_port', type=int, default=10025 , help='TC port') + +args = vars(parser.parse_args()) + +# test data +TEST_DATA = args['testdata'] + +# telemetry +TM_SEND_ADDRESS = args['tm_host'] +TM_SEND_PORT = args['tm_port'] +RATE = args['rate'] + +# telecommand +TC_RECEIVE_ADDRESS = args['tc_host'] +TC_RECEIVE_PORT = args['tc_port'] def send_tm(simulator): tm_socket = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) - with io.open('testdata.ccsds', 'rb') as f: + with io.open(TEST_DATA, 'rb') as f: simulator.tm_counter = 1 header = bytearray(6) while f.readinto(header) == 6: @@ -22,7 +49,7 @@ def send_tm(simulator): f.seek(-6, io.SEEK_CUR) f.readinto(packet) - tm_socket.sendto(packet, ('127.0.0.1', 10015)) + tm_socket.sendto(packet, (TM_SEND_ADDRESS, TM_SEND_PORT)) simulator.tm_counter += 1 sleep(1 / simulator.rate) @@ -30,7 +57,7 @@ def send_tm(simulator): def receive_tc(simulator): tc_socket = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) - tc_socket.bind(('127.0.0.1', 10025)) + tc_socket.bind((TC_RECEIVE_ADDRESS, TC_RECEIVE_PORT )) while True: data, _ = tc_socket.recvfrom(4096) simulator.last_tc = data @@ -64,16 +91,11 @@ def print_status(self): if __name__ == '__main__': - parser = ArgumentParser() - parser.add_argument("-r", "--rate", - dest="rate", - default=1, - type=int, - help="Playback rate. 1 = 1Hz, 10 = 10Hz, etc.") - args = parser.parse_args() - simulator = Simulator(args.rate) + simulator = Simulator(RATE) simulator.start() - sys.stdout.write('Using playback rate of ' + str(args.rate) + 'Hz \r\n'); + sys.stdout.write('Using playback rate of ' + str(RATE) + 'Hz, '); + sys.stdout.write('TC host=' + str(TM_SEND_ADDRESS) + ', TM port=' + str(TM_SEND_PORT) + ', '); + sys.stdout.write('TC host=' + str(TC_RECEIVE_ADDRESS) + ', TM port=' + str(TC_RECEIVE_PORT) + '\r\n'); try: prev_status = None while True: From d8629a5f32ee3d6700c741a8fb88858fc9ed871f Mon Sep 17 00:00:00 2001 From: Haisam Ido Date: Thu, 3 Oct 2024 17:27:59 -0400 Subject: [PATCH 2/3] fixed TM to TC in message fixed TM to TC in message --- simulator.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/simulator.py b/simulator.py index d975b2b..8df73d4 100755 --- a/simulator.py +++ b/simulator.py @@ -95,7 +95,7 @@ def print_status(self): simulator.start() sys.stdout.write('Using playback rate of ' + str(RATE) + 'Hz, '); sys.stdout.write('TC host=' + str(TM_SEND_ADDRESS) + ', TM port=' + str(TM_SEND_PORT) + ', '); - sys.stdout.write('TC host=' + str(TC_RECEIVE_ADDRESS) + ', TM port=' + str(TC_RECEIVE_PORT) + '\r\n'); + sys.stdout.write('TC host=' + str(TC_RECEIVE_ADDRESS) + ', TC port=' + str(TC_RECEIVE_PORT) + '\r\n'); try: prev_status = None while True: From 2e1adc069a714fe6ad493f05f740874177be96c3 Mon Sep 17 00:00:00 2001 From: Haisam Ido Date: Thu, 3 Oct 2024 17:30:39 -0400 Subject: [PATCH 3/3] fixed stdout write string fixed stdout write string --- simulator.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/simulator.py b/simulator.py index 8df73d4..7c9de19 100755 --- a/simulator.py +++ b/simulator.py @@ -94,7 +94,7 @@ def print_status(self): simulator = Simulator(RATE) simulator.start() sys.stdout.write('Using playback rate of ' + str(RATE) + 'Hz, '); - sys.stdout.write('TC host=' + str(TM_SEND_ADDRESS) + ', TM port=' + str(TM_SEND_PORT) + ', '); + sys.stdout.write('TM host=' + str(TM_SEND_ADDRESS) + ', TM port=' + str(TM_SEND_PORT) + ', '); sys.stdout.write('TC host=' + str(TC_RECEIVE_ADDRESS) + ', TC port=' + str(TC_RECEIVE_PORT) + '\r\n'); try: prev_status = None