# 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.
import copy
import hashlib
import random
K_SKIP = [0, 0, 1]
K_FAIL = [0, 1, 0]
K_PASS = [1, 0, 0]
[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:
obj_out_hash_str = ""
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):
if type(input_str) == str:
return input_str
else:
return input_str.decode("utf-8")
[docs]def get_data_sub_packet_type(new_data):
out_string = ""
data_type = type(new_data)
if data_type == MarkerSetDescription:
out_string = "Type: 0 Markerset\n"
elif data_type == RigidBodyDescription:
out_string = "Type: 1 Rigid Body\n"
elif data_type == SkeletonDescription:
out_string = "Type: 2 Skeleton\n"
elif data_type == ForcePlateDescription:
out_string = "Type: 3 Force Plate\n"
elif data_type == DeviceDescription:
out_string = "Type: 4 Device\n"
elif data_type == CameraDescription:
out_string = "Type: 5 Camera\n"
elif data_type == None:
out_string = "Type: None\n"
else:
out_string = "Type: Unknown %s\n" % str(data_type)
return out_string
# cMarkerSetDescription
[docs]class MarkerSetDescription:
def __init__(self):
self.marker_set_name = "Not Set"
self.marker_names_list = []
[docs] def set_name(self, new_name):
self.marker_set_name = new_name
[docs] def get_num_markers(self):
return len(self.marker_names_list)
[docs] def add_marker_name(self, marker_name):
self.marker_names_list.append(copy.copy(marker_name))
return self.get_num_markers()
[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_tab_str3 = get_tab_str(tab_str, level + 2)
out_string = ""
out_string += "%sMarker Set Name: %s\n" % (
out_tab_str,
get_as_string(self.marker_set_name),
)
num_markers = len(self.marker_names_list)
out_string += "%sMarker Count : %d\n" % (out_tab_str2, num_markers)
for i in range(num_markers):
out_string += "%s%3.1d Marker Name: %s\n" % (
out_tab_str3,
i,
get_as_string(self.marker_names_list[i]),
)
return out_string
[docs]class RBMarker:
def __init__(self, marker_name="", active_label=0, pos=[0.0, 0.0, 0.0]):
self.marker_name = marker_name
self.active_label = active_label
self.pos = pos
[docs] def get_as_string(self, tab_str=" ", level=0):
out_tab_str = get_tab_str(tab_str, level)
out_string = ""
out_string += "%sMarker Label: %s Position: [%f %f %f] %s\n" % (
out_tab_str,
self.active_label,
self.pos[0],
self.pos[1],
self.pos[2],
self.marker_name,
)
return out_string
[docs]class RigidBodyDescription:
def __init__(self, sz_name="", new_id=0, parent_id=0, pos=[0.0, 0.0, 0.0]):
self.sz_name = sz_name
self.id_num = new_id
self.parent_id = parent_id
self.pos = pos
self.rb_marker_list = []
[docs] def set_name(self, new_name):
self.sz_name = new_name
[docs] def set_id(self, new_id):
self.id_num = new_id
[docs] def set_parent_id(self, parent_id):
self.parent_id = parent_id
[docs] def set_pos(self, p_x, p_y, p_z):
self.pos = [p_x, p_y, p_z]
[docs] def get_num_markers(self):
return len(self.rb_marker_list)
[docs] def add_rb_marker(self, new_rb_maker):
self.rb_marker_list.append(copy.deepcopy(new_rb_maker))
return self.get_num_markers()
[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_string = ""
out_string += "%sRigid Body Name : %s\n" % (
out_tab_str,
get_as_string(self.sz_name),
)
out_string += "%sID : %d\n" % (out_tab_str, self.id_num)
out_string += "%sParent ID : %d\n" % (out_tab_str, self.parent_id)
out_string += "%sPosition : [%3.2f, %3.2f, %3.2f]\n" % (
out_tab_str,
self.pos[0],
self.pos[1],
self.pos[2],
)
num_markers = len(self.rb_marker_list)
out_string += "%sNumber of Markers : %d\n" % (out_tab_str, num_markers)
# loop over markers
for i in range(num_markers):
out_string += "%s%i %s" % (
out_tab_str2,
i,
self.rb_marker_list[i].get_as_string(tab_str, 0),
)
return out_string
[docs]class SkeletonDescription:
def __init__(self, name="", new_id=0):
self.name = name
self.id_num = new_id
self.rigid_body_description_list = []
[docs] def set_name(self, new_name):
self.name = new_name
[docs] def set_id(self, new_id):
self.id_num = new_id
[docs] def add_rigid_body_description(self, rigid_body_description):
self.rigid_body_description_list.append(copy.deepcopy(rigid_body_description))
return len(self.rigid_body_description_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_string = ""
out_string += "%sName : %s\n" % (
out_tab_str,
get_as_string(self.name),
)
out_string += "%sID : %d\n" % (out_tab_str, self.id_num)
num_bones = len(self.rigid_body_description_list)
out_string += "%sRigid Body (Bone) Count : %d\n" % (out_tab_str, num_bones)
for i in range(num_bones):
out_string += "%sRigid Body (Bone) %d\n" % (out_tab_str2, i)
out_string += self.rigid_body_description_list[i].get_as_string(
tab_str, level + 2
)
return out_string
[docs]class ForcePlateDescription:
def __init__(self, new_id=0, serial_number=""):
self.id_num = new_id
self.serial_number = serial_number
self.width = 0
self.length = 0
self.position = [0.0, 0.0, 0.0]
self.cal_matrix = [[0.0 for col in range(12)] for row in range(12)]
self.corners = [[0.0 for col in range(3)] for row in range(4)]
self.plate_type = 0
self.channel_data_type = 0
self.channel_list = []
[docs] def set_id(self, new_id):
self.id_num = new_id
[docs] def set_serial_number(self, serial_number):
self.serial_number = serial_number
[docs] def set_dimensions(self, width, length):
self.width = width
self.length = length
[docs] def set_origin(self, p_x, p_y, p_z):
self.position = [p_x, p_y, p_z]
[docs] def set_cal_matrix(self, cal_matrix):
self.cal_matrix = cal_matrix
[docs] def set_corners(self, corners):
self.corners = corners
[docs] def set_plate_type(self, plate_type):
self.plate_type = plate_type
[docs] def set_channel_data_type(self, channel_data_type):
self.channel_data_type = channel_data_type
[docs] def add_channel_name(self, channel_name):
self.channel_list.append(copy.deepcopy(channel_name))
return len(self.channel_list)
[docs] def get_cal_matrix_as_string(self, tab_str="", level=0):
"""Get force plate calibration matrix as string"""
out_tab_str = get_tab_str(tab_str, level)
out_tab_str2 = get_tab_str(tab_str, level + 1)
out_string = ""
out_string += "%sCal Matrix:\n" % out_tab_str
for i in range(0, 12):
out_string += (
"%s%2.1d %3.3e %3.3e %3.3e %3.3e %3.3e %3.3e %3.3e %3.3e %3.3e %3.3e %3.3e %3.3e\n"
% (
out_tab_str2,
i,
self.cal_matrix[i][0],
self.cal_matrix[i][1],
self.cal_matrix[i][2],
self.cal_matrix[i][3],
self.cal_matrix[i][4],
self.cal_matrix[i][5],
self.cal_matrix[i][6],
self.cal_matrix[i][7],
self.cal_matrix[i][8],
self.cal_matrix[i][9],
self.cal_matrix[i][10],
self.cal_matrix[i][11],
)
)
return out_string
[docs] def get_corners_as_string(self, tab_str="", level=0):
"""Get force plate corner positions as a string"""
# Corners 4x3 floats
out_tab_str = get_tab_str(tab_str, level)
out_tab_str2 = get_tab_str(tab_str, level + 1)
out_string = ""
out_string += "%sCorners:\n" % out_tab_str
for i in range(0, 4):
out_string += "%s%2.1d %3.3e %3.3e %3.3e\n" % (
out_tab_str2,
i,
self.corners[i][0],
self.corners[i][1],
self.corners[i][2],
)
return out_string
[docs] def get_as_string(self, tab_str=" ", level=0):
"""Get force plate description as a class"""
out_tab_str = get_tab_str(tab_str, level)
out_string = ""
out_string += "%sID : %d\n" % (out_tab_str, self.id_num)
out_string += "%sSerial Number : %s\n" % (
out_tab_str,
get_as_string(self.serial_number),
)
out_string += "%sWidth : %3.2f\n" % (out_tab_str, self.width)
out_string += "%sLength : %3.2f\n" % (out_tab_str, self.length)
out_string += "%sOrigin : %3.2f, %3.2f, %3.2f\n" % (
out_tab_str,
self.position[0],
self.position[1],
self.position[2],
)
out_string += self.get_cal_matrix_as_string(tab_str, level)
out_string += self.get_corners_as_string(tab_str, level)
out_string += "%sPlate Type : %d\n" % (
out_tab_str,
self.plate_type,
)
out_string += "%sChannel Data Type : %d\n" % (
out_tab_str,
self.channel_data_type,
)
num_channels = len(self.channel_list)
out_string += "%sNumber of Channels : %d\n" % (out_tab_str, num_channels)
# Channel Names list of NoC strings
out_tab_str2 = get_tab_str(tab_str, level + 1)
for channel_num in range(num_channels):
out_string += "%sChannel Name %d: %s\n" % (
out_tab_str2,
channel_num,
get_as_string(self.channel_list[channel_num]),
)
return out_string
[docs]class DeviceDescription:
"""Device Description class"""
def __init__(self, new_id, name, serial_number, device_type, channel_data_type):
self.id_num = new_id
self.name = name
self.serial_number = serial_number
self.device_type = device_type
self.channel_data_type = channel_data_type
self.channel_list = []
[docs] def set_id(self, new_id):
"""Set the device id"""
self.id_num = new_id
[docs] def set_name(self, name):
"""Set the Device name"""
self.name = name
[docs] def add_channel_name(self, channel_name):
"""Add channel name to channel_list"""
self.channel_list.append(channel_name)
return len(self.channel_list)
[docs] def get_as_string(self, tab_str=" ", level=0):
"""Get Device Description as string"""
out_tab_str = get_tab_str(tab_str, level)
out_tab_str2 = get_tab_str(tab_str, level + 1)
out_string = ""
out_string += "%sID : %5.1d\n" % (out_tab_str, self.id_num)
out_string += "%sName : %s\n" % (
out_tab_str,
get_as_string(self.name),
)
out_string += "%sSerial Number : %s\n" % (
out_tab_str,
get_as_string(self.serial_number),
)
out_string += "%sDevice Type : %d\n" % (out_tab_str, self.device_type)
out_string += "%sChannel Data Type : %d\n" % (
out_tab_str,
self.channel_data_type,
)
num_channels = len(self.channel_list)
out_string += "%sNumber of Channels : %d\n" % (out_tab_str, num_channels)
for i in range(num_channels):
out_string += "%sChannel %2.1d Name : %s\n" % (
out_tab_str2,
i,
get_as_string(self.channel_list[i]),
)
return out_string
[docs]class CameraDescription:
"""Camera Description class"""
def __init__(self, name, position_vec3, orientation_quat):
self.name = name
self.position = position_vec3
self.orientation = orientation_quat
[docs] def get_as_string(self, tab_str="..", level=0):
"""Get Camera Description as a string"""
out_tab_str = get_tab_str(tab_str, level)
out_string = ""
out_string += "%sName : %s\n" % (out_tab_str, get_as_string(self.name))
out_string += "%sPosition : [%3.2f, %3.2f, %3.2f]\n" % (
out_tab_str,
self.position[0],
self.position[1],
self.position[2],
)
out_string += "%sOrientation : [%3.2f, %3.2f, %3.2f, %3.2f]\n" % (
out_tab_str,
self.orientation[0],
self.orientation[1],
self.orientation[2],
self.orientation[3],
)
return out_string
# cDataDescriptions
# Full data descriptions
[docs]class DataDescriptions:
"""Data Descriptions class"""
order_num = 0
def __init__(self):
self.data_order_dict = {}
self.marker_set_list = []
self.rigid_body_list = []
self.skeleton_list = []
self.force_plate_list = []
self.device_list = []
self.camera_list = []
[docs] def generate_order_name(self):
"""Generate the name for the order list based on the current length of the list"""
# should be a one up counter instead of based on length of data_order_dict
order_name = "data_%3.3d" % self.order_num
self.order_num += 1
return order_name
# Add Marker Set
[docs] def add_marker_set(self, new_marker_set):
"""Add a marker set"""
order_name = self.generate_order_name()
# generate order entry
pos = len(self.marker_set_list)
self.data_order_dict[order_name] = ("marker_set_list", pos)
self.marker_set_list.append(copy.deepcopy(new_marker_set))
# Add Rigid Body
[docs] def add_rigid_body(self, new_rigid_body):
"""Add a rigid body"""
order_name = self.generate_order_name()
# generate order entry
pos = len(self.rigid_body_list)
self.data_order_dict[order_name] = ("rigid_body_list", pos)
self.rigid_body_list.append(copy.deepcopy(new_rigid_body))
# Add a skeleton
[docs] def add_skeleton(self, new_skeleton):
"""Add a skeleton"""
order_name = self.generate_order_name()
# generate order entry
pos = len(self.skeleton_list)
self.data_order_dict[order_name] = ("skeleton_list", pos)
self.skeleton_list.append(copy.deepcopy(new_skeleton))
# Add a force plate
[docs] def add_force_plate(self, new_force_plate):
"""Add a force plate"""
order_name = self.generate_order_name()
# generate order entry
pos = len(self.force_plate_list)
self.data_order_dict[order_name] = ("force_plate_list", pos)
self.force_plate_list.append(copy.deepcopy(new_force_plate))
[docs] def add_device(self, newdevice):
"""add_device - Add a device"""
order_name = self.generate_order_name()
# generate order entry
pos = len(self.device_list)
self.data_order_dict[order_name] = ("device_list", pos)
self.device_list.append(copy.deepcopy(newdevice))
[docs] def add_camera(self, newcamera):
"""Add a new camera"""
order_name = self.generate_order_name()
# generate order entry
pos = len(self.camera_list)
self.data_order_dict[order_name] = ("camera_list", pos)
self.camera_list.append(copy.deepcopy(newcamera))
[docs] def add_data(self, new_data):
"""Add data based on data type"""
data_type = type(new_data)
if data_type == MarkerSetDescription:
self.add_marker_set(new_data)
elif data_type == RigidBodyDescription:
self.add_rigid_body(new_data)
elif data_type == SkeletonDescription:
self.add_skeleton(new_data)
elif data_type == ForcePlateDescription:
self.add_force_plate(new_data)
elif data_type == DeviceDescription:
self.add_device(new_data)
elif data_type == CameraDescription:
self.add_camera(new_data)
elif data_type is None:
data_type = None
else:
print("ERROR: Type %s unknown" % str(data_type))
[docs] def get_object_from_list(self, list_name, pos_num):
"""Determine list name and position of the object"""
ret_value = None
if (list_name == "marker_set_list") and (pos_num < len(self.marker_set_list)):
ret_value = self.marker_set_list[pos_num]
elif (list_name == "rigid_body_list") and (pos_num < len(self.rigid_body_list)):
ret_value = self.rigid_body_list[pos_num]
elif (list_name == "skeleton_list") and (pos_num < len(self.skeleton_list)):
ret_value = self.skeleton_list[pos_num]
elif (list_name == "force_plate_list") and (
pos_num < len(self.force_plate_list)
):
ret_value = self.force_plate_list[pos_num]
elif (list_name == "device_list") and (pos_num < len(self.device_list)):
ret_value = self.device_list[pos_num]
elif (list_name == "camera_list") and (pos_num < len(self.camera_list)):
ret_value = self.camera_list[pos_num]
else:
ret_value = None
return ret_value
[docs] def get_as_string(self, tab_str=" ", level=0):
"""Ensure data comes back as a string"""
out_tab_str = get_tab_str(tab_str, level)
out_tab_str2 = get_tab_str(tab_str, level + 1)
out_tab_str3 = get_tab_str(tab_str, level + 2)
out_string = ""
num_data_sets = len(self.data_order_dict)
out_string += "%sNumber of Data Sets: %d\n" % (out_tab_str, num_data_sets)
i = 0
for tmp_key, tmp_value in self.data_order_dict.items():
# tmp_name,tmp_num=self.data_order_dict[data_set]
tmp_name = tmp_value[0]
tmp_num = tmp_value[1]
tmp_object = self.get_object_from_list(tmp_name, tmp_num)
out_string += "%sDataset %3.1d\n" % (out_tab_str2, i)
tmp_string = get_data_sub_packet_type(tmp_object)
if tmp_string != "":
out_string += "%s%s" % (out_tab_str2, tmp_string)
# out_string += "%s%s %s %d\n"%(out_tab_str2, data_set, tmp_name,tmp_num)
out_string += "%s%s %s %s\n" % (out_tab_str2, tmp_key, tmp_name, tmp_num)
if tmp_object is not None:
out_string += tmp_object.get_as_string(tab_str, level + 2)
else:
out_string += "%s%s %s %s not found\n" % (
out_tab_str3,
tmp_key,
tmp_name,
tmp_num,
)
out_string += "\n"
i += 1
return out_string
# cDataDescriptions END
[docs]def generate_marker_set_description(set_num=0):
"""generate_marker_set_description - Testing functions"""
marker_set_description = MarkerSetDescription()
marker_set_description.set_name("MarkerSetName%3.3d" % set_num)
marker_set_description.add_marker_name("MarkerName%3.3d_0" % set_num)
marker_set_description.add_marker_name("MarkerName%3.3d_1" % set_num)
marker_set_description.add_marker_name("MarkerName%3.3d_2" % set_num)
marker_set_description.add_marker_name("MarkerName%3.3d_3" % set_num)
return marker_set_description
[docs]def generate_rb_marker(marker_num=0):
"""generate_rb_marker - Generate rigid body marker based on marker number"""
marker_num_mod = marker_num % 4
marker_name = "RBMarker_%3.3d" % marker_num
marker_active_label = marker_num + 10000
marker_pos = [1.0, 4.0, 9.0]
if marker_num_mod == 1:
marker_pos = [1.0, 8.0, 27.0]
elif marker_num_mod == 2:
marker_pos = [3.1, 4.1, 5.9]
elif marker_num_mod == 3:
marker_pos = [1.0, 3.0, 6.0]
return RBMarker(marker_name, marker_active_label, marker_pos)
[docs]def generate_rigid_body_description(rbd_num=0):
"""generate_rigid_body_description - Generate Rigid Body Description Data"""
rbd = RigidBodyDescription()
rbd.set_name("rigidBodyDescription_%3.3d" % rbd_num)
rbd.set_id(3141)
rbd.set_parent_id(314)
rbd.set_pos(1, 4, 9)
rbd.add_rb_marker(generate_rb_marker(0))
rbd.add_rb_marker(generate_rb_marker(1))
rbd.add_rb_marker(generate_rb_marker(2))
return rbd
[docs]def generate_skeleton_description(skeleton_num=0):
"""generate_skeleton_description -Generate Test SkeletonDescription Data"""
skel_desc = SkeletonDescription(
"SkeletonDescription_%3.3d" % skeleton_num, skeleton_num
)
# generate some rigid bodies to add
skel_desc.add_rigid_body_description(generate_rigid_body_description(0))
skel_desc.add_rigid_body_description(generate_rigid_body_description(1))
skel_desc.add_rigid_body_description(generate_rigid_body_description(2))
skel_desc.add_rigid_body_description(generate_rigid_body_description(3))
skel_desc.add_rigid_body_description(generate_rigid_body_description(5))
skel_desc.add_rigid_body_description(generate_rigid_body_description(7))
return skel_desc
[docs]def generate_force_plate_description(force_plate_num=0):
"""generate_force_plate_description - Generate Test ForcePlateDescription Data"""
fp_id = force_plate_num
random.seed(force_plate_num)
serial_number = "S/N_%5.5d" % random.randint(0, 99999)
width = random.random() * 10
length = random.random() * 10
origin = [(random.random() * 100), (random.random() * 100), (random.random() * 100)]
corners = [[0.0, 0.0, 0.0], [0.0, 1.0, 0.0], [1.0, 1.0, 0.0], [1.0, 0.0, 0.0]]
fp_desc = ForcePlateDescription(fp_id, serial_number)
fp_desc.set_dimensions(width, length)
fp_desc.set_origin(origin[0], origin[1], origin[2])
# fp_desc.set_cal_matrix(cal_matrix)
fp_desc.set_corners(corners)
for i in range(3):
fp_desc.add_channel_name("channel_%3.3d" % i)
return fp_desc
[docs]def generate_device_description(dev_num=0):
"""generate_device_description- Generate Test DeviceDescription Data"""
new_id = 0
name = "Device%3.3d" % dev_num
serial_number = "SerialNumber%3.3d" % dev_num
device_type = dev_num % 4
channel_data_type = dev_num % 5
dev_desc = DeviceDescription(
new_id, name, serial_number, device_type, channel_data_type
)
for i in range(channel_data_type + 3):
dev_desc.add_channel_name("channel_name_%2.2d" % i)
return dev_desc
[docs]def generate_camera_description(cam_num=0):
"""generate_camera_description - Generate Test CameraDescription data"""
pos_vec3 = [1, 2, 3]
orientation_quat = [1, 2, 3, 4]
return CameraDescription("Camera_%3.3d" % cam_num, pos_vec3, orientation_quat)
# generate_data_descriptions - Generate Test DataDescriptions
[docs]def generate_data_descriptions(data_desc_num=0):
"""Generate data descriptions"""
data_descs = DataDescriptions()
data_descs.add_data(generate_marker_set_description(data_desc_num + 0))
data_descs.add_data(generate_marker_set_description(data_desc_num + 1))
data_descs.add_data(generate_rigid_body_description(data_desc_num + 0))
data_descs.add_data(generate_rigid_body_description(data_desc_num + 1))
data_descs.add_skeleton(generate_skeleton_description(data_desc_num + 3))
data_descs.add_skeleton(generate_skeleton_description(data_desc_num + 9))
data_descs.add_skeleton(generate_skeleton_description(data_desc_num + 27))
data_descs.add_force_plate(generate_force_plate_description(data_desc_num + 123))
data_descs.add_force_plate(generate_force_plate_description(data_desc_num + 87))
data_descs.add_force_plate(generate_force_plate_description(data_desc_num + 21))
data_descs.add_device(generate_device_description(data_desc_num + 0))
data_descs.add_device(generate_device_description(data_desc_num + 2))
data_descs.add_device(generate_device_description(data_desc_num + 4))
data_descs.add_camera(generate_camera_description(data_desc_num + 0))
data_descs.add_camera(generate_camera_description(data_desc_num + 10))
data_descs.add_camera(generate_camera_description(data_desc_num + 3))
data_descs.add_camera(generate_camera_description(data_desc_num + 7))
return data_descs
# test_all - Test all the major classes
[docs]def test_all(run_test=True):
"""Test all the Data Description classes"""
totals = [0, 0, 0]
if run_test is True:
test_cases = [
[
"Test Marker Set Description 0",
"754fe535286ca84bd054d9aca5e9906ab9384d92",
"generate_marker_set_description(0)",
True,
],
[
"Test RB Marker 0",
"0f2612abf2ce70e479d7b9912f646f12910b3310",
"generate_rb_marker(0)",
True,
],
[
"Test Rigid Body Description 0",
"7a4e93dcda442c1d9c5dcc5c01a247e4a6c01b66",
"generate_rigid_body_description(0)",
True,
],
[
"Test Skeleton Description 0",
"b4d1a031dd7c323e3d316b5312329881a6a552ca",
"generate_skeleton_description(0)",
True,
],
[
"Test Force Plate Description 0",
"b385dd1096bdd9f521eb48bb9cbfb3414ea075bd",
"generate_force_plate_description(0)",
True,
],
[
"Test Device Description 0",
"39b4fdda402bc73c0b1cd5c7f61599476aa9a926",
"generate_device_description(0)",
True,
],
[
"Test Camera Description 0",
"614602c5d290bda3b288138d5e25516dd1e1e85a",
"generate_camera_description(0)",
True,
],
[
"Test Data Description 0",
"e5f448d10087ac818a65934710a85fc7ebfdf89e",
"generate_data_descriptions(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)