GY-63_MS5611/libraries/Set/examples/allTest/allTest.ino

430 lines
9.0 KiB
Arduino
Raw Normal View History

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();
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();
stop = micros();
2020-11-27 05:33:55 -05:00
Serial.println(stop - start);
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");
start = micros();
2020-11-27 05:33:55 -05:00
for (uint8_t i = 0; i < 100; i++)
{
2021-01-29 06:31:58 -05:00
n = setA.last();
while (n != -1)
{
n = setA.prev();
}
}
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