aboutsummaryrefslogtreecommitdiffstats
path: root/julia-c/README.md
blob: d990b21849fcd81e8975c37b87c0e9e425c3a11f (plain)
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
# julia.c

### Simple CLI for efficient Julia Set fractal rendering in C

The motivation for this tool was to improve upon my earlier Julia Set code 
with a cleaner web app interface. But using Python/numpy/PIL as the driver for 
image rendering was just too slow. This is supposed to be a better driver program 
meant to be lightweight, and easy to be called from another application with 
not-so complicated syntax. 

If for some reason you use it in anything important, *you shoud also sanitize the input*
with another programming/scripting language to esnure the syntax doesn't break anything.
You'll notice immediately you can mess with the inputs a bit but still get an image 
-- assume it is NOT secure on it's own

I make use of the STB Image library avaliable [here](https://github.com/nothings/stb) for image
rendering.

Call `./julia` without options for a help menu. Functions come from complex.h
documented [here](https://code-reference.com/c/complex.h) with some
simplifications and subtractions. Supported arguments are:

- acos 
- acosh 
- asin 
- asinh 
- atan 
- atanh 
- cos 
- cosh 
- exp 
- log (natural log, only) 
- sin 
- sinh 
- sqrt 
- tan 
- tanh
- pow 

All functions can optionally be appended with a number (up to and including 9999) 
to raise them to a power, with '^'. As an example: `pow^3`, is "z^3. Decimal powers are
also usable, such as `cos^.5` as long as it's less than 4 digits. You can optionally 
just pass any string to get the default z^2 Julia Sets for example, `./julia nil ...`

The executable was compiled on Debian sid so it won't work on Windows, or certain other
operating systems. If you have gcc installed, you can just run `make` and then `./julia`
to run. 

If you're on Windows, you'll need to [install GCC](https://gcc.gnu.org/install/binaries.html)
to do the same