Modelling a Mind
Coming up with a functional model of consciousness has been, and still is, a very hard and elusive task. The difficult part is dealing with the "hard problem of consciousness" which is about explaining the existence of qualia - e.g. the experience of hearing the birds chirping, the feeling of joy, the association between a beautiful sunny day and pleasure. To me it is obvious that, in order to seriously tackle the problem of understanding how human experience works, we need to come up with proper technical terms and ideas that describe these phenomena in an objective manner. This would trivialize the concept of human experience but I feel that it's a necessary step. Ultimately, as soon as you break down the jigsaw puzzle into its smallest parts, it loses its magical wonder at the expense of a huge increase in our understanding. We are trivialization machines.
I've had my mind set for some time now on creating a simple RL agent having an architecture inspired by that of the human mind. I want to test whether with such an architecture the agent will be able to learn at all, and if yes, how will it perform compared to other more established approaches.
Importantly, at this stage I've purposefully left language completely out of the picture. Language is basically an encoding of concepts with the purpose of getting your message across to the other person. I think it's safe to say that although it's language that helps in demonstrating our consciousness, language itself does not make us conscious. Therefore, it makes sense to ask "What does a conscious agent which cannot talk look like?". In other words, the point of building a simple conscious agent is not to solve the Turing test from the first try, but rather to test whether it works at all.
Figure 1 above is an initial draft of the architecture. It consist of various predictors each with its own purpose.
-
One type of inputs to the mind of the agent are the sensory signals from the outside world. The signals coming from the outside world are, in the case of humans, what we see, hear, and smell. They contain patterns from the environment in which the body of the agent exists. In the case of Atari agents, the sensory inputs would be the image frames. In the case of robots they would be various readings from LIDARs, heat sensors, and cameras.
-
A second type of inputs is any quantity of interest that comes from the body of the agent, not the environment surrounding it. With humans, this would be any physiological or psycological need or desire - e.g. hunger, thirst, and the need for social approval. These are generated by the body of the agent - which is a proper dynamic system with complex interactions and feedback loops between its components. For example, the feeling of hunger can be thought of as an alarm signal resulting from the various feedback loops in the human's digestive system. This alarm signal then becomes an input to the mind of the agent where it is processed.
-
An input processor is a function which takes in the large noisy streams of sensory information and processes them, producing low-dimensional latent representations of the sensory input. With humans this function would loosely correspond to the vastly distributed central nervous system which processes the electric signals coming from all over the body.
-
A concept buffer stores the mental representations of the important objects, ideas, phenomena that a person encounters throughout their life. The concept buffer is continuously updated as one learns more skills and concepts. Importantly, it could also store the concept of the of the self - a person who looks like you and behaves like you. The concept buffer is also linked to the language. Every concept in the buffer, apart from its learned mental representation, can have a label associated with it, which is a word used to refer to that concept. E.g. "dog" refers to the concept of an animal that barks, while "me" or "I" refers to the mental concept of a person who behaves like me and looks like me. Most probably there is no difference between recursive and non-recursive labels.
-
An attention model is responsible for what we perceive in any given point in time. If you are like me, you constantly have thoughts in your head, whether they are memories, imagined future scenarios, or just objects from your surroundings. The attention model is what drives the thoughts in your head and is most closely associated with consciousness and wakefulness. It attends over the concepts you have amassed, the current state from the processed inputs, and possibly even itself. The feeling of consciousness could be described as the memory of the last concept/pattern that the attention model attended.
-
A dynamics predictor is a function that learns the dynamics of the environment, It leans to predict the next state and to simulate state trajectories (what we call imagination or memories), irrespective of whether the agent has taken any meaningful action in the current time or not. Various emotional states like surprise, curiosity, and fear result from here, which can become drivers of the agent's decisions later on.
-
A policy is an abstract component mapping the current state of the surroundings into actions - electrical signals that trigger muscle responses. This is the standard RL action-selection function.
Based on all of these components, a simplified control loop for the mind is:
- Process the sensory inputs, recognize any known patterns;
- Propose new patterns for storing as concepts;
- Integrate the proposals into the concept buffer, removing or updating other concepts if necessary;
- Predict the next state based on hypothetical actions (imagination)
- Focus attention on sensory inputs or known concepts.
- Produce an action.
Note that with just a processor and a policy, you get a primitive reptilian brain based on instincts. By adding a dynamics predictor and the difference between the current state and its expectation, you get a limbic brain. Finally, with the addition of concepts and attention you get a neocortex, capable of reasoning.
Regarding the practical implementation of this mind, I think the processor, dynamics predictor, and policy can be built using artificial neural networks. The attention model can be an attention layer. The concept buffer is tricky because it would involve having a storage component for patterns (e.g. vectors) that is updated in a learnable way and is outside of the networks. Perhaps a stateful component that is continuously updated can be used.
It might be necessary that all components are capable of handling time-series. In that case, a deep learning approach will require LSTMs, GRUs, or temporal transformers. It is also likely that the agent should have a model-based mind that can plan ahead and choose its actions accordingly.
Ultimately, this mental architecture will require compromises when it comes to implementation. Nonetheless, I will try to build it as closely as possible to the idea here. I'm sure it's performance will yield a lot of precious insights and intuition after that.