89 lines
1.6 KiB
Arduino
Raw Normal View History

2020-11-27 11:10:47 +01:00
// FILE: Fibonacci.ino
// AUTHOR: Rob Tillaart
// DATE: 2018-03-05
2023-02-08 14:03:23 +01:00
// PURPOSE: Generate Fibonacci numbers with bit array
2021-10-19 16:11:27 +02:00
// URL: https://github.com/RobTillaart/BitArray
2020-11-27 11:10:47 +01:00
// URL: https://forum.arduino.cc/index.php?topic=532760.0
#include "BitArray.h"
2023-02-08 14:03:23 +01:00
2020-11-27 11:10:47 +01:00
#define NR 70
BitArray a;
BitArray b;
2021-10-19 16:11:27 +02:00
2020-11-27 11:10:47 +01:00
void setup()
{
Serial.begin(230400);
2023-02-08 14:03:23 +01:00
// 10 bit can hold 3 digits 000..999 (1000 with overflow)
// 10 bits give effective use of 1000/1024 = 97%
2020-11-27 11:10:47 +01:00
int x = a.begin(10, NR);
if (x != 0) Serial.println(x);
x = b.begin(10, NR);
if (x != 0) Serial.println(x);
a.clear();
b.clear();
b.set(0, 1);
uint32_t start = millis();
for (int x = 0; x <= 1000; x++)
{
{
Serial.print(x);
Serial.write('\t');
for (int16_t i = NR - 1; i >= 0; i--)
{
uint32_t t = a.get(i);
if (t < 100) Serial.write('0');
if (t < 10) Serial.write('0');
Serial.print(t);
}
Serial.write('\n');
}
add();
}
Serial.println(millis() - start);
}
2021-10-19 16:11:27 +02:00
2020-11-27 11:10:47 +01:00
void loop()
{}
2021-10-19 16:11:27 +02:00
2023-02-08 14:03:23 +01:00
// add numbers in groups of 3 digits
2020-11-27 11:10:47 +01:00
void add()
{
uint8_t carry = 0;
for (uint16_t i = 0; i <= NR; i++)
{
uint16_t ta = a.get(i);
uint16_t tb = b.get(i);
2023-02-08 14:03:23 +01:00
// if there is nothing to add, skip column
2020-11-27 11:10:47 +01:00
if (ta == 0 && tb == 0 && carry == 0) continue;
2023-02-08 14:03:23 +01:00
// do the add
2020-11-27 11:10:47 +01:00
uint16_t tc = ta + tb + carry;
2023-02-08 14:03:23 +01:00
// does column overflow? then correct
2020-11-27 11:10:47 +01:00
if (tc > 999)
{
tc -= 1000;
2023-02-08 14:03:23 +01:00
carry = 1; // carry for next column
2020-11-27 11:10:47 +01:00
}
else carry = 0;
b.set(i, tc);
a.set(i, tb);
}
}
2021-10-19 16:11:27 +02:00
2023-02-08 14:03:23 +01:00
// -- END OF FILE --