Skip to content

This is the main public repo for FLIP. Currently it is a placeholder, codes will be moved here after final development (est. in summer 2024)

License

Notifications You must be signed in to change notification settings

xiangtaoxu/FLIP_main

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 

Repository files navigation

FLIP

!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

Notes: FLIP is still under internal development and testing. Codes will be made public in this github repo later (est. summer of 2024)

!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

A Forest Lidar Integrated toolset based on Python

Authors: Xiangtao Xu, Tao Han, et al.

A formal and detailed description of FLIP package can be found in TBD

Introduction

Why FLIP ?

Recent years, terrestrial laser scanning (TLS) sees many applications in forestry as TLS can measure the forest structure with high spatial detail and accuracy. However, the diffculty to access the information content of point clouds limit the utilization of TLS. To obtain tree-scale metrics (DBH, basel area, volume, etc...), we must segment individual trees from forest-level point clouds. This process often means intensive manual segmentation, which is a impossible task where hundreds of trees or large forest area exists.

Here, FLIP is an open-source python-based integrated tool, which can support rapid tree segmentation (1 to 4 hours depends on your computation power) from LiDAR point clouds of different forest biomes (temporal, tropical and boreal). The FLIP package provides functions for i) data preprocessing (point clouds cropping, subsampling and filtering), ii) ground layer and above ground height extraction, iii) extract and assemble linear units from point clouds, and many more functions in the future!

Installation

To implement this toolbox you need to install the required Python packages in an environment. You will need a recent installation of Anaconda3 or miniconda3. Once you installed Anaconda or miniconda on your PC, open the Anaconda prompt and change current directory to locate the folder where you downloaded FLIP package. Then, create a new environment named CloudCompy39 (you can set any name you want) and install all the required packages.

Required packages

Now, all the required packages have been installed in an environment named CloudCompy39. Make sure activate the environment before running FLIP repository:

# activate the environment
conda activate CloudCompy39
# rem this script sets the environment for CloudComPy. The Conda environment must be activated before calling this script.
envCloudCompy.bat 

Getting Started

Preprocessing

Point clouds cropping

# create boundary box according to the coordinates of scanpositions 
# INPUT_DIR should include "ScanPosition.txt"

Downsampling and filtering

# subsample point clouds within the box (default value of 0.03 m)
SubSampleCloud_MP()

# filter point clouds
pc_filter = FilterCloud()

See more details in config.yaml to get the default values of parameters used in functions.

Get ground layer and above ground height

cloud_ground = GetGroundCloud(pc_filter)
cc.SavePointCloud(cloud_ground, GROUND_FILENAME)
pc_agh = GetAboveGroundHeight(pc_filter,cloud_ground)
cc.SavePointCloud(pc_agh, AGH_FILENAME)

add figures

Segmentation

Clustering

# obtain all potential linear untis from cloud
N_stems = GetGeometricUnits(AGH_FILENAME, res= SEG_RES)

Post-segmentation processing

# add raw cloud and aggregate all trees
AssimilateRawCloud()
AggregateTrees()

add figures

Contribution

Feedback and bug reports are welcome. Please write us at [email protected] if you want to make contributions.

How to cite

Please cite us using the reference below if you use these codes in your research.

@article{makecite,
  author       = {Xiangtao Xu},
  title        = {},
  journal      = {},
  year         = {},
  volume       = {},
  pages        = {}
  doi          = {}
}

About

This is the main public repo for FLIP. Currently it is a placeholder, codes will be moved here after final development (est. in summer 2024)

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published