亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? subdivmorpher.cpp

?? 微軟的基于HMM的人臉識別原代碼, 非常經典的說
?? CPP
字號:
#include "stdafx.h"
#include "SubdivMorpher.h"

typedef struct
{
    CV_SUBDIV2D_POINT_FIELDS()
    CvPoint2D32f* another;
}
StereoSubdivPoint;

CCvSubdivMorpher::CCvSubdivMorpher()
{
    m_subdiv = cvCreateSubdiv2D( 0, sizeof(*m_subdiv),
                                 sizeof(StereoSubdivPoint),
                                 sizeof(CvQuadEdge2D),
                                 cvCreateMemStorage(0));
    Clear();
    SetPointCount(100);

    m_win_size = cvSize(20,20);
    m_pyr_level = 3;
    m_criteria = cvTermCriteria(CV_TERMCRIT_ITER|CV_TERMCRIT_EPS,20,0.1);
}    


bool CCvSubdivMorpher::GeneratePoints()
{
#if 1
    int x, y;
    int count = m_count - 4;

    CvSize size = GetImageSize( m_left_gray_img );

    int ny = cvRound( cvSqrt( ((float)count)*size.height/size.width ));
    int nx = cvFloor( ((float)count)/MAX(ny,1) );

    float x_scale = ((float)size.width)/(nx + 1);
    float y_scale = ((float)size.height)/(ny + 1);

    if( nx < 2 || ny < 2 ) return false;

    m_realcount = nx*ny;

    for( y = 0; y < ny; y++ )
    {
        for( x = 0; x < nx; x++ )
        {
            m_left_points[y*nx + x] =
                cvPoint2D32f( (x + 0.5f)*x_scale, (y + 0.5f)*y_scale );
        }
    }

#else
    m_realcount = m_count;

    cvGoodFeaturesToTrack( m_left_gray_img, m_left_pyr, m_right_pyr, m_left_points,
                           &m_realcount, 0.01, 5 );
#endif

    cvFindCornerSubPix( m_left_gray_img, m_left_points, m_realcount,
                        m_win_size, cvSize(-1,-1), m_criteria );
    return true;


}

bool CCvSubdivMorpher::OnCalculateStereo()
{
    CvSize size = GetImageSize( m_left_img );
    int i, k;
    bool result = false;
    char* status = new char[m_count];
    
    m_left_gray_img = CreateIsometricImage( m_left_img, m_left_gray_img,
                                            m_left_img->depth, 1 );
    m_right_gray_img = CreateIsometricImage( m_right_img, m_right_gray_img,
                                             m_right_img->depth, 1 );

    m_left_pyr = CreateIsometricImage( m_left_img, m_left_pyr,
                                       IPL_DEPTH_32F, 1 );
    m_right_pyr = CreateIsometricImage( m_right_img, m_right_pyr,
                                        IPL_DEPTH_32F, 1 );

    iplColorToGray( m_left_img, m_left_gray_img );
    iplColorToGray( m_right_img, m_right_gray_img );

    m_left_gray_img->roi->width &= -(1 << m_pyr_level);
    m_left_gray_img->roi->height &= -(1 << m_pyr_level);
    m_right_gray_img->roi = m_left_gray_img->roi;

    result = GeneratePoints();
    if( !result ) return result;

    cvCalcOpticalFlowPyrLK( m_left_gray_img, m_right_gray_img,
                            m_left_pyr, m_right_pyr, m_left_points, m_right_points,
                            m_realcount, m_win_size, m_pyr_level, status, 0,
                            m_criteria,0);

    m_right_gray_img->roi = m_left_gray_img->roi = m_left_img->roi;

    for( i = 0, k = 0; i < m_realcount; i++ )
    {
        if( status[i] &&
            m_left_points[i].x > 1 && m_left_points[i].x < size.width - 2 &&
            m_left_points[i].y > 1 && m_left_points[i].y < size.height - 2  &&
            m_right_points[i].x > 1 && m_right_points[i].x < size.width - 2 &&
            m_right_points[i].y > 1 && m_right_points[i].y < size.height - 2 )
        {
            if( k < i )
            {
                m_left_points[k] = m_left_points[i];
                m_right_points[k] = m_right_points[i];
            }
            k++;
        }
    }

    delete status;

    m_realcount = k + 4;

    m_right_points[k]   = m_left_points[k] = cvPoint2D32f( 1.f, 1.f );
    m_right_points[k+1] = m_left_points[k+1] = cvPoint2D32f( size.width - 2.f, 1.f );
    m_right_points[k+2] = m_left_points[k+2] = cvPoint2D32f( size.width - 2.f, size.height - 2.f );
    m_right_points[k+3] = m_left_points[k+3] = cvPoint2D32f( 1.f, size.height - 2.f );

    cvInitSubdivDelaunay2D( m_subdiv, cvRect(0,0,size.width,size.height));

    for( i = 0; i < m_realcount; i++ )
    {
        if( i == 77 )
        {
            printf("%d",i);
        }
        StereoSubdivPoint* point = (StereoSubdivPoint*)
            cvSubdivDelaunay2DInsert( m_subdiv, m_left_points[i] );
        point->another = m_right_points + i;
    }

    return result;
}


bool CCvSubdivMorpher::OnCalculateVirtualImage()
{
    CvSeqReader reader;
    int i, total = m_subdiv->edges->total;

    iplSet( m_virtual_img, 0 );

    cvStartReadSeq( (CvSeq*)(m_subdiv->edges), &reader, 0 );

    for( i = 0; i < total; i++ )
    {
        CvQuadEdge2D* quadedge = (CvQuadEdge2D*)reader.ptr;
        CvSubdiv2DEdge edge = (CvSubdiv2DEdge)quadedge;

        if( CV_IS_SET_ELEM_EXISTS( quadedge ))
        {
            if( !quadedge->pt[3] ) // left facet was not considered
            {
                MorphFacet( edge );            
            }

            if( !quadedge->pt[1] ) // right facet was not considered
            {
                MorphFacet( cvSubdiv2DSymEdge(edge));
            }
        }

        CV_NEXT_SEQ_ELEM( sizeof(*quadedge), reader );
    }

    cvSetSeqReaderPos( 0, 0, &reader );

    // clear "facet visited" flags
    for( i = 0; i < total; i++ )
    {
        CvQuadEdge2D* quadedge = (CvQuadEdge2D*)reader.ptr;
        quadedge->pt[1] = quadedge->pt[3] = 0;
        CV_NEXT_SEQ_ELEM( sizeof(*quadedge), reader );
    }
    //iplCopy( m_left_img, m_virtual_img );

    cvDeleteMoire( m_virtual_img );

    return true;
}


void CCvSubdivMorpher::MorphFacet( CvSubdiv2DEdge edge )
{
#define SHIFT      10
#define DELTA      (1 << (SHIFT - 1))
#define ASHIFT     8
#define ADELTA     (1 << (ASHIFT - 1))

    CvPoint2D32f left_points[3];
    CvPoint2D32f right_points[3];
    CvPoint2D32f middle_points[3];
    CvPoint left_c, right_c, middle_c;

    CvSize size;
    int left_step = 0, right_step = 0, middle_step = 0;
    uchar* left_data = 0;
    uchar* right_data = 0;
    uchar* middle_data = 0;
    int min_len, max_len;
    int i, j, v;
    CvPoint2D32f left_pt_step, right_pt_step, middle_pt_step;
    float t;
    int alpha = cvRound(m_pan*(1 << ASHIFT));
    int flag = 0;

    cvGetImageRawData( m_left_img, &left_data, &left_step, &size );
    cvGetImageRawData( m_right_img, &right_data, &right_step, 0 );
    cvGetImageRawData( m_virtual_img, &middle_data, &middle_step, 0 );

    for( i = 0; i < 3; i++ )
    {
        StereoSubdivPoint* subdiv_pt = (StereoSubdivPoint*)cvSubdiv2DEdgeOrg( edge );
        
        left_points[i] = subdiv_pt->pt;
        right_points[i] = subdiv_pt->another ? *subdiv_pt->another : left_points[i];
        
        ((CvQuadEdge2D*)(edge & ~3))->pt[(edge + 3) & 3] = (CvSubdiv2DPoint*)1;
        edge = cvSubdiv2DGetEdge( edge, CV_NEXT_AROUND_LEFT );

        middle_points[i].x = left_points[i].x + m_pan*(right_points[i].x - left_points[i].x);
        middle_points[i].y = left_points[i].y + m_pan*(right_points[i].y - left_points[i].y);

        flag |= (unsigned)left_points[i].x >= (unsigned)size.width ||
                (unsigned)left_points[i].y >= (unsigned)size.height;
    }

    if( flag ) return;

    // calculate min and max side length in the middle triangle
    v = cvRound(fabs(middle_points[0].x - middle_points[1].x) + 
                fabs(middle_points[0].y - middle_points[1].y));

    min_len = max_len = v;
    i = 0;

    v = cvRound(fabs(middle_points[1].x - middle_points[2].x) + 
                fabs(middle_points[1].y - middle_points[2].y));

    if( v < min_len ) min_len = v, i = 1;
    if( v > max_len ) max_len = v;

    v = cvRound(fabs(middle_points[0].x - middle_points[2].x) + 
                fabs(middle_points[0].y - middle_points[2].y));

    if( v < min_len ) min_len = v, i = 2;
    if( v > max_len ) max_len = v;

    if( i != 0 )
    {
        CvPoint2D32f t;
        CV_SWAP( left_points[2], left_points[i-1], t );
        CV_SWAP( right_points[2], right_points[i-1], t );
        CV_SWAP( middle_points[2], middle_points[i-1], t );
    }

    left_c = cvPoint( cvRound(left_points[2].x*(1 << SHIFT)),
                      cvRound(left_points[2].y*(1 << SHIFT)));
    right_c = cvPoint( cvRound(right_points[2].x*(1 << SHIFT)),
                       cvRound(right_points[2].y*(1 << SHIFT)));
    middle_c = cvPoint( cvRound(middle_points[2].x*(1 << SHIFT)),
                        cvRound(middle_points[2].y*(1 << SHIFT)));

    t = 1.f/min_len;

    left_pt_step = cvPoint2D32f( (left_points[1].x - left_points[0].x)*t,
                                 (left_points[1].y - left_points[0].y)*t );

    right_pt_step = cvPoint2D32f( (right_points[1].x - right_points[0].x)*t,
                                  (right_points[1].y - right_points[0].y)*t );

    middle_pt_step = cvPoint2D32f( (middle_points[1].x - middle_points[0].x)*t,
                                   (middle_points[1].y - middle_points[0].y)*t );

    t = 1.f/max_len;

    for( i = 0; i < min_len; i++ )
    {
        CvPoint left_pt = cvPoint( cvRound(left_points[0].x*(1 << SHIFT)) + DELTA,
                                   cvRound(left_points[0].y*(1 << SHIFT)) + DELTA),
                right_pt = cvPoint( cvRound(right_points[0].x*(1 << SHIFT)) + DELTA,
                                    cvRound(right_points[0].y*(1 << SHIFT)) + DELTA),
                middle_pt = cvPoint( cvRound(middle_points[0].x*(1 << SHIFT)) + DELTA,
                                     cvRound(middle_points[0].y*(1 << SHIFT)) + DELTA);

        CvPoint left_pt_step2 = cvPoint( cvRound((left_c.x - left_pt.x)*t),
                                         cvRound((left_c.y - left_pt.y)*t)),
                right_pt_step2 = cvPoint( cvRound((right_c.x - right_pt.x)*t),
                                          cvRound((right_c.y - right_pt.y)*t)),
                middle_pt_step2 = cvPoint( cvRound((middle_c.x - middle_pt.x)*t),
                                           cvRound((middle_c.y - middle_pt.y)*t));

        for( j = 0; j < max_len; j++ )
        {
            uchar* left_ptr = left_data + (left_pt.y >> SHIFT)*left_step
                              + (left_pt.x >> SHIFT)*3;
            uchar* right_ptr = right_data + (right_pt.y >> SHIFT)*right_step
                               + (right_pt.x >> SHIFT)*3;
            uchar* middle_ptr = middle_data + (middle_pt.y >> SHIFT)*middle_step
                                + (middle_pt.x >> SHIFT)*3;
            
            int t0, t1, t2;

            t0 = ((left_ptr[0] << ASHIFT) + alpha*(right_ptr[0] - left_ptr[0]) + ADELTA) >> ASHIFT;
            t1 = ((left_ptr[1] << ASHIFT) + alpha*(right_ptr[1] - left_ptr[1]) + ADELTA) >> ASHIFT;
            t2 = ((left_ptr[2] << ASHIFT) + alpha*(right_ptr[2] - left_ptr[2]) + ADELTA) >> ASHIFT;

            middle_ptr[0] = (uchar)t0;
            middle_ptr[1] = (uchar)t1;
            middle_ptr[2] = (uchar)t2;

            left_pt.x += left_pt_step2.x;
            left_pt.y += left_pt_step2.y;
            right_pt.x += right_pt_step2.x;
            right_pt.y += right_pt_step2.y;
            middle_pt.x += middle_pt_step2.x;
            middle_pt.y += middle_pt_step2.y;
        }

        left_points[0].x += left_pt_step.x;
        left_points[0].y += left_pt_step.y;

        right_points[0].x += right_pt_step.x;
        right_points[0].y += right_pt_step.y;

        middle_points[0].x += middle_pt_step.x;
        middle_points[0].y += middle_pt_step.y;
    }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区三区免费大片 | av不卡免费电影| 色一情一乱一乱一91av| 欧美一级欧美一级在线播放| 国产精品国产三级国产aⅴ中文| 日韩vs国产vs欧美| 一本久久a久久精品亚洲| 精品成人一区二区三区| 婷婷综合另类小说色区| 91亚洲永久精品| 久久久99精品久久| 另类中文字幕网| 欧美日韩视频在线一区二区| 国产精品国产三级国产三级人妇 | 成人不卡免费av| 日韩女优电影在线观看| 午夜久久电影网| 色综合久久久久网| 欧美国产日韩a欧美在线观看 | 亚洲综合精品久久| aaa欧美日韩| 国产精品视频一二三区| 国内精品嫩模私拍在线| 日韩免费高清av| 日日摸夜夜添夜夜添亚洲女人| 色婷婷激情久久| 亚洲人吸女人奶水| 91香蕉国产在线观看软件| 中文字幕精品三区| 国产不卡在线一区| 国产欧美视频在线观看| 国产福利一区二区三区| 久久久亚洲午夜电影| 国产一区二区三区综合| 久久久久久久久99精品| 国产美女精品人人做人人爽| 欧美精品一区二区三区四区| 久久99久久久久久久久久久| 日韩一区二区高清| 精品一区二区免费| 国产丝袜欧美中文另类| 国产成人在线看| 国产精品每日更新| 色综合久久88色综合天天免费| 亚洲免费观看高清完整版在线| 欧美综合天天夜夜久久| 亚洲福利国产精品| 日韩欧美中文字幕精品| 国产最新精品免费| 国产精品素人视频| 欧美性猛片xxxx免费看久爱| 日韩高清一区二区| 久久综合久久综合久久| 国产成+人+日韩+欧美+亚洲| 亚洲欧美一区二区三区孕妇| 91成人在线免费观看| 日韩高清不卡一区二区三区| 久久久精品综合| 91麻豆精品一区二区三区| 午夜婷婷国产麻豆精品| 精品剧情v国产在线观看在线| 风流少妇一区二区| 亚洲午夜久久久久久久久电影院| 欧美一级黄色大片| 成人av高清在线| 天堂精品中文字幕在线| 久久久久久久精| 欧洲精品视频在线观看| 国内成人自拍视频| 一区二区三区精品| 久久综合九色欧美综合狠狠| 色综合久久天天综合网| 久久精品国产亚洲一区二区三区| 亚洲欧洲日产国产综合网| 91麻豆精品国产91久久久久久 | 91免费版在线| 热久久久久久久| 亚洲三级免费观看| 欧美r级在线观看| 欧美性猛交一区二区三区精品 | 国产亚洲成av人在线观看导航| 色婷婷久久99综合精品jk白丝| 精品在线观看免费| 亚洲国产精品久久艾草纯爱| 欧美激情一区二区三区不卡| 欧美高清www午色夜在线视频| 白白色亚洲国产精品| 精品夜夜嗨av一区二区三区| 天堂蜜桃91精品| 伊人开心综合网| 欧美国产日韩亚洲一区| 精品国产一区二区三区久久久蜜月 | 日韩精品综合一本久道在线视频| 91亚洲大成网污www| 国产伦精品一区二区三区在线观看 | 欧美日韩一卡二卡三卡 | 欧美日韩国产综合一区二区三区| 国产99久久久国产精品免费看 | 性感美女极品91精品| **性色生活片久久毛片| 久久精品一区蜜桃臀影院| 欧美一区二区三区视频免费| 欧美午夜精品一区二区三区| 99re66热这里只有精品3直播 | 色菇凉天天综合网| 成人h动漫精品一区二| 国产精品99久久久久| 久久99九九99精品| 久久国产精品第一页| 免费观看一级特黄欧美大片| 三级亚洲高清视频| 日韩高清不卡一区二区三区| 午夜av一区二区三区| 亚洲亚洲人成综合网络| 亚洲最大成人综合| 亚洲国产视频一区二区| 亚洲综合色视频| 亚洲成精国产精品女| 日韩制服丝袜av| 免费在线观看视频一区| 麻豆极品一区二区三区| 蜜臀a∨国产成人精品| 老鸭窝一区二区久久精品| 蜜桃一区二区三区在线| 美腿丝袜亚洲三区| 极品少妇一区二区| 国产在线精品一区二区不卡了 | 日韩欧美亚洲国产精品字幕久久久| 欧美日本精品一区二区三区| 51精品国自产在线| 欧美电影精品一区二区| 久久久久久97三级| 国产精品欧美一区喷水| 亚洲美女淫视频| 天堂久久一区二区三区| 国产一区二区视频在线播放| 成人中文字幕电影| 91麻豆精品一区二区三区| 欧美日本在线观看| 久久久精品国产99久久精品芒果| 国产精品丝袜一区| 亚洲综合丝袜美腿| 久久精品国产99国产| 成人黄色在线网站| 欧美在线啊v一区| 日韩久久免费av| 国产精品久久久久久久蜜臀| 亚洲国产日韩一区二区| 国产一区二区三区四区在线观看 | 美女爽到高潮91| 成人黄色一级视频| 欧美丰满少妇xxxxx高潮对白| 久久久精品tv| 亚洲成人动漫精品| 国产成人高清在线| 欧美色视频在线观看| 久久午夜羞羞影院免费观看| 亚洲视频一区在线观看| 麻豆国产精品官网| 日本高清不卡一区| 欧美精品一区二区三区蜜臀| 亚洲一区二区四区蜜桃| 国产精品乡下勾搭老头1| 欧美三级乱人伦电影| 国产农村妇女精品| 日韩电影在线一区| 色综合久久久久| 亚洲国产岛国毛片在线| 日本在线观看不卡视频| 色婷婷激情综合| 亚洲国产精品成人综合| 理论片日本一区| 欧美日韩另类一区| 亚洲人成网站色在线观看| 国产美女精品在线| 日韩一区二区三区免费看| 亚洲一区二区三区四区在线免费观看 | 制服丝袜日韩国产| 亚洲激情图片小说视频| 成人毛片视频在线观看| 欧美成人高清电影在线| 亚洲成人免费在线| 91免费看视频| 国产精品福利av| 粉嫩一区二区三区性色av| 精品国产网站在线观看| 日本不卡高清视频| 3d成人h动漫网站入口| 亚洲国产综合91精品麻豆| 96av麻豆蜜桃一区二区| 中国色在线观看另类| 国产精品系列在线播放| 久久网这里都是精品| 精品无人区卡一卡二卡三乱码免费卡 | www日韩大片| 美女精品自拍一二三四| 欧美精品xxxxbbbb| 肉丝袜脚交视频一区二区| 欧美日韩在线播放一区| 亚洲a一区二区|