Please cite the software if you are using it in your scientific publication.
<p align="left">
<img src="https://raw.githubusercontent.com/eEcoLiDAR/laserchicken/master/laserchicken_logo.png" width="500"/>
</p>
[![Build Status](https://github.com/eEcoLiDAR/laserchicken/workflows/Build/badge.svg)](https://github.com/eEcoLiDAR/laserchicken/actions)
[![Codacy Badge](https://api.codacy.com/project/badge/Grade/6e3836750fe14f34ba85e26956e8ef10)](https://www.codacy.com/app/c-meijer/eEcoLiDAR?utm_source=www.github.com&utm_medium=referral&utm_content=eEcoLiDAR/eEcoLiDAR&utm_campaign=Badge_Grade)
[![Coverage Status](https://coveralls.io/repos/github/eEcoLiDAR/laserchicken/badge.svg)](https://coveralls.io/github/eEcoLiDAR/laserchicken)
[![DOI](https://zenodo.org/badge/95649056.svg)](https://zenodo.org/badge/latestdoi/95649056)
[![Documentation Status](https://readthedocs.org/projects/laserchicken/badge/?version=latest)](https://laserchicken.readthedocs.io/en/latest/)
[![CII Best Practices](https://bestpractices.coreinfrastructure.org/projects/4524/badge)](https://bestpractices.coreinfrastructure.org/projects/4524)
Toolkit for handling point clouds created using airborne laser scanning (ALS). Find neighboring points in your point cloud and describe them as feature values. Read our [user manual](https://laserchicken.readthedocs.io/) and our (very modest) [tutorial](https://github.com/eEcoLiDAR/laserchicken/blob/master/tutorial.ipynb).
# Installation
Prerequisites:
- Python 3.7 or higher
- pip
```
pip install laserchicken
```
#### Necessary steps for making a new release
* Check citation.cff using general DOI for all version (option: create file via 'cffinit')
* Create .zenodo.json file from CITATION.cff (using cffconvert)
```cffconvert --validate```
```cffconvert --ignore-suspect-keys --outputformat zenodo --outfile .zenodo.json```
* Set new version number in laserchicken/_version.txt
* Check that documentation uses the correct version
* Edit Changelog (based on commits in https://github.com/eecolidar/laserchicken/compare/v0.3.2...master)
* Test if package can be installed with pip (`pip install .`)
* Create Github release
* Upload to pypi (now implemented via GitHub Actions):
```python setup.py sdist bdist_wheel```
```python -m twine upload --repository-url https://upload.pypi.org/legacy/ dist/*```
(or ```python -m twine upload --repository-url https://test.pypi.org/legacy/ dist/*``` to test first)
* Check doi on zenodo
## Feature testing
All features were tested for the following general conditions:
- Output consistent point clouds and don't crash with artificial data, real data, all zero data (x, y or z), data without points, data with very low number of neighbors (0, 1, 2)
- Input should not be changed by the feature extractor
The specific features were tested as follows.
*Echo ratio*
A test was written with artificial data to check the correctness of the calculation with manually calculated ratio. Also tested on real data to make sure it doesn't crash, without checking for correctness. We could add a test for correctness with real data but we would need both that data and a verified ground truth.
*Eigenvalues*
Only sanity tests (l1>l2>l3) on real data and corner cases but no actual test for correctness. The code is very simple though and mainly calls numpy.linalg.eig.
*Height statistics (max_z','min_z','mean_z','median_z','std_z','var_z','coeff_var_z','skew_z','kurto_z)*
Tested on real data for correctness. It is however unclear where the ground truths come from. Code is mainly calling numpy methods that do all the work already. Only calculations in our code are:
```
range_z = max_z - min_z
coeff_var_z = np.std(z) / np.mean(z)
```
I don't know about any packages that could provide an out of the box coefficient of variance. This is probably because the calculation is so simple.
*Pulse penetration ratio*
Tested for correctness using artificial data against manually calculated values. No comparison was made with other implementations.
*Sigma_z*
Tested for correctness using artificial data against manually calculated values. No comparison was made with other implementations.
*Percentiles*
Tested for correctness using a simple case with artificial data against manually calculated values.
*point_density*
Tested for correctness on artificial data.
Raw data
{
"_id": null,
"home_page": "https://github.com/eEcoLiDAR/eEcoLiDAR",
"name": "laserchicken",
"maintainer": "",
"docs_url": null,
"requires_python": "",
"maintainer_email": "",
"keywords": "Python,Point cloud",
"author": "",
"author_email": "",
"download_url": "",
"platform": null,
"description": "Please cite the software if you are using it in your scientific publication.\n<p align=\"left\">\n <img src=\"https://raw.githubusercontent.com/eEcoLiDAR/laserchicken/master/laserchicken_logo.png\" width=\"500\"/>\n</p>\n\n[![Build Status](https://github.com/eEcoLiDAR/laserchicken/workflows/Build/badge.svg)](https://github.com/eEcoLiDAR/laserchicken/actions)\n[![Codacy Badge](https://api.codacy.com/project/badge/Grade/6e3836750fe14f34ba85e26956e8ef10)](https://www.codacy.com/app/c-meijer/eEcoLiDAR?utm_source=www.github.com&utm_medium=referral&utm_content=eEcoLiDAR/eEcoLiDAR&utm_campaign=Badge_Grade)\n[![Coverage Status](https://coveralls.io/repos/github/eEcoLiDAR/laserchicken/badge.svg)](https://coveralls.io/github/eEcoLiDAR/laserchicken)\n[![DOI](https://zenodo.org/badge/95649056.svg)](https://zenodo.org/badge/latestdoi/95649056)\n[![Documentation Status](https://readthedocs.org/projects/laserchicken/badge/?version=latest)](https://laserchicken.readthedocs.io/en/latest/)\n[![CII Best Practices](https://bestpractices.coreinfrastructure.org/projects/4524/badge)](https://bestpractices.coreinfrastructure.org/projects/4524)\n\nToolkit for handling point clouds created using airborne laser scanning (ALS). Find neighboring points in your point cloud and describe them as feature values. Read our [user manual](https://laserchicken.readthedocs.io/) and our (very modest) [tutorial](https://github.com/eEcoLiDAR/laserchicken/blob/master/tutorial.ipynb).\n\n# Installation\nPrerequisites:\n- Python 3.7 or higher\n- pip\n```\npip install laserchicken\n```\n\n#### Necessary steps for making a new release\n* Check citation.cff using general DOI for all version (option: create file via 'cffinit')\n* Create .zenodo.json file from CITATION.cff (using cffconvert) \n```cffconvert --validate``` \n```cffconvert --ignore-suspect-keys --outputformat zenodo --outfile .zenodo.json```\n* Set new version number in laserchicken/_version.txt\n* Check that documentation uses the correct version\n* Edit Changelog (based on commits in https://github.com/eecolidar/laserchicken/compare/v0.3.2...master)\n* Test if package can be installed with pip (`pip install .`)\n* Create Github release\n* Upload to pypi (now implemented via GitHub Actions): \n```python setup.py sdist bdist_wheel``` \n```python -m twine upload --repository-url https://upload.pypi.org/legacy/ dist/*``` \n(or ```python -m twine upload --repository-url https://test.pypi.org/legacy/ dist/*``` to test first)\n* Check doi on zenodo\n\n\n## Feature testing\n\nAll features were tested for the following general conditions:\n- Output consistent point clouds and don't crash with artificial data, real data, all zero data (x, y or z), data without points, data with very low number of neighbors (0, 1, 2)\n- Input should not be changed by the feature extractor\n\nThe specific features were tested as follows.\n\n*Echo ratio*\n\nA test was written with artificial data to check the correctness of the calculation with manually calculated ratio. Also tested on real data to make sure it doesn't crash, without checking for correctness. We could add a test for correctness with real data but we would need both that data and a verified ground truth.\n\n*Eigenvalues*\n\nOnly sanity tests (l1>l2>l3) on real data and corner cases but no actual test for correctness. The code is very simple though and mainly calls numpy.linalg.eig.\n\n*Height statistics (max_z','min_z','mean_z','median_z','std_z','var_z','coeff_var_z','skew_z','kurto_z)*\n\nTested on real data for correctness. It is however unclear where the ground truths come from. Code is mainly calling numpy methods that do all the work already. Only calculations in our code are:\n\n```\nrange_z = max_z - min_z\ncoeff_var_z = np.std(z) / np.mean(z)\n```\n\nI don't know about any packages that could provide an out of the box coefficient of variance. This is probably because the calculation is so simple.\n\n*Pulse penetration ratio*\n\nTested for correctness using artificial data against manually calculated values. No comparison was made with other implementations.\n\n*Sigma_z*\n\nTested for correctness using artificial data against manually calculated values. No comparison was made with other implementations.\n\n*Percentiles*\n\nTested for correctness using a simple case with artificial data against manually calculated values.\n\n*point_density*\n\nTested for correctness on artificial data.\n\n\n\n\n\n",
"bugtrack_url": null,
"license": "Apache 2.0",
"summary": "Point cloud toolkit",
"version": "0.6.1",
"project_urls": {
"Homepage": "https://github.com/eEcoLiDAR/eEcoLiDAR"
},
"split_keywords": [
"python",
"point cloud"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "b7e7af8e4648bca193f6a8f3e1b98820499518ad1b779ba64ed544215c696e94",
"md5": "64c654a55d020544154b191e13ed3522",
"sha256": "0ccc62c36fbd80bf41c75fe5d5c2562a78f3d89b42643e5ed3b8598cae2ee2ba"
},
"downloads": -1,
"filename": "laserchicken-0.6.1-py3-none-any.whl",
"has_sig": false,
"md5_digest": "64c654a55d020544154b191e13ed3522",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": null,
"size": 94581,
"upload_time": "2023-07-05T12:28:40",
"upload_time_iso_8601": "2023-07-05T12:28:40.333249Z",
"url": "https://files.pythonhosted.org/packages/b7/e7/af8e4648bca193f6a8f3e1b98820499518ad1b779ba64ed544215c696e94/laserchicken-0.6.1-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2023-07-05 12:28:40",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "eEcoLiDAR",
"github_project": "eEcoLiDAR",
"travis_ci": false,
"coveralls": true,
"github_actions": true,
"requirements": [],
"lcname": "laserchicken"
}