Added hyperspace to object mapping idea.
[sixth-data.git] / doc / index.html
index cc7cce5..d0f979d 100644 (file)
@@ -2,7 +2,7 @@
 <html lang="en">
 <head>
 <title>Sixth - system for data storage, computation, exploration and interaction</title>
-<!-- 2017-05-25 Thu 22:58 -->
+<!-- 2017-07-19 Wed 21:46 -->
 <meta charset="utf-8">
 <meta name="viewport" content="width=device-width, initial-scale=1">
 <meta name="generator" content="Org-mode">
@@ -220,25 +220,28 @@ License</a> or later as published by the Free Software Foundation.
 </ul>
 </li>
 
-<li><a href="http://svjatoslav.eu/programs.jsp">other applications hosted at svjatoslav.eu</a>
+<li><a href="http://www.svjatoslav.eu/programs.jsp">other applications hosted at svjatoslav.eu</a>
 </li>
 </ul>
 
 
 <div id="outline-container-sec-1" class="outline-2">
-<h2 id="sec-1"><span class="section-number-2">1</span> Vision / goal</h2>
+<h2 id="sec-1"><a id="ID-f6764282-a6f6-44e6-8716-b428074dd093" name="ID-f6764282-a6f6-44e6-8716-b428074dd093"></a><span class="section-number-2">1</span> Vision / goal</h2>
 <div class="outline-text-2" id="text-1">
 <p>
-Provide versioned, clustered, flexible, object-relational database
-functionality for the <a href="http://www2.svjatoslav.eu/gitbrowse/sixth/doc/index.html">Sixth computation engine</a>.
+Provide versioned, clustered, flexible, distributed, multi-dimensional
+data storage engine for the <a href="http://www2.svjatoslav.eu/gitbrowse/sixth/doc/index.html">Sixth computation engine</a>.
 </p>
 
+<ul class="org-ul">
+<li>Speaking of traditional relational database and object oriented
+business applications:
 <ul class="org-ul">
 <li>I hate object-relational impedance mismatch.
 </li>
 
-<li>I don't like to convert data between persistent database and runtime
-objects for every transaction. How about creating united
+<li>I don't like to convert data between persistent database and
+runtime objects for every transaction. How about creating united
 database/computation engine instead to:
 <ul class="org-ul">
 <li>Eliminate constant moving and converting of data between 2 systems.
@@ -250,11 +253,14 @@ memory.
 </ul>
 </li>
 </ul>
+</li>
+</ul>
+</div>
 </div>
 
-<div id="outline-container-sec-1-1" class="outline-3">
-<h3 id="sec-1-1"><span class="section-number-3">1.1</span> Inspiration</h3>
-<div class="outline-text-3" id="text-1-1">
+<div id="outline-container-sec-2" class="outline-2">
+<h2 id="sec-2"><span class="section-number-2">2</span> Inspiration</h2>
+<div class="outline-text-2" id="text-2">
 <ul class="org-ul">
 <li>Relational databases:
 <ul class="org-ul">
@@ -280,102 +286,131 @@ memory.
 </li>
 </ul>
 </div>
-</div>
 
-<div id="outline-container-sec-1-2" class="outline-3">
-<h3 id="sec-1-2"><span class="section-number-3">1.2</span> Solution (the big idea)</h3>
-<div class="outline-text-3" id="text-1-2">
-<p>
-I see 4D data structure.
-</p>
-
-
-<figure>
-<p><img src="data model.png" class="img-responsive" alt="data model.png">
-</p>
-</figure>
+<div id="outline-container-sec-2-1" class="outline-3">
+<h3 id="sec-2-1"><a id="ID-d2375acc-af14-4f18-8ad0-7949501178c5" name="ID-d2375acc-af14-4f18-8ad0-7949501178c5"></a><span class="section-number-3">2.1</span> Brain</h3>
+<div class="outline-text-3" id="text-2-1">
+<ul class="org-ul">
+<li>Appears to have more than 3D dimensional design. Food for
+thought&#x2026;)
+<ul class="org-ul">
+<li><a href="https://singularityhub.com/2017/06/21/is-there-a-multidimensional-mathematical-world-hidden-in-the-brains-computation/">https://singularityhub.com/2017/06/21/is-there-a-multidimensional-mathematical-world-hidden-in-the-brains-computation/</a>
+</li>
+</ul>
+</li>
 
-<p>
-Dimensions:
-</p>
+<li>From there come following ideas:
 <ul class="org-ul">
-<li>List of all the objecs in the system (rows).
+<li>Maybe every problem can be translated to geometry (use any shapes
+and as many dimensions as you need). Solution(s) to such problems
+would then appear as relatively simple search/comparison/lookup
+results. As a bonus, such geometrical *data storage* AND
+*computation* can be naturally made in *parallel* and
+*distributed*. That's what neurons in the brain appear to be doing
+! :) . Learning means building/updating the model (the hard
+part). Question answering is making (relatively simple) lookups
+(geometrical queries) against the model.
 </li>
-<li>List of all declared unique object fields (columns).
+
+<li>Mapping of hyperspace to traditional object-oriented programming
+model:
+<ul class="org-ul">
+<li>Object is a point in space (universe). Each object member
+variable translates to its own dimension. That is: if class
+declares 4 variables for an object, then corresponding object
+can be stored as a single point inside 4 dimensional
+space. Variable values translate to point coordinates in
+space. That is: Integer, floating point number and even boolean
+and string can be translated to linear value that can be used as
+a coordinate along particular dimension.
 </li>
-<li>List of all historical transactions/commits/versions (think of
-sheets of paper).
+
+<li>Each class declares its own space (universe). All class
+instances (objects) are points inside that particular
+universe. References between objects of different types are
+hyperlinks (portals) between different universes.
 </li>
-<li>List of all concurrently running branches/threads. Branches can
-appear and merge over time as needed.
+</ul>
 </li>
-<li>(Every cell is concrete field value within an object)
+</ul>
 </li>
 </ul>
+</div>
+</div>
+</div>
 
-<p>
-Partitioning/clustering:
-</p>
+<div id="outline-container-sec-3" class="outline-2">
+<h2 id="sec-3"><span class="section-number-2">3</span> Current status</h2>
+<div class="outline-text-2" id="text-3">
 <ul class="org-ul">
-<li>Why not to partition/(load balance) as required across networked
-physical computers along arbitrary dimension(s) declared above ?
+<li>More or less defined <a href="#sec-1">Vision / goal</a>.
 </li>
-</ul>
 
-<p>
-Indexing (for fast searching):
-</p>
+<li>Collected some <a href="#sec-2-1">ideas</a>.
+</li>
+
+<li>Implemented very simple persistent key-value map.
 <ul class="org-ul">
-<li>Why not to index along arbitrary dimensions (as required) ?
+<li>Long term goal is to use it as a backing storage engine and
+implement more advanced features on top of this.
+</li>
+</ul>
 </li>
 </ul>
+</div>
+</div>
 
+<div id="outline-container-sec-4" class="outline-2">
+<h2 id="sec-4"><span class="section-number-2">4</span> See also</h2>
+<div class="outline-text-2" id="text-4">
 <p>
-Further optimizations:
+Interesting or competing projects with good ideas:
 </p>
+
 <ul class="org-ul">
-<li>In current early stage, trying to focus on minimum possible set of
-features that would provide maximum possible set of power/benefit :)
-</li>
-<li>Once featres are locked. Anything can be optimised. Optimization for
-size (deduplication) can be solved using Git style content
-addressible storage mechanism.
+<li>GRAKN.AI: database in the form of a knowledge graph that uses
+machine reasoning to simplify data processing challenges for AI
+applications.
+<ul class="org-ul">
+<li><a href="https://grakn.ai/">https://grakn.ai/</a>
 </li>
 </ul>
-</div>
-</div>
-</div>
+</li>
 
-<div id="outline-container-sec-2" class="outline-2">
-<h2 id="sec-2"><span class="section-number-2">2</span> Current status</h2>
-<div class="outline-text-2" id="text-2">
+<li>Gemstone/S based on Smalltalk.
 <ul class="org-ul">
-<li>Implemented very simple persistent key-value map.
+<li><a href="http://esug.org/data/ESUG2015/3%20wednesday/1100-1130%20SQL%20Queries%20on%20Smalltalk%20Objects/SQL%20Queries%20in%20Smalltalk%20(James%20Foster)">http://esug.org/data/ESUG2015/3%20wednesday/1100-1130%20SQL%20Queries%20on%20Smalltalk%20Objects/SQL%20Queries%20in%20Smalltalk%20(James%20Foster)</a>.pdf
 </li>
 </ul>
+</li>
 
-<p>
-Long term goal is to implement more advanced features on top of this.
-</p>
+<li>Magma distributed database in Smalltalk.
+<ul class="org-ul">
+<li><a href="http://wiki.squeak.org/squeak/2665">http://wiki.squeak.org/squeak/2665</a>
+</li>
+</ul>
+</li>
+</ul>
 </div>
 </div>
 </div><div class="col-md-3"><nav id="table-of-contents">
 <div id="text-table-of-contents" class="bs-docs-sidebar">
 <ul class="nav">
-<li><a href="#sec-1">1. Vision / goal</a>
+<li><a href="#sec-1">1. Vision / goal</a></li>
+<li><a href="#sec-2">2. Inspiration</a>
 <ul class="nav">
-<li><a href="#sec-1-1">1.1. Inspiration</a></li>
-<li><a href="#sec-1-2">1.2. Solution (the big idea)</a></li>
+<li><a href="#sec-2-1">2.1. Brain</a></li>
 </ul>
 </li>
-<li><a href="#sec-2">2. Current status</a></li>
+<li><a href="#sec-3">3. Current status</a></li>
+<li><a href="#sec-4">4. See also</a></li>
 </ul>
 </div>
 </nav>
 </div></div></div>
 <footer id="postamble" class="">
 <div><p class="author">Author: Svjatoslav Agejenko</p>
-<p class="date">Created: 2017-05-25 Thu 22:58</p>
+<p class="date">Created: 2017-07-19 Wed 21:46</p>
 <p class="creator"><a href="http://www.gnu.org/software/emacs/">Emacs</a> 25.1.1 (<a href="http://orgmode.org">Org-mode</a> 8.2.10)</p>
 </div>
 </footer>