A Generic Platform for Processing 3D Meshes and Point Clouds Vincent Vidal, Eric Lombardi, Martial Tola, Florent Dupont, Guillaume Lavoué

A Generic Platform for Processing 3D Meshes and Point Clouds Vincent Vidal, Eric Lombardi, Martial Tola, Florent Dupont, Guillaume Lavoué

MEPP2: a generic platform for processing 3D meshes and point clouds Vincent Vidal, Eric Lombardi, Martial Tola, Florent Dupont, Guillaume Lavoué To cite this version: Vincent Vidal, Eric Lombardi, Martial Tola, Florent Dupont, Guillaume Lavoué. MEPP2: a generic platform for processing 3D meshes and point clouds. EUROGRAPHICS 2020 (Short Paper), May 2020, Norrköping, Sweden. hal-02611582 HAL Id: hal-02611582 https://hal.archives-ouvertes.fr/hal-02611582 Submitted on 19 May 2020 HAL is a multi-disciplinary open access L’archive ouverte pluridisciplinaire HAL, est archive for the deposit and dissemination of sci- destinée au dépôt et à la diffusion de documents entific research documents, whether they are pub- scientifiques de niveau recherche, publiés ou non, lished or not. The documents may come from émanant des établissements d’enseignement et de teaching and research institutions in France or recherche français ou étrangers, des laboratoires abroad, or from public or private research centers. publics ou privés. Distributed under a Creative Commons Attribution| 4.0 International License EUROGRAPHICS 2020/ F. Banterle and A. Wilkie Short Paper MEPP2: a generic platform for processing 3D meshes and point clouds Vincent Vidal, Eric Lombardi , Martial Tola , Florent Dupont and Guillaume Lavoué Université de Lyon, CNRS, LIRIS, Lyon, France Abstract In this paper, we present MEPP2, an open-source C++ software development kit (SDK) for processing and visualizing 3D surface meshes and point clouds. It provides both an application programming interface (API) for creating new processing filters and a graphical user interface (GUI) that facilitates the integration of new filters as plugins. Static and dynamic 3D meshes and point clouds with appearance-related attributes (color, texture information, normal) are supported. The strength of the platform is to be generic programming oriented. It offers an abstraction layer, based on C++ Concepts, that provides interoperability over several third party mesh and point cloud data structures, such as OpenMesh, CGAL, and PCL. Generic code can be run on all data structures implementing the required concepts, which allows for performance and memory footprint comparison. Our platform also permits to create complex processing pipelines gathering idiosyncratic functionalities of the different libraries. We provide examples of such applications. MEPP2 runs on Windows, Linux & Mac OS X and is intended for engineers, researchers, but also students thanks to simple use, facilitated by the proposed architecture and extensive documentation. CCS Concepts • Computing methodologies ! Mesh models; Point-based models; • Software and its engineering ! Software libraries and repositories; 1. Introduction GUI for processing and visualizing 3D surface meshes and point clouds. With the increasing capability of 3D data acquisition devices, mod- Several platforms exist for processing 3D meshes such as Meshlab eling software and graphics processing units, three-dimensional [CCC08] based on VCGlibz, MEPP [LTD12], and libigl [JP∗18]. (3D) graphics are now commonplace in many applications from These platforms either use their own data structures or are based simulation and gaming to upcoming tele-immersive communica- on existing ones such as OpenMesh [BSBK02] or CGAL Poly- tion. 3D assets commonly consist of surface meshes on which tex- hedron [The20]. For point clouds, a popular platform is Cloud- ture images are mapped (e.g. affecting surface geometry or normal, Compare [Gir19], and available libraries include PCL [RC11] and or reflectance terms such as diffuse, gloss, specular). Another pop- CGAL Point Set. The MEPP2 platform differs from these existing ular 3D representation is the 3D point cloud that has the benefit to tools in several ways: be the direct output of acquisition devices. It supports a wide range of 3D data: static and dynamic meshes To ease the development of new algorithms and stimulate research and point clouds, together with several types of attributes: vertex/ around the processing of 3D mesh and point cloud, it is crucial point colors and normals, different kinds of texture maps (including to have efficient open source tools and libraries available for the physically-based maps). It is not limited to one single data structure scientific community. This need for dedicated libraries is empha- but integrates a wide range of them (for both mesh and point cloud sized by the fact that manipulating 3D data is far more complex representation): OpenMesh, CGAL Surface Mesh, CGAL Polyhe- than manipulating 2D images. As an example, obtaining the direct dral Surface, CGAL Linear Cell Complex, AIF (Adjacency and In- neighborhood of a pixel in an image is a trivial operation; how- cidence Framework), PCL (Point Cloud Library), and CGAL Point ever, computing neighbors of a 3D vertex in a 3D mesh (resp. point Set. It offers generic-programming abstraction layers, allowing to cloud), with reasonable time complexity, requires a dedicated data invoke any data structure with the same source code. It offers an structure such as halfedge (resp. octree). In this context, we intro- application programming interface (API) for creating new process- duce the MEPP2 platformy, a C++ software development kit and y https://github.com/MEPP-team/MEPP2 z https://github.com/cnr-isti-vclab/vcglib/ c 2020 The Author(s) Eurographics Proceedings c 2020 The Eurographics Association. V. Vidal & E. Lombardi & M. Tola & F. Dupont & G. Lavoué / MEPP2 ing filters and a graphical user interface (GUI) to integrate filters as main concepts to process the topology of a surface mesh (Face- plugins. It is developer-oriented and provides extensive documen- Graph in Fig.1). Boost defines the concepts needed to process a tation and tutorials for creating filters and plugins. graph (e.g. boost::Graph, boost::IncidenceGraph, etc.) and CGAL defines concepts that refine the boost::IncidenceGraph concept to The next section introduces the architecture of MEPP2. Section process a graph that is also a polygonal 2-manifold surface. Be- 3 provides source code examples, while currently available filters yond this use of the CGAL FaceGraph concept, MEPP2 supplies are presented in Section4. Section5 details two applications. new concepts for geometry, point cloud, and property maps (this latter is extended from Boost). These concepts are detailed below. 2. Architecture Boost graph concept. It provides vertex and edge manipulation Figure1 shows the architecture of the MEPP2 platform. The core features, such as vertex/edge descriptor, vertex/edge iterator and of the platform is the central layer: the FEVV template library some basic functions to iterate on vertices and edges of the graph. (FEVV holds for Face Edge Vertex Volume). It relies on a set of CGAL HalfedgeGraph and FaceGraph concepts. They extend concepts [GJS∗06], which provide an abstraction layer over sev- the Boost graph concept with halfedge and face related features. eral third party mesh and point cloud data structures. Generic fil- CGAL also offers circulators around a face or a vertex, which are ters can then be created based on this template library. Structure- implemented using HalfedgeGraph concept. specific filters can also be written. Filters can either be called using FEVV geometry concept. This concept mainly provides a generic a command-line interface or integrated into the graphical user in- way to create a point and to access its x, y, and z coordinates. It also terface. All these elements and principles are detailed below. gives access to Point, Vector, Scalar, and Kernel associated types. FEVV property map concept. The original need for "generic" property maps arises from contexts where one needs to have the warranty that storing/accessing a property map associated with some mesh will function even if such a property map is not na- tively supported by the specific mesh data structure. For example, when using the native readers, the properties read from the mesh file (like vertex color, vertex normal, face color...) are stored in- side the data structure itself. But when using a generic reader, we do not have anymore access to the data structure internal storage. "Generic" property maps, based on boost property maps, provide such a location for storing mesh properties independently from any specific data structure. The FEVV property map concept also pro- vides a property map container that is used to gather all the property maps associated with the same mesh. FEVV point cloud concept. The point cloud concept is intended to manipulate point cloud objects generically. It reuses the nota- tions of the Boost graph concept related to the vertices (for access, addition, and removal) so that a simple algorithm iterating on ver- tices can be written in a generic way for meshes and point clouds. The point cloud concept also provides a k-nearest neighbor feature, which is common in point cloud processing. Figure 1: Layers overview of the MEPP2 platform. Third-party concept and data structures are represented in blue, while MEPP2 2.2. Adjacency and Incidence Framework (AIF) contributions are depicted in green. MEPP2 provides an implementation of the Adjacency and Inci- 2.1. Concepts dence Framework (AIF) data structure [SG03] to represent and pro- cess non-manifold surface meshes. AIF captures the incidence rela- In C++, the development of a generic -highly reusable-, flexible tionships between faces and edges, and between edges and vertices. and efficient software library is done through the use of constrained

View Full Text

Details

  • File Type
    pdf
  • Upload Time
    -
  • Content Languages
    English
  • Upload User
    Anonymous/Not logged-in
  • File Pages
    5 Page
  • File Size
    -

Download

Channel Download Status
Express Download Enable

Copyright

We respect the copyrights and intellectual property rights of all users. All uploaded documents are either original works of the uploader or authorized works of the rightful owners.

  • Not to be reproduced or distributed without explicit permission.
  • Not used for commercial purposes outside of approved use cases.
  • Not used to infringe on the rights of the original creators.
  • If you believe any content infringes your copyright, please contact us immediately.

Support

For help with questions, suggestions, or problems, please contact us