diff options
author | Campbell Barton <ideasman42@gmail.com> | 2016-10-13 07:51:20 +0300 |
---|---|---|
committer | Campbell Barton <ideasman42@gmail.com> | 2016-10-26 15:33:41 +0300 |
commit | 72921a1e43033d7fea998dd607a68250da5d93bd (patch) | |
tree | de5defe233ec5b73b6fd7bf8da07b6d4e8270cac /extern/rangetree/range_tree_c_api.h | |
parent | 44522a5b98f908928e93ab32c9d6046de4342d9b (diff) |
RangeTree API rewrite
Rewrite the current range-tree API used by dyn-topo undo
to avoid inefficiencies from stdc++'s set use.
- every call to `take_any` (called for all verts & faces)
removed and added to the set.
- further range adjustment also took 2x btree edits.
This patch inlines a btree which is modified in-place,
so common resizing operations don't need to perform a remove & insert.
Ranges are stored in a list so `take_any` can access the first item
without a btree lookup.
Since range-tree isn't a bottleneck in sculpting, this only gives minor speedups.
Measured approx ~15% overall faster calculation for sculpting,
although this number time doesn't include GPU updates and depends on how
much edits fragment the range-tree.
Diffstat (limited to 'extern/rangetree/range_tree_c_api.h')
-rw-r--r-- | extern/rangetree/range_tree_c_api.h | 62 |
1 files changed, 0 insertions, 62 deletions
diff --git a/extern/rangetree/range_tree_c_api.h b/extern/rangetree/range_tree_c_api.h deleted file mode 100644 index 6abfb6bd55e..00000000000 --- a/extern/rangetree/range_tree_c_api.h +++ /dev/null @@ -1,62 +0,0 @@ -/* This program is free software; you can redistribute it and/or - modify it under the terms of the GNU General Public License as - published by the Free Software Foundation; either version 2 of the - License, or (at your option) any later version. - - This program is distributed in the hope that it will be useful, but - WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - General Public License for more details. - - You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA - 02110-1301, USA. -*/ - -#ifndef __RANGE_TREE_C_API_H__ -#define __RANGE_TREE_C_API_H__ - -#ifdef __cplusplus -extern "C" { -#endif - -/* Simple C-accessible wrapper for RangeTree<unsigned> */ - -#ifndef RANGE_TREE_C_API_INTERNAL -typedef struct RangeTreeUInt RangeTreeUInt; -#endif - -RangeTreeUInt *range_tree_uint_alloc(unsigned min, unsigned max); - -RangeTreeUInt *range_tree_uint_copy(RangeTreeUInt *src); - -void range_tree_uint_free(RangeTreeUInt *rt); - -void range_tree_uint_take(RangeTreeUInt *rt, unsigned v); - -bool range_tree_uint_retake(RangeTreeUInt *rt, unsigned v); - -unsigned range_tree_uint_take_any(RangeTreeUInt *rt); - -void range_tree_uint_release(RangeTreeUInt *rt, unsigned v); - -bool range_tree_uint_has(const RangeTreeUInt *rt, unsigned v); - -bool range_tree_uint_has_range( - const RangeTreeUInt *rt, - unsigned vmin, unsigned vmax); - -bool range_tree_uint_empty(const RangeTreeUInt *rt); - -unsigned range_tree_uint_size(const RangeTreeUInt *rt); - -void range_tree_uint_print(const RangeTreeUInt *rt); - -unsigned int range_tree_uint_allocation_lower_bound(const RangeTreeUInt *rt); - -#ifdef __cplusplus -} -#endif - -#endif /* __RANGE_TREE_C_API_H__ */ |