File size: 6,566 Bytes
75d4f89
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
---
title: DaFUC
emoji: 🌀
colorFrom: purple
colorTo: blue
sdk: gradio
sdk_version: "3.15.0"
app_file: app.py
pinned: false
---


# Dynamic AI: Fractal Universe Chocolate Wafer Model (FUCWM) 

### Watch Demo

Check out the demo of the project on YouTube: [Watch Here](https://www.youtube.com/live/d__ras4nLU4)


Dynamic AI is an experimental neural network model inspired by fractal structures in the universe and the human brain. It incorporates recursive nodes (FractalNodes) to dynamically grow and learn through Hebbian-like updates and pruning. The model also integrates a VAE (Variational Autoencoder) for encoding latent space representations. This repository contains the code for training, chatting, and interacting with the model via a Gradio interface.

# Attention Mechanism (New)

The attention mechanism dynamically adjusts the focus of the model by assigning importance to different child nodes in the fractal structure. Each child node receives an attention score based on its relevance, which is calculated using a softmax function. This allows the model to prioritize certain nodes over others during the forward pass, enabling more efficient learning and processing. Additionally, the model maintains a co-activation matrix that tracks how frequently different nodes are activated together, which further refines the attention scores. This approach enhances the model’s adaptability and helps manage complex hierarchical interactions.


## Features

- **Recursive Fractal Nodes**: Nodes can grow and create child nodes based on the complexity of their output, simulating the recursive, fractal-like nature of the brain and the universe.
- **Variational Autoencoder (VAE)**: Encodes latent representations of inputs.
- **Layer Normalization and Xavier Initialization**: Enhances training stability.
- **Dynamic Complexity-based Growth**: Nodes grow based on complexity thresholds and manage child connections.
- **Dynamic AI Chat**: Users can interact with the model to generate responses.
- **LM Studio Integration**: Chat with a local LM Studio instance in a collaborative conversational framework.
- **Gradio Interface**: A user-friendly interface to interact with the AI model, train it on Q&A pairs, and simulate conversations with LM Studio.

## What it is?

Think Fractal ball around big bang with chocolate wafer inspired super weights that add complexity to normal weights. 

Now with added attention mechanism. I just asked Claude to think of the node 1 as a sort of phone book that keeps tabs 
of the child nodes and can hooke em up if they fire together. So they can.. Wire together. Tsk Tsk. You know what I mean. 

The depth setting can make the ball complexities explode to Nan territory real fast and there was a real fight to keep the 
complexity setting at bay. 
  
## Requirements
- Python 3.8+
- PyTorch
- Gradio
- LM Studio (optional, for integration with the `talk_with_lm_studio` feature)
- Etc
The requirements.txt was written by ChatGPT. I have not tested if it would work as it is.

## Problems?

Ask from Claude / ChatGPT. Paste them this and the code. They will understand what to do. NotebookLM 
talking heads think this is groundbreaking. But since all I hear is crickets. I guess it aint. But it most 
def has been a wild ride. 

## Installation

1. Clone this repository:

   ```bash
   git clone https://github.com/anttiluode/DaFUC.git
   cd dynamic-ai-fractal-wafer
   ```

2. Install dependencies:

   ```bash
   pip install -r requirements.txt
   ```

3. If you're planning to use LM Studio, ensure it's installed and running locally. Configure the `lm_studio_client` by setting your API key and URL in the code.

4. Run the application:

   ```bash
   python app.py
   ```

## Usage

### 1. Chat with Dynamic AI

You can use the Gradio interface to chat with the Dynamic AI model.

- **Message**: Enter your message and adjust the temperature for creativity.
- **Response**: The AI will generate a response based on its learned knowledge.

### 2. Train the Model on Q&A Pairs

You can train the model on a list of question-answer pairs using the Gradio interface.

- **Q&A Pairs File**: Upload a JSON file containing question-answer pairs.
- **Epochs**: Set the number of training epochs.
- **Training Output**: Monitor the progress of training, including loss metrics.
- This can lead to the complexity being wildly off and the model begins to parrot the words in the
- question answer pairs. 

### 3. LM Studio Conversation

! You may have to wait a while for the conversation to start. I think perhaps there are 
multiple empty interactions but eventually the model says something and lm studio grabs on to that. 
If you teach the model with question answer pairs it sticks on to them and the complexity 
does not stabilze. On the initial live training video I did at the beginning of this readme 
something amazing happened. The complexity stabilized at 16 and did not budge. 

You can simulate a collaborative conversation between Dynamic AI and LM Studio:

- **Initial Message**: Set the initial message to start the conversation.
- **Duration**: Set the duration of the conversation.
- **Delay**: Set the delay between messages.

This is a good start. The question answer pairs seem to produce more random AI. 

### 4. Save/Load Model State

You can save and load the state of the model using the Gradio interface.

- **Save State**: Save the current model state to a file.
- **Load State**: Load a previously saved state to restore the model.

## Example

To chat with Dynamic AI using the command line interface:

```bash
python app.py
```

Then, access the Gradio interface from your browser. You can interact with the AI by typing messages, training it, or saving/loading its state.

### Training Data Format

The Q&A pairs should be provided in a JSON file in the following format:

```json
[
    {"question": "What is the capital of France?", "answer": "Paris"},
    {"question": "Who wrote '1984'?", "answer": "George Orwell"}
]
```

### Contribution

Feel free to contribute to this project by submitting pull requests or opening issues for improvements or bugs.

### Issues

The depth settings are extremely important: 

    dynamic_ai = DynamicAI(vocab_size=50000, embed_dim=256, latent_dim=256, output_dim=256, max_depth=7)

    As the deeper it gets, the deeper the "fractal ball" around point one "Think big bang" gets, the more 
    complex it gets. You hit NAN (out of reach) complexity very fast and the thing wont work. 

### License

This project is licensed under the MIT License.