Skip to content

Commit

Permalink
174 precommit install (#178)
Browse files Browse the repository at this point in the history
* first stab precommits #174

* change projection method to numpy #174

* update notebooks 3/4 #174

* test for lens position #174

* update notebooks 3/4 #174

* pyproject.toml inserted with changelog #174

* Reduced fixtures to speed up tests

* fixing CI test issues #174

* updated all tests, captured warnings #174

* bump version and changelog #174

* added accidentally removed notebook 04, remove `lazy=False` from 02 #174
  • Loading branch information
hcwinsemius authored Sep 20, 2024
1 parent 6cfb1b2 commit 23f3222
Show file tree
Hide file tree
Showing 35 changed files with 440 additions and 326 deletions.
13 changes: 8 additions & 5 deletions .github/workflows/tests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ on:
- tests/*
- pyorc/*
- pyproject.toml
jobs:
jobs:
Test-matrix:
name: ${{ matrix.os }} - py${{ matrix.python-version }}
runs-on: ${{ matrix.os }}
Expand All @@ -26,7 +26,7 @@ jobs:
matrix:
os: ["ubuntu-latest" ] #, "macos-latest", "windows-latest"]
python-version: ["3.10"] # fix tests to support older versions

steps:
- uses: actions/checkout@v4

Expand All @@ -43,7 +43,7 @@ jobs:
- name: OpenCV dependencies
run: |
sudo apt update
sudo apt install libegl1 libopengl0 -y
sudo apt install libegl1 libopengl0 ffmpeg -y
# build environment with pip
- name: Install pyorc
Expand All @@ -54,5 +54,8 @@ jobs:
# run all tests
- name: Test
run: python -m pytest --verbose --cov=pyorc --cov-report xml

- uses: codecov/codecov-action@v4

- name: Upload coverage to Codecov
uses: codecov/codecov-action@v4
env:
CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }}
12 changes: 12 additions & 0 deletions .pre-commit-config.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
repos:
- repo: https://github.com/pre-commit/pre-commit-hooks
rev: v4.6.0 # Use the latest version
hooks:
- id: trailing-whitespace
- id: end-of-file-fixer
- id: check-added-large-files

- repo: https://github.com/kynan/nbstripout
rev: 0.7.1 # Use the latest version
hooks:
- id: nbstripout
52 changes: 39 additions & 13 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,29 @@
## [0.6.0] - 2024-09-20
### Added
A logo with modifications in trademark guidelines in TRADEMARK.md and README.md.
Logo is also shown in the online documentation on https://localdevices.github.io/pyorc
### Changed
`Frames.project` with `method="numpy"` is improved so that it also works well in heavily undersampled areas.
`Video` instances defaulting with `lazy=False`. This in most cases increases the speed of video treatment significantly.
For large videos with large memory requirements, videos can be opened with `lazy=True`.
### Deprecated
### Removed
### Fixed
The legacy `setup.py` has been replaced by a `pyproject.toml` using flit installer.
### Security


## [0.5.6] - 2024-06-28
### Added
### Changed
`Frames.project` with `method="numpy"` is improved so that it also works well in heavily undersampled areas.
### Deprecated
`Video` instances will default with `lazy=False` in v0.6.0. A warning message will appear for now
### Removed
### Fixed
### Security


## [0.5.5] - 2024-05-15
### Added
### Changed
Expand All @@ -23,7 +49,7 @@ Projection with `method="numpy"` sometimes results in missing values in the resu
## [0.5.3] - 2023-11-10
### Added
`frames.project` now has a `method` option which allows for choosing projection using opencv-methods (`method="cv"`)
which is currently still the default, or numpy-like operations (`method="numpy"`). `method="numpy"` is new and we
which is currently still the default, or numpy-like operations (`method="numpy"`). `method="numpy"` is new and we
may change the default behaviour to this option in a later release as it is much more robust in cases with a lot
of lens distortion and where part of the area of interest is outside of the field of view.

Expand All @@ -32,8 +58,8 @@ Video rotation can be defined in the camera configuration, on the CLI with `--ro
as measured in degrees, or for individual single videos as an additional input argument to `pyorc.Video`
e.g. `pyorc.Video(..., rotation=90)`.
### Changed
Some default values for estimating the intrinsic lens parameters from control points are changed. We now estimate the
first two barrel distortion coefficients if enough information for constraining them is available.
Some default values for estimating the intrinsic lens parameters from control points are changed. We now estimate the
first two barrel distortion coefficients if enough information for constraining them is available.
### Deprecated
### Removed
### Fixed
Expand All @@ -54,7 +80,7 @@ pyopenrivercam for scalable computation across a cloud. API / CLI users do not n
### Removed
### Fixed
Notebook 02 in the examples folder contained a deprecation error with the stabilize option for opening videos. This
has been corrected and functionality description improved.
has been corrected and functionality description improved.
### Security

## [0.5.1] - 2023-06-27
Expand All @@ -63,7 +89,7 @@ has been corrected and functionality description improved.
### Deprecated
### Removed
### Fixed
- removed the strict cartopy dependency. This enables pip installation for users that are not interested in
- removed the strict cartopy dependency. This enables pip installation for users that are not interested in
geographical plotting. Enables also installation on raspi platforms (only 64-bit!)
- Transects sometimes gave infinite discharge when areas with zero depth received a small velocity. This has now
been resolved.
Expand All @@ -72,12 +98,12 @@ has been corrected and functionality description improved.

## [0.5.0] - 2023-05-24
### Added
- make it a lot easier to get well-calibrated ground control and lens parameters at the same time. we now do this
by optimizing the lens' focal length and (if enough ground control is provided) barrel distortion whilst fitting
- make it a lot easier to get well-calibrated ground control and lens parameters at the same time. we now do this
by optimizing the lens' focal length and (if enough ground control is provided) barrel distortion whilst fitting
the perspective to the user-provided ground control points.
- provide the fitted ground control points in the interface so that the user can immediately see if the ground control
- provide the fitted ground control points in the interface so that the user can immediately see if the ground control
points are well fitted or if anything seems to be wrong with one or more control points.
- feature stabilization on command line which consequently provided user-interfacing to select non-moving areas by
- feature stabilization on command line which consequently provided user-interfacing to select non-moving areas by
pointing and clicking.
### Changed
- Much-improved stabilization for non-stable videos
Expand All @@ -93,12 +119,12 @@ has been corrected and functionality description improved.
## [0.4.0] - 2023-03-10
### Added
The most notable change is that the code now includes an automatically installed command-line interface. This
will facilitate a much easier use by a large user group. Also the documentation is fully updated to include all
will facilitate a much easier use by a large user group. Also the documentation is fully updated to include all
functionalities for both command-line users and API users. In detail we have the following additions:
- First release of a command-line interface for the entire process of camera configuration, processing and preparing
outputs and figures.
- Service layer that makes it easy for developers to connect pyorc to apps such as GUIs or dashboards.
- Full user guide with description of both the command-line interface and API.
- Full user guide with description of both the command-line interface and API.
### Changed
- Small modifications and additions in the API to accomodate the command-line interface building.
### Deprecated
Expand Down Expand Up @@ -147,7 +173,7 @@ functionalities for both command-line users and API users. In detail we have the
- Improved pytest code coverage

### Changed
- several API modifications to accommodate lens calibration and 6-point orthorectification
- several API modifications to accommodate lens calibration and 6-point orthorectification
- CameraConfig format changed
- CameraConfig.lens_parameters no longer used (replaced by camera_matrix and dist_coeffs)
- CameraConfig.gcps extended orthorectification with 6(+)-point x, y, z perspective option
Expand Down Expand Up @@ -178,7 +204,7 @@ functionalities for both command-line users and API users. In detail we have the
## [0.2.3] - 2022-08-10
### Added
### Changed
- pyorc.transect.get_q added method="log_interp" using a log-depth normalized velocity and linear interpolation
- pyorc.transect.get_q added method="log_interp" using a log-depth normalized velocity and linear interpolation

### Deprecated
### Removed
Expand Down
2 changes: 1 addition & 1 deletion docs/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ def remove_dir_content(path: str) -> None:
# -- Project information -----------------------------------------------------

project = 'pyorc'
copyright = '2023, Rainbow Sensing'
copyright = '2024, Rainbow Sensing'
author = 'Hessel Winsemius'

# The full version, including alpha/beta/rc tags
Expand Down
3 changes: 1 addition & 2 deletions envs/pyorc-test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ dependencies:
- numba
- opencv
- pip
- pytest<8.0.0 # due to temporary problem with lazy_fixtures, see https://github.com/pytest-dev/pytest/issues/11890
- pytest
- pytest-cov
- pytest-benchmark
- pytest-lazy-fixture
Expand All @@ -38,4 +38,3 @@ dependencies:
- yaml
- pip:
- openpiv

Loading

0 comments on commit 23f3222

Please sign in to comment.