Isis 3 Programmer Reference
Pixel.h
1#ifndef Pixel_h
2#define Pixel_h
8/* SPDX-License-Identifier: CC0-1.0 */
9#include "SpecialPixel.h"
10
11namespace Isis {
48 class Pixel {
49 public:
50 Pixel();
51 Pixel(int sample, int line, int band, double DN);
52 Pixel(const Pixel& pixel);
53 virtual ~Pixel();
54
55
56 Pixel &operator=(const Pixel& other);
57
58 int line() const;
59 int sample() const;
60 int band() const;
61 double DN() const;
62
63 static unsigned char To8Bit(const double d);
64 unsigned char To8Bit();
65 static short int To16Bit(const double d);
66 short int To16Bit();
67 static short unsigned int To16UBit(const double d);
68 short unsigned int To16Ubit();
69 static float To32Bit(const double d);
70 float To32Bit();
71
72 static double ToDouble(const unsigned char t);
73 static double ToDouble(const short int t);
74 static double ToDouble(const short unsigned int t);
75 static double ToDouble(const float t);
76 double ToDouble();
77
78 static float ToFloat(const unsigned char d);
79 static float ToFloat(const short int d);
80 static float ToFloat(const short unsigned int d);
81 static float ToFloat(const double d);
82 float ToFloat();
83
84 static std::string ToString(double d);
85 std::string ToString();
86
95 static inline bool IsSpecial(const double d) {
96 return(d < VALID_MIN8);
97 }
98
105 bool IsSpecial() {
106 return IsSpecial(m_DN);
107 }
108
118 static inline bool IsSpecial(const float f) {
119 return(f < VALID_MIN4);
120 }
121
130 static inline bool IsValid(const double d) {
131 return(d >= VALID_MIN8);
132 }
133
140 bool IsValid() {
141 return IsValid(m_DN);
142 }
143
151 static inline bool IsNull(const double d) {
152 return(d == NULL8);
153 }
154
160 bool IsNull() {
161 return IsNull(m_DN);
162 }
163
171 static inline bool IsHigh(const double d) {
172 return(d == HIGH_REPR_SAT8) || (d == HIGH_INSTR_SAT8);
173 }
174
180 bool IsHigh() {
181 return IsHigh(m_DN);
182 }
183
191 static inline bool IsLow(const double d) {
192 return(d == LOW_REPR_SAT8) || (d == LOW_INSTR_SAT8);
193 }
194
200 bool IsLow() {
201 return IsLow(m_DN);
202 }
203
211 static inline bool IsHrs(const double d) {
212 return(d == HIGH_REPR_SAT8);
213 }
214
220 bool IsHrs() {
221 return IsHrs(m_DN);
222 }
223
231 static inline bool IsHis(const double d) {
232 return(d == HIGH_INSTR_SAT8);
233 }
234
240 bool IsHis() {
241 return IsHis(m_DN);
242 }
243
251 static inline bool IsLis(const double d) {
252 return(d == LOW_INSTR_SAT8);
253 }
254
260 bool IsLis() {
261 return IsLis(m_DN);
262 }
263
271 static inline bool IsLrs(const double d) {
272 return(d == LOW_REPR_SAT8);
273 }
274
280 bool IsLrs() {
281 return IsLrs(m_DN);
282 }
283
284 private:
287
290
293
295 double m_DN;
296
297 }; // end of pixel class
298}
299#endif
Store and/or manipulate pixel values.
Definition Pixel.h:48
virtual ~Pixel()
Default destructor.
Definition Pixel.cpp:76
int m_sample
sample coordinate of pixel
Definition Pixel.h:289
short unsigned int To16Ubit()
Converts internal pixel value to a short int pixel with special pixel translations.
Definition Pixel.cpp:237
Pixel & operator=(const Pixel &other)
Copy assignment operator.
Definition Pixel.cpp:66
unsigned char To8Bit()
Converts internal pixel value to an unsigned char pixel with special pixel translations.
Definition Pixel.cpp:140
static bool IsLow(const double d)
Returns true if the input pixel is one of the low saturation types.
Definition Pixel.h:191
static bool IsHis(const double d)
Returns true if the input pixel is high instrument saturation.
Definition Pixel.h:231
int line() const
Definition Pixel.cpp:80
static bool IsValid(const double d)
Returns true if the input pixel is valid.
Definition Pixel.h:130
std::string ToString()
Returns the name of the pixel type as a string.
Definition Pixel.cpp:488
static bool IsHrs(const double d)
Returns true if the input pixel is high representation saturation.
Definition Pixel.h:211
static bool IsHigh(const double d)
Returns true if the input pixel is one of the high saturation types.
Definition Pixel.h:171
bool IsLis()
Returns true if the input pixel is low instrument saturation.
Definition Pixel.h:260
bool IsHigh()
Returns true if the input pixel is one of the high saturation types.
Definition Pixel.h:180
float To32Bit()
Converts internal pixel value to float with special pixel translations.
Definition Pixel.cpp:267
bool IsValid()
Returns true if the input pixel is valid.
Definition Pixel.h:140
short int To16Bit()
Converts internal pixel value to a short int pixel with special pixel translations.
Definition Pixel.cpp:189
bool IsHis()
Returns true if the input pixel is high instrument saturation.
Definition Pixel.h:240
bool IsSpecial()
Returns true if the input pixel is special.
Definition Pixel.h:105
int m_band
band coordinate of pixel
Definition Pixel.h:292
Pixel()
Constructs an empty Pixel.
Definition Pixel.cpp:18
int sample() const
Definition Pixel.cpp:86
bool IsNull()
Returns true if the input pixel is null.
Definition Pixel.h:160
static bool IsLrs(const double d)
Returns true if the input pixel is low representation saturation.
Definition Pixel.h:271
double m_DN
DN of pixel.
Definition Pixel.h:295
bool IsLrs()
Returns true if the input pixel is low representation saturation.
Definition Pixel.h:280
int m_line
line coordinate of pixel
Definition Pixel.h:286
double ToDouble()
Converts stored pixel value to a double.
Definition Pixel.cpp:359
bool IsHrs()
Returns true if the input pixel is high representation saturation.
Definition Pixel.h:220
static bool IsLis(const double d)
Returns true if the input pixel is low instrument saturation.
Definition Pixel.h:251
static bool IsSpecial(const double d)
Returns true if the input pixel is special.
Definition Pixel.h:95
int band() const
Definition Pixel.cpp:92
static short unsigned int To16UBit(const double d)
Converts double pixels to short unsigned int pixels with special pixel translations.
Definition Pixel.cpp:200
float ToFloat()
Converts internal pixel value to float with pixel translations and care for overflows (underflows are...
Definition Pixel.cpp:457
bool IsLow()
Returns true if the input pixel is one of the low saturation types.
Definition Pixel.h:200
static bool IsSpecial(const float f)
Returns true if the input pixel is special.
Definition Pixel.h:118
static bool IsNull(const double d)
Returns true if the input pixel is null.
Definition Pixel.h:151
double DN() const
Definition Pixel.cpp:98
This is free and unencumbered software released into the public domain.
Definition Apollo.h:16