青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

eryar

PipeCAD - Plant Piping Design Software.
RvmTranslator - Translate AVEVA RVM to OBJ, glTF, etc.
posts - 603, comments - 590, trackbacks - 0, articles - 0

Visulalization Boost Voronoi in OpenSceneGraph

eryar@163.com

Abstract. One of the important features of the boost polygon library is the implementation of the generic sweepline algorithm to construct Voronoi diagrams of points and linear segments in 2D(developed as part of the Google Summer of Code 2010 program). Voronoi diagram data structure has applications in image segmentation, optical character recognition, nearest neighbor queries execution. It is closely related with the other computational geometry conectps: Delaunay triangulation, medial axis, straight skeleton, the largest empty circle. The paper focus on the usage of Boost.Polygon Voronoi Diagram and visualize it in OpenSceneGraph.

Key words. Voronoi, Boost.Polygon, C++, OpenSceneGraph, Visualization

1. Introduction

計算幾何(Computational Geometry)作為一門學科,起源于20世紀70年代,經過近四十多年的發展,其研究內容不斷擴大,涉及Voronoi圖、三角剖分、凸包、直線與多邊形求交、可見性、路徑規劃、多邊形剖分等內容。據相關統計,在數以千計的相關文章中,約有15%是關于Voronoi圖及其對偶(dual)圖Delaunay三角剖分(Delaunay Triangulation)的研究。由于Voronoi圖具有最近性、鄰接性等眾多性質和比較系統的理論體系,如今已經在計算機圖形學、機械工程、地理信息系統、機器人、圖像處理、大數據分析與處理、生物計算及無線傳感網絡等領域得到了廣泛應用,同時也是解決碰撞檢測、路徑規劃、可見性計算、骨架計算以及凸包計算等計算幾何所涉及的其他問題的有效工具。

Voronoi圖的起源最早可以追溯到17世紀。1644年,Descartes用類似Voronoi圖的結構顯示太陽系中物質的分布。數學家G.L. Dirichlet和M.G.Voronoi分別于1850年和1908年在他們的論文中討論了Voronoi圖的概念,所以Voronoi圖又叫Dirichlet tessellation。在其他領域,這個概念也曾獨立地出現,如生物學和生理學中稱之為中軸變換(Medial Axis Transform)或骨架(Skeleton)。化學與物理學中稱之為Wigner-Seitz Zones,氣象學與地理學中稱之為Thiessen多邊形。Voronoi圖最早由Thiessen應用于氣象觀測站中隨機分布的研究。由于M.G. Voronoi從更通用的n維情況對其進行研究和定義,所以Voronoi圖這個名稱為大多數人所使用。

在路徑規劃、機械加工、模式識別、虛擬現實、生物計算等領域,將站點從離散點擴展到線段圓弧等生成Voronoi圖的方式也是非常常見的。

目前可用于生成Voronoi圖的庫有一些,很多是開源庫。像CGAL庫、boost中也提供了生成Voronoi圖的算法。本文根據Boost.Polygon中的Voronoi庫,并用OpenSceneGraph顯示出剖分結果。

2. Boost.Polygon Voronoi Diagram

Boost.Polygon庫提供了構造Voronoi圖的接口,可根據點集、線段集來生成Voronoi圖,如下圖所示:

wps_clip_image-28950

Figure 2.1 Voronoi Diagram generated by Boost.Polygon Voronoi Algorithms

Boost.Polygon中的基于掃描線算法(sweep-line algorithm)Voronoi庫可以實現如下功能:

v 輸入數據可以是點集和線段;

v 算法的穩定性高及輸出完整的拓樸信息;

v 可以控制輸出的幾何信息的精度;

計算幾何方面以穩定性著稱的CGAL庫中的Voronoi算法只滿足前兩個功能。S-Hull庫以上功能都沒有很好的滿足。下面是一些Boost.Polygon,CGAL,S-Hull庫的對比數據:

wps_clip_image-24820

wps_clip_image-17491

Figure 2.2 Construction time for 10 random points

wps_clip_image-6204

Figure 2.3 Construction time for 100 random points

wps_clip_image-7587

Figure 2.4 Construction time for 1000 random points

wps_clip_image-22652

Figure 2.5 Construction time for 10000 random points

wps_clip_image-7032

Figure 2.6 Memory usage for 100000 random points

wps_clip_image-14814

Figure 2.7 Logarithmic Execution Time

結論:

v 在輸入上沒有限制這點上CGAL要優于Boost.Polygon;

v Boost.Polygon Voronoi的穩定性要高于S-Hull;

v Boost.Polygon Voronoi和S-Hull的時間復雜度為N*log(N),而CGAL的不是;

v Boost.Polygon Voronoi的輸出頂點的精度高于CGAL庫;

v Boost.Polygon Voronoi的速度快;

v Boost.Polygon Voronoi根據10000個點或1000個線段來構造Voronoi的時間為0.02秒以內,所以可用來處理有實時性要求的場景;

3. Implementation

Boost.Polygon的Voronoi算法使用簡單,只需要輸入點集或線段集合,就可以直接構造出Voronoi圖了。最簡單的程序示例代碼如下:

 

/*
*    Copyright (c) 2014 eryar All Rights Reserved.
*
*        File    : Main.cpp
*        Author  : eryar@163.com
*        Date    : 2014-05-06 18:28
*        Version : V1.0
*
*    Description : The Simplest example for boost voronoi library.
*      Key words : boost voronoi, C++
*
*/

#include 
"boost/polygon/voronoi.hpp"

using namespace boost::polygon;

typedef 
int coordinate_type;
typedef point_data
<coordinate_type> Point;
typedef voronoi_diagram
<double> VD;

int main(int argc, char* argv[])
{
    std::vector
<Point> points;

    points.push_back(Point(
00));
    points.push_back(Point(
16));
    points.push_back(Point(
-45));
    points.push_back(Point(
5-1));
    points.push_back(Point(
3-11));
    points.push_back(Point(
13-1));

    VD vd;
    construct_voronoi(points.begin(), points.end(), 
&vd);

    
return 0;
}

且Boost.Polygon的Voronoi算法遍歷Voronoi邊Edges,Voronoi單元cell,Voronoi頂點Vertex也很直接。如下代碼所示為遍歷所有邊,來將剖分結果可視化:

 

/*
*    Copyright (c) 2014 eryar All Rights Reserved.
*
*        File    : Main.cpp
*        Author  : eryar@163.com
*        Date    : 2014-05-06 18:28
*        Version : V1.0
*
*    Description : VoronoiViewer for boost voronoi library visulization.
*      Key words : boost voronoi, C++, OpenSceneGraph
*
*/

#include 
<osgViewer/Viewer>
#include 
<osgGA/StateSetManipulator>
#include 
<osgViewer/ViewerEventHandlers>

#pragma comment(lib, 
"osgd.lib")
#pragma comment(lib, 
"osgDBd.lib")
#pragma comment(lib, 
"osgGAd.lib")
#pragma comment(lib, 
"osgViewerd.lib")


#include 
"boost/polygon/voronoi.hpp"

using namespace boost::polygon;

typedef 
double coordinate_type;
typedef point_data
<coordinate_type> Point;
typedef voronoi_diagram
<coordinate_type> VD;


osg::Node
* BuildVoronoiDiagram(void)
{
    srand(static_cast
<unsigned int> (time(NULL)));

    osg::ref_ptr
<osg::Geode> theGeode = new osg::Geode();
    osg::ref_ptr
<osg::Geometry> theLines = new osg::Geometry();
    osg::ref_ptr
<osg::Vec3Array> theVertices = new osg::Vec3Array();

    VD vd;
    std::vector
<Point> thePoints;

    
// Add points for the Voronoi Diagram.
    for (int i = 0; i < 100++i)
    {
        
int x = rand() % 100;
        
int y = rand() % 100;

        thePoints.push_back(Point(x, y));

        
// Display the site of the Voronoi Diagram.
        theVertices->push_back(osg::Vec3(x - 10.0, y));
        theVertices
->push_back(osg::Vec3(x + 10.0, y));

        theVertices
->push_back(osg::Vec3(x, 0.0, y - 1));
        theVertices
->push_back(osg::Vec3(x, 0.0, y + 1));
    }

    construct_voronoi(thePoints.begin(), thePoints.end(), 
&vd);

    
// Visualize the edge of the Voronoi Diagram.
    
// Traversing Voronoi edges using edge iterator.
    for (VD::const_edge_iterator it = vd.edges().begin(); it != vd.edges().end(); ++it)
    {
        
if (it->is_primary())
        {
            
if (it->is_finite())
            {
                theVertices
->push_back(osg::Vec3(it->vertex0()->x(), 0.0, it->vertex0()->y()));
                theVertices
->push_back(osg::Vec3(it->vertex1()->x(), 0.0, it->vertex1()->y()));
            }
            
else
            {
                Point p1 
= thePoints[it->cell()->source_index()];
                Point p2 
= thePoints[it->twin()->cell()->source_index()];
                Point origin;
                Point direction;
                coordinate_type koef 
= 1.0;

                origin.x((p1.x() 
+ p2.x()) * 0.5);
                origin.y((p1.y() 
+ p2.y()) * 0.5);

                direction.x(p1.y() 
- p2.y());
                direction.y(p2.x() 
- p1.x());

                
if (it->vertex0() == NULL)
                {
                    theVertices
->push_back(osg::Vec3(
                        origin.x() 
- direction.x() * koef, 
                        
0.0,
                        origin.y() 
- direction.y() * koef));
                }
                
else
                {
                    theVertices
->push_back(osg::Vec3(it->vertex0()->x(), 0.0, it->vertex0()->y()));
                }

                
if (it->vertex1() == NULL)
                {
                    theVertices
->push_back(osg::Vec3(
                        origin.x() 
+ direction.x() * koef, 
                        
0.0,
                        origin.y() 
+ direction.y() * koef));
                }
                
else
                {
                    theVertices
->push_back(osg::Vec3(it->vertex1()->x(), 0.0, it->vertex1()->y()));
                }
            }
        }
    }
    
    theLines
->setVertexArray(theVertices);

    
// Set the colors.
    osg::ref_ptr<osg::Vec4Array> theColors = new osg::Vec4Array();
    theColors
->push_back(osg::Vec4(1.0f1.0f0.0f1.0f));

    theLines
->setColorArray(theColors);
    theLines
->setColorBinding(osg::Geometry::BIND_OVERALL);

    
// Set the normal.
    osg::ref_ptr<osg::Vec3Array> theNormals = new osg::Vec3Array();
    theNormals
->push_back(osg::Vec3(0.0f-1.0f0.0f));

    theLines
->setNormalArray(theNormals);
    theLines
->setNormalBinding(osg::Geometry::BIND_OVERALL);

    theLines
->addPrimitiveSet(new osg::DrawArrays(osg::PrimitiveSet::LINES, 0, theVertices->size()));
    
    theGeode
->addDrawable(theLines);

    
return theGeode.release();
}


int main(int argc, char *argv[])
{
    osgViewer::Viewer theViewer;

    theViewer.setSceneData(BuildVoronoiDiagram());
    theViewer.addEventHandler(
new osgGA::StateSetManipulator(theViewer.getCamera()->getOrCreateStateSet()));
    theViewer.addEventHandler(
new osgViewer::StatsHandler);
    theViewer.addEventHandler(
new osgViewer::WindowSizeHandler);

    
return theViewer.run();
}

繪制Voronoi的邊時,當邊是有限的finite時,直接可以畫出直線;當邊是infinite時,根據定義計算出了無界邊的方向。顯示結果如下圖所示:

wps_clip_image-8913

Figure 3.1 Construct Voronoi Diagram by 10 random points by Boost.Polygon

wps_clip_image-27895

Figure 3.2 Construct Voronoi Diagram by 100 random points by Boost.Polygon

4. Conclusion

Boost.Polygon中的Voronoi圖算法穩定性及性能較高,且可以根據站點查找相關的拓樸信息,如根據站點查找Voronoi單元等;惟一不足的就是默認只處理整數點集。

當輸入有線段時,生成的Voronoi圖中有曲線,曲線的繪制可參考相關例子實現。

Boost.Polygon中的Voronoi算法都以模板實現,編譯時只需要包含相關的頭文件即可,不依賴其他庫,使用還是很方便的。

5. References

1. http://www.boost.org/

2. Boost.Polygon,http://www.boost.org/doc/libs/1_55_0/libs/polygon/doc/index.htm

3. Voronoi Basic Tutorial,\boost_1_54_0\libs\polygon\doc\voronoi_basic_tutorial.htm

4. 汪嘉業, 王文平, 屠長河, 楊承磊. 計算幾何及應用. 科學出版社. 2011

5. 楊承磊, 呂琳, 楊義軍, 孟祥旭. Voronoi圖及其應用. 清華大學出版社. 2013

 

Feedback

# re: Visulalization Boost Voronoi in OpenSceneGraph  回復  更多評論   

2014-05-08 10:37 by OpenCASCAE->3D
韋恩圖,在我們地理信息專業也有涉及,真棒,又受教了,哈哈。

# re: Visulalization Boost Voronoi in OpenSceneGraph  回復  更多評論   

2014-05-08 13:11 by eryar
是的,Voronoi圖的作用很大,我也是要學習中,看看能不能應用一下
@OpenCASCAE-&gt;3D
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久久精品国产免大香伊| 国产久一道中文一区| 欧美黑人在线观看| 另类图片综合电影| 免费亚洲电影在线| 久久久久国产免费免费| 久久久久久久久综合| 蜜桃av噜噜一区| 亚洲国产成人av| 欧美国产专区| 在线一区亚洲| 久久av老司机精品网站导航| 久久www成人_看片免费不卡| 久久国产日韩欧美| 欧美日韩亚洲视频| 伊人久久亚洲影院| 一本色道精品久久一区二区三区| 久久gogo国模裸体人体| 欧美aⅴ一区二区三区视频| 亚洲盗摄视频| 香蕉视频成人在线观看| 欧美精品一区二区三区在线看午夜| 国产精品主播| 亚洲香蕉网站| 亚洲福利视频一区二区| 欧美一区91| 亚洲狠狠婷婷| 久久综合九色综合久99| 国产一区二区三区视频在线观看| 中日韩午夜理伦电影免费| 老色批av在线精品| 在线播放精品| 免费亚洲一区二区| 玖玖玖国产精品| 亚洲娇小video精品| 老妇喷水一区二区三区| 欧美一区日本一区韩国一区| 国产精品激情电影| 香港久久久电影| 亚洲欧美清纯在线制服| 国产精品一区二区三区成人| 欧美夜福利tv在线| 欧美在线视频不卡| 在线欧美三区| 99成人在线| 国产欧美日韩亚洲精品| 嫩草国产精品入口| 欧美日韩妖精视频| 欧美中文在线观看| 欧美大尺度在线观看| 亚洲欧美日韩成人| 麻豆成人91精品二区三区| 99re6这里只有精品| 欧美亚洲综合另类| 亚洲午夜精品一区二区三区他趣 | 欧美aⅴ99久久黑人专区| 亚洲欧美日韩国产成人精品影院| 久久久久久久久久久一区| 亚洲精品视频免费| 久久青草欧美一区二区三区| 欧美巨乳在线| 麻豆精品网站| 国产亚洲福利一区| 亚洲一区二区三区四区中文 | 久久久久国产精品麻豆ai换脸| 麻豆亚洲精品| 亚洲丰满在线| 91久久精品视频| 久久国产夜色精品鲁鲁99| 一区二区三区四区五区精品视频| 久久婷婷麻豆| 亚洲国产日韩一区| 一本到高清视频免费精品| 欧美精品一区二区三区一线天视频| 免费日韩av片| 亚洲最新在线视频| 国产精品magnet| 亚洲自拍另类| 久久激情婷婷| 亚洲成色777777在线观看影院| 久久夜色精品国产| 亚洲高清影视| 亚洲综合不卡| 亚洲福利视频一区| 欧美日韩一区二区在线观看视频 | 国产精品99久久99久久久二8| 在线视频亚洲一区| 一区二区三区在线视频观看| 欧美另类专区| 久久精品亚洲热| 亚洲精品在线视频| 乱码第一页成人| 午夜视频久久久| 欧美jizzhd精品欧美巨大免费| 亚洲欧洲一区二区在线播放| 午夜精品视频在线观看一区二区 | 蜜臀av性久久久久蜜臀aⅴ四虎| 日韩一区二区精品视频| 欧美 日韩 国产 一区| 一区二区三区av| 亚洲高清不卡av| 国产精品一区二区三区乱码| 国产精品sss| 欧美午夜一区二区三区免费大片| 欧美成人国产| 欧美激情第4页| 欧美日韩免费在线| 欧美天天综合网| 国产精品超碰97尤物18| 欧美日韩一级片在线观看| 欧美日韩国产电影| 欧美午夜精品久久久久久浪潮| 欧美日韩精品一本二本三本| 欧美精品一区二区蜜臀亚洲| 欧美成人免费在线| 欧美日韩精品二区| 欧美日韩免费一区| 狠狠色丁香婷婷综合影院| 亚洲福利视频网站| 亚洲午夜视频在线| 久久精品一区| 亚洲日本欧美天堂| 午夜精品久久久久久久99樱桃| 亚洲午夜未删减在线观看| 午夜精品理论片| 蜜臀久久99精品久久久画质超高清 | 国产日韩亚洲欧美综合| 国产资源精品在线观看| 亚洲国产日韩一级| 欧美一区2区三区4区公司二百| 免费国产自线拍一欧美视频| 一本色道久久综合亚洲精品不 | 欧美日韩黄视频| 国产综合色产在线精品| 亚洲免费电影在线| 久久久亚洲欧洲日产国码αv| 亚洲电影天堂av| 久久成人精品视频| 美女精品视频一区| 国产在线国偷精品产拍免费yy| 夜夜嗨av色一区二区不卡| 久久亚洲私人国产精品va| 亚洲一区二区av电影| 欧美日韩一区二区国产| 日韩一区二区精品视频| 亚洲福利电影| 欧美日韩精品一区二区天天拍小说| 欲香欲色天天天综合和网| 久久激情中文| 羞羞色国产精品| 国产精品日韩精品欧美在线 | 国产精品视频久久久| 亚洲小视频在线观看| 一本色道久久综合精品竹菊| 欧美日韩国产在线一区| 亚洲天堂网站在线观看视频| 亚洲国产女人aaa毛片在线| 免费久久精品视频| 亚洲精品欧洲| 91久久精品美女| 欧美视频三区在线播放| 欧美一区二区视频观看视频| 欧美中文字幕在线观看| 18成人免费观看视频| 亚洲日本激情| 影音先锋日韩精品| 一本综合精品| 在线国产日韩| 亚洲视频网站在线观看| 亚洲国产精品v| 亚洲小视频在线观看| 亚洲国产日韩欧美在线99| 9i看片成人免费高清| 在线播放不卡| 亚洲国产婷婷香蕉久久久久久99| 一区二区日韩伦理片| 国产综合精品| 久久久91精品国产一区二区三区| 99亚洲一区二区| 美女脱光内衣内裤视频久久影院 | 久久er精品视频| 亚洲视频碰碰| 久久理论片午夜琪琪电影网| 亚洲国产精品热久久| 欧美久久久久| 美国十次成人| 亚洲国产精品黑人久久久| 久久精品人人做人人综合| 久久精品国产亚洲一区二区三区| 欧美三日本三级少妇三99| 亚洲欧洲日本一区二区三区| 亚洲人成在线观看| 欧美日韩在线视频观看| 亚洲午夜羞羞片| 欧美/亚洲一区| 宅男精品视频| 欧美日韩国产91| 欧美亚洲一区二区在线观看| 亚洲国产日韩一区| 久久综合久久久久88|