2015-03-01 12:03:22 +01:00
|
|
|
//
|
|
|
|
// FILE: fraction.h
|
|
|
|
// AUTHOR: Rob Tillaart
|
2015-03-05 18:26:06 +01:00
|
|
|
// VERSION: 0.1.07
|
2015-03-01 12:03:22 +01:00
|
|
|
// PURPOSE: demo library for fractions for Arduino
|
|
|
|
// URL:
|
|
|
|
//
|
|
|
|
// Released to the public domain
|
|
|
|
//
|
|
|
|
|
|
|
|
#ifndef Fraction_h
|
|
|
|
#define Fraction_h
|
|
|
|
|
|
|
|
#include "Arduino.h"
|
|
|
|
|
2015-03-05 18:26:06 +01:00
|
|
|
#define FRACTIONLIBVERSION "0.1.07"
|
2015-03-01 12:03:22 +01:00
|
|
|
|
|
|
|
class Fraction: public Printable
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
Fraction(double);
|
|
|
|
Fraction(int32_t, int32_t);
|
2015-03-05 17:46:55 +10:00
|
|
|
Fraction(int32_t p) : n(p), d(1) {}
|
|
|
|
Fraction(int16_t p) : n(p), d(1) {}
|
|
|
|
Fraction(int8_t p) : n(p), d(1) {}
|
|
|
|
Fraction(uint32_t p) : n(p), d(1) {}
|
|
|
|
Fraction(uint16_t p) : n(p), d(1) {}
|
|
|
|
Fraction(uint8_t p) : n(p), d(1) {}
|
2015-03-05 18:26:06 +01:00
|
|
|
Fraction(const Fraction &f) : n(f.n), d(f.d) {}
|
2015-03-01 12:03:22 +01:00
|
|
|
|
|
|
|
size_t printTo(Print& p) const;
|
|
|
|
|
2015-03-01 12:15:35 +01:00
|
|
|
// equalities
|
2015-03-05 17:42:23 +10:00
|
|
|
bool operator == (const Fraction&);
|
|
|
|
bool operator != (const Fraction&);
|
|
|
|
bool operator > (const Fraction&);
|
|
|
|
bool operator >= (const Fraction&);
|
|
|
|
bool operator < (const Fraction&);
|
|
|
|
bool operator <= (const Fraction&);
|
2015-03-01 12:03:22 +01:00
|
|
|
|
2015-03-01 12:15:35 +01:00
|
|
|
// negation
|
|
|
|
Fraction operator - ();
|
2015-03-01 12:03:22 +01:00
|
|
|
|
2015-03-01 12:47:02 +01:00
|
|
|
// basic math
|
2015-03-05 17:42:23 +10:00
|
|
|
Fraction operator + (const Fraction&);
|
|
|
|
Fraction operator - (const Fraction&);
|
|
|
|
Fraction operator * (const Fraction&);
|
|
|
|
Fraction operator / (const Fraction&);
|
2015-03-01 12:03:22 +01:00
|
|
|
|
2015-03-05 17:42:23 +10:00
|
|
|
Fraction& operator += (const Fraction&);
|
|
|
|
Fraction& operator -= (const Fraction&);
|
|
|
|
Fraction& operator *= (const Fraction&);
|
|
|
|
Fraction& operator /= (const Fraction&);
|
2015-03-01 12:03:22 +01:00
|
|
|
|
2015-03-01 12:11:21 +01:00
|
|
|
double toDouble();
|
2015-03-01 12:47:02 +01:00
|
|
|
bool isProper(); // abs(f) < 1
|
|
|
|
double toAngle();
|
|
|
|
|
2015-03-05 18:06:21 +10:00
|
|
|
static Fraction mediant(const Fraction&, const Fraction&);
|
2015-03-01 12:47:02 +01:00
|
|
|
// approximate a fraction with defined denominator
|
2015-03-05 18:06:21 +10:00
|
|
|
static Fraction setDenominator(const Fraction&, uint16_t);
|
2015-03-01 12:47:02 +01:00
|
|
|
|
2015-03-01 12:11:21 +01:00
|
|
|
|
2015-03-05 18:06:21 +10:00
|
|
|
protected:
|
2015-03-01 12:03:22 +01:00
|
|
|
void simplify();
|
|
|
|
double fractionize(double);
|
2015-03-05 18:29:58 +10:00
|
|
|
int32_t gcd(int32_t, int32_t);
|
2015-03-01 12:03:22 +01:00
|
|
|
|
|
|
|
int32_t n;
|
|
|
|
int32_t d;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|
2015-03-01 12:05:22 +01:00
|
|
|
//
|
2015-03-01 12:11:21 +01:00
|
|
|
// -- END OF FILE --
|
|
|
|
//
|