[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <504A4114.5010106@iki.fi>
Date: Fri, 07 Sep 2012 21:46:44 +0300
From: Sakari Ailus <sakari.ailus@....fi>
To: Prabhakar Lad <prabhakar.lad@...com>
CC: LMML <linux-media@...r.kernel.org>,
dlos <davinci-linux-open-source@...ux.davincidsp.com>,
linux-kernel@...r.kernel.org,
Manjunath Hadli <manjunath.hadli@...com>,
Laurent Pinchart <laurent.pinchart@...asonboard.com>,
linux-doc@...r.kernel.org, Hans Verkuil <hans.verkuil@...co.com>,
Sylwester Nawrocki <s.nawrocki@...sung.com>,
Mauro Carvalho Chehab <mchehab@...radead.org>,
Hans de Goede <hdegoede@...hat.com>,
Kyungmin Park <kyungmin.park@...sung.com>,
Rob Landley <rob@...dley.net>
Subject: Re: [PATCH v4] media: v4l2-ctrls: add control for dpcm predictor
Hi Prabhakar,
Prabhakar Lad wrote:
> Hi Sakari,
>
> Thanks for the review.
>
> On Wednesday 05 September 2012 12:42 AM, Sakari Ailus wrote:
>> Hi Prabhakar,
>>
>> Thanks for the patch. I've got a few comments below.
>>
>> On Tue, Sep 04, 2012 at 11:07:52AM +0530, Prabhakar Lad wrote:
>>> From: Lad, Prabhakar <prabhakar.lad@...com>
>>>
>>> add V4L2_CID_DPCM_PREDICTOR control of type menu, which
>>> determines the dpcm predictor. The predictor can be either
>>> simple or advanced.
>>>
>>> Signed-off-by: Lad, Prabhakar <prabhakar.lad@...com>
>>> Signed-off-by: Manjunath Hadli <manjunath.hadli@...com>
>>> Acked-by: Hans Verkuil <hans.verkuil@...co.com>
>>> Reviewed-by: Sylwester Nawrocki <s.nawrocki@...sung.com>
>>> Cc: Sakari Ailus <sakari.ailus@....fi>
>>> Cc: Laurent Pinchart <laurent.pinchart@...asonboard.com>
>>> Cc: Mauro Carvalho Chehab <mchehab@...radead.org>
>>> Cc: Hans de Goede <hdegoede@...hat.com>
>>> Cc: Kyungmin Park <kyungmin.park@...sung.com>
>>> Cc: Rob Landley <rob@...dley.net>
>>> ---
>>> This patches has one checkpatch warning for line over
>>> 80 characters altough it can be avoided I have kept it
>>> for consistency.
>>>
>>> Changes for v4:
>>> 1: Aligned the description to fit appropriately in the
>>> para tag, pointed by Sylwester.
>>>
>>> Changes for v3:
>>> 1: Added better explanation for DPCM, pointed by Hans.
>>>
>>> Changes for v2:
>>> 1: Added documentaion in controls.xml pointed by Sylwester.
>>> 2: Chnaged V4L2_DPCM_PREDICTOR_ADVANCE to V4L2_DPCM_PREDICTOR_ADVANCED
>>> pointed by Sakari.
>>>
>>> Documentation/DocBook/media/v4l/controls.xml | 46 +++++++++++++++++++++++++-
>>> drivers/media/v4l2-core/v4l2-ctrls.c | 9 +++++
>>> include/linux/videodev2.h | 5 +++
>>> 3 files changed, 59 insertions(+), 1 deletions(-)
>>>
>>> diff --git a/Documentation/DocBook/media/v4l/controls.xml b/Documentation/DocBook/media/v4l/controls.xml
>>> index 93b9c68..ad873ea 100644
>>> --- a/Documentation/DocBook/media/v4l/controls.xml
>>> +++ b/Documentation/DocBook/media/v4l/controls.xml
>>> @@ -4267,7 +4267,51 @@ interface and may change in the future.</para>
>>> pixels / second.
>>> </entry>
>>> </row>
>>> - <row><entry></entry></row>
>>> + <row>
>>> + <entry spanname="id"><constant>V4L2_CID_DPCM_PREDICTOR</constant></entry>
>>> + <entry>menu</entry>
>>> + </row>
>>> + <row id="v4l2-dpcm-predictor">
>>> + <entry spanname="descr"> Differential pulse-code modulation (DPCM) is a signal
>>> + encoder that uses the baseline of pulse-code modulation (PCM) but adds some
>>> + functionalities based on the prediction of the samples of the signal. The input
>>> + can be an analog signal or a digital signal.
>>> +
>>> + <para>If the input is a continuous-time analog signal, it needs to be sampled
>>> + first so that a discrete-time signal is the input to the DPCM encoder.</para>
>>> +
>>> + <para>Simple: take the values of two consecutive samples; if they are analog
>>> + samples, quantize them; calculate the difference between the first one and the
>>> + next; the output is the difference, and it can be further entropy coded.</para>
>>> +
>>> + <para>Advanced: instead of taking a difference relative to a previous input sample,
>>> + take the difference relative to the output of a local model of the decoder process;
>>> + in this option, the difference can be quantized, which allows a good way to
>>> + incorporate a controlled loss in the encoding.</para>
>>
>> This is directly from Wikipedia, isn't it?
>>
> Yes.
>
>> What comes to the content, DPCM in the context of V4L2 media bus codes, as a
>> digital interface, is always digital. So there's no need to document it.
>> Entropy coding is also out of the question: the samples of the currently
>> defined formats are equal in size.
>>
> Ok.
Could you replace the above with this text (with appropriate indentation
etc.) while keeping the reference to Wikipedia?
------8<------
Differential pulse-code modulation (DPCM) compression can be used to
compress the samples into fewer bits than they would otherwise require.
This is done by calculating the difference between consecutive samples
and outputting the difference which in average is much smaller than the
values of the samples themselves since there is generally lots of
correlation between adjacent pixels. In decompression the original
samples are reconstructed. The process isn't lossless as the encoded
sample size in bits is less than the original.
Formats using DPCM compression include <xref
linkend="pixfmt-srggb10dpcm8" />.
This control is used to select the predictor used to encode the samples.
The main difference between the simple and the advanced predictors is
image quality, with advanced predictor supposed to produce better
quality images as a result. Simple predictor can be used e.g. for
testing purposes.
------8<------
Kind regards,
--
Sakari Ailus
sakari.ailus@....fi
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists