Some useful useless stuff
Cléber Zavadniak
2022
Cléber Zavadniak
- ~1999: "Apostila de C"
- 2004: Computing Science (incomplete)
- 2004: C(microcontrollers) / C++
- Linux+Networks
- PHP+MySQL
- 2013: Python[Django]+MySQL+integrations
- Python[Django]+Postgres+EDA+Microservicos+REST
- Python[Django]+Postgres+RPC+Mezzoservices+REST
- Python[Flask]+SQLAlchemy+Postgres+QuasiREST
- 2020: Go+Postgres+GraphQL
- 2021: Lucid
https://cleber.solutions/
data:image/s3,"s3://crabby-images/5fbf4/5fbf4a9427447e259394e5fb3c3091de89693889" alt=""
"How do I create a JS function
to be called recursively
that retains state
but without access to global/outer scope?"
% 1- The "interface" function:
fib(N) -> fib_iter(N, 0, 1).
% 2- The break:
fib_iter(0, Result, _Next) -> Result;
% 3- The iteration:
fib_iter(Iter, Result, Next) ->
fib_iter(Iter-1, Next, Result+Next).
Erlang example
fib(N) -> fib_iter(N, 0, 1).
fib_iter(0, Result, _Next) -> Result;
fib_iter(Iter, Result, Next) ->
fib_iter(Iter-1, Next, Result+Next).
fib(3) % interface
fib_iter(3, 0, 1) % iteration
fib_iter(2, 1, 1) % iteration
fib_iter(1, 1, 2) % iteration
fib_iter(0, 2, 3) % break
2 % result
Index: 0 1 2 3
Sequence: 0 1 1 2
Some honorable mentions
Before we really start,
of (probably) very useful "useless" things.
LISP
data:image/s3,"s3://crabby-images/a5f2c/a5f2cdb09bab003be17c2e0c6c81172efc524337" alt=""
Tcl
data:image/s3,"s3://crabby-images/e5990/e59904d46a0282558526fffaf0e846d62a7e8bf9" alt=""
It's Redis! See https://gist.github.com/antirez/6ca04dd191bdb82aad9fb241013e88a8
Haskell
data:image/s3,"s3://crabby-images/c8409/c8409f80ad42e830511553def4a5e2dc8d6312cb" alt=""
Zig
data:image/s3,"s3://crabby-images/bb05a/bb05a06a893e6ce20394896db394a0cd41bb3df3" alt=""
data:image/s3,"s3://crabby-images/cf133/cf133fe3402b8ccfe17ee62d84619dd5459d7511" alt=""
Now, forget everything.
Prolog
Logical Programming
Logical Programming
- Based in... Logic.
- Basically, the structured study of the truth
- Among other things, "predicate calculus"
- The core of a Prolog program: find the truth.
You sure you forgot everything?
- Variables
- Functions
- Flow control
Forget it.
In the terminal
swipl -f awesome.pl
swipl -f roads.pl
path(a, e, Path, Distance).
path(a, e, Path, Distance), [H|T] = Path, [H2|T2] = T, H2 = b.
append([a], [b], X).
append(A, B, [a, b, c, d]).
<comma> = AND | <semicolon> = OR/ELSE | <period> = END
See:
https://medium.com/clebertech-en/prolog-is-not-that-hard-f8cb2b8b3e43
https://medium.com/clebertech-en/prolog-is-not-that-hard-part-2-3a88ac8f02e0
Use cases
- Logic
- Combinatorial Analisys
- Artificial Inteligente
- Compilers (semantic checks)
- Automatic tests generators
Interesting example: "julian"
Date and time, based only on constraints.
julian
:- use_module(library(julian)). :- use_module(library(clpfd)). solution(Year) :- % Eisenhower presidency had % Fourth of July on Sunday in ... form_time([dow(sunday), Year-07-04]), Year in 1953..1961. ?- solution(Y). Y = 1954.
In other languages
- Python
- kanren ("logpy")
- Go
- golog
- Javascript
- tau-prolog
Forth
Concatenative languages
See also:
"Stack based"
- Operations always from the stack
- The stack is pure
"concatenative" is not a synonym
with "stack based".
Concatenative:
Prog_A <concat operation> ProgB =
Prog_B(Prog_A)
Stack
- [] # Empty
- 100 → [100]
- 200 → [100, 200]
- 300 → [100, 200, 300]
- + → [100, 500]
- * → [50000]
Code sample
\ Display indexes of a 2D array : INDEXES ( rows columns -- ) SWAP ( columns rows ) 0 ?DO \ For number of rows CR \ CR goes to next line DUP \ DUPlicate columns 0 ?DO \ For number of rows J . \ Display row index I . \ Display column index SPACE \ SPACE displays a space LOOP \ End of inner loop LOOP ; \ End of outer loop 3 4 INDEXES
data:image/s3,"s3://crabby-images/61c9c/61c9c76d7f35d04f85c10fefeef76727c62dc7aa" alt=""
But... WHY?
Imagine you have only
32 bytes
of available memory
and have to run some fairly complex algorithms.
Too far fetched?
data:image/s3,"s3://crabby-images/8c230/8c230ed6c954d6c49e31c8df4aaa8ea13f669923" alt=""
data:image/s3,"s3://crabby-images/aa019/aa019974895327b3157957a12b703f2b2c1d1ba1" alt=""
Argo Submersible Vehicle
(Now retired) Space Shuttle
Forth
- 2 stacks:
- Values
- Return addresses
- Partially compiled, partially interpreted
- Threaded code
- Built-in words are compiled
- User-defined words are a sequence of jumps between other words
C
- 1 stack:
- Activation records
- Arguments and runtime addresses share the same space
- Compiled?
- Yes (C)
- No (shell)
- Yes, to VM (Python)
- +FFI
Le Fin
My advice:
Take some time to study some absurd topic.
Copy of Técnicas Alternativas de Programação
By Cléber Zavadniak
Copy of Técnicas Alternativas de Programação
- 148