<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
目錄hw1下的影象是一些膠片的照片,請將其進行度量矯正。
推薦流程:採用Canny運算元,檢測邊緣點;採用Hough直線檢測,根據邊緣點檢測膠片邊緣對應的4條直線;4條直線在影象平面中的交點為膠片影象的4個頂點。根據4個頂點與真實世界中膠片的位置(假設膠片影象長寬比為4:3),得到兩個平面之間的單應變換矩陣,並根據單應變換矩陣實現影象矯正。
使用Canny運算元,檢測邊緣點;以邊緣點作為輸入,採用Hough直線檢測,檢測出最多點共線的四條直線,這四條直線的交點就是照片中螢幕的四個頂點;假設膠片影象長寬比為4:3,那麼此時已知四個匹配的點,可以求解出兩個平面之間的單應變換矩陣;從而可以使用原影象、單應變換矩陣,對原影象進行變換,即可實現影象矯正。實現紀錄檔
Canny邊緣檢測:Python OpenCV Canny邊緣檢測演演算法的原理實現詳解
Hough直線檢測:Python OpenCV Hough直線檢測演演算法的原理實現
在具體實現時,發現對於給定的影象,幾乎不可能通過調整閾值的方式,使得Hough檢測到的直線剛好是螢幕邊框。經過多輪調整,在下界為180、上界為260時取得了較為理想的結果,
如下圖所示:
對於三張影象,經過實驗,最終選擇的最佳閾值為:
correct('images/1.jpeg', 180, 260) correct('images/2.jpeg', 30, 100) correct('images/3.jpeg', 100, 160)
但即便是最佳閾值,也無法做到僅檢測出四條線。思考過後,決定加入一步人工篩選。
有兩種可行的技術方案:
考慮到如果篩選交點的話,工作量明顯比篩選直線更大,所以選擇人工篩選直線。後面有時間的話考慮加入圖形化介面,目前因時間原因,選擇專注於演演算法本身,暫不考慮視覺化程式設計。
直接顯示出下圖用於篩選:
這裡符合條件的直線id為2、3、6、7。
求解得到的交點:
我們假設目標影象是4:3的,也就是其大小為(800, 600),從而我們可以確定目標影象中四個關鍵點位置為[0, 0], [800, 0], [0, 600], [800, 600]。為了保證交點與目標點一一對應,最為高效的解決方案是,我們篩選影象的時候,按照上、左、下、右的順序即可。
def correct(image_path, threshold1, threshold2): # 讀取影象並轉換為灰度影象 image = cv2.imread(image_path) gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY) # 使用Canny運算元檢測邊緣 edges = canny_detect(gray, threshold1, threshold2, show=False) # 使用Hough檢測直線 lines = hough_detect(image, edges, show=False) # 手動篩選 for id, line in enumerate(lines): rho, theta = line[0] x1, y1, x2, y2 = convert_polar_to_two_points(rho, theta) temp_image = image.copy() cv2.line(temp_image, (x1, y1), (x2, y2), (255, 0, 0), 7) plt.subplot(5, 5, id + 1) plt.imshow(temp_image) plt.title('{}'.format(id)) plt.xticks([]) plt.yticks([]) plt.show() choose = input('請輸入您選擇的直線的id,以空格分隔:').split(' ') # 求解交點 crossover_points = [] assert len(choose) == 4 for i in range(4): for j in range(i+1, 4): rho1, theta1 = lines[int(choose[i])][0] rho2, theta2 = lines[int(choose[j])][0] # 如果角度差太小,認為它們是平行線 if abs(theta2 - theta1) > np.pi / 8 and abs(theta2 - theta1) < np.pi * 7 / 8: crossover_points.append(cal_crossover(rho1, theta1, rho2, theta2)) # 確定變換前後的座標 before = np.float32(crossover_points) after = np.float32([[0, 0], [800, 0], [0, 600], [800, 600]]) # 單應變換 h = cv2.getPerspectiveTransform(before, after) result = cv2.warpPerspective(image, h, (800, 600)) cv2.imwrite(image_path.split('.')[0] + '_correct.jpeg', result) return result
矯正結果:
到此這篇關於Python OpenCV 影象矯正的原理實現的文章就介紹到這了,更多相關Python OpenCV 影象矯正內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45