mediapipe-nightly 0.10.21.post20241223__cp312-cp312-manylinux_2_28_x86_64.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (593) hide show
  1. mediapipe/__init__.py +26 -0
  2. mediapipe/calculators/__init__.py +0 -0
  3. mediapipe/calculators/audio/__init__.py +0 -0
  4. mediapipe/calculators/audio/mfcc_mel_calculators_pb2.py +33 -0
  5. mediapipe/calculators/audio/rational_factor_resample_calculator_pb2.py +33 -0
  6. mediapipe/calculators/audio/spectrogram_calculator_pb2.py +37 -0
  7. mediapipe/calculators/audio/stabilized_log_calculator_pb2.py +31 -0
  8. mediapipe/calculators/audio/time_series_framer_calculator_pb2.py +33 -0
  9. mediapipe/calculators/core/__init__.py +0 -0
  10. mediapipe/calculators/core/bypass_calculator_pb2.py +31 -0
  11. mediapipe/calculators/core/clip_vector_size_calculator_pb2.py +31 -0
  12. mediapipe/calculators/core/concatenate_vector_calculator_pb2.py +31 -0
  13. mediapipe/calculators/core/constant_side_packet_calculator_pb2.py +39 -0
  14. mediapipe/calculators/core/dequantize_byte_array_calculator_pb2.py +31 -0
  15. mediapipe/calculators/core/flow_limiter_calculator_pb2.py +32 -0
  16. mediapipe/calculators/core/gate_calculator_pb2.py +33 -0
  17. mediapipe/calculators/core/get_vector_item_calculator_pb2.py +31 -0
  18. mediapipe/calculators/core/graph_profile_calculator_pb2.py +31 -0
  19. mediapipe/calculators/core/packet_cloner_calculator_pb2.py +31 -0
  20. mediapipe/calculators/core/packet_resampler_calculator_pb2.py +33 -0
  21. mediapipe/calculators/core/packet_thinner_calculator_pb2.py +33 -0
  22. mediapipe/calculators/core/quantize_float_vector_calculator_pb2.py +31 -0
  23. mediapipe/calculators/core/sequence_shift_calculator_pb2.py +31 -0
  24. mediapipe/calculators/core/split_vector_calculator_pb2.py +33 -0
  25. mediapipe/calculators/image/__init__.py +0 -0
  26. mediapipe/calculators/image/bilateral_filter_calculator_pb2.py +31 -0
  27. mediapipe/calculators/image/feature_detector_calculator_pb2.py +31 -0
  28. mediapipe/calculators/image/image_clone_calculator_pb2.py +31 -0
  29. mediapipe/calculators/image/image_cropping_calculator_pb2.py +33 -0
  30. mediapipe/calculators/image/image_transformation_calculator_pb2.py +38 -0
  31. mediapipe/calculators/image/mask_overlay_calculator_pb2.py +33 -0
  32. mediapipe/calculators/image/opencv_encoded_image_to_image_frame_calculator_pb2.py +31 -0
  33. mediapipe/calculators/image/opencv_image_encoder_calculator_pb2.py +35 -0
  34. mediapipe/calculators/image/recolor_calculator_pb2.py +34 -0
  35. mediapipe/calculators/image/rotation_mode_pb2.py +29 -0
  36. mediapipe/calculators/image/scale_image_calculator_pb2.py +34 -0
  37. mediapipe/calculators/image/segmentation_smoothing_calculator_pb2.py +31 -0
  38. mediapipe/calculators/image/set_alpha_calculator_pb2.py +31 -0
  39. mediapipe/calculators/image/warp_affine_calculator_pb2.py +36 -0
  40. mediapipe/calculators/internal/__init__.py +0 -0
  41. mediapipe/calculators/internal/callback_packet_calculator_pb2.py +33 -0
  42. mediapipe/calculators/tensor/__init__.py +0 -0
  43. mediapipe/calculators/tensor/audio_to_tensor_calculator_pb2.py +35 -0
  44. mediapipe/calculators/tensor/bert_preprocessor_calculator_pb2.py +31 -0
  45. mediapipe/calculators/tensor/feedback_tensors_calculator_pb2.py +37 -0
  46. mediapipe/calculators/tensor/image_to_tensor_calculator_pb2.py +40 -0
  47. mediapipe/calculators/tensor/inference_calculator_pb2.py +63 -0
  48. mediapipe/calculators/tensor/landmarks_to_tensor_calculator_pb2.py +33 -0
  49. mediapipe/calculators/tensor/regex_preprocessor_calculator_pb2.py +31 -0
  50. mediapipe/calculators/tensor/tensor_converter_calculator_pb2.py +34 -0
  51. mediapipe/calculators/tensor/tensor_to_joints_calculator_pb2.py +31 -0
  52. mediapipe/calculators/tensor/tensors_readback_calculator_pb2.py +35 -0
  53. mediapipe/calculators/tensor/tensors_to_audio_calculator_pb2.py +33 -0
  54. mediapipe/calculators/tensor/tensors_to_classification_calculator_pb2.py +44 -0
  55. mediapipe/calculators/tensor/tensors_to_detections_calculator_pb2.py +39 -0
  56. mediapipe/calculators/tensor/tensors_to_floats_calculator_pb2.py +33 -0
  57. mediapipe/calculators/tensor/tensors_to_landmarks_calculator_pb2.py +33 -0
  58. mediapipe/calculators/tensor/tensors_to_segmentation_calculator_pb2.py +34 -0
  59. mediapipe/calculators/tensor/vector_to_tensor_calculator_pb2.py +27 -0
  60. mediapipe/calculators/tflite/__init__.py +0 -0
  61. mediapipe/calculators/tflite/ssd_anchors_calculator_pb2.py +32 -0
  62. mediapipe/calculators/tflite/tflite_converter_calculator_pb2.py +33 -0
  63. mediapipe/calculators/tflite/tflite_custom_op_resolver_calculator_pb2.py +31 -0
  64. mediapipe/calculators/tflite/tflite_inference_calculator_pb2.py +49 -0
  65. mediapipe/calculators/tflite/tflite_tensors_to_classification_calculator_pb2.py +31 -0
  66. mediapipe/calculators/tflite/tflite_tensors_to_detections_calculator_pb2.py +31 -0
  67. mediapipe/calculators/tflite/tflite_tensors_to_landmarks_calculator_pb2.py +33 -0
  68. mediapipe/calculators/tflite/tflite_tensors_to_segmentation_calculator_pb2.py +31 -0
  69. mediapipe/calculators/util/__init__.py +0 -0
  70. mediapipe/calculators/util/align_hand_to_pose_in_world_calculator_pb2.py +31 -0
  71. mediapipe/calculators/util/annotation_overlay_calculator_pb2.py +32 -0
  72. mediapipe/calculators/util/association_calculator_pb2.py +31 -0
  73. mediapipe/calculators/util/collection_has_min_size_calculator_pb2.py +31 -0
  74. mediapipe/calculators/util/combine_joints_calculator_pb2.py +36 -0
  75. mediapipe/calculators/util/detection_label_id_to_text_calculator_pb2.py +36 -0
  76. mediapipe/calculators/util/detections_to_rects_calculator_pb2.py +33 -0
  77. mediapipe/calculators/util/detections_to_render_data_calculator_pb2.py +33 -0
  78. mediapipe/calculators/util/face_to_rect_calculator_pb2.py +26 -0
  79. mediapipe/calculators/util/filter_detections_calculator_pb2.py +31 -0
  80. mediapipe/calculators/util/flat_color_image_calculator_pb2.py +32 -0
  81. mediapipe/calculators/util/labels_to_render_data_calculator_pb2.py +34 -0
  82. mediapipe/calculators/util/landmark_projection_calculator_pb2.py +31 -0
  83. mediapipe/calculators/util/landmarks_refinement_calculator_pb2.py +41 -0
  84. mediapipe/calculators/util/landmarks_smoothing_calculator_pb2.py +33 -0
  85. mediapipe/calculators/util/landmarks_to_detection_calculator_pb2.py +31 -0
  86. mediapipe/calculators/util/landmarks_to_floats_calculator_pb2.py +31 -0
  87. mediapipe/calculators/util/landmarks_to_render_data_calculator_pb2.py +32 -0
  88. mediapipe/calculators/util/landmarks_transformation_calculator_pb2.py +37 -0
  89. mediapipe/calculators/util/latency_pb2.py +26 -0
  90. mediapipe/calculators/util/local_file_contents_calculator_pb2.py +31 -0
  91. mediapipe/calculators/util/logic_calculator_pb2.py +34 -0
  92. mediapipe/calculators/util/non_max_suppression_calculator_pb2.py +35 -0
  93. mediapipe/calculators/util/packet_frequency_calculator_pb2.py +31 -0
  94. mediapipe/calculators/util/packet_frequency_pb2.py +26 -0
  95. mediapipe/calculators/util/packet_latency_calculator_pb2.py +31 -0
  96. mediapipe/calculators/util/rect_to_render_data_calculator_pb2.py +32 -0
  97. mediapipe/calculators/util/rect_to_render_scale_calculator_pb2.py +31 -0
  98. mediapipe/calculators/util/rect_transformation_calculator_pb2.py +31 -0
  99. mediapipe/calculators/util/refine_landmarks_from_heatmap_calculator_pb2.py +31 -0
  100. mediapipe/calculators/util/resource_provider_calculator_pb2.py +28 -0
  101. mediapipe/calculators/util/set_joints_visibility_calculator_pb2.py +41 -0
  102. mediapipe/calculators/util/thresholding_calculator_pb2.py +31 -0
  103. mediapipe/calculators/util/timed_box_list_id_to_label_calculator_pb2.py +31 -0
  104. mediapipe/calculators/util/timed_box_list_to_render_data_calculator_pb2.py +32 -0
  105. mediapipe/calculators/util/top_k_scores_calculator_pb2.py +31 -0
  106. mediapipe/calculators/util/visibility_copy_calculator_pb2.py +27 -0
  107. mediapipe/calculators/util/visibility_smoothing_calculator_pb2.py +31 -0
  108. mediapipe/calculators/video/__init__.py +0 -0
  109. mediapipe/calculators/video/box_detector_calculator_pb2.py +32 -0
  110. mediapipe/calculators/video/box_tracker_calculator_pb2.py +32 -0
  111. mediapipe/calculators/video/flow_packager_calculator_pb2.py +32 -0
  112. mediapipe/calculators/video/flow_to_image_calculator_pb2.py +31 -0
  113. mediapipe/calculators/video/motion_analysis_calculator_pb2.py +42 -0
  114. mediapipe/calculators/video/opencv_video_encoder_calculator_pb2.py +31 -0
  115. mediapipe/calculators/video/tool/__init__.py +0 -0
  116. mediapipe/calculators/video/tool/flow_quantizer_model_pb2.py +26 -0
  117. mediapipe/calculators/video/tracked_detection_manager_calculator_pb2.py +32 -0
  118. mediapipe/calculators/video/video_pre_stream_calculator_pb2.py +35 -0
  119. mediapipe/examples/__init__.py +14 -0
  120. mediapipe/examples/desktop/__init__.py +14 -0
  121. mediapipe/framework/__init__.py +0 -0
  122. mediapipe/framework/calculator_options_pb2.py +29 -0
  123. mediapipe/framework/calculator_pb2.py +59 -0
  124. mediapipe/framework/calculator_profile_pb2.py +48 -0
  125. mediapipe/framework/deps/__init__.py +0 -0
  126. mediapipe/framework/deps/proto_descriptor_pb2.py +29 -0
  127. mediapipe/framework/formats/__init__.py +0 -0
  128. mediapipe/framework/formats/affine_transform_data_pb2.py +28 -0
  129. mediapipe/framework/formats/annotation/__init__.py +0 -0
  130. mediapipe/framework/formats/annotation/locus_pb2.py +32 -0
  131. mediapipe/framework/formats/annotation/rasterization_pb2.py +29 -0
  132. mediapipe/framework/formats/body_rig_pb2.py +28 -0
  133. mediapipe/framework/formats/classification_pb2.py +31 -0
  134. mediapipe/framework/formats/detection_pb2.py +36 -0
  135. mediapipe/framework/formats/image_file_properties_pb2.py +26 -0
  136. mediapipe/framework/formats/image_format_pb2.py +29 -0
  137. mediapipe/framework/formats/landmark_pb2.py +37 -0
  138. mediapipe/framework/formats/location_data_pb2.py +38 -0
  139. mediapipe/framework/formats/matrix_data_pb2.py +31 -0
  140. mediapipe/framework/formats/motion/__init__.py +0 -0
  141. mediapipe/framework/formats/motion/optical_flow_field_data_pb2.py +30 -0
  142. mediapipe/framework/formats/object_detection/__init__.py +0 -0
  143. mediapipe/framework/formats/object_detection/anchor_pb2.py +26 -0
  144. mediapipe/framework/formats/rect_pb2.py +29 -0
  145. mediapipe/framework/formats/time_series_header_pb2.py +28 -0
  146. mediapipe/framework/graph_runtime_info_pb2.py +31 -0
  147. mediapipe/framework/mediapipe_options_pb2.py +27 -0
  148. mediapipe/framework/packet_factory_pb2.py +31 -0
  149. mediapipe/framework/packet_generator_pb2.py +33 -0
  150. mediapipe/framework/status_handler_pb2.py +28 -0
  151. mediapipe/framework/stream_handler/__init__.py +0 -0
  152. mediapipe/framework/stream_handler/default_input_stream_handler_pb2.py +27 -0
  153. mediapipe/framework/stream_handler/fixed_size_input_stream_handler_pb2.py +27 -0
  154. mediapipe/framework/stream_handler/sync_set_input_stream_handler_pb2.py +29 -0
  155. mediapipe/framework/stream_handler/timestamp_align_input_stream_handler_pb2.py +27 -0
  156. mediapipe/framework/stream_handler_pb2.py +30 -0
  157. mediapipe/framework/test_calculators_pb2.py +31 -0
  158. mediapipe/framework/thread_pool_executor_pb2.py +29 -0
  159. mediapipe/framework/tool/__init__.py +0 -0
  160. mediapipe/framework/tool/calculator_graph_template_pb2.py +44 -0
  161. mediapipe/framework/tool/field_data_pb2.py +28 -0
  162. mediapipe/framework/tool/node_chain_subgraph_pb2.py +31 -0
  163. mediapipe/framework/tool/packet_generator_wrapper_calculator_pb2.py +28 -0
  164. mediapipe/framework/tool/source_pb2.py +33 -0
  165. mediapipe/framework/tool/switch_container_pb2.py +32 -0
  166. mediapipe/gpu/__init__.py +0 -0
  167. mediapipe/gpu/copy_calculator_pb2.py +33 -0
  168. mediapipe/gpu/gl_animation_overlay_calculator_pb2.py +31 -0
  169. mediapipe/gpu/gl_context_options_pb2.py +31 -0
  170. mediapipe/gpu/gl_scaler_calculator_pb2.py +32 -0
  171. mediapipe/gpu/gl_surface_sink_calculator_pb2.py +32 -0
  172. mediapipe/gpu/gpu_origin_pb2.py +29 -0
  173. mediapipe/gpu/scale_mode_pb2.py +28 -0
  174. mediapipe/model_maker/__init__.py +27 -0
  175. mediapipe/model_maker/setup.py +107 -0
  176. mediapipe/modules/__init__.py +0 -0
  177. mediapipe/modules/face_detection/__init__.py +0 -0
  178. mediapipe/modules/face_detection/face_detection_full_range_cpu.binarypb +0 -0
  179. mediapipe/modules/face_detection/face_detection_full_range_sparse.tflite +0 -0
  180. mediapipe/modules/face_detection/face_detection_pb2.py +30 -0
  181. mediapipe/modules/face_detection/face_detection_short_range.tflite +0 -0
  182. mediapipe/modules/face_detection/face_detection_short_range_cpu.binarypb +0 -0
  183. mediapipe/modules/face_geometry/__init__.py +0 -0
  184. mediapipe/modules/face_geometry/data/__init__.py +0 -0
  185. mediapipe/modules/face_geometry/effect_renderer_calculator_pb2.py +27 -0
  186. mediapipe/modules/face_geometry/env_generator_calculator_pb2.py +28 -0
  187. mediapipe/modules/face_geometry/geometry_pipeline_calculator_pb2.py +27 -0
  188. mediapipe/modules/face_geometry/libs/__init__.py +0 -0
  189. mediapipe/modules/face_geometry/protos/__init__.py +0 -0
  190. mediapipe/modules/face_geometry/protos/environment_pb2.py +31 -0
  191. mediapipe/modules/face_geometry/protos/face_geometry_pb2.py +29 -0
  192. mediapipe/modules/face_geometry/protos/geometry_pipeline_metadata_pb2.py +32 -0
  193. mediapipe/modules/face_geometry/protos/mesh_3d_pb2.py +31 -0
  194. mediapipe/modules/face_landmark/__init__.py +0 -0
  195. mediapipe/modules/face_landmark/face_landmark.tflite +0 -0
  196. mediapipe/modules/face_landmark/face_landmark_front_cpu.binarypb +0 -0
  197. mediapipe/modules/face_landmark/face_landmark_with_attention.tflite +0 -0
  198. mediapipe/modules/hand_landmark/__init__.py +0 -0
  199. mediapipe/modules/hand_landmark/calculators/__init__.py +0 -0
  200. mediapipe/modules/hand_landmark/hand_landmark_full.tflite +0 -0
  201. mediapipe/modules/hand_landmark/hand_landmark_lite.tflite +0 -0
  202. mediapipe/modules/hand_landmark/hand_landmark_tracking_cpu.binarypb +0 -0
  203. mediapipe/modules/hand_landmark/handedness.txt +2 -0
  204. mediapipe/modules/holistic_landmark/__init__.py +0 -0
  205. mediapipe/modules/holistic_landmark/calculators/__init__.py +0 -0
  206. mediapipe/modules/holistic_landmark/calculators/roi_tracking_calculator_pb2.py +37 -0
  207. mediapipe/modules/holistic_landmark/hand_recrop.tflite +0 -0
  208. mediapipe/modules/holistic_landmark/holistic_landmark_cpu.binarypb +0 -0
  209. mediapipe/modules/iris_landmark/__init__.py +0 -0
  210. mediapipe/modules/iris_landmark/iris_landmark.tflite +0 -0
  211. mediapipe/modules/objectron/__init__.py +0 -0
  212. mediapipe/modules/objectron/calculators/__init__.py +0 -0
  213. mediapipe/modules/objectron/calculators/a_r_capture_metadata_pb2.py +102 -0
  214. mediapipe/modules/objectron/calculators/annotation_data_pb2.py +38 -0
  215. mediapipe/modules/objectron/calculators/belief_decoder_config_pb2.py +28 -0
  216. mediapipe/modules/objectron/calculators/camera_parameters_pb2.py +30 -0
  217. mediapipe/modules/objectron/calculators/filter_detection_calculator_pb2.py +35 -0
  218. mediapipe/modules/objectron/calculators/frame_annotation_to_rect_calculator_pb2.py +31 -0
  219. mediapipe/modules/objectron/calculators/frame_annotation_tracker_calculator_pb2.py +31 -0
  220. mediapipe/modules/objectron/calculators/lift_2d_frame_annotation_to_3d_calculator_pb2.py +32 -0
  221. mediapipe/modules/objectron/calculators/object_pb2.py +38 -0
  222. mediapipe/modules/objectron/calculators/tensors_to_objects_calculator_pb2.py +32 -0
  223. mediapipe/modules/objectron/calculators/tflite_tensors_to_objects_calculator_pb2.py +32 -0
  224. mediapipe/modules/objectron/object_detection_oidv4_labelmap.txt +24 -0
  225. mediapipe/modules/objectron/objectron_cpu.binarypb +0 -0
  226. mediapipe/modules/palm_detection/__init__.py +0 -0
  227. mediapipe/modules/palm_detection/palm_detection_full.tflite +0 -0
  228. mediapipe/modules/palm_detection/palm_detection_lite.tflite +0 -0
  229. mediapipe/modules/pose_detection/__init__.py +0 -0
  230. mediapipe/modules/pose_detection/pose_detection.tflite +0 -0
  231. mediapipe/modules/pose_landmark/__init__.py +0 -0
  232. mediapipe/modules/pose_landmark/pose_landmark_cpu.binarypb +0 -0
  233. mediapipe/modules/pose_landmark/pose_landmark_full.tflite +0 -0
  234. mediapipe/modules/selfie_segmentation/__init__.py +0 -0
  235. mediapipe/modules/selfie_segmentation/selfie_segmentation.tflite +0 -0
  236. mediapipe/modules/selfie_segmentation/selfie_segmentation_cpu.binarypb +0 -0
  237. mediapipe/modules/selfie_segmentation/selfie_segmentation_landscape.tflite +0 -0
  238. mediapipe/python/__init__.py +29 -0
  239. mediapipe/python/_framework_bindings.cpython-312-x86_64-linux-gnu.so +0 -0
  240. mediapipe/python/calculator_graph_test.py +251 -0
  241. mediapipe/python/image_frame_test.py +194 -0
  242. mediapipe/python/image_test.py +218 -0
  243. mediapipe/python/packet_creator.py +275 -0
  244. mediapipe/python/packet_getter.py +120 -0
  245. mediapipe/python/packet_test.py +533 -0
  246. mediapipe/python/solution_base.py +604 -0
  247. mediapipe/python/solution_base_test.py +396 -0
  248. mediapipe/python/solutions/__init__.py +27 -0
  249. mediapipe/python/solutions/download_utils.py +37 -0
  250. mediapipe/python/solutions/drawing_styles.py +249 -0
  251. mediapipe/python/solutions/drawing_utils.py +320 -0
  252. mediapipe/python/solutions/drawing_utils_test.py +258 -0
  253. mediapipe/python/solutions/face_detection.py +105 -0
  254. mediapipe/python/solutions/face_detection_test.py +92 -0
  255. mediapipe/python/solutions/face_mesh.py +125 -0
  256. mediapipe/python/solutions/face_mesh_connections.py +500 -0
  257. mediapipe/python/solutions/face_mesh_test.py +170 -0
  258. mediapipe/python/solutions/hands.py +153 -0
  259. mediapipe/python/solutions/hands_connections.py +32 -0
  260. mediapipe/python/solutions/hands_test.py +219 -0
  261. mediapipe/python/solutions/holistic.py +167 -0
  262. mediapipe/python/solutions/holistic_test.py +142 -0
  263. mediapipe/python/solutions/objectron.py +288 -0
  264. mediapipe/python/solutions/objectron_test.py +81 -0
  265. mediapipe/python/solutions/pose.py +192 -0
  266. mediapipe/python/solutions/pose_connections.py +22 -0
  267. mediapipe/python/solutions/pose_test.py +262 -0
  268. mediapipe/python/solutions/selfie_segmentation.py +76 -0
  269. mediapipe/python/solutions/selfie_segmentation_test.py +68 -0
  270. mediapipe/python/timestamp_test.py +78 -0
  271. mediapipe/tasks/__init__.py +14 -0
  272. mediapipe/tasks/cc/__init__.py +0 -0
  273. mediapipe/tasks/cc/audio/__init__.py +0 -0
  274. mediapipe/tasks/cc/audio/audio_classifier/__init__.py +0 -0
  275. mediapipe/tasks/cc/audio/audio_classifier/proto/__init__.py +0 -0
  276. mediapipe/tasks/cc/audio/audio_classifier/proto/audio_classifier_graph_options_pb2.py +35 -0
  277. mediapipe/tasks/cc/audio/audio_embedder/__init__.py +0 -0
  278. mediapipe/tasks/cc/audio/audio_embedder/proto/__init__.py +0 -0
  279. mediapipe/tasks/cc/audio/audio_embedder/proto/audio_embedder_graph_options_pb2.py +35 -0
  280. mediapipe/tasks/cc/audio/core/__init__.py +0 -0
  281. mediapipe/tasks/cc/audio/utils/__init__.py +0 -0
  282. mediapipe/tasks/cc/components/__init__.py +0 -0
  283. mediapipe/tasks/cc/components/calculators/__init__.py +0 -0
  284. mediapipe/tasks/cc/components/calculators/classification_aggregation_calculator_pb2.py +31 -0
  285. mediapipe/tasks/cc/components/calculators/score_calibration_calculator_pb2.py +35 -0
  286. mediapipe/tasks/cc/components/calculators/tensors_to_embeddings_calculator_pb2.py +32 -0
  287. mediapipe/tasks/cc/components/containers/__init__.py +0 -0
  288. mediapipe/tasks/cc/components/containers/proto/__init__.py +0 -0
  289. mediapipe/tasks/cc/components/containers/proto/classifications_pb2.py +30 -0
  290. mediapipe/tasks/cc/components/containers/proto/embeddings_pb2.py +35 -0
  291. mediapipe/tasks/cc/components/containers/proto/landmarks_detection_result_pb2.py +32 -0
  292. mediapipe/tasks/cc/components/processors/__init__.py +0 -0
  293. mediapipe/tasks/cc/components/processors/proto/__init__.py +0 -0
  294. mediapipe/tasks/cc/components/processors/proto/classification_postprocessing_graph_options_pb2.py +38 -0
  295. mediapipe/tasks/cc/components/processors/proto/classifier_options_pb2.py +27 -0
  296. mediapipe/tasks/cc/components/processors/proto/detection_postprocessing_graph_options_pb2.py +36 -0
  297. mediapipe/tasks/cc/components/processors/proto/detector_options_pb2.py +27 -0
  298. mediapipe/tasks/cc/components/processors/proto/embedder_options_pb2.py +27 -0
  299. mediapipe/tasks/cc/components/processors/proto/embedding_postprocessing_graph_options_pb2.py +32 -0
  300. mediapipe/tasks/cc/components/processors/proto/image_preprocessing_graph_options_pb2.py +34 -0
  301. mediapipe/tasks/cc/components/processors/proto/text_model_type_pb2.py +28 -0
  302. mediapipe/tasks/cc/components/processors/proto/text_preprocessing_graph_options_pb2.py +32 -0
  303. mediapipe/tasks/cc/components/utils/__init__.py +0 -0
  304. mediapipe/tasks/cc/core/__init__.py +0 -0
  305. mediapipe/tasks/cc/core/proto/__init__.py +0 -0
  306. mediapipe/tasks/cc/core/proto/acceleration_pb2.py +28 -0
  307. mediapipe/tasks/cc/core/proto/base_options_pb2.py +30 -0
  308. mediapipe/tasks/cc/core/proto/external_file_pb2.py +31 -0
  309. mediapipe/tasks/cc/core/proto/inference_subgraph_pb2.py +32 -0
  310. mediapipe/tasks/cc/core/proto/model_resources_calculator_pb2.py +32 -0
  311. mediapipe/tasks/cc/genai/__init__.py +0 -0
  312. mediapipe/tasks/cc/genai/inference/__init__.py +0 -0
  313. mediapipe/tasks/cc/genai/inference/c/__init__.py +0 -0
  314. mediapipe/tasks/cc/genai/inference/calculators/__init__.py +0 -0
  315. mediapipe/tasks/cc/genai/inference/calculators/detokenizer_calculator_pb2.py +27 -0
  316. mediapipe/tasks/cc/genai/inference/calculators/llm_gpu_calculator_pb2.py +32 -0
  317. mediapipe/tasks/cc/genai/inference/calculators/model_data_calculator_pb2.py +27 -0
  318. mediapipe/tasks/cc/genai/inference/calculators/tokenizer_calculator_pb2.py +29 -0
  319. mediapipe/tasks/cc/genai/inference/common/__init__.py +0 -0
  320. mediapipe/tasks/cc/genai/inference/proto/__init__.py +0 -0
  321. mediapipe/tasks/cc/genai/inference/proto/llm_file_metadata_pb2.py +32 -0
  322. mediapipe/tasks/cc/genai/inference/proto/llm_params_pb2.py +33 -0
  323. mediapipe/tasks/cc/genai/inference/proto/prompt_template_pb2.py +27 -0
  324. mediapipe/tasks/cc/genai/inference/proto/sampler_params_pb2.py +29 -0
  325. mediapipe/tasks/cc/genai/inference/proto/transformer_params_pb2.py +45 -0
  326. mediapipe/tasks/cc/genai/inference/utils/__init__.py +0 -0
  327. mediapipe/tasks/cc/genai/inference/utils/llm_utils/__init__.py +0 -0
  328. mediapipe/tasks/cc/genai/inference/utils/xnn_utils/__init__.py +0 -0
  329. mediapipe/tasks/cc/metadata/__init__.py +0 -0
  330. mediapipe/tasks/cc/metadata/python/__init__.py +0 -0
  331. mediapipe/tasks/cc/metadata/python/_pywrap_metadata_version.cpython-312-x86_64-linux-gnu.so +0 -0
  332. mediapipe/tasks/cc/metadata/tests/__init__.py +0 -0
  333. mediapipe/tasks/cc/metadata/utils/__init__.py +0 -0
  334. mediapipe/tasks/cc/text/__init__.py +0 -0
  335. mediapipe/tasks/cc/text/custom_ops/__init__.py +0 -0
  336. mediapipe/tasks/cc/text/custom_ops/ragged/__init__.py +0 -0
  337. mediapipe/tasks/cc/text/custom_ops/sentencepiece/__init__.py +0 -0
  338. mediapipe/tasks/cc/text/custom_ops/sentencepiece/testdata/__init__.py +0 -0
  339. mediapipe/tasks/cc/text/language_detector/__init__.py +0 -0
  340. mediapipe/tasks/cc/text/language_detector/custom_ops/__init__.py +0 -0
  341. mediapipe/tasks/cc/text/language_detector/custom_ops/utils/__init__.py +0 -0
  342. mediapipe/tasks/cc/text/language_detector/custom_ops/utils/hash/__init__.py +0 -0
  343. mediapipe/tasks/cc/text/language_detector/custom_ops/utils/utf/__init__.py +0 -0
  344. mediapipe/tasks/cc/text/text_classifier/__init__.py +0 -0
  345. mediapipe/tasks/cc/text/text_classifier/proto/__init__.py +0 -0
  346. mediapipe/tasks/cc/text/text_classifier/proto/text_classifier_graph_options_pb2.py +35 -0
  347. mediapipe/tasks/cc/text/text_embedder/__init__.py +0 -0
  348. mediapipe/tasks/cc/text/text_embedder/proto/__init__.py +0 -0
  349. mediapipe/tasks/cc/text/text_embedder/proto/text_embedder_graph_options_pb2.py +35 -0
  350. mediapipe/tasks/cc/text/tokenizers/__init__.py +0 -0
  351. mediapipe/tasks/cc/text/utils/__init__.py +0 -0
  352. mediapipe/tasks/cc/vision/__init__.py +0 -0
  353. mediapipe/tasks/cc/vision/core/__init__.py +0 -0
  354. mediapipe/tasks/cc/vision/custom_ops/__init__.py +0 -0
  355. mediapipe/tasks/cc/vision/face_detector/__init__.py +0 -0
  356. mediapipe/tasks/cc/vision/face_detector/proto/__init__.py +0 -0
  357. mediapipe/tasks/cc/vision/face_detector/proto/face_detector_graph_options_pb2.py +34 -0
  358. mediapipe/tasks/cc/vision/face_geometry/__init__.py +0 -0
  359. mediapipe/tasks/cc/vision/face_geometry/calculators/__init__.py +0 -0
  360. mediapipe/tasks/cc/vision/face_geometry/calculators/env_generator_calculator_pb2.py +28 -0
  361. mediapipe/tasks/cc/vision/face_geometry/calculators/geometry_pipeline_calculator_pb2.py +29 -0
  362. mediapipe/tasks/cc/vision/face_geometry/data/__init__.py +0 -0
  363. mediapipe/tasks/cc/vision/face_geometry/libs/__init__.py +0 -0
  364. mediapipe/tasks/cc/vision/face_geometry/proto/__init__.py +0 -0
  365. mediapipe/tasks/cc/vision/face_geometry/proto/environment_pb2.py +31 -0
  366. mediapipe/tasks/cc/vision/face_geometry/proto/face_geometry_graph_options_pb2.py +29 -0
  367. mediapipe/tasks/cc/vision/face_geometry/proto/face_geometry_pb2.py +29 -0
  368. mediapipe/tasks/cc/vision/face_geometry/proto/geometry_pipeline_metadata_pb2.py +32 -0
  369. mediapipe/tasks/cc/vision/face_geometry/proto/mesh_3d_pb2.py +31 -0
  370. mediapipe/tasks/cc/vision/face_landmarker/__init__.py +0 -0
  371. mediapipe/tasks/cc/vision/face_landmarker/proto/__init__.py +0 -0
  372. mediapipe/tasks/cc/vision/face_landmarker/proto/face_blendshapes_graph_options_pb2.py +34 -0
  373. mediapipe/tasks/cc/vision/face_landmarker/proto/face_landmarker_graph_options_pb2.py +37 -0
  374. mediapipe/tasks/cc/vision/face_landmarker/proto/face_landmarks_detector_graph_options_pb2.py +35 -0
  375. mediapipe/tasks/cc/vision/face_landmarker/proto/tensors_to_face_landmarks_graph_options_pb2.py +32 -0
  376. mediapipe/tasks/cc/vision/face_stylizer/__init__.py +0 -0
  377. mediapipe/tasks/cc/vision/face_stylizer/calculators/__init__.py +0 -0
  378. mediapipe/tasks/cc/vision/face_stylizer/calculators/tensors_to_image_calculator_pb2.py +36 -0
  379. mediapipe/tasks/cc/vision/face_stylizer/proto/__init__.py +0 -0
  380. mediapipe/tasks/cc/vision/face_stylizer/proto/face_stylizer_graph_options_pb2.py +35 -0
  381. mediapipe/tasks/cc/vision/gesture_recognizer/__init__.py +0 -0
  382. mediapipe/tasks/cc/vision/gesture_recognizer/calculators/__init__.py +0 -0
  383. mediapipe/tasks/cc/vision/gesture_recognizer/calculators/combined_prediction_calculator_pb2.py +33 -0
  384. mediapipe/tasks/cc/vision/gesture_recognizer/calculators/landmarks_to_matrix_calculator_pb2.py +31 -0
  385. mediapipe/tasks/cc/vision/gesture_recognizer/proto/__init__.py +0 -0
  386. mediapipe/tasks/cc/vision/gesture_recognizer/proto/gesture_classifier_graph_options_pb2.py +35 -0
  387. mediapipe/tasks/cc/vision/gesture_recognizer/proto/gesture_embedder_graph_options_pb2.py +34 -0
  388. mediapipe/tasks/cc/vision/gesture_recognizer/proto/gesture_recognizer_graph_options_pb2.py +36 -0
  389. mediapipe/tasks/cc/vision/gesture_recognizer/proto/hand_gesture_recognizer_graph_options_pb2.py +36 -0
  390. mediapipe/tasks/cc/vision/hand_detector/__init__.py +0 -0
  391. mediapipe/tasks/cc/vision/hand_detector/proto/__init__.py +0 -0
  392. mediapipe/tasks/cc/vision/hand_detector/proto/hand_detector_graph_options_pb2.py +34 -0
  393. mediapipe/tasks/cc/vision/hand_detector/proto/hand_detector_result_pb2.py +30 -0
  394. mediapipe/tasks/cc/vision/hand_landmarker/__init__.py +0 -0
  395. mediapipe/tasks/cc/vision/hand_landmarker/calculators/__init__.py +0 -0
  396. mediapipe/tasks/cc/vision/hand_landmarker/calculators/hand_association_calculator_pb2.py +31 -0
  397. mediapipe/tasks/cc/vision/hand_landmarker/proto/__init__.py +0 -0
  398. mediapipe/tasks/cc/vision/hand_landmarker/proto/hand_landmarker_graph_options_pb2.py +36 -0
  399. mediapipe/tasks/cc/vision/hand_landmarker/proto/hand_landmarks_detector_graph_options_pb2.py +34 -0
  400. mediapipe/tasks/cc/vision/hand_landmarker/proto/hand_roi_refinement_graph_options_pb2.py +28 -0
  401. mediapipe/tasks/cc/vision/holistic_landmarker/__init__.py +0 -0
  402. mediapipe/tasks/cc/vision/holistic_landmarker/proto/__init__.py +0 -0
  403. mediapipe/tasks/cc/vision/holistic_landmarker/proto/holistic_landmarker_graph_options_pb2.py +34 -0
  404. mediapipe/tasks/cc/vision/holistic_landmarker/proto/holistic_result_pb2.py +29 -0
  405. mediapipe/tasks/cc/vision/image_classifier/__init__.py +0 -0
  406. mediapipe/tasks/cc/vision/image_classifier/proto/__init__.py +0 -0
  407. mediapipe/tasks/cc/vision/image_classifier/proto/image_classifier_graph_options_pb2.py +35 -0
  408. mediapipe/tasks/cc/vision/image_embedder/__init__.py +0 -0
  409. mediapipe/tasks/cc/vision/image_embedder/proto/__init__.py +0 -0
  410. mediapipe/tasks/cc/vision/image_embedder/proto/image_embedder_graph_options_pb2.py +35 -0
  411. mediapipe/tasks/cc/vision/image_generator/__init__.py +0 -0
  412. mediapipe/tasks/cc/vision/image_generator/diffuser/__init__.py +0 -0
  413. mediapipe/tasks/cc/vision/image_generator/diffuser/stable_diffusion_iterate_calculator_pb2.py +40 -0
  414. mediapipe/tasks/cc/vision/image_generator/proto/__init__.py +0 -0
  415. mediapipe/tasks/cc/vision/image_generator/proto/conditioned_image_graph_options_pb2.py +40 -0
  416. mediapipe/tasks/cc/vision/image_generator/proto/control_plugin_graph_options_pb2.py +34 -0
  417. mediapipe/tasks/cc/vision/image_generator/proto/image_generator_graph_options_pb2.py +30 -0
  418. mediapipe/tasks/cc/vision/image_segmenter/__init__.py +0 -0
  419. mediapipe/tasks/cc/vision/image_segmenter/calculators/__init__.py +0 -0
  420. mediapipe/tasks/cc/vision/image_segmenter/calculators/tensors_to_segmentation_calculator_pb2.py +34 -0
  421. mediapipe/tasks/cc/vision/image_segmenter/proto/__init__.py +0 -0
  422. mediapipe/tasks/cc/vision/image_segmenter/proto/image_segmenter_graph_options_pb2.py +35 -0
  423. mediapipe/tasks/cc/vision/image_segmenter/proto/segmenter_options_pb2.py +33 -0
  424. mediapipe/tasks/cc/vision/interactive_segmenter/__init__.py +0 -0
  425. mediapipe/tasks/cc/vision/object_detector/__init__.py +0 -0
  426. mediapipe/tasks/cc/vision/object_detector/proto/__init__.py +0 -0
  427. mediapipe/tasks/cc/vision/object_detector/proto/object_detector_options_pb2.py +34 -0
  428. mediapipe/tasks/cc/vision/pose_detector/__init__.py +0 -0
  429. mediapipe/tasks/cc/vision/pose_detector/proto/__init__.py +0 -0
  430. mediapipe/tasks/cc/vision/pose_detector/proto/pose_detector_graph_options_pb2.py +34 -0
  431. mediapipe/tasks/cc/vision/pose_landmarker/__init__.py +0 -0
  432. mediapipe/tasks/cc/vision/pose_landmarker/proto/__init__.py +0 -0
  433. mediapipe/tasks/cc/vision/pose_landmarker/proto/pose_landmarker_graph_options_pb2.py +36 -0
  434. mediapipe/tasks/cc/vision/pose_landmarker/proto/pose_landmarks_detector_graph_options_pb2.py +34 -0
  435. mediapipe/tasks/cc/vision/utils/__init__.py +0 -0
  436. mediapipe/tasks/cc/vision/utils/ghum/__init__.py +0 -0
  437. mediapipe/tasks/metadata/image_segmenter_metadata_schema.fbs +59 -0
  438. mediapipe/tasks/metadata/image_segmenter_metadata_schema_py_generated.py +108 -0
  439. mediapipe/tasks/metadata/metadata_schema.fbs +732 -0
  440. mediapipe/tasks/metadata/metadata_schema_py_generated.py +3251 -0
  441. mediapipe/tasks/metadata/object_detector_metadata_schema.fbs +98 -0
  442. mediapipe/tasks/metadata/object_detector_metadata_schema_py_generated.py +674 -0
  443. mediapipe/tasks/metadata/schema_py_generated.py +18438 -0
  444. mediapipe/tasks/python/__init__.py +27 -0
  445. mediapipe/tasks/python/audio/__init__.py +33 -0
  446. mediapipe/tasks/python/audio/audio_classifier.py +324 -0
  447. mediapipe/tasks/python/audio/audio_embedder.py +285 -0
  448. mediapipe/tasks/python/audio/core/__init__.py +16 -0
  449. mediapipe/tasks/python/audio/core/audio_record.py +125 -0
  450. mediapipe/tasks/python/audio/core/audio_task_running_mode.py +29 -0
  451. mediapipe/tasks/python/audio/core/base_audio_task_api.py +181 -0
  452. mediapipe/tasks/python/benchmark/__init__.py +13 -0
  453. mediapipe/tasks/python/benchmark/benchmark_utils.py +70 -0
  454. mediapipe/tasks/python/benchmark/vision/__init__.py +13 -0
  455. mediapipe/tasks/python/benchmark/vision/benchmark.py +99 -0
  456. mediapipe/tasks/python/benchmark/vision/core/__init__.py +14 -0
  457. mediapipe/tasks/python/benchmark/vision/core/base_vision_benchmark_api.py +40 -0
  458. mediapipe/tasks/python/components/__init__.py +13 -0
  459. mediapipe/tasks/python/components/containers/__init__.py +53 -0
  460. mediapipe/tasks/python/components/containers/audio_data.py +137 -0
  461. mediapipe/tasks/python/components/containers/bounding_box.py +73 -0
  462. mediapipe/tasks/python/components/containers/category.py +78 -0
  463. mediapipe/tasks/python/components/containers/classification_result.py +111 -0
  464. mediapipe/tasks/python/components/containers/detections.py +181 -0
  465. mediapipe/tasks/python/components/containers/embedding_result.py +89 -0
  466. mediapipe/tasks/python/components/containers/keypoint.py +77 -0
  467. mediapipe/tasks/python/components/containers/landmark.py +122 -0
  468. mediapipe/tasks/python/components/containers/landmark_detection_result.py +106 -0
  469. mediapipe/tasks/python/components/containers/rect.py +109 -0
  470. mediapipe/tasks/python/components/processors/__init__.py +23 -0
  471. mediapipe/tasks/python/components/processors/classifier_options.py +86 -0
  472. mediapipe/tasks/python/components/utils/__init__.py +13 -0
  473. mediapipe/tasks/python/components/utils/cosine_similarity.py +68 -0
  474. mediapipe/tasks/python/core/__init__.py +13 -0
  475. mediapipe/tasks/python/core/base_options.py +121 -0
  476. mediapipe/tasks/python/core/optional_dependencies.py +25 -0
  477. mediapipe/tasks/python/core/task_info.py +139 -0
  478. mediapipe/tasks/python/genai/__init__.py +14 -0
  479. mediapipe/tasks/python/genai/bundler/__init__.py +23 -0
  480. mediapipe/tasks/python/genai/bundler/llm_bundler.py +130 -0
  481. mediapipe/tasks/python/genai/bundler/llm_bundler_test.py +168 -0
  482. mediapipe/tasks/python/genai/converter/__init__.py +24 -0
  483. mediapipe/tasks/python/genai/converter/converter_base.py +179 -0
  484. mediapipe/tasks/python/genai/converter/converter_factory.py +79 -0
  485. mediapipe/tasks/python/genai/converter/llm_converter.py +374 -0
  486. mediapipe/tasks/python/genai/converter/llm_converter_test.py +63 -0
  487. mediapipe/tasks/python/genai/converter/pytorch_converter.py +318 -0
  488. mediapipe/tasks/python/genai/converter/pytorch_converter_test.py +86 -0
  489. mediapipe/tasks/python/genai/converter/quantization_util.py +516 -0
  490. mediapipe/tasks/python/genai/converter/quantization_util_test.py +259 -0
  491. mediapipe/tasks/python/genai/converter/safetensors_converter.py +580 -0
  492. mediapipe/tasks/python/genai/converter/safetensors_converter_test.py +83 -0
  493. mediapipe/tasks/python/genai/converter/weight_bins_writer.py +120 -0
  494. mediapipe/tasks/python/genai/converter/weight_bins_writer_test.py +95 -0
  495. mediapipe/tasks/python/metadata/__init__.py +13 -0
  496. mediapipe/tasks/python/metadata/flatbuffers_lib/_pywrap_flatbuffers.cpython-312-x86_64-linux-gnu.so +0 -0
  497. mediapipe/tasks/python/metadata/metadata.py +928 -0
  498. mediapipe/tasks/python/metadata/metadata_displayer_cli.py +34 -0
  499. mediapipe/tasks/python/metadata/metadata_writers/__init__.py +13 -0
  500. mediapipe/tasks/python/metadata/metadata_writers/face_stylizer.py +138 -0
  501. mediapipe/tasks/python/metadata/metadata_writers/image_classifier.py +71 -0
  502. mediapipe/tasks/python/metadata/metadata_writers/image_segmenter.py +170 -0
  503. mediapipe/tasks/python/metadata/metadata_writers/metadata_info.py +1166 -0
  504. mediapipe/tasks/python/metadata/metadata_writers/metadata_writer.py +845 -0
  505. mediapipe/tasks/python/metadata/metadata_writers/model_asset_bundle_utils.py +71 -0
  506. mediapipe/tasks/python/metadata/metadata_writers/object_detector.py +331 -0
  507. mediapipe/tasks/python/metadata/metadata_writers/text_classifier.py +119 -0
  508. mediapipe/tasks/python/metadata/metadata_writers/writer_utils.py +91 -0
  509. mediapipe/tasks/python/test/__init__.py +13 -0
  510. mediapipe/tasks/python/test/audio/__init__.py +13 -0
  511. mediapipe/tasks/python/test/audio/audio_classifier_test.py +387 -0
  512. mediapipe/tasks/python/test/audio/audio_embedder_test.py +297 -0
  513. mediapipe/tasks/python/test/test_utils.py +196 -0
  514. mediapipe/tasks/python/test/text/__init__.py +13 -0
  515. mediapipe/tasks/python/test/text/language_detector_test.py +228 -0
  516. mediapipe/tasks/python/test/text/text_classifier_test.py +235 -0
  517. mediapipe/tasks/python/test/text/text_embedder_test.py +326 -0
  518. mediapipe/tasks/python/test/vision/__init__.py +13 -0
  519. mediapipe/tasks/python/test/vision/face_aligner_test.py +190 -0
  520. mediapipe/tasks/python/test/vision/face_detector_test.py +523 -0
  521. mediapipe/tasks/python/test/vision/face_landmarker_test.py +565 -0
  522. mediapipe/tasks/python/test/vision/face_stylizer_test.py +191 -0
  523. mediapipe/tasks/python/test/vision/hand_landmarker_test.py +437 -0
  524. mediapipe/tasks/python/test/vision/holistic_landmarker_test.py +544 -0
  525. mediapipe/tasks/python/test/vision/image_classifier_test.py +657 -0
  526. mediapipe/tasks/python/test/vision/image_embedder_test.py +423 -0
  527. mediapipe/tasks/python/test/vision/image_segmenter_test.py +512 -0
  528. mediapipe/tasks/python/test/vision/interactive_segmenter_test.py +341 -0
  529. mediapipe/tasks/python/test/vision/object_detector_test.py +493 -0
  530. mediapipe/tasks/python/test/vision/pose_landmarker_test.py +518 -0
  531. mediapipe/tasks/python/text/__init__.py +35 -0
  532. mediapipe/tasks/python/text/core/__init__.py +16 -0
  533. mediapipe/tasks/python/text/core/base_text_task_api.py +54 -0
  534. mediapipe/tasks/python/text/language_detector.py +220 -0
  535. mediapipe/tasks/python/text/text_classifier.py +187 -0
  536. mediapipe/tasks/python/text/text_embedder.py +188 -0
  537. mediapipe/tasks/python/vision/__init__.py +90 -0
  538. mediapipe/tasks/python/vision/core/__init__.py +14 -0
  539. mediapipe/tasks/python/vision/core/base_vision_task_api.py +226 -0
  540. mediapipe/tasks/python/vision/core/image_processing_options.py +39 -0
  541. mediapipe/tasks/python/vision/core/vision_task_running_mode.py +31 -0
  542. mediapipe/tasks/python/vision/face_aligner.py +158 -0
  543. mediapipe/tasks/python/vision/face_detector.py +332 -0
  544. mediapipe/tasks/python/vision/face_landmarker.py +3244 -0
  545. mediapipe/tasks/python/vision/face_stylizer.py +158 -0
  546. mediapipe/tasks/python/vision/gesture_recognizer.py +480 -0
  547. mediapipe/tasks/python/vision/hand_landmarker.py +504 -0
  548. mediapipe/tasks/python/vision/holistic_landmarker.py +576 -0
  549. mediapipe/tasks/python/vision/image_classifier.py +358 -0
  550. mediapipe/tasks/python/vision/image_embedder.py +362 -0
  551. mediapipe/tasks/python/vision/image_segmenter.py +433 -0
  552. mediapipe/tasks/python/vision/interactive_segmenter.py +285 -0
  553. mediapipe/tasks/python/vision/object_detector.py +389 -0
  554. mediapipe/tasks/python/vision/pose_landmarker.py +455 -0
  555. mediapipe/util/__init__.py +0 -0
  556. mediapipe/util/analytics/__init__.py +0 -0
  557. mediapipe/util/analytics/mediapipe_log_extension_pb2.py +44 -0
  558. mediapipe/util/analytics/mediapipe_logging_enums_pb2.py +37 -0
  559. mediapipe/util/audio_decoder_pb2.py +33 -0
  560. mediapipe/util/color_pb2.py +33 -0
  561. mediapipe/util/label_map_pb2.py +27 -0
  562. mediapipe/util/render_data_pb2.py +58 -0
  563. mediapipe/util/sequence/__init__.py +14 -0
  564. mediapipe/util/sequence/media_sequence.py +716 -0
  565. mediapipe/util/sequence/media_sequence_test.py +290 -0
  566. mediapipe/util/sequence/media_sequence_util.py +800 -0
  567. mediapipe/util/sequence/media_sequence_util_test.py +389 -0
  568. mediapipe/util/tracking/__init__.py +0 -0
  569. mediapipe/util/tracking/box_detector_pb2.py +39 -0
  570. mediapipe/util/tracking/box_tracker_pb2.py +32 -0
  571. mediapipe/util/tracking/camera_motion_pb2.py +31 -0
  572. mediapipe/util/tracking/flow_packager_pb2.py +60 -0
  573. mediapipe/util/tracking/frame_selection_pb2.py +35 -0
  574. mediapipe/util/tracking/frame_selection_solution_evaluator_pb2.py +28 -0
  575. mediapipe/util/tracking/motion_analysis_pb2.py +35 -0
  576. mediapipe/util/tracking/motion_estimation_pb2.py +66 -0
  577. mediapipe/util/tracking/motion_models_pb2.py +42 -0
  578. mediapipe/util/tracking/motion_saliency_pb2.py +26 -0
  579. mediapipe/util/tracking/push_pull_filtering_pb2.py +26 -0
  580. mediapipe/util/tracking/region_flow_computation_pb2.py +59 -0
  581. mediapipe/util/tracking/region_flow_pb2.py +49 -0
  582. mediapipe/util/tracking/tone_estimation_pb2.py +45 -0
  583. mediapipe/util/tracking/tone_models_pb2.py +32 -0
  584. mediapipe/util/tracking/tracked_detection_manager_config_pb2.py +26 -0
  585. mediapipe/util/tracking/tracking_pb2.py +73 -0
  586. mediapipe_nightly-0.10.21.post20241223.dist-info/LICENSE +218 -0
  587. mediapipe_nightly-0.10.21.post20241223.dist-info/METADATA +199 -0
  588. mediapipe_nightly-0.10.21.post20241223.dist-info/RECORD +593 -0
  589. mediapipe_nightly-0.10.21.post20241223.dist-info/WHEEL +5 -0
  590. mediapipe_nightly-0.10.21.post20241223.dist-info/top_level.txt +4 -0
  591. mediapipe_nightly.libs/libEGL-48f73270.so.1.1.0 +0 -0
  592. mediapipe_nightly.libs/libGLESv2-ed5eda4f.so.2.1.0 +0 -0
  593. mediapipe_nightly.libs/libGLdispatch-64b28464.so.0.0.0 +0 -0
@@ -0,0 +1,518 @@
1
+ # Copyright 2023 The MediaPipe Authors. All Rights Reserved.
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+ """Tests for pose landmarker."""
15
+
16
+ import enum
17
+ from typing import List
18
+ from unittest import mock
19
+
20
+ from absl.testing import absltest
21
+ from absl.testing import parameterized
22
+ import numpy as np
23
+
24
+ from google.protobuf import text_format
25
+ from mediapipe.python._framework_bindings import image as image_module
26
+ from mediapipe.tasks.cc.components.containers.proto import landmarks_detection_result_pb2
27
+ from mediapipe.tasks.python.components.containers import landmark as landmark_module
28
+ from mediapipe.tasks.python.components.containers import landmark_detection_result as landmark_detection_result_module
29
+ from mediapipe.tasks.python.components.containers import rect as rect_module
30
+ from mediapipe.tasks.python.core import base_options as base_options_module
31
+ from mediapipe.tasks.python.test import test_utils
32
+ from mediapipe.tasks.python.vision import pose_landmarker
33
+ from mediapipe.tasks.python.vision.core import image_processing_options as image_processing_options_module
34
+ from mediapipe.tasks.python.vision.core import vision_task_running_mode as running_mode_module
35
+
36
+ PoseLandmarkerResult = pose_landmarker.PoseLandmarkerResult
37
+ _LandmarksDetectionResultProto = (
38
+ landmarks_detection_result_pb2.LandmarksDetectionResult
39
+ )
40
+ _BaseOptions = base_options_module.BaseOptions
41
+ _Rect = rect_module.Rect
42
+ _Landmark = landmark_module.Landmark
43
+ _NormalizedLandmark = landmark_module.NormalizedLandmark
44
+ _LandmarksDetectionResult = (
45
+ landmark_detection_result_module.LandmarksDetectionResult
46
+ )
47
+ _Image = image_module.Image
48
+ _PoseLandmarker = pose_landmarker.PoseLandmarker
49
+ _PoseLandmarkerOptions = pose_landmarker.PoseLandmarkerOptions
50
+ _RUNNING_MODE = running_mode_module.VisionTaskRunningMode
51
+ _ImageProcessingOptions = image_processing_options_module.ImageProcessingOptions
52
+
53
+ _POSE_LANDMARKER_BUNDLE_ASSET_FILE = 'pose_landmarker.task'
54
+ _BURGER_IMAGE = 'burger.jpg'
55
+ _POSE_IMAGE = 'pose.jpg'
56
+ _POSE_LANDMARKS = 'pose_landmarks.pbtxt'
57
+ _LANDMARKS_MARGIN = 0.03
58
+
59
+
60
+ def _get_expected_pose_landmarker_result(
61
+ file_path: str,
62
+ ) -> PoseLandmarkerResult:
63
+ landmarks_detection_result_file_path = test_utils.get_test_data_path(
64
+ file_path
65
+ )
66
+ with open(landmarks_detection_result_file_path, 'rb') as f:
67
+ landmarks_detection_result_proto = _LandmarksDetectionResultProto()
68
+ # Use this if a .pb file is available.
69
+ # landmarks_detection_result_proto.ParseFromString(f.read())
70
+ text_format.Parse(f.read(), landmarks_detection_result_proto)
71
+ landmarks_detection_result = _LandmarksDetectionResult.create_from_pb2(
72
+ landmarks_detection_result_proto
73
+ )
74
+ return PoseLandmarkerResult(
75
+ pose_landmarks=[landmarks_detection_result.landmarks],
76
+ pose_world_landmarks=[],
77
+ )
78
+
79
+
80
+ class ModelFileType(enum.Enum):
81
+ FILE_CONTENT = 1
82
+ FILE_NAME = 2
83
+
84
+
85
+ class PoseLandmarkerTest(parameterized.TestCase):
86
+
87
+ def setUp(self):
88
+ super().setUp()
89
+ self.test_image = _Image.create_from_file(
90
+ test_utils.get_test_data_path(_POSE_IMAGE)
91
+ )
92
+ self.model_path = test_utils.get_test_data_path(
93
+ _POSE_LANDMARKER_BUNDLE_ASSET_FILE
94
+ )
95
+
96
+ def _expect_pose_landmarks_correct(
97
+ self, actual_landmarks, expected_landmarks, margin
98
+ ):
99
+ # Expects to have the same number of poses detected.
100
+ self.assertLen(actual_landmarks, len(expected_landmarks))
101
+
102
+ for i, _ in enumerate(actual_landmarks):
103
+ for j, elem in enumerate(actual_landmarks[i]):
104
+ self.assertAlmostEqual(elem.x, expected_landmarks[i][j].x, delta=margin)
105
+ self.assertAlmostEqual(elem.y, expected_landmarks[i][j].y, delta=margin)
106
+
107
+ def _expect_pose_landmarker_results_correct(
108
+ self,
109
+ actual_result: PoseLandmarkerResult,
110
+ expected_result: PoseLandmarkerResult,
111
+ output_segmentation_masks: bool,
112
+ margin: float,
113
+ ):
114
+ self._expect_pose_landmarks_correct(
115
+ actual_result.pose_landmarks, expected_result.pose_landmarks, margin
116
+ )
117
+ if output_segmentation_masks:
118
+ self.assertIsInstance(actual_result.segmentation_masks, List)
119
+ for _, mask in enumerate(actual_result.segmentation_masks):
120
+ self.assertIsInstance(mask, _Image)
121
+ else:
122
+ self.assertIsNone(actual_result.segmentation_masks)
123
+
124
+ def test_create_from_file_succeeds_with_valid_model_path(self):
125
+ # Creates with default option and valid model file successfully.
126
+ with _PoseLandmarker.create_from_model_path(self.model_path) as landmarker:
127
+ self.assertIsInstance(landmarker, _PoseLandmarker)
128
+
129
+ def test_create_from_options_succeeds_with_valid_model_path(self):
130
+ # Creates with options containing model file successfully.
131
+ base_options = _BaseOptions(model_asset_path=self.model_path)
132
+ options = _PoseLandmarkerOptions(base_options=base_options)
133
+ with _PoseLandmarker.create_from_options(options) as landmarker:
134
+ self.assertIsInstance(landmarker, _PoseLandmarker)
135
+
136
+ def test_create_from_options_fails_with_invalid_model_path(self):
137
+ # Invalid empty model path.
138
+ with self.assertRaisesRegex(
139
+ RuntimeError, 'Unable to open file at /path/to/invalid/model.tflite'
140
+ ):
141
+ base_options = _BaseOptions(
142
+ model_asset_path='/path/to/invalid/model.tflite'
143
+ )
144
+ options = _PoseLandmarkerOptions(base_options=base_options)
145
+ _PoseLandmarker.create_from_options(options)
146
+
147
+ def test_create_from_options_succeeds_with_valid_model_content(self):
148
+ # Creates with options containing model content successfully.
149
+ with open(self.model_path, 'rb') as f:
150
+ base_options = _BaseOptions(model_asset_buffer=f.read())
151
+ options = _PoseLandmarkerOptions(base_options=base_options)
152
+ landmarker = _PoseLandmarker.create_from_options(options)
153
+ self.assertIsInstance(landmarker, _PoseLandmarker)
154
+
155
+ @parameterized.parameters(
156
+ (
157
+ ModelFileType.FILE_NAME,
158
+ False,
159
+ _get_expected_pose_landmarker_result(_POSE_LANDMARKS),
160
+ ),
161
+ (
162
+ ModelFileType.FILE_CONTENT,
163
+ False,
164
+ _get_expected_pose_landmarker_result(_POSE_LANDMARKS),
165
+ ),
166
+ (
167
+ ModelFileType.FILE_NAME,
168
+ True,
169
+ _get_expected_pose_landmarker_result(_POSE_LANDMARKS),
170
+ ),
171
+ (
172
+ ModelFileType.FILE_CONTENT,
173
+ True,
174
+ _get_expected_pose_landmarker_result(_POSE_LANDMARKS),
175
+ ),
176
+ )
177
+ def test_detect(
178
+ self,
179
+ model_file_type,
180
+ output_segmentation_masks,
181
+ expected_detection_result,
182
+ ):
183
+ # Creates pose landmarker.
184
+ if model_file_type is ModelFileType.FILE_NAME:
185
+ base_options = _BaseOptions(model_asset_path=self.model_path)
186
+ elif model_file_type is ModelFileType.FILE_CONTENT:
187
+ with open(self.model_path, 'rb') as f:
188
+ model_content = f.read()
189
+ base_options = _BaseOptions(model_asset_buffer=model_content)
190
+ else:
191
+ # Should never happen
192
+ raise ValueError('model_file_type is invalid.')
193
+
194
+ options = _PoseLandmarkerOptions(
195
+ base_options=base_options,
196
+ output_segmentation_masks=output_segmentation_masks,
197
+ )
198
+ landmarker = _PoseLandmarker.create_from_options(options)
199
+
200
+ # Performs pose landmarks detection on the input.
201
+ detection_result = landmarker.detect(self.test_image)
202
+
203
+ # Comparing results.
204
+ self._expect_pose_landmarker_results_correct(
205
+ detection_result,
206
+ expected_detection_result,
207
+ output_segmentation_masks,
208
+ _LANDMARKS_MARGIN,
209
+ )
210
+ # Closes the pose landmarker explicitly when the pose landmarker is not used
211
+ # in a context.
212
+ landmarker.close()
213
+
214
+ @parameterized.parameters(
215
+ (
216
+ ModelFileType.FILE_NAME,
217
+ False,
218
+ _get_expected_pose_landmarker_result(_POSE_LANDMARKS),
219
+ ),
220
+ (
221
+ ModelFileType.FILE_CONTENT,
222
+ False,
223
+ _get_expected_pose_landmarker_result(_POSE_LANDMARKS),
224
+ ),
225
+ (
226
+ ModelFileType.FILE_NAME,
227
+ True,
228
+ _get_expected_pose_landmarker_result(_POSE_LANDMARKS),
229
+ ),
230
+ (
231
+ ModelFileType.FILE_CONTENT,
232
+ True,
233
+ _get_expected_pose_landmarker_result(_POSE_LANDMARKS),
234
+ ),
235
+ )
236
+ def test_detect_in_context(
237
+ self,
238
+ model_file_type,
239
+ output_segmentation_masks,
240
+ expected_detection_result,
241
+ ):
242
+ # Creates pose landmarker.
243
+ if model_file_type is ModelFileType.FILE_NAME:
244
+ base_options = _BaseOptions(model_asset_path=self.model_path)
245
+ elif model_file_type is ModelFileType.FILE_CONTENT:
246
+ with open(self.model_path, 'rb') as f:
247
+ model_content = f.read()
248
+ base_options = _BaseOptions(model_asset_buffer=model_content)
249
+ else:
250
+ # Should never happen
251
+ raise ValueError('model_file_type is invalid.')
252
+
253
+ options = _PoseLandmarkerOptions(
254
+ base_options=base_options,
255
+ output_segmentation_masks=output_segmentation_masks,
256
+ )
257
+ with _PoseLandmarker.create_from_options(options) as landmarker:
258
+ # Performs pose landmarks detection on the input.
259
+ detection_result = landmarker.detect(self.test_image)
260
+
261
+ # Comparing results.
262
+ self._expect_pose_landmarker_results_correct(
263
+ detection_result,
264
+ expected_detection_result,
265
+ output_segmentation_masks,
266
+ _LANDMARKS_MARGIN,
267
+ )
268
+
269
+ def test_detect_fails_with_region_of_interest(self):
270
+ # Creates pose landmarker.
271
+ base_options = _BaseOptions(model_asset_path=self.model_path)
272
+ options = _PoseLandmarkerOptions(base_options=base_options)
273
+ with self.assertRaisesRegex(
274
+ ValueError, "This task doesn't support region-of-interest."
275
+ ):
276
+ with _PoseLandmarker.create_from_options(options) as landmarker:
277
+ # Set the `region_of_interest` parameter using `ImageProcessingOptions`.
278
+ image_processing_options = _ImageProcessingOptions(
279
+ region_of_interest=_Rect(0, 0, 1, 1)
280
+ )
281
+ # Attempt to perform pose landmarks detection on the cropped input.
282
+ landmarker.detect(self.test_image, image_processing_options)
283
+
284
+ def test_empty_detection_outputs(self):
285
+ # Creates pose landmarker.
286
+ base_options = _BaseOptions(model_asset_path=self.model_path)
287
+ options = _PoseLandmarkerOptions(base_options=base_options)
288
+ with _PoseLandmarker.create_from_options(options) as landmarker:
289
+ # Load an image with no poses.
290
+ test_image = _Image.create_from_file(
291
+ test_utils.get_test_data_path(_BURGER_IMAGE)
292
+ )
293
+ # Performs pose landmarks detection on the input.
294
+ detection_result = landmarker.detect(test_image)
295
+ # Comparing results.
296
+ self.assertEmpty(detection_result.pose_landmarks)
297
+ self.assertEmpty(detection_result.pose_world_landmarks)
298
+
299
+ def test_missing_result_callback(self):
300
+ options = _PoseLandmarkerOptions(
301
+ base_options=_BaseOptions(model_asset_path=self.model_path),
302
+ running_mode=_RUNNING_MODE.LIVE_STREAM,
303
+ )
304
+ with self.assertRaisesRegex(
305
+ ValueError, r'result callback must be provided'
306
+ ):
307
+ with _PoseLandmarker.create_from_options(options) as unused_landmarker:
308
+ pass
309
+
310
+ @parameterized.parameters((_RUNNING_MODE.IMAGE), (_RUNNING_MODE.VIDEO))
311
+ def test_illegal_result_callback(self, running_mode):
312
+ options = _PoseLandmarkerOptions(
313
+ base_options=_BaseOptions(model_asset_path=self.model_path),
314
+ running_mode=running_mode,
315
+ result_callback=mock.MagicMock(),
316
+ )
317
+ with self.assertRaisesRegex(
318
+ ValueError, r'result callback should not be provided'
319
+ ):
320
+ with _PoseLandmarker.create_from_options(options) as unused_landmarker:
321
+ pass
322
+
323
+ def test_calling_detect_for_video_in_image_mode(self):
324
+ options = _PoseLandmarkerOptions(
325
+ base_options=_BaseOptions(model_asset_path=self.model_path),
326
+ running_mode=_RUNNING_MODE.IMAGE,
327
+ )
328
+ with _PoseLandmarker.create_from_options(options) as landmarker:
329
+ with self.assertRaisesRegex(
330
+ ValueError, r'not initialized with the video mode'
331
+ ):
332
+ landmarker.detect_for_video(self.test_image, 0)
333
+
334
+ def test_calling_detect_async_in_image_mode(self):
335
+ options = _PoseLandmarkerOptions(
336
+ base_options=_BaseOptions(model_asset_path=self.model_path),
337
+ running_mode=_RUNNING_MODE.IMAGE,
338
+ )
339
+ with _PoseLandmarker.create_from_options(options) as landmarker:
340
+ with self.assertRaisesRegex(
341
+ ValueError, r'not initialized with the live stream mode'
342
+ ):
343
+ landmarker.detect_async(self.test_image, 0)
344
+
345
+ def test_calling_detect_in_video_mode(self):
346
+ options = _PoseLandmarkerOptions(
347
+ base_options=_BaseOptions(model_asset_path=self.model_path),
348
+ running_mode=_RUNNING_MODE.VIDEO,
349
+ )
350
+ with _PoseLandmarker.create_from_options(options) as landmarker:
351
+ with self.assertRaisesRegex(
352
+ ValueError, r'not initialized with the image mode'
353
+ ):
354
+ landmarker.detect(self.test_image)
355
+
356
+ def test_calling_detect_async_in_video_mode(self):
357
+ options = _PoseLandmarkerOptions(
358
+ base_options=_BaseOptions(model_asset_path=self.model_path),
359
+ running_mode=_RUNNING_MODE.VIDEO,
360
+ )
361
+ with _PoseLandmarker.create_from_options(options) as landmarker:
362
+ with self.assertRaisesRegex(
363
+ ValueError, r'not initialized with the live stream mode'
364
+ ):
365
+ landmarker.detect_async(self.test_image, 0)
366
+
367
+ def test_detect_for_video_with_out_of_order_timestamp(self):
368
+ options = _PoseLandmarkerOptions(
369
+ base_options=_BaseOptions(model_asset_path=self.model_path),
370
+ running_mode=_RUNNING_MODE.VIDEO,
371
+ )
372
+ with _PoseLandmarker.create_from_options(options) as landmarker:
373
+ unused_result = landmarker.detect_for_video(self.test_image, 1)
374
+ with self.assertRaisesRegex(
375
+ ValueError, r'Input timestamp must be monotonically increasing'
376
+ ):
377
+ landmarker.detect_for_video(self.test_image, 0)
378
+
379
+ @parameterized.parameters(
380
+ (
381
+ _POSE_IMAGE,
382
+ 0,
383
+ False,
384
+ _get_expected_pose_landmarker_result(_POSE_LANDMARKS),
385
+ ),
386
+ (
387
+ _POSE_IMAGE,
388
+ 0,
389
+ True,
390
+ _get_expected_pose_landmarker_result(_POSE_LANDMARKS),
391
+ ),
392
+ (_BURGER_IMAGE, 0, False, PoseLandmarkerResult([], [])),
393
+ )
394
+ def test_detect_for_video(
395
+ self, image_path, rotation, output_segmentation_masks, expected_result
396
+ ):
397
+ test_image = _Image.create_from_file(
398
+ test_utils.get_test_data_path(image_path)
399
+ )
400
+ # Set rotation parameters using ImageProcessingOptions.
401
+ image_processing_options = _ImageProcessingOptions(
402
+ rotation_degrees=rotation
403
+ )
404
+ options = _PoseLandmarkerOptions(
405
+ base_options=_BaseOptions(model_asset_path=self.model_path),
406
+ output_segmentation_masks=output_segmentation_masks,
407
+ running_mode=_RUNNING_MODE.VIDEO,
408
+ )
409
+ with _PoseLandmarker.create_from_options(options) as landmarker:
410
+ for timestamp in range(0, 300, 30):
411
+ result = landmarker.detect_for_video(
412
+ test_image, timestamp, image_processing_options
413
+ )
414
+ if result.pose_landmarks:
415
+ self._expect_pose_landmarker_results_correct(
416
+ result,
417
+ expected_result,
418
+ output_segmentation_masks,
419
+ _LANDMARKS_MARGIN,
420
+ )
421
+ else:
422
+ self.assertEqual(result, expected_result)
423
+
424
+ def test_calling_detect_in_live_stream_mode(self):
425
+ options = _PoseLandmarkerOptions(
426
+ base_options=_BaseOptions(model_asset_path=self.model_path),
427
+ running_mode=_RUNNING_MODE.LIVE_STREAM,
428
+ result_callback=mock.MagicMock(),
429
+ )
430
+ with _PoseLandmarker.create_from_options(options) as landmarker:
431
+ with self.assertRaisesRegex(
432
+ ValueError, r'not initialized with the image mode'
433
+ ):
434
+ landmarker.detect(self.test_image)
435
+
436
+ def test_calling_detect_for_video_in_live_stream_mode(self):
437
+ options = _PoseLandmarkerOptions(
438
+ base_options=_BaseOptions(model_asset_path=self.model_path),
439
+ running_mode=_RUNNING_MODE.LIVE_STREAM,
440
+ result_callback=mock.MagicMock(),
441
+ )
442
+ with _PoseLandmarker.create_from_options(options) as landmarker:
443
+ with self.assertRaisesRegex(
444
+ ValueError, r'not initialized with the video mode'
445
+ ):
446
+ landmarker.detect_for_video(self.test_image, 0)
447
+
448
+ def test_detect_async_calls_with_illegal_timestamp(self):
449
+ options = _PoseLandmarkerOptions(
450
+ base_options=_BaseOptions(model_asset_path=self.model_path),
451
+ running_mode=_RUNNING_MODE.LIVE_STREAM,
452
+ result_callback=mock.MagicMock(),
453
+ )
454
+ with _PoseLandmarker.create_from_options(options) as landmarker:
455
+ landmarker.detect_async(self.test_image, 100)
456
+ with self.assertRaisesRegex(
457
+ ValueError, r'Input timestamp must be monotonically increasing'
458
+ ):
459
+ landmarker.detect_async(self.test_image, 0)
460
+
461
+ @parameterized.parameters(
462
+ (
463
+ _POSE_IMAGE,
464
+ 0,
465
+ False,
466
+ _get_expected_pose_landmarker_result(_POSE_LANDMARKS),
467
+ ),
468
+ (
469
+ _POSE_IMAGE,
470
+ 0,
471
+ True,
472
+ _get_expected_pose_landmarker_result(_POSE_LANDMARKS),
473
+ ),
474
+ (_BURGER_IMAGE, 0, False, PoseLandmarkerResult([], [])),
475
+ )
476
+ def test_detect_async_calls(
477
+ self, image_path, rotation, output_segmentation_masks, expected_result
478
+ ):
479
+ test_image = _Image.create_from_file(
480
+ test_utils.get_test_data_path(image_path)
481
+ )
482
+ # Set rotation parameters using ImageProcessingOptions.
483
+ image_processing_options = _ImageProcessingOptions(
484
+ rotation_degrees=rotation
485
+ )
486
+ observed_timestamp_ms = -1
487
+
488
+ def check_result(
489
+ result: PoseLandmarkerResult, output_image: _Image, timestamp_ms: int
490
+ ):
491
+ if result.pose_landmarks:
492
+ self._expect_pose_landmarker_results_correct(
493
+ result,
494
+ expected_result,
495
+ output_segmentation_masks,
496
+ _LANDMARKS_MARGIN,
497
+ )
498
+ else:
499
+ self.assertEqual(result, expected_result)
500
+ self.assertTrue(
501
+ np.array_equal(output_image.numpy_view(), test_image.numpy_view())
502
+ )
503
+ self.assertLess(observed_timestamp_ms, timestamp_ms)
504
+ self.observed_timestamp_ms = timestamp_ms
505
+
506
+ options = _PoseLandmarkerOptions(
507
+ base_options=_BaseOptions(model_asset_path=self.model_path),
508
+ output_segmentation_masks=output_segmentation_masks,
509
+ running_mode=_RUNNING_MODE.LIVE_STREAM,
510
+ result_callback=check_result,
511
+ )
512
+ with _PoseLandmarker.create_from_options(options) as landmarker:
513
+ for timestamp in range(0, 300, 30):
514
+ landmarker.detect_async(test_image, timestamp, image_processing_options)
515
+
516
+
517
+ if __name__ == '__main__':
518
+ absltest.main()
@@ -0,0 +1,35 @@
1
+ # Copyright 2022 The MediaPipe Authors.
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+
15
+ """MediaPipe Tasks Text API."""
16
+
17
+ import mediapipe.tasks.python.text.language_detector
18
+ import mediapipe.tasks.python.text.text_classifier
19
+ import mediapipe.tasks.python.text.text_embedder
20
+
21
+ LanguageDetector = language_detector.LanguageDetector
22
+ LanguageDetectorOptions = language_detector.LanguageDetectorOptions
23
+ LanguageDetectorResult = language_detector.LanguageDetectorResult
24
+ TextClassifier = text_classifier.TextClassifier
25
+ TextClassifierOptions = text_classifier.TextClassifierOptions
26
+ TextClassifierResult = text_classifier.TextClassifierResult
27
+ TextEmbedder = text_embedder.TextEmbedder
28
+ TextEmbedderOptions = text_embedder.TextEmbedderOptions
29
+ TextEmbedderResult = text_embedder.TextEmbedderResult
30
+
31
+ # Remove unnecessary modules to avoid duplication in API docs.
32
+ del mediapipe
33
+ del language_detector
34
+ del text_classifier
35
+ del text_embedder
@@ -0,0 +1,16 @@
1
+ """Copyright 2022 The MediaPipe Authors.
2
+
3
+ All Rights Reserved.
4
+
5
+ Licensed under the Apache License, Version 2.0 (the "License");
6
+ you may not use this file except in compliance with the License.
7
+ You may obtain a copy of the License at
8
+
9
+ http://www.apache.org/licenses/LICENSE-2.0
10
+
11
+ Unless required by applicable law or agreed to in writing, software
12
+ distributed under the License is distributed on an "AS IS" BASIS,
13
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ See the License for the specific language governing permissions and
15
+ limitations under the License.
16
+ """
@@ -0,0 +1,54 @@
1
+ # Copyright 2022 The MediaPipe Authors.
2
+ #
3
+ # Licensed under the Apache License, Version 2.0 (the "License");
4
+ # you may not use this file except in compliance with the License.
5
+ # You may obtain a copy of the License at
6
+ #
7
+ # http://www.apache.org/licenses/LICENSE-2.0
8
+ #
9
+ # Unless required by applicable law or agreed to in writing, software
10
+ # distributed under the License is distributed on an "AS IS" BASIS,
11
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
+ # See the License for the specific language governing permissions and
13
+ # limitations under the License.
14
+ """MediaPipe text task base api."""
15
+
16
+ from mediapipe.framework import calculator_pb2
17
+ from mediapipe.python._framework_bindings import task_runner
18
+ from mediapipe.tasks.python.core.optional_dependencies import doc_controls
19
+
20
+ _TaskRunner = task_runner.TaskRunner
21
+
22
+
23
+ @doc_controls.do_not_generate_docs
24
+ class BaseTextTaskApi(object):
25
+ """The base class of the user-facing mediapipe text task api classes."""
26
+
27
+ def __init__(self,
28
+ graph_config: calculator_pb2.CalculatorGraphConfig) -> None:
29
+ """Initializes the `BaseVisionTaskApi` object.
30
+
31
+ Args:
32
+ graph_config: The mediapipe text task graph config proto.
33
+ """
34
+ self._runner = _TaskRunner.create(graph_config)
35
+
36
+ def close(self) -> None:
37
+ """Shuts down the mediapipe text task instance.
38
+
39
+ Raises:
40
+ RuntimeError: If the mediapipe text task failed to close.
41
+ """
42
+ self._runner.close()
43
+
44
+ def __enter__(self):
45
+ """Returns `self` upon entering the runtime context."""
46
+ return self
47
+
48
+ def __exit__(self, unused_exc_type, unused_exc_value, unused_traceback):
49
+ """Shuts down the mediapipe text task instance on exit of the context manager.
50
+
51
+ Raises:
52
+ RuntimeError: If the mediapipe text task failed to close.
53
+ """
54
+ self.close()