-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathArt.hs
40 lines (30 loc) · 1.17 KB
/
Art.hs
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
{-# LANGUAGE ExtendedDefaultRules,TypeFamilies #-}
module Art where
import SyntaxTree
import Language
import Compiler
import Optimizer
import Runtime
import Control.Monad (when)
import Prelude hiding (cos,sin,length,abs,(.),(^))
import qualified Prelude (length)
data Layer = Color SyntaxTree | Combination Layer Layer SyntaxTree
-- class Graph g where
-- type Vertex g
-- empty :: g
-- vertex :: Vertex g -> g
-- overlay :: g -> g -> g
-- connect :: g -> g -> g
-- instance Num Layer where
-- instance Graph Layer where
-- type Vertex Layer = SyntaxTree
-- empty = Color $ vector (1,1,1)
-- overlay a b = Combination a b 0.5
-- connect (Combination a1 b1 l1) (Combination a2 b2 l2) = Combination (a1 + a2) (b1 + b2) $ clamp 0 1 $ l1 + l2
-- connect a b = overlay a b
color (a,b,c) = Color $ vector (a,b,c)
_uv = (var Vector2 "uv") - (vector (0.5,0.5))
circle r = smoothstep r (r+0.02) (root $ (_uv.x * _uv.x) + (_uv.y * _uv.y))
spinny x y = x^10 - 5/2*x^8 + 35/16*x^6 - 25/32*x^4 + 25/256*x^2 + 1/16*y^6 - 3/32*y^4 + 9/256*y^2 - 1/256
compileLayers (Color a) = a
compileLayers (Combination l1 l2 ast) = mix (compileLayers l1) (compileLayers l2) ast