mirror of
https://github.com/RobTillaart/Arduino.git
synced 2024-10-03 18:09:02 -04:00
137 lines
2.5 KiB
C++
137 lines
2.5 KiB
C++
//
|
|
// FILE: bitArrayDemo3.ino
|
|
// AUTHOR: Rob Tillaart
|
|
// PURPOSE: demo performance bit array
|
|
// DATE: 2017-07-15
|
|
// URL: https://github.com/RobTillaart/BitArray
|
|
// URL: https://forum.arduino.cc/index.php?topic=361167.0
|
|
|
|
|
|
#include "BitArray.h"
|
|
|
|
|
|
BitArray b;
|
|
|
|
uint32_t start;
|
|
uint32_t stop;
|
|
volatile int32_t x = 0;
|
|
|
|
|
|
void setup()
|
|
{
|
|
Serial.begin(115200);
|
|
Serial.print("Start ");
|
|
Serial.println(__FILE__);
|
|
Serial.print("LIB VERSION:\t");
|
|
Serial.println(BITARRAY_LIB_VERSION);
|
|
|
|
test(1, 10000);
|
|
test(2, 5000);
|
|
test(3, 3333);
|
|
test(4, 2500);
|
|
}
|
|
|
|
|
|
void test(uint8_t bits, uint16_t cnt)
|
|
{
|
|
b.begin(bits, cnt);
|
|
Serial.print("CAPACITY:\t");
|
|
Serial.println(b.capacity());
|
|
Serial.print(" MEMORY:\t");
|
|
Serial.println(b.memory());
|
|
Serial.print(" BITS:\t");
|
|
Serial.println(b.bits());
|
|
Serial.print("SEGMENTS:\t");
|
|
Serial.println(b.segments());
|
|
delay(100);
|
|
|
|
|
|
Serial.println("\nGET:");
|
|
start = micros();
|
|
for (uint16_t i = 0; i < cnt; i++)
|
|
{
|
|
x += b.get(i);
|
|
}
|
|
stop = micros();
|
|
Serial.print("DURATION:\t");
|
|
Serial.println(stop - start);
|
|
delay(100);
|
|
|
|
start = micros();
|
|
for (uint16_t i = 0; i < cnt; i++)
|
|
{
|
|
x += b.get(i);
|
|
x += b.get(i);
|
|
}
|
|
stop = micros();
|
|
Serial.print("DURATION:\t");
|
|
Serial.println(stop - start);
|
|
Serial.print(" X:\t");
|
|
Serial.println(x);
|
|
delay(100);
|
|
|
|
Serial.println("\nSET:");
|
|
start = micros();
|
|
for (uint16_t i = 0; i < cnt; i++)
|
|
{
|
|
b.set(i, 0);
|
|
}
|
|
stop = micros();
|
|
Serial.print("DURATION:\t");
|
|
Serial.println(stop - start);
|
|
delay(100);
|
|
|
|
start = micros();
|
|
for (uint16_t i = 0; i < cnt; i++)
|
|
{
|
|
b.set(i, 0);
|
|
b.set(i, 0);
|
|
}
|
|
stop = micros();
|
|
Serial.print("DURATION:\t");
|
|
Serial.println(stop - start);
|
|
delay(100);
|
|
|
|
Serial.println("\nCLEAR:");
|
|
start = micros();
|
|
b.clear();
|
|
stop = micros();
|
|
Serial.print("DURATION:\t");
|
|
Serial.println(stop - start);
|
|
delay(100);
|
|
|
|
Serial.println("\nTOGGLE:");
|
|
start = micros();
|
|
for (uint16_t i = 0; i < cnt; i++)
|
|
{
|
|
b.toggle(i);
|
|
}
|
|
stop = micros();
|
|
Serial.print("DURATION:\t");
|
|
Serial.println(stop - start);
|
|
delay(100);
|
|
|
|
start = micros();
|
|
for (uint16_t i = 0; i < cnt; i++)
|
|
{
|
|
b.toggle(i);
|
|
b.toggle(i);
|
|
}
|
|
stop = micros();
|
|
Serial.print("DURATION:\t");
|
|
Serial.println(stop - start);
|
|
delay(100);
|
|
|
|
|
|
Serial.println("Done...");
|
|
}
|
|
|
|
|
|
void loop()
|
|
{
|
|
}
|
|
|
|
|
|
// -- END OF FILE --
|
|
|