mediapipe-nightly 0.10.21.post20241223__cp312-cp312-macosx_11_0_universal2.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 (594) 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/arm64.cpython-312-darwin.so +0 -0
  240. mediapipe/python/_framework_bindings.cpython-312-darwin.so +0 -0
  241. mediapipe/python/calculator_graph_test.py +251 -0
  242. mediapipe/python/image_frame_test.py +194 -0
  243. mediapipe/python/image_test.py +218 -0
  244. mediapipe/python/packet_creator.py +275 -0
  245. mediapipe/python/packet_getter.py +120 -0
  246. mediapipe/python/packet_test.py +533 -0
  247. mediapipe/python/solution_base.py +604 -0
  248. mediapipe/python/solution_base_test.py +396 -0
  249. mediapipe/python/solutions/__init__.py +27 -0
  250. mediapipe/python/solutions/download_utils.py +37 -0
  251. mediapipe/python/solutions/drawing_styles.py +249 -0
  252. mediapipe/python/solutions/drawing_utils.py +320 -0
  253. mediapipe/python/solutions/drawing_utils_test.py +258 -0
  254. mediapipe/python/solutions/face_detection.py +105 -0
  255. mediapipe/python/solutions/face_detection_test.py +92 -0
  256. mediapipe/python/solutions/face_mesh.py +125 -0
  257. mediapipe/python/solutions/face_mesh_connections.py +500 -0
  258. mediapipe/python/solutions/face_mesh_test.py +170 -0
  259. mediapipe/python/solutions/hands.py +153 -0
  260. mediapipe/python/solutions/hands_connections.py +32 -0
  261. mediapipe/python/solutions/hands_test.py +219 -0
  262. mediapipe/python/solutions/holistic.py +167 -0
  263. mediapipe/python/solutions/holistic_test.py +142 -0
  264. mediapipe/python/solutions/objectron.py +288 -0
  265. mediapipe/python/solutions/objectron_test.py +81 -0
  266. mediapipe/python/solutions/pose.py +192 -0
  267. mediapipe/python/solutions/pose_connections.py +22 -0
  268. mediapipe/python/solutions/pose_test.py +262 -0
  269. mediapipe/python/solutions/selfie_segmentation.py +76 -0
  270. mediapipe/python/solutions/selfie_segmentation_test.py +68 -0
  271. mediapipe/python/timestamp_test.py +78 -0
  272. mediapipe/tasks/__init__.py +14 -0
  273. mediapipe/tasks/cc/__init__.py +0 -0
  274. mediapipe/tasks/cc/audio/__init__.py +0 -0
  275. mediapipe/tasks/cc/audio/audio_classifier/__init__.py +0 -0
  276. mediapipe/tasks/cc/audio/audio_classifier/proto/__init__.py +0 -0
  277. mediapipe/tasks/cc/audio/audio_classifier/proto/audio_classifier_graph_options_pb2.py +35 -0
  278. mediapipe/tasks/cc/audio/audio_embedder/__init__.py +0 -0
  279. mediapipe/tasks/cc/audio/audio_embedder/proto/__init__.py +0 -0
  280. mediapipe/tasks/cc/audio/audio_embedder/proto/audio_embedder_graph_options_pb2.py +35 -0
  281. mediapipe/tasks/cc/audio/core/__init__.py +0 -0
  282. mediapipe/tasks/cc/audio/utils/__init__.py +0 -0
  283. mediapipe/tasks/cc/components/__init__.py +0 -0
  284. mediapipe/tasks/cc/components/calculators/__init__.py +0 -0
  285. mediapipe/tasks/cc/components/calculators/classification_aggregation_calculator_pb2.py +31 -0
  286. mediapipe/tasks/cc/components/calculators/score_calibration_calculator_pb2.py +35 -0
  287. mediapipe/tasks/cc/components/calculators/tensors_to_embeddings_calculator_pb2.py +32 -0
  288. mediapipe/tasks/cc/components/containers/__init__.py +0 -0
  289. mediapipe/tasks/cc/components/containers/proto/__init__.py +0 -0
  290. mediapipe/tasks/cc/components/containers/proto/classifications_pb2.py +30 -0
  291. mediapipe/tasks/cc/components/containers/proto/embeddings_pb2.py +35 -0
  292. mediapipe/tasks/cc/components/containers/proto/landmarks_detection_result_pb2.py +32 -0
  293. mediapipe/tasks/cc/components/processors/__init__.py +0 -0
  294. mediapipe/tasks/cc/components/processors/proto/__init__.py +0 -0
  295. mediapipe/tasks/cc/components/processors/proto/classification_postprocessing_graph_options_pb2.py +38 -0
  296. mediapipe/tasks/cc/components/processors/proto/classifier_options_pb2.py +27 -0
  297. mediapipe/tasks/cc/components/processors/proto/detection_postprocessing_graph_options_pb2.py +36 -0
  298. mediapipe/tasks/cc/components/processors/proto/detector_options_pb2.py +27 -0
  299. mediapipe/tasks/cc/components/processors/proto/embedder_options_pb2.py +27 -0
  300. mediapipe/tasks/cc/components/processors/proto/embedding_postprocessing_graph_options_pb2.py +32 -0
  301. mediapipe/tasks/cc/components/processors/proto/image_preprocessing_graph_options_pb2.py +34 -0
  302. mediapipe/tasks/cc/components/processors/proto/text_model_type_pb2.py +28 -0
  303. mediapipe/tasks/cc/components/processors/proto/text_preprocessing_graph_options_pb2.py +32 -0
  304. mediapipe/tasks/cc/components/utils/__init__.py +0 -0
  305. mediapipe/tasks/cc/core/__init__.py +0 -0
  306. mediapipe/tasks/cc/core/proto/__init__.py +0 -0
  307. mediapipe/tasks/cc/core/proto/acceleration_pb2.py +28 -0
  308. mediapipe/tasks/cc/core/proto/base_options_pb2.py +30 -0
  309. mediapipe/tasks/cc/core/proto/external_file_pb2.py +31 -0
  310. mediapipe/tasks/cc/core/proto/inference_subgraph_pb2.py +32 -0
  311. mediapipe/tasks/cc/core/proto/model_resources_calculator_pb2.py +32 -0
  312. mediapipe/tasks/cc/genai/__init__.py +0 -0
  313. mediapipe/tasks/cc/genai/inference/__init__.py +0 -0
  314. mediapipe/tasks/cc/genai/inference/c/__init__.py +0 -0
  315. mediapipe/tasks/cc/genai/inference/calculators/__init__.py +0 -0
  316. mediapipe/tasks/cc/genai/inference/calculators/detokenizer_calculator_pb2.py +27 -0
  317. mediapipe/tasks/cc/genai/inference/calculators/llm_gpu_calculator_pb2.py +32 -0
  318. mediapipe/tasks/cc/genai/inference/calculators/model_data_calculator_pb2.py +27 -0
  319. mediapipe/tasks/cc/genai/inference/calculators/tokenizer_calculator_pb2.py +29 -0
  320. mediapipe/tasks/cc/genai/inference/common/__init__.py +0 -0
  321. mediapipe/tasks/cc/genai/inference/proto/__init__.py +0 -0
  322. mediapipe/tasks/cc/genai/inference/proto/llm_file_metadata_pb2.py +32 -0
  323. mediapipe/tasks/cc/genai/inference/proto/llm_params_pb2.py +33 -0
  324. mediapipe/tasks/cc/genai/inference/proto/prompt_template_pb2.py +27 -0
  325. mediapipe/tasks/cc/genai/inference/proto/sampler_params_pb2.py +29 -0
  326. mediapipe/tasks/cc/genai/inference/proto/transformer_params_pb2.py +45 -0
  327. mediapipe/tasks/cc/genai/inference/utils/__init__.py +0 -0
  328. mediapipe/tasks/cc/genai/inference/utils/llm_utils/__init__.py +0 -0
  329. mediapipe/tasks/cc/genai/inference/utils/xnn_utils/__init__.py +0 -0
  330. mediapipe/tasks/cc/metadata/__init__.py +0 -0
  331. mediapipe/tasks/cc/metadata/python/__init__.py +0 -0
  332. mediapipe/tasks/cc/metadata/python/_pywrap_metadata_version/arm64.cpython-312-darwin.so +0 -0
  333. mediapipe/tasks/cc/metadata/python/_pywrap_metadata_version.cpython-312-darwin.so +0 -0
  334. mediapipe/tasks/cc/metadata/tests/__init__.py +0 -0
  335. mediapipe/tasks/cc/metadata/utils/__init__.py +0 -0
  336. mediapipe/tasks/cc/text/__init__.py +0 -0
  337. mediapipe/tasks/cc/text/custom_ops/__init__.py +0 -0
  338. mediapipe/tasks/cc/text/custom_ops/ragged/__init__.py +0 -0
  339. mediapipe/tasks/cc/text/custom_ops/sentencepiece/__init__.py +0 -0
  340. mediapipe/tasks/cc/text/custom_ops/sentencepiece/testdata/__init__.py +0 -0
  341. mediapipe/tasks/cc/text/language_detector/__init__.py +0 -0
  342. mediapipe/tasks/cc/text/language_detector/custom_ops/__init__.py +0 -0
  343. mediapipe/tasks/cc/text/language_detector/custom_ops/utils/__init__.py +0 -0
  344. mediapipe/tasks/cc/text/language_detector/custom_ops/utils/hash/__init__.py +0 -0
  345. mediapipe/tasks/cc/text/language_detector/custom_ops/utils/utf/__init__.py +0 -0
  346. mediapipe/tasks/cc/text/text_classifier/__init__.py +0 -0
  347. mediapipe/tasks/cc/text/text_classifier/proto/__init__.py +0 -0
  348. mediapipe/tasks/cc/text/text_classifier/proto/text_classifier_graph_options_pb2.py +35 -0
  349. mediapipe/tasks/cc/text/text_embedder/__init__.py +0 -0
  350. mediapipe/tasks/cc/text/text_embedder/proto/__init__.py +0 -0
  351. mediapipe/tasks/cc/text/text_embedder/proto/text_embedder_graph_options_pb2.py +35 -0
  352. mediapipe/tasks/cc/text/tokenizers/__init__.py +0 -0
  353. mediapipe/tasks/cc/text/utils/__init__.py +0 -0
  354. mediapipe/tasks/cc/vision/__init__.py +0 -0
  355. mediapipe/tasks/cc/vision/core/__init__.py +0 -0
  356. mediapipe/tasks/cc/vision/custom_ops/__init__.py +0 -0
  357. mediapipe/tasks/cc/vision/face_detector/__init__.py +0 -0
  358. mediapipe/tasks/cc/vision/face_detector/proto/__init__.py +0 -0
  359. mediapipe/tasks/cc/vision/face_detector/proto/face_detector_graph_options_pb2.py +34 -0
  360. mediapipe/tasks/cc/vision/face_geometry/__init__.py +0 -0
  361. mediapipe/tasks/cc/vision/face_geometry/calculators/__init__.py +0 -0
  362. mediapipe/tasks/cc/vision/face_geometry/calculators/env_generator_calculator_pb2.py +28 -0
  363. mediapipe/tasks/cc/vision/face_geometry/calculators/geometry_pipeline_calculator_pb2.py +29 -0
  364. mediapipe/tasks/cc/vision/face_geometry/data/__init__.py +0 -0
  365. mediapipe/tasks/cc/vision/face_geometry/libs/__init__.py +0 -0
  366. mediapipe/tasks/cc/vision/face_geometry/proto/__init__.py +0 -0
  367. mediapipe/tasks/cc/vision/face_geometry/proto/environment_pb2.py +31 -0
  368. mediapipe/tasks/cc/vision/face_geometry/proto/face_geometry_graph_options_pb2.py +29 -0
  369. mediapipe/tasks/cc/vision/face_geometry/proto/face_geometry_pb2.py +29 -0
  370. mediapipe/tasks/cc/vision/face_geometry/proto/geometry_pipeline_metadata_pb2.py +32 -0
  371. mediapipe/tasks/cc/vision/face_geometry/proto/mesh_3d_pb2.py +31 -0
  372. mediapipe/tasks/cc/vision/face_landmarker/__init__.py +0 -0
  373. mediapipe/tasks/cc/vision/face_landmarker/proto/__init__.py +0 -0
  374. mediapipe/tasks/cc/vision/face_landmarker/proto/face_blendshapes_graph_options_pb2.py +34 -0
  375. mediapipe/tasks/cc/vision/face_landmarker/proto/face_landmarker_graph_options_pb2.py +37 -0
  376. mediapipe/tasks/cc/vision/face_landmarker/proto/face_landmarks_detector_graph_options_pb2.py +35 -0
  377. mediapipe/tasks/cc/vision/face_landmarker/proto/tensors_to_face_landmarks_graph_options_pb2.py +32 -0
  378. mediapipe/tasks/cc/vision/face_stylizer/__init__.py +0 -0
  379. mediapipe/tasks/cc/vision/face_stylizer/calculators/__init__.py +0 -0
  380. mediapipe/tasks/cc/vision/face_stylizer/calculators/tensors_to_image_calculator_pb2.py +36 -0
  381. mediapipe/tasks/cc/vision/face_stylizer/proto/__init__.py +0 -0
  382. mediapipe/tasks/cc/vision/face_stylizer/proto/face_stylizer_graph_options_pb2.py +35 -0
  383. mediapipe/tasks/cc/vision/gesture_recognizer/__init__.py +0 -0
  384. mediapipe/tasks/cc/vision/gesture_recognizer/calculators/__init__.py +0 -0
  385. mediapipe/tasks/cc/vision/gesture_recognizer/calculators/combined_prediction_calculator_pb2.py +33 -0
  386. mediapipe/tasks/cc/vision/gesture_recognizer/calculators/landmarks_to_matrix_calculator_pb2.py +31 -0
  387. mediapipe/tasks/cc/vision/gesture_recognizer/proto/__init__.py +0 -0
  388. mediapipe/tasks/cc/vision/gesture_recognizer/proto/gesture_classifier_graph_options_pb2.py +35 -0
  389. mediapipe/tasks/cc/vision/gesture_recognizer/proto/gesture_embedder_graph_options_pb2.py +34 -0
  390. mediapipe/tasks/cc/vision/gesture_recognizer/proto/gesture_recognizer_graph_options_pb2.py +36 -0
  391. mediapipe/tasks/cc/vision/gesture_recognizer/proto/hand_gesture_recognizer_graph_options_pb2.py +36 -0
  392. mediapipe/tasks/cc/vision/hand_detector/__init__.py +0 -0
  393. mediapipe/tasks/cc/vision/hand_detector/proto/__init__.py +0 -0
  394. mediapipe/tasks/cc/vision/hand_detector/proto/hand_detector_graph_options_pb2.py +34 -0
  395. mediapipe/tasks/cc/vision/hand_detector/proto/hand_detector_result_pb2.py +30 -0
  396. mediapipe/tasks/cc/vision/hand_landmarker/__init__.py +0 -0
  397. mediapipe/tasks/cc/vision/hand_landmarker/calculators/__init__.py +0 -0
  398. mediapipe/tasks/cc/vision/hand_landmarker/calculators/hand_association_calculator_pb2.py +31 -0
  399. mediapipe/tasks/cc/vision/hand_landmarker/proto/__init__.py +0 -0
  400. mediapipe/tasks/cc/vision/hand_landmarker/proto/hand_landmarker_graph_options_pb2.py +36 -0
  401. mediapipe/tasks/cc/vision/hand_landmarker/proto/hand_landmarks_detector_graph_options_pb2.py +34 -0
  402. mediapipe/tasks/cc/vision/hand_landmarker/proto/hand_roi_refinement_graph_options_pb2.py +28 -0
  403. mediapipe/tasks/cc/vision/holistic_landmarker/__init__.py +0 -0
  404. mediapipe/tasks/cc/vision/holistic_landmarker/proto/__init__.py +0 -0
  405. mediapipe/tasks/cc/vision/holistic_landmarker/proto/holistic_landmarker_graph_options_pb2.py +34 -0
  406. mediapipe/tasks/cc/vision/holistic_landmarker/proto/holistic_result_pb2.py +29 -0
  407. mediapipe/tasks/cc/vision/image_classifier/__init__.py +0 -0
  408. mediapipe/tasks/cc/vision/image_classifier/proto/__init__.py +0 -0
  409. mediapipe/tasks/cc/vision/image_classifier/proto/image_classifier_graph_options_pb2.py +35 -0
  410. mediapipe/tasks/cc/vision/image_embedder/__init__.py +0 -0
  411. mediapipe/tasks/cc/vision/image_embedder/proto/__init__.py +0 -0
  412. mediapipe/tasks/cc/vision/image_embedder/proto/image_embedder_graph_options_pb2.py +35 -0
  413. mediapipe/tasks/cc/vision/image_generator/__init__.py +0 -0
  414. mediapipe/tasks/cc/vision/image_generator/diffuser/__init__.py +0 -0
  415. mediapipe/tasks/cc/vision/image_generator/diffuser/stable_diffusion_iterate_calculator_pb2.py +40 -0
  416. mediapipe/tasks/cc/vision/image_generator/proto/__init__.py +0 -0
  417. mediapipe/tasks/cc/vision/image_generator/proto/conditioned_image_graph_options_pb2.py +40 -0
  418. mediapipe/tasks/cc/vision/image_generator/proto/control_plugin_graph_options_pb2.py +34 -0
  419. mediapipe/tasks/cc/vision/image_generator/proto/image_generator_graph_options_pb2.py +30 -0
  420. mediapipe/tasks/cc/vision/image_segmenter/__init__.py +0 -0
  421. mediapipe/tasks/cc/vision/image_segmenter/calculators/__init__.py +0 -0
  422. mediapipe/tasks/cc/vision/image_segmenter/calculators/tensors_to_segmentation_calculator_pb2.py +34 -0
  423. mediapipe/tasks/cc/vision/image_segmenter/proto/__init__.py +0 -0
  424. mediapipe/tasks/cc/vision/image_segmenter/proto/image_segmenter_graph_options_pb2.py +35 -0
  425. mediapipe/tasks/cc/vision/image_segmenter/proto/segmenter_options_pb2.py +33 -0
  426. mediapipe/tasks/cc/vision/interactive_segmenter/__init__.py +0 -0
  427. mediapipe/tasks/cc/vision/object_detector/__init__.py +0 -0
  428. mediapipe/tasks/cc/vision/object_detector/proto/__init__.py +0 -0
  429. mediapipe/tasks/cc/vision/object_detector/proto/object_detector_options_pb2.py +34 -0
  430. mediapipe/tasks/cc/vision/pose_detector/__init__.py +0 -0
  431. mediapipe/tasks/cc/vision/pose_detector/proto/__init__.py +0 -0
  432. mediapipe/tasks/cc/vision/pose_detector/proto/pose_detector_graph_options_pb2.py +34 -0
  433. mediapipe/tasks/cc/vision/pose_landmarker/__init__.py +0 -0
  434. mediapipe/tasks/cc/vision/pose_landmarker/proto/__init__.py +0 -0
  435. mediapipe/tasks/cc/vision/pose_landmarker/proto/pose_landmarker_graph_options_pb2.py +36 -0
  436. mediapipe/tasks/cc/vision/pose_landmarker/proto/pose_landmarks_detector_graph_options_pb2.py +34 -0
  437. mediapipe/tasks/cc/vision/utils/__init__.py +0 -0
  438. mediapipe/tasks/cc/vision/utils/ghum/__init__.py +0 -0
  439. mediapipe/tasks/metadata/image_segmenter_metadata_schema.fbs +59 -0
  440. mediapipe/tasks/metadata/image_segmenter_metadata_schema_py_generated.py +108 -0
  441. mediapipe/tasks/metadata/metadata_schema.fbs +732 -0
  442. mediapipe/tasks/metadata/metadata_schema_py_generated.py +3251 -0
  443. mediapipe/tasks/metadata/object_detector_metadata_schema.fbs +98 -0
  444. mediapipe/tasks/metadata/object_detector_metadata_schema_py_generated.py +674 -0
  445. mediapipe/tasks/metadata/schema_py_generated.py +18438 -0
  446. mediapipe/tasks/python/__init__.py +27 -0
  447. mediapipe/tasks/python/audio/__init__.py +33 -0
  448. mediapipe/tasks/python/audio/audio_classifier.py +324 -0
  449. mediapipe/tasks/python/audio/audio_embedder.py +285 -0
  450. mediapipe/tasks/python/audio/core/__init__.py +16 -0
  451. mediapipe/tasks/python/audio/core/audio_record.py +125 -0
  452. mediapipe/tasks/python/audio/core/audio_task_running_mode.py +29 -0
  453. mediapipe/tasks/python/audio/core/base_audio_task_api.py +181 -0
  454. mediapipe/tasks/python/benchmark/__init__.py +13 -0
  455. mediapipe/tasks/python/benchmark/benchmark_utils.py +70 -0
  456. mediapipe/tasks/python/benchmark/vision/__init__.py +13 -0
  457. mediapipe/tasks/python/benchmark/vision/benchmark.py +99 -0
  458. mediapipe/tasks/python/benchmark/vision/core/__init__.py +14 -0
  459. mediapipe/tasks/python/benchmark/vision/core/base_vision_benchmark_api.py +40 -0
  460. mediapipe/tasks/python/components/__init__.py +13 -0
  461. mediapipe/tasks/python/components/containers/__init__.py +53 -0
  462. mediapipe/tasks/python/components/containers/audio_data.py +137 -0
  463. mediapipe/tasks/python/components/containers/bounding_box.py +73 -0
  464. mediapipe/tasks/python/components/containers/category.py +78 -0
  465. mediapipe/tasks/python/components/containers/classification_result.py +111 -0
  466. mediapipe/tasks/python/components/containers/detections.py +181 -0
  467. mediapipe/tasks/python/components/containers/embedding_result.py +89 -0
  468. mediapipe/tasks/python/components/containers/keypoint.py +77 -0
  469. mediapipe/tasks/python/components/containers/landmark.py +122 -0
  470. mediapipe/tasks/python/components/containers/landmark_detection_result.py +106 -0
  471. mediapipe/tasks/python/components/containers/rect.py +109 -0
  472. mediapipe/tasks/python/components/processors/__init__.py +23 -0
  473. mediapipe/tasks/python/components/processors/classifier_options.py +86 -0
  474. mediapipe/tasks/python/components/utils/__init__.py +13 -0
  475. mediapipe/tasks/python/components/utils/cosine_similarity.py +68 -0
  476. mediapipe/tasks/python/core/__init__.py +13 -0
  477. mediapipe/tasks/python/core/base_options.py +121 -0
  478. mediapipe/tasks/python/core/optional_dependencies.py +25 -0
  479. mediapipe/tasks/python/core/task_info.py +139 -0
  480. mediapipe/tasks/python/genai/__init__.py +14 -0
  481. mediapipe/tasks/python/genai/bundler/__init__.py +23 -0
  482. mediapipe/tasks/python/genai/bundler/llm_bundler.py +130 -0
  483. mediapipe/tasks/python/genai/bundler/llm_bundler_test.py +168 -0
  484. mediapipe/tasks/python/genai/converter/__init__.py +24 -0
  485. mediapipe/tasks/python/genai/converter/converter_base.py +179 -0
  486. mediapipe/tasks/python/genai/converter/converter_factory.py +79 -0
  487. mediapipe/tasks/python/genai/converter/llm_converter.py +374 -0
  488. mediapipe/tasks/python/genai/converter/llm_converter_test.py +63 -0
  489. mediapipe/tasks/python/genai/converter/pytorch_converter.py +318 -0
  490. mediapipe/tasks/python/genai/converter/pytorch_converter_test.py +86 -0
  491. mediapipe/tasks/python/genai/converter/quantization_util.py +516 -0
  492. mediapipe/tasks/python/genai/converter/quantization_util_test.py +259 -0
  493. mediapipe/tasks/python/genai/converter/safetensors_converter.py +580 -0
  494. mediapipe/tasks/python/genai/converter/safetensors_converter_test.py +83 -0
  495. mediapipe/tasks/python/genai/converter/weight_bins_writer.py +120 -0
  496. mediapipe/tasks/python/genai/converter/weight_bins_writer_test.py +95 -0
  497. mediapipe/tasks/python/metadata/__init__.py +13 -0
  498. mediapipe/tasks/python/metadata/flatbuffers_lib/_pywrap_flatbuffers/arm64.cpython-312-darwin.so +0 -0
  499. mediapipe/tasks/python/metadata/flatbuffers_lib/_pywrap_flatbuffers.cpython-312-darwin.so +0 -0
  500. mediapipe/tasks/python/metadata/metadata.py +928 -0
  501. mediapipe/tasks/python/metadata/metadata_displayer_cli.py +34 -0
  502. mediapipe/tasks/python/metadata/metadata_writers/__init__.py +13 -0
  503. mediapipe/tasks/python/metadata/metadata_writers/face_stylizer.py +138 -0
  504. mediapipe/tasks/python/metadata/metadata_writers/image_classifier.py +71 -0
  505. mediapipe/tasks/python/metadata/metadata_writers/image_segmenter.py +170 -0
  506. mediapipe/tasks/python/metadata/metadata_writers/metadata_info.py +1166 -0
  507. mediapipe/tasks/python/metadata/metadata_writers/metadata_writer.py +845 -0
  508. mediapipe/tasks/python/metadata/metadata_writers/model_asset_bundle_utils.py +71 -0
  509. mediapipe/tasks/python/metadata/metadata_writers/object_detector.py +331 -0
  510. mediapipe/tasks/python/metadata/metadata_writers/text_classifier.py +119 -0
  511. mediapipe/tasks/python/metadata/metadata_writers/writer_utils.py +91 -0
  512. mediapipe/tasks/python/test/__init__.py +13 -0
  513. mediapipe/tasks/python/test/audio/__init__.py +13 -0
  514. mediapipe/tasks/python/test/audio/audio_classifier_test.py +387 -0
  515. mediapipe/tasks/python/test/audio/audio_embedder_test.py +297 -0
  516. mediapipe/tasks/python/test/test_utils.py +196 -0
  517. mediapipe/tasks/python/test/text/__init__.py +13 -0
  518. mediapipe/tasks/python/test/text/language_detector_test.py +228 -0
  519. mediapipe/tasks/python/test/text/text_classifier_test.py +235 -0
  520. mediapipe/tasks/python/test/text/text_embedder_test.py +326 -0
  521. mediapipe/tasks/python/test/vision/__init__.py +13 -0
  522. mediapipe/tasks/python/test/vision/face_aligner_test.py +190 -0
  523. mediapipe/tasks/python/test/vision/face_detector_test.py +523 -0
  524. mediapipe/tasks/python/test/vision/face_landmarker_test.py +565 -0
  525. mediapipe/tasks/python/test/vision/face_stylizer_test.py +191 -0
  526. mediapipe/tasks/python/test/vision/hand_landmarker_test.py +437 -0
  527. mediapipe/tasks/python/test/vision/holistic_landmarker_test.py +544 -0
  528. mediapipe/tasks/python/test/vision/image_classifier_test.py +657 -0
  529. mediapipe/tasks/python/test/vision/image_embedder_test.py +423 -0
  530. mediapipe/tasks/python/test/vision/image_segmenter_test.py +512 -0
  531. mediapipe/tasks/python/test/vision/interactive_segmenter_test.py +341 -0
  532. mediapipe/tasks/python/test/vision/object_detector_test.py +493 -0
  533. mediapipe/tasks/python/test/vision/pose_landmarker_test.py +518 -0
  534. mediapipe/tasks/python/text/__init__.py +35 -0
  535. mediapipe/tasks/python/text/core/__init__.py +16 -0
  536. mediapipe/tasks/python/text/core/base_text_task_api.py +54 -0
  537. mediapipe/tasks/python/text/language_detector.py +220 -0
  538. mediapipe/tasks/python/text/text_classifier.py +187 -0
  539. mediapipe/tasks/python/text/text_embedder.py +188 -0
  540. mediapipe/tasks/python/vision/__init__.py +90 -0
  541. mediapipe/tasks/python/vision/core/__init__.py +14 -0
  542. mediapipe/tasks/python/vision/core/base_vision_task_api.py +226 -0
  543. mediapipe/tasks/python/vision/core/image_processing_options.py +39 -0
  544. mediapipe/tasks/python/vision/core/vision_task_running_mode.py +31 -0
  545. mediapipe/tasks/python/vision/face_aligner.py +158 -0
  546. mediapipe/tasks/python/vision/face_detector.py +332 -0
  547. mediapipe/tasks/python/vision/face_landmarker.py +3244 -0
  548. mediapipe/tasks/python/vision/face_stylizer.py +158 -0
  549. mediapipe/tasks/python/vision/gesture_recognizer.py +480 -0
  550. mediapipe/tasks/python/vision/hand_landmarker.py +504 -0
  551. mediapipe/tasks/python/vision/holistic_landmarker.py +576 -0
  552. mediapipe/tasks/python/vision/image_classifier.py +358 -0
  553. mediapipe/tasks/python/vision/image_embedder.py +362 -0
  554. mediapipe/tasks/python/vision/image_segmenter.py +433 -0
  555. mediapipe/tasks/python/vision/interactive_segmenter.py +285 -0
  556. mediapipe/tasks/python/vision/object_detector.py +389 -0
  557. mediapipe/tasks/python/vision/pose_landmarker.py +455 -0
  558. mediapipe/util/__init__.py +0 -0
  559. mediapipe/util/analytics/__init__.py +0 -0
  560. mediapipe/util/analytics/mediapipe_log_extension_pb2.py +44 -0
  561. mediapipe/util/analytics/mediapipe_logging_enums_pb2.py +37 -0
  562. mediapipe/util/audio_decoder_pb2.py +33 -0
  563. mediapipe/util/color_pb2.py +33 -0
  564. mediapipe/util/label_map_pb2.py +27 -0
  565. mediapipe/util/render_data_pb2.py +58 -0
  566. mediapipe/util/sequence/__init__.py +14 -0
  567. mediapipe/util/sequence/media_sequence.py +716 -0
  568. mediapipe/util/sequence/media_sequence_test.py +290 -0
  569. mediapipe/util/sequence/media_sequence_util.py +800 -0
  570. mediapipe/util/sequence/media_sequence_util_test.py +389 -0
  571. mediapipe/util/tracking/__init__.py +0 -0
  572. mediapipe/util/tracking/box_detector_pb2.py +39 -0
  573. mediapipe/util/tracking/box_tracker_pb2.py +32 -0
  574. mediapipe/util/tracking/camera_motion_pb2.py +31 -0
  575. mediapipe/util/tracking/flow_packager_pb2.py +60 -0
  576. mediapipe/util/tracking/frame_selection_pb2.py +35 -0
  577. mediapipe/util/tracking/frame_selection_solution_evaluator_pb2.py +28 -0
  578. mediapipe/util/tracking/motion_analysis_pb2.py +35 -0
  579. mediapipe/util/tracking/motion_estimation_pb2.py +66 -0
  580. mediapipe/util/tracking/motion_models_pb2.py +42 -0
  581. mediapipe/util/tracking/motion_saliency_pb2.py +26 -0
  582. mediapipe/util/tracking/push_pull_filtering_pb2.py +26 -0
  583. mediapipe/util/tracking/region_flow_computation_pb2.py +59 -0
  584. mediapipe/util/tracking/region_flow_pb2.py +49 -0
  585. mediapipe/util/tracking/tone_estimation_pb2.py +45 -0
  586. mediapipe/util/tracking/tone_models_pb2.py +32 -0
  587. mediapipe/util/tracking/tracked_detection_manager_config_pb2.py +26 -0
  588. mediapipe/util/tracking/tracking_pb2.py +73 -0
  589. mediapipe/version.txt +1 -0
  590. mediapipe_nightly-0.10.21.post20241223.dist-info/LICENSE +218 -0
  591. mediapipe_nightly-0.10.21.post20241223.dist-info/METADATA +199 -0
  592. mediapipe_nightly-0.10.21.post20241223.dist-info/RECORD +593 -0
  593. mediapipe_nightly-0.10.21.post20241223.dist-info/WHEEL +5 -0
  594. mediapipe_nightly-0.10.21.post20241223.dist-info/top_level.txt +4 -0
@@ -0,0 +1,565 @@
1
+ # Copyright 2023 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
+ """Tests for face landmarker."""
15
+
16
+ import enum
17
+ from unittest import mock
18
+
19
+ from absl.testing import absltest
20
+ from absl.testing import parameterized
21
+ import numpy as np
22
+
23
+ from google.protobuf import text_format
24
+ from mediapipe.framework.formats import classification_pb2
25
+ from mediapipe.framework.formats import landmark_pb2
26
+ from mediapipe.python._framework_bindings import image as image_module
27
+ from mediapipe.tasks.python.components.containers import category as category_module
28
+ from mediapipe.tasks.python.components.containers import landmark as landmark_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 face_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
+
37
+ FaceLandmarkerResult = face_landmarker.FaceLandmarkerResult
38
+ _BaseOptions = base_options_module.BaseOptions
39
+ _Category = category_module.Category
40
+ _Rect = rect_module.Rect
41
+ _Landmark = landmark_module.Landmark
42
+ _NormalizedLandmark = landmark_module.NormalizedLandmark
43
+ _Image = image_module.Image
44
+ _FaceLandmarker = face_landmarker.FaceLandmarker
45
+ _FaceLandmarkerOptions = face_landmarker.FaceLandmarkerOptions
46
+ _RUNNING_MODE = running_mode_module.VisionTaskRunningMode
47
+ _ImageProcessingOptions = image_processing_options_module.ImageProcessingOptions
48
+
49
+ _FACE_LANDMARKER_BUNDLE_ASSET_FILE = 'face_landmarker_v2.task'
50
+ _PORTRAIT_IMAGE = 'portrait.jpg'
51
+ _CAT_IMAGE = 'cat.jpg'
52
+ _PORTRAIT_EXPECTED_FACE_LANDMARKS = 'portrait_expected_face_landmarks.pbtxt'
53
+ _PORTRAIT_EXPECTED_BLENDSHAPES = 'portrait_expected_blendshapes.pbtxt'
54
+ _LANDMARKS_MARGIN = 0.03
55
+ _BLENDSHAPES_MARGIN = 0.13
56
+ _FACIAL_TRANSFORMATION_MATRIX_MARGIN = 0.02
57
+
58
+
59
+ def _get_expected_face_landmarks(file_path: str):
60
+ proto_file_path = test_utils.get_test_data_path(file_path)
61
+ face_landmarks_results = []
62
+ with open(proto_file_path, 'rb') as f:
63
+ proto = landmark_pb2.NormalizedLandmarkList()
64
+ text_format.Parse(f.read(), proto)
65
+ face_landmarks = []
66
+ for landmark in proto.landmark:
67
+ face_landmarks.append(_NormalizedLandmark.create_from_pb2(landmark))
68
+ face_landmarks_results.append(face_landmarks)
69
+ return face_landmarks_results
70
+
71
+
72
+ def _get_expected_face_blendshapes(file_path: str):
73
+ proto_file_path = test_utils.get_test_data_path(file_path)
74
+ face_blendshapes_results = []
75
+ with open(proto_file_path, 'rb') as f:
76
+ proto = classification_pb2.ClassificationList()
77
+ text_format.Parse(f.read(), proto)
78
+ face_blendshapes_categories = []
79
+ face_blendshapes_classifications = classification_pb2.ClassificationList()
80
+ face_blendshapes_classifications.MergeFrom(proto)
81
+ for face_blendshapes in face_blendshapes_classifications.classification:
82
+ face_blendshapes_categories.append(
83
+ category_module.Category(
84
+ index=face_blendshapes.index,
85
+ score=face_blendshapes.score,
86
+ display_name=face_blendshapes.display_name,
87
+ category_name=face_blendshapes.label,
88
+ )
89
+ )
90
+ face_blendshapes_results.append(face_blendshapes_categories)
91
+ return face_blendshapes_results
92
+
93
+
94
+ def _get_expected_facial_transformation_matrixes():
95
+ matrix = np.array([
96
+ [0.9995292, -0.01294756, 0.038823195, -0.3691378],
97
+ [0.0072318087, 0.9937692, -0.1101321, 22.75809],
98
+ [-0.03715533, 0.11070588, 0.99315894, -65.765925],
99
+ [0, 0, 0, 1],
100
+ ])
101
+ facial_transformation_matrixes_results = []
102
+ facial_transformation_matrixes_results.append(matrix)
103
+ return facial_transformation_matrixes_results
104
+
105
+
106
+ class ModelFileType(enum.Enum):
107
+ FILE_CONTENT = 1
108
+ FILE_NAME = 2
109
+
110
+
111
+ class FaceLandmarkerTest(parameterized.TestCase):
112
+
113
+ def setUp(self):
114
+ super().setUp()
115
+ self.test_image = _Image.create_from_file(
116
+ test_utils.get_test_data_path(_PORTRAIT_IMAGE)
117
+ )
118
+ self.model_path = test_utils.get_test_data_path(
119
+ _FACE_LANDMARKER_BUNDLE_ASSET_FILE
120
+ )
121
+
122
+ def _expect_landmarks_correct(self, actual_landmarks, expected_landmarks):
123
+ # Expects to have the same number of faces detected.
124
+ self.assertLen(actual_landmarks, len(expected_landmarks))
125
+
126
+ for i, _ in enumerate(actual_landmarks):
127
+ for j, elem in enumerate(actual_landmarks[i]):
128
+ self.assertAlmostEqual(
129
+ elem.x, expected_landmarks[i][j].x, delta=_LANDMARKS_MARGIN
130
+ )
131
+ self.assertAlmostEqual(
132
+ elem.y, expected_landmarks[i][j].y, delta=_LANDMARKS_MARGIN
133
+ )
134
+
135
+ def _expect_blendshapes_correct(
136
+ self, actual_blendshapes, expected_blendshapes
137
+ ):
138
+ # Expects to have the same number of blendshapes.
139
+ self.assertLen(actual_blendshapes, len(expected_blendshapes))
140
+
141
+ for i, _ in enumerate(actual_blendshapes):
142
+ for j, elem in enumerate(actual_blendshapes[i]):
143
+ self.assertEqual(elem.index, expected_blendshapes[i][j].index)
144
+ self.assertAlmostEqual(
145
+ elem.score,
146
+ expected_blendshapes[i][j].score,
147
+ delta=_BLENDSHAPES_MARGIN,
148
+ )
149
+
150
+ def _expect_facial_transformation_matrixes_correct(
151
+ self, actual_matrix_list, expected_matrix_list
152
+ ):
153
+ self.assertLen(actual_matrix_list, len(expected_matrix_list))
154
+
155
+ for i, elem in enumerate(actual_matrix_list):
156
+ self.assertEqual(elem.shape[0], expected_matrix_list[i].shape[0])
157
+ self.assertEqual(elem.shape[1], expected_matrix_list[i].shape[1])
158
+ self.assertSequenceAlmostEqual(
159
+ elem.flatten(),
160
+ expected_matrix_list[i].flatten(),
161
+ delta=_FACIAL_TRANSFORMATION_MATRIX_MARGIN,
162
+ )
163
+
164
+ def test_create_from_file_succeeds_with_valid_model_path(self):
165
+ # Creates with default option and valid model file successfully.
166
+ with _FaceLandmarker.create_from_model_path(self.model_path) as landmarker:
167
+ self.assertIsInstance(landmarker, _FaceLandmarker)
168
+
169
+ def test_create_from_options_succeeds_with_valid_model_path(self):
170
+ # Creates with options containing model file successfully.
171
+ base_options = _BaseOptions(model_asset_path=self.model_path)
172
+ options = _FaceLandmarkerOptions(base_options=base_options)
173
+ with _FaceLandmarker.create_from_options(options) as landmarker:
174
+ self.assertIsInstance(landmarker, _FaceLandmarker)
175
+
176
+ def test_create_from_options_fails_with_invalid_model_path(self):
177
+ # Invalid empty model path.
178
+ with self.assertRaisesRegex(
179
+ RuntimeError, 'Unable to open file at /path/to/invalid/model.tflite'
180
+ ):
181
+ base_options = _BaseOptions(
182
+ model_asset_path='/path/to/invalid/model.tflite'
183
+ )
184
+ options = _FaceLandmarkerOptions(base_options=base_options)
185
+ _FaceLandmarker.create_from_options(options)
186
+
187
+ def test_create_from_options_succeeds_with_valid_model_content(self):
188
+ # Creates with options containing model content successfully.
189
+ with open(self.model_path, 'rb') as f:
190
+ base_options = _BaseOptions(model_asset_buffer=f.read())
191
+ options = _FaceLandmarkerOptions(base_options=base_options)
192
+ landmarker = _FaceLandmarker.create_from_options(options)
193
+ self.assertIsInstance(landmarker, _FaceLandmarker)
194
+
195
+ @parameterized.parameters(
196
+ (
197
+ ModelFileType.FILE_NAME,
198
+ _FACE_LANDMARKER_BUNDLE_ASSET_FILE,
199
+ _get_expected_face_landmarks(_PORTRAIT_EXPECTED_FACE_LANDMARKS),
200
+ None,
201
+ None,
202
+ ),
203
+ (
204
+ ModelFileType.FILE_CONTENT,
205
+ _FACE_LANDMARKER_BUNDLE_ASSET_FILE,
206
+ _get_expected_face_landmarks(_PORTRAIT_EXPECTED_FACE_LANDMARKS),
207
+ None,
208
+ None,
209
+ ),
210
+ )
211
+ def test_detect(
212
+ self,
213
+ model_file_type,
214
+ model_name,
215
+ expected_face_landmarks,
216
+ expected_face_blendshapes,
217
+ expected_facial_transformation_matrixes,
218
+ ):
219
+ # Creates face landmarker.
220
+ model_path = test_utils.get_test_data_path(model_name)
221
+ if model_file_type is ModelFileType.FILE_NAME:
222
+ base_options = _BaseOptions(model_asset_path=model_path)
223
+ elif model_file_type is ModelFileType.FILE_CONTENT:
224
+ with open(model_path, 'rb') as f:
225
+ model_content = f.read()
226
+ base_options = _BaseOptions(model_asset_buffer=model_content)
227
+ else:
228
+ # Should never happen
229
+ raise ValueError('model_file_type is invalid.')
230
+
231
+ options = _FaceLandmarkerOptions(
232
+ base_options=base_options,
233
+ output_face_blendshapes=True if expected_face_blendshapes else False,
234
+ output_facial_transformation_matrixes=True
235
+ if expected_facial_transformation_matrixes
236
+ else False,
237
+ )
238
+ landmarker = _FaceLandmarker.create_from_options(options)
239
+
240
+ # Performs face landmarks detection on the input.
241
+ detection_result = landmarker.detect(self.test_image)
242
+ # Comparing results.
243
+ if expected_face_landmarks is not None:
244
+ self._expect_landmarks_correct(
245
+ detection_result.face_landmarks, expected_face_landmarks
246
+ )
247
+ if expected_face_blendshapes is not None:
248
+ self._expect_blendshapes_correct(
249
+ detection_result.face_blendshapes, expected_face_blendshapes
250
+ )
251
+ if expected_facial_transformation_matrixes is not None:
252
+ self._expect_facial_transformation_matrixes_correct(
253
+ detection_result.facial_transformation_matrixes,
254
+ expected_facial_transformation_matrixes,
255
+ )
256
+
257
+ # Closes the face landmarker explicitly when the face landmarker is not used
258
+ # in a context.
259
+ landmarker.close()
260
+
261
+ @parameterized.parameters(
262
+ (
263
+ ModelFileType.FILE_NAME,
264
+ _FACE_LANDMARKER_BUNDLE_ASSET_FILE,
265
+ _get_expected_face_landmarks(_PORTRAIT_EXPECTED_FACE_LANDMARKS),
266
+ None,
267
+ None,
268
+ ),
269
+ (
270
+ ModelFileType.FILE_CONTENT,
271
+ _FACE_LANDMARKER_BUNDLE_ASSET_FILE,
272
+ _get_expected_face_landmarks(_PORTRAIT_EXPECTED_FACE_LANDMARKS),
273
+ None,
274
+ None,
275
+ ),
276
+ )
277
+ def test_detect_in_context(
278
+ self,
279
+ model_file_type,
280
+ model_name,
281
+ expected_face_landmarks,
282
+ expected_face_blendshapes,
283
+ expected_facial_transformation_matrixes,
284
+ ):
285
+ # Creates face landmarker.
286
+ model_path = test_utils.get_test_data_path(model_name)
287
+ if model_file_type is ModelFileType.FILE_NAME:
288
+ base_options = _BaseOptions(model_asset_path=model_path)
289
+ elif model_file_type is ModelFileType.FILE_CONTENT:
290
+ with open(model_path, 'rb') as f:
291
+ model_content = f.read()
292
+ base_options = _BaseOptions(model_asset_buffer=model_content)
293
+ else:
294
+ # Should never happen
295
+ raise ValueError('model_file_type is invalid.')
296
+
297
+ options = _FaceLandmarkerOptions(
298
+ base_options=base_options,
299
+ output_face_blendshapes=True if expected_face_blendshapes else False,
300
+ output_facial_transformation_matrixes=True
301
+ if expected_facial_transformation_matrixes
302
+ else False,
303
+ )
304
+
305
+ with _FaceLandmarker.create_from_options(options) as landmarker:
306
+ # Performs face landmarks detection on the input.
307
+ detection_result = landmarker.detect(self.test_image)
308
+ # Comparing results.
309
+ if expected_face_landmarks is not None:
310
+ self._expect_landmarks_correct(
311
+ detection_result.face_landmarks, expected_face_landmarks
312
+ )
313
+ if expected_face_blendshapes is not None:
314
+ self._expect_blendshapes_correct(
315
+ detection_result.face_blendshapes, expected_face_blendshapes
316
+ )
317
+ if expected_facial_transformation_matrixes is not None:
318
+ self._expect_facial_transformation_matrixes_correct(
319
+ detection_result.facial_transformation_matrixes,
320
+ expected_facial_transformation_matrixes,
321
+ )
322
+
323
+ def test_empty_detection_outputs(self):
324
+ options = _FaceLandmarkerOptions(
325
+ base_options=_BaseOptions(model_asset_path=self.model_path)
326
+ )
327
+ with _FaceLandmarker.create_from_options(options) as landmarker:
328
+ # Load the image with no faces.
329
+ no_faces_test_image = _Image.create_from_file(
330
+ test_utils.get_test_data_path(_CAT_IMAGE)
331
+ )
332
+ # Performs face landmarks detection on the input.
333
+ detection_result = landmarker.detect(no_faces_test_image)
334
+ self.assertEmpty(detection_result.face_landmarks)
335
+ self.assertEmpty(detection_result.face_blendshapes)
336
+ self.assertEmpty(detection_result.facial_transformation_matrixes)
337
+
338
+ def test_missing_result_callback(self):
339
+ options = _FaceLandmarkerOptions(
340
+ base_options=_BaseOptions(model_asset_path=self.model_path),
341
+ running_mode=_RUNNING_MODE.LIVE_STREAM,
342
+ )
343
+ with self.assertRaisesRegex(
344
+ ValueError, r'result callback must be provided'
345
+ ):
346
+ with _FaceLandmarker.create_from_options(options) as unused_landmarker:
347
+ pass
348
+
349
+ @parameterized.parameters((_RUNNING_MODE.IMAGE), (_RUNNING_MODE.VIDEO))
350
+ def test_illegal_result_callback(self, running_mode):
351
+ options = _FaceLandmarkerOptions(
352
+ base_options=_BaseOptions(model_asset_path=self.model_path),
353
+ running_mode=running_mode,
354
+ result_callback=mock.MagicMock(),
355
+ )
356
+ with self.assertRaisesRegex(
357
+ ValueError, r'result callback should not be provided'
358
+ ):
359
+ with _FaceLandmarker.create_from_options(options) as unused_landmarker:
360
+ pass
361
+
362
+ def test_calling_detect_for_video_in_image_mode(self):
363
+ options = _FaceLandmarkerOptions(
364
+ base_options=_BaseOptions(model_asset_path=self.model_path),
365
+ running_mode=_RUNNING_MODE.IMAGE,
366
+ )
367
+ with _FaceLandmarker.create_from_options(options) as landmarker:
368
+ with self.assertRaisesRegex(
369
+ ValueError, r'not initialized with the video mode'
370
+ ):
371
+ landmarker.detect_for_video(self.test_image, 0)
372
+
373
+ def test_calling_detect_async_in_image_mode(self):
374
+ options = _FaceLandmarkerOptions(
375
+ base_options=_BaseOptions(model_asset_path=self.model_path),
376
+ running_mode=_RUNNING_MODE.IMAGE,
377
+ )
378
+ with _FaceLandmarker.create_from_options(options) as landmarker:
379
+ with self.assertRaisesRegex(
380
+ ValueError, r'not initialized with the live stream mode'
381
+ ):
382
+ landmarker.detect_async(self.test_image, 0)
383
+
384
+ def test_calling_detect_in_video_mode(self):
385
+ options = _FaceLandmarkerOptions(
386
+ base_options=_BaseOptions(model_asset_path=self.model_path),
387
+ running_mode=_RUNNING_MODE.VIDEO,
388
+ )
389
+ with _FaceLandmarker.create_from_options(options) as landmarker:
390
+ with self.assertRaisesRegex(
391
+ ValueError, r'not initialized with the image mode'
392
+ ):
393
+ landmarker.detect(self.test_image)
394
+
395
+ def test_calling_detect_async_in_video_mode(self):
396
+ options = _FaceLandmarkerOptions(
397
+ base_options=_BaseOptions(model_asset_path=self.model_path),
398
+ running_mode=_RUNNING_MODE.VIDEO,
399
+ )
400
+ with _FaceLandmarker.create_from_options(options) as landmarker:
401
+ with self.assertRaisesRegex(
402
+ ValueError, r'not initialized with the live stream mode'
403
+ ):
404
+ landmarker.detect_async(self.test_image, 0)
405
+
406
+ def test_detect_for_video_with_out_of_order_timestamp(self):
407
+ options = _FaceLandmarkerOptions(
408
+ base_options=_BaseOptions(model_asset_path=self.model_path),
409
+ running_mode=_RUNNING_MODE.VIDEO,
410
+ )
411
+ with _FaceLandmarker.create_from_options(options) as landmarker:
412
+ unused_result = landmarker.detect_for_video(self.test_image, 1)
413
+ with self.assertRaisesRegex(
414
+ ValueError, r'Input timestamp must be monotonically increasing'
415
+ ):
416
+ landmarker.detect_for_video(self.test_image, 0)
417
+
418
+ @parameterized.parameters(
419
+ (
420
+ _FACE_LANDMARKER_BUNDLE_ASSET_FILE,
421
+ _get_expected_face_landmarks(_PORTRAIT_EXPECTED_FACE_LANDMARKS),
422
+ None,
423
+ None,
424
+ ),
425
+ )
426
+ def test_detect_for_video(
427
+ self,
428
+ model_name,
429
+ expected_face_landmarks,
430
+ expected_face_blendshapes,
431
+ expected_facial_transformation_matrixes,
432
+ ):
433
+ # Creates face landmarker.
434
+ model_path = test_utils.get_test_data_path(model_name)
435
+ base_options = _BaseOptions(model_asset_path=model_path)
436
+
437
+ options = _FaceLandmarkerOptions(
438
+ base_options=base_options,
439
+ running_mode=_RUNNING_MODE.VIDEO,
440
+ output_face_blendshapes=True if expected_face_blendshapes else False,
441
+ output_facial_transformation_matrixes=True
442
+ if expected_facial_transformation_matrixes
443
+ else False,
444
+ )
445
+
446
+ with _FaceLandmarker.create_from_options(options) as landmarker:
447
+ for timestamp in range(0, 300, 30):
448
+ # Performs face landmarks detection on the input.
449
+ detection_result = landmarker.detect_for_video(
450
+ self.test_image, timestamp
451
+ )
452
+ # Comparing results.
453
+ if expected_face_landmarks is not None:
454
+ self._expect_landmarks_correct(
455
+ detection_result.face_landmarks, expected_face_landmarks
456
+ )
457
+ if expected_face_blendshapes is not None:
458
+ self._expect_blendshapes_correct(
459
+ detection_result.face_blendshapes, expected_face_blendshapes
460
+ )
461
+ if expected_facial_transformation_matrixes is not None:
462
+ self._expect_facial_transformation_matrixes_correct(
463
+ detection_result.facial_transformation_matrixes,
464
+ expected_facial_transformation_matrixes,
465
+ )
466
+
467
+ def test_calling_detect_in_live_stream_mode(self):
468
+ options = _FaceLandmarkerOptions(
469
+ base_options=_BaseOptions(model_asset_path=self.model_path),
470
+ running_mode=_RUNNING_MODE.LIVE_STREAM,
471
+ result_callback=mock.MagicMock(),
472
+ )
473
+ with _FaceLandmarker.create_from_options(options) as landmarker:
474
+ with self.assertRaisesRegex(
475
+ ValueError, r'not initialized with the image mode'
476
+ ):
477
+ landmarker.detect(self.test_image)
478
+
479
+ def test_calling_detect_for_video_in_live_stream_mode(self):
480
+ options = _FaceLandmarkerOptions(
481
+ base_options=_BaseOptions(model_asset_path=self.model_path),
482
+ running_mode=_RUNNING_MODE.LIVE_STREAM,
483
+ result_callback=mock.MagicMock(),
484
+ )
485
+ with _FaceLandmarker.create_from_options(options) as landmarker:
486
+ with self.assertRaisesRegex(
487
+ ValueError, r'not initialized with the video mode'
488
+ ):
489
+ landmarker.detect_for_video(self.test_image, 0)
490
+
491
+ def test_detect_async_calls_with_illegal_timestamp(self):
492
+ options = _FaceLandmarkerOptions(
493
+ base_options=_BaseOptions(model_asset_path=self.model_path),
494
+ running_mode=_RUNNING_MODE.LIVE_STREAM,
495
+ result_callback=mock.MagicMock(),
496
+ )
497
+ with _FaceLandmarker.create_from_options(options) as landmarker:
498
+ landmarker.detect_async(self.test_image, 100)
499
+ with self.assertRaisesRegex(
500
+ ValueError, r'Input timestamp must be monotonically increasing'
501
+ ):
502
+ landmarker.detect_async(self.test_image, 0)
503
+
504
+ @parameterized.parameters(
505
+ (
506
+ _PORTRAIT_IMAGE,
507
+ _FACE_LANDMARKER_BUNDLE_ASSET_FILE,
508
+ _get_expected_face_landmarks(_PORTRAIT_EXPECTED_FACE_LANDMARKS),
509
+ None,
510
+ None,
511
+ ),
512
+ )
513
+ def test_detect_async_calls(
514
+ self,
515
+ image_path,
516
+ model_name,
517
+ expected_face_landmarks,
518
+ expected_face_blendshapes,
519
+ expected_facial_transformation_matrixes,
520
+ ):
521
+ test_image = _Image.create_from_file(
522
+ test_utils.get_test_data_path(image_path)
523
+ )
524
+ observed_timestamp_ms = -1
525
+
526
+ def check_result(
527
+ result: FaceLandmarkerResult, output_image: _Image, timestamp_ms: int
528
+ ):
529
+ # Comparing results.
530
+ if expected_face_landmarks is not None:
531
+ self._expect_landmarks_correct(
532
+ result.face_landmarks, expected_face_landmarks
533
+ )
534
+ if expected_face_blendshapes is not None:
535
+ self._expect_blendshapes_correct(
536
+ result.face_blendshapes, expected_face_blendshapes
537
+ )
538
+ if expected_facial_transformation_matrixes is not None:
539
+ self._expect_facial_transformation_matrixes_correct(
540
+ result.facial_transformation_matrixes,
541
+ expected_facial_transformation_matrixes,
542
+ )
543
+ self.assertTrue(
544
+ np.array_equal(output_image.numpy_view(), test_image.numpy_view())
545
+ )
546
+ self.assertLess(observed_timestamp_ms, timestamp_ms)
547
+ self.observed_timestamp_ms = timestamp_ms
548
+
549
+ model_path = test_utils.get_test_data_path(model_name)
550
+ options = _FaceLandmarkerOptions(
551
+ base_options=_BaseOptions(model_asset_path=model_path),
552
+ running_mode=_RUNNING_MODE.LIVE_STREAM,
553
+ output_face_blendshapes=True if expected_face_blendshapes else False,
554
+ output_facial_transformation_matrixes=True
555
+ if expected_facial_transformation_matrixes
556
+ else False,
557
+ result_callback=check_result,
558
+ )
559
+ with _FaceLandmarker.create_from_options(options) as landmarker:
560
+ for timestamp in range(0, 300, 30):
561
+ landmarker.detect_async(test_image, timestamp)
562
+
563
+
564
+ if __name__ == '__main__':
565
+ absltest.main()