No-op: whitespace.
[libdcp.git] / src / modified_gamma_transfer_function.h
1 /*
2     Copyright (C) 2012-2014 Carl Hetherington <cth@carlh.net>
3
4     This program is free software; you can redistribute it and/or modify
5     it under the terms of the GNU General Public License as published by
6     the Free Software Foundation; either version 2 of the License, or
7     (at your option) any later version.
8
9     This program is distributed in the hope that it will be useful,
10     but WITHOUT ANY WARRANTY; without even the implied warranty of
11     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12     GNU General Public License for more details.
13
14     You should have received a copy of the GNU General Public License
15     along with this program; if not, write to the Free Software
16     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
17
18 */
19
20 /** @file  src/modified_gamma_transfer_function.h
21  *  @brief ModifiedGammaTransferFunction class.
22  */
23
24 #include "transfer_function.h"
25
26 namespace dcp {
27
28 /** A transfer function which for an input x gives an output y where
29  *
30  *  y = x / B                      for x <= threshold
31  *  y = ((x + A) / (1 + A))^power  for x >  threshold
32  */
33 class ModifiedGammaTransferFunction : public TransferFunction
34 {
35 public:
36         ModifiedGammaTransferFunction (double power, double threshold, double A, double B);
37
38         double power () const {
39                 return _power;
40         }
41
42         double threshold () const {
43                 return _threshold;
44         }
45
46         double A () const {
47                 return _A;
48         }
49
50         double B () const {
51                 return _B;
52         }
53
54         bool about_equal (boost::shared_ptr<const TransferFunction>, double epsilon) const;
55
56 protected:
57         double * make_lut (int bit_depth, bool inverse) const;
58
59 private:
60         double _power;
61         double _threshold;
62         double _A;
63         double _B;
64 };
65
66 }