Change colourspace handling round a bit:
[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 #include "transfer_function.h"
21
22 namespace dcp {
23
24 /** A transfer function which for an input x gives an output y where
25  *
26  *  y = x / B                      for x <= threshold
27  *  y = ((x + A) / (1 + A))^power  for x >  threshold
28  */
29 class ModifiedGammaTransferFunction : public TransferFunction
30 {
31 public:
32         ModifiedGammaTransferFunction (float power, float threshold, float A, float B);
33
34         float power () const {
35                 return _power;
36         }
37
38         float threshold () const {
39                 return _threshold;
40         }
41
42         float A () const {
43                 return _A;
44         }
45
46         float B () const {
47                 return _B;
48         }
49
50         bool about_equal (boost::shared_ptr<const TransferFunction>, float epsilon) const;
51         
52 protected:
53         float * make_lut (int bit_depth) const;
54         
55 private:
56         float _power;
57         float _threshold;
58         float _A;
59         float _B;
60 };
61
62 }