Arithmetic Computations and Memory Management Using a Binary Tree Encoding af Natural Numbers

Two applications of a binary tree data type based on a simple pairing function (a bijection between natural numbers and pairs of natural numbers) are explored. First, the tree is used to encode natural numbers, and algorithms that perform basic arithmetic computations are presented along with formal...

Full description

Bibliographic Details
Main Author: Haraburda, David
Other Authors: Tarau, Paul
Format: Others
Language:English
Published: University of North Texas 2011
Subjects:
Online Access:https://digital.library.unt.edu/ark:/67531/metadc103323/
Description
Summary:Two applications of a binary tree data type based on a simple pairing function (a bijection between natural numbers and pairs of natural numbers) are explored. First, the tree is used to encode natural numbers, and algorithms that perform basic arithmetic computations are presented along with formal proofs of their correctness. Second, using this "canonical" representation as a base type, algorithms for encoding and decoding additional isomorphic data types of other mathematical constructs (sets, sequences, etc.) are also developed. An experimental application to a memory management system is constructed and explored using these isomorphic types. A practical analysis of this system's runtime complexity and space savings are provided, along with a proof of concept framework for both applications of the binary tree type, in the Java programming language.