1 // max.h
2 //
3 // Copyright (C) 2003, 2004 Jason Bevins
4 //
5 // This library is free software; you can redistribute it and/or modify it
6 // under the terms of the GNU Lesser General Public License as published by
7 // the Free Software Foundation; either version 2.1 of the License, or (at
8 // your option) any later version.
9 //
10 // This library is distributed in the hope that it will be useful, but WITHOUT
11 // ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
12 // FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public
13 // License (COPYING.txt) for more details.
14 //
15 // You should have received a copy of the GNU Lesser General Public License
16 // along with this library; if not, write to the Free Software Foundation,
17 // Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
18 //
19 // The developer's email is jlbezigvins@gmzigail.com (for great email, take
20 // off every 'zig'.)
21 //
22 module noise.mod.max;
23 
24 private {
25   import noise.mod.modulebase;
26   import noise.misc;
27 }
28 /// @addtogroup libnoise
29 /// @{
30 
31 /// @addtogroup modules
32 /// @{
33 
34 /// @addtogroup combinermodules
35 /// @{
36 
37 /// Noise module that outputs the larger of the two output values from two
38 /// source modules.
39 ///
40 /// @image html modulemax.png
41 ///
42 /// This noise module requires two source modules.
43 class Max : Mod
44 {
45 
46   public:
47 
48     /// Constructor.
49     this()
50     {
51         super(this.GetSourceModCount());
52     }
53 
54     override int GetSourceModCount () const
55     {
56       return 2;
57     }
58 
59     override double GetValue (double x, double y, double z) const
60     {
61       assert (m_pSourceMod[0] !is null);
62       assert (m_pSourceMod[1] !is null);
63 
64       double v0 = m_pSourceMod[0].GetValue (x, y, z);
65       double v1 = m_pSourceMod[1].GetValue (x, y, z);
66       return GetMax (v0, v1);
67     }
68 
69 }
70 
71 /// @}
72 
73 /// @}
74 
75 /// @}