# Copyright © 2021 Naturalpoint
#
# Licensed under the Apache License, Version 2.0 (the "License")
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# OptiTrack NatNet direct depacketization sample for Python 3.x
#
# Uses the Python NatNetClient.py library to establish a connection (by creating a NatNetClient),
# and receive data via a NatNet connection and decode it using the NatNetClient library.
# Utility functions
import copy
import hashlib
import random
K_SKIP = [0, 0, 1]
K_FAIL = [0, 1, 0]
K_PASS = [1, 0, 0]
# get_tab_str
# generate a string that takes the nesting level into account
[docs]def get_tab_str(tab_str, level):
out_tab_str = ""
loop_range = range(0, level)
for _ in loop_range:
out_tab_str += tab_str
return out_tab_str
[docs]def add_lists(totals, totals_tmp):
totals[0] += totals_tmp[0]
totals[1] += totals_tmp[1]
totals[2] += totals_tmp[2]
return totals
[docs]def test_hash(test_name, test_hash_str, test_object):
out_str = test_object.get_as_string()
out_hash_str = hashlib.sha1(out_str.encode()).hexdigest()
ret_value = True
if test_hash_str == out_hash_str:
print("[PASS]:%s" % test_name)
else:
print("[FAIL]:%s test_hash_str != out_hash_str" % test_name)
print("test_hash_str=%s" % test_hash_str)
print("out_hash_str=%s" % out_hash_str)
print("out_str =\n%s" % out_str)
ret_value = False
return ret_value
[docs]def test_hash2(test_name, test_hash_str, test_object, run_test=True):
ret_value = K_FAIL
out_str = "FAIL"
out_str2 = ""
indent_string = " "
if not run_test:
ret_value = K_SKIP
out_str = "SKIP"
elif test_object == None:
out_str = "FAIL"
ret_value = K_FAIL
out_str2 = "%sERROR: test_object was None" % indent_string
else:
if str(type(test_object)) != "NoneType":
obj_out_str = test_object.get_as_string()
obj_out_hash_str = hashlib.sha1(obj_out_str.encode()).hexdigest()
if test_hash_str == obj_out_hash_str:
out_str = "PASS"
ret_value = K_PASS
else:
out_str2 += "%s%s test_hash_str != out_hash_str\n" % (
indent_string,
test_name,
)
out_str2 += "%stest_hash_str=%s\n" % (indent_string, test_hash_str)
out_str2 += "%sobj_out_hash_str=%s\n" % (indent_string, obj_out_hash_str)
out_str2 += "%sobj_out_str =\n%s" % (indent_string, obj_out_str)
ret_value = K_FAIL
print("[%s]:%s" % (out_str, test_name))
if len(out_str2):
print("%s" % out_str2)
return ret_value
[docs]def get_as_string(input_str):
type_input_str = str(type(input_str))
if type_input_str == "<class 'str'>":
return input_str
elif type_input_str == "<class 'NoneType'>":
return ""
elif type_input_str == "<class 'bytes'>":
return input_str.decode("utf-8")
else:
print("type_input_str = %s NOT HANDLED" % type_input_str)
return input_str
# MoCap Frame Classes
[docs]class FramePrefixData:
def __init__(self, frame_number):
self.frame_number = frame_number
[docs] def get_as_string(self, tab_str=" ", level=0):
out_tab_str = get_tab_str(tab_str, level)
out_str = "%sFrame #: %3.1d\n" % (out_tab_str, self.frame_number)
return out_str
[docs]class MarkerData:
def __init__(self):
self.model_name = ""
self.marker_pos_list = []
[docs] def set_model_name(self, model_name):
self.model_name = model_name
[docs] def add_pos(self, pos):
self.marker_pos_list.append(copy.deepcopy(pos))
return len(self.marker_pos_list)
[docs] def get_num_points(self):
return len(self.marker_pos_list)
[docs] def get_as_string(self, tab_str=" ", level=0):
out_tab_str = get_tab_str(tab_str, level)
out_tab_str2 = get_tab_str(tab_str, level + 1)
out_str = ""
if self.model_name != "":
out_str += "%sModel Name : %s\n" % (
out_tab_str,
get_as_string(self.model_name),
)
marker_count = len(self.marker_pos_list)
out_str += "%sMarker Count :%3.1d\n" % (out_tab_str, marker_count)
for i in range(marker_count):
pos = self.marker_pos_list[i]
out_str += "%sMarker %3.1d pos : [%3.2f,%3.2f,%3.2f]\n" % (
out_tab_str2,
i,
pos[0],
pos[1],
pos[2],
)
return out_str
[docs]class MarkerSetData:
def __init__(self):
self.marker_data_list = []
self.unlabeled_markers = MarkerData()
self.unlabeled_markers.set_model_name("")
[docs] def add_marker_data(self, marker_data):
self.marker_data_list.append(copy.deepcopy(marker_data))
return len(self.marker_data_list)
[docs] def add_unlabeled_marker(self, pos):
self.unlabeled_markers.add_pos(pos)
[docs] def get_marker_set_count(self):
return len(self.marker_data_list)
[docs] def get_unlabeled_marker_count(self):
return self.unlabeled_markers.get_num_points()
[docs] def get_as_string(self, tab_str=" ", level=0):
out_tab_str = get_tab_str(tab_str, level)
out_str = ""
# Labeled markers count
marker_data_count = len(self.marker_data_list)
out_str += "%sMarker Set Count:%3.1d\n" % (out_tab_str, marker_data_count)
for marker_data in self.marker_data_list:
out_str += marker_data.get_as_string(tab_str, level + 1)
# Unlabeled markers count (4 bytes)
unlabeled_markers_count = self.unlabeled_markers.get_num_points()
out_str += "%sUnlabeled Markers Count:%3.1d\n" % (
out_tab_str,
unlabeled_markers_count,
)
out_str += self.unlabeled_markers.get_as_string(tab_str, level + 1)
return out_str
[docs]class RigidBodyMarker:
def __init__(self):
self.pos = [0.0, 0.0, 0.0]
self.id_num = 0
self.size = 0
self.error = 0
[docs] def get_as_string(self, tab_str=" ", level=0):
out_tab_str = get_tab_str(tab_str, level)
out_str = ""
out_str += "%sPosition: [%3.2f %3.2f %3.2f]\n" % (
out_tab_str,
self.pos[0],
self.pos[1],
self.pos[2],
)
out_str += "%sID : %3.1d\n" % (out_tab_str, self.id_num)
out_str += "%sSize : %3.1d\n" % (out_tab_str, self.size)
return out_str
[docs]class RigidBody:
def __init__(self, new_id, pos, rot):
self.id_num = new_id
self.pos = pos
self.rot = rot
self.rb_marker_list = []
self.tracking_valid = False
self.error = 0.0
[docs] def add_rigid_body_marker(self, rigid_body_marker):
self.rb_marker_list.append(copy.deepcopy(rigid_body_marker))
return len(self.rb_marker_list)
[docs] def get_as_string(self, tab_str=0, level=0):
out_tab_str = get_tab_str(tab_str, level)
out_tab_str2 = get_tab_str(tab_str, level + 1)
out_str = ""
# header
out_str += "%sID : %3.1d\n" % (out_tab_str, self.id_num)
# Position and orientation
out_str += "%sPosition : [%3.2f, %3.2f, %3.2f]\n" % (
out_tab_str,
self.pos[0],
self.pos[1],
self.pos[2],
)
out_str += "%sOrientation : [%3.2f, %3.2f, %3.2f, %3.2f]\n" % (
out_tab_str,
self.rot[0],
self.rot[1],
self.rot[2],
self.rot[3],
)
marker_count = len(self.rb_marker_list)
marker_count_range = range(0, marker_count)
# Marker Data
if marker_count > 0:
out_str += "%sMarker Count: %3.1d\n" % (out_tab_str, marker_count)
for i in marker_count_range:
out_str += "%sMarker %3.1d\n" % (out_tab_str2, i)
rbmarker = self.rb_marker_list[i]
out_str += rbmarker.get_as_string(tab_str, level + 2)
out_str += "%sMarker Error : %3.2f\n" % (out_tab_str, self.error)
# Valid Tracking
tf_string = "False"
if self.tracking_valid:
tf_string = "True"
out_str += "%sTracking Valid: %s\n" % (out_tab_str, tf_string)
return out_str
[docs]class RigidBodyData:
def __init__(self):
self.rigid_body_list = []
[docs] def add_rigid_body(self, rigid_body):
self.rigid_body_list.append(copy.deepcopy(rigid_body))
return len(self.rigid_body_list)
[docs] def get_rigid_body_count(self):
return len(self.rigid_body_list)
[docs] def get_as_string(self, tab_str=" ", level=0):
out_tab_str = get_tab_str(tab_str, level)
out_str = ""
rigid_body_count = len(self.rigid_body_list)
out_str += "%sRigid Body Count: %3.1d\n" % (out_tab_str, rigid_body_count)
for rigid_body in self.rigid_body_list:
out_str += rigid_body.get_as_string(tab_str, level + 1)
return out_str
[docs]class Skeleton:
def __init__(self, new_id=0):
self.id_num = new_id
self.rigid_body_list = []
[docs] def add_rigid_body(self, rigid_body):
self.rigid_body_list.append(copy.deepcopy(rigid_body))
return len(self.rigid_body_list)
[docs] def get_as_string(self, tab_str=" ", level=0):
out_tab_str = get_tab_str(tab_str, level)
out_tab_str2 = get_tab_str(tab_str, level + 1)
out_str = ""
out_str += "%sID: %3.1d\n" % (out_tab_str, self.id_num)
rigid_body_count = len(self.rigid_body_list)
out_str += "%sRigid Body Count: %3.1d\n" % (out_tab_str, rigid_body_count)
for rb_num in range(rigid_body_count):
out_str += "%sRigid Body %3.1d\n" % (out_tab_str2, rb_num)
out_str += self.rigid_body_list[rb_num].get_as_string(tab_str, level + 2)
return out_str
[docs]class SkeletonData:
def __init__(self):
self.skeleton_list = []
[docs] def add_skeleton(self, new_skeleton):
self.skeleton_list.append(copy.deepcopy(new_skeleton))
[docs] def get_skeleton_count(self):
return len(self.skeleton_list)
[docs] def get_as_string(self, tab_str=" ", level=0):
out_tab_str = get_tab_str(tab_str, level)
out_tab_str2 = get_tab_str(tab_str, level + 1)
out_str = ""
skeleton_count = len(self.skeleton_list)
out_str += "%sSkeleton Count: %3.1d\n" % (out_tab_str, skeleton_count)
for skeleton_num in range(skeleton_count):
out_str += "%sSkeleton %3.1d\n" % (out_tab_str2, skeleton_num)
out_str += self.skeleton_list[skeleton_num].get_as_string(
tab_str, level + 2
)
return out_str
[docs]class LabeledMarker:
def __init__(self, new_id, pos, size=0.0, param=0, residual=0.0):
self.id_num = new_id
self.pos = pos
self.size = size
self.param = param
self.residual = residual
if str(type(size)) == "<class 'tuple'>":
self.size = size[0]
def __decode_marker_id(self):
model_id = self.id_num >> 16
marker_id = self.id_num & 0x0000FFFF
return model_id, marker_id
def __decode_param(self):
occluded = (self.param & 0x01) != 0
point_cloud_solved = (self.param & 0x02) != 0
model_solved = (self.param & 0x04) != 0
return occluded, point_cloud_solved, model_solved
[docs] def get_as_string(self, tab_str, level):
out_tab_str = get_tab_str(tab_str, level)
model_id, marker_id = self.__decode_marker_id()
out_str = ""
out_str += "%sID : [MarkerID: %3.1d] [ModelID: %3.1d]\n" % (
out_tab_str,
marker_id,
model_id,
)
out_str += "%spos : [%3.2f, %3.2f, %3.2f]\n" % (
out_tab_str,
self.pos[0],
self.pos[1],
self.pos[2],
)
out_str += "%ssize : [%3.2f]\n" % (out_tab_str, self.size)
occluded, point_cloud_solved, model_solved = self.__decode_param()
out_str += "%soccluded : [%3.1d]\n" % (out_tab_str, occluded)
out_str += "%spoint_cloud_solved : [%3.1d]\n" % (
out_tab_str,
point_cloud_solved,
)
out_str += "%smodel_solved : [%3.1d]\n" % (out_tab_str, model_solved)
out_str += "%serr : [%3.2f]\n" % (out_tab_str, self.residual)
return out_str
[docs]class LabeledMarkerData:
def __init__(self):
self.labeled_marker_list = []
[docs] def add_labeled_marker(self, labeled_marker):
self.labeled_marker_list.append(copy.deepcopy(labeled_marker))
return len(self.labeled_marker_list)
[docs] def get_labeled_marker_count(self):
return len(self.labeled_marker_list)
[docs] def get_as_string(self, tab_str=" ", level=0):
out_tab_str = get_tab_str(tab_str, level)
out_tab_str2 = get_tab_str(tab_str, level + 1)
out_str = ""
labeled_marker_count = len(self.labeled_marker_list)
out_str += "%sLabeled Marker Count:%3.1d\n" % (
out_tab_str,
labeled_marker_count,
)
for i in range(0, labeled_marker_count):
out_str += "%sLabeled Marker %3.1d\n" % (out_tab_str2, i)
labeled_marker = self.labeled_marker_list[i]
out_str += labeled_marker.get_as_string(tab_str, level + 2)
return out_str
[docs]class ForcePlateChannelData:
def __init__(self):
# list of floats
self.frame_list = []
[docs] def add_frame_entry(self, frame_entry):
self.frame_list.append(copy.deepcopy(frame_entry))
return len(self.frame_list)
[docs] def get_as_string(self, tab_str, level, channel_num=-1):
fc_max = 4
out_tab_str = get_tab_str(tab_str, level)
out_str = ""
frame_count = len(self.frame_list)
fc_show = min(frame_count, fc_max)
out_str += "%s" % (out_tab_str)
if channel_num >= 0:
out_str += "Channel %3.1d: " % channel_num
out_str += "%3.1d Frames - Frame Data: " % (frame_count)
for i in range(fc_show):
out_str += "%3.2f " % (self.frame_list[i])
if fc_show < frame_count:
out_str += " - Showing %3.1d of %3.1d frames" % (fc_show, frame_count)
out_str += "\n"
return out_str
[docs]class ForcePlate:
def __init__(self, new_id=0):
self.id_num = new_id
self.channel_data_list = []
[docs] def add_channel_data(self, channel_data):
self.channel_data_list.append(copy.deepcopy(channel_data))
return len(self.channel_data_list)
[docs] def get_as_string(self, tab_str, level):
out_tab_str = get_tab_str(tab_str, level)
out_str = ""
out_str += "%sID : %3.1d" % (out_tab_str, self.id_num)
num_channels = len(self.channel_data_list)
out_str += "%sChannel Count: %3.1d\n" % (out_tab_str, num_channels)
for i in range(num_channels):
out_str += self.channel_data_list[i].get_as_string(tab_str, level + 1, i)
return out_str
[docs]class ForcePlateData:
def __init__(self):
self.force_plate_list = []
[docs] def add_force_plate(self, force_plate):
self.force_plate_list.append(copy.deepcopy(force_plate))
return len(self.force_plate_list)
[docs] def get_force_plate_count(self):
return len(self.force_plate_list)
[docs] def get_as_string(self, tab_str=" ", level=0):
out_tab_str = get_tab_str(tab_str, level)
out_tab_str2 = get_tab_str(tab_str, level + 1)
out_str = ""
force_plate_count = len(self.force_plate_list)
out_str += "%sForce Plate Count: %3.1d\n" % (out_tab_str, force_plate_count)
for i in range(force_plate_count):
out_str += "%sForce Plate %3.1d\n" % (out_tab_str2, i)
out_str += self.force_plate_list[i].get_as_string(tab_str, level + 2)
return out_str
[docs]class DeviceChannelData:
def __init__(self):
# list of floats
self.frame_list = []
[docs] def add_frame_entry(self, frame_entry):
self.frame_list.append(copy.deepcopy(frame_entry))
return len(self.frame_list)
[docs] def get_as_string(self, tab_str, level, channel_num=-1):
fc_max = 4
out_tab_str = get_tab_str(tab_str, level)
out_str = ""
frame_count = len(self.frame_list)
fc_show = min(frame_count, fc_max)
out_str += "%s" % (out_tab_str)
if channel_num >= 0:
out_str += "Channel %3.1d: " % channel_num
out_str += "%3.1d Frames - Frame Data: " % (frame_count)
for i in range(fc_show):
out_str += "%3.2f " % (self.frame_list[i])
if fc_show < frame_count:
out_str += " - Showing %3.1d of %3.1d frames" % (fc_show, frame_count)
out_str += "\n"
return out_str
[docs]class Device:
def __init__(self, new_id):
self.id_num = new_id
self.channel_data_list = []
[docs] def add_channel_data(self, channel_data):
self.channel_data_list.append(copy.deepcopy(channel_data))
return len(self.channel_data_list)
[docs] def get_as_string(self, tab_str, level, device_num):
out_tab_str = get_tab_str(tab_str, level)
out_str = ""
num_channels = len(self.channel_data_list)
out_str += "%sDevice %3.1d ID: %3.1d Num Channels: %3.1d\n" % (
out_tab_str,
device_num,
self.id_num,
num_channels,
)
for i in range(num_channels):
out_str += self.channel_data_list[i].get_as_string(tab_str, level + 1, i)
return out_str
[docs]class DeviceData:
def __init__(self):
self.device_list = []
[docs] def add_device(self, device):
self.device_list.append(copy.deepcopy(device))
return len(self.device_list)
[docs] def get_device_count(self):
return len(self.device_list)
[docs] def get_as_string(self, tab_str=" ", level=0):
out_tab_str = get_tab_str(tab_str, level)
out_str = ""
device_count = len(self.device_list)
out_str += "%sDevice Count: %3.1d\n" % (out_tab_str, device_count)
for i in range(device_count):
out_str += self.device_list[i].get_as_string(tab_str, level + 1, i)
return out_str
[docs]class FrameSuffixData:
def __init__(self):
self.timecode = -1
self.timecode_sub = -1
self.timestamp = -1
self.stamp_camera_mid_exposure = -1
self.stamp_data_received = -1
self.stamp_transmit = -1
self.param = 0
self.is_recording = False
self.tracked_models_changed = True
[docs] def get_as_string(self, tab_str=" ", level=0):
out_tab_str = get_tab_str(tab_str, level)
out_str = ""
if not self.timestamp == -1:
out_str += "%sTimestamp : %3.2f\n" % (out_tab_str, self.timestamp)
if not self.stamp_camera_mid_exposure == -1:
out_str += "%sMid-exposure timestamp : %3.1d\n" % (
out_tab_str,
self.stamp_camera_mid_exposure,
)
if not self.stamp_data_received == -1:
out_str += "%sCamera data received timestamp : %3.1d\n" % (
out_tab_str,
self.stamp_data_received,
)
if not self.stamp_transmit == -1:
out_str += "%sTransmit timestamp : %3.1d\n" % (
out_tab_str,
self.stamp_transmit,
)
return out_str
[docs]class MoCapData:
def __init__(self):
# Packet Parts
self.prefix_data = None
self.marker_set_data = None
self.rigid_body_data = None
self.skeleton_data = None
self.labeled_marker_data = None
self.force_plate_data = None
self.device_data = None
self.suffix_data = None
[docs] def set_prefix_data(self, new_prefix_data):
self.prefix_data = new_prefix_data
[docs] def set_marker_set_data(self, new_marker_set_data):
self.marker_set_data = new_marker_set_data
[docs] def set_rigid_body_data(self, new_rigid_body_data):
self.rigid_body_data = new_rigid_body_data
[docs] def set_skeleton_data(self, new_skeleton_data):
self.skeleton_data = new_skeleton_data
[docs] def set_labeled_marker_data(self, new_labeled_marker_data):
self.labeled_marker_data = new_labeled_marker_data
[docs] def set_force_plate_data(self, new_force_plate_data):
self.force_plate_data = new_force_plate_data
[docs] def set_device_data(self, new_device_data):
self.device_data = new_device_data
[docs] def set_suffix_data(self, new_suffix_data):
self.suffix_data = new_suffix_data
[docs] def get_as_string(self, tab_str=" ", level=0):
out_tab_str = get_tab_str(tab_str, level)
out_str = ""
out_str += "%sMoCap Frame Begin\n%s-----------------\n" % (
out_tab_str,
out_tab_str,
)
if not self.prefix_data == None:
out_str += self.prefix_data.get_as_string()
else:
out_str += "%sNo Prefix Data Set\n" % (out_tab_str)
if not self.marker_set_data == None:
out_str += self.marker_set_data.get_as_string(tab_str, level + 1)
else:
out_str += "%sNo Marker Set Data Set\n" % (out_tab_str)
if not self.rigid_body_data == None:
out_str += self.rigid_body_data.get_as_string(tab_str, level + 1)
else:
out_str += "%sNo Rigid Body Data Set\n" % (out_tab_str)
if not self.skeleton_data == None:
out_str += self.skeleton_data.get_as_string(tab_str, level + 1)
else:
out_str += "%sNo Skeleton Data Set\n" % (out_tab_str)
if not self.labeled_marker_data == None:
out_str += self.labeled_marker_data.get_as_string(tab_str, level + 1)
else:
out_str += "%sNo Labeled Marker Data Set\n" % (out_tab_str)
if not self.force_plate_data == None:
out_str += self.force_plate_data.get_as_string(tab_str, level + 1)
else:
out_str += "%sNo Force Plate Data Set\n" % (out_tab_str)
if not self.device_data == None:
out_str += self.device_data.get_as_string(tab_str, level + 1)
else:
out_str += "%sNo Device Data Set\n" % (out_tab_str)
if not self.suffix_data == None:
out_str += self.suffix_data.get_as_string(tab_str, level + 1)
else:
out_str += "%sNo Suffix Data Set\n" % (out_tab_str)
out_str += "%sMoCap Frame End\n%s-----------------\n" % (
out_tab_str,
out_tab_str,
)
return out_str
# test program
[docs]def generate_prefix_data(frame_num=0):
frame_prefix_data = FramePrefixData(frame_num)
return frame_prefix_data
[docs]def generate_label(label_base="label", label_num=0):
out_label = "%s_%3.3d" % (label_base, label_num)
return out_label
[docs]def generate_position_srand(pos_num=0, frame_num=0):
random.seed(pos_num + (frame_num * 1000))
position = [
(random.random() * 100),
(random.random() * 100),
(random.random() * 100),
]
return position
[docs]def generate_marker_data(label_base, label_num, num_points=1):
label = generate_label(label_base, label_num)
if (label_base == None) or (label_base == ""):
label = ""
marker_data = MarkerData()
marker_data.set_model_name(label)
start_num = label_num * 10000
end_num = start_num + num_points
for point_num in range(start_num, end_num):
position = generate_position_srand(point_num)
marker_data.add_pos(position)
return marker_data
[docs]def generate_marker_set_data(frame_num=0, marker_set_num=0):
marker_set_data = MarkerSetData()
# add labeled markers
marker_set_data.add_marker_data(generate_marker_data("marker", 0, 3))
marker_set_data.add_marker_data(generate_marker_data("marker", 1, 6))
marker_set_data.add_marker_data(generate_marker_data("marker", 2, 5))
# add unlabeled markers
num_points = 5
start_num = (frame_num * 100000) + (10000 + marker_set_num)
end_num = start_num + num_points
for point_num in range(start_num, end_num):
position = generate_position_srand(point_num)
marker_set_data.add_unlabeled_marker(position)
return marker_set_data
[docs]def generate_rigid_body_marker_srand(marker_num=0, frame_num=0):
rigid_body_marker = RigidBodyMarker()
rbm_num = 11000 + marker_num
random.seed(rbm_num)
rigid_body_marker.pos = generate_position_srand(rbm_num, frame_num)
rigid_body_marker.id_num = marker_num
rigid_body_marker.size = 1
rigid_body_marker.error = random.random()
return rigid_body_marker
[docs]def generate_rigid_body(body_num=0, frame_num=0):
pos = generate_position_srand(10000 + body_num, frame_num)
rot = [1, 0, 0, 0]
rigid_body = RigidBody(body_num, pos, rot)
rigid_body.add_rigid_body_marker(generate_rigid_body_marker_srand(0, frame_num))
rigid_body.add_rigid_body_marker(generate_rigid_body_marker_srand(1, frame_num))
rigid_body.add_rigid_body_marker(generate_rigid_body_marker_srand(2))
return rigid_body
[docs]def generate_rigid_body_data(frame_num=0):
rigid_body_data = RigidBodyData()
# add rigid bodies
rigid_body_data.add_rigid_body(generate_rigid_body(0, frame_num))
rigid_body_data.add_rigid_body(generate_rigid_body(1, frame_num))
rigid_body_data.add_rigid_body(generate_rigid_body(2, frame_num))
return rigid_body_data
[docs]def generate_skeleton(frame_num=0, skeleton_num=0, num_rbs=1):
skeleton = Skeleton(skeleton_num)
# add rigid bodies
rb_seed_start = skeleton_num * 165
rb_seed_end = rb_seed_start + num_rbs
for rb_num in range(rb_seed_start, rb_seed_end):
skeleton.add_rigid_body(generate_rigid_body(rb_num, frame_num))
return skeleton
[docs]def generate_skeleton_data(frame_num=0):
skeleton_data = SkeletonData()
skeleton_data.add_skeleton(generate_skeleton(frame_num, 0, 2))
skeleton_data.add_skeleton(generate_skeleton(frame_num, 1, 6))
skeleton_data.add_skeleton(generate_skeleton(frame_num, 2, 3))
return skeleton_data
[docs]def generate_labeled_marker(frame_num=0, marker_num=0):
point_num = (frame_num * 2000) + marker_num
pos = generate_position_srand(point_num)
size = 1
param = 0
# occluded 0x01
param += 0x01 * 0
# point_cloud_solved 0x02
param += 0x02 * 0
# model_solved 0x04
param += 0x04 * 1
residual = 0.01
return LabeledMarker(marker_num, pos, size, param, residual)
[docs]def generate_labeled_marker_data(frame_num=0):
labeled_marker_data = LabeledMarkerData()
# add labeled marker
labeled_marker_data.add_labeled_marker(generate_labeled_marker(frame_num, 0))
labeled_marker_data.add_labeled_marker(generate_labeled_marker(frame_num, 1))
labeled_marker_data.add_labeled_marker(generate_labeled_marker(frame_num, 2))
return labeled_marker_data
[docs]def generate_fp_channel_data(frame_num=0, fp_num=0, channel_num=0, num_frames=1):
rseed = (frame_num * 100000) + (fp_num * 10000) + (channel_num * 1000)
random.seed(rseed)
fp_channel_data = ForcePlateChannelData()
for _ in range(num_frames):
fp_channel_data.add_frame_entry(100.0 * random.random())
return fp_channel_data
[docs]def generate_force_plate(frame_num=0, fp_num=0, num_channels=1):
force_plate = ForcePlate(fp_num)
# add channel_data
for i in range(num_channels):
force_plate.add_channel_data(generate_fp_channel_data(frame_num, fp_num, i, 10))
return force_plate
[docs]def generate_force_plate_data(frame_num=0):
force_plate_data = ForcePlateData()
# add force plates
force_plate_data.add_force_plate(generate_force_plate(frame_num, 0, 3))
force_plate_data.add_force_plate(generate_force_plate(frame_num, 1, 4))
force_plate_data.add_force_plate(generate_force_plate(frame_num, 2, 2))
return force_plate_data
[docs]def generate_device_channel_data(
frame_num=0, device_num=0, channel_num=0, num_frames=1
):
rseed = (frame_num * 100000) + (device_num * 10000) + (channel_num * 1000)
random.seed(rseed)
device_channel_data = DeviceChannelData()
for _ in range(num_frames):
device_channel_data.add_frame_entry(100.0 * random.random())
return device_channel_data
[docs]def generate_device(frame_num=0, device_num=0):
device = Device(device_num)
device.add_channel_data(generate_device_channel_data(frame_num, device_num, 1, 4))
device.add_channel_data(generate_device_channel_data(frame_num, device_num, 3, 2))
device.add_channel_data(generate_device_channel_data(frame_num, device_num, 7, 6))
return device
[docs]def generate_device_data(frame_num=0):
device_data = DeviceData()
device_data.add_device(generate_device(frame_num, 0))
device_data.add_device(generate_device(frame_num, 2))
return device_data
[docs]def generate_suffix_data(frame_num=0):
frame_suffix_data = FrameSuffixData()
frame_suffix_data.stamp_camera_mid_exposure = 5844402979291 + frame_num
frame_suffix_data.stamp_data_received = 0
frame_suffix_data.stamp_transmit = 5844403268753 + frame_num
frame_suffix_data.timecode = 0
frame_suffix_data.timecode_sub = 0
frame_suffix_data.timestamp = 762.63
return frame_suffix_data
[docs]def generate_mocap_data(frame_num=0):
mocap_data = MoCapData()
mocap_data.set_prefix_data(generate_prefix_data(frame_num))
mocap_data.set_marker_set_data(generate_marker_set_data(frame_num))
mocap_data.set_rigid_body_data(generate_rigid_body_data(frame_num))
mocap_data.set_skeleton_data(generate_skeleton_data(frame_num))
mocap_data.set_labeled_marker_data(generate_labeled_marker_data(frame_num))
mocap_data.set_force_plate_data(generate_force_plate_data(frame_num))
mocap_data.set_device_data(generate_device_data(frame_num))
mocap_data.set_suffix_data(generate_suffix_data(frame_num))
return mocap_data
[docs]def test_all(run_test=True):
totals = [0, 0, 0]
if run_test is True:
test_cases = [
[
"Test Prefix Data 0",
"bffba016d02cf2167780df31aee697e1ec746b4c",
"generate_prefix_data(0)",
True,
],
[
"Test Marker Set Data 0",
"d2550194fed1b1fc525f4f4d06bf584f291f41c7",
"generate_marker_set_data(0)",
True,
],
[
"Test Rigid Body Data 0",
"abd1a48a476eaa9b5c4fae6e705e03aa75f85624",
"generate_rigid_body_data(0)",
True,
],
[
"Test Skeleton Data 0",
"1e36e3334e291cebfaa530d7aab2122d6983ecab",
"generate_skeleton_data(0)",
True,
],
[
"Test Labeled Marker Data 0",
"25f3ee026c3c8fc716fbb05c34138ef5afd95d75",
"generate_labeled_marker_data(0)",
True,
],
[
"Test Force Plate Data 0",
"b83d04a1b89169bdcefee3bc3951c3bdcb6b792e",
"generate_force_plate_data(0)",
True,
],
[
"Test Device Data 0",
"be10f0b93a7ba3858dce976b7868c1f79fd719c3",
"generate_device_data(0)",
True,
],
[
"Test Suffix Data 0",
"6aa02c434bdb53a418ae1b1f73317dc80a5f887d",
"generate_suffix_data(0)",
True,
],
[
"Test MoCap Data 0",
"09930ecf665d9eb3ca61616f9bcc55890373f414",
"generate_mocap_data(0)",
True,
],
]
num_tests = len(test_cases)
for i in range(num_tests):
data = eval(test_cases[i][2])
totals_tmp = test_hash2(
test_cases[i][0], test_cases[i][1], data, test_cases[i][3]
)
totals = add_lists(totals, totals_tmp)
print("--------------------")
print("[PASS] Count = %3.1d" % totals[0])
print("[FAIL] Count = %3.1d" % totals[1])
print("[SKIP] Count = %3.1d" % totals[2])
return totals
if __name__ == "__main__":
test_all(True)