AipBodyAnalysis.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233
  1. <?php
  2. /*
  3. * Copyright (c) 2017 Baidu.com, Inc. All Rights Reserved
  4. *
  5. * Licensed under the Apache License, Version 2.0 (the "License"); you may not
  6. * use this file except in compliance with the License. You may obtain a copy of
  7. * 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, WITHOUT
  13. * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
  14. * License for the specific language governing permissions and limitations under
  15. * the License.
  16. */
  17. require_once 'lib/AipBase.php';
  18. class AipBodyAnalysis extends AipBase {
  19. /**
  20. * 人体关键点识别 body_analysis api url
  21. * @var string
  22. */
  23. private $bodyAnalysisUrl = 'https://aip.baidubce.com/rest/2.0/image-classify/v1/body_analysis';
  24. /**
  25. * 人体检测与属性识别 body_attr api url
  26. * @var string
  27. */
  28. private $bodyAttrUrl = 'https://aip.baidubce.com/rest/2.0/image-classify/v1/body_attr';
  29. /**
  30. * 人流量统计 body_num api url
  31. * @var string
  32. */
  33. private $bodyNumUrl = 'https://aip.baidubce.com/rest/2.0/image-classify/v1/body_num';
  34. /**
  35. * 手势识别 gesture api url
  36. * @var string
  37. */
  38. private $gestureUrl = 'https://aip.baidubce.com/rest/2.0/image-classify/v1/gesture';
  39. /**
  40. * 人像分割 body_seg api url
  41. * @var string
  42. */
  43. private $bodySegUrl = 'https://aip.baidubce.com/rest/2.0/image-classify/v1/body_seg';
  44. /**
  45. * 驾驶行为分析 driver_behavior api url
  46. * @var string
  47. */
  48. private $driverBehaviorUrl = 'https://aip.baidubce.com/rest/2.0/image-classify/v1/driver_behavior';
  49. /**
  50. * 人流量统计-动态版 body_tracking api url
  51. * @var string
  52. */
  53. private $bodyTrackingUrl = 'https://aip.baidubce.com/rest/2.0/image-classify/v1/body_tracking';
  54. /**
  55. * 手部关键点识别 hand_analysis api url
  56. * @var string
  57. */
  58. private $handAnalysisUrl = 'https://aip.baidubce.com/rest/2.0/image-classify/v1/hand_analysis';
  59. /**
  60. * 人体关键点识别接口
  61. *
  62. * @param string $image - 图像数据,base64编码,要求base64编码后大小不超过4M,最短边至少15px,最长边最大4096px,支持jpg/png/bmp格式
  63. * @param array $options - 可选参数对象,key: value都为string类型
  64. * @description options列表:
  65. * @return array
  66. */
  67. public function bodyAnalysis($image, $options=array()){
  68. $data = array();
  69. $data['image'] = base64_encode($image);
  70. $data = array_merge($data, $options);
  71. return $this->request($this->bodyAnalysisUrl, $data);
  72. }
  73. /**
  74. * 人体检测与属性识别接口
  75. *
  76. * @param string $image - 图像数据,base64编码,要求base64编码后大小不超过4M,最短边至少15px,最长边最大4096px,支持jpg/png/bmp格式
  77. * @param array $options - 可选参数对象,key: value都为string类型
  78. * @description options列表:
  79. * type gender,<br>age,<br>lower_wear,<br>upper_wear,<br>headwear,<br>glasses,<br>upper_color,<br>lower_color,<br>cellphone,<br>upper_wear_fg,<br>upper_wear_texture,<br>lower_wear_texture,<br>orientation,<br>umbrella,<br>bag,<br>smoke,<br>vehicle,<br>carrying_item,<br>upper_cut,<br>lower_cut,<br>occlusion,<br>is_human | 1)可选值说明:<br>gender-性别,<br>age-年龄阶段,<br>lower_wear-下身服饰,<br>upper_wear-上身服饰,<br>headwear-是否戴帽子,<br>glasses-是否戴眼镜,<br>upper_color-上身服饰颜色,<br>lower_color-下身服饰颜色,<br>cellphone-是否使用手机,<br>upper_wear_fg-上身服饰细分类,<br>upper_wear_texture-上身服饰纹理,<br>orientation-身体朝向,<br>umbrella-是否撑伞;<br>bag-背包,<br>smoke-是否吸烟,<br>vehicle-交通工具,<br>carrying_item-是否有手提物,<br>upper_cut-上方截断,<br>lower_cut-下方截断,<br>occlusion-遮挡,<br>is_human-是否是正常人体<br>2)type 参数值可以是可选值的组合,用逗号分隔;**如果无此参数默认输出全部21个属性**
  80. * @return array
  81. */
  82. public function bodyAttr($image, $options=array()){
  83. $data = array();
  84. $data['image'] = base64_encode($image);
  85. $data = array_merge($data, $options);
  86. return $this->request($this->bodyAttrUrl, $data);
  87. }
  88. /**
  89. * 人流量统计接口
  90. *
  91. * @param string $image - 图像数据,base64编码,要求base64编码后大小不超过4M,最短边至少15px,最长边最大4096px,支持jpg/png/bmp格式
  92. * @param array $options - 可选参数对象,key: value都为string类型
  93. * @description options列表:
  94. * area 特定框选区域坐标,支持多个多边形区域,最多支持10个区域,如输入超过10个区域,截取前10个区域进行识别。<br>**此参数为空或无此参数、或area参数设置错误时,默认识别整个图片的人数** 。<br>area参数设置错误的示例:某个坐标超过原图大小,x、y坐标未成对出现等;注意:**设置了多个区域时,任意一个坐标设置错误,则认为area参数错误、失效**。<br>**area参数设置格式**:<br>1)多个区域用英文分号“;”分隔;<br>2)同一个区域内的坐标用英文逗号“,”分隔,默认尾点和首点相连做闭合。<br>示例:<br>1)单个多边形区域:x1,y1,x2,y2,x3,y3...xn,yn<br>2)多个多边形区域:xa1,ya1,xa2,ya2,xa3,ya3...xan,yan;xb1,yb1,xb2,yb2,xb3,yb3...xbn,ybn;..
  95. * show 是否输出渲染的图片,默认不返回,**选true时返回渲染后的图片(base64)**,其它无效值或为空则默认false
  96. * @return array
  97. */
  98. public function bodyNum($image, $options=array()){
  99. $data = array();
  100. $data['image'] = base64_encode($image);
  101. $data = array_merge($data, $options);
  102. return $this->request($this->bodyNumUrl, $data);
  103. }
  104. /**
  105. * 手势识别接口
  106. *
  107. * @param string $image - 图像数据,base64编码,要求base64编码后大小不超过4M,最短边至少15px,最长边最大4096px,支持jpg/png/bmp格式
  108. * @param array $options - 可选参数对象,key: value都为string类型
  109. * @description options列表:
  110. * @return array
  111. */
  112. public function gesture($image, $options=array()){
  113. $data = array();
  114. $data['image'] = base64_encode($image);
  115. $data = array_merge($data, $options);
  116. return $this->request($this->gestureUrl, $data);
  117. }
  118. /**
  119. * 人像分割接口
  120. *
  121. * @param string $image - 图像数据,base64编码,要求base64编码后大小不超过4M,最短边至少15px,最长边最大4096px,支持jpg/png/bmp格式
  122. * @param array $options - 可选参数对象,key: value都为string类型
  123. * @description options列表:
  124. * type 可以通过设置type参数,自主设置返回哪些结果图,避免造成带宽的浪费<br>1)可选值说明:<br>labelmap - 二值图像,需二次处理方能查看分割效果<br>scoremap - 人像前景灰度图<br>foreground - 人像前景抠图,透明背景<br>2)type 参数值可以是可选值的组合,用逗号分隔;如果无此参数默认输出全部3类结果图
  125. * @return array
  126. */
  127. public function bodySeg($image, $options=array()){
  128. $data = array();
  129. $data['image'] = base64_encode($image);
  130. $data = array_merge($data, $options);
  131. return $this->request($this->bodySegUrl, $data);
  132. }
  133. /**
  134. * 驾驶行为分析接口
  135. *
  136. * @param string $image - 图像数据,base64编码,要求base64编码后大小不超过4M,最短边至少15px,最长边最大4096px,支持jpg/png/bmp格式
  137. * @param array $options - 可选参数对象,key: value都为string类型
  138. * @description options列表:
  139. * type smoke,cellphone,<br>not_buckling_up,<br>both_hands_leaving_wheel,<br>not_facing_front |识别的属性行为类别,英文逗号分隔,默认所有属性都识别;<br>smoke //吸烟,<br>cellphone //打手机 ,<br>not_buckling_up // 未系安全带,<br>both_hands_leaving_wheel // 双手离开方向盘,<br>not_facing_front // 视角未看前方
  140. * @return array
  141. */
  142. public function driverBehavior($image, $options=array()){
  143. $data = array();
  144. $data['image'] = base64_encode($image);
  145. $data = array_merge($data, $options);
  146. return $this->request($this->driverBehaviorUrl, $data);
  147. }
  148. /**
  149. * 人流量统计-动态版接口
  150. *
  151. * @param string $image - 图像数据,base64编码,要求base64编码后大小不超过4M,最短边至少15px,最长边最大4096px,支持jpg/png/bmp格式
  152. * @param string $dynamic - true:动态人流量统计,返回总人数、跟踪ID、区域进出人数;<br>false:静态人数统计,返回总人数
  153. * @param array $options - 可选参数对象,key: value都为string类型
  154. * @description options列表:
  155. * case_id 当dynamic为True时,必填;任务ID(通过case_id区分不同视频流,自拟,不同序列间不可重复即可)
  156. * case_init 当dynamic为True时,必填;每个case的初始化信号,为true时对该case下的跟踪算法进行初始化,为false时重载该case的跟踪状态。当为false且读取不到相应case的信息时,直接重新初始化
  157. * show 否返回结果图(含统计值和跟踪框渲染),默认不返回,选true时返回渲染后的图片(base64),其它无效值或为空则默认false
  158. * area 当dynamic为True时,必填;静态人数统计时,只统计区域内的人,缺省时为全图统计。<br>动态人流量统计时,进出区域的人流会被统计。<br>逗号分隔,如‘x1,y1,x2,y2,x3,y3...xn,yn',按顺序依次给出每个顶点的xy坐标(默认尾点和首点相连),形成闭合多边形区域。<br>服务会做范围(顶点左边需在图像范围内)及个数校验(数组长度必须为偶数,且大于3个顶点)。只支持单个多边形区域,建议设置矩形框,即4个顶点。**坐标取值不能超过图像宽度和高度,比如1280的宽度,坐标值最小建议从1开始,最大到1279**。
  159. * @return array
  160. */
  161. public function bodyTracking($image, $dynamic, $options=array()){
  162. $data = array();
  163. $data['image'] = base64_encode($image);
  164. $data['dynamic'] = $dynamic;
  165. $data = array_merge($data, $options);
  166. return $this->request($this->bodyTrackingUrl, $data);
  167. }
  168. /**
  169. * 手部关键点识别接口
  170. *
  171. * @param string $image - 图像数据,base64编码,要求base64编码后大小不超过4M,最短边至少15px,最长边最大4096px,支持jpg/png/bmp格式
  172. * @param array $options - 可选参数对象,key: value都为string类型
  173. * @description options列表:
  174. * @return array
  175. */
  176. public function handAnalysis($image, $options=array()){
  177. $data = array();
  178. $data['image'] = base64_encode($image);
  179. $data = array_merge($data, $options);
  180. return $this->request($this->handAnalysisUrl, $data);
  181. }
  182. }