2014-11-18 13:28:12 -05:00
|
|
|
//
|
|
|
|
// FILE: allTest.ino
|
|
|
|
// AUTHOR: Rob Tillaart
|
|
|
|
// PURPOSE: demo/test Set class
|
|
|
|
// DATE: 2014-11-16
|
2021-01-29 06:31:58 -05:00
|
|
|
// URL: https://github.com/RobTillaart/SET
|
|
|
|
|
2014-11-18 13:28:12 -05:00
|
|
|
|
2020-11-27 05:33:55 -05:00
|
|
|
#include "set.h"
|
2014-11-18 13:28:12 -05:00
|
|
|
|
2021-01-29 06:31:58 -05:00
|
|
|
|
2014-11-18 13:28:12 -05:00
|
|
|
Set setA, setB;
|
|
|
|
volatile bool b;
|
|
|
|
|
2020-11-27 05:33:55 -05:00
|
|
|
uint32_t start, stop;
|
|
|
|
|
2014-11-18 13:28:12 -05:00
|
|
|
void setup()
|
|
|
|
{
|
|
|
|
Serial.begin(115200);
|
|
|
|
Serial.print("Start set_demo : ");
|
|
|
|
Serial.println(SET_LIB_VERSION);
|
|
|
|
Serial.println();
|
|
|
|
|
|
|
|
timingTest();
|
|
|
|
equalTest();
|
|
|
|
intersectionTest();
|
|
|
|
intersection2Test();
|
|
|
|
subsetTest();
|
|
|
|
iterationTest();
|
|
|
|
|
|
|
|
Serial.println("done...");
|
|
|
|
Serial.println();
|
|
|
|
}
|
|
|
|
|
2021-12-28 04:38:33 -05:00
|
|
|
|
2014-11-18 13:28:12 -05:00
|
|
|
void loop()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2021-12-28 04:38:33 -05:00
|
|
|
|
2014-11-18 13:28:12 -05:00
|
|
|
void timingTest()
|
|
|
|
{
|
|
|
|
Set myset;
|
|
|
|
|
|
|
|
Serial.println("TIMING TEST");
|
2021-01-29 06:31:58 -05:00
|
|
|
Serial.print("100x clear():\t");
|
2020-11-27 05:33:55 -05:00
|
|
|
start = micros();
|
2021-01-29 06:31:58 -05:00
|
|
|
for (uint8_t i = 0; i < 100; i++) myset.clear();
|
2020-11-27 05:33:55 -05:00
|
|
|
stop = micros();
|
|
|
|
Serial.println(stop - start);
|
2014-11-18 13:28:12 -05:00
|
|
|
|
|
|
|
Serial.print("100x add():\t");
|
|
|
|
start = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
for (uint8_t i = 0; i < 100; i++) myset.add(i);
|
2014-11-18 13:28:12 -05:00
|
|
|
stop = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
Serial.println(stop - start);
|
2014-11-18 13:28:12 -05:00
|
|
|
|
|
|
|
Serial.print("100x sub():\t");
|
|
|
|
start = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
for (uint8_t i = 0; i < 100; i++) myset.sub(i);
|
2014-11-18 13:28:12 -05:00
|
|
|
stop = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
Serial.println(stop - start);
|
2014-11-18 13:28:12 -05:00
|
|
|
|
|
|
|
Serial.print("100x has():\t");
|
|
|
|
start = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
for (uint8_t i = 0; i < 100; i++) b = myset.has(i);
|
2014-11-18 13:28:12 -05:00
|
|
|
stop = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
Serial.println(stop - start);
|
2014-11-18 13:28:12 -05:00
|
|
|
|
|
|
|
Serial.print("100x invert(v):\t");
|
|
|
|
start = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
for (uint8_t i = 0; i < 100; i++) myset.invert(i);
|
2014-11-18 13:28:12 -05:00
|
|
|
stop = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
Serial.println(stop - start);
|
2014-11-18 13:28:12 -05:00
|
|
|
|
|
|
|
Serial.print("invert():\t");
|
|
|
|
start = micros();
|
|
|
|
myset.invert();
|
|
|
|
stop = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
Serial.println(stop - start);
|
2014-11-18 13:28:12 -05:00
|
|
|
|
|
|
|
Serial.print("count() empty:\t");
|
2021-01-29 06:31:58 -05:00
|
|
|
myset.clear();
|
2014-11-18 13:28:12 -05:00
|
|
|
start = micros();
|
|
|
|
myset.count();
|
|
|
|
stop = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
Serial.println(stop - start);
|
2014-11-18 13:28:12 -05:00
|
|
|
|
|
|
|
Serial.print("count() full:\t");
|
2021-01-29 06:31:58 -05:00
|
|
|
myset.clear();
|
2014-11-18 13:28:12 -05:00
|
|
|
myset.invert();
|
|
|
|
start = micros();
|
|
|
|
myset.count();
|
|
|
|
stop = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
Serial.println(stop - start);
|
2014-11-18 13:28:12 -05:00
|
|
|
Serial.println();
|
|
|
|
|
2017-07-16 14:09:23 -04:00
|
|
|
Serial.print("100x isEmpty(): empty\t");
|
2021-01-29 06:31:58 -05:00
|
|
|
myset.clear();
|
2017-07-16 11:33:43 -04:00
|
|
|
start = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
for (uint8_t i = 0; i < 100; i++) b = myset.isEmpty();
|
2017-07-16 14:09:23 -04:00
|
|
|
stop = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
Serial.println(stop - start);
|
|
|
|
|
2017-07-16 14:09:23 -04:00
|
|
|
Serial.print("100x isEmpty(): full\t");
|
2021-01-29 06:31:58 -05:00
|
|
|
myset.clear();
|
2017-07-16 14:09:23 -04:00
|
|
|
myset.invert();
|
|
|
|
start = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
for (uint8_t i = 0; i < 100; i++) b = myset.isEmpty();
|
2017-07-16 14:09:23 -04:00
|
|
|
stop = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
Serial.println(stop - start);
|
|
|
|
|
2017-07-16 14:09:23 -04:00
|
|
|
Serial.print("100x isFull(): empty\t");
|
2021-01-29 06:31:58 -05:00
|
|
|
myset.clear();
|
2017-07-16 14:09:23 -04:00
|
|
|
start = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
for (uint8_t i = 0; i < 100; i++) b = myset.isFull();
|
2017-07-16 14:09:23 -04:00
|
|
|
stop = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
Serial.println(stop - start);
|
|
|
|
|
2017-07-16 14:09:23 -04:00
|
|
|
Serial.print("100x isFull(): full\t");
|
2021-01-29 06:31:58 -05:00
|
|
|
myset.clear();
|
2017-07-16 14:09:23 -04:00
|
|
|
myset.invert();
|
|
|
|
start = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
for (uint8_t i = 0; i < 100; i++) b = myset.isFull();
|
2017-07-16 11:33:43 -04:00
|
|
|
stop = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
Serial.println(stop - start);
|
2017-07-16 11:33:43 -04:00
|
|
|
Serial.println();
|
|
|
|
|
2014-11-18 13:28:12 -05:00
|
|
|
|
|
|
|
randomSeed(1);
|
2021-01-29 06:31:58 -05:00
|
|
|
setA.clear();
|
|
|
|
setB.clear();
|
2020-11-27 05:33:55 -05:00
|
|
|
for (int i = 0; i<150; i++)
|
2014-11-18 13:28:12 -05:00
|
|
|
{
|
2021-01-29 06:31:58 -05:00
|
|
|
setA.add(random(256));
|
|
|
|
setB.add(random(256));
|
2014-11-18 13:28:12 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
Serial.print("a = b + c:\t");
|
|
|
|
start = micros();
|
|
|
|
myset = setA + setB;
|
|
|
|
stop = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
Serial.println(stop - start);
|
2014-11-18 13:28:12 -05:00
|
|
|
|
|
|
|
Serial.print("a = b - c:\t");
|
|
|
|
start = micros();
|
|
|
|
myset = setA - setB;
|
|
|
|
stop = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
Serial.println(stop - start);
|
2014-11-18 13:28:12 -05:00
|
|
|
|
|
|
|
Serial.print("a = b * c:\t");
|
|
|
|
start = micros();
|
|
|
|
myset = setA * setB;
|
|
|
|
stop = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
Serial.println(stop - start);
|
2014-11-18 13:28:12 -05:00
|
|
|
|
|
|
|
Serial.print("a += b:\t");
|
|
|
|
start = micros();
|
|
|
|
myset += setA;
|
|
|
|
stop = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
Serial.println(stop - start);
|
2014-11-18 13:28:12 -05:00
|
|
|
|
|
|
|
Serial.print("a -= b:\t");
|
|
|
|
start = micros();
|
|
|
|
myset -= setA;
|
|
|
|
stop = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
Serial.println(stop - start);
|
2014-11-18 13:28:12 -05:00
|
|
|
|
|
|
|
Serial.print("a *= b:\t");
|
|
|
|
start = micros();
|
|
|
|
myset *= setA;
|
|
|
|
stop = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
Serial.println(stop - start);
|
2014-11-18 13:28:12 -05:00
|
|
|
|
|
|
|
Serial.print("a == b:\t");
|
|
|
|
start = micros();
|
|
|
|
b = (setA == setB);
|
|
|
|
stop = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
Serial.println(stop - start);
|
2014-11-18 13:28:12 -05:00
|
|
|
|
|
|
|
Serial.print("a != b:\t");
|
|
|
|
start = micros();
|
|
|
|
b = (setA != setB);
|
|
|
|
stop = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
Serial.println(stop - start);
|
2014-11-18 13:28:12 -05:00
|
|
|
|
|
|
|
Serial.print("a <= b:\t");
|
|
|
|
start = micros();
|
|
|
|
b = (setA <= setB);
|
|
|
|
stop = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
Serial.println(stop - start);
|
2014-11-18 13:28:12 -05:00
|
|
|
|
|
|
|
Serial.println();
|
|
|
|
Serial.println("iteration 10 elements");
|
|
|
|
Serial.print("first:\t");
|
2021-01-29 06:31:58 -05:00
|
|
|
setA.clear();
|
2014-11-18 13:28:12 -05:00
|
|
|
randomSeed(1);
|
2020-11-27 05:33:55 -05:00
|
|
|
for (int i = 0; i < 10; i++)
|
2014-11-18 13:28:12 -05:00
|
|
|
{
|
2021-01-29 06:31:58 -05:00
|
|
|
setA.add(random(256));
|
2014-11-18 13:28:12 -05:00
|
|
|
}
|
|
|
|
start = micros();
|
|
|
|
int n = setA.first();
|
|
|
|
stop = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
Serial.println(stop - start);
|
2021-12-28 04:38:33 -05:00
|
|
|
|
2014-11-18 13:28:12 -05:00
|
|
|
Serial.print("next:\t");
|
|
|
|
start = micros();
|
|
|
|
n = setA.next();
|
|
|
|
stop = micros();
|
2021-12-28 04:38:33 -05:00
|
|
|
Serial.println(stop - start);
|
|
|
|
|
2020-11-27 05:33:55 -05:00
|
|
|
Serial.print("100x first + next until -1 :\t");
|
2014-11-18 13:28:12 -05:00
|
|
|
start = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
for (uint8_t i = 0; i < 100; i++)
|
2014-11-18 13:28:12 -05:00
|
|
|
{
|
2021-01-29 06:31:58 -05:00
|
|
|
n = setA.first();
|
|
|
|
while (n != -1)
|
|
|
|
{
|
|
|
|
n = setA.next();
|
|
|
|
}
|
2014-11-18 13:28:12 -05:00
|
|
|
}
|
|
|
|
stop = micros();
|
2021-12-28 04:38:33 -05:00
|
|
|
Serial.println(stop - start);
|
|
|
|
|
2020-11-27 05:33:55 -05:00
|
|
|
Serial.print("100x last + prev until -1 :\t");
|
2015-03-07 12:46:16 -05:00
|
|
|
start = micros();
|
2020-11-27 05:33:55 -05:00
|
|
|
for (uint8_t i = 0; i < 100; i++)
|
2015-03-07 12:46:16 -05:00
|
|
|
{
|
2021-01-29 06:31:58 -05:00
|
|
|
n = setA.last();
|
|
|
|
while (n != -1)
|
|
|
|
{
|
|
|
|
n = setA.prev();
|
|
|
|
}
|
2015-03-07 12:46:16 -05:00
|
|
|
}
|
|
|
|
stop = micros();
|
2021-12-28 04:38:33 -05:00
|
|
|
Serial.println(stop - start);
|
2014-11-18 13:28:12 -05:00
|
|
|
Serial.println();
|
2021-12-28 04:38:33 -05:00
|
|
|
|
2014-11-18 13:28:12 -05:00
|
|
|
Serial.println();
|
|
|
|
}
|
|
|
|
|
2021-12-28 04:38:33 -05:00
|
|
|
|
2014-11-18 13:28:12 -05:00
|
|
|
void equalTest()
|
|
|
|
{
|
|
|
|
Serial.println("EQUAL TEST");
|
|
|
|
randomSeed(1);
|
2021-01-29 06:31:58 -05:00
|
|
|
setA.clear();
|
|
|
|
setB.clear();
|
2014-11-18 13:28:12 -05:00
|
|
|
Serial.println(setA == setB?"true":"false");
|
|
|
|
setB.add(0);
|
|
|
|
Serial.println(setA == setB?"true":"false");
|
|
|
|
Serial.println(setA == setA?"true":"false");
|
|
|
|
|
|
|
|
Set setC(setB);
|
|
|
|
Serial.println(setC == setB?"true":"false");
|
|
|
|
Serial.println(setC.count());
|
|
|
|
|
|
|
|
Set setD = setB;
|
|
|
|
Serial.println(setD != setB?"unequal":"equal");
|
|
|
|
Serial.println(setD == setB?"true":"false");
|
|
|
|
Serial.println(setD.count());
|
|
|
|
|
|
|
|
setD = setA;
|
|
|
|
Serial.println(setD == setB?"true":"false");
|
|
|
|
Serial.println(setD.count());
|
|
|
|
|
|
|
|
Serial.println();
|
|
|
|
}
|
|
|
|
|
2021-12-28 04:38:33 -05:00
|
|
|
|
2014-11-18 13:28:12 -05:00
|
|
|
void intersectionTest()
|
|
|
|
{
|
|
|
|
Serial.println("INTERSECTION TEST");
|
|
|
|
randomSeed(1);
|
2021-01-29 06:31:58 -05:00
|
|
|
setA.clear();
|
|
|
|
setB.clear();
|
2020-11-27 05:33:55 -05:00
|
|
|
for (int i = 0; i < 150; i++)
|
2014-11-18 13:28:12 -05:00
|
|
|
{
|
2021-01-29 06:31:58 -05:00
|
|
|
setA.add(random(256));
|
|
|
|
setB.add(random(256));
|
2014-11-18 13:28:12 -05:00
|
|
|
}
|
|
|
|
Serial.println(setA.count());
|
|
|
|
Serial.println(setB.count());
|
|
|
|
setA *= setB;
|
|
|
|
Serial.println(setA.count());
|
|
|
|
Serial.println();
|
|
|
|
|
|
|
|
Serial.println("union test");
|
|
|
|
randomSeed(1);
|
2021-01-29 06:31:58 -05:00
|
|
|
setA.clear();
|
|
|
|
setB.clear();
|
2020-11-27 05:33:55 -05:00
|
|
|
for (int i = 0; i < 150; i++)
|
2014-11-18 13:28:12 -05:00
|
|
|
{
|
2021-01-29 06:31:58 -05:00
|
|
|
setA.add(random(256));
|
|
|
|
setB.add(random(256));
|
2014-11-18 13:28:12 -05:00
|
|
|
}
|
|
|
|
Serial.println(setA.count());
|
|
|
|
Serial.println(setB.count());
|
|
|
|
setA += setB;
|
|
|
|
Serial.println(setA.count());
|
|
|
|
Serial.println();
|
|
|
|
|
|
|
|
Serial.println("diff test");
|
|
|
|
randomSeed(1);
|
2021-01-29 06:31:58 -05:00
|
|
|
setA.clear();
|
|
|
|
setB.clear();
|
2020-11-27 05:33:55 -05:00
|
|
|
for (int i = 0; i < 150; i++)
|
2014-11-18 13:28:12 -05:00
|
|
|
{
|
2021-01-29 06:31:58 -05:00
|
|
|
setA.add(random(256));
|
|
|
|
setB.add(random(256));
|
2014-11-18 13:28:12 -05:00
|
|
|
}
|
|
|
|
Serial.println(setA.count());
|
|
|
|
Serial.println(setB.count());
|
|
|
|
setA -= setB;
|
|
|
|
Serial.println(setA.count());
|
|
|
|
|
|
|
|
Serial.println();
|
|
|
|
}
|
|
|
|
|
2021-12-28 04:38:33 -05:00
|
|
|
|
2014-11-18 13:28:12 -05:00
|
|
|
void intersection2Test()
|
|
|
|
{
|
|
|
|
Serial.println("INTERSECTION2 TEST");
|
|
|
|
randomSeed(1);
|
2021-01-29 06:31:58 -05:00
|
|
|
setA.clear();
|
|
|
|
setB.clear();
|
2020-11-27 05:33:55 -05:00
|
|
|
for (int i = 0; i < 150; i++)
|
2014-11-18 13:28:12 -05:00
|
|
|
{
|
2021-01-29 06:31:58 -05:00
|
|
|
setA.add(random(256));
|
|
|
|
setB.add(random(256));
|
2014-11-18 13:28:12 -05:00
|
|
|
}
|
|
|
|
Set setC;
|
|
|
|
setC = setA * setB;
|
|
|
|
Serial.println(setA.count());
|
|
|
|
Serial.println(setB.count());
|
|
|
|
Serial.println(setC.count());
|
|
|
|
Serial.println();
|
|
|
|
|
|
|
|
Serial.println("union2 test");
|
|
|
|
setC = setA + setB;
|
|
|
|
Serial.println(setA.count());
|
|
|
|
Serial.println(setB.count());
|
|
|
|
Serial.println(setC.count());
|
|
|
|
Serial.println();
|
|
|
|
|
|
|
|
Serial.println("diff2 test");
|
|
|
|
setC = setA - setB;
|
|
|
|
Serial.println(setA.count());
|
|
|
|
Serial.println(setB.count());
|
|
|
|
Serial.println(setC.count());
|
|
|
|
Serial.println();
|
|
|
|
}
|
|
|
|
|
2021-12-28 04:38:33 -05:00
|
|
|
|
2014-11-18 13:28:12 -05:00
|
|
|
void subsetTest()
|
|
|
|
{
|
|
|
|
Serial.println("SUBSET TEST");
|
|
|
|
Set setE;
|
2020-11-27 05:33:55 -05:00
|
|
|
for (int i = 0; i < 5; i++) setE.add(i);
|
2014-11-18 13:28:12 -05:00
|
|
|
|
|
|
|
Set setF(setE);
|
|
|
|
|
|
|
|
Serial.println(setE.count());
|
|
|
|
Serial.println(setF.count());
|
|
|
|
|
|
|
|
Serial.println(setE <= setF?"subset":"no subset");
|
|
|
|
Serial.println(setF <= setE?"subset":"no subset");
|
|
|
|
|
|
|
|
setF.add(6);
|
|
|
|
Serial.println(setE <= setF?"subset":"no subset");
|
|
|
|
Serial.println(setF <= setE?"subset":"no subset");
|
|
|
|
|
|
|
|
setF.sub(3);
|
|
|
|
Serial.println(setE <= setF?"subset":"no subset");
|
|
|
|
Serial.println(setF <= setE?"subset":"no subset");
|
|
|
|
|
|
|
|
Serial.println();
|
|
|
|
}
|
|
|
|
|
2021-12-28 04:38:33 -05:00
|
|
|
|
2014-11-18 13:28:12 -05:00
|
|
|
void iterationTest()
|
|
|
|
{
|
2020-11-27 05:33:55 -05:00
|
|
|
Serial.println("10x ITERATE OVER SET TEST");
|
2014-11-18 13:28:12 -05:00
|
|
|
randomSeed(1);
|
2021-01-29 06:31:58 -05:00
|
|
|
setA.clear();
|
2020-11-27 05:33:55 -05:00
|
|
|
for (int i = 0; i < 10; i++)
|
2014-11-18 13:28:12 -05:00
|
|
|
{
|
2021-01-29 06:31:58 -05:00
|
|
|
setA.add(random(256));
|
2014-11-18 13:28:12 -05:00
|
|
|
}
|
|
|
|
Serial.println(setA.count());
|
2020-11-27 05:33:55 -05:00
|
|
|
start = micros();
|
|
|
|
for (int i = 0; i < 10; i++)
|
2014-11-18 13:28:12 -05:00
|
|
|
{
|
2021-01-29 06:31:58 -05:00
|
|
|
int n = setA.first();
|
|
|
|
while (n != -1)
|
|
|
|
{
|
|
|
|
Serial.print(n);
|
|
|
|
Serial.print('\t');
|
|
|
|
n = setA.next();
|
|
|
|
}
|
|
|
|
Serial.println();
|
2014-11-18 13:28:12 -05:00
|
|
|
}
|
2020-11-27 05:33:55 -05:00
|
|
|
stop = micros();
|
2014-11-18 13:28:12 -05:00
|
|
|
Serial.println();
|
2021-12-28 04:38:33 -05:00
|
|
|
Serial.println(stop - start);
|
2020-11-27 05:33:55 -05:00
|
|
|
Serial.println();
|
2021-12-28 04:38:33 -05:00
|
|
|
|
2020-11-27 05:33:55 -05:00
|
|
|
start = micros();
|
|
|
|
for (int i = 0; i < 10; i++)
|
2014-11-18 13:28:12 -05:00
|
|
|
{
|
2021-01-29 06:31:58 -05:00
|
|
|
int n = setA.last();
|
|
|
|
while (n != -1)
|
|
|
|
{
|
|
|
|
Serial.print(n);
|
|
|
|
Serial.print('\t');
|
|
|
|
n = setA.prev();
|
|
|
|
}
|
|
|
|
Serial.println();
|
2014-11-18 13:28:12 -05:00
|
|
|
}
|
2020-11-27 05:33:55 -05:00
|
|
|
stop = micros();
|
|
|
|
Serial.println();
|
2021-12-28 04:38:33 -05:00
|
|
|
Serial.println(stop - start);
|
2014-11-18 13:28:12 -05:00
|
|
|
Serial.println();
|
|
|
|
}
|
2020-11-27 05:33:55 -05:00
|
|
|
|
2021-12-28 04:38:33 -05:00
|
|
|
|
2020-11-27 05:33:55 -05:00
|
|
|
// -- END OF FILE --
|
2021-12-28 04:38:33 -05:00
|
|
|
|