2021-12-18 14:11:39 +01:00

72 lines
1009 B
C++

//
// FILE: FractionFindSum.ino
// AUTHOR: Rob Tillaart
// PURPOSE: demo
// DATE: 13-feb-2015
// URL: https://github.com/RobTillaart/Fraction
//
#include "fraction.h"
uint32_t start;
uint32_t stop;
void setup()
{
pinMode(13, OUTPUT);
Serial.begin(115200);
Serial.print("\n\nStart F: ");
Serial.println(FRACTION_LIB_VERSION);
Serial.println();
randomSeed(analogRead(A0) * 256 + analogRead(A1));
start = micros();
stop = micros();
// Serial.println(stop - start);
for (int i = 1; i < 93; i++)
{
Fraction f(i, 93);
findSum(f);
}
}
void findSum(Fraction f)
{
Fraction z(0, 1);
Serial.print(f);
Serial.print(" =\t ");
for (long i = 1; i < 10000; i++)
{
Fraction g(1, i);
if (g <= f)
{
f -= g;
z += g;
Serial.print(g);
Serial.print(" + ");
}
if (f == Fraction(0, 1))
{
break;
}
}
Serial.print("\t => ");
Serial.println(z);
Serial.println();
}
void loop()
{
}
// -- END OF FILE --