深度圖壓縮之-高低8位拆分保存

?使用kinect相機保存數據,為了減少保存的數據集量,對圖像進行壓縮。將彩色圖像直接壓縮成.mp4格式,此時圖像上的一些高頻信息會被損失掉。

為了能夠讓深度圖有比較高的保真度,減少深度圖上高頻信息的損失,我們將16位的深度圖,分成高8位和第8位,將低8位保存成mp4視頻的形式

將高8位直接保存成單通道的深度圖。

下面的函數實現了將一幅CV_16UC1類型的深度圖拆分成高8位和低8位,并且將低8位的數據寫入三通道的圖像中,便于壓縮為mp4格式。

int depth2HighLow(cv::Mat Full_Depth, cv::Mat &High_Depth, cv::Mat &Low_Depth)
{if (Full_Depth.type() != CV_16UC1){std::cout << "the input depth must be CV_16UC1" << std::endl;return false;}uint16_t* Pdepth = Full_Depth.ptr<uint16_t>(0);uchar* Phigh = High_Depth.data;uchar* Plow = Low_Depth.data;for (int i = 0; i < Full_Depth.cols*Full_Depth.rows; i++){*Phigh = (*Pdepth) >> 8;Phigh++;*Plow = (*Pdepth) & 0xff;Plow++;*Plow = (*Pdepth) & 0xff;Plow++;*Plow = (*Pdepth) & 0xff;Plow++;Pdepth++;}return true;
}

我們在使用深度圖時,需要將高8位和第8位再組合到一起。

void Gray2uint16(cv::Mat High,cv::Mat low,cv::Mat &Depth)
{uint16_t *Pdepth=Depth.ptr<uint16_t>(0);uchar *Phigh=High.data;uchar *Plow=low.data;for (size_t i = 0; i < High.cols*High.rows; i++){*Pdepth=uint16_t((uint16_t(*Phigh)<<8)+(*Plow));Pdepth++;Phigh++;Plow++;}}

?下面是關于讀取視頻的相關代碼

int main ( int argc, char** argv )
{std::string dataset_folder = std::string(argv[3]);std::string depth_color_video = dataset_folder + "/" + "color_depth.mp4";std::string high_depth_images = dataset_folder + "/" + "color_depth/";cv::VideoCapture cap(depth_color_video);if(!cap.isOpened()){std::cout<<"opencv mp4 file failed"<<std::endl;return false;}bool have_data = true;int framenum = 0;while(have_data){cv::Mat ImgRead;cap>>ImgRead;if(ImgRead.empty()){std::cout<<"read finished"<<std::endl;have_data = false;continue;}cv::Mat Color_img, Low_depth;cv::Rect rgb_rect(0, 0, ImgRead.cols/2, ImgRead.rows);cv::Rect low_depth_rect(ImgRead.cols/2, 0, ImgRead.cols/2, ImgRead.rows);ImgRead(rgb_rect).copyTo(Color_img);ImgRead(low_depth_rect).copyTo(Low_depth);// cv::imshow("Color_img", Color_img);// cv::imshow("low_depth", Low_depth);// cv::waitKey(2);//read the high depth imagesstd::string HighPath = high_depth_images + "/" + std::to_string(framenum) + ".png";cv::Mat High_depth = cv::imread(HighPath, cv::IMREAD_UNCHANGED);std::cout<<"frame name: "<<HighPath<<std::endl;// cv::imshow("high_depth", High_depth);// cv::waitKey(2);cv::Mat Low_gray;//the type of Low_depth is 8UC3, we change it into 8UC1cv::cvtColor(Low_depth, Low_gray, cv::COLOR_BGR2GRAY);cv::Mat full_depth_gray(Low_gray.size(), CV_16UC1);Gray2uint16(High_depth, Low_gray, full_depth_gray);// cv::imshow("full_depth", full_depth_gray);// cv::waitKey(2);framenum++;}return 0;
}

?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/252326.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/252326.shtml
英文地址,請注明出處:http://en.pswp.cn/news/252326.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

linux 一個超簡單的makefile

2019獨角獸企業重金招聘Python工程師標準>>> makefile 自動化變量&#xff1a; $ : 規則的目標文件名 例如&#xff1a;main:main.o test.o g -Wall -g main.o test.o -o main 可以寫成&#xff1a; main:main.o test.o g -Wall -g main.o test.o -o $ $< : …

poj2480(利用歐拉函數的積性求解)

題目鏈接: http://poj.org/problem?id2480 題意&#xff1a;∑gcd(i, N) 1<i <N&#xff0c;就這個公式&#xff0c;給你一個n&#xff0c;讓你求sumgcd(1,n)gcd(2,n)gcd(3,n)…………gcd(n-1,n)gcd(n,n),&#xff08;1<n<2^31&#xff09;是多少&#xff1f; 放…

跨域問題

一、為什么會有跨域問題&#xff1f; 是因為瀏覽器的同源策略是對ajax請求進行阻攔了&#xff0c;但是不是所有的請求都給做跨域&#xff0c;像是一般的href屬性&#xff0c;a標簽什么的都不攔截。 二、解決跨域問題的兩種方式 JSONPCORS 三、JSONP 先簡單來說一下JSONP&#x…

PAT A1052

這個需要注意的是相關的string轉整數或者double的函數&#xff1b;詳見這個鏈接blog #include <iostream> #include <string> using namespace std; bool isPrime(int n) {if (n 0 || n 1) return false;for (int i 2; i * i < n; i)if (n % i 0) return fa…

php審計學習:xdcms2.0.8注入

注入點Fields: 注冊頁面會引用如下方法: $fields 變量是從 $fields$_POST[fields]; 這里獲取&#xff0c; 在代碼里沒有過濾。 打印 fields 數據查看: 從代碼上看 $field_sql.",{$k}{$f_value}"; 最終會變成: ,truename111111,email12345 因為 $field_sql 最終會引入…

windows下安裝python和Python-opencv

背景&#xff1a;目前基于python的圖像處理和機器視覺的研究還挺多&#xff0c;最近不是在研究目標檢測和目標跟蹤的算法&#xff0c;由于檢測和跟蹤的環境比較簡單所以從不帶學習的跟蹤方法&#xff0c;在搜索資料時搜到這個網站&#xff0c;是對opencv中的目標跟蹤算法的一個…

捋一捋js面向對象的繼承問題

說到面向對象這個破玩意&#xff0c;曾經一度我都處于很懵逼的狀態&#xff0c;那么面向對象究竟是什么呢&#xff1f;其實說白了&#xff0c;所謂面向對象&#xff0c;就是基于類這個概念&#xff0c;來實現封裝、繼承和多態的一種編程思想罷了。今天我們就來說一下這其中繼承…

java8簡單入門

1、介紹 本片文章會從一下幾個知識點進行介紹&#xff1a; 函數式接口 FunctionalInterfaceLambda 表達式函數引用 Function ReferenceStream看了幾篇關于 java8 入門的例子&#xff0c;其中引入了許多令人期待已久的特性&#xff08;雖然我沒有過這樣的體會&#xff09;&#…

玩轉帶外觸發的單目相機之一

背景&#xff1a;去年開始研究vins,但是只是用了普通的相機&#xff0c;然后將IMU和相機粘在一起&#xff0c;然后就是聯合標定相機和IMU。VINS使用的相機是帶有外觸發的&#xff0c;還進行了相機和IMU的硬件時間同步。當時我特別想買個帶外觸發的相機&#xff0c;一直沒找到資…

基于django的視頻點播網站開發-step11-后臺用戶管理功能...

用戶管理功能&#xff0c;包含用戶添加、列表展示、編輯、刪除四大功能。下面我們一一揭曉。 用戶添加 我們先實現用戶添加功能&#xff0c;我們現在urls.py下添加相關的路由 path(user_add/, views.UserAddView.as_view(), nameuser_add), path(user_list/, views.UserListVie…

BZOJ 1070 拆點 費用流

1070: [SCOI2007]修車 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 5860 Solved: 2487[Submit][Status][Discuss]Description 同一時刻有N位車主帶著他們的愛車來到了汽車維修中心。維修中心共有M位技術人員&#xff0c;不同的技術人員對不同 的車進行維修所用的時間是不…

分布式之數據庫和緩存雙寫一致性方案解析

先做一個說明&#xff0c;從理論上來說&#xff0c;給緩存設置過期時間&#xff0c;是保證最終一致性的解決方案。這種方案下&#xff0c;我們可以對存入緩存的數據設置過期時間&#xff0c;所有的寫操作以數據庫為準&#xff0c;對緩存操作只是盡最大努力即可。也就是說如果數…

使用python從csv文件中讀入兩列擬合直線

背景&#xff1a;要判斷跟蹤算法在控制目標物走直線的情況下跟蹤的軌跡是否為直線&#xff0c;我保存下來跟蹤算法跟蹤到的目標的中心點在圖像上的像素位置&#xff0c;然后擬合出穿過這些點的直線&#xff0c;然后計算這些點距離直線的平均距離來判斷跟蹤的精度。&#xff08;…

window document

1 打開一個新窗口 var newDocwindow.open("text/html","replace");var txt"<html><body>Learning about the DOM is FUN!</body></html>";newDoc.document.write(txt);newDoc.close(); //該方法將關閉 open() 方法打開…

‘(‘:illegal token on right side of ‘::‘

背景&#xff1a;想整理升級一下代碼&#xff0c;添加了兩個類&#xff0c;再一編譯代碼&#xff0c;出現了好多這樣的錯誤提示“(:illegal token on right side of ::”&#xff0c;我很納悶這是啥問題&#xff0c;我就使用“注釋法”來定位出錯的位置&#xff0c;我發現把所有…

mysql-數據庫操作

doc界面操作mysql:<br/> 以phpstudy為例 登錄數據庫&#xff1a;進入phpstudy/mysql/bin下&#xff0c;mysql -u用戶名 -p密碼 選擇數據庫&#xff1a;use 數據庫名; 設置編碼格式&#xff1a;set names gbk; 查看表結構或字段信息&#xff1a;desc 表名; 建立數據庫&…

虹軟免費人臉識別SDK注冊指南

2019獨角獸企業重金招聘Python工程師標準>>> 成為開發者三步完成賬號的基本注冊與認證&#xff1a; STEP1:點擊注冊虹軟AI開放平臺右上角注冊選項&#xff0c;完成注冊流程。 STEP2:首次使用&#xff0c;登錄后進入開發者中心&#xff0c;點擊賬號管理完成企業或者個…

Mybatis使用statementType=STATEMENT實現動態傳入表名或字段名

mybatis中使用statementType"STATEMENT"實現動態傳入字段名時一直報語句錯誤&#xff0c;但實際上語句并沒有毛病&#xff0c;爬了一天坑才找到問題&#xff0c;記錄一下。 整條語句中里所有傳入的值都要使用${xxx},不能使用#{xxx}。 <select id"listMap&quo…

C++中的類加多線程代碼修煉

背景&#xff1a;現在在做一個目標跟蹤的項目&#xff0c;需要實時的從工業相機中獲取圖像&#xff0c;然后再跟蹤圖像上的目標物&#xff0c;由于起初為了測試跟蹤算法&#xff0c;就把“從相機獲取圖像”和“跟蹤處理”都放在了主線程中&#xff0c;在實際測試時&#xff0c;…

Activity Monitor 閃退 無法進入睡眠

Activity Monitor 閃退 & 無法進入睡眠 情況描述 黑蘋果?主機突然無法進入睡眠。 考慮到可能是后臺程序阻礙了系統正常進入睡眠&#xff0c; 于是想要通過Activity Monitor查看系統的活動情況&#xff0c;然而&#xff0c;Activity Monitor閃退。 重新開機&#xff0c;快速…