1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107
|
// ==========================================================
// Helper class for rational numbers
//
// Design and implementation by
// - Herv Drolon <drolon@infonie.fr>
//
// This file is part of FreeImage 3
//
// COVERED CODE IS PROVIDED UNDER THIS LICENSE ON AN "AS IS" BASIS, WITHOUT WARRANTY
// OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, WITHOUT LIMITATION, WARRANTIES
// THAT THE COVERED CODE IS FREE OF DEFECTS, MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE
// OR NON-INFRINGING. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE COVERED
// CODE IS WITH YOU. SHOULD ANY COVERED CODE PROVE DEFECTIVE IN ANY RESPECT, YOU (NOT
// THE INITIAL DEVELOPER OR ANY OTHER CONTRIBUTOR) ASSUME THE COST OF ANY NECESSARY
// SERVICING, REPAIR OR CORRECTION. THIS DISCLAIMER OF WARRANTY CONSTITUTES AN ESSENTIAL
// PART OF THIS LICENSE. NO USE OF ANY COVERED CODE IS AUTHORIZED HEREUNDER EXCEPT UNDER
// THIS DISCLAIMER.
//
// Use at your own risk!
// ==========================================================
#ifndef FIRATIONAL_H
#define FIRATIONAL_H
/**
Helper class to deal with rational numbers
*/
class FIRational {
private:
/// numerator
long _numerator;
/// denominator
long _denominator;
public:
/// Default constructor
FIRational();
/// Constructor with longs
FIRational(long n, long d = 1);
/// Constructor with FITAG
FIRational(const FITAG *tag);
/// Constructor with a float
FIRational(float value);
/// Copy constructor
FIRational (const FIRational& r);
/// Destructor
~FIRational();
/// Assignement operator
FIRational& operator=(FIRational& r);
/// Get the numerator
long getNumerator();
/// Get the denominator
long getDenominator();
/// Converts rational value by truncating towards zero
long truncate() {
// Return truncated rational
return _denominator ? (long) (_numerator / _denominator) : 0;
}
/**@name Implicit conversions */
//@{
short shortValue() {
return (short)truncate();
}
int intValue() {
return (int)truncate();
}
long longValue() {
return (long)truncate();
}
float floatValue() {
return _denominator ? ((float)_numerator)/((float)_denominator) : 0;
}
double doubleValue() {
return _denominator ? ((double)_numerator)/((double)_denominator) : 0;
}
//@}
/// Checks if this rational number is an integer, either positive or negative
BOOL isInteger();
/// Convert as "numerator/denominator"
std::string toString();
private:
/// Initialize and normalize a rational number
void initialize(long n, long d);
/// Calculate GCD
long gcd(long a, long b);
/// Normalize numerator / denominator
void normalize();
};
#endif // FIRATIONAL_H
|