Skip to content

Commit 24eb055

Browse files
update
1 parent c03d84f commit 24eb055

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

58 files changed

+5385
-12
lines changed

2023/10/30/pgvector

Submodule pgvector updated 147 files

2024/02/11/donjon

Submodule donjon updated 1 file

2024/09/06/vscode

Submodule vscode deleted from 48dde95

2024/10/16/next-mdx-deck-o1js-perf

2024/11/09/notes.org

+8
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,8 @@
1+
2+
self as a quotient space of the universe.
3+
Self S/~ (universe U)
4+
5+
Self/~ as a filter function of the universe.
6+
7+
quasi-quotation as a quasi - quotient as quasi-poly-morphism with different labeled factors, roots or indivisible parts which are a parameterized
8+
to construct an object

2024/11/12/notes.org

+60
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,60 @@
1+
artificial superintelligence
2+
ai agents
3+
hyperon netamoto
4+
filecoin
5+
frameworks
6+
methods
7+
agi term
8+
research papers
9+
probablistic logical networks
10+
neurosymbolic ai
11+
12+
* giza
13+
decentralized infrastucture
14+
defi
15+
zkml models
16+
decisions
17+
risk
18+
market conditions
19+
trades
20+
yields
21+
22+
trust assumptions
23+
verifiability
24+
ai agents
25+
proof of reputation
26+
attestations
27+
28+
mpc multi party computation
29+
deploy ml models and zkapps
30+
apps like rendering, ml
31+
scalable, because you dont need to replicate computation with zkml
32+
hide some of the data.
33+
scaling.
34+
submodules.
35+
privacy.
36+
verification.
37+
38+
Fran Algaba, 13:42
39+
40+
Sebastian Rod
41+
trust triangle
42+
agent may say things about itself, yourself,
43+
someone else says something about you,
44+
digital trust, organization, other users.
45+
Identifiable agent.
46+
ai ml applications will need attestations, on chain , zkp, reputation base on agents
47+
agents need to identify themselves. stable agent. give agent identifier.
48+
only for that agent.
49+
50+
maintain a proof or trust over time.
51+
show me your id. verify id.
52+
chain of assumptions or trust.
53+
did the model change, training data.
54+
55+
context:
56+
landscape of decentralized ai.
57+
what is zkml.
58+
59+
alex balgirev.
60+
hosting the model on the nodes.

2024/11/20/notes.org

+18
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,18 @@
1+
plan:
2+
dont write new code:
3+
search for open source (on github and in a local cache) projects to integrate
4+
read and understand them,
5+
index them, maybe vectorize them.
6+
Assume that all data can be expressed in a lisp like syntax.
7+
We assume that the prelude of the system looks something like this :
8+
Evaluate and learn from the world around you from the following input:
9+
Create an interactive typescript code that can generate and eval code
10+
and produce structured errors, like an lsp feedback system.
11+
so now we can generate valid syntax. we can see that the semantics
12+
are in tests or proofs.
13+
We can demonstrate the code is correct as a formal proof even.
14+
so we want to generate a proof and code to execute that proves it. a self carrying proof.
15+
we can imagine it as a type schema like (share(model(learn(introspect(act(decide(orient(observe(input x)))))))))
16+
17+
18+

2024/11/21/imml.1.org

+55
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,55 @@
1+
*** Intermediate Meta-Languages (IMMLs)
2+
3+
*Intermediate Meta-Languages (IMMLs)* are languages that bridge the gap between high-level,
4+
declarative programming languages and low-level, executable code. They offer a higher level of
5+
abstraction than traditional intermediate languages like LLVM IR or bytecode but still remain
6+
closer to the target execution environment than fully abstract meta-languages.
7+
8+
*** Research Existing Meta-Languages
9+
10+
1. *PPL (Programmable Programming Language)*:
11+
- *Overview*: PPL is designed to enable programmers to write programs that can be executed and
12+
modified dynamically.
13+
- *Proximity to Executable Code*: PPL is closer to executable code than fully abstract languages
14+
because it allows for direct manipulation of the program's execution state. However, it is
15+
still a higher-level language compared to low-level IRs.
16+
17+
2. *APL (Array Processing Language)*:
18+
- *Overview*: APL was designed for mathematical and logical array processing and is known for its
19+
unique syntax and high-level nature.
20+
- *Proximity to Executable Code*: APL is more abstract than fully executable languages but still
21+
operates on arrays, which are a common data structure in many programs. It can be compiled
22+
into low-level code but is not as direct as PPL or MetaOCaml.
23+
24+
3. *MetaOCaml (a dialect of OCaml)*:
25+
- *Overview*: MetaOCaml allows for the creation of programs that manipulate other programs as
26+
data. It extends OCaml with features such as quotation, splicing, and first-class
27+
continuations.
28+
- *Proximity to Executable Code*: MetaOCaml is closer to executable code than fully abstract
29+
languages because it enables dynamic manipulation of program structures. However, it is still
30+
a higher-level language compared to low-level IRs.
31+
32+
*** Determining IMMLs
33+
34+
Based on the research, the following languages can serve as Intermediate Meta-Languages (IMMLs):
35+
36+
1. *MetaOCaml*:
37+
- *Reason*: MetaOCaml extends OCaml with powerful features for manipulating programs as data,
38+
making it closer to executable code than fully abstract languages while still offering a
39+
higher level of abstraction compared to traditional intermediate languages.
40+
41+
2. *PPL*:
42+
- *Reason*: PPL allows dynamic manipulation of the program's execution state, making it suitable
43+
for creating IMMLs that are both powerful and close to executable code.
44+
45+
3. *APL*:
46+
- *Reason*: While more abstract than fully executable languages, APL operates on arrays, a common
47+
data structure in many programs, and can be compiled into low-level code. It provides a high
48+
level of abstraction but remains closer to executable code than other fully abstract
49+
languages.
50+
51+
*** Conclusion
52+
53+
MetaOCaml is particularly well-suited for creating Intermediate Meta-Languages due to its ability to
54+
manipulate program structures dynamically. However, PPL and APL also have their merits in serving as
55+
IMMLs based on their proximity to executable code and the specific needs of the application domain.

2024/11/21/imml.2.org

+123
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,123 @@
1+
The detailed step-by-step plan you've outlined is an excellent framework for systematically proving
2+
a goal using multiple iterative rewrites and various languages. Here's how it breaks down:
3+
4+
*** 1. Define Intermediate Meta-Languages (IMMLs)
5+
*Task:* Identify and define the intermediate meta-languages that are closer to executable code than
6+
the original document.
7+
- *Language:* Python, Haskell, OCaml
8+
- *Steps:*
9+
- Research existing meta-languages such as PPL (Programmable Programming Language), APL (Array
10+
Processing Language), or MetaOCaml (a dialect of OCaml).
11+
- Determine which languages can serve as IMMLs based on their proximity to executable code.
12+
13+
*** 2. Rewrite the Document Using Different LLMs
14+
*Task:* Write a script that feeds the document to different LLMs and increments the stack for each
15+
iteration, resulting in new versions of the document in each IMML.
16+
- *Language:* Python with ~llama~
17+
- *Steps:*
18+
- Implement a loop to iterate N times.
19+
- In each iteration, use a different LLM (e.g., OpenAI's GPT-3, Hugging Face's Transformers) to
20+
rewrite the document.
21+
- Increment the stack by appending new layers or annotations.
22+
23+
*** 3. Use Coq and MetaCoQ to Prove Properties
24+
*Task:* Apply formal verification techniques using Coq and MetaCoQ to prove properties of each
25+
version and their relations to previous ones.
26+
- *Language:* Coq, Haskell, OCaml
27+
- *Steps:*
28+
- Write Coq theories for each intermediate version.
29+
- Extract proofs into Haskell and OCaml code.
30+
- Use quickcheck to validate the properties.
31+
32+
*** 4. Compile and Lift Code Using Template Haskell and Ppx
33+
*Task:* Use Template Haskell and OCaml Ppx to compile and lift the latest version of the document
34+
into executable code in CakeML or a similar language.
35+
- *Language:* Template Haskell, OCaml Ppx, CakeML
36+
- *Steps:*
37+
- Write Template Haskell code to generate CakeML syntax.
38+
- Use OCaml Ppx to optimize and annotate the code.
39+
- Compile the code using CakeML compiler.
40+
41+
*** 5. Test the Compiled Code
42+
*Task:* Automate testing of the compiled code using quickcheck and other tools, ensuring correctness
43+
and functional equivalence to the original document.
44+
- *Language:* Python with ~quickcheck~
45+
- *Steps:*
46+
- Write test cases that validate the functionality of the compiled code.
47+
- Run tests in an automated environment.
48+
49+
*** 6. Load Hex Codes into MES Hex Loader
50+
*Task:* Load the hex codes generated from the compiled CakeML into the mes hex loader as an
51+
assembler and execute them, same for wasm and even llvm.
52+
- *Language:* Bash, Mes, GCC, LLVM
53+
- *Steps:*
54+
- Convert the hex codes to a format suitable for mes loader.
55+
- Assemble the code using GCC.
56+
- Execute the code in the mes hex loader.
57+
58+
*** 7. Manage Packages and Dependencies
59+
*Task:* Use github, Rust crates, and Guix to manage packages and dependencies, ensuring
60+
reproducibility and stability across platforms.
61+
- *Language:* Bash, Rust, Guix
62+
- *Steps:*
63+
- Create a ~guix~ manifest file for project dependencies.
64+
- Install necessary packages using guix package manager.
65+
- Automate dependency management with scripts.
66+
67+
*** 8. Integrate Emacs and the Ellama Package
68+
*Task:* Integrate Emacs and the ellama package for communicating with LLMs and automating code
69+
review tasks.
70+
- *Language:* Emacs Lisp, Python
71+
- *Steps:*
72+
- Write Emacs Lisp functions to interact with the ellama package.
73+
- Implement Emacs key bindings for automated code review.
74+
- Test the integration in an Emacs environment.
75+
76+
*** 9. Compile Final Code Using GCC and Linux
77+
*Task:* Use GCC and Linux for compiling and executing the final code, taking advantage of their
78+
optimizations and features.
79+
- *Language:* Bash, GCC, Python
80+
- *Steps:*
81+
- Write a script to compile the final code using GCC.
82+
- Run the compiled executable on the Linux system.
83+
- Ensure compatibility across different hardware configurations.
84+
85+
*** 10. Trace Executions and Construct Zero Knowledge Proof
86+
*Task:* Trace the executions of the code and construct zero knowledge proofs that summarize the
87+
execution succinctly.
88+
- *Language:* Python, ZKP libraries
89+
- *Steps:*
90+
- Write scripts to trace and record code execution.
91+
- Use ZKP libraries to generate zero knowledge proofs for each execution.
92+
93+
*** 11. Document Each Step and Version
94+
*Task:* Document each step, tool, and version using org babel for easy reference and collaboration.
95+
- *Language:* Org Mode
96+
- *Steps:*
97+
- Write detailed documentation for each step of the process.
98+
- Use org babel to create versioned notes and results.
99+
- Share documentation with team members.
100+
101+
*** 12. Continuously Refine and Improve the Process
102+
*Task:* Continuously refine and improve the process based on feedback, data, and insights from users
103+
and experts in AI, programming, and linguistics.
104+
- *Language:* Python, Jupyter Notebook
105+
- *Steps:*
106+
- Conduct regular reviews of the process.
107+
- Gather feedback from users and experts.
108+
- Use data to identify areas for improvement.
109+
- Implement changes to enhance efficiency and effectiveness.
110+
111+
*** 13. Split Larger Task into Smaller Tasks
112+
*Task:* Split the larger task into smaller tasks that require less context because this one it
113+
getting too big.
114+
- *Language:* Python
115+
- *Steps:*
116+
- Analyze the current task and identify sub-tasks.
117+
- Define clear goals for each sub-task.
118+
- Allocate resources and timelines for each sub-task.
119+
120+
This structured approach ensures a systematic process from defining intermediate languages to final
121+
execution, with formal verification, testing, and documentation at every step.
122+
123+
---

0 commit comments

Comments
 (0)