jackychen | 8f9902a | 2015-11-26 02:59:48 -0800 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (c) 2015 The WebRTC project authors. All Rights Reserved. |
| 3 | * |
| 4 | * Use of this source code is governed by a BSD-style license |
| 5 | * that can be found in the LICENSE file in the root of the source |
| 6 | * tree. An additional intellectual property rights grant can be found |
| 7 | * in the file PATENTS. All contributing project authors may |
| 8 | * be found in the AUTHORS file in the root of the source tree. |
| 9 | */ |
| 10 | |
| 11 | #ifndef WEBRTC_MODULES_VIDEO_PROCESSING_VIDEO_DENOISER_H_ |
| 12 | #define WEBRTC_MODULES_VIDEO_PROCESSING_VIDEO_DENOISER_H_ |
| 13 | |
kwiberg | e065fcf | 2016-03-02 01:01:11 -0800 | [diff] [blame] | 14 | #include <memory> |
| 15 | |
jackychen | 8f9902a | 2015-11-26 02:59:48 -0800 | [diff] [blame] | 16 | #include "webrtc/modules/video_processing/util/denoiser_filter.h" |
jackychen | fa0befe | 2016-04-01 07:46:58 -0700 | [diff] [blame] | 17 | #include "webrtc/modules/video_processing/util/noise_estimation.h" |
jackychen | 8f9902a | 2015-11-26 02:59:48 -0800 | [diff] [blame] | 18 | #include "webrtc/modules/video_processing/util/skin_detection.h" |
| 19 | |
| 20 | namespace webrtc { |
| 21 | |
| 22 | class VideoDenoiser { |
| 23 | public: |
jackychen | 67e94fb | 2016-01-11 21:34:07 -0800 | [diff] [blame] | 24 | explicit VideoDenoiser(bool runtime_cpu_detection); |
jackychen | afaae0d | 2016-04-12 23:02:55 -0700 | [diff] [blame] | 25 | |
Niels Möller | 6af2e86 | 2016-06-17 09:12:44 +0200 | [diff] [blame^] | 26 | // TODO(nisse): Let the denoised_frame and denoised_frame_prev be |
| 27 | // member variables referencing two I420Buffer, and return a refptr |
| 28 | // to the current one. When we also move the double-buffering logic |
| 29 | // from the caller. |
| 30 | void DenoiseFrame(const rtc::scoped_refptr<VideoFrameBuffer>& frame, |
| 31 | // Buffers are allocated/replaced when dimensions |
| 32 | // change. |
| 33 | rtc::scoped_refptr<I420Buffer>* denoised_frame, |
| 34 | rtc::scoped_refptr<I420Buffer>* denoised_frame_prev, |
jackychen | afaae0d | 2016-04-12 23:02:55 -0700 | [diff] [blame] | 35 | bool noise_estimation_enabled); |
jackychen | 8f9902a | 2015-11-26 02:59:48 -0800 | [diff] [blame] | 36 | |
| 37 | private: |
Niels Möller | 6af2e86 | 2016-06-17 09:12:44 +0200 | [diff] [blame^] | 38 | void DenoiserReset(const rtc::scoped_refptr<VideoFrameBuffer>& frame, |
| 39 | rtc::scoped_refptr<I420Buffer>* denoised_frame, |
| 40 | rtc::scoped_refptr<I420Buffer>* denoised_frame_prev); |
jackychen | afaae0d | 2016-04-12 23:02:55 -0700 | [diff] [blame] | 41 | |
| 42 | // Check the mb position, return 1: close to the frame center (between 1/8 |
| 43 | // and 7/8 of width/height), 3: close to the border (out of 1/16 and 15/16 |
| 44 | // of width/height), 2: in between. |
| 45 | int PositionCheck(int mb_row, int mb_col, int noise_level); |
| 46 | |
| 47 | // To reduce false detection in moving object detection (MOD). |
| 48 | void ReduceFalseDetection(const std::unique_ptr<uint8_t[]>& d_status, |
| 49 | std::unique_ptr<uint8_t[]>* d_status_red, |
| 50 | int noise_level); |
| 51 | |
| 52 | // Return whether a block might cause trailing artifact by checking if one of |
| 53 | // its neighbor blocks is a moving edge block. |
| 54 | bool IsTrailingBlock(const std::unique_ptr<uint8_t[]>& d_status, |
| 55 | int mb_row, |
| 56 | int mb_col); |
| 57 | |
| 58 | // Copy input blocks to dst buffer on moving object blocks (MOB). |
| 59 | void CopySrcOnMOB(const uint8_t* y_src, uint8_t* y_dst); |
| 60 | |
jackychen | 6650d6d | 2016-04-25 16:53:59 -0700 | [diff] [blame] | 61 | // Copy luma margin blocks when frame width/height not divisible by 16. |
| 62 | void CopyLumaOnMargin(const uint8_t* y_src, uint8_t* y_dst); |
| 63 | |
jackychen | 8f9902a | 2015-11-26 02:59:48 -0800 | [diff] [blame] | 64 | int width_; |
| 65 | int height_; |
jackychen | afaae0d | 2016-04-12 23:02:55 -0700 | [diff] [blame] | 66 | int mb_rows_; |
| 67 | int mb_cols_; |
| 68 | int stride_y_; |
| 69 | int stride_u_; |
| 70 | int stride_v_; |
jackychen | fa0befe | 2016-04-01 07:46:58 -0700 | [diff] [blame] | 71 | CpuType cpu_type_; |
kwiberg | e065fcf | 2016-03-02 01:01:11 -0800 | [diff] [blame] | 72 | std::unique_ptr<DenoiserFilter> filter_; |
jackychen | fa0befe | 2016-04-01 07:46:58 -0700 | [diff] [blame] | 73 | std::unique_ptr<NoiseEstimation> ne_; |
jackychen | afaae0d | 2016-04-12 23:02:55 -0700 | [diff] [blame] | 74 | // 1 for moving edge block, 0 for static block. |
| 75 | std::unique_ptr<uint8_t[]> moving_edge_; |
| 76 | // 1 for moving object block, 0 for static block. |
| 77 | std::unique_ptr<uint8_t[]> moving_object_; |
| 78 | // x_density_ and y_density_ are used in MOD process. |
jackychen | fa0befe | 2016-04-01 07:46:58 -0700 | [diff] [blame] | 79 | std::unique_ptr<uint8_t[]> x_density_; |
| 80 | std::unique_ptr<uint8_t[]> y_density_; |
jackychen | afaae0d | 2016-04-12 23:02:55 -0700 | [diff] [blame] | 81 | // Save the return values by MbDenoise for each block. |
| 82 | std::unique_ptr<DenoiserDecision[]> mb_filter_decision_; |
jackychen | 8f9902a | 2015-11-26 02:59:48 -0800 | [diff] [blame] | 83 | }; |
| 84 | |
| 85 | } // namespace webrtc |
| 86 | |
| 87 | #endif // WEBRTC_MODULES_VIDEO_PROCESSING_VIDEO_DENOISER_H_ |