當前位置: 首頁>>代碼示例>>Python>>正文


Python pcl.PointCloud方法代碼示例

本文整理匯總了Python中pcl.PointCloud方法的典型用法代碼示例。如果您正苦於以下問題:Python pcl.PointCloud方法的具體用法?Python pcl.PointCloud怎麽用?Python pcl.PointCloud使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在pcl的用法示例。


在下文中一共展示了pcl.PointCloud方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: create_xyzrgb

# 需要導入模塊: import pcl [as 別名]
# 或者: from pcl import PointCloud [as 別名]
def create_xyzrgb(data):
    '''
    Create PointXYZRGB point cloud from ordinary nx6 array, or equivalent list representation
    Note that RGB value should be represented in integer of 0~255
    '''
    data = np.array(data, copy=False)
    if data.shape[-1] != 6:
        return ValueError("Each point should contain 3 values")

    rgb_dt = np.dtype(dict(names=['b','g','r'], formats=['u1','u1','u1'], itemsize=4))
    rgb_arr = np.empty(len(data), dtype=rgb_dt)
    rgb_arr['r'], rgb_arr['g'], rgb_arr['b'] = data[:,3], data[:,4], data[:,5]
    cloud_dt = np.dtype(dict(names=['x','y','z','rgb'], formats=['f4','f4','f4','u4'], offsets=[0,4,8,16], itemsize=20))
    cloud_arr = np.empty(len(data), dtype=cloud_dt)
    cloud_arr['x'], cloud_arr['y'], cloud_arr['z'], cloud_arr['rgb'] = data[:,0], data[:,1], data[:,2], rgb_arr.view('u4')
    return PointCloud(cloud_arr, 'XYZRGB') 
開發者ID:cmpute,項目名稱:pcl.py,代碼行數:18,代碼來源:__init__.py

示例2: test_load_pointcloud

# 需要導入模塊: import pcl [as 別名]
# 或者: from pcl import PointCloud [as 別名]
def test_load_pointcloud(self):
        cloud1 = pcl.PointCloud(np.random.rand(100, 4).astype('f4'))
        cloud2 = pcl.PointCloud(np.random.rand(100, 4).astype('f4'))
        
        viewer = pcl.Visualizer()
        viewer.addPointCloud(cloud1)
        viewer.addCoordinateSystem()
        viewer.removeCoordinateSystem()
        
        v1 = viewer.createViewPort(0, 0, 0.5, 1)
        v2 = viewer.createViewPort(0.5, 0, 1, 1)
        viewer.addPointCloud(cloud1, viewport=v1, id="cloud1")
        viewer.addPointCloud(cloud2, viewport=v2, id="cloud2")
        
        viewer.spinOnce(time=1000)
        viewer.close() 
開發者ID:cmpute,項目名稱:pcl.py,代碼行數:18,代碼來源:test_visualizer.py

示例3: test_add_callback

# 需要導入模塊: import pcl [as 別名]
# 或者: from pcl import PointCloud [as 別名]
def test_add_callback(self):
        def key_callback(event):
            print(event.KeyCode, event.KeySym)
        def mouse_callback(event):
            print(event.X, event.Y, event.Type, event.Button)
        def picking_callback(event):
            print(event.Point, event.PointIndex)
        def area_callback(event):
            print(event.PointsIndices)

        cloud = pcl.PointCloud(np.random.rand(100, 4).astype('f4'))
        viewer = pcl.Visualizer()
        viewer.addPointCloud(cloud)
        viewer.registerKeyboardCallback(key_callback)
        viewer.registerMouseCallback(mouse_callback)
        viewer.registerPointPickingCallback(picking_callback)
        viewer.registerAreaPickingCallback(area_callback)

        viewer.spinOnce(time=2000)
        viewer.close() 
開發者ID:cmpute,項目名稱:pcl.py,代碼行數:22,代碼來源:test_visualizer.py

示例4: test_add_shape

# 需要導入模塊: import pcl [as 別名]
# 或者: from pcl import PointCloud [as 別名]
def test_add_shape(self):
        cloud = pcl.PointCloud(np.random.rand(100, 4).astype('f4'))
        
        viewer = pcl.Visualizer()
        viewer.addPointCloud(cloud)
        
        viewer.addLine([-1,-1,-1], [1,1,1])
        viewer.addArrow([1,-1,-1], [-1,1,1], line_color=[0.7,0,0], text_color=[0,3,0,0])
        viewer.addSphere([0,0,0], 1)

        viewer.addText("Text", -1, 1, fontsize=100)
        viewer.addText3D("Text3D", [-1,1,-1], text_scale=2)
        
        viewer.spinOnce(time=500)
        viewer.updateSphere([0,0,0], 2)
        viewer.spinOnce(time=500)
        
        viewer.close() 
開發者ID:cmpute,項目名稱:pcl.py,代碼行數:20,代碼來源:test_visualizer.py

示例5: XYZRGB_to_XYZ

# 需要導入模塊: import pcl [as 別名]
# 或者: from pcl import PointCloud [as 別名]
def XYZRGB_to_XYZ(XYZRGB_cloud):
    """ Converts a PCL XYZRGB point cloud to an XYZ point cloud (removes color info)

        Args:
            XYZRGB_cloud (PointCloud_PointXYZRGB): A PCL XYZRGB point cloud

        Returns:
            PointCloud_PointXYZ: A PCL XYZ point cloud
    """
    XYZ_cloud = pcl.PointCloud()
    points_list = []

    for data in XYZRGB_cloud:
        points_list.append([data[0], data[1], data[2]])

    XYZ_cloud.from_list(points_list)
    return XYZ_cloud 
開發者ID:anshulpaigwar,項目名稱:Attentional-PointNet,代碼行數:19,代碼來源:pcl_helper.py

示例6: exact_planar_normals

# 需要導入模塊: import pcl [as 別名]
# 或者: from pcl import PointCloud [as 別名]
def exact_planar_normals(self):
        import pcl
        if self.__csv_path == "":
            print "csv file path is not spcified!"
        raw_data = np.genfromtxt(self.__csv_path, delimiter=",", skip_header=1)
        points_xyz_arr = np.array(raw_data[:, :3], dtype=np.float32)
        points_cloud = pcl.PointCloud()
        points_cloud.from_array(points_xyz_arr)
        for i in xrange(self.__palnar_normal_num):
            seg = points_cloud.make_segmenter()
            seg.set_optimize_coefficients(True)
            seg.set_model_type(pcl.SACMODEL_PLANE)
            seg.set_method_type(pcl.SAC_RANSAC)
            seg.set_distance_threshold(self.ransac_distance_threshold)
            indices, model = seg.segment()
            if len(indices) < self.__plane_detection_points_thre:
                break
            # model turns Hessian Normal Form of a plane in 3D
            # http://mathworld.wolfram.com/HessianNormalForm.html
            self.__normals_list.append(model)
            tmp = points_cloud.to_array()
            tmp = np.delete(tmp, indices, 0)
            points_cloud.from_array(tmp)
            # show_xyzrgb_points_vtk(tmp) 
開發者ID:mfxox,項目名稱:ILCC,代碼行數:26,代碼來源:pcd_corners_est.py

示例7: get_plane_model

# 需要導入模塊: import pcl [as 別名]
# 或者: from pcl import PointCloud [as 別名]
def get_plane_model(arr):
    import pcl
    ransac_distance_threshold = 0.05
    point_cloud = pcl.PointCloud(arr.astype(np.float32))
    seg = point_cloud.make_segmenter_normals(ksearch=50)

    seg.set_model_type(pcl.SACMODEL_PLANE)
    seg.set_method_type(pcl.SAC_RANSAC)
    seg.set_max_iterations(10000)
    seg.set_distance_threshold(ransac_distance_threshold)
    indices, model = seg.segment()
    print "percentage of points in plane model: ", np.float32(len(indices)) / arr.shape[0]
    return model


# project a point to an estimated plane 
開發者ID:mfxox,項目名稱:ILCC,代碼行數:18,代碼來源:pcd_corners_est.py

示例8: get_pc_segments

# 需要導入模塊: import pcl [as 別名]
# 或者: from pcl import PointCloud [as 別名]
def get_pc_segments(pc_np):
    view_range = 300
    ground_range = 0.3

    inds = (
        (pc_np[:, 0] < view_range)
        & (pc_np[:, 1] < view_range)
        & (pc_np[:, 2] > ground_range)
        & (pc_np[:, 0] > -view_range)
        & (pc_np[:, 1] > -view_range)
    )

    pc_np = pc_np[inds]

    pc = pcl.PointCloud(pc_np.astype(np.float32))
    pc_segments = pc_segmentation(pc)

    return pc_segments 
開發者ID:alliecc,項目名稱:argoverse_baselinetracker,代碼行數:20,代碼來源:tools_pcl.py

示例9: create_rgb

# 需要導入模塊: import pcl [as 別名]
# 或者: from pcl import PointCloud [as 別名]
def create_rgb(data):
    '''
    Create RGB point cloud from ordinary nx3 array, or equivalent list representation.
    Note that RGB value should be represented in integer of 0~255
    '''
    data = np.array(data, copy=False)
    if data.shape[-1] != 3:
        return ValueError("Each point should contain 3 values")

    rgb_dt = np.dtype(dict(names=['b','g','r'], formats=['u1','u1','u1'], itemsize=16))
    rgb_arr = np.empty(len(data), dtype=rgb_dt)
    rgb_arr['r'], rgb_arr['g'], rgb_arr['b'] = data[:,0], data[:,1], data[:,2]
    return PointCloud(rgb_arr.view('u4'), 'RGB') 
開發者ID:cmpute,項目名稱:pcl.py,代碼行數:15,代碼來源:__init__.py

示例10: create_xyz

# 需要導入模塊: import pcl [as 別名]
# 或者: from pcl import PointCloud [as 別名]
def create_xyz(data):
    '''
    Create PointXYZ point cloud from ordinary nx3 array, or equivalent list representation
    '''
    data = np.array(data, copy=False)
    if data.shape[-1] != 3:
        return ValueError("Each point should contain 3 values")

    dt = np.dtype(dict(names=['x','y','z'], formats=['f4','f4','f4'], itemsize=16))
    arr = np.empty(len(data), dtype=dt)
    arr['x'], arr['y'], arr['z'] = data[:,0], data[:,1], data[:,2]
    return PointCloud(arr, 'XYZ') 
開發者ID:cmpute,項目名稱:pcl.py,代碼行數:14,代碼來源:__init__.py

示例11: create_xyzrgba

# 需要導入模塊: import pcl [as 別名]
# 或者: from pcl import PointCloud [as 別名]
def create_xyzrgba(data):
    '''
    Create PointXYZRGBA point cloud from ordinary nx6 array, or equivalent list representation
    '''
    data = np.array(data, copy=False)
    if data.shape[-1] != 7:
        return ValueError("Each point should contain 3 values")

    rgba_dt = np.dtype(dict(names=['b','g','r','a'], formats=['u1','u1','u1','u1'], itemsize=4))
    rgba_arr = np.empty(len(data), dtype=rgba_dt)
    rgba_arr['r'], rgba_arr['g'], rgba_arr['b'], rgba_arr['a'] = data[:,3], data[:,4], data[:,5], data[:,6]
    cloud_dt = np.dtype(dict(names=['x','y','z','rgba'], formats=['f4','f4','f4','u4'], offsets=[0,4,8,16], itemsize=20))
    cloud_arr = np.empty(len(data), dtype=cloud_dt)
    cloud_arr['x'], cloud_arr['y'], cloud_arr['z'], cloud_arr['rgba'] = data[:,0], data[:,1], data[:,2], rgba_arr.view('u4')
    return PointCloud(cloud_arr, 'XYZRGBA') 
開發者ID:cmpute,項目名稱:pcl.py,代碼行數:17,代碼來源:__init__.py

示例12: create_xyzi

# 需要導入模塊: import pcl [as 別名]
# 或者: from pcl import PointCloud [as 別名]
def create_xyzi(data):
    '''
    Create PointXYZI point cloud from ordinary nx4 array, or equivalent list representation
    '''
    data = np.array(data, copy=False)
    if data.shape[-1] != 4:
        return ValueError("Each point should contain 4 values")

    dt = np.dtype(dict(names=['x','y','z','intensity'], formats=['f4','f4','f4','f4'], offsets=[0,4,8,16], itemsize=32))
    arr = np.empty(len(data), dtype=dt)
    arr['x'], arr['y'], arr['z'], arr['intensity'] = data[:,0], data[:,1], data[:,2], data[:,3]
    return PointCloud(arr, 'XYZI') 
開發者ID:cmpute,項目名稱:pcl.py,代碼行數:14,代碼來源:__init__.py

示例13: test_normal_init

# 需要導入模塊: import pcl [as 別名]
# 或者: from pcl import PointCloud [as 別名]
def test_normal_init(self):
        cloud_array = np.array([[1,2,3],[2,3,4]], dtype='f4')
        with self.assertRaises(ValueError):
            cloud = pcl.PointCloud(cloud_array)

        # add padding zeros after points
        cloud_array_pad = np.insert(cloud_array, 3, 0, axis=1)
        cloud = pcl.PointCloud(cloud_array_pad)
        assert len(cloud) == 2
        assert np.allclose(cloud.xyz, cloud_array)
        assert len(cloud.fields) == 3
        assert cloud.names == ['x', 'y', 'z'] 
開發者ID:cmpute,項目名稱:pcl.py,代碼行數:14,代碼來源:test_pointcloud.py

示例14: test_list_init

# 需要導入模塊: import pcl [as 別名]
# 或者: from pcl import PointCloud [as 別名]
def test_list_init(self):
        cloud = pcl.PointCloud([(1,2,3),(2,3,4)], 'xyz')
        assert len(cloud) == 2
        assert np.allclose(cloud.xyz, [[1,2,3],[2,3,4]])
        assert cloud.names == ['x', 'y', 'z'] 
開發者ID:cmpute,項目名稱:pcl.py,代碼行數:7,代碼來源:test_pointcloud.py

示例15: test_struct_init

# 需要導入模塊: import pcl [as 別名]
# 或者: from pcl import PointCloud [as 別名]
def test_struct_init(self):
        cloud_array = np.array([(1,2,3),(2,3,4)],
            dtype={'names':['x','y','z'], 'formats':['f4','f4','f4'], 'itemsize':16})
        cloud = pcl.PointCloud(cloud_array)
        assert len(cloud) == 2
        assert np.allclose(cloud.xyz, [[1,2,3],[2,3,4]])
        assert cloud.names == ['x', 'y', 'z']

        cloud = pcl.PointCloud(np.array([(1,2,3,5),(2,3,4,5)], 
            dtype={'names':['x','y','z','i'], 'formats':['f4','f4','f4','i1'], 'offsets':[0,4,8,16]}))
        assert len(cloud) == 2
        assert np.allclose(cloud.xyz, [[1,2,3],[2,3,4]])
        assert cloud.names == ['x', 'y', 'z', 'i'] 
開發者ID:cmpute,項目名稱:pcl.py,代碼行數:15,代碼來源:test_pointcloud.py


注:本文中的pcl.PointCloud方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。