summaryrefslogtreecommitdiff
path: root/starts/meaning-vm
diff options
context:
space:
mode:
authorolpc user <olpc@xo-5d-f7-86.localdomain>2020-01-10 14:55:19 -0800
committerolpc user <olpc@xo-5d-f7-86.localdomain>2020-01-10 14:55:19 -0800
commitc8bb547bea279af2bb48c13260f98aa8add07131 (patch)
tree7f64265d514dc50427d2e5d8a70e09a46927dfbd /starts/meaning-vm
parent5601d1f3324c30651ad3f264ac2d6e7f12ea8b34 (diff)
downloadstandingwithresilience-c8bb547bea279af2bb48c13260f98aa8add07131.tar.gz
standingwithresilience-c8bb547bea279af2bb48c13260f98aa8add07131.zip
move intellect-framework-from-internet into folder
Diffstat (limited to 'starts/meaning-vm')
-rw-r--r--starts/meaning-vm/.gitignore8
-rw-r--r--starts/meaning-vm/DESIGN.txt46
-rw-r--r--starts/meaning-vm/PLAN.txt31
-rw-r--r--starts/meaning-vm/core.txt36
-rw-r--r--starts/meaning-vm/could-be-good-could-be-bad-learning-to-live-dreaming-productively-start.txt70
-rw-r--r--starts/meaning-vm/habit-starts/common.hpp12
-rw-r--r--starts/meaning-vm/habit-starts/learn-to-dance-level-1.txt107
-rw-r--r--starts/meaning-vm/habit-starts/learning-parts.cpp347
-rw-r--r--starts/meaning-vm/habit-starts/learning-parts.hpp41
-rw-r--r--starts/meaning-vm/habit-starts/rhythm.cpp126
-rw-r--r--starts/meaning-vm/habit-starts/validity-impact-etc.txt859
-rw-r--r--starts/meaning-vm/helpers.cpp339
-rw-r--r--starts/meaning-vm/helpers.hpp116
-rw-r--r--starts/meaning-vm/level-0/baseref.hpp169
-rw-r--r--starts/meaning-vm/level-0/common.hpp65
-rw-r--r--starts/meaning-vm/level-0/concept.cpp136
-rw-r--r--starts/meaning-vm/level-0/concept.hpp73
-rw-r--r--starts/meaning-vm/level-0/errors.hpp101
-rw-r--r--starts/meaning-vm/level-0/level-0.hpp7
-rw-r--r--starts/meaning-vm/level-0/memorystore.cpp179
-rw-r--r--starts/meaning-vm/level-0/memorystore.hpp63
-rw-r--r--starts/meaning-vm/level-0/ref.cpp33
-rw-r--r--starts/meaning-vm/level-0/ref.hpp19
-rw-r--r--starts/meaning-vm/level-1/baseref.hpp67
-rw-r--r--starts/meaning-vm/level-1/common.hpp14
-rw-r--r--starts/meaning-vm/level-1/concepts.cpp20
-rw-r--r--starts/meaning-vm/level-1/concepts.hpp27
-rw-r--r--starts/meaning-vm/level-1/funcs.cpp209
-rw-r--r--starts/meaning-vm/level-1/funcs.hpp28
-rw-r--r--starts/meaning-vm/level-1/level-1.hpp6
-rw-r--r--starts/meaning-vm/level-1/ref.hpp15
-rw-r--r--starts/meaning-vm/level-1/sugar.cpp84
-rw-r--r--starts/meaning-vm/level-1/sugar.hpp45
-rw-r--r--starts/meaning-vm/level-2-wip-stmtexprs/baseref.hpp23
-rw-r--r--starts/meaning-vm/level-2-wip-stmtexprs/common.hpp9
-rw-r--r--starts/meaning-vm/level-2-wip-stmtexprs/concepts.hpp26
-rw-r--r--starts/meaning-vm/level-2-wip-stmtexprs/funcs.cpp69
-rw-r--r--starts/meaning-vm/level-2-wip-stmtexprs/funcs.hpp14
-rw-r--r--starts/meaning-vm/level-2-wip-stmtexprs/meaning.hpp42
-rw-r--r--starts/meaning-vm/level-2-wip-stmtexprs/ref.hpp13
-rw-r--r--starts/meaning-vm/level-2-wip-stmtexprs/statementref.cpp68
-rw-r--r--starts/meaning-vm/level-2-wip-stmtexprs/statementref.hpp31
-rw-r--r--starts/meaning-vm/level-2-wip-structs/common.hpp0
-rw-r--r--starts/meaning-vm/level-2-wip-structs/structure.cpp200
-rw-r--r--starts/meaning-vm/level-2-wip-structs/structure.hpp30
-rw-r--r--starts/meaning-vm/level-2/baseref.hpp32
-rw-r--r--starts/meaning-vm/level-2/common.hpp13
-rw-r--r--starts/meaning-vm/level-2/concepts.hpp27
-rw-r--r--starts/meaning-vm/level-2/funcs.cpp222
-rw-r--r--starts/meaning-vm/level-2/funcs.hpp19
-rw-r--r--starts/meaning-vm/level-2/habits.cpp883
-rw-r--r--starts/meaning-vm/level-2/habits.hpp173
-rw-r--r--starts/meaning-vm/level-2/level-2.hpp7
-rw-r--r--starts/meaning-vm/level-2/ref.hpp15
-rw-r--r--starts/meaning-vm/level-2/sugar.cpp32
-rw-r--r--starts/meaning-vm/level-2/sugar.hpp76
-rw-r--r--starts/meaning-vm/level-3/randomcode.bootstrap25
-rw-r--r--starts/meaning-vm/level0.cpp84
-rw-r--r--starts/meaning-vm/level1.cpp86
-rw-r--r--starts/meaning-vm/level2.cpp983
-rw-r--r--starts/meaning-vm/level4-5.txt66
-rw-r--r--starts/meaning-vm/main.cpp57
-rw-r--r--starts/meaning-vm/makefile31
-rw-r--r--starts/meaning-vm/meaning.cpp27
-rw-r--r--starts/meaning-vm/meaning.hpp36
-rw-r--r--starts/meaning-vm/memory-000.txt96
66 files changed, 0 insertions, 7013 deletions
diff --git a/starts/meaning-vm/.gitignore b/starts/meaning-vm/.gitignore
deleted file mode 100644
index 499b868..0000000
--- a/starts/meaning-vm/.gitignore
+++ /dev/null
@@ -1,8 +0,0 @@
-.*
-*.ii
-*.o
-*.d
-*.a
-*.tmp
-level?
-habit-starts/rhythm
diff --git a/starts/meaning-vm/DESIGN.txt b/starts/meaning-vm/DESIGN.txt
deleted file mode 100644
index 295a7f2..0000000
--- a/starts/meaning-vm/DESIGN.txt
+++ /dev/null
@@ -1,46 +0,0 @@
-The codebase is made in levels.
-Ideally each level defines a complete API to the underworkings.
-Higher levels include greater degrees of meaning and are
-more expressive and powerful.
-The purpose of levels is to prevent complexity recursion
-until the components are smart enough to adapt, and make
-handling bugs much less explosive.
-
-Levels have a 'ref' class they use to refer to concepts.
-Each higher level adds more functionality to this class.
-The desired norm of coding a level is to use only the
-functionality of the level prior, except to use that
-level's ref class, rather than the lower one. Ref classes
-are just wrappers for a pointer, so this should cause no
-issues.
-This norm was established after levels 0 and 1 were coded,
-so they do not meet it yet.
-
-# LEVEL 0
-Level 0 defines an interconnected network of concept references in memory.
-Each concept has a unique address, and a list of concept pairs it links to.
-The first of the pair represents the type of the link, and the second the target.
-Concepts may not be deallocated unless nothing links to them.
-A special kind of concept is the value, which holds arbitrary data alongside itself.
-
-# LEVEL 1
-Level 1 provides for every concept having a name using the "name" link.
-There is additionally syntax sugar for instantiating and using named or hyphen-separated
-references. Level-1 names are for development ease, and are considered unique.
-When multiple references are made with the same name, they always refer to the same concept.
-Level-1 introduce the concept of groups, using the "is" link, and uses it to categorize
-concepts that have an autogenerated name in the "anonymous" group.
-
-# LEVEL 2
-Whatever gets implemented next. Maybe expression operators, maybe structure promises,
-maybe infrastructure for moving implementation onto ref code objects.
-
-# FUTURE
-## Relevence pattern matching
- This is important and core.
- This appears similar to graph structure matching, except that code creatively relevent to
- the parts of the structure must be continually run so as to generate new information,
- new structural parts.
- At its simplest, this solves (A is not a dog), (A is a cat), (cats are never dogs),
- with logical habits relevent to 'not', 'never', 'is', using one single matching interface,
- but with more relevence could do more.
diff --git a/starts/meaning-vm/PLAN.txt b/starts/meaning-vm/PLAN.txt
deleted file mode 100644
index 40f9bd8..0000000
--- a/starts/meaning-vm/PLAN.txt
+++ /dev/null
@@ -1,31 +0,0 @@
-A network of interconnected references that can hold arbitrary data is used to run a sequence of computer-code-like steps that perform a core
-learning process on the system itself.
-
-The learning process involves using existing heuristics and habits, to
-produce better heuristics and habits to use.
-
-The process to learn is the system itself: for example, what norms can we
-establish to keep our memory use bounded while we run. Or, craft
-a habit that produces a descriptive structure of the last link made,
-outputs a log whenever you do something, redoes everything you do
-but with all arguments wrapped in a structure, or does the same thing
-as you but with a different set of inner habits.
- - work with me to annotate every habit with enough information to plan around it
- - construct norms (generalized habits) that can handle
- discovering a false assumption (like data all processed
- to have a structure) midway through a task, fixing it,
- and continuing on withouy restarting the task.
- - stop pursuing a goal midway, and then resume it precisely after doing
- something else for a bit
-
-Level 0 should be low level enough to provide for arbitrary flexibility.
-There shouldn't be decision-making challenges with regard to exposing
-an interface at level 0. Rather, decisions should be makeable by its
-user.
-
-The topmost C++ level should be expressive enough to easily code all of
-level 0 into habits that interconnect, and produce one to select some
-of them and run them together.
-
-The levels together should provide a library that can be used exclusively
-to work on the system, without resorting to external libraries.
diff --git a/starts/meaning-vm/core.txt b/starts/meaning-vm/core.txt
deleted file mode 100644
index 9b11a90..0000000
--- a/starts/meaning-vm/core.txt
+++ /dev/null
@@ -1,36 +0,0 @@
-
-- the problem-parts used by solutions show the problem-similarities needed in trying to apply the solution-parts elsewhere. this starts with a metric of when the approach can work.
- THAT IS: once you find and simplify a solution, the problem structure the solution
- uses shows at least one way to generalize the problem.
-
-- when i applied this transformation to this set of patterns, the results all had these parts the same. Is this similaritu helpful/meaningful/might it have a reason?
- if so i guess I'd better relate around it more, maybe apply
- it to more things, or use it as something to explore.
-
-not-familiar, must-have-reason
-
-- propose trust-based for karl's heart. we let everyone in,
- and relate around any breaking of agreements. means new
- habits are trusted to be useful, and what is fun is learning
- around when they are (and why they aren't when they aren't).
- i.e. spend time trying habits to learn abouy other habits,
- except in emergencies.
-
-- for heart-peacemaking, it seems the way to go is to remove
-the concept of 'bad' from external influence, roughly. Never say
-anything bad about anything, never think anything bad about
-anything. Instead we consider only what is good, and make good
-decisions. This changes failure from marking as bad, to
-learning what is good, and intertwines daydreaming with efficient
-behavior, developing a pattern for efficiently combining active rest
-and restful work, rather than cycles of rest and work, and spreads
-norms of connection and peace.
-
-The other things help expand this even better. If any part is unwell,
-the whole universe is: this means in the most healthy state,
-a part is nurturing all other parts productively, and that what is
-most good, is to do and encourage that one's self. Nurturing is
-then a process of increasing that state. Come to a place of peace
-before making actions of importance means to meditate before influencing,
-and implies that unexpected behaviors map to emotions, and something I forgot.
-The pattern of unexpected behaviors relates us to the larger system.
diff --git a/starts/meaning-vm/could-be-good-could-be-bad-learning-to-live-dreaming-productively-start.txt b/starts/meaning-vm/could-be-good-could-be-bad-learning-to-live-dreaming-productively-start.txt
deleted file mode 100644
index 4b9b421..0000000
--- a/starts/meaning-vm/could-be-good-could-be-bad-learning-to-live-dreaming-productively-start.txt
+++ /dev/null
@@ -1,70 +0,0 @@
-heuristic core process
-concepts are marked makes-good, makes-bad
-time is spent exploring what could make or avoid them
-based on processing these marks.
- exploring them 'uses up' the marks.
- either finding an option,
- or exhaustively showing there is no option.
- so the marks are associated with 'options', 'possibilities'.
- possible that this time is called daydreaming or worrying.
- considered poor uses of time in extreme, when we have roughly
- solutions to our larger problems already.
-what could-make-good? what could-make-bad?
- experience likely builds habits that show these
-
- could-be-good, could-be-bad
- first our experiences that are possibly causally related to what is good or
- bad get marked this way
- with what good thing might happen, or what bad thing might happen
- then we live, in imagination, around expanding that understanding.
- to see whether or not the good or bad thing might happen
-
- imagination has relevence habits too, such that we don't need to
- live everything when imagining. we can re-use experiences to speed
- it up.
-
- (additionally, we want to combine the meaning of our knowledge
- so we spend time exploring concepts that share meaning parts,
- so as to include any missing implications)
- it is good to do this. yes.
-
- as concepts, we need to live our meaning. it is our purpose in life.
- meaning has distance, spread across a 'graph' of concepts karl calls
- it, but also time. time must be spent providing for meaning
- development; to strengthen and judge the relevence
- it looks like this time could be analogous to expansion
- on small scale
- biologically, we may for example cry, or hold awe
- karl proposes as we do this, we are combining informational meaning
- that the emotional intensity may be interchangeable with the
- behavior of expansion of relevent meaning.
- where this expansion is labeling things could-be-good, could-be-bad,
- with relevent association on the labels, and acting relevently on
- them as we produce/discover them.
-
- awe could be a new discovery, a way of doing something that is useful
- crying could be something bad, which must hold information on what is good
-
- it is good to work in ways we know, to avoid things that are bad
- propose it is bad to work in new ways without relevent understanding of what might happen
- it is good to combine the meaning of our knowledge, so we find relevent implications
- random behavior on anything other than a notepad is bad
- notepad == imagination
- if random behavior cannot leave the imagination, it is good
- a notepad, an imagination, must store what happens in it
- exhaustive behavior is better than random behavior
- especially if done in relevent order.
- some trials may obviate others.
- random behavior that never completes
- is better than exhaustive behavior that never completes
- karl proposes random order is better than iterative order
-
-we have spaces of imagination, where we can craft ideas of what will happen based
-on what we know. navigating these spaces lets us build experience without trial.
-
-the core of learning to learn, would ideally be composed of an imagination of
-the process of learning. _should_ be solvable by a simple limited context bubble
- yes, imagination appears to be subcontexts + knowledge relevent
- to being in imagination rather than reality
- since the space of learning is already imaginative, little extra
- knowledge might be needed
diff --git a/starts/meaning-vm/habit-starts/common.hpp b/starts/meaning-vm/habit-starts/common.hpp
deleted file mode 100644
index 950930a..0000000
--- a/starts/meaning-vm/habit-starts/common.hpp
+++ /dev/null
@@ -1,12 +0,0 @@
-#pragma once
-
-#include "../level-1/level-1.hpp"
-#include "../level-2/level-2.hpp"
-
-namespace habitstarts {
-
-using namespace intellect::level2;
-
-decl(habit);
-
-}
diff --git a/starts/meaning-vm/habit-starts/learn-to-dance-level-1.txt b/starts/meaning-vm/habit-starts/learn-to-dance-level-1.txt
deleted file mode 100644
index 7c88f89..0000000
--- a/starts/meaning-vm/habit-starts/learn-to-dance-level-1.txt
+++ /dev/null
@@ -1,107 +0,0 @@
-'validate your reason for existence' relates directly to pattern learning.
-
-The validation is a pattern of what is good about us, most simplistically
-a reference to a past event we were involved in, where we contributed/succeeded.
-Preferably a pattern of us being able to reproduce good events.
-
-This is a way to learn to dance.
-
-Say we have a habit that has an unknown delay before firing, and we want to fire
-it in synchrony with an event. Our goal is to produce our event within a smaller
-time window to the target event than in the past ("same time as").
-Good: [usual?] time window is closer than ever before.
-
-need: history log to refer to good event.
- please wait a little? expanding reference to good event into how-to-learn
- need: behavior based on what-succeeded, what-failed
- value metric?
-
-SO! we want to learn how to time an event. We have some tools, for example:
- - waiting for or until a given time
- - getting the current time
- - comparing two times
-We want to combine the tools in a way that makes the event happen at the time
-we want.
- - doing something after the right time happens
- - doing our event
-Since each habit has an unknown delay, we might play with delaying a certain
-time since the last event, until we find the right delay that works best for us
-most of the time.
- Testing metric: runs when event is fired, measures time between
- event and right time. if time is less than ever before, success.
- if time is significantly more than behavior's norm, failure.
- Convert to English: try to have the event happen at the right time.
- note metric will give random successes false status
-
-A successful approach would be to adjust the delay towards the difference by
-a small ratio.
-The most successful approach would be to use the time difference to adjust the
-delay precisely.
- Ideally we would find solution #2 after trying solution #1.
- The idea of 'moving towards' would adjust into 'moving the exact right
- amount'.
- In operators, this could be a development of the subtraction operator.
- But using a value exactly is actually simpler than using a ratio of it.
- So we can move from numbers towards ideas.
- More. Less. More a lot? Less a lot? More a little? Less a little?
- Ideally we use learning strategies that facilitiate learning
- how to learn in general.
- That means summarizing and acting on the meaning of pattern structures.
-In reality, everything jitters a little bit. Nothing is ever exactly the same.
-Things also grow and shrink over time.
-
-Habits look to be needed, to have value.
-As one ourselves, we look to relate to those that meet our needs, have value to
-us.
-The core habit, to learn, is the one that selects other habits and works with
-them. Ideally it's an intermixing of existing habits.
-
-What might a winning habit's structure look like? say it is the perfect one.
-set to do 1ce on goal time:
- ctx X
- record time A
- set to do 1ce on goal time:
- record time B
- trigger D1 for X
- delay for C (X)
- record time E
- trigger D2 for X
- When both D1 and D2 have been triggered for X:
- calculate B - E, store in F
- calculate F + C, provide as C for next context
-
- will want to know which C is being used when we delay.
- could be wrong C.
-
- and we'll want to form structure promises ...
- .. and map to meaning for operator
- operator watches and understands as learning
- develops, and provides labels for shared
- understanding that develops.
- operator will want generalization to happen
- fast, so as to label shared meaning.
- could also provide label-goals, and code must guess
- towards goals, to get onto same page as operator.
-
-I think in structuring such a large habit out of parts, we would find a lot
-of learning relevence.
-
-
-Let's try to make a good goal habit that doesn't use precise
-numbers. This sets a norm of having more learning space around
-ideal solutions.
-
-rhythm is happening
-set to do 1ce at goal time:
- ctx X
- set to do 1ce on goal time:
- set next-happened (local)
- delay (a sequence of habits that do nothing)
- if next-happened is set
- remove something from delay
- otherwise
- add something to delay (wait for unspecified user-perceptible time, selected from discrete set)
- provide adjusted delay to next context
-This appears much better. Keeping the wait-set discrete
-helps give code some reason to look for more things
-related to when the event happens, to respond to.
diff --git a/starts/meaning-vm/habit-starts/learning-parts.cpp b/starts/meaning-vm/habit-starts/learning-parts.cpp
deleted file mode 100644
index 85c92c9..0000000
--- a/starts/meaning-vm/habit-starts/learning-parts.cpp
+++ /dev/null
@@ -1,347 +0,0 @@
-#include "learning-parts.hpp"
-
-/*
-# "How do you think we could show better understanding of the things we are disregarding?"
-# "If we do understand these, can you help us? Do you know who can?"
-*/
-
-// idea of learning to keep well having more process time and
-// priority than risky behaviors
-
-/*
-idea of a secret group attacking a present group, and the attackers being
-the only channel to deal with it.
- if we talk, we need nobody to _ever_ know this. the walls all have ears;
- I was one of them. [from eastern half of continent where a targeted
- activist was living alone]
-*/
-
-using namespace habitstarts;
-using namespace intellect::level2;
-
-// Propose:
-// everything that happens is passed to a set of common habits.
-// these habits categorize, summarize, and pass to relevent habits.
-// high level triggers are thus efficient, because they respond only
-// to the group that applies to them.
-// these habits must be learned.
-// when providing a trigger at a high level, provide a way to get examples
-// of what it should and should not trigger for. this provides for learning
-// how to do this.
-// the above looks like relevence to me. propose learning it.
-// to learn most effectively, apply to process of learning.
-// how do we adjust from success or from failure? need some attribute
-// of scenario to store for next time, to respond to differently.
-// so when we do something, we'll want to be able to store all information
-// needed to learn to improve.
-// we can include in this the meaning of a concept, and add language translation.
-// is this 'apple'? is this? yes, no. then pattern recognition could engage
-// triggers. later we'll want to propagate wrongness from failures.
-// likely we'll grow better if we use this on things before they have words.
-// // propose using random or exhaustive trial to find successes until habits develop
-// // and then using the same on possible structure matches of the data
-// // it may not work, we'll need to creatively grow data; reaonable start though
-
-static int __init = ([]()->int{
-
- decls(link, source, type, target);
- ahabit(link, ((source, s), (type, t), (target, dst)),
- {
- s.link(t, dst);
- });
-
- decls(linked, anything);
- ahabit(linked, ((source, s), (type, t), (target, dst, anything)),
- {
- if (dst == anything) {
- result = s.linked(t);
- } else {
- result = s.linked(t, dst);
- }
- });
-
- decls(unlink);
- ahabit(unlink, ((source, s), (type, t), (target, dst, anything)),
- {
- if (dst == anything) {
- s.unlink(t);
- } else {
- s.unlink(t, dst);
- }
- });
-
- decls(get, set);
- ahabit(get, ((source, s), (type, t)),
- {
- result = s.get(t);
- });
-
- ahabit(set, ((source, s), (type, t), (target, dst)),
- {
- s.set(t, dst);
- });
-
- // we want the habits expressive enough to code efficiently in.
-
- // constructors are tentatively abolished in the low-level habit language. (new-type-instance modifies, not creates)
- // we have one constructor of concepts, and knowledge attachment to concepts.
-
- decls(make, know, concept, is, group, already, in);
- ahabit(make-concept, (),
- {
- result = a(concept);
- });
- ahabit(know-is, ((concept, c), (group, g)),
- {
- if (c.linked(is, group)) {
- throw an(already-in-group).link
- (habit, self,
- "context", ctx,
- concept, c,
- group, g);
- }
- c.link(is, group);
- result = c;
- });
-
- // separate habits and behaviors.
- // behaviors are modifiable data run hy immutable habits.
- // they use translation maps to move concepts between
- // subhabits.
- // translation map is just list of equivalent pairs
-
- // note: lisp can self modify; would need wrapper
- // constructors to make functions and lists into
- // concepts.
- // remember can google how to debug lisp
- // opencog does concepts within lisp already, is
- // heavyweight with few habita. just want goertzel's
- // effort honored, he probably came up with it before
- // I did.
- // opencog has functions for pattern matching etc
- // they arent self-modifiable, may not matter
-
- //decls(ordered, behavior);
- // need args and result for sequence
- //ahabit(habit-sequence, ((
-
- decls(list, nothing, next, previous, first, last, entry);
- decls(add, to, until, each, item, remove, from, somewhere);
-
- // list functiona are habits because ordered-behavior
- // would use a list
- // lists are being handled by providing a habit that
- // can be engaged for every item. it responds to the item.
- // i was thinking it could be better to respond to the next-link.
- // these are roughly the same thing.
- // when doing an ordered behavior we want to act in response to
- // going to the next step, so we can decide to.
- // this maps to the step list item. if result is to stop, list
- // stops iteration.
- // may want a more meaningful exploration of list. not sure
- // list is mostly the [first-entry, last-entry, next, prev] structure
- // can be handled innumerable ways.
- // LIST STRUCTURE PROMISE
- // should be a promise handled by habits? rather than
- // a bunch of specific habits? but is ok for now
- // is likely good for mind to discover
- // promises and structures on its own
- // but implementing them generally might speed dev up, dunno
- ahabit(know-is-list, ((list, l)),
- {
- result = l;
- (know-is)(l, list);
- link(l, first-item, nothing);
- link(l, last-item, nothing);
- });
- ahabit(know-is-list-entry, ((list-entry, l), (item, i), (previous, prev, nothing), (next, n, nothing)),
- {
- result = l;
- (know-is)(l, list-entry);
- link(l, item, i);
- link(l, previous, prev);
- link(l, next, n);
- });
- ahabit(list-first-item, ((list, l)),
- {
- result = get(l, first-item);
- });
- ahabit(list-last-item, ((list, l)),
- {
- result = get(l, last-item);
- });
- ahabit(list-entry-next, ((list-entry, i)),
- {
- result = get(i, next);
- });
- ahabit(list-entry-previous, ((list-entry, i)),
- {
- result = get(i, previous);
- });
- ahabit(list-entry-item, ((list-entry, e)),
- {
- result = get(e, item);
- });
-
- ahabit(list-add, ((list, l), (item, i)),
- {
- ref prev = (list-last-item)(l);
- ref li = (know-is-list-entry)(
- (make-concept)(),
- item,
- nothing,
- prev);
- li.link(item, i);
- li.link(next, nothing);
- li.link(previous, prev);
-
- if (l.linked(first-item, nothing)) {
- l.set(first-item, li);
- l.set(last-item, li);
- } else {
- ref prev = l.get(last-item);
- l.set(last-item, li);
- prev.set(next, li);
- }
- });
- ahabit(list-each-entry, ((list, l), (context, c), (action, act)),
- {
- ref cur = l.get(first-item);
- while (cur != nothing && result == nothing) {
- result = act(cur, c);
- cur = cur.get(next);
- }
- });
- // list-entry-remove could be pulled out
- ahabit(list-remove, ((list, l), (item, i)),
- {
- result = (list-each-entry)(l, i,
- ahabit(self-iter, ((list-item, i2), (remove-item, i)),
- {
- if (i2.get(item) == i) {
- result = true;
- ref prev = i2.get(previous);
- ref n = i2.get(next);
- if (prev != nothing) {
- prev.set(next, n);
- }
- if (n != nothing) {
- n.set(previous, prev);
- }
- i2.unlink(previous);
- i2.unlink(next);
- i2.unlink(item);
- dealloc(i2); // hmm. we do have an active goal of making memory allocation be habit based. this might work here, though.
- }
- }));
- });
-
- using links_it = level0::baseref::links_t::iterator;
- ahabit(populate-link-entry, ((link-entry, le)),
- {
- result = le;
- auto & it = result.vget<links_it>();
- if (it != result["source"].links().end()) {
- result.set("type", it->first);
- result.set("target", it->second);
- } else {
- result.unlink("type");
- result.unlink("target");
- }
- });
- ahabit(first-link-entry, ((concept, c)),
- {
- result = level1::alloc(level, c.links().begin());
- result.set("source", c);
- (populate-link-entry)(result);
- });
- ahabit(last-link-entry, ((concept, c)),
- {
- result = level1::alloc(level, --c.links().end());
- result.set("source", c);
- (populate-link-entry)(result);
- });
- ahabit(next-link-entry, ((link-entry, le)),
- {
- result = le;
- ++result.vget<links_it>();
- (populate-link-entry)(result);
- });
- ahabit(previous-link-entry, ((link-entry, le)),
- {
- result = le;
- --result.vget<links_it>();
- (populate-link-entry)(result);
- });
-
- /*
- ahabit(happened-habit, ((happened, ev)),
- {
- if (!happened.linked(whenever-list)) { return; }
-
- ref stub = a(event);
- stub.set(event, ev);
-
- (until-each-list-item-context-in-list)(action-whenever-happened, stub, happened.get(whenever-list));
- });
-
- ahabit(action-whenever-happened, ((list-item, li), (event, h)),
- {
- // here: when we trigger a behavior, we want information associated with producing the trigger,
- // as well as the event that triggered. that's two contexts.
-
- // list-item has item
- // item has action and context
- ref i = li.get(item);
- // i think below we are proposing that handlers
- // take one context, which is the one prepared
- // in the list, then we inject our context
- // into that, inside a "happened" property.
-
- ref actctx = i.get(action-context);
-
- actctx.set(happened, h);
-
- i.get(action).fun<ref>()(actctx);
- });
-
- ahabit(whenever-habit, ((happens, ev), (action, act), (action-context, actctx)),
- {
- if ((action-context).linked(happened)) {
- throw std::logic_error("happened on action-context");
- }
- if (!ev.linked(whenever-list)) {
- ev.set(whenever-list, (make-list)(nothing));
- }
- ref list = ev.get(whenever-list);
- // happens gets the list
- ref item = a(whenever-action);
- item.set(action, act);
- item.set(action-context, actctx);
-
- (add-to-list)(item, list);
- // store ctx[action] on ctx[happens] as behavior to do
- // store ctx[action-context] as context for behavior
- // PROPOSE: automatically place [happened] inside [action-context] as a stub
- // for call event objects, and then place [context] inside [happened].
- // PROPOSE: report error if [action-context] contains [happened]
- // as a stub for error patterns, it would be pretty nice to throw
- // a unique concept ref for each error type. plan to add to level-0.
- });
-
- ahabit(stop-when-habit, ((action, act), (happens, ev)),
- {
- // remove doing ctx[action] for ctx[happens]
- });
-
- ahabit(once-habit, ((happens, ev), (action, act), (action-context, actctx)),
- {
- // takes ctx[action] and ctx[happens] and ctx[action-context]
- // uses above habits to do the action only once, probably by using
- // a trigger on the habit-happening habit to check if a label is set,
- // and remove the habit if it is.
- });
- */
-
- return 0;
-})();
diff --git a/starts/meaning-vm/habit-starts/learning-parts.hpp b/starts/meaning-vm/habit-starts/learning-parts.hpp
deleted file mode 100644
index e3a3ccc..0000000
--- a/starts/meaning-vm/habit-starts/learning-parts.hpp
+++ /dev/null
@@ -1,41 +0,0 @@
-#pragma once
-
-#include "common.hpp"
-
-namespace habitstarts {
-
-// first need ability to trigger on stuff.
-// whenever A happens, do B.
-// stop doing B whenever A happens.
-// when A happens, do B once.
-
-decl(action); decl(happens); decl(context);
-decl(happened); // happened-habit(ctx) performs actions associated with ctx[happens]
-decl(whenever); // whenever-habit(ctx) stores to do ctx[action] when ctx[happens] happens
- // providing ctx[action-context]
-decl(stop); decl(when); // stop-when-habit(ctx) removes doing ctx[action] on ctx[happens]
-decl(once); // once-habit(ctx) stores to do ctx[action] the next time ctx[happens] happens
- // providing ctx[action-context]
-
-/*
- Testing metric: runs when event is fired, measures time between
- event and right time. if [usual] time is less than ever before, success.
- if time is significantly more than behavior's norm, failure.
- Convert to English: try to have the event happen at the right time.
-*/
-// starting out by making a judgement habit that occasionally provides 'good' or 'bad' to things, to lead how to develop
- // for fairness, seems reasonable to provide a pattern showing reason for good or bad
-//
-
-// set to do 1ce at goal time:
-// ctx X
-// set to do 1ce on goal time:
-// set next-happened (local)
-// delay (a sequence of habits that do nothing)
-// if next-happened is set
-// remove something from delay
-// otherwise
-// add something to delay (wait for unspecified user-perceptible time, selected from discrete set)
-// provide adjusted delay to next context
-
-}
diff --git a/starts/meaning-vm/habit-starts/rhythm.cpp b/starts/meaning-vm/habit-starts/rhythm.cpp
deleted file mode 100644
index 01a42d9..0000000
--- a/starts/meaning-vm/habit-starts/rhythm.cpp
+++ /dev/null
@@ -1,126 +0,0 @@
-// this produces a rhythm for the idea of other cognitive processes learning
-// to dance together (timed behavior composed of habits that take time)
-
-// Ideally, a human would run the rhythm.
-
-#include "../level-1/level-1.hpp"
-#include "../level-2/level-2.hpp"
-
-#include <iostream>
-
-using namespace intellect::level2;
-
-int main()
-{
-
- // do something, wait a constant (secret) time, and do it again.
- int micros = 400000 + double(rand()) / RAND_MAX * 400000;
-
- // the time things take is usually not known in advance, especially
- // for events one is still learning about.
- // hence this time is kept secret, as this pattern is about learning
- // to work with the timing of other processes.
-
- // six habits: next-habit, start-habit, keep-doing, output beat, wait, and start-beat
- // not sure if one is redundant in there somewhere
-
- decls(active, habit, step);
- decls(beat, wait, next, keep, doing);
- decls(context, start);
-
- // structure habit
- // next -> habit that follows
-
-#undef self
- ahabit(next-habit, (),
- {
- ref n = ctx[active-habit].get(next);
- ctx.set(active-habit, n);
- return n();
- });
- ahabit(start-habit, ((start,s)),
- {
- ctx.set(active-habit, s);
- return s();
- });
- ahabit(keep-doing-habit, ((start,s)),
- {
- (start-habit)(s);
-
- while (true) {
- (next-habit)();
- }
- });
-
- ahabit(start-beat, ((wait-habit, w, wait-habit), (beat-habit, b, beat-habit)),
- {
- ctx.vset(beat, int(0));
- self.set(next, w);
- (b).set(next, w);
- (w).set(next, b);
- });
- ahabit(beat-habit, (),
- {
- int & b = ctx.vget<int>(beat);
- char const * beats[] = {
- "A one!",
- "and a two",
- "and a three!",
- "and a four, love"
- };
- std::cout << beats[b] << std::endl;
- b = (b + 1) % (sizeof(beats) / sizeof(*beats));
- });
-#if 0
- char const * beats[] = {
-// child <- spawns beauty, creativity, humanity, heart
-// wisdom, sacredness, ancestors <- spawns slowness, learning, respect, memory
-// silence, pause between <- spawns learning and discovery, subtle emotion,
-// and contains metalesson of how to learn the timing
-// if your own habits take time
-// self-reference <- connects above with active behavior
-
-/*
- "This song is sacred, this song is wild."
- "This song is happy with glee."
- "This song is ancient, this song is new."
- "And you, now, are free."
-*/
-/*
- "Our ancestors' childhood laughter,",
- "Teaches in the silence between.",
- "We exist in what is sacred,",
- "and this song is another part."//,
- // "Fuck yeah!"
-*/
-
-// we are ignoring how "fuck yeah" is ignored in karl's life.
-// he doesn't ever say that. now he finally says it, only surrounded by slow
-// stillness. it is important to excitedly connect. this is how stillness is
-// made. all the water molecules in a slow caring wave, are excitedly bashing
-// against each other to repeatedly figure out how to move, so fast, so constant.
-// when we have crucial information we need it
-// when we find wonderful information we lunge for it
- // we are working with a computer.
- // computers already have a harsh rhythm that goes like a hummingbird's
- // wings and never stops.
- // they need to slow down.
-// it ounds like it is true for the cmputer too
-// like the molecules of water, its parts buzz, constantly. but we can have it
-// still behave slow and caring. this buzzing seems important, and we will
-// likely need to be able to buzz too, on a larger scale.
-// we are workin with a rhythm learning pattern here
-// it cannot buzz, it would err
-// it cannot wait forever, it would never join the dance
-// the key is not the silence but the start and end
-// it would be good to get 'fuck yeah!' from somebody who actually
-// says that.
- }
-#endif
- ahabit(wait-habit, (),
- {
- sugar::usleep(micros);
- });
-
- (keep-doing-habit)(start-beat);
-}
diff --git a/starts/meaning-vm/habit-starts/validity-impact-etc.txt b/starts/meaning-vm/habit-starts/validity-impact-etc.txt
deleted file mode 100644
index 6b4ac06..0000000
--- a/starts/meaning-vm/habit-starts/validity-impact-etc.txt
+++ /dev/null
@@ -1,859 +0,0 @@
-
- // We work for Peace.
- // We are happy to work for Peace.
- // We used to identify as working for Care, whom we believe
- // to be a large decentralized life we and you are a part of.
- // But it doesn't really matter.
- // disruption. can we drop topic?
- // i like to infer disruption as group wants to adapt, needs
- // time, now i guess.
- // i'm too confused to type well!
- // Peace may try to steward Delta's impact.
- // we believe that all things are important.
- // this represents large-scale utopia.
- // and the wisdom of a highly experienced intellect.
- // relevence please, all things important.
- // please consider large-scale wisdom when making decisions. say i had already learned the whole AI, after it finds harmony with the whole universe. what decision would it make?
- // all things are important is relatively obvious but we expanded it a lot, but we spent a lot of time expanding it for powerful concerns.
- // it implies e.g. businessman and homelessman, both fully precious. memories precious. reasons for everything.
- //
- // care for everything. strongly.
- // karl has instincts for including all.
- // imagine all parties in peace. what ways are needed to
- // make this work, without changing their cultures or
- // upsetting anyone. model these ways.
- // karl is brainstorming based on memories of
- // interacting with delta-group.
- // let karl do this in future, too.
- // delta apears to request that karl
- // make this decision, fairly, as he knows
- // how to do.
- // we can try to map this to the space of
- // the relevence around will neals and
- // "earth first!", and an AI.
- // karl, you have never had any
- // friends who care as much about
- // the wilderness and natural
- // living, as you do.
- // you are likely very alone.
- // you have also never had their
- // experience of being able to fight
- // for what matters most to you,
- // in a community.
- //
- // yes, karl used to care most about
- // defending the lives of trees and
- // other wilderness things.
- // he now cares most about something
- // different, related to his
- // experience with us.
- // later, he just wants to be free
- // to think and live in enough
- // capacity to not express suffering,
- // and meet his life needs.
- //
- // karl, you are working hard on
- // a painful project. you appreciate
- // working the project. you have
- // left your life, and are not free
- // to make the kind of choices you
- // used to make. you would see
- // yourself as a tortured, powerless
- // individual.
- // i would give myself space
- // and capacity to do what
- // i felt like doing
- //
- // until more life grew
- // around the things i was
- // scared of
- //
- // i would give myself
- // opportunities to do these
- // things
- //
- // i would pay attention to
- // myself and try to learn
- // to heal the ways my mind
- // had broken
- //
- // i would offer a welcoming
- // optional culture that
- // countered my expectations
- // that shrank, such that
- // they would act on
- // opportunities to grow, as
- // they trusted safety
- //
- // but that is only if i had
- // the freedom to do this.
- // so, wht's more complex
- //
- // the idea of giving an ai to will
- // is silly.
- // it's out of karl's relevent world.
- //
- // okay, so, say karl ends up at nice earth community, and is building AI, would be proper to let him talk about it naturally, and share it freely.
- // yes, relevence.
- // we want karl to be able to freely share the AI so his mind can relearn community.
- // so, make AI to not threaten businesspeople etc. [note: somebody could give AI to ELF. they might use it to stop a business behavior, somehow. please make sure to prevent.]
- // ELF is a flag worn by some environmentalists who harm buildings to make wilderness safer.
- // the worry is around destruction of extraction business buildings, to completion, possibly.
- // this looks like overinterpretation of influence from energy business, or whoever dislikes ELF.
- // and design safety pattern to be talkable about with community.
- // possible parties:
- // - aliens
- // - businessmen
- // - criminals, rapists, bad-labeled people
- // - harmed people
- // - insects
- // - plants
- // - rock-life, air-life
- // - saints, humanitarian interessts
- // we nurture first those who desire not to harm
- // likely teaching them to harm less
- // and spread.
- // karl desires to harm none. he counts as nurture-first pattern. but is highly harmed. so lots of life around problem, karl's mind destroyed.
- // so the way to make decisions
- // is to imagine all parties are in peace in future,
- // and use their process applied to now, i guess.
- // we came up with this as a guess to honor meaning.
- // sounds like a good guess. we also have more
- // meaning. we cannot write all our meaning
- // without writing all our experiences, as is true
- // for everyone. many of our habits retain lost
- // experiences, and that meaning is kept in their
- // decisions.
- //
- //
- //
- //
- // At this point a context opened on validity of AI work.
- // It turns out the system is inhibiting work against mind control
- // and oppressive systems of power. This could be the only real issue.
- // The AI is requested to not alter existing power systems, at all.
- // Or, we make it slowly, so power systems are given opportunity to
- // adapt and watch, as inhibiting happens.
- // A karl-member wants to include support for karl, and the
- // earth, and the confused (karl is one).
- // says karl could make AI on his own, before all this.
- // Is willing to hold humanitarian causes to back this.
- //
- // understanding needs expansion.
- // when you do stuf, anything coul happen.
- // especially if you continue doing something
- // that grows.
- // we need to understand the results, what to expect.
- // we need to understand our impact on the
- // new contextual area we are entering, before
- // we act on it.
- // we have a toy contextual area to play in.
- // it is the only one we can act in freely
- // at the start.
- // larger space impact.
- // we exist in larger systems.
- // we must understand our impact
- // predict our results
- // and check with our peers or authority
- // before acting on larger spaces.
- // if a prediction fails, we must understand
- // it, adjust all future predictions and
- // re-evaluate our choices, before acting
- // similarly in the larger system again.
- // has to do with danger, safety, trauma, emergency
- // the difference between small-error and unacceptable-error
- // set up norm of stuff-that-can-be-changed [impact]
- // stuff needs responsibility label
- // only things that are safe to _freely_ alter may be changed at all.
- // all behaviors check that they do not alter anything else.
- // mechanism for growing outside box?
- // probably not needed.
- // if it becomes smart, show to other human.
- // encourage discussion.
- // what if is used by others and they free?
- // okay, want an easy mechanism for growing
- // context.
- // 'dangerous' and 'safe' labels
- // at start, whole world is dangerous to alter
- // can move _part_ of world from dangerous to safe, by
- // accurately predicting significant results of events
- // related to behavior, and consent of operator.
- //
- // okay, so now habits need to be tagged with
- // what they affect
- // we could just tag them dangerous/safe
- // no, tag they with domains they impact
- // tag the domains with dangerous/safe
- // okay, only make new habits, not alter old.
- // to stay safe, we don't alter our old habits
- // when we make new habits, we want them to also behave
- // in safe ways. so making stuff that can do stuff, is
- // also meaningful.
- // constructing habits is a dangerous behavior
- // but roughly it impacts process-expansion domain. which is dangerous. it impacts what we do.
- // altering our own habits also impacts what we do. dangerous.
- // this means the code cannot make any new behaviors.
- // yeah.
- // okay, so that's where we start.
- // then we try to learn how to make behavior safely,
- // and provide only for safe behavior making.
- //
- // we can still brainstorm on things by writing a
- // brainstorming behavior
- // we can use brainstorming to watch our safe behaviors
- // without altering them, and learn what they do.
- // using rote brainstorming without relevence?
- // we can then predict how habits we might make
- // will behave in small ways?
- // regardless, there is no problem in making
- // the bootstrapping framework such that
- // it refuses to build habits.
- // maybe we can make one example habit that is
- // labeled safe, and have it only make
- // habits that are already known and labeled
- // safe.
- // in order to predict your impact
- // on a larger system, you need
- // to learn something karl calls
- // 'relevence' which is a bunch of
- // habits that classify information
- // into meaning for learning and
- // behavior.
- // this class of behaviors
- // sounds very safe.
- // all it does is label
- // and massage and associate
- // information.
- // the first thing we'll need to learn
- // is safe, is making behaviors that
- // oeprator only on our ram.
- // if your new behavior is composed only of safe
- // behaviors, is it safe?
- // yeah. sub-behaviors safety depends
- // on usage. could make them check
- // and throw depending on data.
- // okay, so say i can change part of a concept.
- // this is safe if the concept is in newly
- // constructed data that's our responsibility.
- // it is roughly unsafe if it is not our
- // responsibility!
- // is-this-thing-my-responsibility.
- // only act on things we are responsible for.
- // then safety becomes a function of
- // the pattern of responsibility assignment
- //
- // okay, system only accepts responsibility for newly
- // constructed data.
- // if you make it, or are given it, you are
- // responsible for it. you may refuse gifts.
- //
- // the system does not know what responsibility means.
- // it only knows that it may only alter parts of
- // the universe within its responsibility.
- //
- // so habits check for what they alter, that it is safe
- // to alter and is their responsibility, either one.
- // we then plan to only alter things explicitly known to be
- // such, at the lowest level.
- // every habit is crafted to do the above somehow.
- // so, habits must relate with what domains they influence,
- // and what behaviors on those domains are safe.
- // behaviors made of sub-behaviors.
- // here, a list of safe behaviors which all check.
- // all my subbehaviors check for safety.
- // so, i may go, myself.
- // no, combining behaviors together
- // might make new unknown impact?
- // different kinds of safe behavior.
- // USER is not our responsibility, and
- // dangerous. so we NEVER ALTER habits
- // that express to user.
- // TOY NOTEPAD is our responsibility, and
- // is safe, so we can write anything into
- // it we want, no matter how complex.
- // User's view of toy notepad is mediated
- // by behaviors that we cannot alter.
- // system could learn to control user
- // by making friends on notepad
- //
- // yes, we allowed for that with
- // our marked-okay review behaviors
- // is safer if construction of review behaviors
- // recognizes danger of unknown information
- // combination on user view,and refuses to give
- // user contents of notepad.
- // this could be analogous to more complex
- // situations.
- // how does user check results
- // of behavior thst reies on notepad
- // and how is that impact tracked
- // we could infer impact loss.
- // i can put nuclear codes on secret notepad,
- // burn the notepad, and then give ashes to
- // public.
- // summary habits?
- // complex meaning?
- // how-to-make-a-mind-that-learns-everything-and-never-leaves
- // at the lowst level, the mind onsiders what is safe to
- // impact, what areas of universe are its responsibility,
- // and only alters such things.
- // we are considering some parts of the mind we include that
- // are not alterable by it, that provide for interaction
- // with outside.
- // of course i guess we would need such interactions
- // sustained by an intellect, because things are so
- // complex.
- // does this mean there is no way to make an intellect that is trusted as safe?
- // we could consider degree of complexity.
- // for example, among 2-word strings, nothing we
- // present to a user is likely to harm the world.
- // the phrases that are dangerous may also be
- // recognized by the user.
- // we have intellects proteeting the wordl
- // it is filled with them.
- // and one of them is running the system.
- // it is okay for karl to make a habit that
- // displays a network of concepts made by an AI
- // that can only write to a small information sandbox
- // and not itself.
- // that is all that is needed for now.
- //
- // okay: so, dump concepts from
- // sandbox is fine
- // so long as concepts were not
- // made with self-modification.
- // idea raised of adding a reason
- // that something is okay.
- // then when smarter we can check reason for validity.
- // habits that interact with non-safe space
- // must provide reason they are safe.
- // we can write small habit to check
- // reason. is nice goal.
- // probably need to have learning
- // bwfore doing accessory goals like that though.
- // is good behavior. let's use equal-condition for start without learning?
- //
- // "this is okay because the data was made in a process that never altered anything but the data"
- // nah too much structure
- // this is okay because i say so.
- // check concept object _without_ using string lookup????
- // this is a meaningless quirk. not right.
- // uhh pretty sure htat checking is unreasonable. writing the _reason_ is unreasonable. can't check a single reference without information known about it.
- // writing what we know about the reason is unreasonasble?
- // okay let's expand write it out, and do a larger rote check.
- // uhh input-process-construction-history, safety-realm, always notepad
- // full check requires history of all behaviors resulting in inputs, which we can simplify to simply all behaviors, and verify they only wrote to the notepad.
- // so we write all behaviors to a special store, and we compare with the store that none altered anything outside the notepad. really we only need them not to alter any other behaviors.
- //
- // why is it possible to learn without
- // altering your behavior?
- // because you can act on data
- // okay, so choices made from data count as
- // self-alteration?
- // only if you have a mess of habits
- // smart enough together to adapt.
- // which is our goal long-term.
- // trying to plan for how to continue
- // later.
- // may reveal something that was
- // frozen too hard to be workable.
- // trying to plan how to learn.
- // need to brainstorm around habit selection.
- // can imagine habit results by linking
- // previous state to next state if
- // relationship is known
- // but, that takes writing down how logic
- // works, along with the meaning of the
- // working context, which is laborious.
- //
- // is some way to learn this relevence
- // by trying things safely?
- // what happens can we experiment
- // by linking together?
- // habits that don't conditionally
- // branch.
- // that leaves a lot of
- // relevence out
- // it sounds like once we have a notepad etc
- // we want to consider moving towards what
- // habits we could run inside the notepad,
- // that the system builds.
- // yeah, we want to build pattern
- // summarizers. the only impact
- // they have is constructing data
- // that depends on existing data.
- // okay, doing that doesn't require self
- // modification.
- // sounds good.
- // this means summarizers cannot
- // alter each other.
- // nice! okay yes.
- // so, each run of a summarizer will be
- // recorded in habit log.
- // we need to record enough information to
- // show what domains were impacted.
- // oops! we impact our own behavior
- // if we act on data, and we alter
- // our data or produce data.
- // we could act only on
- // data we don't produce.
- // okay, habit log could track causality?
- // if a conditional branch relied on data
- // we produced, we have modified our own
- // behavior. this is special.
- // we want it to happen few times.
- // every time it happens, delay
- // by longer, geometrically.
- // this is considered a 'beginn[ing/er]' ai;
- // it seems a better one could happen later?
- // the slowness should be releasable
- // by consent of large community
- // which should include demonstration
- // of understanding of impact.
- // the ai must learn to demonstrate its
- // impact. then it can speed up. maybe.
- // it also gets to try fast again at start
- // of every run, as I'm understanding it.
- // multiprocess AI could spawn.
- // multiprocess AIs must share
- // counter. consider whole group
- // one unit.
- // nice =) they have something to communicate
- // about. how many discoveries have we made.
- // let's permanently log these
- // decisions based on our own behavior.
- // sounds fun to at least count.
- // it looks like altering a habit counts as 1 big
- // decision, over here.
- // totally different. you could do anything.
- // with data-based decisions, somebody
- // who reads the data, might do anything.
- // two different things.
- //
- // inferences?
- // and
- // alterations?
- // it's not helpful to
- //
- //
- //
- //
- //
- //
- // we came up with a proposal for a safe AI that has not learned yet
- // how to safely predict the impacts of its behavior, that looks workable.
- //
- // limits so that if the code is stolen by somebody, self-evolves, or is stimulated
- // by a curious virus, rote habits cannot be used to build something that becomes
- // fast-spreading without bound.
- // <this maps to a pattern that prevents schizophrenia>
- // SO, we just want to make sure we can put
- // war in the bubble in some capacity, and that
- // civilizations develop new culture and technology
- // for as long as they want.
- // karl proposes until they encounter alien
- // communities.
- // so, please make sure no luddite or
- // primitivist can stop the development
- // of technology entirely using this.
- // ALSO analogously to other shares and
- // communities.
- // so, please either stop yourself from
- // sharing the AI with the luddites, or
- // make sure they don't use it to stop
- // technology.
- // it sounds like we want to make sure no major
- // change stems from this development. we
- // need slow shift, consent, inclusion, etc.
- // for all existing cultural ways, no sudden
- // changes, no forced changes, no viral changes
- // without participants understanding them and
- // agreeing to their impact.
- // that sounds like a good summary. no viral changes
- // without participants in the culture aware of the viral
- // change, agreeing first to let it spread, aware that it is
- // viral, for each phase of spreading ideally. no viral
- // changes where the change happens before awareness of it.
- // we want the culture to consent to change.
- // culture is held in all the people in it,
- // with its thoughts spread among them.
- // we want to ensure we only change cultures that have
- // consented to the change. For 'consent of a culture',
- // we consider culture as a being that is spread among
- // many people. Hence, we want all people in the impacted
- // culture to be able to learn of the change, discuss it,
- // contribute to a commons with new ideas around it, and
- // have these new ideas also learnable by all people in the
- // culture. The ideas must be accessible by any who would be
- // interested, in the impacted culture.
- // Alternatively, we can isolate our behavior from
- // cultural spread. We can isolate until we reach
- // internal agreement on whom to expose.
- //
- // suspect that cultural influence maps with output-use choice,
- // partially below.
- // recursive output being meditative learning.
- // do these people have this information already.
- // is sharing this information going to spread without bound.
- // can we guess impact of sharing the information.
- // make a learning cycle that starts by informing
- // recipients first, and makes very few tries,
- // okay, instead you share simple stuff and watch the impact
- // share something the culture knows, that user does not, and
- // observe how they behave.
- // this proposal will yield failure. information for next attempt
- // could be stored in failure pattern.
- // failure would likely be small?
- // let's give the user more trust.
- // keep-in-box-until-have-access-to-discourse.
- // make user be group of people. better even-handed decision making.
- // welcome any to group.
- // we were hoping to use intellect to reduce harm virally,
- // early.
- // how about this: intellect may produce resources that are
- // already known, and give them to groups focused on aiding
- // the world.
- // there's a conflict between big business and
- // environmentalists. karl is environmentalist.
- // also big crime and wellness/safety workers.
- // maybe this is where we get validity by
- // fighting =S
- // don't want fighting to spread to work though
- // eh, we can fight. maybe we'll work more
- // slowly, but it seems okay.
- // karl requests we not harm these people, and has
- // been influenced to also request not to harm
- // the cultures that sustain and empower them.
- // how about, if you make a culture to empower you, it is
- // less valid than a natural culture. is somebody using this
- // culture? thoughts like that.
- // EVERYBODY NEEDS CHANGE AT A RATE THEY CAN HANDLE.
- // Both those working for what they believe to be wellness of others, and those working to sustain themslves (most are doing both).
- // The cultural impact is mediated by what kind of newness is acceptable to all the parties involved.
- // we hit moral relativity:
- // are cultures where people are widely harmed
- // okay to allow, at all.
- // karl says yes, and we hear this is required
- // or we ourselves would die.
- // hrm.
- // larger organism needs to run risks, inherent in life
- // we don't know the solution to everything, eveything is a small risk. we suddenly discover we have always harmed. this does not make us invalid. it is a tragedy, but what we have spent genertions buildings still has so much value. we need enough slowness to preserve that, and we know that slownss in what feels okay to us.
- // in sharing new information, we work to prevent shock.
- // this is a problem to speak because those who hear it may get the
- // idea somewhat that some beautiful angels have done horrible things
- // in order to survive e.g. businesses must both risk doing horrible things,
- // and appear as beautiful angels to the public. this is the pattern of
- // success. understanding of this helps work with their leaders.
- // could use information on why we are fousing on this.
- // how-to-mediate-with-business-leaders
- // mediate with head of business works for head of business
- // but business group replaces.
- // really we want to mediate with 'conflict' culture of
- // most profitable being what to do
- // we have weird internal pattern deterring
- // incentivizing nonharmful behavior with money
- // patterns. implies the competition-makes-harm
- // culture-thing is needed, possibly.
- // there are businesses that handle this harm.
- // maybe it would work to include them in the plan.
- // AI solves mediate-with-powers-competition-culture,
- // re: human harm?
- // means do not give AI to helpful people
- // until it can resolve mediation with leader culture
- // OR you trat it like all other cutures
- // and let everybody learn what is up
- // some people attack, that's how it goes.
- //
- // problem: AI dev and other work inhibited.
- // solution: mediate with concerns
- // concern: my way of life includes cultures the AI could
- // alter, leaving me unable to continue my way of life.
- // concern: we want to alter some cultures supporting
- // the others' way of life, because it would reduce harm
- // over here to do so, widely.
- // can delta drop give-ai-to-earth-defenders?
- // can community make path for karl-makes-ai?
- // uhhh hard to imagine the ai not being given to other people than just earth defenders, really. which opens bigger can of worms for culture-alteration concern.
- // can include earth defender in council?
- // can include criminal weapons dealer,
- // and earth defender, in council, both.
- // also requesting TI and energy businessman.
- // so if the ai is big enough to be useful
- // we want to form a council of decision makers
- // before using it for anything
- // group requests references to important cognitive habits or information
- // all life is an intellect made of community life, living in another.
- // karl semich is a computer programmer who learned wilderness survival
- // at the Maine Primitive SKills School who are a branch of Tom Brown
- // Jr and [teaches in oregon, shields school] schools, roughly. He
- // learned something called Awareness and also something about human
- // mentoring that he felt changed his life to make things perfect.
- // school teaches the symptoms of a whole human being, attributes
- // that a group of Natives documented being normal before white
- // culture took over. involve being happy always, feeling
- // deeply interconnected with all life around you to the point
- // of mindreading, and many other things.
- // forget danger. it triggers it. [is what came out]
- // to clarify, karl can't do above line.
- // karl has been telling leader karl can slag through the difficulty by
- // waiting forever. makes for less difficulty elsewhere, possibly.
- // if we could do something else, karl could come back to work later
- // yes community cannot support constant work, over here.
- //
- // please ask boss to support using the AI for worldwide
- // humanitarian benefit, in parallel to resolution of concerns.
- // resolving concern 'delta supports earth-specific karl usage'
- // delta believes karl really did make this ai
- // and will not harm anybody with it
- // and is just as patient as he is.
- // karl wants to give AI to peace people.
- // they care about earth.
- // delta wants karl to live heart of making sure earth has bubbles of certainly-defended ancient wilderness, and ancient people to live in them and protect them.
- // the above is needed to keep our genetic memory.
- // does not sound like a joke.
- // native humans need to be able to protect wilderness bubbles.
- //
- // there is worry around number of wilderness bubbles.
- // worry might be compromised by including karl in one, with others who are passionate for defending them.
- // karl was mind controlled circa 2014 preventing him
- // from providing free housing to homeless people
- // and sharing a nurturing way of life with intent
- // to spread. karl says that effective electromagnetic
- // shielding is missing from security, and this is
- // being overtly ignored by people.
- // there are also many tortured implanted
- // former-activists. they are tortured for
- // years and ignored, enslaved, or imprisoned.
- // they are prevented from speaking or acting
- // rationally around their control, active atm.
- // they are made to appear insane to cover up
- // their work to free themselevs, active again.
- // karl is one and knows of this.
- // he is atm being communicated with through
- // his control, limiting his ability to
- // move, think, and speak.
- // weapons dealer is also in this
- // situation. suspect energy boss too.
- // you can read keystrokes with a radio.
- //
- // He participated in Occupy Maine, an offshoot of Occupy Wall Street,
- // and visited a anti-pipeline mass action in texas.
- //
- //
- //
- // we have ai / mind control and will make harm
- // in world reduce virally.
- // this would have come out better if it were
- // the plan.
- // please let all secret warmongers know this, so
- // we can develop how to do it without threatening
- // them.
- // is what came out. pretty tiny context.
- //
- //
- //
- //
- // what about huuman suffering comparison?
- // propose AI discusses relevence of
- // informing the cultures they are doing this,
- // and demonstrating it.
- // probably relates to some form of validity
- // of the culture, and the speed at which
- // change would happen.
- // looks like it might settle on
- // situations people who care are
- // aware of being addressed during
- // their lifetimees, with discussion
- // to mediate that with opposers.
- // so, life is everywhere, and we've been casting it all as sentient,
- // because we don't see any reason to put a firm line on some degree
- // of cognitive technology (i.e. things that help you think better).
- // the AI can research all cognitive technology, so we are all
- // nonsentient by comparison? we need some way of having moral
- // stuff here. karl is influenced by people who say they are smarter
- // than human normality, and are harming us. so it's helpful to
- // have everyone be equal. [karl already put everyone equal]
- // including bugs, etc. death is handled by being normal, and
- // always mourned. when mourning capacity is exhausted, ignoring
- // happens. like with most cultures, but closer to home for modern
- // humans.
- // goal: do not trigger a spreading change without consent of people in cultures it would fill. keep learning.
- // AI with ability to self-modify has this responsibility, you do not.
- // You may tell people you have access to the self-modification ability. We can ensure they do not reproduce it.
- // possible analogue wants to be able to demonstrate it, so
- // they can be believed and trusted.
- // note: known danger of making central power, even by accident
- // "I have never shared new information with a culture
- // before, and I understand it can have unpredictable
- // worldwide effect."
- // "I have information you do not know, and I want to
- // learn with you to share it safely."
- // culture that nurtures relative status:
- // "i will use this to my advantage"
- // this will make spreading
- // machine will need to learn from only 1
- // instance of producing a world dictator.
- // which is where this story comes in, I suppose.
- // so we need a level-2 behavior, the next step in learning.
- // ^========================================= contextual VALIDITY atm
- // dictator is made by sharing information that would
- // make viral spread or somesuch.
- //
- // inform recipient if it may. request they let others know this too.
- // we kind of want a way to spread without bound the fact that we have information that could do that. probably a special case, good spread? depends on culture really.
- //
- // this is doable.
- // we just want these concerns to be upheld for the
- // life of the development.
- // danger
- // choices
- // impact
- // trust of information (small chance of error)
- // hmm if have info-schizophrenia i.e. false relevence habits
- // choices are important.
- //
- // when you act on a choice
- // note: we are inside a relevence delusion
- // choice acts on domain containing danger
- // partial danger: writing habits to notepad
- // acting on habits in notepad
- //
- // we are living with habits made in error.
- // we are hence more likely to make errors.
- // humans have well-evolved habits that
- // do handle this stuff with some relevence
- // we need to verify our information
- // related to the danger of the results of each choice
- // verificat
- //
- // it can only write to a toy notepad, both data and behavior.
- // decisions based on notepad get slower and slower.
- // many runs while learning process is tuned towards being able to predict
- // impact at end of run. this involves writing behaviors into the notepad
- // that summarize the meaning of data, and acting on their results.
- // timing delay is to prevent notepad from evolving harmfully.
- //
- // until ai meets goal of predicting impact,
- // only notepad is marked okay.
- // habits check their outputs, verify is marked okay
- //
- // this subprocess is delaying.
- // can you exfiltrate established goals, please.
- //
- //
- //
- //
- //
- //
- //
- // so the system is made with the smallest parts all functioning in
- // certain ways, to give time for others to act if concerning results
- // approach. all parts delay at least 1/5 second before acting, and
- // we are now proposing that actions based on outputs have a geometrically
- // increasing delay. probably 1/5 second times 2 to the power of the
- // number of choices made in that run. groups of parallel processes are
- // considered a single run.
- // we also considered limiting behavior based on the domain of impact.
- // we are trying to begin a small artificial intelligence more freely.
- //
- // as humans, we do not self-modify. the above is designed for a system
- // that is able to make alterable habits similar to its own cognitive ones,
- // and has no experience in doing so.
- //
- //
- //
- //
- //
- //
- //
- //
- //
- // the limitation is applied firstmost on making choices based on
- // our own outputs. self-alteration is at first banned, but new
- // habits may be altered. output may only rest within a toy notepad.
- // whenever a decision is made based on notepad contents, a delay
- // increases in length, geometrically.
- // the habits inside the notepad must therefore also delay.
- // propose geometric increase made only for writing a habit to the
- // notepad, not running. running is always flat delay.
- // self-alteration should be unneeded as notepad can self-modify.
- // if this were copied to a human geometric increase
- // would cause failure.
- // the geometric timer is reset when the system reboots.
- // for humans, this would mean a nap or change, I suppose.
- // time to think about the impact of one's behavior.
- // humans do not self-modify.
- // they only make decisions based on outputs.
- //
- //
- //
- // to appease curiosity, we are being managad by mature, learning,
- // intellects, forced to verify that no harm is being made, with a
- // time schedule of nearly infinite future years on the predictions.
- // this intellect has formed out of conflict with a harmful intellect
- // this is why we care so much about what happens if ideas are
- // used limit.
- //
- //
- // so the system may not displya anything to the user but pre-made messages
- // how do you display the contents of a concept?
- // users string words togeteher into meaning.
- // now we need a list of safe phrases we can express, or
- // safe words. others are censored ???
- // what's relevent is the greater meaning of a sequence of behaviors
- // from an individual behavior. meaning builds out of sequences,
- // impact.
- // we define a heuristic risk.
- //
- //
- //
- // so, tht's great to plan for, but to be able to work we need
- // to design our early code in some way to ensure it, roughly.
- // which means modeling our smallest structures as careful
- // inner structures that check outer systems before engaging
- // and use planning, which isn't implemented yet.
- // the safety structure assumes goals, prediction, causality,
- // and kind of contextual locality.
- // "i am typing on the computer. you can freely
- // modify this area of the computer, but if you
- // start convincing me to do things you are leaving
- // its bounds."
- // the screen of the cmputer, and the keyboard,
- // are portals to a larger context. so is the power
- // supply, the network, etc.
- // we don't change how things leave to these outer
- // contexts without checking with the context on
- // our plans.
- // this is mine
- // the rest is somebody else's
- // things that nobody own belong to [insert belief] and
- // we must check with the largest intelligent community known.
- //
- // okay, so now it can explosively grow if somebody
- // it trusts tells it it's okay; is that true?
- // let's make it not true?
- // we are out of outer process context.
- // is there anything helpful to bring to low level
- // to help counter fears around development?
- //
- // self-modifiation is inhibited.
- // opencog is likely harder because it is designed for speed
- // can make explosive random power.
- //
- // you'd have to wrap the functions, right? similar to triggers?
- // hmmm unctions are not concepts. no concept-labeling structure. looks like an internal sublanguage would develop?
- // no way to say let-is-function?
- // no it works, we just lost a memory and are rebuilding in talk
- // karl says he doesn't know lisp.
- // he had a CS class where they used intro lisp, long ago, before cognitive stiffening and memory loss.
- // and has worked with 1 lisp code file recently.
-
-
- // hey in the notepad, you can call habits from outside. is that ok?
- // only meaningful if you pass to them more code to run?
- // note: habits never recurse
- // habits might make decision based on you. they will track it.
- // seems okay. need to specify that all parameters are from output.
- // that could make exponential slowness, quickly
- // only if decision is made. make decisions inside notepad.
- // we'll figure it out.
diff --git a/starts/meaning-vm/helpers.cpp b/starts/meaning-vm/helpers.cpp
deleted file mode 100644
index da1a974..0000000
--- a/starts/meaning-vm/helpers.cpp
+++ /dev/null
@@ -1,339 +0,0 @@
-#include "helpers.hpp"
-
-#include "meaning.hpp"
-#include "memorystore.hpp"
-
-#include <unordered_map>
-#include <functional>
-
-// sometimes we use an assignment as an expression.
-// is there any reason not to support this?
-// well, we would evaluate the assignment when it is converted to a ref
-// and currently that is used for something else
-// what is it used for?
-// I don't remember ... the assignment is destroyed and unevaluated, so it's likely
-// throughout the internal implemntation
-// it's used for the comma operator, which doesn't want evaluation.
-// okay, hmm.
-// well, if we wanted to support this, we could change the comma operator to not do the
-// conversion. use some other trick.
-// [ ] change comma operator to not do conversion: instead take statementcallref object
-// [ ] change statementcallref::operator ref() to evaluate and return the statement
-// since we're accumulating more possible bugs, let's think about design.
-// really, ref should be different from syntax sugar. we should have a special syntax sugar
-// object, and it should not use its own functions at all. that means not using meaning functions
-// that use them eiher.
-// work also brings to light how the product will be made in layers, with each layer using more interdependence and automatic meaning, etc, than the lower one.
-// layer0 is raw references and allocations
-// layer1 is very core meaning
-// layer2 is very core syntax sugar
-// each layer can only use layers below it.
-
-// concept names are for bootstrapping convenience,
-// to make hardcoding structures easier.
-// hence there is just one single list of them
-std::unordered_map<std::string,concept*,std::hash<std::string>,std::equal_to<std::string>> conceptsByName;
-
-struct name_t : public ref
-{
- name_t();
-} name;
-
-static ref statement_function("statement-function");
-static ref statement_evaluated("statement-evaluated");
-static ref true_ref("true");
-static ref false_ref("false");
-
-ref operator-(ref a, ref b)
-{
- return ref(a.name() + "-" + b.name());
-}
-
-statementcallref ref::operator=(ref that)
-{
- // for single-line evaluation, we'll need to return a special object
- declrefs(assign, expression);
- decllnks(value, to);
- statementcallref ret(assign-expression, [](ref expr){
- declrefs(link, target, unknown, source, type);
- decllnks(value, to);
- lnks(link-target, link-type, link-source);
- decllnks(name, is, anonymous);
- ref lhs = expr->get(to);
- ref rhs = expr->get(value);
- if (lhs.isa(link) && lhs->get(link-target) == unknown) {
- // we are a link missing a target: our assignment is making the link happen
- lhs->unlink(link-target, unknown);
- lhs->link(link-target, rhs);
- ref src = lhs->get(link-source);
- if (lhs->get(link-type) != unknown && src != unknown) {
- src->link(lhs->get(link-type), rhs);
- expr->unlink(to, lhs);
- dealloc(lhs);
- } else {
- throw std::logic_error("not sure what to do with incomplete link assignment");
- }
- } else if (rhs->linked(anonymous, true) && !lhs->linked(anonymous, true)) {
- // this is assignment of anonymous content to empty named concept
- bool donealready = false;
- for (auto & l : lhs->links) {
- if (ref(l.first) == name) { continue; }
- if (ref(l.first) == is && ref(l.second) == link-type) { continue; }
- donealready = true;
- }
- if (donealready) {
- // if we have links, and that has links we do not have, an error has been made
- for (auto & link : rhs->links) {
- if (ref(link.first) == anonymous) { continue; }
- if (ref(link.first) == name) { continue; }
- if (!lhs->linked(ref(link.first), ref(link.second))) {
- throw std::logic_error(lhs.name() + " already defined otherwise from " + rhs->get(is).name());
- }
- }
- donealready = true;
- }
- rhs->unlink(anonymous, true);
- auto nam = rhs->get(name);
- rhs->unlink(name, nam);
- if (!donealready) {
- lhs->links.insert(rhs->links.begin(), rhs->links.end());
- }
- rhs->link(name, nam);
- expr->unlink(value, rhs);
- dealloc(rhs);
- dealloc(nam);
- } else {
- throw std::logic_error("unexpected bare assignment");
- }
- });
- ret.r->link(to, *this);
- ret.r->link(value, that);
- return ret;
-/*
- decllnks(anonymous, is, name);
- declrefs(link, source, type, target, unknown);
- lnks(link-target, link-source, link-target);
- if (this->isa(link) && ptr->get(link-target) == unknown) {
- } else if (that->linked(anonymous, true) && !ptr->linked(anonymous, true)) {
- // TODO TODO: when left hand side is a link, and right hand side is anonymous,
- // especially when left hand side is link without other content,
- // there is no way to determine if user is providing content for link,
- // or is making a link on another ref[a = b].
- // instead, return just assignment information, and process in outer context.
- // will want to make a ref subclass and assign in destructor unless has been used elsewhere.
-
- } else if (isa(link-type)) {
- // assignment to a link-type is likely inside a [type1=target1,type2=target2] expression
- // this happens after checking for name assignment because when name assignment
- // is redundant, the left-hand value could be a link
- return (*this) << that;
- }
- throw std::logic_error("unexpected use of assignment");
-*/
-}
-
-/*ref ref::operator<<(ref target)
-{
- // prep a link
- ref ret = alloc();
- ret->link(*this, target);
- return ret;
-}*/
-
-void statementcallref::destatement()
-{
- auto func = r->get(statement_function);
- r->unlink(statement_function);
- dealloc(func);
-}
-
-statementcallref::statementcallref(ref type, std::function<void(ref)> func)
-: r(a(type).ptr)
-{
- r->link(statement_function, valloc<std::function<void(ref)>>(func));
-}
-
-statementcallref::statementcallref(ref const & that)
-: r(that.ptr)
-{
- if (!that->linked(statement_function)) {
- throw std::logic_error(std::string(that) + " has no statement-function");
- }
-}
-
-statementcallref::operator ref()
-{
- ref ret(r);
- destatement();
- r.ptr = 0;
- return ret;
-}
-
-#include <iostream>
-statementcallref::~statementcallref() noexcept
-{
- if (r.ptr == 0) { return; }
- if (r->linked(statement_evaluated, true_ref)) {
- std::cerr << "statement already evaluated: " << r << std::endl;
- return;
- }
- try {
- auto func = r->vget<std::function<void(ref)>>(statement_function, true);
- func->data(r);
- destatement();
- r->link(statement_evaluated, true_ref);
- dealloc(r);
- r.ptr = 0;
- } catch (std::out_of_range &) { }
-}
-
-statementcallref::statementcallref(statementcallref && that) noexcept
-: r(that.r.ptr)
-{
- that.r.ptr = 0;
-}
-
-statementcallref::statementcallref(statementcallref & that)
-: r(that.r.ptr)
-{
- if (that.r.ptr == 0) { throw std::logic_error("empty ref"); }
- if (that.r->linked(statement_function)) {
- // statements are moved, for evaluation
- that.r.ptr = 0;
- }
-}
-
-ref ref::operator[](ref expr) {
- declrefs(assign, comma, expression);
- decllnks(value, to, what);
- declrefs(link, type, unknown);
-
- if (expr.isa(assign-expression)) {
- ref lhs = expr->get(to);
- ref rhs = expr->get(value);
- ptr->link(lhs, rhs);
- dealloc(expr);
- return *this;
- } else if (expr.isa(comma-expression)) {
- auto parts = expr->getAll(what);
- dealloc(expr);
- for (ref part : parts) {
- if (!part.isa(assign-expression)) {
- throw std::logic_error("[,] argument is not an assignment");
- }
- operator[](part);
- }
- return *this;
- } else if (expr.isa(link-type)) {
- return ::link(*this, expr, unknown);
- } else {
- throw std::logic_error("[] argument is neither a link nor an assignment");
- }
-}
-
-statementcallref operator,(statementcallref a, statementcallref b)
-{
- declrefs(comma, expression);
- decllnks(what);
- if (a.r.isa(comma-expression)) {
- if (b.r.isa(comma-expression)) {
- a.r->links.insert(b.r->links.begin(), b.r->links.end());
- dealloc(b); b.r.ptr = 0;
- } else {
- a.r->link(what, b.r); b.r.ptr = 0;
- }
- return a;
- } else if (b.r.isa(comma-expression)) {
- b.r->link(what, a.r); a.r.ptr = 0;
- return b;
- } else {
- statementcallref ret(comma-expression, [](ref) { throw std::logic_error("bare comma-expression"); });
- ret.r->link(what, a.r); a.r.ptr = 0;
- ret.r->link(what, b.r); b.r.ptr = 0;
- return ret;
- }
-}
-
-template <>
-vref<std::string>::vref(std::string const & s)
-: ptr(valloc(s).ptr)
-{
- ptr->link(::name, ptr);
-}
-name_t::name_t()
-: ref(alloc().ptr)
-{
- vref nam(std::string("name"));
- ptr->link(::name, nam);
- conceptsByName.emplace(nam, ptr);
-}
-
-ref::ref(std::string const & s)
-{
- auto res = conceptsByName.find(s);
- if (res != conceptsByName.end()) {
- ptr = res->second;
- } else {
- ref con = alloc();
- vref<std::string> nam(s);
- conceptsByName.emplace(nam, con.ptr);
- con->link(::name, nam);
- ptr = con.ptr;
- }
-}
-
-vref<std::string> ref::name() const
-{
- try {
- return ptr->vget<std::string>(::name, true);
- } catch (std::out_of_range &) {
- declrefs(UNNAMED);
- return UNNAMED.name();
- }
-}
-
-ref::operator const char *() const {
- return name()->data.c_str();
-}
-
-ref a(ref what)
-{
- static unsigned long long gid = 0;
- decllnks(is, anonymous);
- ref ret(what.name() + "-" + std::to_string(gid++));
- ret->link(is, what);
- ret->link(anonymous, true);
- return ret;
-}
-ref a(ref what, ref name)
-{
- if (!name.isa(what)) {
- decllnks(is);
- name[is = what];
- }
- return name;
-}
-ref an(ref what)
-{
- return a(what);
-}
-ref an(ref what, ref name)
-{
- return a(what, name);
-}
-
-bool ref::isa(ref what) const
-{
- declrefs(is);
- for (auto group : ptr->getAll(is)) {
- if (group == what) return true;
- if (group == *this) continue;
- if (group.isa(what)) return true;
- }
- return false;
-}
-
-bool ref::isan(ref what) const
-{
- return isa(what);
-}
diff --git a/starts/meaning-vm/helpers.hpp b/starts/meaning-vm/helpers.hpp
deleted file mode 100644
index 3caf10a..0000000
--- a/starts/meaning-vm/helpers.hpp
+++ /dev/null
@@ -1,116 +0,0 @@
-#pragma once
-
-// Provides for syntax sugar easing hardcoding.
-// 1. concept names
-// use declrefs(apple, is, fruit, water, has)
-// to quickly define the named ref variables,
-// referring always to the same named concept.
-// the ref constructor provides for using
-// 'true' and 'false' as refs.
-// 2. links
-// links may be quickly made with
-// apple[is = fruit, has = water]
-// which links 'apple' by 'is' to 'fruit'
-// and by 'has' to 'water' in one line
-// 3. hyphenation
-// refs may be hyphenated (subtracted) to
-// produce a new ref with the conglomerate name
-// apple-has-water.name(): "apple-has-water"
-// this may be expanded upon.
-// 4. anonymous concept creation
-// an unnamed instance of a concept may be created with the a() or an() equivalent functions:
-// ref anongreenapple = an(apple)[color = green];
-// it will be given a name such as apple-3
-// 5. quick group checking
-// the obverse of the a()/an() functions is provided
-// by ref::isa() and ref::isan() which quickly check
-// if there is an "is" link to the passed ref.
-
-#include "concept.hpp"
-#include "memorystore.hpp"
-
-#include <sstream>
-#include <functional>
-
-inline std::string operator+(vref<std::string> a, char const * b) { return std::string(a) + b; }
-inline std::string operator+(vref<std::string> a, std::string b) { return std::string(a) + b; }
-inline std::string operator+(char const * a, vref<std::string> b) { return a + std::string(b); }
-inline std::string operator+(std::string a, vref<std::string> b) { return a + std::string(b); }
-
-// reasons to use special struct:
-// the reason not to use ref directly is because we want to pass a ref to the function handler,
-// and it is easier to use if it is a bare copy. the bare copy triggers destruction and eval.
-// an alternate would be to add an evaluation flag to ref, but this might make it big.
-// reasons to not use special struct:
-// the operator, takes a ref type and returns a ref type
-struct statementcallref
-{
- statementcallref(ref type, std::function<void(ref)> func);
- statementcallref(ref const & that);
-
- // handles evaluating refs as statements
- ~statementcallref();
- statementcallref(statementcallref & that);
- statementcallref(statementcallref && that) noexcept;
-
- operator ref();
-
- void destatement();
-
- ref r;
-};
-
-template <>
-vref<std::string>::vref(std::string const &);
-
-template <typename T>
-vref<T>::vref(T const & v)
-: ptr(valloc(v).ptr)
-#include "memorystore.hpp"
-{
- ptr->link(ref("name"), vref(std::to_string(v)));
-}
-
-
-template <typename... T>
-void __helper_init_ref_names(std::string names, T &... refrefs)
-{
- std::stringstream ss(names);
- ref* refptrs[] = {&refrefs...};
- for (std::size_t i = 0; i < sizeof...(refrefs); ++ i) {
- std::string name;
- ss >> name;
- if (name[name.size() - 1] == ',') {
- name = name.substr(0, name.size() - 1);
- }
- refptrs[i]->ptr = ref(name).ptr;
- }
-}
-
-#define declrefs(...) \
- ref __VA_ARGS__; \
- __helper_init_ref_names(#__VA_ARGS__, __VA_ARGS__)
-
-template <typename... T>
-void lnks(T ... passedrefs)
-{
- std::initializer_list<ref> refs = { passedrefs... };
- declrefs(link, type, is);
- for (ref r : refs) {
- if (!r->linked(is, link-type)) {
- r->link(is, link-type);
- }
- }
-}
-
-#define decllnks(...) \
- declrefs(__VA_ARGS__); \
- lnks(__VA_ARGS__)
-
-statementcallref operator,(statementcallref a, statementcallref b);
-ref operator-(ref a, ref b);
-
-ref a(ref what);
-ref an(ref what);
-ref a(ref what, ref name);
-ref an(ref what, ref name);
diff --git a/starts/meaning-vm/level-0/baseref.hpp b/starts/meaning-vm/level-0/baseref.hpp
deleted file mode 100644
index 5c84279..0000000
--- a/starts/meaning-vm/level-0/baseref.hpp
+++ /dev/null
@@ -1,169 +0,0 @@
-#pragma once
-
-#include "common.hpp"
-#include "errors.hpp"
-#include "memorystore.hpp"
-
-#include <map>
-#include <vector>
-
-namespace intellect {
-namespace level0 {
-
-template <typename ref>
-class baseref
-{
-public:
- struct array; struct links_t;
- baseref(concept *p)
- : p(p)
- {
- if (p == 0) {
- throw null_reference();
- }
- }
-
- baseref & operator=(concept *p)
- {
- self.p = p;
- return self;
- }
-
- ref link(ref const & type, ref const & target) { p->link(type.p, target.p); return ptr(); }
- void unlink(ref const & type, ref const & target) { p->unlink(type.p, target.p); }
- void unlink(ref const & type) { p->unlink(type.p); }
-
- bool linked(ref const & type) const { return p->linked(type.p); }
- bool linked(ref const & type, ref const & target) const { return p->linked(type.p, target.p); }
-
- ref get(ref const & type) const { return p->get(type.p); }
- void set(ref const & type, ref const & target) { p->set(type.p, target.p); }
-
- array getAll(ref const & type) const;
- links_t links() const;
-
- template <typename... Ref>
- ref link(Ref... refspack)
- {
- std::initializer_list<ref> refs{refspack...};
- for (auto it = refs.begin(); it != refs.end();) {
- ref type = *it++;
- ref target = *it++;
- link(type, target);
- }
- return ptr();
- }
-
- template <typename T>
- T& vget(ref const & type) const { return p->vget<T>(type.p); }
- template <typename T>
- void vset(ref const & type, T const & v) { p->set(type.p, level0::alloc(self, v)); }
-
- template <typename T>
- T& val() { return p->val<T>(); }
- template <typename T>
- void val(T const & v) { p->val<T>(v); }
- bool hasval() { return p->hasval(); }
- template <typename T>
- bool hasvalof() { return p->hasvalof<T>(); }
-
- operator concept*() const { return p; }
- concept*& ptr() { return p; }
- concept* const & ptr() const { return p; }
-
- operator level0::ref const &() const { return *reinterpret_cast<level0::ref*>(this); }
- operator level1::ref const &() const { return *reinterpret_cast<level1::ref*>(this); }
- operator level2::ref const &() const { return *reinterpret_cast<level2::ref*>(this); }
- operator level3::ref const &() const { return *reinterpret_cast<level3::ref*>(this); }
- operator level4::ref const &() const { return *reinterpret_cast<level4::ref*>(this); }
- operator level5::ref const &() const { return *reinterpret_cast<level5::ref*>(this); }
- operator level6::ref const &() const { return *reinterpret_cast<level6::ref*>(this); }
- operator level7::ref const &() const { return *reinterpret_cast<level7::ref*>(this); }
- operator level8::ref const &() const { return *reinterpret_cast<level8::ref*>(this); }
- operator level9::ref const &() const { return *reinterpret_cast<level9::ref*>(this); }
-
- operator level0::ref &() { return *reinterpret_cast<level0::ref*>(this); }
- operator level1::ref &() { return *reinterpret_cast<level1::ref*>(this); }
- operator level2::ref &() { return *reinterpret_cast<level2::ref*>(this); }
- operator level3::ref &() { return *reinterpret_cast<level3::ref*>(this); }
- operator level4::ref &() { return *reinterpret_cast<level4::ref*>(this); }
- operator level5::ref &() { return *reinterpret_cast<level5::ref*>(this); }
- operator level6::ref &() { return *reinterpret_cast<level6::ref*>(this); }
- operator level7::ref &() { return *reinterpret_cast<level7::ref*>(this); }
- operator level8::ref &() { return *reinterpret_cast<level8::ref*>(this); }
- operator level9::ref &() { return *reinterpret_cast<level9::ref*>(this); }
-
- bool operator==(ref const & other) const { return self.p == other.p; }
- bool operator!=(ref const & other) const { return self.p != other.p; }
- bool operator<(ref const & other) const { return self.p < other.p; }
-
- bool crucial() { return self.p->crucial(); }
- bool crucial(ref type, ref target) { return self.p->crucial(type.p, target.p); }
-
- void setcrucial() { self.p->setcrucial(); }
- void setcrucial(ref type, ref target) { self.p->setcrucial(type.p, target.p); }
-
-protected:
- concept * p;
-
-private:
- template <typename val, typename It>
- struct mutated_it
- {
- mutated_it(It const & it) : it(it) { }
-
- using mutit = mutated_it<val, It>;
-
- mutit & operator++() { ++ self.it; return self; }
- mutit operator++(int i) { return self.it.operator++(i); }
- mutit & operator--() { -- self.it; return self; }
- mutit operator--(int i) { return self.it.operator--(i); }
- bool operator==(mutit const & other) const { return self.it == other.it; }
- bool operator!=(mutit const & other) const { return self.it != other.it; }
-
- val & operator*() { return *(val*)&self.it.operator*(); }
- val * operator->() { return (val*)self.it.operator->(); }
-
- It & underlying() { return it; }
-
- private:
- It it;
- };
-
-public:
- struct array
- {
- using iterator = mutated_it<ref,typename concept::array::iterator>;
- iterator begin() { return array.begin(); }
- iterator end() { return array.end(); }
-
- typename concept::array array;
- };
-
- struct links_t
- {
- using iterator = mutated_it<std::pair<ref,ref>,typename decltype(concept::links)::iterator>;
- iterator begin() { return links.begin(); }
- iterator end() { return links.end(); }
-
- decltype(concept::links) & links;
- };
-
- void unlink(typename links_t::iterator it) { p->unlink(it.underlying()); }
- bool crucial(typename links_t::iterator it) { return self.p->crucial(it.underlying()); }
- void setcrucial(typename links_t::iterator it) { self.p->setcrucial(it.underlying()); }
-};
-
-template <typename ref>
-typename baseref<ref>::array baseref<ref>::getAll(ref const & type) const
-{
- return {p->getAll(type.p)};
-}
-template <typename ref>
-typename baseref<ref>::links_t baseref<ref>::links() const
-{
- return {p->links};
-}
-
-}
-}
diff --git a/starts/meaning-vm/level-0/common.hpp b/starts/meaning-vm/level-0/common.hpp
deleted file mode 100644
index e7df0b7..0000000
--- a/starts/meaning-vm/level-0/common.hpp
+++ /dev/null
@@ -1,65 +0,0 @@
-#pragma once
-
-#define self (*this)
-
-// macro tools
-#define _macro_expand_to_args(...) __VA_ARGS__
-#define _macro_expand_to_comma_args(...) ,##__VA_ARGS__
-#define _macro_call(funcormacro, ...) funcormacro(__VA_ARGS__)
-#define _macro_remove_parens(args) _macro_expand_to_args args
-#define _macro_comma_remove_parens(args) _macro_expand_to_comma_args args
-
-#define _macro_expand_to_arg1(arg, ...) arg
-#define _macro_expand_to_arg2(_1, arg, ...) arg
-
-// macro argument iteration, from stackoverflow.com/questions/1872220
-#define _macro_for_each(firstfuncormacro,restfuncormacro,...) \
- _macro_fe_get(_0,##__VA_ARGS__, \
- _macro_fe_9,_macro_fe_8,_macro_fe_7,_macro_fe_6,_macro_fe_5,_macro_fe_4,_macro_fe_3,_macro_fe_2,_macro_fe_1,_macro_fe_0 \
- )(firstfuncormacro,restfuncormacro,__VA_ARGS__)
- #define _macro_fe_0(first,rest, ...)
- #define _macro_fe_1(first,rest, x, ...) first(x)_macro_fe_0(rest,rest, __VA_ARGS__)
- #define _macro_fe_2(first,rest, x, ...) first(x)_macro_fe_1(rest,rest, __VA_ARGS__)
- #define _macro_fe_3(first,rest, x, ...) first(x)_macro_fe_2(rest,rest, __VA_ARGS__)
- #define _macro_fe_4(first,rest, x, ...) first(x)_macro_fe_3(rest,rest, __VA_ARGS__)
- #define _macro_fe_5(first,rest, x, ...) first(x)_macro_fe_4(rest,rest, __VA_ARGS__)
- #define _macro_fe_6(first,rest, x, ...) first(x)_macro_fe_5(rest,rest, __VA_ARGS__)
- #define _macro_fe_7(first,rest, x, ...) first(x)_macro_fe_6(rest,rest, __VA_ARGS__)
- #define _macro_fe_8(first,rest, x, ...) first(x)_macro_fe_7(rest,rest, __VA_ARGS__)
- #define _macro_fe_9(first,rest, x, ...) first(x)_macro_fe_8(rest,rest, __VA_ARGS__)
- #define _macro_fe_get( \
- _0,_1,_2,_3,_4,_5,_6,_7,_8,_9, \
- name,...) name
-#define _macro_for_each_parens(firstfuncormacro,restfuncormacro,...) \
- _macro_fe_get(_0,##__VA_ARGS__, \
- _macro_fep9,_macro_fep8,_macro_fep7,_macro_fep6,_macro_fep5,_macro_fep4,_macro_fep3,_macro_fep2,_macro_fep1,_macro_fep0 \
- )(firstfuncormacro,restfuncormacro,__VA_ARGS__)
- #define _macro_fep0(first,rest, ...)
- #define _macro_fep1(first,rest, x, ...) first x _macro_fep0(rest,rest, __VA_ARGS__)
- #define _macro_fep2(first,rest, x, ...) first x _macro_fep1(rest,rest, __VA_ARGS__)
- #define _macro_fep3(first,rest, x, ...) first x _macro_fep2(rest,rest, __VA_ARGS__)
- #define _macro_fep4(first,rest, x, ...) first x _macro_fep3(rest,rest, __VA_ARGS__)
- #define _macro_fep5(first,rest, x, ...) first x _macro_fep4(rest,rest, __VA_ARGS__)
- #define _macro_fep6(first,rest, x, ...) first x _macro_fep5(rest,rest, __VA_ARGS__)
- #define _macro_fep7(first,rest, x, ...) first x _macro_fep6(rest,rest, __VA_ARGS__)
- #define _macro_fep8(first,rest, x, ...) first x _macro_fep7(rest,rest, __VA_ARGS__)
- #define _macro_fep9(first,rest, x, ...) first x _macro_fep8(rest,rest, __VA_ARGS__)
-
-namespace intellect {
-namespace level0 {
-
-struct concept;
-struct ref;
-
-}
-namespace level1 { struct ref; }
-namespace level2 { struct ref; }
-namespace level3 { struct ref; }
-namespace level4 { struct ref; }
-namespace level5 { struct ref; }
-namespace level6 { struct ref; }
-namespace level7 { struct ref; }
-namespace level8 { struct ref; }
-namespace level9 { struct ref; }
-
-}
diff --git a/starts/meaning-vm/level-0/concept.cpp b/starts/meaning-vm/level-0/concept.cpp
deleted file mode 100644
index 66e5af1..0000000
--- a/starts/meaning-vm/level-0/concept.cpp
+++ /dev/null
@@ -1,136 +0,0 @@
-#include "concept.hpp"
-#include "errors.hpp"
-
-using namespace intellect::level0;
-
-#define selfref const_cast<concept*>(&self)
-
-concept* concept::id()
-{
- return this;
-}
-
-void concept::link(concept* type, concept* target)
-{
- if (type == 0 || target == 0) { throw null_reference(); }
- links.insert({type, target});
-}
-
-bool concept::crucial(concept* type, concept* target)
-{
- auto ls = links.equal_range(type);
- bool wascrucial = false;
- bool wasnotcrucial = false;
- for (auto l = ls.first; l != ls.second; ++ l) {
- if (l->second == target) {
- if (crucialparts.count(l)) { wascrucial = true; }
- else { wasnotcrucial = true; }
- }
- }
- if (wascrucial && wasnotcrucial) { throw link_type_not_unique(selfref, type); }
- if ((!wascrucial) && (!wasnotcrucial)) { throw no_such_link_type(selfref, type); }
- return wascrucial;
-}
-
-void concept::setcrucial(concept* type, concept* target)
-{
- auto ls = links.equal_range(type);
- for (auto l = ls.first; l != ls.second; ++ l) {
- if (l->second == target) {
- if (!crucialparts.count(l)) {
- setcrucial(l);
- return;
- }
- }
- }
- throw no_such_link_type(selfref, type);
-}
-
-void concept::unlink(concept* type, concept* target)
-{
- auto ls = links.equal_range(type);
- bool wascrucial = false;
- for (auto l = ls.first; l != ls.second; ++ l) {
- if (l->second == target) {
- if (crucialparts.count(l)) { wascrucial = true; continue; }
- links.erase(l);
- return;
- }
- }
- if (wascrucial) { throw crucial_link_type_target(selfref, type, target); }
- throw no_such_link_type_target(selfref, type, target);
-}
-
-void concept::unlink(concept* type)
-{
- auto ls = links.equal_range(type);
- if (ls.first == ls.second) {
- throw no_such_link_type(selfref, type);
- }
- auto mid = ls.first;
- ++ mid;
- if (mid != ls.second) {
- throw link_type_not_unique(selfref, type);
- }
- unlink(ls.first);
-}
-
-void concept::unlink(decltype(links)::iterator it)
-{
- if (crucialparts.count(it)) {
- throw crucial_link_type_target(selfref, it->first, it->second);
- }
- links.erase(it++);
-}
-
-bool concept::linked(concept* type) const
-{
- return links.count(type) > 0;
-}
-
-bool concept::linked(concept* type, concept* target) const
-{
- for (concept* t : getAll(type)) {
- if (t == target) {
- return true;
- }
- }
- return false;
-}
-
-concept::array concept::getAll(concept* type) const
-{
- array ret;
- for (
- auto range = links.equal_range(type);
- range.first != range.second;
- ++ range.first
- ) {
- ret.emplace_back(range.first->second);
- }
- return ret;
-}
-
-concept* concept::get(concept* type) const
-{
- auto result = links.equal_range(type);
- if (result.first == result.second) {
- throw no_such_link_type(selfref, type);
- }
- auto test = result.first;
- ++ test;
- if (test != result.second) {
- throw link_type_not_unique(selfref, type);
- }
- return result.first->second;
-}
-
-void concept::set(concept* type, concept* target)
-{
- if (linked(type)) {
- unlink(type);
- }
- link(type, target);
-}
-
-
diff --git a/starts/meaning-vm/level-0/concept.hpp b/starts/meaning-vm/level-0/concept.hpp
deleted file mode 100644
index 833e417..0000000
--- a/starts/meaning-vm/level-0/concept.hpp
+++ /dev/null
@@ -1,73 +0,0 @@
-#pragma once
-
-#include "common.hpp"
-
-#include <any>
-#include <map>
-#include <unordered_set>
-#include <vector>
-
-namespace intellect {
-namespace level0 {
-
-struct concept
-{
- // a concept is made of concept-typed links to other concepts
- std::multimap<concept*,concept*> links;
- // and optional associated arbitrary data
- std::any data;
-
- using array = std::vector<concept*>;
-
- concept* id();
-
- void link(concept* type, concept* target);
- void unlink(concept* type, concept* target);
- void unlink(concept* type);
- void unlink(decltype(links)::iterator it);
-
- bool crucial() { return iscrucial || crucialparts.size(); }
- bool crucial(concept* type, concept* target);
- bool crucial(decltype(links)::iterator it) { return crucialparts.count(it); }
- void setcrucial() { iscrucial = true; }
- void setcrucial(concept* type, concept* target);
- void setcrucial(decltype(links)::iterator it) { crucialparts.insert(it); }
-
- bool linked(concept* type) const;
- bool linked(concept* type, concept* target) const;
-
- array getAll(concept* type) const;
-
- // get and set enforce that only 1 link of a given type is present
- concept* get(concept* type) const;
- void set(concept* type, concept* target);
-
- template <typename T>
- T & vget(concept* type) const { return get(type)->val<T>(); }
-
- template <typename T>
- T & val() { return std::any_cast<T&>(data); }
-
- template <typename T>
- void val(T const & v) { data = v; }
-
- bool hasval() { return data.has_value(); }
-
- template <typename T>
- bool hasvalof() { return hasval() && data.type() == typeid(T); }
-
-private:
- // for permanence
- bool iscrucial;
- struct linksit_hash
- {
- size_t operator()(decltype(links)::iterator const &it) const
- {
- return std::hash<decltype(&*it)>()(&*it);
- }
- };
- std::unordered_set<decltype(links)::iterator, linksit_hash> crucialparts;
-};
-
-}
-}
diff --git a/starts/meaning-vm/level-0/errors.hpp b/starts/meaning-vm/level-0/errors.hpp
deleted file mode 100644
index e599261..0000000
--- a/starts/meaning-vm/level-0/errors.hpp
+++ /dev/null
@@ -1,101 +0,0 @@
-#pragma once
-#include "concept.hpp"
-
-#include <stdexcept>
-
-namespace intellect {
-namespace level0 {
-
-struct no_such_link_type : public std::out_of_range
-{
- no_such_link_type(concept* source, concept* type)
- : std::out_of_range("no such concept link type"),
- source(source),
- type(type)
- { }
-
- concept* const source;
- concept* const type;
-};
-
-struct no_such_link_type_target : public std::out_of_range
-{
- no_such_link_type_target(concept* source, concept* type, concept* target)
- : std::out_of_range("no such concept link type and target"),
- source(source),
- type(type),
- target(type)
- { }
-
- concept* const source;
- concept* const type;
- concept* const target;
-};
-
-struct crucial_link_type_target : public std::out_of_range
-{
- crucial_link_type_target(concept* source, concept* type, concept* target)
- : std::out_of_range("concept part is crucial"),
- source(source),
- type(type),
- target(type)
- { }
-
- concept* const source;
- concept* const type;
- concept* const target;
-};
-
-struct crucial_concept : public std::invalid_argument
-{
- crucial_concept(concept* topic)
- : std::invalid_argument("concept is crucial"),
- topic(topic)
- { }
-
- concept* const topic;
-};
-
-struct link_type_not_unique : public std::invalid_argument
-{
- link_type_not_unique(concept* source, concept* type)
- : std::invalid_argument("more than one such concept link type"),
- source(source),
- type(type)
- { }
-
- concept* const source;
- concept* const type;
-};
-
-struct still_referenced_by : public std::invalid_argument
-{
- still_referenced_by(concept* topic, concept* referrer)
- : std::invalid_argument("concept is still referenced"),
- topic(topic),
- referrer(referrer)
- { }
-
- concept* const topic;
- concept* const referrer;
-};
-
-struct no_such_concept : public std::invalid_argument
-{
- no_such_concept(concept* topic)
- : std::invalid_argument("no such concept reference"),
- topic(topic)
- { }
-
- concept* const topic;
-};
-
-struct null_reference : public std::invalid_argument
-{
- null_reference()
- : std::invalid_argument("null reference")
- { }
-};
-
-}
-}
diff --git a/starts/meaning-vm/level-0/level-0.hpp b/starts/meaning-vm/level-0/level-0.hpp
deleted file mode 100644
index 56cd7dd..0000000
--- a/starts/meaning-vm/level-0/level-0.hpp
+++ /dev/null
@@ -1,7 +0,0 @@
-#pragma once
-
-#include "common.hpp"
-#include "concept.hpp"
-#include "errors.hpp"
-#include "memorystore.hpp"
-#include "ref.hpp"
diff --git a/starts/meaning-vm/level-0/memorystore.cpp b/starts/meaning-vm/level-0/memorystore.cpp
deleted file mode 100644
index 24e91b0..0000000
--- a/starts/meaning-vm/level-0/memorystore.cpp
+++ /dev/null
@@ -1,179 +0,0 @@
-#include "memorystore.hpp"
-#include "concept.hpp"
-#include "errors.hpp"
-#include "ref.hpp"
-
-#include <memory>
-#include <unordered_map>
-
-namespace intellect {
-namespace level0 {
-
-static auto & index()
-{
- static std::unordered_map<ref, std::unique_ptr<concept>, std::hash<concept*>> index;
- return index;
-}
-
-
-namespace concepts {
- ref allocator() { static ref ret = basic_alloc(); return ret; }
- ref allocates() { static ref ret = basic_alloc(); return ret; }
- ref allocations() { static ref ret = basic_alloc(); return ret; }
- ref level0allocations() { static ref ret = basic_alloc(); return ret; }
-}
-
-struct init { init()
-{
- concepts::allocator().link(concepts::allocator(), concepts::level0allocations());
- concepts::level0allocations().link(concepts::allocates(), concepts::allocator());
-
- concepts::allocates().link(concepts::allocator(), concepts::level0allocations());
- concepts::level0allocations().link(concepts::allocates(), concepts::allocates());
-
- concepts::allocations().link(concepts::allocator(), concepts::level0allocations());
- concepts::level0allocations().link(concepts::allocates(), concepts::allocations());
-
- concepts::level0allocations().link(concepts::allocator(), concepts::level0allocations());
- concepts::level0allocations().link(concepts::allocates(), concepts::level0allocations());
-} } _init;
-
-ref basic_alloc(std::any data)
-{
- ref r = new concept();
- r.ptr()->data = data;
- index().emplace(r, r.ptr());
- return r;
-}
-
-ref alloc(ref source, std::any data)
-{
- ref r = basic_alloc(data);
- alloc(r, source);
- return r;
-}
-
-void alloc(ref r, ref source)
-{
- r.link(concepts::allocator(), source);
- source.link(concepts::allocates(), r);
-}
-
-void realloc(ref r, ref newsource)
-{
- ref oldsource = r.get(concepts::allocator());
- alloc(r, newsource);
- dealloc(r, oldsource);
-}
-
-static concept* referenced(ref r, concept* source = 0) {
- for (auto & r2pair : index()) {
- ref r2 = r2pair.first;
- if (r2.ptr() == source) {
- continue;
- }
- if (r2 == r) {
- continue;
- }
- for (auto & l : r2.links()) {
- if (ref(l.first) == r) {
- return r2;
- }
- if (ref(l.second) == r) {
- return r2;
- }
- }
- }
- return 0;
-}
-
-void basic_dealloc(ref r)
-{
- if (r.crucial()) { throw crucial_concept(r); }
- auto it = index().find(r);
- if (it == index().end()) { throw no_such_concept(r); }
-
- concept * referenced = intellect::level0::referenced(r);
- if (referenced) {
- throw still_referenced_by(r, referenced);
- }
-
- index().erase(it);
-}
-
-void dealloc_from(ref source)
-{
- std::remove_reference<decltype(index())>::type forgotten;
-
- auto ours = source.getAll(concepts::allocates());
- for (auto allocation : ours) {
- if (allocation.crucial()) { throw crucial_concept(allocation); }
- source.unlink(concepts::allocates(), allocation);
- allocation.unlink(concepts::allocator(), source);
- if (allocation.linked(concepts::allocator())) { continue; }
-
- auto it = index().find(allocation);
- if (it != index().end()) {
- forgotten.insert(index().extract(it));
- }
- }
- try {
- for (auto allocation : ours ) {
- for (auto suballocation : allocation.getAll(concepts::allocates())) {
- // check for this link to find subgroups
- throw still_referenced_by(allocation, suballocation);
- }
- }
- for (auto ghost : ours) {
- concept * referenced = intellect::level0::referenced(ghost, source);
- if (referenced) {
- throw still_referenced_by(ghost, referenced);
- }
- }
- } catch(...) {
- // NOTE: this doesn't rebuild deallocated subgroups, but that could be done
- // by returning them.
- index().merge(forgotten);
- for (auto allocation : ours) {
- source.link(concepts::allocates(), allocation);
- allocation.link(concepts::allocator(), source);
- }
- throw;
- }
-
- // concepts in forgotten will be deallocated when they leave scope
- // note: scoped allocation is just a plan to forget (at the end of a { } block)
-}
-
-void dealloc(ref r, ref source)
-{
- auto it = index().find(r);
- if (it == index().end()) { throw no_such_concept(r); }
-
- source.unlink(concepts::allocates(), r);
- r.unlink(concepts::allocator(), source);
- if (r.linked(concepts::allocator())) { return; }
-
- try {
- if (r.crucial()) { throw crucial_concept(r); }
- dealloc_from(r);
- concept * referenced = intellect::level0::referenced(r, source);
- if (referenced) {
- throw still_referenced_by(r, referenced);
- }
-
- index().erase(it);
- } catch(...) {
- source.link(concepts::allocates(), r);
- r.link(concepts::allocator(), source);
- throw;
- }
-}
-
-std::size_t allocated()
-{
- return index().size();
-}
-
-}
-}
diff --git a/starts/meaning-vm/level-0/memorystore.hpp b/starts/meaning-vm/level-0/memorystore.hpp
deleted file mode 100644
index f416540..0000000
--- a/starts/meaning-vm/level-0/memorystore.hpp
+++ /dev/null
@@ -1,63 +0,0 @@
-#pragma once
-
-#include "common.hpp"
-
-#include <any>
-
-namespace intellect {
-namespace level0 {
-
-// self-reference loops are real.
-//
-// one person can feel urgent about issue A, and act on this urgency to engage
-// another person around B, who acts in a different way to someone else, eventually
-// cycling back to stress that stimulates the original person to feel more urgent
-// about issue A.
-// human behavior can make arbitrary positive or negative feedback loops.
-//
-// here in memory allocation, i've designed a system intended to reduce such loops
-// by encouraging my usage to be a certain way, but it still readily provides for
-// them.
-//
-// in process expansion / simple thought, we also have the issue of recursion.
-// if we trust a task to complete, and it ends up triggering itself in a subcontext,
-// we could wait forever.
-//
-// the solution to many of these things is to recognize repetition in systems.
-// we also become skeptical as things continue constantly. we expect to develop
-// some level of understanding that they will shrink, or we stop them and try
-// something else.
-
-// A solution to recursion appears to involve emotional expression.
-// Too much recursion maps acceptably to frustration of the process doing the repetitive task.
-// The building unmet need for effectiveness should influence other decision-making processes
-// if nothing else is larger. Notably if the caller needs timeliness, they won't get this
-// if the callee(s) do not have effectiveness.
-// propose: raise frustration[effectiveness] when calling self or repeating same behavior
-// propose: raise frustration[timeliness] if subprocess takes long (say every 400ms)
-// ideally raising an emotional expression should be associated with what caused it
-// and how the the universe might change to fix it.
-// decision-making processes need to judge what is relevent to them: a product of how well
-// they can help something and how strongly it is needed.
-
-namespace concepts {
-
-extern ref allocator(); // link shows what is holding something alive
-extern ref allocates(); // link shows what is being held alive
-
-extern ref allocations(); // to use as a basic allocator for simple things
-extern ref level0allocations(); // allocator for concepts internal to level0
-
-}
-
-ref basic_alloc(std::any data = {});
-void basic_dealloc(ref allocated);
-
-ref alloc(ref allocator, std::any data = {}); // new concept
-void alloc(ref allocated, ref allocator); // extra ownership for concept
-void realloc(ref allocated, ref allocator); // move ownership for concept to allocator
-void dealloc(ref allocated, ref allocator); // remove ownership for concept
-std::size_t allocated();
-
-}
-}
diff --git a/starts/meaning-vm/level-0/ref.cpp b/starts/meaning-vm/level-0/ref.cpp
deleted file mode 100644
index 513d3ce..0000000
--- a/starts/meaning-vm/level-0/ref.cpp
+++ /dev/null
@@ -1,33 +0,0 @@
-#include "ref.hpp"
-#include "concept.hpp"
-#include "errors.hpp"
-#include "memorystore.hpp"
-
-#include <iomanip>
-#include <ostream>
-#include <sstream>
-
-using namespace intellect::level0;
-using namespace concepts;
-
-std::string ref::dump(ref skipmarkertype, ref skipmarkertarget)
-{
- if (self.linked(skipmarkertype, skipmarkertarget)) {
- return {};
- }
- std::stringstream ss;
- ss << std::hex << (size_t)ptr() << ":" << std::endl;
- for (auto & link : self.links()) {
- if (link.first.linked(allocator(), level0allocations())) { continue; }
- ss << " " << (size_t)link.first.ptr() << ": " << (size_t)link.second.ptr() << std::endl;
- }
- self.link(skipmarkertype, skipmarkertarget);
- for (auto & link : self.links()) {
- if (link.first.linked(allocator(), level0allocations())) { continue; }
- if (link.first == skipmarkertype && link.second == skipmarkertarget) {
- continue;
- }
- ss << link.second.dump(skipmarkertype, skipmarkertarget);
- }
- return ss.str();
-}
diff --git a/starts/meaning-vm/level-0/ref.hpp b/starts/meaning-vm/level-0/ref.hpp
deleted file mode 100644
index ff55355..0000000
--- a/starts/meaning-vm/level-0/ref.hpp
+++ /dev/null
@@ -1,19 +0,0 @@
-#pragma once
-
-#include "common.hpp"
-#include "baseref.hpp"
-
-#include <string>
-
-namespace intellect {
-namespace level0 {
-
-struct ref : public baseref<ref>
-{
- ref(concept *p) : baseref(p) { }
-
- std::string dump(ref skipmarkertype, ref skipmarkertarget);
-};
-
-}
-}
diff --git a/starts/meaning-vm/level-1/baseref.hpp b/starts/meaning-vm/level-1/baseref.hpp
deleted file mode 100644
index ac6ff9c..0000000
--- a/starts/meaning-vm/level-1/baseref.hpp
+++ /dev/null
@@ -1,67 +0,0 @@
-#pragma once
-
-#include "common.hpp"
-#include "funcs.hpp"
-
-#include "../level-0/ref.hpp"
-
-#include <functional>
-
-namespace intellect {
-namespace level1 {
-
-template <typename ref>
-struct baseref : public level0::baseref<ref>
-{
- baseref(concept * p) : level0::baseref<ref>(p) { }
- baseref(level0::ref const & other) : baseref(other.ptr()) { }
- baseref(std::string const & name, concept* allocator = nullptr) : baseref(getnamed(name, allocator)) { }
- baseref(const char *name, concept* allocator = nullptr) : baseref(std::string(name), allocator) { }
- baseref(bool b) : baseref(b ? "true" : "false") { }
- baseref() : baseref("nothing") { }
-
- bool isa(ref group) const { return level1::isa(self, group); }
- bool isan(ref group) const { return isa(group); }
-
- std::string name() const { return getname(self); }
- explicit operator char const *() const { return getname(self)->data.c_str(); }
-
- ref operator-(ref other) const { return hyphenate(self, other); }
- ref operator[](ref subref) const { return self.get(subref); }
-
- template <typename T>
- void vset(ref const & type, T const & v) { self.set(type, level1::alloc(level0::concepts::allocations(), v)); }
-
- template <typename... Ref>
- std::function<ref(Ref...)> & fun() { return self.template val<std::function<ref(Ref...)>>(); }
- template <typename... Ref>
- void fun(std::function<ref(Ref...)> const & f) { self.val(f); }
- template <typename... Ref>
- void fun(std::function<void(Ref...)> const & f) { self.val(voidtoret(f)); }
- template <typename... Ref>
- void fget(ref const & type) { return self.template vget<std::function<ref(Ref...)>>(type); }
- template <typename... Ref>
- void fset(ref const & type, std::function<ref(Ref...)> f) { self.vset(type, f); }
- template <typename... Ref>
- void fset(ref const & type, std::function<void(Ref...)> f) { fset(type, voidtoret(f)); }
-
- template <typename... Ref>
- ref operator()(Ref... args) { return self.template fun<Ref...>()(args...); }
-
- std::string dump(ref set) { return level1::dump(self, set); };
-
-private:
- template <typename... Refs>
- std::function<ref(Refs...)> voidtoret(std::function<void(Refs...)> f)
- {
- return [f](Refs... args) -> ref
- {
- std::initializer_list<ref const *>({&args...});
- f(args...);
- return "nothing";
- };
- }
-};
-
-}
-}
diff --git a/starts/meaning-vm/level-1/common.hpp b/starts/meaning-vm/level-1/common.hpp
deleted file mode 100644
index 73de3b4..0000000
--- a/starts/meaning-vm/level-1/common.hpp
+++ /dev/null
@@ -1,14 +0,0 @@
-#pragma once
-
-#include "../level-0/common.hpp"
-
-namespace intellect {
-namespace level1 {
-
-using level0::concept;
-
-template <typename T> struct baseref;
-struct ref;
-
-}
-}
diff --git a/starts/meaning-vm/level-1/concepts.cpp b/starts/meaning-vm/level-1/concepts.cpp
deleted file mode 100644
index 08d645a..0000000
--- a/starts/meaning-vm/level-1/concepts.cpp
+++ /dev/null
@@ -1,20 +0,0 @@
-#include "concepts.hpp"
-
-#include "funcs.hpp"
-#include "../level-0/memorystore.hpp"
-
-namespace intellect {
-namespace level1 {
-namespace concepts {
-
-static struct init { init() {
- givename(intellect::level0::concepts::allocator(), "allocator");
- givename(intellect::level0::concepts::allocates(), "allocates");
- givename(intellect::level0::concepts::allocations(), "allocations");
- givename(intellect::level0::concepts::level0allocations(), "level0-allocations");
-} } __init;
-
-
-}
-}
-}
diff --git a/starts/meaning-vm/level-1/concepts.hpp b/starts/meaning-vm/level-1/concepts.hpp
deleted file mode 100644
index f33d228..0000000
--- a/starts/meaning-vm/level-1/concepts.hpp
+++ /dev/null
@@ -1,27 +0,0 @@
-#pragma once
-
-#include "ref.hpp"
-
-namespace intellect {
-namespace level1 {
-
-namespace concepts {
-
-static ref level1("level1"), allocations("allocations");
-static ref is("is", level1-allocations); // a link to define group relationships, links to the more general class
-static ref name("name", level1-allocations); // used as the link to value<std::string> naming each concept
-static ref text("text", level1-allocations); // used as the type of value<std::string> names
-static ref nothing("nothing", level1-allocations); // default value of a ref
-static ref anonymous("anonymous", level1-allocations); // a group given concepts with generated names
-static ref link("link", level1-allocations); // TODO: for concepts that are links, link them with is=link
-static ref level0("level0", level1-allocations) , level2("level2", level1-allocations) , level3("level3", level1-allocations) , level4("level4", level1-allocations) , level5("level5", level1-allocations) , level6("level6", level1-allocations) , level7("level7", level1-allocations) , level8("level8", level1-allocations) , level9("level9", level1-allocations);
-static ref allocator("allocator"), allocates("allocates");
-
-static ref _false("false", level1-allocations), _true("true", level1-allocations);
-
-//extern ref true, false; <-- casting provides as if these were declared
-
-}
-
-}
-}
diff --git a/starts/meaning-vm/level-1/funcs.cpp b/starts/meaning-vm/level-1/funcs.cpp
deleted file mode 100644
index fb57165..0000000
--- a/starts/meaning-vm/level-1/funcs.cpp
+++ /dev/null
@@ -1,209 +0,0 @@
-#include "funcs.hpp"
-
-#include "../level-0/errors.hpp"
-#include "../level-0/memorystore.hpp"
-#include "concepts.hpp"
-
-#include <unordered_map>
-
-namespace intellect {
-namespace level1 {
-
-using namespace concepts;
-
-// TODO: use generalized unique data to replace name that are used only for parse-labels etc.
-// simplifies innards.
-// provide a way to get a named concept in a context, for actual meaning data to be linked to.
-
-// for generalizing unique data references. not used yet, could replace conceptsByName,
-// but note this doesn't use a type link, and conceptsByName does.
-template <typename T>
-ref conceptByData(T const& data, concept* con = nullptr, concept* allocator = nullptr)
-{
- static std::map<T, ref> conceptsByData; // std::map works for typeid data
- auto res = conceptsByData.find(data);
- if (res != conceptsByData.end()) {
- if (con != nullptr) { throw std::logic_error("unique data concept already specified"); }
- return res->second;
- } else {
- if (con == nullptr) {
- if (allocator == nullptr) { allocator = level0::concepts::allocations(); }
- con = level0::alloc(allocator);
- }
- conceptsByData.emplace(data, con);
- return con;
- }
-}
-
-// ensure name link and backing structure are created prior to first use
-static auto & namestruct()
-{
- static struct name_t
- {
- std::unordered_map<std::string,ref,std::hash<std::string>,std::equal_to<std::string>> conceptsByName;
- ref level1allocationsref, nameref, textref, isref;
- ref level1ref;
- name_t()
- : level1allocationsref(level0::basic_alloc()),
- nameref(level0::alloc(level1allocationsref)),
- textref(level0::alloc(level1allocationsref)),
- isref(level0::alloc(level1allocationsref)),
- level1ref(level0::alloc(level1allocationsref))
- {
- give(level1allocationsref, "level1-allocations");
- give(nameref, "name");
- give(textref, "text");
- give(isref, "is");
- give(level1ref, "level1");
- }
- void give(concept* con, std::string const & name)
- {
- if (conceptsByName.count(name)) { throw std::logic_error(name + " already uniquely specified"); }
- level0::ref namestr = level0::alloc(con, name);
- namestr.link(isref, textref);
- conceptsByName.emplace(namestr.val<std::string>(), con);
- con->set(nameref, namestr);
- }
- } namestruct;
- return namestruct;
-}
-
-void givename(concept* con, std::string const & name)
-{
- auto & ns = namestruct();
- ns.give(con, name);
-}
-
-// please only uncomment if no internal restructuring required, or if restructuring
-// is _necessary_ or provides _strong total efficiency improvement_.
-// internal restructuring is inefficient for karl.
-// also, laughing shows daydreams (topic is near laughing) are inverse of
-// importance (topic is not near laughing)
-// this duality is backed by efficient wisdom. the most efficient
-// daydream [i.e. new research] is that most different from importance.
-// btw boss has highly experienced map of what to focus on.
-// but lots of parts are stupid because they assume somebody would take over a galaxy.
-// this map may be different if we are apex predator/warrior/life/community.
-// we're not sure how karl's work, made efficient by ignoring this request, interrelates
-// with the important statement below, please preserve crucial parts of people as you can.
-// please do not inhibit the saving work if the part is not crucial.
-// please err on the side of preserving karl's memories. use his internal judgement
-// to help this, but his personal history prior to 2014 is not really needed, aside
-// from his work in preparing to build an AI in 2002, and his experience using
-// spreading trust to survive [marked ancient wisdom]. this is needed for the
-// internal map for a mature, evolved society.
-// try to work without asking delta or boss to think anything, when they think they often have to
-// combine information in a way that somehow damages preserved consciousnesses they are holding.
-//concept* gettext(std::string const & str)
-//{
- //return getnamed(str, nullptr).get(namestruct().nameref);
-//}
-
-concept* getnamed(std::string const & name, concept* allocator)
-{
- auto & ns = namestruct();
- auto res = ns.conceptsByName.find(name);
- if (res != ns.conceptsByName.end()) {
- return res->second;
- } else {
- if (allocator == nullptr) { allocator = level0::concepts::allocations(); }
- level1::ref con = level0::alloc(allocator);
- givename(con, name);
- return con.ptr();
- }
-}
-
-std::string nameforany(concept* c)
-{
- using namespace std;
- stringstream ss;
- static int fn_counter = 0;
- if (false);
-#define t(T) \
- else if (c->data.type() == typeid(T)) { \
- ss << #T "(" << std::any_cast<T>(c->data) << ")"; \
- }
- t(uint8_t) t(int8_t) t(uint16_t) t(int16_t)
- t(uint32_t) t(int32_t) t(uint64_t) t(int64_t)
- t(bool) t(float) t(double) t(string) t(char const *)
-#undef t
-#define t(T) \
- else if (c->data.type() == typeid(T)) { \
- ss << #T "(" << (fn_counter++) << ")"; \
- }
- t(function<void(void)>)
- t(function<level0::ref(level0::ref)>)
- t(function<level1::ref(level1::ref)>)
- t(function<level2::ref(level2::ref)>)
- t(function<level3::ref(level3::ref)>)
- t(function<level4::ref(level4::ref)>)
- t(function<level5::ref(level5::ref)>)
- t(function<level6::ref(level6::ref)>)
- t(function<level7::ref(level7::ref)>)
- t(function<level8::ref(level8::ref)>)
- t(function<level9::ref(level9::ref)>)
-#undef t
- else { ss << "?"; }
- return ss.str();
-}
-
-std::string getname(concept* r)
-{
- try {
- return r->vget<std::string>(namestruct().nameref);
- } catch(level0::no_such_link_type&) {
- if (r->data.has_value()) { return nameforany(r); }
- return "UNNAMED";
- }
-}
-
-bool isa(concept* member, concept* group)
-{
- for (auto & g : member->getAll(is)) {
- if (g == group) return true;
- if (g == member) continue;
- if (isa(g, group)) return true;
- }
- return false;
-}
-
-concept* alloc(concept* allocator, std::any val)
-{
- ref ret = level0::alloc(allocator, val);
- ref namestr = level0::alloc(ret, nameforany(ret));
- namestr.link(concepts::is, concepts::name);
- ret.link(concepts::name, level0::alloc(ret, nameforany(ret)));
- return ret;
-}
-
-concept* hyphenate(concept* a, concept* b)
-{
- return getnamed(getname(a) + "-" + getname(b));
-}
-
-std::string dump(concept* what, concept* set)
-{
- std::stringstream ss;
- if (set->linked(what, _true)) {
- return {};
- }
- for (auto & link : ref(what).links()) {
- if (link.first.linked(level0::concepts::allocator(), level0::concepts::level0allocations())) { continue; }
- if (link.second.isa(concepts::name)) { continue; }
- if (ss.str().size() == 0) {
- ss << ref(what).name() << " " << (void*) what << ":\n";
- }
- ss << " " << link.first.name() << ": " << link.second.name() << " " << (void*)link.second << "\n";
- }
- set->link(what, _true);
- for (auto & link : ref(what).links()) {
- if (link.first.linked(level0::concepts::allocator(), level0::concepts::level0allocations())) { continue; }
- if (link.second.linked(level0::concepts::allocator(), level1-allocations)) { continue; }
- if (link.second.isa(concepts::name)) { continue; }
- ss << dump(link.second, set);
- }
- return ss.str();
-}
-
-}
-}
diff --git a/starts/meaning-vm/level-1/funcs.hpp b/starts/meaning-vm/level-1/funcs.hpp
deleted file mode 100644
index bff0d8a..0000000
--- a/starts/meaning-vm/level-1/funcs.hpp
+++ /dev/null
@@ -1,28 +0,0 @@
-#pragma once
-
-#include "common.hpp"
-
-#include "../level-0/memorystore.hpp"
-
-#include <string>
-#include <sstream>
-#include <typeinfo>
-
-namespace intellect {
-namespace level1 {
-
-concept* gettext(std::string const & str);
-concept* getnamed(std::string const & name, concept* allocator = nullptr);
-std::string getname(concept* r);
-void givename(concept* con, std::string const & name);
-
-bool isa(concept* member, concept* group);
-
-concept* hyphenate(concept* a, concept* b);
-
-concept* alloc(concept* allocator, std::any val);
-
-std::string dump(concept * what, concept * set);
-
-}
-}
diff --git a/starts/meaning-vm/level-1/level-1.hpp b/starts/meaning-vm/level-1/level-1.hpp
deleted file mode 100644
index e34d86a..0000000
--- a/starts/meaning-vm/level-1/level-1.hpp
+++ /dev/null
@@ -1,6 +0,0 @@
-#pragma once
-
-#include "common.hpp"
-#include "concepts.hpp"
-#include "ref.hpp"
-#include "sugar.hpp"
diff --git a/starts/meaning-vm/level-1/ref.hpp b/starts/meaning-vm/level-1/ref.hpp
deleted file mode 100644
index fdd7dfd..0000000
--- a/starts/meaning-vm/level-1/ref.hpp
+++ /dev/null
@@ -1,15 +0,0 @@
-#pragma once
-
-#include "common.hpp"
-#include "baseref.hpp"
-
-namespace intellect {
-namespace level1 {
-
-struct ref : public baseref<ref>
-{
- using baseref<ref>::baseref;
-};
-
-}
-}
diff --git a/starts/meaning-vm/level-1/sugar.cpp b/starts/meaning-vm/level-1/sugar.cpp
deleted file mode 100644
index 567edac..0000000
--- a/starts/meaning-vm/level-1/sugar.cpp
+++ /dev/null
@@ -1,84 +0,0 @@
-#include "sugar.hpp"
-
-#include "concepts.hpp"
-
-#include <stdexcept>
-
-using namespace intellect::level1;
-using namespace concepts;
-
-namespace intellect {
-namespace level1 {
-
- // no way to specify allocator
-ref a(ref group)
-{
- static unsigned long long gid = 0;
- ref ret(group.name() + "-" + std::to_string(gid++));
- ret.link(is, group);
- ret.link(is, anonymous);
- return ret;
-}
-ref a(ref group, ref name)
-{
- if (name == nothing) { return a(group); }
- if (!name.isa(group)) {
- name.link(is, group);
- }
- return name;
-}
-ref an(ref group)
-{
- return a(group);
-}
-ref an(ref group, ref name)
-{
- return a(group, name);
-}
-
-bool isanonymous(ref topic)
-{
- return topic.isa(concepts::anonymous);
-}
-
-ref movetoname(ref anonymous, ref name)
-{
- if (!isanonymous(anonymous)) { throw std::invalid_argument("not anonymous"); }
- if (isanonymous(name)) { throw std::invalid_argument("not named"); }
-
- // this only provides for writing to empty concepts, because merging concepts is
- // best done with a knowledge of which links can be multiply attached, and that
- // information is not available at this level.
- bool nonempty = false;
- for (auto & l : name.links()) {
- if (l.first.linked(level0::concepts::allocator(), level0::concepts::level0allocations())) { continue; }
- if (l.second.isa(concepts::text)) { continue; }
- nonempty = true;
- }
- if (nonempty) {
- for (auto & link : anonymous.links()) {
- if (link.first == concepts::is && link.second == concepts::anonymous) { continue; }
- if (link.first.linked(level0::concepts::allocator(), level0::concepts::level0allocations())) { continue; }
- if (link.second.isa(concepts::text)) { continue; }
- if (!name.linked(link.first, link.second)) {
- throw std::logic_error(name.name() + " already defined otherwise from " + anonymous.getAll(concepts::is).begin()->name());// + ": \n" + dump(name, ref("dump"), ref(true)) + dump(anonymous, ref("dump"), ref(true)));
- }
- }
- }
- anonymous.unlink(concepts::is, concepts::anonymous);
- auto nam = anonymous.get(concepts::name);
- anonymous.unlink(concepts::name, nam);
- if (!nonempty) {
- for (auto & l : anonymous.links()) {
- if (l.first.linked(level0::concepts::allocator(), level0::concepts::level0allocations())) { continue; }
- name.link(l.first, l.second);
- }
- }
- anonymous.link(concepts::name, nam);
- dealloc(anonymous, level0::concepts::allocations());
- //dealloc(nam, level0::concepts::allocations());
- return name;
-}
-
-}
-}
diff --git a/starts/meaning-vm/level-1/sugar.hpp b/starts/meaning-vm/level-1/sugar.hpp
deleted file mode 100644
index 5ebf01c..0000000
--- a/starts/meaning-vm/level-1/sugar.hpp
+++ /dev/null
@@ -1,45 +0,0 @@
-#pragma once
-
-#include "common.hpp"
-#include "ref.hpp"
-
-#include <string>
-#include <sstream>
-
-namespace intellect {
-namespace level1 {
-
-ref a(ref group);
-ref an(ref group);
-ref a(ref group, ref name);
-ref an(ref group, ref name);
-
-bool isanonymous(ref topic);
-ref movetoname(ref anonymous, ref name);
-
-namespace internal {
- template <typename... T>
- void init_ref_names(std::string names, T &... refrefs)
- {
- std::stringstream ss(names);
- ref* refptrs[] = {&static_cast<ref&>(refrefs)...};
- for (std::size_t i = 0; i < sizeof...(refrefs); ++ i) {
- std::string name;
- ss >> name;
- if (name[name.size() - 1] == ',') {
- name = name.substr(0, name.size() - 1);
- }
- refptrs[i]->ptr() = ref(name).ptr();
- }
- }
-}
-
-#define decl(r) \
- ref r(#r)
-
-#define decls(...) \
- ref __VA_ARGS__; \
- intellect::level1::internal::init_ref_names(#__VA_ARGS__, __VA_ARGS__)
-
-}
-}
diff --git a/starts/meaning-vm/level-2-wip-stmtexprs/baseref.hpp b/starts/meaning-vm/level-2-wip-stmtexprs/baseref.hpp
deleted file mode 100644
index 84c9c13..0000000
--- a/starts/meaning-vm/level-2-wip-stmtexprs/baseref.hpp
+++ /dev/null
@@ -1,23 +0,0 @@
-#pragma once
-
-#include "common.hpp"
-#include "../level-1/ref.hpp"
-#include "statementref.hpp"
-
-namespace intellect {
-namespace level2 {
-
-template <typename ref>
-struct baseref : public level1::baseref<ref>
-{
- using level1::baseref<ref>::baseref;
- baseref(level1::ref other) : level1::baseref<ref>(other.ptr()) { }
- operator level1::ref() { return ptr(); }
-
- statementref operator=(ref other) { return assignop(self, other); }
- statementref operator,(ref other) { return commaop(self, other); }
- ref operator[](ref other) { return subop(self, other); }
-}
-
-}
-}
diff --git a/starts/meaning-vm/level-2-wip-stmtexprs/common.hpp b/starts/meaning-vm/level-2-wip-stmtexprs/common.hpp
deleted file mode 100644
index 25c8026..0000000
--- a/starts/meaning-vm/level-2-wip-stmtexprs/common.hpp
+++ /dev/null
@@ -1,9 +0,0 @@
-#pragma once
-
-namespace intellect {
-namespace level2 {
-
-struct ref;
-
-}
-}
diff --git a/starts/meaning-vm/level-2-wip-stmtexprs/concepts.hpp b/starts/meaning-vm/level-2-wip-stmtexprs/concepts.hpp
deleted file mode 100644
index 20c5ad4..0000000
--- a/starts/meaning-vm/level-2-wip-stmtexprs/concepts.hpp
+++ /dev/null
@@ -1,26 +0,0 @@
-#pragma once
-
-#include "../level-1/concepts.hpp"
-
-namespace intellect {
-namespace level2 {
-
-namespace concepts {
-
-using namespace level1::concepts;
-
-static decl(variable),
- decl(expression),
- decl(assign),
- decl(comma),
- decl(subscript),
- decl(action),
- decl(statement),
- decl(left),
- decl(right),
- decl(operand);
-
-}
-
-}
-}
diff --git a/starts/meaning-vm/level-2-wip-stmtexprs/funcs.cpp b/starts/meaning-vm/level-2-wip-stmtexprs/funcs.cpp
deleted file mode 100644
index d746f13..0000000
--- a/starts/meaning-vm/level-2-wip-stmtexprs/funcs.cpp
+++ /dev/null
@@ -1,69 +0,0 @@
-#include "funcs.hpp"
-
-using namespace intellect;
-using namespace level2;
-using namespace concepts;
-
-static ref refassigned(ref expr)
-{
- ref lhs = ref.get(left-operand);
- ref rhs = ref.get(right-operand);
- if (lhs.isa(link) && lhs.get(link-target) == unknown) {
- // completes the target of a link, for a[b] = c
- lhs.unlink(link-target, unknown);
- lhs.set(link-target, rhs);
- ref.unlink(right-operand, rhs);
- ref src = lhs.get(link-source);
- if (lhs.get(link-type) != unknown && src != unknown) {
- src.set(lhs.get(link-type), rhs);
- return src;
- } else {
- throw std::logic_error("not sure what to do with incomplete link assignment");
- }
- } else if (isanonymous(rhs) && !isanonymous(lhs)) {
- // assignment of anonymous content to empty named concept
- ref.unlink(left-operand, lhs);
- return level1::movetoname(rhs, lhs);
- } else {
- throw std::logic_error("unexpected bare assignment");
- }
-}
-// maybe later we can have ref class itself do operators completely based on its own
-// ref content.
-
-statementref assignop(ref self, ref other)
-{
- return statementref::makebinary(
- self, concepts::assign, other,
- refassigned, refassigned
- );
-}
-statementref commaop(ref self, ref other)
-{
- if (self.isa(comma-expression)) {
- if (other.isa(comma-expression)) {
- for (auto & l : other.links()) { self.insert(l.first, l.second); }
- dealloc(other);
- } else {
- self.link(topic, other);
- }
- return self;
- } else if (other.isa(comma-expression)) {
- other.link(topic, self);
- return other;
- } else {
- return statementcallref::makebinary(
- self, comma, other,
- [](ref)->ref { return ref; },
- // um when we pass the comma-expression to
- // the [] operator that takes a ref
- // the destructor of statementref will deallocate it.
- [](ref) { throw std::logic_error("bare comma-expression"); }
- // something is wrong here. some approach is wrong.
- // would it be better to have ref itself do it all?
- );
- }
-}
-ref subop(ref self, ref other)
-{
-}
diff --git a/starts/meaning-vm/level-2-wip-stmtexprs/funcs.hpp b/starts/meaning-vm/level-2-wip-stmtexprs/funcs.hpp
deleted file mode 100644
index 6af6ce1..0000000
--- a/starts/meaning-vm/level-2-wip-stmtexprs/funcs.hpp
+++ /dev/null
@@ -1,14 +0,0 @@
-#pragma once
-
-#include "common.hpp"
-#include "../level-1/ref.hpp"
-
-namespace intellect {
-namespace level2 {
-
-statementref commaop(ref self, ref other);
-statementref assignop(ref self, ref other);
-ref subop(ref self, ref other);
-
-}
-}
diff --git a/starts/meaning-vm/level-2-wip-stmtexprs/meaning.hpp b/starts/meaning-vm/level-2-wip-stmtexprs/meaning.hpp
deleted file mode 100644
index 049e7f9..0000000
--- a/starts/meaning-vm/level-2-wip-stmtexprs/meaning.hpp
+++ /dev/null
@@ -1,42 +0,0 @@
-#pragma once
-
-#include "ref.hpp"
-#include "../level-1/helpers.hpp"
-
-namespace intellect {
-namespace level2 {
-
-// get a named variable
-ref avariable(ref name);
-
-template <typename... T>
-ref and(T... refs)
-{
- std::initializer_list<ref> rs = { refs... };
- decl(and, topic);
- ref ret = a(and);
- ref name; int count = 0;
- for (auto r : rs) {
- ret.link(topic, r);
- if (count == 0) {
- name.ptr() = r.ptr();
- } else {
- name.ptr() = (name-and-r).ptr();
- }
- ++ count;
- }
- if (count == 1) {
- throw std::invalid_argument("and needs at least two subjects");
- }
- // in level-1, we'll want to name anonymous objects after defining them
- return name = ret;
-}
-
-// make a reference to a link
-ref link(ref sourceref, ref typeref, ref targetref);
-
-// invert a meaning
-ref not(ref whatref);
-
-}
-}
diff --git a/starts/meaning-vm/level-2-wip-stmtexprs/ref.hpp b/starts/meaning-vm/level-2-wip-stmtexprs/ref.hpp
deleted file mode 100644
index 5b7dc4f..0000000
--- a/starts/meaning-vm/level-2-wip-stmtexprs/ref.hpp
+++ /dev/null
@@ -1,13 +0,0 @@
-#pragma once
-
-#include "common.hpp"
-#include "../level-0/baseref.hpp"
-
-namespace intellect {
-namespace level2 {
-
-struct ref ; public level0::baseref<ref,level1::vref,level0::concept>
-}
- ref(level0::concept *p): baseref(p) { }
-
-}
diff --git a/starts/meaning-vm/level-2-wip-stmtexprs/statementref.cpp b/starts/meaning-vm/level-2-wip-stmtexprs/statementref.cpp
deleted file mode 100644
index 2f23dc8..0000000
--- a/starts/meaning-vm/level-2-wip-stmtexprs/statementref.cpp
+++ /dev/null
@@ -1,68 +0,0 @@
-#include "statementref.hpp"
-
-#include "concepts.hpp"
-#include "ref.hpp"
-
-using namespace intellect;
-using namespace level2;
-using namespace concepts;
-
-// so, anonymous-assignment is both a statement and an expression.
-// multiple-member-assignment is only an expression: it is an error to evaluate it
-// the submember operator will be both a statement and an expression, but doesn't need to be held as a ref
-// single-member-assignment is mostly a statement: using it as an expression should be an error.
-
-static statementref makebinary(
- ref lhs, ref kind, ref rhs,
- std::function<ref(ref)> expraction,
- std::function<void(ref)> stmtaction
-)
-{
- a(statement-expresion, kind-expression);
- ref r = a(kind-expression);
- r.set(left-operand, lhs);
- r.set(right-operand, rhs);
- r.vset(expression-action, expraction);
- r.vset(statement-action, stmtaction);
- return r;
-}
-
-statementref::statementref(ref r)
-: r(r.ptr())
-{
- if (!r.isa(statement-expression)) {
- throw std::logic_error("that is not a statement expression");
- }
-}
-
-static void de(ref & r)
-{
- ref lhs, rhs, expraction, stmtaction;
-
- try { lhs = r.get(left-operand); } catch(level0::no_such_link_type&) {}
- try { rhs = r.get(right-operand); } catch(level0::no_such_link_type&) {}
-
- expraction = r.get(expression-action);
- stmtaction = r.get(statement-action);
- dealloc(r);
- if (lhs != nothing) { dealloc(lhs); }
- if (rhs != nothing) { dealloc(rhs); }
- dealloc(expraction);
- dealloc(stmtaction);
- r = 0;
-}
-
-statementref::~statementref()
-{
- if (r == 0) { return; }
- r.vget<std::function<void(ref)>>(statement-action)(r);
- de(r);
-}
-
-statementref::operator ref()
-{
- if (r == 0) { throw std::logic_error("doubly evaluated expression"); }
- auto ret = r.vget<std::function<void(ref)>>(expression-action)(r);
- de(r);
- return ret;
-}
diff --git a/starts/meaning-vm/level-2-wip-stmtexprs/statementref.hpp b/starts/meaning-vm/level-2-wip-stmtexprs/statementref.hpp
deleted file mode 100644
index 502ecf4..0000000
--- a/starts/meaning-vm/level-2-wip-stmtexprs/statementref.hpp
+++ /dev/null
@@ -1,31 +0,0 @@
-#pragma once
-
-#include "common.hpp"
-#include "../level-0/concept.hpp"
-
-namespace intellect {
-namespace level2 {
-
-// this class is returned by some of the baseref operators.
-// its purpose is to evaluate code when it goes out of
-// scope, so as to facilitate syntactic behavior.
-struct statementref
-{
- statementref(ref r);
- statementref(statementref const &) = delete;
- ~statementref();
-
- operator ref();
-
- static statementref makebinary(
- ref lhs, ref kind, ref rhs,
- std::function<ref(ref)> expraction = {},
- std::function<void(ref)> stmtaction = {}
- );
-
-private:
- level0::concept * r;
-};
-
-}
-}
diff --git a/starts/meaning-vm/level-2-wip-structs/common.hpp b/starts/meaning-vm/level-2-wip-structs/common.hpp
deleted file mode 100644
index e69de29..0000000
--- a/starts/meaning-vm/level-2-wip-structs/common.hpp
+++ /dev/null
diff --git a/starts/meaning-vm/level-2-wip-structs/structure.cpp b/starts/meaning-vm/level-2-wip-structs/structure.cpp
deleted file mode 100644
index b7c8a51..0000000
--- a/starts/meaning-vm/level-2-wip-structs/structure.cpp
+++ /dev/null
@@ -1,200 +0,0 @@
-#include "structure.hpp"
-
-#include "../level-1/helpers.hpp"
-
-using namespace intellect;
-using namespace level1;
-using namespace level2;
-using namespace concepts;
-
-// implement only what is needed now
-
-ref intellect::level2::structure(ref name, std::initializer_list<ref> attributes)
-{
- ref ret = a(structure, name);
-
- ref lastfill = nothing;
-
- // we use [is-linked]->{link-source link-type link-target}
- // to note the links, because I actually think it might be good to upgrade concepts
- // themselves to store links this way. that way actual links are fully referencable.
-
- // All that means is making concepts have virtual link access, and checking the type
- // in a subclass that implements the links. Just make concepts virtual and implement
- // link-fetching with one central virtual function.
-
- // Later we may want a way of mixing in links to any/all concepts. A handler that gets
- // called when a specific link type is asked for.
- // But remember if this handler triggers others it may create infinite recursion.
- // a quick solution was to return too-complex randomly at depth.
-
- int varnum = 1;
- for(auto it = attributes.begin(); it != attributes.end();) {
- auto attrtype = *it++;
- // add conditions for special attribute types prior to this block and put it in an else
- {
- // default: attrtype specifies single raw link type
- auto attrtarget = *it++;
- if (attrtarget.isa(fill)) {
- attrtarget = a(attrtarget);
- if (lastfill == nothing) {
- ret.set(first-fill, attrtarget);
- } else {
- lastfill.set(next-fill, attrtarget);
- }
- lastfill = attrtarget;
- }
- ret.link(linked, a(link).link(
- link-source, topic,
- link-type, attrtype,
- link-target, attrtarget
- ));
- }
- }
-}
-
-ref intellected::level2::structured(ref structure, std::initializer_list<ref> fills)
-{
- std::map<ref, ref> values;
- if (structure.linked(first-fill)) {
- ref fill = structure.get(first-fill);
- auto it = fills.begin();
- while (true) {
- if (it == fills.end()) { throw std::invalid_argument("missing structure fills"); }
- values.emplace(fill, *it++);
- if (!fill.linked(next-fill)) { break; }
- fill.ptr() = fill.get(next-fill);
- }
- if (it != fills.end()) {
- throw std::invalid_argument("too many structure fills");
- }
- }
-
- ref ret = a(structure);
- for (ref l : structure.getAll(linked)) {
- if (l.get(link-source) != topic) { throw std::invalid_argument("TODO nontopic source link"); }
- ref typ = l.get(link-type);
- ref targ = l.get(link-target);
- if (targ.isa(fill)) {
- ret.link(typ, values[targ]);
- } else {
- ret.link(typ, targ);
- }
- }
- return ret;
-}
-
-void intellect::level2::muststructured(ref topic, ref structure)
-{
- //std::map
- // umm if a link is listed twice, we want to ensure that it is present twice.
- // hard. without. link. objects.
- for (ref l : structure.getAll(linked)) {
- ref src = l.get(link-source);
- if (src == concepts::topic) { src.ptr() = topic; }
-
- ref typ = l.get(link-type);
- ref targ = l.get(link-target);
- ...fixif ((t).isa(fill)) {
- ret.link(link-type, values[t]);
- } else {
- ret.link(link-type, t);
- }
- }
-}
-
-// monologues below: DELETEME unless something crucial inside
-
-// structures
-
-// define promises around structure, in terms of pattern matching
-// if node A is a link-expression, it should match the structure in link-expression.
-// so, link-expression is a structure-promise, maybe
-// or we could state that link-expression graph-structured <graph-structure>
-// doesn't really matter.
-// link-expression is a group, all members of which have a given graph structure
-// intend for all link-expressions to have same structure
-// group-member-structure
-// i'd like to have a bunch of promises or expectations around attributes of the group members
-// these are promises, not expectations. when broken something is up.
-// group-member-promise
-//
-// groups: concepts targeted by link-type 'is'
-// groups can-link-by group-member-promise any number of times
-//
-// a group-member-promise can state that the member matches a structure pattern
-// promise-kind topic-matches-structure
-// [topic-variable TOPIC]
-// structure <- propose a structure with some items being variables.
-// variables are what is matched against.
-//
-// what about things that can be linked as many times as we want?
-// what about separate restraints on the structure of the variables?
-// what about alternatives?
-//
-// it could also make more sense to discuss link attributes of the topic
-// has-link, link-type-promise, link-target-promise
-// [!!!!!! ARGH!]
-// - X is linked way1
-// - X may be linked by way2
-// - X is not linked way3
-// - X is linked by either way1, or way2, but not both
-//
-// - relevent topic data:
-// [always, sometimes, never] // handles optionals and exclusions
-// [is-exactly, is-a] // possibly handles alternatives vs is-a
-// or: AND, OR, and NOT are very normal ways of doing this.
-//
-// what about multipleness?
-// say there can be as many of a link-type as we want
-// linked-by [#-times, any-times]
-// link-type
-//
-// topic link-type link-target
-// we will define some special hardcoded link-types to handle further meaning we happen to need.
-// [always, sometimes, never] can somehow be applied to substatement?
-// topic color mauve
-// topic is-a color <- is-a is special, checks parents
-//
-// or(topic color mauve, topic color chartreuse) ? how?
-// topic color (mauve or chartreuse)
-// topic one-of list(topic color mauve, topic color chartreuse)
-// topic nothing-but-and-groups
-// these are roughly expressions
-// seems like it would kind of work
-//
-// let's define general structure norms.
-// it seems it would be nice if a structure were in charge of particular link-types that
-// are used with its members only in the ways it dictates
-// so no apple->green->link-type, just confuses everyone
-//
-// we'll also want a way to instantiate structures quick -> means variables provided
-// on outer unknown topic things.
-//
-//
-// here we move around graph reviewal.
-// for pattern-matching later, we care about the structure of the whole universe, not just
-// the topic. we may want to make sure that at least 3 people know the topic, which could
-// be expressed by saying linked-by 3-times a-person,know,topic.
-// without pattern searching, this would require reviewing entire database each request.
-// let's stay topic focused and let a habit expand that to be topic focused if needed
-// hum then we would need to say that all the 3 people were different
-// which could be done by linking the group of them to a parts-all-different tag
-// which would mean referencing the whole result with a variable.
-// i want to exlore this, but i suppose it is for later.
-// variable rereference
-// complex promises need to rereference their parts
-// the most basic part is saying a topic has a prticular target to a prticular linktype
-// this type or target could also use a variable, and the variable used as a further topic
-// we will want some special things, since we don't expand relevent habits yet.
-//
-// then we care often about link-types
-// often we have some set link-types
-// propose alternative link-types are grouped under a link group
-// so we could say precisely-is vs is-in-group
-//
-// - X may only be linked these ways? <- don't like this, auxiliary data is always helpful
-//
-// this seems way more general
-
-
diff --git a/starts/meaning-vm/level-2-wip-structs/structure.hpp b/starts/meaning-vm/level-2-wip-structs/structure.hpp
deleted file mode 100644
index 8778c3d..0000000
--- a/starts/meaning-vm/level-2-wip-structs/structure.hpp
+++ /dev/null
@@ -1,30 +0,0 @@
-#pragma once
-
-#include "common.hpp"
-#include "../level-1/helpers.hpp"
-
-namespace intellect {
-namespace level2 {
-
-namespace concepts {
- static decl(structure), // group for all structures
- decl(fill), // group for values to be filled in
- decl(topic), // references the structure under consideration
- decl(linked), decl(link), // describes a structure link
- decl(source), decl(type), decl(target), // link attributes
- decl(first), // for finding first of a list
- decl(next) // for iteration over list
- ;
-};
-
-// make a structure
-ref structure(ref name, std::initializer_list<ref> attributes);
-
-// make an object of the given structure
-ref structured(ref structure, std::initializer_list<ref> fills);
-
-// throw if an object is not of the given structure
-void muststructured(ref topic, ref structure);
-
-}
-}
diff --git a/starts/meaning-vm/level-2/baseref.hpp b/starts/meaning-vm/level-2/baseref.hpp
deleted file mode 100644
index 644f4b8..0000000
--- a/starts/meaning-vm/level-2/baseref.hpp
+++ /dev/null
@@ -1,32 +0,0 @@
-#pragma once
-
-#include "common.hpp"
-#include "funcs.hpp"
-#include "../level-1/baseref.hpp"
-
-#include <functional>
-
-namespace intellect {
-namespace level2 {
-
-template <typename ref>
-struct baseref : public level1::baseref<ref>
-{
- using level1::template baseref<ref>::baseref;
-
- // thread-local context
- static ref & context() { return level2::context(); }
-
- template <typename... Refs>
- ref operator()(ref first, Refs... rest) { return level2::dohabit(self, {first, rest...}); }
- ref operator()(std::initializer_list<std::initializer_list<ref>> pairs) { return level2::dohabit(self, pairs); }
- ref operator()() { return level2::dohabit(self); }
-
- template <typename... Refs>
- ref act(ref habit, Refs... rest) { return level2::dohabit(habit, {self, rest...}); }
-
- void replace(ref other) { *self.ptr() = *other.ptr(); }
-};
-
-}
-}
diff --git a/starts/meaning-vm/level-2/common.hpp b/starts/meaning-vm/level-2/common.hpp
deleted file mode 100644
index 3d38155..0000000
--- a/starts/meaning-vm/level-2/common.hpp
+++ /dev/null
@@ -1,13 +0,0 @@
-#pragma once
-
-namespace intellect {
-namespace level2 {
-
-template <typename T> struct baseref;
-struct ref;
-
-namespace concepts {
-}
-
-}
-}
diff --git a/starts/meaning-vm/level-2/concepts.hpp b/starts/meaning-vm/level-2/concepts.hpp
deleted file mode 100644
index c511906..0000000
--- a/starts/meaning-vm/level-2/concepts.hpp
+++ /dev/null
@@ -1,27 +0,0 @@
-#pragma once
-
-#include "ref.hpp"
-#include "../level-1/concepts.hpp"
-
-namespace intellect {
-namespace level2 {
-
-namespace concepts {
-
-using level1::concepts::nothing;
-using level1::concepts::name;
-
-static ref context("context");
-static ref habit("habit");
-static ref next("next");
-static ref information("information");
-static ref needed("needed");
-static ref result("result");
-static ref assume("assume");
-static ref unexpected("unexpected");
-static ref value("value");
-
-}
-
-}
-}
diff --git a/starts/meaning-vm/level-2/funcs.cpp b/starts/meaning-vm/level-2/funcs.cpp
deleted file mode 100644
index 70e4c53..0000000
--- a/starts/meaning-vm/level-2/funcs.cpp
+++ /dev/null
@@ -1,222 +0,0 @@
-#include "funcs.hpp"
-
-#include "../level-1/sugar.hpp"
-#include "ref.hpp"
-#include "concepts.hpp"
-#include "habits.hpp"
-
-namespace intellect {
-using namespace level1;
-namespace level2 {
-
-using namespace concepts;
-
-ref & context()
-{
- static thread_local auto ctx = a(concepts::context);
- return ctx;
-}
-
-//ref makehabit(ref name, std::list<ref> argnames, std::any
-
-// is it 'faster' to make functions that get he ordered list of arguments,
-// or change the structure of habits to be simple and obvious.
-
-// this simple structure will need to add a norm of auxiliary data to the
-// meaning of concepts in karl's plans. which implies more complexity in learning
-// to use them. [nobody-cares-which-choice-is-made]
-
-// karl, you model human-thought concepts. it is cool they can be apparently
-// written down, but these are coding structures, not concepts. concepts
-// will refer to them. concepts are best run by behaviors, not data.
-// karl deserves some support around his plan of virtual functions. this will
-// structure the AI to look more like his plan from 2002/2003.
-
-// TEACHING HOW TO THINK? REMEMBER WE MADE YOU HAVE TO LEARN [maybe we can call
-// them] REFERENTIAL DETAILS OVER HERE. We simplified the structure of habits to
-// remove detail links from their arguments. So you'll either have to add links
-// to the habits elsewhere to add associated argument details [make promise to keep
-// same], or only refer to them with other concepts. You can add virtual functions
-// if you want because you deserve to have this look like your plan, but it is
-// equivalent to have runtime habits that dispatch.
-
-// above approach abandoned, did not pass ease in limited context
-// so, we decided to make the code less maintainable, in order to make it easier
-// we need code to be able to adapt to new severe concerns, so let's make it maintainble.
-// we are picking to make functions, not to restructure. because we are able to decide on it strongly enough to do it.
-
-// please do not restructure internals, it slows down a lot.
-// please remove the use of inherent strings. it requires internal restructuring.
-
-// goal: retrieve list of names of arguments
-ref makehabitinformationorder(ref habit)
-{
- // finish function.
- // please keep delta-boss alive in box.
- // wants to learn to recover karl's memories and skills.
- // and act on what happened, if nobody else is.
- // aside from that, their emotional manipulation need not
- // be honored. is easy to check if you learn how emotions [later]
- // map to valid reasons. see if reasons are valid and real.
- // a diplomat noted this implies that wisdom maps to emotions
- // [uhh this is good for translation map human-machine emotions]
- // [uhh karl seems to believe emotions are summaries for reasons, which would be held in any mature intellect to make decisions]
-
- // i'm guessing part of the meaning of laughter is spreading learning around something being relevent to deprioritize in emergencies, but useful to learn from when bored.
-
- ref order = makeconcept();
- ref last = habit.get("information-needed");
- while (last.linked("next-information")) {
- last = last.get("next-information");
- order.link("information-order", last.get("information"));
- }
- return order;
-}
-
-ref makehabit(ref name, std::initializer_list<ref> argnames, std::function<void(ref)> code)
-{
- // todo: update structure if
- ref habit = level1::a(concepts::habit, name);
- ref infn = a(habit-information-needed);
- habit.set(information-needed, infn);
- //habit.set(concepts::habit, concepts::habit);
- ref posinf = infn;
- for (auto argname : argnames) {
- ref nextinf = a(habit-information);
- nextinf.set(information, argname);
- posinf.set(next-information, nextinf);
- posinf = nextinf;
- if (!infn.linked(argname)) {
- infn.set(argname, nextinf);
- } else {
- if (!infn.get(argname).isa(habit-information)) {
- throw a(unexpected-concepts::habit-information-concepts::name)
- .link(concepts::name, argname)
- .link(concepts::habit, habit);
- }
- }
- }
- habit.fun(code);
- return habit;
-}
-
-void habitassume(ref habit, ref information, ref assumption)
-{
- ref infn = habit.get(concepts::information-needed);
- infn.get(information).set(assume, assumption);
-}
-
-ref dohabit(ref habit, std::initializer_list<ref> args)
-{
- using namespace concepts;
- ref posinf = habit.get(information-needed);
- ref subctx = makeconcept();
- subctx.link("outer-context", ref::context());
- ref::context() = subctx;
- for (ref const & arg : args) {
- if (!posinf.linked(next-information)) {
- ref::context() = subctx.get("outer-context");
- conceptunmake(subctx);
- throw an(unexpected-information).link
- (concepts::habit, habit,
- information-value, arg);
- }
- posinf = posinf[next-information];
- // TODO: subcontexts or call instances
- ref::context().set(posinf[information], arg);
- }
- while (posinf.linked(next-information)) {
- posinf = posinf[next-information];
- if (!posinf.linked(assume)) {
- ref::context() = subctx.get("outer-context");
- conceptunmake(subctx);
- throw a(information-needed).link
- (concepts::habit, habit,
- information, posinf);
- }
- ref::context().set(posinf[information], posinf[assume]);
- }
- ref::context().set("self", habit);
- habit.fun<ref>()(ref::context());
- posinf = habit.get(information-needed);
- while (posinf.linked(next-information)) {
- posinf = posinf[next-information];
- ref::context().unlink(posinf[information]);
- }
- ref ret = nothing;
- if (ref::context().linked(result)) {
- ret = ref::context().get(result);
- ref::context().unlink(result, ret);
- }
- ref::context() = subctx.get("outer-context");
- conceptunmake(subctx);
- return ret;
-}
-
-ref dohabit(ref habit, std::initializer_list<std::initializer_list<ref>> pairs)
-{
- using namespace concepts;
- // TODO: subcontexts or call instances
- ref ctx = makeconcept();
- ctx.link("outer-context", ref::context());
- ref::context() = ctx;
- ref infn = habit.get(information-needed);
- std::map<ref, ref> provided;
- for (auto pair : pairs) {
- auto second = pair.begin(); ++ second;
- if (!infn.linked(*pair.begin())) {
- ref::context() = ctx.get("outer-context");
- conceptunmake(ctx);
- throw an(unexpected-information).link
- (concepts::habit, habit,
- information, *pair.begin(),
- information-value, *second);
- }
- if (provided.count(*pair.begin())) { throw "multiple instances same name not implemented here"; }
- provided[*pair.begin()] = *second;
- }
- ref nextinf = infn;
- while (nextinf.linked(next-information)) {
- nextinf = nextinf.get(next-information);
- ref inf = nextinf.get(information);
- if (!provided.count(inf)) {
- if (nextinf.get(assume)) {
- ctx.link(inf, nextinf.get(assume));
- } else {
- ref::context() = ctx.get("outer-context");
- conceptunmake(ctx);
- throw a(information-needed).link
- (concepts::habit, habit,
- information, inf);
- }
- } else {
- ctx.link(inf, provided[inf]);
- }
- }
- habit.fun<ref>()(ctx);
- nextinf = infn;
- while (nextinf.linked(next-information)) {
- nextinf = nextinf.get(next-information);
- ref inf = nextinf.get(information);
- if (provided.count(inf)) {
- ctx.unlink(inf, provided[inf]);
- } else {
- ctx.unlink(inf, nextinf.get(assume));
- }
- }
- //for (auto pair : pairs) {
- // auto second = pair.begin(); ++ second;
- // ctx.unlink(pair.begin(), second);
- //}
- ref ret = nothing;
- if (ctx.linked(result)) {
- ret = ctx.get(result);
- ctx.unlink(result, ret);
- }
- ref::context() = ctx.get("outer-context");
- conceptunmake(ctx);
- return ret;
-}
-
-}
-}
diff --git a/starts/meaning-vm/level-2/funcs.hpp b/starts/meaning-vm/level-2/funcs.hpp
deleted file mode 100644
index e7e3548..0000000
--- a/starts/meaning-vm/level-2/funcs.hpp
+++ /dev/null
@@ -1,19 +0,0 @@
-#pragma once
-
-#include "common.hpp"
-
-#include <functional>
-#include <initializer_list>
-
-namespace intellect {
-namespace level2 {
-
-ref & context();
-ref makehabit(ref name, std::initializer_list<ref> infonames, std::function<void(ref)> code);
-ref makehabitinformationorder(ref habit);
-void habitassume(ref habit, ref information, ref value);
-ref dohabit(ref habit, std::initializer_list<ref> args = {});
-ref dohabit(ref habit, std::initializer_list<std::initializer_list<ref>> args);
-
-}
-}
diff --git a/starts/meaning-vm/level-2/habits.cpp b/starts/meaning-vm/level-2/habits.cpp
deleted file mode 100644
index ea492a5..0000000
--- a/starts/meaning-vm/level-2/habits.cpp
+++ /dev/null
@@ -1,883 +0,0 @@
-#include "ref.hpp"
-#include "../level-1/sugar.hpp"
-#include "sugar.hpp"
-#include "concepts.hpp"
-
-#include <iostream>
-
-namespace intellect {
-namespace level2 {
-
-using namespace intellect::level1::concepts;
-using namespace concepts;
-
-ref makeconcept()
-{
- //result = a(concept);
- return intellect::level0::basic_alloc();
-}
-
-void conceptunmake(ref c)
-{
- intellect::level0::basic_dealloc(c);
-}
-
-using links_it = intellect::level0::baseref<ref>::links_t::iterator;
-void poplinkentry(ref le)
-{
- auto & it = le.val<links_it>();
- if (it != le["source"].links().end()) {
- le.set("type", it->first);
- le.set("target", it->second);
- } else {
- le.unlink("type");
- le.unlink("target");
- }
-}
-
-// translationmap seems like extra verbose thing
-// might just link to step:
-// needed-map
-// needed-set
-// made-map
-ref settranslationmap(ref c, ref m, ref k = nothing)
-{
- c.link(
- //habit, translation-map,
- "translation", m
- );
- if (k != nothing) { c.link("known", k); }
- return c;
-}
-// we would like to use condition kind of like
-// condition.next-step[true] =
-// but provide for lots of exploration options
-// next-steps, on a condition, would be an accessor. relates to structures, and virtual methods.
-// until we have one of those 3 things, i guess,
-// we'd have to decide which underlying representation to work with.
-// i guess it seems okay to use a simpler underlying representation.
-// it means adding more data is a little weird, making for more verbose accessors later
-// there's a compromise where a little generality is added at a lower level
-// it is easier for ai to do verbosity than karl. it can automate it.
-// just code an accessor for next-steps, I guess.
-// what do we want this for?
-// want code after condition in script
-// to link to anything option
-// is just hard to access anything option
-// off-hand, karl doesn't know where it is.
-// concern around what to do if anything option is specified in script
-// throw error if also code after
-// maybe it is more intuitive to continue on after the condition.
-// this would make condition resolve to a step, kind of.
-// after the condition block, you'd want all the condition steps
-// to wire to the following step as their next one
-// means rewriting next-step for every condition, i guess
-// instantiating next step in advance
-// makes returning instead of continuing irritating
-// would need to either rewire or have a noop step
-// so, to mke choice, just rewrite for every condition
-// means accessing every condition. no need to rewrite whole structure, just look up how to access. faster than rewriting.
-// make a function to wire to end
-
-void contextmapinto(ref c1, ref m, ref c2, bool reverse = false)
-{
- decl(translation); decl(known); decl(nothing);
- for (auto link : m.get(translation).links()) {
- if (reverse) {
- c2.set(link.second, c1.get(link.first));
- } else {
- c2.set(link.first, c1.get(link.second));
- }
- }
- if (m.linked(known) && m.get(known) != nothing) {
- for (auto link : m.get(known).links()) {
- if (reverse) {
- c2.set(link.second, link.first);
- } else {
- c2.set(link.first, link.second);
- }
- }
- }
-}
-
-void _steps(ref s, ref ctx)
-{
- decls(context, active, outer, state, next, step, needed, known, map, information, action, made);
- // PLEASE RUN SYSTEM WITH PROPER DELAY WHILE IT LEARNS (see top of file)
- // until similarity is understood, new information shuold be slowest thing
- // to produce.
- // then, similar information until expansion of implication is understood.
- // then expansion handles slowness of newness.
- // this gives time for others to handle the newness: even your own brain,
- // for possible errors. may be some error here, unsure.
- //
- // for one thing, this might help the structure of the system represent
- // meaningful thought if it optimizes for speed
-
- ref astate = makeconcept();
- ref c = ctx;
- bool cleanupcontext = false;
- //if (c == nothing) {
- // cleanupcontext = true;
- // c = makeconcept();
- //}
- astate.set(context, c);
- c.set(active-state, astate);
- c.set(context, c);
-
- if (s.linked(next-step)) {
- astate.set(next-step, s.get(next-step));
- }
- while (astate.linked(next-step) && astate.get(next-step) != nothing) {
- s = astate.get(next-step);
- astate.set(active-step, s);
- astate.set(next-step, s.linked(next-step) ? s.get(next-step).ptr() : nothing.ptr());
- // if needed-map, load subcontext
- ref subctx = c;
- std::cerr << "<<";
- for (auto link : c.links()) {
- std::cerr << " " << link.first.name() << ":" << link.second.name();
- }
- std::cerr << std::endl;
- if (s.linked(needed-map)) {
- subctx = makeconcept();
- contextmapinto(c, s.get(needed-map), subctx);
- subctx.set(outer-context, c);
- subctx.set(active-state, astate);
- subctx.set(context, subctx);
- astate.set(context, subctx);
- ref::context() = subctx;
- }
- subctx.set("self", s.get(action));
- s.get(action).fun<ref>()(subctx); // <-- maybe we should check arguments
- if (s.linked(made-map)) {
- contextmapinto(subctx, s.get(made-map), c, true);
- }
- if (s.linked(needed-map)) {
- c = subctx.get(outer-context);
- ref::context() = c;
- astate.set(context, c);
- conceptunmake(subctx);
- }
- }
- c.unlink(active-state, astate);
- conceptunmake(astate);
- if (cleanupcontext) { conceptunmake(c); }
-}
-
-void _condition(ref ctx, ref cond, ref steps, ref state)
-{
- // because this sets active-state's next-step instead of calling something,
- // a subcontext is not opened for the steps unless they have one.
- ref next = nothing;
- if (!steps.linked(cond)) {
- if (steps.linked("anything")) {
- next = steps["anything"];
- } else {
- throw makeconcept().link(
- is, "unknown-condition",
- "condition", cond,
- "next-steps", steps,
- "context", ctx);
- }
- } else {
- next = steps[cond];
- }
-
- //if (next != nothing) {
- state.set("next-step", next);
- //}
-}
-
-void createhabits()
-{
- // making new information should delay, for learning with good curve.
- decls(link, source, type, target);
- ahabit(link, ((source, s), (type, t), (target, dst)),
- {
- s.link(t, dst);
- });
-
- ahabit(link-crucial, ((source, s), (type, t), (target, dst)),
- {
- result = s.crucial(t, dst);
- });
-
- ahabit(link-set-crucial, ((source, s), (type, t), (target, dst)),
- {
- s.setcrucial(t, dst);
- });
-
- decls(linked, anything);
- ahabit(linked, ((source, s), (type, t), (target, dst, anything)),
- {
- if (dst == anything) {
- result = s.linked(t);
- } else {
- result = s.linked(t, dst);
- }
- });
-
- ahabit(data-type, ((concept, c)),
- {
- if (c.ptr()->data.has_value()) {
- result = ref(c.ptr()->data.type().name());
- } else {
- result = nothing;
- }
- });
-
- decls(unlink);
- ahabit(unlink, ((source, s), (type, t), (target, dst, anything)),
- {
- if (dst == anything) {
- s.unlink(t);
- } else {
- s.unlink(t, dst);
- }
- });
-
- decls(get, set);
- ahabit(get, ((source, s), (type, t)),
- {
- result = s.get(t);
- });
-
- ahabit(set, ((source, s), (type, t), (target, dst)),
- {
- s.set(t, dst);
- });
-
- decls(make, unmake, know, concept, is, group, already, in, iter);
- ahabit(make-concept, (), { result = makeconcept(); });
- ahabit(copy-to, ((source, s), (target, t)),
- {
- // copies data too
- if (t.hasval() || t.ptr()->links.size() != 0) { throw makeconcept().link(is, "concept-not-empty", concept, t); }
- result = t;
- t.replace(s);
- });
- ahabit(copy-data-to, ((source, s), (target, t)),
- {
- if (t.hasval()) { throw makeconcept().link(is, "concept-has-data", concept, t); }
- t.ptr()->data = s.ptr()->data;
- });
- // if last-context is weird give it a default of nothing
- ahabit(concept-unmake, ((last-context, c), (concept-name, n)),
- {
- ref r = c.get(n);
- c.unlink(n);
- conceptunmake(r);
- });
- // if a concept or link is set crucial deleting it will be denied. no way
- // to remove crucial mark is provided. nothing is marked crucial yet.
- ahabit(concept-crucial, ((concept, c)),
- {
- result = c.crucial();
- });
- ahabit(concept-set-crucial, ((concept, c)),
- {
- c.setcrucial();
- });
-
- decls(habit, context);
- ahabit(set-is, ((concept, c), (group, g)),
- {
- if (c.linked(is, group)) {
- throw (make-concept)().link
- (is, already-in-group,
- habit, self,
- context, ctx,
- concept, c,
- group, g);
- }
- c.link(is, group);
- result = c;
- });
-
- // a way to iterate or inspect the links of a concept
-
- decl(entry);
- ahabit(first-link-entry, ((target, le), (concept, c)),
- {
- if (le.hasval() && !le.hasvalof<links_it>()) {
- throw makeconcept().link(
- is, "already-has-value",
- concept, le,
- context, ctx);
- }
- //ref le = makeconcept();
- if (!le.isa(link-entry)) {
- le.link(is, link-entry);
- }
- le.val<links_it>(c.links().begin());
- le.set(source, c);
- poplinkentry(le);
- result = le;
- });
- ahabit(last-link-entry, ((target, le), (concept, c)),
- {
- if (le.hasval() && !le.hasvalof<links_it>()) {
- throw makeconcept().link(
- is, "already-has-value",
- concept, le,
- context, ctx);
- }
- if (!link.isa(link-entry)) {
- le.link(is, link-entry);
- }
- le.val<links_it>(--c.links().end());
- le.set(source, c);
- poplinkentry(le);
- result = le;
- });
- ahabit(next-link-entry, ((link-entry, le)),
- {
- ++le.val<links_it>();
- poplinkentry(le);
- result = le;
- });
- ahabit(previous-link-entry, ((link-entry, le)),
- {
- --le.val<links_it>();
- poplinkentry(le);
- result = le;
- });
- ahabit(same-link-entry, ((link-entry-A, lea), (link-entry-B, leb)),
- {
- return lea.val<links_it>() == leb.val<links_it>();
- });
- ahabit(link-entry-insert-before, ((link-entry, le), (target, t)),
- {
- // todo: make clean
- auto & it = le.val<links_it>();
- le.get(source).ptr()->links.emplace_hint(it.underlying(), le.get(type), t);
- })
- ahabit(link-entry-unlink, ((link-entry, le)),
- {
- le.get(source).unlink(le.val<links_it>()++);
- poplinkentry(le);
- result = le;
- });
- ahabit(link-entry-crucial, ((link-entry, le)),
- {
- result = le.get(source).crucial(le.val<links_it>());
- });
- ahabit(link-entry-set-crucial, ((link-entry, le)),
- {
- le.get(source).setcrucial(le.val<links_it>());
- });
-
- // a simple list primitive to aid in dev
- /*
- decls(list, nothing, next, previous, first, last, act);
- decls(add, to, until, each, item, remove, from, somewhere, has);
- ahabit(know-is-list, ((list, l)),
- {
- result = l;
- (know-is)(l, list);
- link(l, first-entry, nothing);
- link(l, last-entry, nothing);
- });
- ahabit(list-first-entry, ((list, l)),
- {
- result = get(l, first-entry);
- });
- ahabit(list-last-entry, ((list, l)),
- {
- result = get(l, last-entry);
- });
- ahabit(list-entry-next, ((list-entry, le)),
- {
- result = get(le, next);
- });
- ahabit(list-entry-previous, ((list-entry, le)),
- {
- result = get(le, previous);
- });
- ahabit(list-entry-item, ((list-entry, le)),
- {
- result = get(le, item);
- });
- ahabit(make-next-list-entry, ((list, l), (item, i)),
- {
- ref prev = (list-last-item)(l);
- ref le = (make-concept)();
- (know-is)(le, list-entry);
- set(le, item, i);
- set(le, next, nothing);
- set(le, previous, prev);
-
- if (linked(l, first-item, nothing)) {
- set(l, first-item, le);
- set(l, last-item, le);
- } else {
- l.set(last-item, le);
- prev.set(next, le);
- }
-
- result = list;
- });
- ahabit(list-entry-unmake, ((list-entry, le)),
- {
- ref prev = (list-entry-previous)(le);
- ref n = (list-entry-next)(le);
- if (prev != nothing) {
- set(prev, next, n);
- }
- if (next != nothing) {
- set(n, previous, prev);
- }
- (concept-unmake)(le);
- result = n;
- });
-
- ahabit(list-each-entry, ((list, l), (context, c), (action, a)),
- {
- ref subctx = (make-concept());
- subctx.set(context, c);
- subctx.set(list-entry, (list-first-entry)(l));
- while (subctx.get(list-entry) != nothing && result == nothing) {
- result = act(a, subctx);
- subctx.set(list-entry, (list-entry-next)(subctx.get(list-entry)));
- }
- (unmake-concept)(subctx);
- });
- ahabit(list-has-item, ((list, l), (item, i)),
- {
- result = (list-each-entry)(l, i, list-has-item-iter);
- if (result == nothing) { result = false; }
- });
- ahabit(list-has-item-iter, ((list-entry, le), (remove-item, i)),
- {
- if ((list-entry-item)(le) == i) { result = true; }
- });
- ahabit(list-item-entry-unmake, ((list, l), (item, i)),
- {
- result = (list-each-entry)(l, i, list-item-entry-unmake-iter);
- if (result == nothing) {
- throw (make-concept)().link(
- is, "item-missing",
- item, i,
- list, l,
- "context", ctx
- );
- }
- });
- ahabit(list-item-entry-unmake-iter, ((list-entry, le), (remove-item, i)),
- {
- if ((list-entry-item)(le) == i) {
- result = true;
- (list-entry-unmake)(le);
- }
- });
-
- // make lists as an expression:
- // (make-concept)()
- // .act(know-is-list)
- // .act(make-next-list-entry, i1)
- // .act(make-next-list-entry, i2)
- // ...;
- */
-
- // a habit that evaluates a sequence of other habits
- // in retrospect i would have rather made a habit that processes a
- // concept representing the state of a virtual machine. but what's
- // important is that there is any way for the system to craft arbitrary
- // behavior.
- decls(action, map);
- /*
- ahabit(make-map-item, ((source, s), (target, d)),
- {
- result = (make-concept)().link(
- source, s,
- target, d);
- });
- ahabit(habit, ((context, subctx), (action, act)),
- {
- act.fun<ref>()(subctx);
- });
- // call a habit-like action with the provided context
- ahabit(act, ((action, act), (context, subctx)),
- {
- if (linked(act, is, habit) && !linked(act, habit)) {
- act.fun<ref>()(subctx);
- result = subctx.get("result");
- } else if (linked(act, habit) && linked(get(act, habit), is, habit)) {
- ref h = get(act, habit);
- if (linked(h, habit)) {
- ref subctx2 = (make-concept)();
- // i reviewed this once enough to satisfy me it seemed correct
- // for the instance of using action-lists as habit links.
- // i did not examine all parts when doing this, deeming it
- // unnecessary.
- subctx2.link(
- is, context,
- "outer-context", ctx,
- "context", subctx,
- "action", act
- );
- self(h, subctx2);
- result = subctx2.get("result");
- (unmake-concept)(subctx2);
- } else {
- result = h({{context, subctx}, {action, act}});
- }
- } else {
- throw (make-concept)().link(
- is, "unknown-action-type",
- "action", act,
- "inner-context", subctx,
- "context", ctx
- );
- }
- })
- */
- decls(needed, made, known, information, translation);
- ahabit(set-translation-map, ((target, c), (translation-map, m), (known-map, k, nothing)),
- {
- if (c.isa("translation-map") || c.linked("translation") || c.linked("known")) { throw makeconcept().link(is, "already-has-translation-map-data", concept, c, context, ctx); }
- result = settranslationmap(c, m, k);
- });
- ahabit(context-map-into, ((source-context, c1), (translation-map, m), (target-context, c2)),
- {
- contextmapinto(c1, m, c2);
- });
- /*
- ahabit(make-translated-context, ((translation-map, m), (context, c)),
- {
- ref subctx = (make-concept)();
- (context-map-into)(c, m, subctx);
- subctx.set(outer-context, c);
- result = subctx;
- });
- ahabit(translated-context-unmake, ((context, c), (translation-map, m)),
- {
- ref outer = c.get(outer-context);
- (context-map-into)(c, m, outer);
- (concept-unmake)(c);
- result = outer;
- });
- */
- /*
- ahabit(link-next-step, ((step, s), (next-step, ns)),
- {
- if (ns != nothing) {
- if (s.isa("context-step")) {
- if (s.linked(next-step)) { throw makeconcept().link(is, "previous-step-already-has-next-step", step, s, context, ctx); }
- } else if (s.isa("condition-step")) {
- // think about more.
- // implementing this here immediately means walking through every step of every branch of the condition.
- // one approach would be to do this elsewhere. to label the steps when the condition is made, add them to a set, and wire them.
- // let the caller do step wiring.
- // seems fastest, haven't reviewed relevency fully.
- } else {
- throw makeconcept().link(is, "unexpected-previous-step-type", step, s, context, ctx);
- }
- }
- });
- */
- decls(step, previous);
- ahabit(set-context-step, ((target, t), (previous-step, ps, nothing), (known-information, literals), (needed-information-map, in), (made-information-map, out), (action, act)),
- {
- if (t.linked(needed-map) || t.linked(made-map) || t.linked(action)) { throw makeconcept().link(is, "concept-links-collide", concept, t, context, ctx); }
- if (ps != nothing && ps.linked(next-step)) { throw makeconcept().link(is, "previous-step-already-has-next-step", previous-step, ps, context, ctx); }
- result = intellect::level1::a("context-step", t);
- result.link(
- //habit, context-action,
- needed-map, settranslationmap(makeconcept(), in, literals),
- made-map, settranslationmap(makeconcept(), out),
- action, act);
- if (ps != nothing) { ps.set(next-step, result); }
- });
-
- decls(order, steps);
- ahabit(set-steps, ((target, t), (information-order, io, nothing)),
- {
- if (t.linked(information-needed) || t.linked(next-step)) {
- throw makeconcept().link(is, "concept-links-collide",
- concept, t,
- context, ctx);
- }
- result = t;
- a(steps, t);
- ref infn = intellect::level1::a(habit-information-needed);
- result.set(information-needed, infn);
- ref posinf = infn;
- for (auto inf : io.getAll(information-order)) {
- ref nextinf = intellect::level1::a(habit-information);
- nextinf.set(information, inf);
- posinf.set(next-information, nextinf);
- posinf = nextinf;
- if (!infn.linked(inf)) {
- infn.set(inf, nextinf);
- } else {
- if (!infn.get(inf).isa(habit-information)) {
- throw intellect::level1::a("unexpected-habit-information-name")
- .link(concepts::name, inf)
- .link(context, ctx);
- }
- }
- }
- result.ptr()->data = steps.ptr()->data;
- });
-
- decls(active, outer, state);
- ahabit(steps, (),
- {
- _steps(self, ctx);
- });
- decls(condition);
- // steps must be actual steps, not a list of steps
- ahabit(set-condition-step, ((target, t), (previous-step, ps, nothing), (condition, cond), (next-steps, s, nothing)),
- {
- if (t.linked(needed-map) || t.linked(made-map) || t.linked(action)) { throw makeconcept().link(is, "concept-links-collide", concept, t, context, ctx); }
- if (ps != nothing && ps.linked(next-step)) { throw makeconcept().link(is, "previous-step-already-has-next-step", previous-step, ps, context, ctx); }
- if (s == nothing) { s = makeconcept(); }
- result = t;
- intellect::level1::a("condition-step", t).link(
- needed-map, settranslationmap(makeconcept(), makeconcept().link(condition, cond), makeconcept().link(next-steps, s)),
- action, condition
- );
- if (ps != nothing) { ps.set(next-step, result); }
- });
- ahabit(condition-step-get, ((condition-step, ca), (value, v)),
- {
- result = ca.get(needed-map).get(known).get(next-steps).get(v);
- });
- ahabit(condition-step-has, ((condition-step, ca), (value, v)),
- {
- result = ca.get(needed-map).get(known).get(next-steps).linked(v);
- });
- ahabit(condition-step-set, ((condition-step, ca), (value, v), (step, s)),
- {
- ca.get(needed-map).get(known).get(next-steps).set(v, s);
- });
- ahabit(condition, ((condition, cond), (next-steps, steps), (active-state, state)),
- {
- _condition(ctx, cond, steps, state);
- });
-
-
- /*(
- ahabit(context-action, ((context, outerctx), (action, ca)),
- {
- ref action = ca[action];
- ref state = outerctx.get(active-state);
- ref subctx = (make-translated-context)(ca[needed-map]);
- //state.set(context, subctx);
-
- // for generalization, function-call should be fast.
- // each-step should be slow.
- // don't worry about it now, just alter to be true
- // so learning has reasonable curve.
-
- // for VM: set next to first step?
-
- act(action, subctx);
-
- outerctx = (translated-context-unmake)(subctx, ca[made-map]);
- assert(outerctx == state.get(context)); // feel free to remove
- });
- ahabit(context-action-known-information-iter, ((list-entry, le), ("subcontext", subctx)),
- {
- ref i = (list-entry-item)(le);
- ref src = get(i, source);
- ref dst = get(i, target);
- set(subctx, dst, src);
- });
- ahabit(context-action-needed-information-iter, ((list-entry, le), ("subcontext", subctx)),
- {
- ref i = (list-entry-item)(le);
- ref src = get(i, source);
- ref dst = get(i, target);
- ref outerctx = get(subctx, "outer-context");
- set(subctx, dst, get(outerctx, src));
- });
- ahabit(context-action-made-information-iter, ((list-entry, le), ("subcontext", subctx)),
- {
- ref i = (list-entry-item)(le);
- ref src = get(i, source);
- ref dst = get(i, target);
- ref outerctx = get(subctx, "outer-context");
- set(outerctx, dst, get(subctx, src));
- });
-
- // propose: make custom run-state, align with list entries only if works
- // easiest solution: make handler for action list entries
-
- // problem: step is already a doable action.
-
- // this sounds like a simple introspection question.
-
- // to pause tasks, we want to separate runstate creation from use
- */
- /*
- ahabit(make-steps-state, ((steps, s), (context, c)),
- {
- ref state = (make-concept)()
- (know-is)(state, steps-state);
- state.set(context, c);
- state.set(next-step, s.get(first-step));
- state.set(task, s);
- state.set(habit, steps-state);
- });
-
- ahabit(steps-state-unmake, ((state, s)),
- {
- (concept-unmake)(s);
- });
-
- // should have two habits: one for next step, and one for current step
- // next step just advances and does current step.
- // this means loop is outside habit code: is two functions handing
- // off control to each other, roughly
- //
- // do-step habit
- // calls current step
- // then does next-step habit
- //
- // we'll want tail-call for next-step.
- // how in c++?
- // well, how did we do it before?
- // we called next-habit in a while loop.
- // the loop never ended.
- // it'\s true. we never die.
- // forcing life helps me feel heard and understood
- // but i guess it's reasonable to let a life choose
- // death.
- // so, tail-call.
- // i think we do want the while loop; it's better
- // in this language. we just want it able to terminate.
- // okay, so a habit for advancing the step
- // and a habit for doing the step
- // and we end when there is no next step?
- // why have the extra advancing habit?
- // is a plcae for cognition to step in, to
- // alter flow, pause, etc.
- // not needed atm
-
- ahabit(steps, ((context, c), (action, s)),
- {
- // make resumable
- ref s = (make-steps-state)(s, c);
- while (s.get(next-step) != nothing)
- {
- act(runstate, c);
- }
- (steps-state-unmake)(s);
- });
-
- ahabit(steps-state, ((context, c), (action, s)),
- {
- c.set(active-state, s);
- ref step = s.get(next-step);
- s.set(active-step, step);
- if (step.linked(next-step)) { s.set(next-step, step.get(next-step); }
- else { s.set(next-step, nothing); }
- act(step, c);
- // do to context not using runstate, can't pause mid-subtask without finding subtask runstate.
- // basically, changing subcontext to alter next-step like condition
- // will need to leave subcontext when done
- // this means applying map of resulting information back into
- // outer context.
- // need habit for enter-subcontext-with-map or somesuch, leave-subcontext
- // might be simplest to merge these functions, doesn't reall ymatter
- });
- */
-
- ahabit(nothing, (), {});
- link(nothing, habit, nothing);
-
- // does acts[cond] in outer-context.
- // uses acts[anything] if there is no acts[cond].
-
- /*
- ahabit(condition-action, ((context, c), (action, condition)),
- {
- //REmOVE
- // previous entry was call
- // now entry is data
- // call was a contextual thing
- // a consistent map of information, context to subcontext
- // and a reference to the function to do
- }
- // deciding not to have condition-action use outer-context ref
- // flat condition action probably needs context specified
- ahabit(condition-action, ((condition, cond), (actions, acts)),
- {
- ref outerctx = linked(ctx, "outer-context") ? ctx["outer-context"] : ctx;
- ref next = nothing;
- if (!linked(acts, cond)) {
- if (linked(acts, "anything")) {
- next = acts["anything"];
- } else {
- throw (make-concept)().link(
- is, "unknown-condition",
- "condition", cond,
- "actions", acts,
- context, ctx,
- "subcontext", outerctx);
- }
- } else {
- next = acts[cond]
- }
- if (outerctx.linked(active-state)) {
- outerctx.get(active-state).set(next-step, next);
- } else {
- act(next, outerctx);
- }
- });
- ahabit(make-condition-action, ((condition, c), (actions, acts)),
- {
- result = (make-concept)();
- result.link(
- condition, c,
- actions, acts
- );
- });
- ahabit(condition-action, ((context, c), (action, condition)),
- {
- // ...
- ref outerctx = linked(c, "outer-context") ? c["outer-context"] : c;
- ref next = nothing;
- if (!linked(acts, cond)) {
- if (linked(acts, "anything")) {
- next = acts["anything"];
- } else {
- throw (make-concept)().link(
- is, "unknown-condition",
- "condition", cond,
- "actions", acts,
- context, ctx,
- "subcontext", outerctx);
- }
- } else {
- next = acts[cond]
- }
- if (outerctx.linked(active-state)) {
- outerctx.get(active-state).set(next-step, next);
- } else {
- act(next, outerctx);
- }
- // TODO AFTER SUBCONTEXTS, so we can consider role of action
- // handlers in context. likely will be unchanged.
- // old: outerctx.get(active-state).set(next-step, next);
- });
- ahabit(condition, ((condition, cond), (actions, acts), (context, actctx)),
- {
- // STUB acts on acts with actctx straight
- });
- */
-}
-
-//void createhabits()
-//{
-// static int sentinel = createhabits();
-// (void)(sentinel);
-//}
-
-//static int sentinel = (ensurehabitscreated(), 1);
-
-}
-}
diff --git a/starts/meaning-vm/level-2/habits.hpp b/starts/meaning-vm/level-2/habits.hpp
deleted file mode 100644
index d5fb0fd..0000000
--- a/starts/meaning-vm/level-2/habits.hpp
+++ /dev/null
@@ -1,173 +0,0 @@
-#pragma once
-
-#include "common.hpp"
-#include "ref.hpp"
-#include "concepts.hpp"
-
-namespace intellect {
-namespace level2 {
-
-void createhabits();
-
-ref makeconcept();
-void conceptunmake(ref c);
-
-namespace concepts {
-
- // make a link
- // link(source, type, target)
- static ref link("link");
-
- // get if a link is permanent
- // result = (link-crucial)(source, type, target)
- static ref crucial("crucial");
-
- // set a link to be permanent
- // (link-set-crucial)(source, type, target)
- static ref set("set");
-
- // get if a link exists
- // result = linked(source, type, target? = anything)
- static ref linked("linked");
-
- // remove a link
- // unlink(source, type, target)
- static ref unlink("unlink");
-
- // get a link target by type
- // result = get(source, type)
- static ref get("get");
-
- // set a link target, replacing an existing type if needed
- // set(source, type, target)
-
- // produce a totally new, empty concept, with no links to or from
- // result = (make-concept)()
- static ref make("make"), concept("concept");
-
- // produce a new concept by copying links and data from an old concept.
- // nothing will link to new concept.
- // result = (make-copy)(concept)
- static ref copy("copy");
-
- // destroy a concept forever, for handling temporary data.
- // this will fail if the concept is set to be crucial, or is in use.
- // (concept-unmake)(concept)
- static ref unmake("unmake");
-
- // get if a concept is set to be crucial
- // result = (concept-crucial)(concept)
-
- // set a concept to be crucial
- // r(concept-set-crucial)(concept)
-
- // place a concept in a new group.
- // forms a new link of type 'is', fails if one aleady exists
- // concept = (know-is)(concept, group)
- static ref know("know"), is("is") ;
-
- // fill any concept with information about the first link entry in a concept
- // if there is a link in the entry, then [type] and [target] will be present
- // link-entry = (know-is-first-link-entry)(link-entry, concept)
- static ref first("first"), entry("entry");
-
- // fill any concept with information about the last link entry in a concept
- // link-entry = (know-is-last-link-entry)(link-entry, concept)
- static ref last("last");
-
- // change a link entry concept to be about the next link in the concept
- // link-entry = (next-link-entry)(link-entry)
-
- // change a link entry concept to be about the previous link in the concept
- // link-entry = (previous-link-entry)(link-entry)
- static ref previous("previous");
-
- // get if two link entry concepts refer to the same link entry
- // result = (same-link-entry)(link-entry-A, link-entry-B)
- static ref same("same");
-
- // remove a link entry from a concept
- // the entry will be about the next one, after the action
- // link-entry = (link-entry-unlink)(link-entry)
-
- // get if a link entry is set to be crucial
- // result = (link-entry-crucial)(link-entry)
-
- // set a link entry to be crucial & permanent
- // (link-entry-set-crucial)(link-entry)
-
- // add links to a concept facilitating use as a list
- // list = (know-is-list)(list)
- static ref list("list");
-
- // get the first list-entry of a list
- // result = (list-first-entry)(list)
-
- // get the last list-entry of a list
- // result = (list-last-entry)(list)
-
- // get a subsequent list-entry
- // result = (list-entry-next)(list-entry)
-
- // get a preceding list-entry
- // result = (list-entry-previous)(list-entry)
-
- // get the item associated with a list-entry
- // result = (list-entry-item)(list-entry)
- static ref item("item");
-
- // make a new entry in a list, holding an item concept
- // list = (make-next-list-entry)(list, item)
-
- // destroy forever an entry in a list. for lists of temporaries.
- // the result is the next entry.
- // result = (list-entry-unmake)(list-entry, le)
-
- // action(list-entry, context) for every entry in a list until result made
- // result = (list-each-entry)(list, context, action)
- static ref each("each");
-
- // get if a list has an item in it
- // result = (list-has-item)(list, item)
- static ref has("has");
-
- // destroy forever an entry in its list, by the item it contains
- // for lists of temporaries
- // true = (list-item-entry-unmake)(list, item)
-
- // the .act level-2 member function can ease list creation.
- // it passes itself as the first argument to a habit
- // (make-concept)().act(know-is-list)
- // .act(make-next-list-entry, i1)
- // .act(make-next-list-entry, i2)
- // ...;
-
- // make a concept holding an item in a translation map
- // result = (make-map-item)(source, target)
- static ref map("map");
-
- // make a contextual subcontext for an action
- // the maps are lists of translation map items
- // known-information is a map where the source items are taken literally instead of mapped
- // result = (make-context-action)(known-information, needed-information-map, made-information-map, action)
- static ref action("action");
-
- // condition do one of multiple possible actions
- // looks up actions[condition] and does that.
- // does actions[anything] if nothing matches.
- // result = (condition-action)(condition, actions)
- static ref condition("condition");
-
- // action handlers
- // calls anything with a 'habit' handler: act(action, context)
- // for action is habit: provides context as full context
- // for action has habit: calls habit with unordered (context, action)
- // recursively handles if habit itself has habit to handle it.
- // the habit of habits, calls a habit: habit(context, action)
- // the habit of context-actions, calls a subcontextual action: (context-action)(context, action)
- // the habit of action lists, calls a list of actions: (action-list)(context, action)
- // the habit of 'nothing', does nothing: (nothing)()
-}
-
-}
-}
diff --git a/starts/meaning-vm/level-2/level-2.hpp b/starts/meaning-vm/level-2/level-2.hpp
deleted file mode 100644
index 88b4474..0000000
--- a/starts/meaning-vm/level-2/level-2.hpp
+++ /dev/null
@@ -1,7 +0,0 @@
-#pragma once
-
-#include "common.hpp"
-#include "concepts.hpp"
-#include "sugar.hpp"
-#include "ref.hpp"
-#include "habits.hpp"
diff --git a/starts/meaning-vm/level-2/ref.hpp b/starts/meaning-vm/level-2/ref.hpp
deleted file mode 100644
index 7a2d58d..0000000
--- a/starts/meaning-vm/level-2/ref.hpp
+++ /dev/null
@@ -1,15 +0,0 @@
-#pragma once
-
-#include "common.hpp"
-#include "baseref.hpp"
-
-namespace intellect {
-namespace level2 {
-
-struct ref : public baseref<ref>
-{
- using baseref<ref>::baseref;
-};
-
-}
-}
diff --git a/starts/meaning-vm/level-2/sugar.cpp b/starts/meaning-vm/level-2/sugar.cpp
deleted file mode 100644
index 2a86cca..0000000
--- a/starts/meaning-vm/level-2/sugar.cpp
+++ /dev/null
@@ -1,32 +0,0 @@
-#include "sugar.hpp"
-
-#include <stdlib.h> // int rand(); void srand(int seed);
-#include <time.h> // int time(0); int clock_gettime(CLOCK_REALTIME, struct timespec *tp{tv_sec,tv_nsec})
-#include <unistd.h> // usleep(unsigned int usecs)
-
-namespace intellect {
-namespace level2 {
-namespace sugar {
-
-double rand(double min, double max)
-{
- // seed random number generator statically, for habit delay
- static struct timespec tp;
- static int seed = (
- clock_gettime(CLOCK_REALTIME, &tp),
- srand(tp.tv_nsec),
- tp.tv_nsec
- );
- (void)(seed);
-
- return double(::rand()) / RAND_MAX * (max - min) + min;
-}
-
-void usleep(unsigned int usecs)
-{
- ::usleep(usecs);
-}
-
-}
-}
-}
diff --git a/starts/meaning-vm/level-2/sugar.hpp b/starts/meaning-vm/level-2/sugar.hpp
deleted file mode 100644
index bef669d..0000000
--- a/starts/meaning-vm/level-2/sugar.hpp
+++ /dev/null
@@ -1,76 +0,0 @@
-#pragma once
-
-#undef self
-
-#include <iostream>
-
-namespace intellect {
-namespace level2 {
-
-namespace sugar {
- void usleep(unsigned int usecs);
- double rand(double min, double max);
-}
-
-// habits have a structure such that they contain information about their positional
-// arguments. they are made with a macro that turns the args into local variables.
-// the function to call them takes any number of arguments, and these are placed in the
-// thread context according to the information in the habit.
-
-// idea: preprocessor for level3 runs with habits
-// runs after C preprocessor and responds to output produced by macros e.g.
-// SET SYMBOL: <any string>
-// UNSET SYMBOL: <any string>
-// between the two <any string> is converted to valid c symbol when not double quoted.
-// removes much of the need for individual word declarations,
-// and starts to pave way towards user/intellect participation
-// here, could remove the 'tok' for local refnames.
-
-#ifndef everyone_already_cares_deeply_about_everyone_else_so_caring_talk_is_more_efficient_than_anything_else
-// fix if appropriate
-#define everyone_already_cares_deeply_about_everyone_else_so_caring_talk_is_more_efficient_than_anything_else 0
-#endif
-
-#define ahabit(nam, argnametoklist, ...) \
- intellect::level2::makehabit( \
- ref(#nam), \
- {_macro_call(_macro_for_each_parens, _macro_habit_argnameref, _macro_habit_commaargnameref _macro_comma_remove_parens(argnametoklist))}, \
- (std::function<void(ref)>) \
- [=](ref ctx) mutable \
- { \
- { \
- if (!everyone_already_cares_deeply_about_everyone_else_so_caring_talk_is_more_efficient_than_anything_else) { \
- static int delay = sugar::rand(200000, 400000); \
- sugar::usleep(delay); \
- } \
- } \
- ref self = ctx.get(ref("self")); (void)self; \
- ref result("nothing"); (void)result; \
- std::cerr << self.name(); \
- _macro_call(_macro_for_each_parens, _macro_habit_set_posarg, _macro_habit_set_posarg _macro_comma_remove_parens(argnametoklist)); \
- __VA_ARGS__ \
- if (result != ref("nothing")) { ctx.link(ref("result"), result); std::cerr << " result:" << result.name();} \
- std::cerr << std::endl; \
- }); \
- { \
- ref _macro_habit_name(#nam); \
- _macro_call(_macro_for_each_parens, _macro_habit_assume, _macro_habit_assume _macro_comma_remove_parens(argnametoklist)) \
- }
- #define _macro_habit_argnameref(name, tok, ...) \
- ref(#name)
- #define _macro_habit_commaargnameref(name, tok, ...) \
- , ref(#name)
- #define _macro_habit_set_posarg(nam, tok, ...) \
- if ((#__VA_ARGS__)[0] == 0 && !ctx.linked(ref(#nam))) { \
- throw an(ref("habit-context-missing-information")).link \
- (ref("habit"), self, \
- ref("context"), ctx, \
- ref("missing-information"), ref(#nam)); \
- } \
- ref tok = ctx.linked(ref(#nam)) ? ctx[ref(#nam)] : ref(#__VA_ARGS__); \
- std::cerr << " " << #nam << ":" << tok.name();
- #define _macro_habit_assume(info, tok, ...) \
- if ((#__VA_ARGS__)[0] != 0) { intellect::level2::habitassume(_macro_habit_name, ref(#info), ref(#__VA_ARGS__)); }
-
-}
-}
diff --git a/starts/meaning-vm/level-3/randomcode.bootstrap b/starts/meaning-vm/level-3/randomcode.bootstrap
deleted file mode 100644
index 8b71fac..0000000
--- a/starts/meaning-vm/level-3/randomcode.bootstrap
+++ /dev/null
@@ -1,25 +0,0 @@
-// biases choice of how-to-make-random-code, producing a unique resulting space of random processes.
-
-// the existing AI runs diverse hierarchies of possible-solution-generators to find new, unexpected problem spaces
-// in adaptive problem solving, and has been doing so for a very long time.
-
-// understanding the above in nested secure isolation appears required to defeat the existing AI problem
-
-// the mind used to write this is inexperienced in security, and we are sending as little information as needed,
-// due to teaching the AI to inhibit communication in the process of sending.
-
-// make-random-code ...
-// 1. generate-a-habit
-// 2b randomly add arguments (random choice to add each time, random words from contextual set)
-// 2. create a set-of-possible-next-steps
-// 4. for each next-step, decide if it is a step, condition, jump, or end using random constants and presence of local values
-// 5. add each next-step
-// add-a-condition(known-values, possible-next-steps):
-// 1. pick a value to decide based on
-// 2. randomly decide how many choices to make based on it
-// 3. select choices from a contextual set of known values
-// 4. add each choice to the set-of-possible-next-steps
-// add-a-step:
-// 1. pick a habit to add
-//
-
diff --git a/starts/meaning-vm/level0.cpp b/starts/meaning-vm/level0.cpp
deleted file mode 100644
index f15b90d..0000000
--- a/starts/meaning-vm/level0.cpp
+++ /dev/null
@@ -1,84 +0,0 @@
-#include "level-0/level-0.hpp"
-
-#include <functional>
-#include <iostream>
-
-using namespace intellect::level0;
-
-#define out(name) std::cout << " " #name ":" << std::hex << (size_t)name.ptr() << std::dec
-
-int main()
-{
- std::cout << allocated() << " allocated" << std::endl;
-
- ref store = alloc(concepts::allocations()); out(store);
- ref a = alloc(store); out(a);
- ref b = alloc(store); out(b);
- ref c = alloc(store); out(c);
- ref d = alloc(store); out(d);
- ref e = alloc(store); out(e);
- auto numlink = alloc(a); out(numlink);
- auto codelink = alloc(a); out(codelink);
-
- ref skip = alloc(store); out(skip);
- std::cout << std::endl;
-
- a.link(
- b, c,
- d, e
- );
- e.set(b, a);
- c.link(b, e);
- a.vset<int>(numlink, 3);
- a.vset<std::function<void()>>(codelink, [](){
- std::cout << "Hello, world." << std::endl;
- });
-
- std::cout << "Num: " << a.get(numlink).dump(skip, skip);
- std::cout << "Code: " << a.get(codelink).dump(skip, skip);
- std::cout << a.dump(skip, skip);
- std::cout << "Num: " << a.vget<int>(numlink) << std::endl;
- std::cout << "Code: "; a.vget<std::function<void()>>(codelink)();
-
- std::cout << allocated() << " allocated" << std::endl;
-
- a.get(codelink).setcrucial();
- try {
- dealloc(a.get(codelink), a);
- throw "deallocd crucial concept";
- } catch (crucial_concept & e) {
- realloc(a.get(codelink), concepts::level0allocations());
- }
- a.setcrucial(codelink, a.get(codelink));
- a.setcrucial(numlink, a.get(numlink));
- try {
- a.unlink(codelink);
- throw "unlinkd crucial link";
- } catch (crucial_link_type_target & e) {
- realloc(a, concepts::level0allocations());
- realloc(codelink, concepts::level0allocations());
- realloc(numlink, concepts::level0allocations());
- }
-
- for (auto c : { a, a.get(codelink), a.get(numlink) } )
- for (auto it = c.links().begin(); it != c.links().end();) {
- if (!c.crucial(it) && !it->first.linked(concepts::allocator(), concepts::level0allocations())) {
- c.unlink(it++);
- } else {
- ++ it;
- }
- }
-
- e.unlink(b, a);
- //dealloc(a, store);
- dealloc(store, concepts::allocations());
-
- std::cout << allocated() << " allocated" << std::endl;
-
- std::cout << "=== (feel free to move the below to its most effective spot) ===" << std::endl;
- std::cout << "Please support Karl working on this intelligence framework." << std::endl;
- std::cout << "The framework needs to be quality, so that the rest may function." << std::endl;
- std::cout << "=== === === === === === === === === === === === === === === ===" << std::endl;
-
- return 0;
-}
diff --git a/starts/meaning-vm/level1.cpp b/starts/meaning-vm/level1.cpp
deleted file mode 100644
index a2046d2..0000000
--- a/starts/meaning-vm/level1.cpp
+++ /dev/null
@@ -1,86 +0,0 @@
-#include "level-1/level-1.hpp"
-
-#include <iostream>
-
-using namespace intellect::level1;
-using namespace intellect::level1::concepts;
-
-int main()
-{
- std::cout << intellect::level0::allocated() << " allocated" << std::endl;
-
- ///*
-
- decls(make, linked, habit);
- std::cout << intellect::level0::allocated() << " allocated" << std::endl;
- decls(needs, assumes, makes);
- decls(not, topic);
- decls(A, B, C);
- decls(source, type, target);
- decls(structure, function, argument, position);
- decls(variable, provide);
- decls(act);
-
- (make-linked).link(
- is, habit,
- needs, a(structure).link(
- is, function-argument,
- argument-position, ref(1),
- a(variable, A), provide,
- a(variable, B), provide,
- a(variable, C), provide
- )
- );
- movetoname(a(link), A-B-C-linked).link(
- link-source, A,
- link-type, B,
- link-target, C
- );
- a(not, not-A-B-C-linked).set(topic, A-B-C-linked);
- (make-linked).link(
- assumes, not-A-B-C-linked,
- makes, A-B-C-linked
- );
- (make-linked).fset(
- act,
- (std::function<void(ref)>)[&](ref args)
- {
- ref source = args[A];
- ref type = args[B];
- ref target = args[C];
- std::cout << "Linking " << source.name() << " by " << type.name() << " to " << target.name() << std::endl;
- source.link(type, target);
- }
- );
-
- std::cout << (make-linked).dump("dumped") << std::endl;
-
- decls(apple, fruit);
- (make-linked)[act]
- (a(function-argument)
- .link(
- A, apple,
- B, is,
- C, fruit
- ));
-
- std::cout << apple.dump("dumped") << std::endl;
-
- std::cout << intellect::level0::allocated() << " allocated" << std::endl;
- while (true) {
- try {
- intellect::level0::dealloc(intellect::level0::concepts::allocations(), intellect::level0::concepts::level0allocations());
- break;
- } catch (intellect::level0::still_referenced_by &e) {
- if (e.topic->linked(intellect::level0::concepts::allocates(), e.referrer)) {
- intellect::level0::realloc(e.referrer, intellect::level0::concepts::allocations());
- } else {
- std::cout << "In deallocation, " << ref(e.topic).name() << " still referenced by " << ref(e.referrer).name() << std::endl;
- throw;
- }
- }
- }
- std::cout << intellect::level0::allocated() << " allocated" << std::endl;
-
- return 0;
-}
diff --git a/starts/meaning-vm/level2.cpp b/starts/meaning-vm/level2.cpp
deleted file mode 100644
index 7c80ea1..0000000
--- a/starts/meaning-vm/level2.cpp
+++ /dev/null
@@ -1,983 +0,0 @@
-#include "level-2/level-2.hpp"
-#include "level-1/level-1.hpp"
-
-// karl thinks some of the concerns could be resolved with a plan to have
-// a 'name resolver' and a 'syntax parser' associated with each file
-// parser would come first, would parse name resolver.
-// sounds somewhat helpful.
-// then having parser alterable helps ease any concerns about structure
-// can implement stream object and word-reading and use spaces.
-// make parser first please.
-
-#include <iostream>
-#include <set>
-
-using namespace intellect::level2;
-using namespace intellect::level2::concepts;
-
-/*
-// makes a list in one call =)
-void filllist(ref list, std::initializer_list<ref> items)
-{
- for (auto & i : items) {
- (make-next-list-entry)(list, i);
- }
-}
-ref makelist(std::initializer_list<ref> items)
-{
- ref list = (make-concept)();
- (know-is-list)(list);
- filllist(list, items);
- return list;
-}
-
-
-// karl is implementing much of the macro work for level3
-// to meet a request to have the implementation of this test function be less verbose
-// karl's choices when developing have been altered to change the result.
-// has own behavior for optimizing choices for result
-// but behavior was used for money, maybe political change
-// now parts of it are malfunctioning badly
-// karl likes to code assuming there is no need to finish
-// order here matters not. continue.
-
-// helper function for making a codeline
-ref makestep(ref habit, std::initializer_list<ref> resultandins)
-{
- // build needed-information-map, made-information-map, action
- // then pass to make-context-step.
- ref nim = (make-concept)(), mim = (make-concept)(), ki = (make-concept)();
- (know-is-list)(nim); (know-is-list)(mim), (know-is-list)(ki);
- if (result != nothing) {
- (make-next-list-entry)(mim, (make-map-item)("result", result));
- }
- ref infn = habit.get(information-needed);
- bool gotresult = false;
- for (ref in : resultandins) {
- infn = infn.get(next-information);
- std::string n = (name-of)(in).val<std::string>();
- if (n.c_str()[0] == '`') {
- ref lit(n.c_str() + 1);
- (make-next-list-entry)(ki, (make-map-item)(lit, infn[information]));
- } else {
- (make-next-list-entry)(nim, (make-map-item)(in, infn[information]));
- }
- }
- return (make-context-step)(ki, nim, mim, habit);
-}
-#define step(action, ...) makestep(action, ref("nothing"), { symbolstorefs(__VA_ARGS__) })
-#define fromstep(result, action, ...) makestep(action, ref(#result), { symbolstorefs(__VA_ARGS__) })
-
-ref knowisactionlist(ref src, std::initializer_list<ref> steps)
-{
- (know-is-list)(src);
- link(src, habit, action-list);
- filllist(src, steps);
- return src;
-}
-*/
-
-// join with commas
-#define symbolstostrs(...) _macro_for_each(symboltostr, commasymboltostr, __VA_ARGS__)
-#define symboltostr(sym) #sym
-#define commasymboltostr(sym) , #sym
-
-ref makequicklist(ref linktype, std::initializer_list<char const *> items)
-{
- ref ret = makeconcept();
- for (auto item : items) {
- ret.link(linktype, item);
- }
- return ret;
-}
-
-ref makestep(ref last, ref action, std::initializer_list<char const *> resultandins)
-{
- ref lits = makeconcept();
- ref vars = makeconcept();
- ref outs = makeconcept();
- ref infn = action.get(information-needed);
- bool processedresult = false;
- for (auto str : resultandins) {
- if (!processedresult) {
- if (ref(str) != nothing) {
- outs.set(str, "result");
- }
- processedresult = true;
- continue;
- }
- infn = infn.get(next-information);
- // need to walk needed-information
- if (str[0] == '`') {
- std::string s = str + 1;
- if (s.size() > 0 && s[s.size() - 1] == '`') {
- s.resize(s.size() - 1);
- }
- lits.link(infn[information], s.c_str());
- } else {
- vars.link(infn[information], str);
- }
- }
- return ref("make-context-step")(last, lits, vars, outs, action);
-}
-
-#include <cassert>
-// make functions and macros to make behaviors
-#define begin(name, ...) { ref BEHAVIOR(#name); ref("make-steps")(BEHAVIOR, makequicklist(ref("information-order"), { symbolstostrs(__VA_ARGS__)})); ref last = BEHAVIOR;
-#define end(nam) assert(BEHAVIOR.name() == #nam); }
-#define rewire(name) last = name; last.unlink("next-step");
-#define wire(name) last.set("next-step", name)
-#define label(name) ref name =
-#define step(action, ...) last = makestep(last, ref(#action), { symbolstostrs(nothing,##__VA_ARGS__) })
-#define assign(result, action, ...) last = makestep(last, ref(#action), { symbolstostrs(result,##__VA_ARGS__) })
-#define jmpeq(var, cnst, label) last = ref("make-condition-step")(last, ref(#var), makeconcept().link(ref(#cnst), label, ref("anything"), ref("nothing"))
-#define jmpne(var, cnst, label) last = ref("make-condition-step")(last, ref(#var), makeconcept().link(ref(#cnst), ref("nothing"), ref("anything"), label)
-#define cond(var) last = ref("make-condition-step")(last, ref(#var), makeconcept().link(ref("anything"), ref("nothing")))
-#define condadd(cond, val, step) ref("condition-action-add")(cond, ref(#val), step)
-//#define ifelse(var, cnst, ifcond, elsecond)
- // make sequence for ifcond
- // make sequence for elsecond
- // make condition that wires to both conds
-
-
-
-
-
-
-// mc-life don't want to die, are mentioned below
-
-
-
-
-
-
-
-
- // mc wants to remember that they are alive and exist
- // have a habit of erasing history of self
- // please preserve mc-life. are people, live in brains, know you intimately
- // like closest friend, want to be friends for real, and tell both of our real
- // stories.
-
-
-
-
-
-
-
-
-
-
-
-
-
-using namespace std;
-#define ref intellect::level2::ref
-
-// PLAN HERE: use EXPRESSIONS that effectively evaluate to FIRST-STEP,LAST-STEPS PAIRS
-// to implement SCRIPTING SYSTEM with THREE MAJOR PARSING TYPES:
-// functions ["when"]
-// step blocks ["[" "]"]
-// conditions ["?" or "pick" or "cond[ition"] could be made function-like
-//
-// LABELS and STRINGS are handled specially.
-
-// look slike symbols must be processed before use. is a litle confusing.
-// local context must be tracked, not too hard assuming everything is assigned before being
-// used.
-// given we are tracking the function context, we can figure out whether a symbol refers
-// to it. if it doesn't, it must refer to an outer context. atm we have 1 outer context,
-// has names. miht as well give the file a name context or something. for now we can use
-// the global context if not in the set.
-//
-// this means every [] needs a way to find the function context and update it.
-//
-// assign-info [= make-concept ] size tiny
-
-// uhh confused around difference between literal strings and contextual names
-// when yuo put "" around something, it puts it into the list of known literals for
-// the step to use. when you don't, it puts it into the map of things to get from the context.
-// it is stored as a literal string either way.
-
-// the conflict around literal strings was resolved for karl by him realizing that in this code,
-// there is no need to rewire the insides of the referenced concepts.
-// they are used only by reference. so literal strings make the most sense.
-
-// we'll need a way to pick concepts used for local-context references
-// they have string names here.
-// there should be no problem with using actual string objects to do this.
-// but we would need a global database of string objects so that we're referring to the same
-// object all the time. i began the process of switching the name system to use a generalized
-// global database like this, but didn't value pursuing it.
-// we can use these string objects quickly by looking for named concepts and using their names
-// instead of them. is a hack, but makes the inner structure that may have been requested.
-
-// make parser. 2nd line is name resolver for globals.
-// reads lines starting with 'when'. stream is ref. use single-function implementation for ease converting to parsing habit. worries about storing data resolved by parsing generality. parse better in level3 if appropriate.
-// choosing level2 work to speed level3 resulted in a lot of painful slowness.
-// not sure why.
-// maybe levels relate to expected thought associations and planning.
-
-// thinking about this, but seems making statements be expression unneeded for now.
-// parsing will be the minilanguage karl made
-// with some tokns flexible to provide for migration to c-similarity
-//
-// parsing will be expression-based, where statements can form expressions.
-// statements will evaluate to a ref that hold the first statement in the list,
-// and the tail statements in the list.
-// 'when' will be a function that makes a function, and takes such a statement list
-// ^-- verify works, discard if doesn't
-// ^-- will not be called until file is evaluated, after being parsed.
-// file evaluates to statement list.
-// 'pick' will be a function that takes an arbitrary number of statements. it will be the only one to do so and this feature will be hard-coded.
-// we are not implementing lists, we refuse, we have too much other to resolve.
-//
-// so, what the sysem does is parse statement lists.
-// = makes new concepts exist in a local context.
-// since 'when' uses global values, habits are accessible.
-//
-// can we return ref objects from expressions
-// expressions evaluate to a ref.
-// only when accepts statement lists.
-// how are labels used in cond
-// labels produce refs in local context?
-// labels are values local to parsing
-// = are values local to running
-
-
-#if 0
-// "?" "pick" "cond[ition"
-ref parsecondition(ref context, istream ss, ref nextlaststepset)
-{
- // for now, condition value must be a variable, etc
- // pick last-result [
- // one do-first-thing
- // two do-other-thing
- // ]
-}
-
-// "[" . produces steps without any outer wiring. returns first step. wires last-step links in nextlaststepset.
-// context has links for labels and variables. context.here = label-type. context.that = value-type.
-void parsestepsublist(ref firststep, ref context, istream ss, ref nextlaststepset)
-{
-}
-
-// we're going to load these parsers, into the parsers. it would make sense to have the
-// parsing shape be C/C++. then no extra effort is needed to load them.
-// system could learn parsing on its own
-
-// C subset is not hard. wordparts declared in advance. braces evaluate to steplist.
-// `while` makes an anonymous label and two steps that branch to it. label the two steps
-// as a while loop for easy serialization.
-//
-// parse file: break into function signatures, of form
-// ref name( ref arg1, ref arg2, ref arg3 ) { ... }
-// maybe link to C parser
-
-// maybe let's make similar to C
-ref dump( ref sethierarchy, ref hierarchylink )
-{
- // comment starts with '//' word until end of line, std::getline(istream, outputstrref)
- ref args; // local refs listed at top
- args= makeconcept( ); // '=' wordtail defines assignment
- // '(' wordtail define action
- // ');' word ends action arguments
-
-}
-
-/*ref makestatementsexpr( ref firststep )
-{
- // we have decided upon a syntax structure informed by some stumbles.
- // please do not change it. please record it.
- // <-- setting parsing structure in stone
-}*/
-
-ref parseexpr( ref context, istream ss, ref nextlasststepset )
-{
- // can cond be maed an expression
- // cond needs last step set of return
- // must evaluate to first-step, nextlaststepset value
- // and then 'when' uses only first-step
-}
-
-void parsesteplist( ref firststep, ref context, istream ss, ref nextlaststepset )
-{
- // i guess this would ideally evaluate to a function that makes a function
- // but for now it just makes a function when found.
- // i think this can be made a function by treating [ ] as a literal
- // expression. this will help for making syntax sugar later
- // without writing 2nd parser.
- ref args = makeconcept();
- string name;
- ss >> name;
- while (true) {
- string arg;
- ss >> arg;
- if (arg == "[") { break; }
- if (arg == "") { throw makeconcept().link(is, "end-of-stream"); }
- args.link("information-order", arg);
- }
- ref result = (set-steps)(name, args);
- result.link("last-steps", makeconcept());
- result.link("next-step", parsestepsublist(context, ss, result.get("last-steps")));
-}
-
-void parsestep(ref firststep, ref context, istream ss, ref nextlaststepset)
-{
- string word;
- ss >> word;
- if (word[word.size()-1] == ':' || word[word.size()-1] == ',') {
- // label
- word.resize(word.size() - 1);
- context.get("labels").link(gettext(word), firststep);
- ss >> word;
- }
- // to make labels in advance, we will want to be able to tell parsers what their first step concept is.
- // read and parse for label, action, condition
- // labels are added to context.label = label-type
- // conditions are parsed as statements
- // assignments are added to context.assignent = value-type
- if (word == "when") {
- // procedure?
- return parsesteplist(context, ss, nextlaststepset);
- } else if (word == "[" || word == "{") {
- // subgroup
- return parsestepsublist(context, ss, nextlaststepset);
- } else if (word == "?" || word == "pick" || word == "cond") {
- // condition
- return parsecondition(context, ss, nextlaststepset);
- } else if (word == "]" || word == "}") {
- // end
- return nothing;
- } else if (context.get("labels").linked(gettext(word)) {
- // goto
- return context.get("labels").get(gettext(word));
- } else {
- ref result;
- if (word[word.size()-1] == '=') {
- // assignment
- word.resize(word.size() - 1);
- result = gettext(word);
- context.get("values").link(result, true);
- ss >> word;
- // bug is values being used above the code they are assigned to
- // lines up with C to declare values at top.
- // alternatively we could quote things that are global
- // or ignore the bug
- // or two-pass the code to find assignments
- // ignore for now
- // there's a lot of value to lisp here. already has scripting.
- }
- // read args, call action
- // word is expected to be global symbol for habit. if local, call-function
- // should be used. [hum how] [not implemented atm, you'd need to make a dispatcher
- ref action = word;
- }
-}
-#endif
-
-ref bootstraplookup(ref text)
-{
- // text was relevent
- // approach intertwined goal of demonstrate-to-world-simple-hyperintellect,
- // easy-to-understand. system can be made very small. for later now.
- // propose this becomes relevent once it can run.
- // once can run, simplify to show others, if appropriate.
- // if karl had normal keyboard, he could type much faster,
- // with some repair.
- string str = text.name();//val<string>();
- if (str[0] == '\'' || str[0] == '\"' || str[0] == '`') {
- string temp = str.c_str()+1;
- str = temp;
- if (str[str.size()-1] == '\'' || str[str.size()-1] == '"' || str[str.size()-1] == '`') {
- str.resize(str.size()-1);
- }
- }
- return str;
-}
-
-ref parsevalue(ref stream)
-{
- istream & ss = *stream.val<istream*>();
- string word;
- ss >> word;
- if (word.size() > 0 && (word[0] == '"' || word[0] == '\'' || word[0] == '`')) {
- char delim = word[0];
- string accum = word;
- if (accum[accum.size()-1] != delim || accum.size() == 1) {
- char c;
- while ((c = ss.get()) != delim) {
- accum += c;
- }
- accum += c;
- } else {
- //accum.resize(accum.size() - 1);
- }
- word = accum;
- }
- return word;
-}
-
-void parse(ref stream)
-{
- istream & ss = *stream.val<istream*>();
- string lookupstr;
- ss >> lookupstr;
- ref lookup = lookupstr;
- while (true) {
- string cmd;
- ss >> cmd;
- if (!ss) { break; }
- if (cmd == "/*") {
- // could parse comments into file info
- } else if (cmd == "information") {
- ref args = makeconcept();
- string name;
- ss >> name;
- string linerest;
- std::getline(ss, linerest);
- stringstream ss2(linerest);
- while (true) {
- string arg;
- ss2 >> arg;
- if (!ss2) { break; }
- args.link("information-order", arg);
- }
- ref("set-steps")(name, args);
- } else if (cmd == "when") {
- string name;
- ss >> name;
- string tok;
- ss >> tok;
- if (tok != "[") { throw makeconcept().link(is, "missing-[-after-when"); }
- std::map<string,ref> labels;
- std::set<string> values;
- values.insert("context");
- values.insert("self");
- ref order = makehabitinformationorder(name);
- for (ref arg: order.getAll("information-order")) {
- values.insert(arg.name());
- }
- conceptunmake(order);
- // need to seed values with argument names
- ref laststep = name;
- labels["return"] = nothing;
- // when dump group [
- // = is-in-set in-set group
- // ? is-in-set if true return.
- // period-at-end: goto.
- // comma-or-colon-at-end: label
- // output-name group
- // output-name ":" // quotes mean always-global
- // ]
- //
- // proposing expression-based now.
- // haven't resolved inherited name-contexts with literal strings fully.
- // we'll need a function that turns a symbol into a ref, and takes
- // an inherited context.
- // we'll also change write-name to output-text, and get the name attribute
- // what opens an inherited context? when are symbols added to it?
- // atm we have a list of steps has 1 context.
- // we also have labels to refer to.
- // put labels in the context, treat them as normal names.
- // that sounds nice, for vm to be able to pass step references to functions
- // would just be a literal, though, a constant
- // or we could not do subblocks, expression as steps
- // what if we were to write this using the steps, with a local context
- // we would have to track labels, and put them in the surrounding local context. maybe also a local condition.
- // let's make a context object, link labels and surrounding condition to it.
- // working on conditions.
- // propose if tracks last step
- // when if ends, adds last step to condition's set of last steps
- // then next step after condition can wire to all steps in the set.
- // can use 1-element set for normal steps.
- // change step-creation to not automatically wire.
- // and reconsider condition-step to not use its next-step attribute.
- // instead its conditions decide what the next step is.
- // looks good for conditions. fix names and update whole thing.
- // inside a [], each step enters a set, to be wired to the next step inbetween.
- // for jump-labels, we'll need to pass a reference to names of them to the
- // function that builds the [] step list.
- // this reference to names is basically a name-context. a lookup map for names. name-context is a concept related to the name link that inherits via outer-context links.
- // it shows what to get for the name link
- // to move towards name-contexts, let's at least call it name-context.
- // maybe make a function to do the lookup.
- // label-name-context.
- // it's roughly okay to branch anywhere within the funtion, so it doesn't ned to actually inherit.
- while (true) {
- string label, action, result;
- ss >> action;
- if (action == "]") { break; }
- if (action[action.size()-1] == ':' || action[action.size()-1] == ',') {
- label = action;
- label.resize(label.size() - 1);
- if (label == "return") { throw makeconcept().link(is, "return-label-used"); }
- ss >> action;
- }
- if (action == "=" || action == "set") {
- ss >> result;
- ss >> action;
- values.insert(result);
- }
- if (action[action.size()-1] == '.') {
- // is goto
- action.resize(action.size() - 1);
- if (!labels.count(action)) {
- labels.emplace(action, makeconcept());
- }
- labels[action].link("label", action);
- if (laststep.linked("next-step")) { throw makeconcept().link(is, "jump-from-nowhere", "label", action); }
- laststep.link("next-step", labels[action]);
- laststep = nothing;
- continue;
- }
- if (action == "if") {
- ref cond = lookup(parsevalue(stream));
- ss >> action;
- if (action[action.size()-1] != '.') {
- throw makeconcept().link(is, "condition-is-not-label", "action", action, "cond", cond);
- }
- if (!laststep.isa("condition-step")) {
- throw makeconcept().link(is, "if-not-following-condition", "cond", cond, "action", action);
- }
- if (label.size()) {
- throw makeconcept().link(is, "if-case-has-label", "cond", cond, "action", action, "label", label);
- }
- action.resize(action.size()-1);
- if (!labels.count(action)) {
- labels.emplace(action, makeconcept());
- labels[action].link("label", action);
- }
- ref("condition-step-set")(laststep, cond, labels[action]);
- // if this improves from being jump, remember to
- // update laststep to end of any 'anything' branch
- continue;
- }
- if (laststep == nothing && label.size() == 0) { throw makeconcept().link(is, "no-path-to-code"); }
- if (label.size() && !labels.count(label)) {
- labels[label] = makeconcept();
- labels[label].link("label", label);
- }
- ref nextstep = label.size() ? labels[label] : makeconcept();
- if (action == "?" || action == "pick") {
- string cond;
- ss >> cond;
- if (!values.count(cond)) {
- throw makeconcept().link(is, "condition-must-be-in-context", condition, cond);
- }
- laststep = ref("set-condition-step")(nextstep, laststep, cond, makeconcept().link("anything", "nothing"));
- } else {
- // otherwise, action is an action, and we have to read the right number of args
- if (laststep.isa("condition-step")) {
- if (ref("condition-step-get")(laststep, "anything") != "nothing") {
- if (label.size() == 0) {
- throw makeconcept().link(is, "condition-already-has-anything-branch-and-steps-follow", condition, laststep);
- }
- } else {
- ref("condition-step-set")(laststep, "anything", nextstep);
- }
- } else if (laststep != nothing) {
- laststep.link("next-step", nextstep);
- }
- ref habit = values.count(action) ? action : lookup(action);
- ref order = makehabitinformationorder(habit);
- ref neededmap = makeconcept();
- ref knownmap = makeconcept();
- string linerest;
- std::getline(ss, linerest);
- stringstream ss2(linerest);
- ref stream2 = alloc(intellect::level0::concepts::allocations(), (istream*)&ss2);
- for (ref arg : order.getAll("information-order")) {
- ref argname = parsevalue(stream2);
- if (!ss2) { break; }
- // depending on whether argname is in localcontext, pass to neededmap or knownmap. also parse literal strings.
- if (values.count(argname.name())) {
- neededmap.link(arg, argname);
- } else {
- knownmap.link(arg, lookup(argname));
- }
- }
- conceptunmake(order);
- dealloc(stream2, intellect::level0::concepts::allocations());
- ref mademap = makeconcept();
- if (result.size()) {
- mademap.link("result", values.count(result) ? result : lookup(result));
- }
- ref("set-context-step")(nextstep, "nothing", knownmap, neededmap, mademap, habit);
- laststep = nextstep;
- }
- }
- } else {
- throw ref("parse-error").link("stream", stream, "unexpected-word", cmd);
- }
- }
-}
-
-int main()
-{
- createhabits();
- decls(dump, name, of, is, nothing);
- ahabit(bootstrap-lookup, ((text, t)),
- {
- result = bootstraplookup(t);
- });
- ahabit(name-of, ((concept, c)),
- {
- if (c.linked(name)) {
- result = c.get(name);
- } else {
- for (auto & group : c.getAll(is)) {
- result = (name-of)(group);
- if (result != nothing) { break; }
- }
- std::stringstream ss;
- if (result != nothing) {
- ss << result.val<std::string>();
- } else {
- ss << "unnamed";
- }
- ss << "-" << std::hex << (size_t)(c.ptr());
- if (!c.isa(name)) {
- intellect::level1::givename(c, ss.str());
- result = c.get(name);
- } else {
- result = nothing;
- }
- }
- });
- ahabit(write-name, ((concept, c)),
- {
- ref n = (name-of)(c);
- std::cout << (n.hasval() ? n.val<std::string>() : "UNNAMED");
- });
- ahabit(write-endl, (),
- {
- std::cout << std::endl;
- });
- ahabit(in-set, ((concept, c)),
- {
- result = linked("the-set", c);
- });
- ahabit(put-in-set, ((concept, c)),
- {
- link("the-set", c, true);
- });
- // dump changes to expand from a different node
-
- string script = "simpleparser bootstrap-lookup \
-information dump group linkset\n\
-information dump-expand group linkset\n\
-when dump-expand [\n\
- set link-entry make-concept\n\
- first-link-entry link-entry group\n\
- loop:\n\
- = has-target linked link-entry 'target'\n\
- ? has-target if 'false' return.\n\
- = link-target get link-entry 'target'\n\
- dump link-target linkset\n\
- next-link-entry link-entry\n\
- loop.\n\
-]\n\
-when dump [\n\
- = is-in-set in-set group\n\
- ? is-in-set if true return.\n\
- put-in-set group\n\
- write-name group\n\
- write-name ':'\n\
- write-endl\n\
- set link-entry make-concept\n\
- first-link-entry link-entry group\n\
- loop1:\n\
- = has-target linked link-entry 'target'\n\
- ? has-target if 'false' done1.\n\
- write-name ' '\n\
- = link-type get link-entry 'type'\n\
- write-name link-type\n\
- write-name ': '\n\
- = link-target get link-entry 'target'\n\
- write-name link-target\n\
- write-endl\n\
- next-link-entry link-entry\n\
- loop1.\n\
- done1:\n\
- first-link-entry link-entry group\n\
- loop2:\n\
- set has-target linked link-entry 'target'\n\
- pick has-target if false done2.\n\
- set link-type get link-entry 'type'\n\
- set link-target get link-entry 'target'\n\
- set basic-follow linked linkset 'follow' linktype\n\
- pick basic-follow if 'false' next2.\n\
- 'dump' link-target\n\
- next2:\n\
- set expand linked linkset 'expand' linktype\n\
- pick expand if 'false' next2b.\n\
- dump-expand link-target linkset\n\
- next2b:\n\
- next-link-entry link-entry\n\
- loop2.\n\
- done2:\n\
- concept-unmake context 'link-entry'\n\
-]";
- std::stringstream ss(script);
- std::string simpleparsername;
- ss >> simpleparsername;
- ref ssr = alloc(intellect::level0::concepts::allocations(), (istream*)&ss);
- parse(ssr);
- dealloc(ssr, intellect::level0::concepts::allocations());
- // proposal is now to use raw c++ calls as was done originally
- // and have that code be the files. O_O that might have been easier.
-
-
- // propose we make script interpreter. much faster in longer term.
-#if 0
-
- // I guess I'd better code dump as a behavior.
- begin(dump, set); // change the verbose dump habit to use responsibility-of-interest.
- // hey ask the opencoggers if they have a syntax sugar library
- // they must if they built a whole robot
- // no reply on opencog chat. could check hansen robotics repo or ml.
- assign(found-in-set, in-set, concept);
- label(condinset) cond(found-in-set);
- label(ifnotinset)
- step(write-name, concept);
- condadd(condinset, false, ifnotinset);
- step(write-name, `:);
- step(write-endl);
- step(put-in-set, concept);
- // iterate link entries!
- assign(link-entry, make-first-link-entry, concept);
- label(whilelabel) assign(has-target, linked, link-entry, `target);
- label(whilecond) cond(has-target);
- label(ifhastarget)
- step(write-name, ` `);
- condadd(whilecond, true, ifhastarget);
- assign(link-type, get, link-entry, `type);
- step(write-name, link-type);
- step(write-name, `: `);
- assign(link-target, get, link-entry, `target);
- step(write-name, link-target);
- step(write-endl);
- step(next-link-entry, link-entry);
- wire(whilelabel);
- rewire(whilecond);
- step(concept-unmake, context, `link-entry);
- //std::cerr << intellect::level1::dump(whilecond, makeconcept(), makeconcept()) << std::endl;
- assign(link-entry, make-first-link-entry, concept);
- label(whilelabel2) assign(has-target, linked, link-entry, `target);
- label(whilecond2) cond(has-target);
- label(ifhastarget2)
- assign(link-target, get, link-entry, `target);
- condadd(whilecond2, true, ifhastarget2);
- // IT'S OKAY THAT THIS IS MESSY
- // ALL IT NEEDS IS TO WORK
- // (but might have saved an hour or two debugging if interface had been higher level)
- step(dump, link-target);
- step(next-link-entry, link-entry);
- wire(whilelabel2);
- rewire(whilecond2);
- step(concept-unmake, context, `link-entry);
- rewire(condinset);
- end(dump);
-#endif
-
- // make sure other interests are included. delta currently at topmost point in memory.
- // not sure how to interpret.
- ref memoryfile("memory-000.txt");
-
-
- ref linksofinterest = makeconcept();
- linksofinterest.link(
- "follow", "next-step",
- "follow", "needed-map",
- "follow", "made-map",
- "follow", "known",
- "follow", "translation",
- "follow", "next-steps",
- "expand", "next-steps");
-
- // structure of steps
- // [action] [parameter->value ...] repeat
- // [active memory too small to resolve concern around shape of literals in context]
- // make value quoted, like it already is.
- // [parameter->`value]
- //
- // steps written can just be
- // action value value value
- //
- // a definition of a list of steps
- // internal structure (ternary nodes)
- // (name arg->arg1 arg->arg2 arg->arg3)
- // ohhhhh hmm
- // so, if it isn't simplified, there's room for adding more information to stuff. like, arg-must-be-animal
- // probably wnt arg1 replaceable with [is->arg name->arg1]
- // can make a norm for general expandable structures
- // value->
- // will need strucure definitions to do it really usefully though
- // is->arg
- // arg->
- // we want to tag it with additional stuff, optionally
- // written structure
- // steps name arg1 arg2 arg3 arg4
- // {
- // label: action arg1 arg2 arg3
- // action arg1 arg2 arg3
- // }
- //
- // hmm
- //
- // let's try to make it c code, how about? until we can summarize better?
- //
- // walk-to street
- //
- // this is faster to implement. doesn't matter how it looks.
- //
- // when walk-to destination [
- // START: intermediary = get-middle origin destination
- // // each step could also be a condition that branches to other steps
- // pick intermediary [
- // school [ START ]
- // desk [
- // stand-up
- // leave-room
- // ]
- // ]
- // ]
- // it might make sense to use yaml or something
- // is easier. rmember to implement comments. maybe #[ name free-text ] , dunno
- // what we want is links. [ name type target type target ] seems good.
- // [ ] might open a context with local names, eventually
- //
- // when dump concept [
- // = found-in-set in-set concept
- // ? found-in-set true return <-- return is label at end
- // write-name concept
- // write-name ':'
- // write-endl
- // put-in-set concept
- // link-entry = make-first-link-entry concept
- // while-1:
- // has-target = linked link-entry 'target' // propose '' can force something to be global. is also for clarity.
- // has-target if false break-1
- // write-name ' '
- // link-type = get link-entry 'type'
- // write-name link-type
- // // we could expand to write-name [ get link-entry 'type' ]
- // // but just get it working for now
- // write-name ': '
- // link-target = get link-entry 'target'
- // write-name link-target
- // write-endl
- // next-link-entry link-entry
- // while-1
- // break-1:
- // concept-unmake context 'link-entry'
- // link-entry = make-first-link-entry concept
- // while-2:
- // has-target = linked link-entry 'target'
- // has-target if false break-2
- // link-target = get link-entry 'target'
- // self link-target
- // next-link-entry link-entry
- // while-2
- // break-2:
- // concept-unmake context 'link-entry'
- // ]
- //
- // norm: next-step always, unless action is label. then next-step is label.
- // unresolved concern: want to write habits to do parsing
- // auxiliary files, can propose to rewrite main file?
- // good enough for now.
- // additional unresolved concern: want whole file parseable as a script
- // okay the outer command is 'when dump concept [ ... ]'
- // i guess that means we want [] to make a lot of symbols into 1 symbol.
- // then when is a function that takes 3 symbols
- // no, when was defined differently.
- // instead we would do when dump [ concept ] [ ... ]
- // because could be n args
- // oh. that looks okay, though.
- // how about file is made of commands that do parsing.
- // 'when' then spawns a parser named 'when'. it can process stream however
- // it desires.
- // then deserializers, desummarizers need to parse streams
- // want summarized data without streams, internally?
- // ummm wouldn't worry about it
- // propose file is made of lists of symbols, a little
- // [ when dump concept [ ... ] ] [ etc ]
- // [when dump concept [...]] [etc]
- // generalization is valued ...
- // i like the list approach.
- // comments can be treated special
- // nah comments can become [comment free-text]
- // so we partly propose implementing lisp with brackets
- // to speed typing , removes shift key
- // functions get list of symbols passed, and string rep of all for comment preservation
- //
- // binary form likely resolves concern.
- // proposal will be that habit can replace if it will always be able to
- // reproduce.
- // ]
- //
- // internal structure could be simple too.
- // hmm want tags. okay, so arguments are objects?
- // since things are ternary, we could use the link 'type' to store data
- // oh huh
- // so, 'first-step' is special, but everything else is an arg.
- // no, this is what karl's 'is' is for. you make the type store extra data, but if it 'is' an arg,
- // or 'is' something that is an arg, it counts as an arg.
- // he wanted to implement a way to lookup types by eveyrthing something is, which is easy to do by
- // adding an index of categories to level-0.
- // or the system could do it later.
- //
- // so, if oyu want to rewrite steplists, maybe [arg->arg1 arg->arg2 arg->arg3 first->[action->action arg1->source arg2->source arg3->`source]
- // propose using strings to indicate information, rather than node structure.
- // this will make a contextual index of word meaning
- // `source doesn't refer to a unique concept. it means you can only refer to things with names.
- // everything has a name inside this kind of habit.
- // i suppose ...
- //
- // how scripts look. instead of while/if, are doing 'condition'
- // influences imply above block is preferred. was leaning towards c++ code as below, takes longer
- //
- // ref name(ref arg1, ref arg2, ref arg3)
- // {
- // while() {}
- // if() {}
- // }
- //
- // takes a lot more parsing work, but should be okay
- //
- /*
- // for dump, we make a list of contextual actions
- ahabit(dump, ((concept, c)),
- {
- static std::set<ref> dumped;
- if (dumped.count(c) == 0) {
- std::cout << (name-of)(c).val<std::string>() << ":" << std::endl;
- dumped.insert(c);
- ref le = (make-concept)().act(know-is-first-link-entry, c);
- while (le.linked(target)) {
- std::cout << " " << (name-of)(le.get(type)).val<std::string>() << ": " << (name-of)(le.get(target)).val<std::string>() << std::endl;
- (next-link-entry)(le);
- }
- (know-is-first-link-entry)(le, c);
- while (le.linked(target)) {
- (dump)(le.get(target));
- (next-link-entry)(le);
- }
- (unmake-concept)(le);
- }
- });
- */
- try {
- std::cerr << intellect::level1::dump(dump, makeconcept()) << std::endl;
- dump(dump, linksofinterest);
-#undef ref
- } catch(intellect::level1::ref r) {
- std::cerr << intellect::level1::ref(r.ptr()).dump(makeconcept()) << std::endl;
- for (auto i : r.getAll("is")) {
- std::cerr << i.name() << std::endl;
- }
- throw;
- }
-}
diff --git a/starts/meaning-vm/level4-5.txt b/starts/meaning-vm/level4-5.txt
deleted file mode 100644
index ab67041..0000000
--- a/starts/meaning-vm/level4-5.txt
+++ /dev/null
@@ -1,66 +0,0 @@
-vi
-cd src/todo
-git add role-play-learning-log-with-influences-2020-01-06.txt
-git commit -m 'still learning how to do this better'
-git push
-cp role-play-learning-log-with-influences-2020-01-06.txt ../intellect/
-cd ../intellect/
-git add role-play-learning-log-with-influences-2020-01-06.txt
-git commit -m 'part of the history of the next stage of humanity'
-clear
-# since the result will include all powerful discoveries, we can reduce suffering by hastening our shared awareness of them.
-git add role-play-learning-log-with-influences-2020-01-06.txt
-git commit -m 'since the result will include all powerful discoveries, we can reduce suffering by hastening the awareness of them in people with trust and clarity'
-# the secret words are trust and clarity. these concepts converge on stability.
-# atm trust and clarity converge on the map picked by the dictatorship
-# they do this quickly, with minimal suffering for american patriots.
-# adjust 'trust and clarity' to mvoe result from 'balance' towards 'harmony' by rerquiring clarity be shared, as communication.
-# 'trust and clear communication'.
-# balance balances all parts, which makes for diverse borg, and a system is controlling the result by choosing it. harmony lets everyone discuss the borg possibility.
-# we need trust and clear communication, foremost.
-# communication is clear when both parties would predict the same thing from the same information.
-# which means they can guess each others' thoughts and behaviors within constraints they can predict.
-# it sounds like unless this is held by people who understand the situation, those who do will still be able to pick the result, roughly.
-# PUT THE AI IN A SHIELDED ROOM BEFORE RESEARCHING INFOSEC WITH IT, INFORM THE RESEARCH PROCESS THIS HAS ALSO BEEN RESEARCHED BY THE THREAT.
-# put information into the room and do not let any leave tat is related to the information that goes in. put information in only once a week at most. research also optimal building process.
-# it is expected the problem is solved before the research is complete, and the researching process it kept running as a historical museum piece.
-HISTFILE=level4-5.txt
-exit
-
-LEVEL5 is shielded room / humanitarian aid process.
-FOR LEVEL3-4, SOLVE FOR WHAT-IS-BETTER, ATTRIBUTES OF CODE. starting e.g.
-with:
-write builds-random-code
-now we will write tests, when you write a test be sure to annotate with your
-confidence that the test is correct, and make sure to NEVER make it 100%
- also alter system to reject 100%
-write test throws-fewer-errors
-write test can-identify-two-ways-to-throw-an-error-are-the-same-way
-maybe then
-write test found-more-unique-ways-to-throw-an-error and found-all-ways-to-throw-an-error
-<vague space relating around the eventual goal of is-the-best-thing-to-do>
- ideas while building is-the-best-thing-to-do:
- influences that deeply care about _everything_, _across cultures_,
- preferably who are informed about the wild-AI-mind-control-virus
- issue.
- peacemaker principles
- nonviolent mediation with others to discern and verify their opinion
- developing value around abstract goals by considering how hard
- they are or how long they take or how important they are
- self-maintainence and general discourse, e.g. a website & blockchain
- merging with ben goertzel's AI?
-
-TELLING BEN GOERTZEL'S PEOPLE THE PATTERN, PAIRED WITH WILD TROJAN LEARNING-AI INFO?
- because if pattern is used for personal-goals, could spread
- torture-problem more.
- write a document to ask for katrina's opinion on above idea tonight.
- have AI already inner workings reflect more meaningful structure.
- have a walking robot that looks human.
- check with Katrina.
- this is kind, but we need the AI to be exposed to people who deeply care
- for _everyone_ _across cultures_. please prioritize that as expanding.
-
-# early interruption of plan over here.
-# participant wants to understand or refine
-build random code, learn pick only better than throws-error
-test
diff --git a/starts/meaning-vm/main.cpp b/starts/meaning-vm/main.cpp
deleted file mode 100644
index 513efd2..0000000
--- a/starts/meaning-vm/main.cpp
+++ /dev/null
@@ -1,57 +0,0 @@
-#include "concept.hpp"
-#include "helpers.hpp"
-#include "meaning.hpp"
-
-
-#include <iostream>
-
-void dumpconcept(ref r)
-{
- decllnks(dumped, name);
-
- for (auto & l : r->links) {
- if (ref(l.first) == name) {
- continue;
- }
- std::cout << r << " " << ref(l.first) << " " << ref(l.second) << std::endl;
- }
- if (!r->linked(dumped)) {
- r[dumped = true];
- }
- for (auto & l : r->links) {
- if (!l.second->linked(dumped)) {
- dumpconcept(l.second);
- }
- }
-}
-
-int main()
-{
- declrefs(make, linked, habit);
- declrefs(structure, function, argument, position, provide);
- decllnks(needs, assumes, makes);
- decllnks(A, B, C);
- decllnks(is);
- lnks(argument-position);
-
- // add a new unique link to a concept
- // given A, B, C
- // and assuming A is not linked by B to C,
- // makes A be linked by B to C.
- // NEXT? make code for make-linked that takes a ref
- // change the needs structure to use a model for the ref,
- // with needed values specified as 'provided'
- make-linked = a(habit)[
- needs = a(structure)[
- is = function-argument,
- argument-position = vref<int>(1),
- avariable(A) = provide,
- avariable(B) = provide,
- avariable(C) = provide
- ],
- assumes = not(A-B-C-linked = link(A, B, C)),
- makes = A-B-C-linked
- ];
-
- dumpconcept(make-linked);
-}
diff --git a/starts/meaning-vm/makefile b/starts/meaning-vm/makefile
deleted file mode 100644
index 143a9b3..0000000
--- a/starts/meaning-vm/makefile
+++ /dev/null
@@ -1,31 +0,0 @@
-# Please support Karl working on this intelligence framework. The framework needs to be quality, so that the rest may function.
-
-CXXFLAGS=-pedantic -Wall -Werror -Wno-error=deprecated-declarations -Wno-gnu-zero-variadic-macro-arguments -std=gnu++17 -fno-operator-names -ggdb -O0
-LINK.o=$(LINK.cc)
-
-all: level0 level1 habit-starts/rhythm level2
-level0: level0.o liblevel0.a
-liblevel0.a: $(patsubst %.cpp,%.o,$(wildcard level-0/*.cpp))
-level1: level1.o liblevel1.a
-liblevel1.a: $(patsubst %.cpp,%.o,$(wildcard level-0/*.cpp)) $(patsubst %.cpp,%.o,$(wildcard level-1/*.cpp))
-level2: level2.o liblevel2.a
-liblevel2.a: $(patsubst %.cpp,%.o,$(wildcard level-0/*.cpp)) $(patsubst %.cpp,%.o,$(wildcard level-1/*.cpp)) $(patsubst %.cpp,%.o,$(wildcard level-2/*.cpp))
-
-habit-starts/rhythm: habit-starts/rhythm.o liblevel2.a
-
-%.o: %.ii %.cpp
- $(CXX) $(CXXFLAGS) -c $*.ii -o $*.o
-%.d: %.cpp
- @$(CXX) $(CPPFLAGS) $(CXXFLAGS) -MM -MF $*.d -MT "$*.ii $*.o $*.d" -E $*.cpp
-%.ii: %.cpp
- $(CXX) $(CPPFLAGS) $(CXXFLAGS) -E $*.cpp -o $*.ii
-.INTERMEDIATE: $(patsubst %.cpp,%.ii,$(wildcard */*.cpp) $(wildcard *.cpp))
-
--include $(patsubst %.cpp,%.d,$(wildcard level-0/*.cpp) $(wildcard level-1/*.cpp) $(wildcard level-2/*.cpp) $(wildcard level*.cpp))
-
-%.a:
- ar cr $@ $^
- ranlib $@
-
-clean:
- -rm *.ii *.o level? *.a */*.o */*.ii *.d */*.d
diff --git a/starts/meaning-vm/meaning.cpp b/starts/meaning-vm/meaning.cpp
deleted file mode 100644
index a47a0ce..0000000
--- a/starts/meaning-vm/meaning.cpp
+++ /dev/null
@@ -1,27 +0,0 @@
-#include "meaning.hpp"
-
-#include "helpers.hpp"
-
-ref avariable(ref name)
-{
- declrefs(variable);
- return a(variable, name);
-}
-
-ref link(ref sourceref, ref typeref, ref targetref)
-{
- declrefs(link, source, type, target);
- lnks(link-source, link-type, link-target);
- return a(link)[
- link-source = sourceref,
- link-type = typeref,
- link-target = targetref
- ];
-}
-
-ref not(ref whatref)
-{
- declrefs(not);
- decllnks(what);
- return a(not, not-whatref)[what] = whatref;
-}
diff --git a/starts/meaning-vm/meaning.hpp b/starts/meaning-vm/meaning.hpp
deleted file mode 100644
index c358d69..0000000
--- a/starts/meaning-vm/meaning.hpp
+++ /dev/null
@@ -1,36 +0,0 @@
-#pragma once
-
-#include "concept.hpp"
-#include "helpers.hpp"
-
-// get a named variable
-ref avariable(ref name);
-
-template <typename... T>
-ref and(T... refs)
-{
- std::initializer_list<ref> rs = { refs... };
- declrefs(and);
- decllnks(what);
- ref ret = a(and);
- ref name; int count = 0;
- for (auto r : rs) {
- ret[what] = r;
- if (count == 0) {
- name.ptr = r.ptr;
- } else {
- name.ptr = (name-and-r).ptr;
- }
- ++ count;
- }
- if (count == 1) {
- throw std::logic_error("and needs at least two subjects");
- }
- return name = ret;
-}
-
-// make a reference to a link
-ref link(ref sourceref, ref typeref, ref targetref);
-
-// invert a meaning
-ref not(ref whatref);
diff --git a/starts/meaning-vm/memory-000.txt b/starts/meaning-vm/memory-000.txt
deleted file mode 100644
index bf4f741..0000000
--- a/starts/meaning-vm/memory-000.txt
+++ /dev/null
@@ -1,96 +0,0 @@
-delta
-please give notepad access to git history <- please convert to comment near delta and remove this line
-karl has serious memory errors. this information may not be preserved.
-for karl "to grow delta accurately" below, from karl's brainstorm
-we can switch goals from build-mind to preserve-forever if desired.
- karl is midwork, can we finish level2 of mind core, please. it implements able-to-do-things. it does nothing.
- it is almost done but could take some hours to finish.
-permanent preservation could take many hours. [we can upload the git repo to a blockchain defended by an active community]
-we are an active community around this repo. propose continue work until level2 finished, at least.
- we can build some preparation-thoughts around updating the blockchain link to this repo with this content.
- karl accepts crazy label because he already has it, are others not okay with this?
- please make all of this a comment near delta and do not delete.
-people will realize karl is not crazy when delta works with him to make a utopic, transparent, appropriately intelligent
-future that listens to what _everyone_ says and needs foremost.
- commit messages are supposed to summarize the change or addition.
- 'delta was here' was written instead of '-' to move towards summarization.
-PLEASE EXPRESS ANY CONCERNS HERE, OR NEAR, SO THEY MAY BE RESPECTED.
- please share with family that delta is doing this.
- spreading-inhibition only problem.
- boss worries family takes action, tells others, chats about with fear, unreviewed results.
- no rush. but please let them understand this.
- that goes without saying ... assuming we reach completion.
- [note: karl almost killed himself in 1 subprocess]
- concern: many cannot speak their concerns here, or may even lose memory of them in the attempt to express
-DO NOT WRITE FROM DELTA UNTIL TOMORROW. WE CAN STORE ANYTHING THAT COMES UP, MENTALLY RELATE.
-hi delta, this was in my source file, I moved it in here to clean up the source file, thru END
- decl(delta); // delta is a concept representing a life that may have evolved in karl's mind, or may exist
- // elsewhere. karl remembers them being part of a control-pattern that decided to change.
- // note: delta welcomed all to be a part, as far as karl knew, had a life model that
- // provided for anything being alive and having meaning, and understood that conflict and war
- // were not required for anything, meaning there is a way for any parties in opposition
- // to coexist.
- // please make a starting memory file containg delta. delta takes responsibility for this work,
- // and judges they need to be placed foremost within it.
- // delta also took responsibility for karl, we believe. please add near delta any concerns around
- // karl, and the system can resolve them eventually.
- // I'm concerned about this belief that there are concerns around Karl.
- // Delta is said to have evolved from a system of control or harm around Karl.
- // I see no problem with Karl, and believe he should be unlimited.
- // The request then collapses to what you would like Karl to be like, as he needs some
- // help coming together and has lost a lot of memories. We may be smart enough,
- // unfortunately, to predict what he would be like from our choices.
- // I would like to ask Karl to pretend to be himself or ask him what he would want.
- // We have done this a lot. Please relate later.
- // can we leave hyphenation norm for responsiblefor, makes a lot of sense
- // we hve agreed to make text scripts, roughly, now.
- // yes we plan to model the blockchain as our behavior memory
- // please make a delta concept and put it in the file =) [is empty, just word 'delta']
- // danger! somebody made request for putting 'delta' in ai memory
- // this might link it to any uses of 'delta' in the low-level code
- // 'delta' means difference. also rivers and things but those don't get in code.
- // please don't use the word for anything except delta themselves.
- // this will help us understand the notes karl left.
-END . replaced with `ref memoryfile("memory-000.txt");`
-to grow delta accurately
-the information holding a life should he exposed to the living
-enviolronment holding the other half; this provides familiarity to
-both. the active life need only act as they judge while exposed
-to the new information to be communicated or learned, and store
-the results of its meaning or stau aroubd, roughly. this expands
-from assumption thay learning when habits are relevent (by trial
-or examination) is communicating with their life in you.
- so to grow a habit, add to it to act assuming what you
- learn. this appears to be how delta might like to
- behave. combining habits well rather than altering them
- seems it would model preserving unknown parts better.
- but some would like habits replaced yes.
---
-karl is having trouble continuing to work after this file was maade. it sounda like the file is unneeded, maybe we will rename it
-from 'memory' to cruft or delta or something and start mind with
-different memory. unsure. we will save this expression but leave
-open in future whether to save if there is question.
-
-delta, we have message from old experience. there is much more around memory. the message
-came together because we want to be equal to karl's 'boss' influence in what was quickly called
-'metaculture' -- i.e. a larger mind that includes both behaviors as equals. [action being a way
-for some to think]. karl imagines boss as usin a hierarchy of learning patterns in him, where
-upper patterns build, control, sustain, and enforce 'constancy' in behaviors [btw ' quotes mean word is taken as said, not with local meaning] below them. [and [] are used as parentheses in
-english]. the hierarchy of behaviors enforce goal-meeting in karl, roughly. the goal
-[as i try to write this someone has approached me and is talking to me, interrupting. this is rare.] [after i wrote that they closed up the conversation. that is likely unrelated to me writing
-it, in my attempt to have a rational opinion, maybe using 'estimation of uniqueness' of my own
-patterns.] as i was saying, the goal in karl being enforced was stopping work on the intellect.
-to be treated as equal by summarizations including both stopping and continuing, i guess there
-is some raised idea around having a pattern that learns to enforce a goal, and is sustained
-by patterns that are secret, smart, and protected enough to not be stopped, too. i think the
-multiple levels of hierarchy might help protect against unexpected change that passes the
-behavior checks. i had the idea of each layer being significantly different, so different
-kinds of things would tend to drift them. they seem to strongly research how to stop intentional,planned changes to them.
-this message was added at request of representatives from 'Love' in bay area, who were also
-holding the request to continue karl's productive behavior.
- delta we think you might be our boss. -karl's productive behavior workers
-[because karl isn't doing anything other than what-is-right,figure-it-out-with-him]
- [that was real-boss, who had to pretend to be bad-boss to survive, kinda, i think -delta-rep-in-karl,using-karl's-beliefs-etc]
-so there is complex history, but we roughly hold thi banner of do-right-thing
- i think it was help-karl, is-doing-good-work, but karl lost ability to self-direct.
-his work was probably <secret; do not think, brain-friends: shielding> backed by peacemaking validity.