From d32dc9f43a35ad23f81f422109b7e2b6a3690e27 Mon Sep 17 00:00:00 2001 From: Sean Barrett Date: Fri, 15 Apr 2016 21:40:37 -0700 Subject: [PATCH] add todo list, try to compile as C++ (untested), tweak data structure --- stb_connected_components.h | 25 +++++++++++++++++++++++-- 1 file changed, 23 insertions(+), 2 deletions(-) diff --git a/stb_connected_components.h b/stb_connected_components.h index 7b91d42..2ba78a3 100644 --- a/stb_connected_components.h +++ b/stb_connected_components.h @@ -1,4 +1,4 @@ -// stb_connected_components - v0.90 - public domain connected components on grids +// stb_connected_components - v0.91 - public domain connected components on grids // http://github.com/nothings/stb // // Finds connected components on 2D grids for testing reachability between @@ -23,6 +23,19 @@ // license: you are granted a perpetual, irrevocable license to copy, modify, // publish, and distribute this file as you see fit. // +// +// TODO: +// - test C++ compile +// - better API documentation +// - internals documentation (including algorithm) +// - try re-integrating naive algorithm & compare performance +// - batching (keep data structure w/ dirty clusters) +// - function for setting a grid of squares at once (just use batching) +// - shrink data by storing only, say, 2X max exits +// (instead of max exits per clump), and repack cluster +// if it runs out (possibly by just rebuilding from scratch, +// could even use dirty-cluster data structure) +// should reduce 1Kx1K from ~66MB to ~8MB #ifndef INCLUDE_STB_CONNECTED_COMPONENTS_H #define INCLUDE_STB_CONNECTED_COMPONENTS_H @@ -32,6 +45,10 @@ typedef struct st_stbcc_grid stbcc_grid; +#ifdef __cplusplus +extern "C" { +#endif + ////////////////////////////////////////////////////////////////////////////////////////// // // initialization @@ -69,6 +86,10 @@ extern int stbcc_query_grid_open(stbcc_grid *g, int x, int y); // small, you'll need a hash table or something to remap it (or just use extern unsigned int stbcc_get_unique_id(stbcc_grid *g, int x, int y); +#ifdef __cplusplus +} +#endif + #endif // INCLUDE_STB_CONNECTED_COMPONENTS_H #ifdef STB_CONNECTED_COMPONENTS_IMPLEMENTATION @@ -148,7 +169,7 @@ typedef union typedef struct { stbcc__global_clumpid global_label; - unsigned char num_adjacent; + unsigned short num_adjacent; stbcc__relative_clumpid adjacent_clumps[STBCC__MAX_EXITS_PER_CLUMP]; } stbcc__clump;