DistributedPrimeSpirals calculates prime numbers across multiple nodes and visualizes them.
We calculate a large number of prime numbers. The found primes are then visualized by mapping each prime to a point in polar coordinates. Idea taken from 3Blue1Brown.
These visualised prime numbers form a huge spiral pattern. This is implemented as follows: Calculation of the prime numbers in the backend using Elixir. The prime numbers found are then transmitted to a Phoenix LiveView channel, which finally transmits all newly found points to the outermost display layer, implemented with the JavaScript library Three.js in order to generate the desired large spiral patterns
In the project root, run:
docker build -t prime-spirals .
docker-compose up
This creates a cluster of 2 nodes.
To select the number of nodes you can run:
docker-compose up --scale additional-node=<n>
n
is the number of nodes you want to run additionaly to the main node. In total there will be running n+1 nodes.
To run a single instance, you can also run:
docker run -p 4000:4000 prime-spirals
Now visit localhost:4000
from your browser.
You will need phoenix_html, three and three.js, install it with
npm install phoenix_html
npm install three
npm install three.js
Eventually
npm audit fix --force
Furthermore you need Mix, a "build tool that provides tasks for creating, compiling, and testing Elixir projects, managing its dependencies, and more.": https://hexdocs.pm/mix/1.12.3/Mix.html
The project already contains OrbitControls, as it is already imported explicitly in our project structure: https://threejs.org/docs/#examples/en/controls/OrbitControls
Run mix setup
to install and setup dependencies
Start Phoenix endpoint with elixir --sname prime-spirals-node -S mix phx.server
Now visit localhost:4000
from your browser.
Detailed View of the System’s Functional Interaction
The API specification used between frontend and backend via Phoenix Channels
Endpoint: prime_spirals:endpoint
Client requests:
find_primes(n)
// find all primes from 0 to and including n
Server responses:
new_prime
, payload 'num' // a new prime was found, the prime number is in the palyoad under thenum
keyprimes_done
// all primes from 0 to n were found and already sent to the client