• 
    

    
    

      99热精品在线国产_美女午夜性视频免费_国产精品国产高清国产av_av欧美777_自拍偷自拍亚洲精品老妇_亚洲熟女精品中文字幕_www日本黄色视频网_国产精品野战在线观看 ?

      一種基于Kinect的手勢識別系統(tǒng)

      2015-07-18 14:47:46劉嘯宇韓格欣王瑞代麗男
      物聯(lián)網(wǎng)技術 2015年5期
      關鍵詞:手勢識別特征提取

      劉嘯宇++韓格欣++王瑞++代麗男++薄純娟

      摘 要:手勢識別系統(tǒng)有著廣闊的應用前景,一套穩(wěn)定、高效的手勢識別算法可以為其后的機器學習提供良好基礎。簡要分析了計算機圖像處理結(jié)合Kinect在手勢識別領域的應用,并提出了一種結(jié)合Kinect深度信息的可行的手勢識別方法,最后通過實驗驗證了該算法的穩(wěn)定性和效率。

      關鍵詞:Kinect;手勢識別;特征提??;計算機圖像處理

      中圖分類號:TP368 文獻標識碼:A 文章編號:2095-1302(2015)05-00-03

      0 引 言

      人機交互方式多年來都停留在以鍵盤和鼠標為中心的傳統(tǒng)方式上,然而,隨著科技進步,特別是傳感器技術和芯片制造技術的進步,工程師們正在不停的探索新的人機交互體驗。已知的人機交互體驗包括聲音交互、腦電波交互、人體肢體姿態(tài)交互、手勢交互等。這其中,基于計算機圖像處理技術的手勢識別已經(jīng)擁有了廣闊的應用。

      手勢識別技術可以利用在醫(yī)療領用,用于孤獨癥兒童的治療;可以應用在溝通領域,用于聾啞患者的手語交流;也可以應用在游戲領域,創(chuàng)造新的游戲人機交互體驗。但是,現(xiàn)行的手勢識別系統(tǒng)之所以不夠普及,很大一部分在于識別算法的穩(wěn)定性和快速性得不到保證。這是因為使用計算機圖像處理手段的手勢識別系統(tǒng)受到計算機圖像處理能力的極大制約。圖像處理,特別是實時圖像處理,在實際操作中會受到光照、遮蔽、陰影等因素的制約,每一種因素的變化都會對最終的識別結(jié)果造成影響。因此,如何得到穩(wěn)定且置信度高的手勢識別結(jié)果就成了各國計算機圖像處理工程師的重要攻克方向。

      幸運的是,在2009年6月1日E3 2009大會上首次公布的Kinect設備為這種要求提供了更進一步的保障。利用Kinect提供的深度信息,結(jié)合在計算機圖像處理和機器學習領域早已頗有建樹的開源計算機圖形處理庫OPENCV,開發(fā)者可以將制約圖像處理的環(huán)境光因素降到最低,從而開發(fā)出穩(wěn)定可靠的手勢識別系統(tǒng)。

      1 Kinect簡介

      Kinect 是微軟為Xbox研發(fā)的一款體感周邊外設產(chǎn)品。Kinect一經(jīng)提出就因其革命性的超前構(gòu)想和顛覆性的人體姿態(tài)操作方式[1]受到了眾多玩家和開發(fā)者的追捧。Kinect精確的空間定位性能結(jié)合先進的計算機視覺處理算法,可以為人機交互領域提供廣闊的發(fā)展空間。如圖1所示,Kinect通過高分辨率深度信息,能夠分辨空間物體細小的變動;支持錄制1080p高清視頻,在不失去保真度的情況下可支持6人同時操作;Kinect套件自帶骨骼追蹤SDK,可以實時跟蹤 6 個完整骨骼和每套骨骼的 25 個關節(jié)。更重要的是,紅外線傳感器給Kinect賦予了黑暗中識別動作的能力,這大大降低了對用戶操作環(huán)境的要求,使人們可以在沒有照明的情況下使用Kinect,大大解放了對用戶和開發(fā)者對場地的要求,從而讓機器學習變得更簡單[2]。

      圖1 Kinect圖示

      2 計算機圖像處理中的手勢識別

      基于計算機圖像處理的手勢識別系統(tǒng)大體上分為:手勢采集、手勢分割、手勢提取及手勢理解四個步驟[3]。手勢識別的方法見表1。

      表1 手勢識別靜態(tài)識別[4] 動態(tài)識別[5]

      模板匹配法(TM) 動態(tài)時間規(guī)整法(DTW)

      神經(jīng)網(wǎng)絡法(NN) 隱馬爾可夫模型法(HMM)

      在大量手勢識別系統(tǒng)的實際開發(fā)過程中,開發(fā)者都面臨著一個基本的問題:使用不同算法過濾系統(tǒng)來獲取手勢的二值化圖像。常用的獲取方法是基于膚色來過濾手勢輪廓。

      手勢姿態(tài)二值化圖像的獲取關系到后期手勢姿態(tài)理解的穩(wěn)定性和準確性,但是人體的手部顏色受到個體差異、光源顏色以及光照角度的影響,其中任何一個因素變化都將造成陰影、遮蔽等不良影響[6]。Kinect的出現(xiàn)彌補了這個缺陷。利用Kinect的深度和紅外信息,使得Kinect的開發(fā)者可以在不考慮光照的情況下通過深度分辨出位于攝像頭前方的手勢姿態(tài),而被遮蔽的手勢則可以輕易的被系統(tǒng)識別出來過濾掉,防止影響最終結(jié)果。

      3 Kinect在手勢識別中的應用

      本文首先使用Kinect官方SDK中的人體骨骼識別功能識別出人體骨骼模型,如圖2所示。

      圖2 SDK人體骨骼識別

      在人體手部部位,創(chuàng)建一個包絡矩形,這個矩形稱為環(huán)境矩形。Kinect初始化代碼如下:

      private void BodyReader_FrameArrivedEvent(object sender, BodyFrameArrivedEventArgs e)

      {

      bool t_BodyFrameProcessed = false;

      using (BodyFrame bodyFrame = e.FrameReference.AcquireFrame())

      {

      if (bodyFrame != null)

      {

      if (this.bodies == null)

      {

      this.bodies = new

      Body[bodyFrame.BodyCount];

      }

      /* The first time

      GetAndRefreshBodyData is called, Kinect will allocate each Body in the array.

      As long as those body objects are not disposed and not set to null in the array,

      those body objects will be re-used. */

      bodyFrame.GetAndRefreshBodyData(this.bodies);

      t_BodyFrameProcessed = true;

      }

      }

      if (t_BodyFrameProcessed)

      {

      ……

      }

      }

      然后,使用YCrCb色彩空間的膚色分割算法在使用者在線模式下,將位于環(huán)境矩形內(nèi)的使用者手部圖像提取20組,利用20組內(nèi)的中心點顏色均值與環(huán)境矩形內(nèi)所有點的關系計算出使用者手部圖像的顏色閾值。然后利用二分法依次改變閾值,尋找出環(huán)境矩形區(qū)域內(nèi)噪點最少的手部圖像值,最后利用這個值進行手勢姿態(tài)圖像二值化處理。將得到的二值化圖像進行特征化處理,得到手部特征點。通過對特征點的運算,得到最終手勢姿態(tài)理解結(jié)果。

      4 手勢視頻流的二值化處理

      使用Kinect進行手勢視頻流的二值化處理核心代碼如下。獲取最近人體部位識別區(qū)域(在線檢測為手部):

      #region Map the CameraJointPoints to DepthJointPoints and find the min-depth joint

      IReadOnlyDictionary CameraJointPoints = body.Joints;

      // convert the joint points to depth (display) space

      Dictionary DepthJointPoints = new Dictionary();

      // This is our AIM point

      JointType MinDepthJointType = JointType.Head;

      foreach (JointType jointType in CameraJointPoints.Keys)

      {

      // sometimes the depth(Z) of an inferred joint may show as negative

      // clamp down to 0.1f to prevent coordinatemapper from returning (-Infinity, -Infinity)

      CameraSpacePoint position = CameraJointPoints[jointType].Position;

      if (position.Z < 0)

      {

      position.Z = 0.1f;

      }

      if (position.Z < CameraJointPoints[MinDepthJointType].Position.Z)

      {

      MinDepthJointType = jointType;

      }

      DepthJointPoints[jointType] = this.kinectSensor.CoordinateMapper.MapCameraPointToDepthSpace(position);

      }

      #endregion

      在此特征區(qū)域內(nèi),圍繞中心點繪制出環(huán)境矩形,然后調(diào)用OPENCV庫進行手勢姿態(tài)運算:

      frame = cvQueryFrame( capture );//讀取一幀圖像

      if( !frame ) break;

      assert( 0 ==

      binary_image_process( frame , mask , high_threshold1 , high_threshold2 , high_threshold3 , &is_get_binary )

      );

      cvShowImage( “Binary_cam” , mask );

      其中,threshold1、threshold2、threshold3均為閾值在YCrCb空間的顏色分量。

      結(jié)合環(huán)境矩形處理后提取的手勢識別二值化圖形如圖3、圖4所示。

      圖3 手勢識別二值化圖形 圖4 手勢識別二值化圖形

      可見,此方法提取的二值化圖像清晰準確、輕量速度快、穩(wěn)定性高。

      5 手勢姿態(tài)特征的識別與理解

      首先,我們通過對最小包絡圓和手腕的計算得出手掌心位置,然后利用每個點與相鄰點做向量外積,計算是否為手指尖點和手縫點,最后可得出手勢姿態(tài)的全部特征點。

      //計算整個手的中心點

      for( int i=0 ; i < real_contours_number ; i++ ){

      contour_rectangle = cvMinAreaRect2( sort_contours[i] , 0 );

      arm_center[i].x = cvRound( contour_rectangle.center.x );

      arm_center[i].y = cvRound( contour_rectangle.center.y );

      cvCircle( frame , arm_center[i] , 10 , CV_RGB(255,255,255) , -1 , 8 , 0 );

      }

      //取得輪廓中的凸包,畫出手指縫

      for( int i=0 ; i < real_contours_number ; i++ ){

      get_convex_hull( i );

      finger_tip( i );

      hand( i );

      cvClearSeq( hull );

      cvClearSeq( defect );

      }

      最終,得到的含有全部手勢特征點的圖像如圖5 、 圖6所示。

      圖5 手勢特征點

      圖6 同一算法多人多手識別

      6 結(jié) 語

      Kinect的出現(xiàn)為開發(fā)者們提供了強有力的工具,不僅僅是從硬件上,更是從平臺層面增加了很多高級別圖像處理能力,開發(fā)者們可以利于微軟官方SDK開發(fā)出大量基于圖像的應用。結(jié)合Kinect自身具備的聲音識別技術、利用現(xiàn)行的OpenCV開源視覺庫,開發(fā)者們不僅能夠為PC機開發(fā)應用,更可以為嵌入式視頻系統(tǒng)、機器人等領域的專業(yè)需求提供一系列解決方案。

      參考文獻

      [1] Reuben Fleming.Motion Capture Tutorials[OL].[2012-07-01]. http://www.reubenfleming.co.uk

      [2] Microsoft. Introduce to kinect[DB/OL]. https://www.microsoft.com/en-us/kinectforwindows/

      [3]趙健, 張冬泉. 基于OpenCV的數(shù)字手勢識別算法[J]. 計算機應用, 2013, 33(S2):193-196.

      [4]郭興偉,葛元,王林泉.基于形狀特征的字母手勢的分類及識別算法[J].計算機工程,2004,30(18):130-132.

      [5] LEE H-K,KIM J H.An HMM-based threshold model approach for gesture recognition[J].IEEE Transactions on Pattern Analysis and Machine Intelligence, 1999,21( 10) : 961-973.

      [6] SURAL S,QIAN G,PRAMANIK S.Segmentation and histogram generation using the HSV color space for image retrieval[C] of the 2002 International Conference on Image Processing.Piscataway: IEEE,2002: 589-592.

      猜你喜歡
      手勢識別特征提取
      特征提取和最小二乘支持向量機的水下目標識別
      基于Gazebo仿真環(huán)境的ORB特征提取與比對的研究
      電子制作(2019年15期)2019-08-27 01:12:00
      基于Daubechies(dbN)的飛行器音頻特征提取
      電子制作(2018年19期)2018-11-14 02:37:08
      Bagging RCSP腦電特征提取算法
      基于手勢識別的工業(yè)機器人操作控制方法
      基于紅外的非接觸式手勢識別系統(tǒng)設計
      基于嵌入式的智能手表設計
      復雜背景下的手勢識別方法
      基于SIFT算法的手勢控制系統(tǒng)的設計與實現(xiàn)
      一種靜態(tài)手勢數(shù)字識別的實現(xiàn)及應用
      天等县| 慈溪市| 方城县| 樟树市| 江津市| 延边| 永寿县| 维西| 宁陕县| 锡林郭勒盟| 洪泽县| 永修县| 颍上县| 武邑县| 阳原县| 西乌| 昌都县| 牟定县| 思南县| 郴州市| 香格里拉县| 定安县| 永仁县| 枞阳县| 客服| 文昌市| 耿马| 丹巴县| 建始县| 绵竹市| 霍邱县| 贵德县| 桂东县| 平度市| 佛坪县| 滨州市| 肇东市| 海口市| 弥渡县| 陵川县| 郯城县|