Code Monkey home page Code Monkey logo

mandelbrotgolang's Introduction

Distributed computing of the Mandelbrot Set using Go, gRPC and Raylib

This is an implementation in Go of the Mandelbrot Set calculated taking profit of distributed computing and multithreading.

Build and run on a single computer

$ go run main.go

Build and run on multiple computers (distributed computing)

Run the application in slave mode on a cluster node:

$ go run main.go --role=slave

Run the application in master mode on a cluster node:

$ go run main.go --role=master --slaves=192.16.0.2,192.16.0.3,192.16.0.4

192.16.0.2, 192.16.0.3 and 192.16.0.4 are sample IPs of cluster nodes with the application running in slave mode. The master node communicates continuously with the slave nodes and render all the regions of the Mandelbrot Set in real-time in a system window.

Usage

Use a and s keys to zoom-in and zoom-out respectively (be patient when zooming). Use arrow keys to move.

Screenshot

Mandelbrot fractal

Demo

Mandelbrot Set

mandelbrotgolang's People

Contributors

albertnadal avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar

mandelbrotgolang's Issues

Can't compile on system without X11

I have 10 Raspberry Pi's and 3 NUCs running as servers. And I wonted run this application as slave on alle the servers. The master should run on PC. But I can't compile it:

# github.com/gen2brain/raylib-go/raylib
In file included from ./external/glfw/src/internal.h:188,
                 from ./external/glfw/src/context.c:30,
                 from /home/xxx/go/pkg/mod/github.com/gen2brain/[email protected]/raylib/cgo_linux.go:6:
./external/glfw/src/x11_platform.h:33:10: fatal error: X11/Xlib.h: No such file or directory
   33 | #include <X11/Xlib.h>
      |          ^~~~~~~~~~~~
compilation terminated.

Than I installed

sudo apt install libx11-dev

But than I get the next error

# github.com/gen2brain/raylib-go/raylib
In file included from ./external/glfw/src/internal.h:188,
                 from ./external/glfw/src/context.c:30,
                 from /home/xxx/go/pkg/mod/github.com/gen2brain/[email protected]/raylib/cgo_linux.go:6:
./external/glfw/src/x11_platform.h:36:10: fatal error: X11/Xcursor/Xcursor.h: No such file or directory
   36 | #include <X11/Xcursor/Xcursor.h>
      |          ^~~~~~~~~~~~~~~~~~~~~~~
compilation terminated.

Is X11 needed for the slave?!

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.