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

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

?? lucas_kanade.m

?? Lucas_Kanade光流算法產(chǎn)生光流場
?? M
字號:
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%%  Name: Musawir Ali Shah
%%%  Assignment #3
%%%  Project Title: Lucas Kanade Motion Estimation Using Pyramids (Level 4)
%%%  Note: The project specification says use density of 10 in plotting
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

%%% Usage: Lucas_Kanade('1.bmp','2.bmp',10)

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function Lucas_Kanade(file1,file2,density);
%% Read Images %%
img1 = im2double (imread (file1));
%% Take alternating rows and columns %%
[odd1, even1] = split (img1);
img2 = im2double (imread (file2));
[odd2, even2] = split (img2);
%% Run Lucas Kanade %%
[Dx, Dy] = Estimate (odd1, odd2);
%% Plot %%
figure; 
[maxI,maxJ]=size(Dx);
Dx=Dx(1:density:maxI,1:density:maxJ);
Dy=Dy(1:density:maxI,1:density:maxJ);
quiver(1:density:maxJ,(maxI):(-density):1,Dx,-Dy,1);
axis square;


%% Run Lucas Kanade on all levels and interpolate %%
function [Dx, Dy] = Estimate (img1, img2)
level = 4;
half_window_size=2;
[m, n] = size (img1);
G00 = img1; G10 = img2;
if (level>0)
    G01 = reduce (G00); G11 = reduce (G10);
end
if (level>1)
    G02 = reduce (G01); G12 = reduce (G11);
end
if (level>2)
    G03 = reduce (G02); G13 = reduce (G12);
end
if (level>3)
    G04 = reduce (G03); G14 = reduce (G13);
end
l = level;

for i=level:-1:0,
    if (l == level)
        switch (l)
        case 4, Dx = zeros (size (G04)); Dy = zeros (size (G04));
        case 3, Dx = zeros (size (G03)); Dy = zeros (size (G03));
        case 2, Dx = zeros (size (G02)); Dy = zeros (size (G02));
        case 1, Dx = zeros (size (G01)); Dy = zeros (size (G01));
        case 0, Dx = zeros (size (G00)); Dy = zeros (size (G00));
        end
    else
        Dx = expand (Dx); Dy = expand (Dy);
        Dx = Dx .* 2; Dy = Dy .* 2;
    end
    switch (l)
    case 4, 
        W = warp (G04, Dx, Dy); 
        [Vx, Vy] = EstimateMotion (W, G14, half_window_size);
    case 3, 
        W = warp (G03, Dx, Dy); 
        [Vx, Vy] = EstimateMotion (W, G13, half_window_size);
    case 2, 
        W = warp (G02, Dx, Dy); 
        [Vx, Vy] = EstimateMotion (W, G12, half_window_size);
    case 1, 
        W = warp (G01, Dx, Dy); 
        [Vx, Vy] = EstimateMotion (W, G11, half_window_size);
    case 0, 
        W = warp (G00, Dx, Dy); 
        [Vx, Vy] = EstimateMotion (W, G10, half_window_size);
    end
    [m, n] = size (W);
    Dx(1:m, 1:n) = Dx(1:m,1:n) + Vx; Dy(1:m, 1:n) = Dy(1:m, 1:n) + Vy;
    smooth (Dx); smooth (Dy);
    l = l - 1;
end


%% Lucas Kanade on the image sequence at pyramid step %%
function [Vx, Vy] = EstimateMotion (W, G1, half_window_size)
[m, n] = size (W);
Vx = zeros (size (W)); Vy = zeros (size (W));
N = zeros (2*half_window_size+1, 5);
for i = 1:m,
    l = 0;
    for j = 1-half_window_size:1+half_window_size,
        l = l + 1;
        N (l,:) = getSlice (W, G1, i, j, half_window_size);
    end
    replace = 1;    
    for j = 1:n, 
        t = sum (N);
        [v, d] = eig ([t(1) t(2);t(2) t(3)]);
        namda1 = d(1,1); namda2 = d(2,2);
        if (namda1 > namda2) 
            tmp = namda1; namda1 = namda2; namda2 = tmp;
            tmp1 = v (:,1); v(:,1) = v(:,2); v(:,2) = tmp1;
        end
        if (namda2 < 0.001)
            Vx (i, j) = 0; Vy (i, j) = 0;
        elseif (namda2 > 100 * namda1)
            n2 = v(1,2) * t(4) + v(2,2) * t(5);
            Vx (i,j) = n2 * v(1,2) / namda2;
            Vy (i,j) = n2 * v(2,2) / namda2;
        else
            n1 = v(1,1) * t(4) + v(2,1) * t(5);
            n2 = v(1,2) * t(4) + v(2,2) * t(5);
            Vx (i,j) = n1 * v(1,1) / namda1 + n2 * v(1,2) / namda2;
            Vy (i,j) = n1 * v(2,1) / namda1 + n2 * v(2,2) / namda2;
        end
        N (replace, :) = getSlice (W, G1, i, j+half_window_size+1, half_window_size);
        replace = replace + 1;
        if (replace == 2 * half_window_size + 2) 
            replace = 1;
        end
    end
end


%% The Reduce Function for pyramid %%
function result = reduce (ori)
[m,n] = size (ori);
mid = zeros (m, n);
m1 = round (m/2); n1 = round (n/2);
result = zeros (m1, n1);
w = generateFilter (0.4);
for j=1:m,
   tmp = conv([ori(j,n-1:n) ori(j,1:n) ori(j,1:2)], w);
   mid(j,1:n1) = tmp(5:2:n+4);
end
for i=1:n1,
   tmp = conv([mid(m-1:m,i); mid(1:m,i); mid(1:2,i)]', w);
   result(1:m1,i) = tmp(5:2:m+4)';
end

%% The Expansion Function for pyramid %%
function result = expand (ori)   
[m,n] = size (ori);
mid = zeros (m, n);
m1 = m * 2; n1 = n * 2;
result = zeros (m1, n1);
w = generateFilter (0.4);
for j=1:m,
   t = zeros (1, n1);
   t(1:2:n1-1) = ori (j,1:n);
   tmp = conv ([ori(j,n) 0 t ori(j,1) 0], w);
   mid(j,1:n1) = 2 .* tmp (5:n1+4); 
end
for i=1:n1,
   t = zeros (1, m1);
   t(1:2:m1-1) = mid (1:m,i)'; 
   tmp = conv([mid(m,i) 0 t mid(1,i) 0], w);
   result(1:m1,i) = 2 .* tmp (5:m1+4)';
end

function filter = generateFilter (alpha)
filter = [0.25-alpha/2 0.25 alpha 0.25 0.25-alpha/2];

function [N] = getSlice (W, G1, i, j, half_window_size)
N = zeros (1, 5);
[m, n] = size (W);
for y=-half_window_size:half_window_size,
    Y1 = y +i;
    if (Y1 < 1)
        Y1 = Y1 + m;
    elseif (Y1 > m)
        Y1 = Y1 - m;
    end
    X1 = j;
    if (X1 < 1)
        X1 = X1 + n;
    elseif (X1 > n)
        X1 = X1 - n;
    end
    DeriX = Derivative (G1, X1, Y1, 'x'); DeriY = Derivative (G1, X1, Y1, 'y');
    N = N + [ DeriX * DeriX, ...
        DeriX * DeriY, ...
        DeriY * DeriY, ...
        DeriX * (G1 (Y1, X1) - W (Y1, X1)), ...
        DeriY * (G1 (Y1, X1) - W (Y1, X1))];
end

function result = smooth (img) 
result = expand (reduce (img));

function [odd, even] = split (img);
[m, n] = size (img);
odd = img (1:2:m, :);
even = img (2:2:m, :);

%% Interpolation %%
function result = warp (img, Dx, Dy)
[m, n] = size (img);
[x,y] = meshgrid (1:n, 1:m);
x = x + Dx (1:m, 1:n); y = y + Dy (1:m,1:n);
for i=1:m,
    for j=1:n,
        if x(i,j)>n
            x(i,j) = n;
        end
        if x(i,j)<1
            x(i,j) = 1;
        end
        if y(i,j)>m
            y(i,j) = m;
        end
        if y(i,j)<1
            y(i,j) = 1;
        end
    end
end
result = interp2 (img, x, y, 'linear');

%% Calculates the Fx Fy %%
function result = Derivative (img, x, y, direction)
[m, n] = size (img);
switch (direction)
case 'x', 
    if (x == 1)
        result = img (y, x+1) - img (y, x);
    elseif (x == n)
        result = img (y, x) - img (y, x-1);
    else
        result = 0.5 * (img (y, x+1) - img (y, x-1));
    end
case 'y', 
    if (y == 1)
        result = img (y+1, x) - img (y, x);
    elseif (y == m)
        result = img (y, x) - img (y-1, x);
    else 
        result = 0.5 * (img (y+1, x) - img (y-1, x));
    end
end

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产欧美一区二区精品忘忧草| 一区二区三区四区中文字幕| ...av二区三区久久精品| 亚洲一区二区在线观看视频| 另类专区欧美蜜桃臀第一页| 色婷婷精品大视频在线蜜桃视频| 日韩亚洲欧美综合| 亚洲综合久久av| 成人app在线观看| 欧美v亚洲v综合ⅴ国产v| 亚洲一区二区三区在线播放| 国产一区二区伦理片| 7777精品伊人久久久大香线蕉经典版下载 | 久久久午夜精品| 亚洲国产成人av| 成人免费福利片| 久久天天做天天爱综合色| 午夜欧美大尺度福利影院在线看| 成人av电影免费在线播放| 337p日本欧洲亚洲大胆精品| 日韩精品亚洲一区| 色噜噜久久综合| 国产精品久久久久aaaa樱花| 韩国欧美国产1区| 337p亚洲精品色噜噜狠狠| 亚洲最大成人网4388xx| 99久久精品99国产精品| 中文字幕欧美激情一区| 国产高清无密码一区二区三区| 26uuu色噜噜精品一区| 久久国产精品72免费观看| 91精品国产91综合久久蜜臀| 日韩国产欧美在线播放| 91精品婷婷国产综合久久| 日本视频一区二区三区| 欧美一级一级性生活免费录像| 亚洲一级电影视频| 99久久精品费精品国产一区二区| 亚洲欧洲在线观看av| 99精品国产视频| 亚洲免费av网站| 99免费精品在线观看| 国产午夜三级一区二区三| 亚洲超碰97人人做人人爱| 国产成人av电影在线观看| 精品久久久久久无| 久久成人精品无人区| 在线播放日韩导航| 免费观看30秒视频久久| 精品国产一区二区三区久久影院 | 欧美色偷偷大香| 日韩av一区二| 欧美精品一区二区久久婷婷| 国产麻豆一精品一av一免费| 国产欧美日韩综合精品一区二区| 丁香婷婷综合色啪| 亚洲天天做日日做天天谢日日欢 | 91在线一区二区三区| 亚洲人123区| 91精品国产综合久久小美女| 激情欧美一区二区| 国产女同互慰高潮91漫画| 99久久久久久99| 日本最新不卡在线| 日本一区二区三区在线不卡| eeuss鲁片一区二区三区在线观看| 国产精品不卡视频| 欧美高清精品3d| 亚洲成人av资源| 日韩欧美另类在线| 偷拍与自拍一区| 日韩欧美色综合| 国产成人av电影免费在线观看| 18欧美亚洲精品| 欧美日韩综合色| 国产精品亚洲一区二区三区妖精| 一区二区三区美女视频| 日韩你懂的在线播放| 91在线观看成人| 九一九一国产精品| 一区二区三区国产| 国产午夜精品理论片a级大结局| 欧美亚洲国产一区二区三区va| 狠狠色狠狠色综合日日91app| 亚洲乱码国产乱码精品精小说 | 欧美电影一区二区| 不卡一区在线观看| 蜜桃av一区二区在线观看| 亚洲女与黑人做爰| 国产精品欧美综合在线| 欧美一区二区三区电影| 色一情一乱一乱一91av| 丁香六月综合激情| 久久机这里只有精品| 日韩和欧美一区二区三区| 亚洲欧美电影院| 一区在线中文字幕| 中文成人综合网| 久久久久久久综合日本| 91精品国产麻豆| 欧美日韩成人激情| 欧美专区亚洲专区| 色婷婷av一区| 91片黄在线观看| 91在线视频网址| 99久久99久久久精品齐齐| 成人手机在线视频| 国产成人精品www牛牛影视| 国产一区二区三区香蕉| 久久精品国产在热久久| 青娱乐精品视频在线| 日本成人超碰在线观看| 天天影视涩香欲综合网 | 国产精品亚洲成人| 国产呦萝稀缺另类资源| 久久成人久久爱| 国产一区二区三区黄视频| 韩国欧美国产一区| 国产99精品国产| 国产超碰在线一区| 91网站最新地址| 欧洲一区二区三区在线| 欧美久久婷婷综合色| 日韩免费观看高清完整版在线观看| 日韩欧美黄色影院| 久久久久亚洲综合| 成人免费在线观看入口| 一区二区激情小说| 日韩精品一区第一页| 久久99久久精品| www.亚洲精品| 色婷婷av一区二区三区大白胸| 欧美顶级少妇做爰| 久久女同精品一区二区| 中文字幕在线观看不卡视频| 亚洲电影视频在线| 蜜臀av一区二区在线观看| 国产精品亚洲第一| 91精品1区2区| 欧美α欧美αv大片| 欧美激情中文字幕| 亚洲大片精品永久免费| 捆绑紧缚一区二区三区视频| 国产一区日韩二区欧美三区| 成人禁用看黄a在线| 91福利区一区二区三区| 欧美日本一区二区三区| 欧美性色aⅴ视频一区日韩精品| 精品捆绑美女sm三区| 国产午夜精品久久| 亚洲三级在线免费| 天堂久久一区二区三区| 美国三级日本三级久久99| 国产精品一品二品| 日本精品一级二级| 精品国产成人在线影院| 国产精品国产馆在线真实露脸| 亚洲精品乱码久久久久久久久| 亚洲尤物视频在线| 高清成人在线观看| 欧美图片一区二区三区| 精品久久国产字幕高潮| 亚洲在线免费播放| 国产综合色产在线精品| 97se亚洲国产综合自在线观| 欧美日韩精品欧美日韩精品| 国产精品视频麻豆| 午夜欧美视频在线观看| 国产成人在线视频免费播放| 91精品1区2区| 日韩一区在线看| 免费在线观看一区| 91美女在线视频| 国产婷婷色一区二区三区四区| 亚洲一区二区中文在线| 成人网在线播放| 精品国产3级a| 亚洲免费在线电影| 成人免费va视频| 91精品一区二区三区久久久久久| 18涩涩午夜精品.www| 日本午夜精品一区二区三区电影| jlzzjlzz亚洲女人18| 欧美一区二区三区四区久久| 中文字幕一区在线观看视频| 国产91精品在线观看| 日韩午夜三级在线| 亚洲一区二区视频在线| 精品综合久久久久久8888| 欧美一区二区三区四区高清| 一区二区三区四区高清精品免费观看| 国产乱人伦偷精品视频不卡| 欧美亚洲一区二区三区四区| 中文字幕在线免费不卡| 粉嫩av一区二区三区在线播放| 欧美日韩激情一区| 天堂av在线一区| 欧美丝袜丝nylons| 亚洲欧美在线视频观看| 日本伦理一区二区|