Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hofbi/amvs-se
Adaptive Multi-View Live Video Streaming for Teledriving Using a Single Hardware Encoder
https://github.com/hofbi/amvs-se
Last synced: about 17 hours ago
JSON representation
Adaptive Multi-View Live Video Streaming for Teledriving Using a Single Hardware Encoder
- Host: GitHub
- URL: https://github.com/hofbi/amvs-se
- Owner: hofbi
- License: mit
- Created: 2020-11-03T12:10:52.000Z (about 4 years ago)
- Default Branch: master
- Last Pushed: 2022-11-02T10:18:49.000Z (about 2 years ago)
- Last Synced: 2023-03-06T18:01:42.304Z (almost 2 years ago)
- Language: Python
- Size: 1.58 MB
- Stars: 3
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Single Encoder
[![Actions Status](https://github.com/hofbi/amvs-se/workflows/CI/badge.svg)](https://github.com/hofbi/amvs-se)
[![Actions Status](https://github.com/hofbi/amvs-se/workflows/CodeQL/badge.svg)](https://github.com/hofbi/amvs-se)
[![Code style: black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black)Reference implementation for the experiments of
* [Adaptive Multi-View Live Video Streaming for Teledriving Using a Single Hardware Encoder](#proof-of-concept)
* [Preprocessor Rate Control for Adaptive Multi-View Live Video Streaming Using a Single Encoder](#filter-model)## Publications
If you use this software please cite our publications:
*Preprocessor Rate Control for Adaptive Multi-View Live Video Streaming Using a Single Encoder, Markus Hofbauer, Christopher B. Kuhn, Goran Petrovic, Eckehard Steinbach; TCSVT 2022* [PDF](https://www.researchgate.net/publication/357826860_Preprocessor_Rate_Control_for_Adaptive_Multi-View_Live_Video_Streaming_Using_a_Single_Encoder)
```tex
@article{hofbauer_preprocessor_rc,
author = {Hofbauer, Markus and Kuhn, Christopher B. and Petrovic, Goran and Steinbach, Eckehard},
journal = {IEEE Transactions on Circuits and Systems for Video Technology},
title = {Preprocessor Rate Control for Adaptive Multi-View Live Video Streaming Using a Single Encoder},
year = {2022},
volume = {},
number = {},
pages = {1-16},
doi = {10.1109/TCSVT.2022.3142403}
}
```*Adaptive Multi-View Live Video Streaming for Teledriving Using a Single Hardware Encoder, Markus Hofbauer, Christopher B. Kuhn, Goran Petrovic, Eckehard Steinbach; ISM 2020* [PDF](https://www.researchgate.net/publication/345241096_Adaptive_Multi-View_Live_Video_Streaming_for_Teledriving_Using_a_Single_Hardware_Encoder)
```tex
@inproceedings{hofbauer_single_encoder,
author = {Hofbauer, Markus and Kuhn, Christopher and Petrovic, Goran and Steinbach, Eckehard},
booktitle = {2020 IEEE International Symposium on Multimedia (ISM)},
title = {Adaptive Multi-View Live Video Streaming for Teledriving Using a Single Hardware Encoder},
year = {2020},
volume = {},
number = {},
pages = {9-16},
address = {Naples, Italy},
doi = {10.1109/ISM.2020.00008}
}
```*Measuring the Influence of Image Preprocessing on the Rate-Distortion Performance of Video Encoding, Markus Hofbauer, Christopher B. Kuhn, Goran Petrovic, Eckehard Steinbach; ISM 2022* [PDF](https://www.researchgate.net/publication/)
```tex
@inproceedings{hofbauer_preprocessor_evaluation,
author = {Hofbauer, Markus and Kuhn, Christopher and Petrovic, Goran and Steinbach, Eckehard},
booktitle = {24th 2022 IEEE International Symposium on Multimedia (ISM)},
title = {Measuring the Influence of Image Preprocessing on the Rate-Distortion Performance of Video Encoding},
year = {2022},
volume = {},
number = {},
pages = {},
address = {Naples, Italy},
doi = {}
}
```## Setup
This so far has been tested on
| OS | ROS Version |
| ------------ | ----------- |
| Ubuntu 20.04 | Noetic |1. Install [ROS](http://wiki.ros.org/ROS/Installation) and [catkin_tools](https://catkin-tools.readthedocs.io/en/latest/installing.html#installing-catkin-tools)
1. Create a workspace with e.g. `mkdir -p ~/catkin_ws/src && cd ~/catkin_ws/src`
1. Clone this repository into the workspace's `src` folder with `git clone https://github.com/hofbi/amvs-se.git`
1. Run the install script: `./script/install.sh`
1. Build the workspace: `catkin build`
1. Source your workspace `source ~/catkin_ws_teleop/devel/setup.`## Proof of Concept
### Run
This node is the first prototype implementation to verify the theoretical concept by encoding the data with different filters at Constant Quantization Parameter (CQP).
```shell
roslaunch single_encoder single_encoder.launch
```subscribes to the provided input topics. They will be encoded individually and combined into a single superframe. Before the encoding step different filters will be applied depending on the provided settings. The output of the node is a json file containing statistics from the encoding process. The structure is as follows:
```json
{
"bitrate": 1000,
"chroma_drop": false,
"encoderId": 0,
"encoding_time": [],
"filter": "none-1",
"frame_count": [],
"frame_size": [],
"height": 480,
"mdvqm_scores": [],
"psnr_scores": [],
"skip_frames": 0,
"spatial_activities": [],
"stvqm_scores": [],
"temporal_activities": [],
"timestamp": [],
"topic": "/carla/ego_vehicle/camera/rgb/front/image_color",
"width": 640
}
```### Settings
```shell
image_params: # List of input topics (mux will place them next to each other)
- topic: "/carla/ego_vehicle/camera/rgb/front/image_color"
bitrate: 1000 # Target bitrate if in CBR mode ON
skip_frames: 0 # Number of frames that will be skipped by temporal filter
width: 640 # Width that will be used by spatial filter
height: 480 # Height that will be used by spatial filter
chroma_drop: false # Only keep the luminance channel and drop both chrominance channels
filter: # Low pass filter applied to the image
type: "none" # Filter type (supports )
ksize: 1 # Window size of the filter
sigma: 0.0 # Standard deviation (for Gaussian Filter only)
- ...
```### Evaluation
```shell
roslaunch single_encoder single_encoder_validate.launch
```runs the single encoder launch file and plays a specified rosbag once.
#### Plot Statistics
This script is used to visualize the statistics produced from the node. Usage: `python3 script/evaluation/plot_statistics.py -h`
#### Evaluation Runner
The evaluation runner parses all settings files in a provided folder and runs the evaluation launch file with each of the settings and plots the statistics afterwards. The used json file and the figure saved as png will be stored into the provided folder. Usage: `python3 script/evaluation/evaluation_runner.py -h`
#### Plot Evaluation
Parse all json files in the provided folder, redraw the plots and save the output again as png. Further it calculates the `average.csv` file for all provided config files. This is useful if something at the plot script change but the data are still the same or to compare different filter types. Finally, plots of the average data will be created based on the provided filter. Usage: `python3 script/evaluation/plot_evaluation.py -h`
## Preprocessor Model
Preprocessor model for estimating the preprocessing filter parameter from given encoding parameters. Details in [script/cqp/README.md](script/cqp/README.md).
## Development
To install the additional tools required for the development, call
```shell
python3 -m pip install -r requirements.txt
sudo apt install -y clang-format clang-tidy-10
sudo snap install shfmt
```### pre-commit git hooks
We use [pre-commit](https://pre-commit.com/) to manage our git pre-commit hooks.
`pre-commit` is automatically installed from `requirements.txt`.
To set it up, call```sh
git config --unset-all core.hooksPath # may fail if you don't have any hooks set, but that's ok
pre-commit install --overwrite
```#### Usage
With `pre-commit`, you don't use your linters/formatters directly anymore, but through `pre-commit`:
```sh
pre-commit run --file path/to/file1.cpp tools/second_file.py # run on specific file(s)
pre-commit run --all-files # run on all files tracked by git
pre-commit run --from-ref origin/master --to-ref HEAD # run on all files changed on current branch, compared to master
pre-commit run --file # run specific hook on specific file
```