X-Git-Url: https://git.llucax.com/z.facultad/75.52/treemulator.git/blobdiff_plain/31b3562c020843ce3f6900f0d02d4679710defd7..a7320c2537350c61995bd6e3b132563e0c8ba86b:/src/main.cpp diff --git a/src/main.cpp b/src/main.cpp index c405fba..13d7c34 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -2,13 +2,85 @@ #include "btree.h" #include "clave_fija.h" +#include "random.h" +#include "keymanager.h" int main (int argc, char *argv[]) { - BTree tree ("test.idx", 1024); - ClaveFija c(5); + int bloque, altas, bajas; - tree.AddKey (c); + if (argc != 4) { + printf ("Uso : %s \n", argv[0]); + return 1; + } + + bloque = atoi (argv[1]); + altas = atoi (argv[2]); + bajas = atoi (argv[3]); + + KeyManager km; + BTree tree ("test.idx", bloque); + + std::list lst; + std::list::iterator it; + Random::Init (); + Random::Ints (lst, altas); + + double paltas = bajas / (double)(altas + bajas); + + it = lst.begin (); + while (it != lst.end ()) { + ClaveFija c(*it); + + double l = Random::Double (0.0f, 1.0f); + std::cout << l << " >= " << paltas << std::endl; + if (!km.Size() // si no tenemos claves agregadas, mejor que hagamos un alta + || l >= paltas) { + tree.AddKey (c); + try { + tree.AddKey (c); + } catch (Exception *e) { + std::cout << e->Message () << std::endl; + } + km.AddValue (*it); + it++; + } else { + /* Tengo que borrar una clave entre 0 e "i" de la lista + * porque son las que ya agregue. */ + ClaveFija c(km.GetRandom ()); + + tree.DelKey (c); + std::string sss = c; + std::cout << "Clave Borrada " << sss << std::endl; + } + } + + km.PrintInfo (); + + std::list l = km.GetList (); + it = l.begin (); + int bien = 0; + int mal = 0; + while (it != l.end ()) { + ClaveFija c(*it); + BTreeFindResult *r; + + r = tree.FindKey (c); + if (r != NULL) { + std::cout << "** Clave " << (*it) << " encontrada.\n"; + bien++; + delete r; + } else { + std::cout << "** Clave " << (*it) << " NO encontrada.\n"; + mal++; + } + it++; + } + + std::cout << "\n\n === Resultados ===\n"; + std::cout << " Hist : " << bien << "\n"; + std::cout << " Miss : " << mal << "\n"; + std::cout << " Total : " << (bien+mal) << "\n"; return 0; }