1 | """ |
---|
2 | live_log_proc.py |
---|
3 | |
---|
4 | Template script demonstrating how to retrieve and process log data |
---|
5 | live without writing data to an HDF5 file for offline analysis. |
---|
6 | |
---|
7 | This script configures a single WARP v3 node as a monitor, then |
---|
8 | continually retrieves new data from the node's log. New log entries |
---|
9 | are optionally passed to callback functions defined in the |
---|
10 | LOG_ENTRIES_CALLBACKS dictionary. By default RX_OFDM and RX_DSSS |
---|
11 | entries are passed to simple methods which print the timestamp |
---|
12 | and addr1 fields in receied packets. |
---|
13 | |
---|
14 | Copyright (c) 2019 Mango Communications, Inc. |
---|
15 | """ |
---|
16 | |
---|
17 | import wlan_exp.config as config |
---|
18 | import wlan_exp.util as util |
---|
19 | import wlan_exp.log.util as log_util |
---|
20 | |
---|
21 | import time |
---|
22 | |
---|
23 | NETWORK = '10.0.0.0' |
---|
24 | NODE_SERIAL_LIST = ['W3-a-00001'] |
---|
25 | |
---|
26 | # Experiment params |
---|
27 | RUN_TIME = 10 #seconds |
---|
28 | POLL_INTERVAL = 0.250 #seconds |
---|
29 | |
---|
30 | def init_experiment(): |
---|
31 | # Initialize the wlan_exp network config and the 802.11 Ref Design nodes |
---|
32 | network_config = config.WlanExpNetworkConfiguration(network=NETWORK, jumbo_frame_support=False) |
---|
33 | nodes_config = config.WlanExpNodesConfiguration(network_config=network_config, serial_numbers=NODE_SERIAL_LIST) |
---|
34 | nodes = util.init_nodes(nodes_config, network_config) |
---|
35 | |
---|
36 | # This script uses a single node |
---|
37 | n = nodes[0] |
---|
38 | |
---|
39 | # Remove the node from any BSS |
---|
40 | n.configure_bss(None) |
---|
41 | |
---|
42 | # Reset the node's state, including the log |
---|
43 | n.reset_all() |
---|
44 | |
---|
45 | # Disbale the ETH A - Wireless bridge |
---|
46 | n.enable_ethernet_portal(enable=False) |
---|
47 | |
---|
48 | # Tune to the required channel |
---|
49 | n.set_radio_channel(1) |
---|
50 | |
---|
51 | # Enable wrapping in the log |
---|
52 | n.log_configure(log_wrap_enable=True) |
---|
53 | |
---|
54 | return n |
---|
55 | |
---|
56 | def run_experiment(n): |
---|
57 | END_TIME = time.time() + RUN_TIME |
---|
58 | |
---|
59 | while time.time() < END_TIME: |
---|
60 | log_data = n.log_get_all_new(log_tail_pad=0).get_bytes() |
---|
61 | if(len(log_data) > 0): |
---|
62 | raw_log_index = log_util.gen_raw_log_index(log_data) |
---|
63 | |
---|
64 | log_index = log_util.filter_log_index(raw_log_index, |
---|
65 | include_only=list(LOG_ENTRIES_CALLBACKS.keys()), |
---|
66 | merge={'RX_OFDM': ('RX_OFDM', 'RX_OFDM_LTG')}) |
---|
67 | |
---|
68 | filt_entries = log_util.log_data_to_np_arrays(log_data, log_index) |
---|
69 | |
---|
70 | # Iterate over any entries in this log data that have callbacks assigned |
---|
71 | for entry_type in filt_entries.keys(): |
---|
72 | LOG_ENTRIES_CALLBACKS[entry_type](filt_entries[entry_type]) |
---|
73 | |
---|
74 | time.sleep(POLL_INTERVAL) |
---|
75 | |
---|
76 | # Define callback functions to handle various log entry types |
---|
77 | # There must be one function here for each value in the |
---|
78 | # LOG_ENTRIES_CALLBACKS dictionary |
---|
79 | # |
---|
80 | def handle_rx_dsss(entries): |
---|
81 | for e in entries: |
---|
82 | print('--Rx DSSS-- MAC Time: {0:11d}, MAC Time Frac: {1:3d}, Addr 1: {2:012x}'.format( |
---|
83 | e['timestamp'], e['timestamp_frac'], e['addr1'])) |
---|
84 | |
---|
85 | def handle_rx_ofdm(entries): |
---|
86 | for e in entries: |
---|
87 | print('--Rx OFDM-- MAC Time: {0:11d}, MAC Time Frac: {1:3d}, Addr 1: {2:012x}'.format( |
---|
88 | e['timestamp'], e['timestamp_frac'], e['addr1'])) |
---|
89 | |
---|
90 | ######################### |
---|
91 | |
---|
92 | # Define mapping of log entry types and callback functions |
---|
93 | # Entry types not lists here will be ignored |
---|
94 | LOG_ENTRIES_CALLBACKS = {'RX_DSSS': handle_rx_dsss, 'RX_OFDM': handle_rx_ofdm} |
---|
95 | |
---|
96 | n = init_experiment() |
---|
97 | run_experiment(n) |
---|
98 | |
---|