Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

bohutang/omt

Folders and files

NameName
Last commit message
Last commit date

Latest commit

History

2 Commits

Repository files navigation

OMT is short for Order Maintenance Tree, which is dreamed up by Tokutek, and used in TokuDB.
It's a weight balanced binary tree, each node maintains the weights of its left and right subtrees.
OMT having better CPU cache efficiency than skiplist (it's very cool as you improve it to vEB layout).
For more details, please see Cartesian Tree: http://en.wikipedia.org/wiki/Cartesian_tree
Insertion as follows:
1) insert 'key-1'
 /*
 * (key-1)
 */
2) insert 'key-4'
 /*
 * (key-1)
 * \
 * (key-4)
 */
3) insert 'key-7'
 /*
 * (key-1)
 * \
 * (key-4)
 * \
 * (key-7)
 */
4) insert 'key-5'
 /*
 * (key-1)
 * \
 * (key-4)
 * \
 * (key-7)
 * /
 * (key-5)
 */
5) insert 'key-6', the tree need to be rebalanced:
 /*
 * (key-1)
 * \
 * (key-4)
 * \
 * (key-7)
 * /
 * (key-5)
 * \
 * (key-6)
 */
After rebalance:
 /*
 *
 * (key-5)
 * / \
 * (key-4) (key-7)
 * / / \
 * (key-1) (key-6) (key-71)
 *
 */
6) and we insert 'key-72', 'key-75', it cause a balance:
 /*
 *
 * (key-5)
 * / \
 * (key-4) (key-7)
 * / / \
 * (key-1) (key-6) (key-71)
 * \
 * (key-72)
 * \
 * (key-75)
 *
 */
 /***************** after rebalance *********************/
 /*
 *
 * (key-7)
 * / \
 * (key-5) (key-72)
 * / \ / \
 * (key-4) (key-6) (key-71) (key-75)
 * /
 *(key-1)
 *
 */
By BohuTANG @2013年9月19日

About

A cache-efficiency weight balanced binary tree

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 2

Languages

AltStyle によって変換されたページ (->オリジナル) /