Chromium Code Reviews| Index: webrtc/tools/frame_analyzer/reference_less_video_analysis_lib.h |
| diff --git a/webrtc/tools/frame_analyzer/reference_less_video_analysis_lib.h b/webrtc/tools/frame_analyzer/reference_less_video_analysis_lib.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..2fa0898c3242ac24d1deeb9552d5a17937cdc127 |
| --- /dev/null |
| +++ b/webrtc/tools/frame_analyzer/reference_less_video_analysis_lib.h |
| @@ -0,0 +1,50 @@ |
| +/* |
| + * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. |
| + * |
| + * Use of this source code is governed by a BSD-style license |
| + * that can be found in the LICENSE file in the root of the source |
| + * tree. An additional intellectual property rights grant can be found |
| + * in the file PATENTS. All contributing project authors may |
| + * be found in the AUTHORS file in the root of the source tree. |
| + */ |
| + |
| +#ifndef WEBRTC_TOOLS_FRAME_ANALYZER_REFERENCE_LESS_VIDEO_ANALYSIS_LIB_H_ |
| +#define WEBRTC_TOOLS_FRAME_ANALYZER_REFERENCE_LESS_VIDEO_ANALYSIS_LIB_H_ |
| + |
| +#include <string> |
| +#include <vector> |
| + |
|
mandermo
2017/02/07 14:57:50
Using _ in function names is different from the ot
kjellander_webrtc
2017/02/08 09:11:31
You're right, the style guide says CamelCase: http
|
| +// Parse the file header to extract height, width and fps |
| +// for a given video file. |
| +void get_height_width_fps(int *height, int *width, int *fps, |
| + const std::string& video_file); |
| + |
| +// Returns true if the frame is frozen based on psnr and ssim freezing |
| +// threshold values. |
| +bool frozen_frame(std::vector<double> psnr_per_frame, |
| + std::vector<double> ssim_per_frame, size_t frame); |
| + |
| +// Returns the vector of identical cluster of frames that are frozen |
| +// and appears continuously. |
| +std::vector<int> find_frame_clusters(const std::vector<double>& psnr_per_frame, |
| + const std::vector<double>& ssim_per_frame); |
| + |
| +// Prints various freezing metrics like identical frames, |
| +// total unique frames etc. |
| +void print_freezing_metrics(const std::vector<double>& psnr_per_frame, |
| + const std::vector<double>& ssim_per_frame); |
| + |
| +// Compute the metrics like freezing score based on PSNR and SSIM values for a |
| +// given video file. |
| +void compute_metrics(const std::string& video_file_name, |
| + std::vector<double>* psnr_per_frame, |
| + std::vector<double>* ssim_per_frame); |
| + |
| +// Checks the file extension and return true if it is y4m. |
| +bool check_file_extension(const std::string& video_file_name); |
| + |
| +// Compute freezing score metrics and prints the metrics |
| +// for a list of video files. |
| +int run_analysis(const std::string& video_file); |
|
mandermo
2017/02/07 14:57:51
Maybe it could be worth putting the functions in t
kjellander_webrtc
2017/02/08 09:11:32
Yes, please use the webrtc::test namespace.
|
| + |
| +#endif // WEBRTC_TOOLS_FRAME_ANALYZER_REFERENCE_LESS_VIDEO_ANALYSIS_LIB_H_ |