Awesome Golem
Welcome to Awesome Golem, a community-curated list of resources, links, projects, tools and applications on Golem!
The users of Golem run the reference implementation in the form of the Rust implementation, Yagna. Together the users make up the Golem Network, a P2P marketplace for computational resources where individuals can act as one of the two non-exclusive roles; a provider selling idle resources, or a requestor buying resources to run tasks.
Contents
- Golem
- Thorg
- Network Statistics
- Apps
- Bounties and Rewards
- Developer and Requestor Resources
- Provider Resources
- Learning Resources
- Community
Golem
- Golem Network Platform - Learn the Golem platform on the official Golem Network website.
- Golem Factory GitHub - Where you can find the open source code of all things Golem.
- Yagna GitHub - The official Rust implementation of Golem.
- Golem Community Chat - Join the community and team open discussion on Discord.
- Reddit - Golem Network discussion on the Reddit platform.
- Twitter - The Golem Project Twitter.
- Blog - The official blog where you can find the most reliable information on announcements, summaries and updates.
Thorg
- About Thorg - Learn what the Thorg miner does.
- Thorg Usage - Understand the depths of Thorg.
- Twitter - The official Twitter of Thorg.
Network Statistics
- Golem Network Stats - Statistics tracking tasks and provider resource utilization in the Golem Network.
- Golem Stats backend - Backend of the Golem Network Statistics page including API endpoint URLs.
- Stats API Documentation - API endpoints that the Golem Network Stats page uses to display its data.
Apps
- Golem SLATE - Hosted code pen SPA for writing a requester script to have work computed by the network. Utilizes dockerized yagna environments to communicate with the Golem Network in the background.
- Chess On Golem - Hosted Chess app to play against the providers of the network utilizing the Stockfish open source Chess engine.
- Go le' Machin - Web based bulk image editor that allows users to upload multiple images and apply bulk actions to them.
Docker
- Golem Requestor Node - Dockerized requestor environment. Pass in the py script, it sets up the daemon and runs it.
Testing
- Golem Test Harness (Goth) - Tool with the purpose of speeding up your development process and making it more enjoyable for application creators.
- Golem-afl - An experimental test-fuzzing framework. Assists in finding security holes.
- Golem Cargo Test - An adaptive distributed test executor for Rust projects.
- Golem CI - Decentralized task pipeline.
- Golem SLATE - Open source repository for Golem SLATE described in the above Apps section.
- ThorgPress - A tool to benchmark providers and unveil their true capabilities beyond what can be seen through the marketplace.
VPN
- Yagna httpx client - VPN usage on Yagna demonstrating communication with a provider-based HTTP server the way you communicate with any other HTTP server.
- Golem Provider with network access - A requstor that acts as a http proxy for running providers, allowing them to access the wider internet.
Games
- Golem Sudoku - Game of Sudoku with size variants.
- HSOG-requester - Helps the HearthStone community in the design and building of decks by running a large number of simulated games.
- ChessOnGolem - Open source repository for Chess described in first Apps section. Includes React frontend for the 2 AI's playing against each other through the Golem backend.
- Golem Fleet Battle Simulator - System for calculating the results of a battle between two opposing starship fleets. Used in the iOS game Rock Paper Frigate to determine the result of PvP fleet battles.
CLI Tools
- Golem Completion Engine - Enhanced bash completion engine that extends built-in completions by providing contextual help for golemsp and yagna.
- Golocity - Build and deploy your dockerized applications on the Golem Network in just two commands.
- gc__push_image - A CLI tool that publishes the GVMI image to Skynet, making users able to change the image_url without self-hosting/giving up control.
Video Transcoding and Editing
- Golem Network Video Transcoder - Sample app to transcode videos. Select your transcoding profile and then upload your videos.
- Golem Transcoding requestor - React + Spring based webapp accepting video files as input and transcoding these files into different formats.
- Golem Auto Editor - Run Auto-Editor to automatically perform some video editing functions, offload the video processing to Golem.
Data Analysis
- Coacervate - Coacervate is a free and open-source public good that lets you easily run genomic analyses on an extremely low-cost global supercomputer; democratizing access to the knowledge and infrastructure required to carry out groundbreaking research.
- Flan - Tool for entrepreneurs that provide customized analysis of millions of worldwide trade value records giving them a bold guideline about what sectors they would need to take more attention to.
- Golem Lorenz-attractor - A system of three coupled, first-order, nonlinear differential equations which describe the trajectory of a particle through time.
- Golem Geomandel - Python script for generating sequences of Mandelbrot images centered on a single point and with zoom increasing in each image.
- Golem COVID - Creates images of new deaths per million related to COVID. After all images generated, it will gather them and create a gif.
- Golem Parallel Matplotlib - Various statistical analyses are performed on circadian rhythm measurements in human test subjects.
- Full-Text Search Engine - A search engine service that goes through text files.
Data Simulation
- cadCAD Golem - Package wrapper for cadCAD to dispatch the simulation workload to multiple Golem nodes. Supports Jupyter Notebook.
- Golem Array - Antenna array design and simulation.
- Limit visualization - Plots graphs with various limits. Supports discontinous graphs.
- GolemGraphWavePair - Generates graph frames, then combine them into an animation.
- Golemized strong-gravitational-lense - Simple distributed computing hack that simulates a physical phenomena called gravitional lensing.
Data Optimization
- Golem or-tools - Uses the or-tools Constraint Programming library to solve problems.
- No more COFUD - Calculates how to fit the most people into a space while keeping 2 meters distance between each other.
- Mutta Puffs - Sports league scheduler that solves the Travelling Tournament Problem for a given set of teams using Population-based Simulated Annealing.
Finance
- ZKSync .csv export - Scrapes ZKSync to generate financial data in a .csv file.
Machine Learning
- DeML-Golem - Decentralised Machine Learning using Federated Learning to combine the sub-step models, it trains on different provider nodes into a full fleged model.
- Golem Image Classifier - Train and classify images through an active service.
Deep Learning
- Mlg - CNN predict services, a deep learning application that distributes popular CNNs pre-trained with ImageNet datasets.
- Deepart Golem - Makes art using distributed computing by running a tensorflow app, uploading your content and style picture.
RNG
- Gandom - Extract random streams from providers. Supports two PRNGs, one based on Chaos machines and the other that makes use of Sodium.
- Entropythief - Get random entropy at a steal of a rate from multiple providers utilizing the linux entropy source or Intel's RDRAND cpu instruction (inspired by Gandom).
Password Recovery
- Golem-JTR - Run John The Ripper to recover a password.
- Yacat - Hashcat password-recovery step-by-step.
DeFi
- Golem Staking Pool incentivize system for GLM holders - A smart contract in order to provide the opportunity of yield farming for GLM token holders.
- Magic-doll - Sumer is a DeFi application that people may delegate their Splinterland card to earn passive income. Its core is
Kyle
, a Golem app that does all the computation to pick the best team to play for each match.
User Interfaces
- Golem UI - Electron user interface for Yagna.
Miscellaneous
- Gc__ListOffers - List offers by providers on the Golem Network with a GUI.
- Gc__gvmi_hash - Recalculate the hash of gvmi image file. Solves the issue of having lost the hash of a previously uploaded image or if you're unsure if a key corresponds to a specific image.
- gvm-vim - Golemized docker image for compiling the VIM editor.
- YaJSapi fork with greeting example - Simple Node.js requestor app that greets you. It writes some important message to a file and then downloads it for you, the basic eskeleton of a requestor app. Look in
examples/greetings
. - Golem Image Sharpening - A tool to sharpen images.
- Filterms - Market-strategy for whitelisting or blacklisting as a Golem requestor (yapapi).
- golem-bulk-image-handler - Takes an input image and processes it in many different ways using the Pillow library.
Bounties and Rewards
- GLM Rewards Program - A program that incentivizes activity within development, support, content creation, and more.
- Gitcoin Bounties - A collection of open bounties and hackathons hosted on Gitcoin.
Developer and Requestor Resources
- Yagna handbook - Handbook for the Golem, implementation name, Yagna.
- Yagna Python API docs - Documentation for Yapapi.
- Releases List - GitHub releases of Yagna.
- Requestor flash tutorial - Get started quick and create your first tasks/request on Golem.
- Yagna tag on Stack Overflow - Use the Yagna tag if you have an interesting question you'd like answered.
- Breakdown of blender.js - JS guide for developers to get a better idea of how to run a task with the JavaScript API.
- EasyYagnaJS - Copies over Node.js dependencies directly to the provider, making developers not have to use Docker in their workflow.
- push-gvmi - A GitHub action that automatically builds and uploads the GVMI image to Golem plus a way to scrape the newest hash for local usage.
Provider Resources
- Provider Tutorial - Get started as a Provider on Golem Network using the handbook.
- Provider FAQ - Community curated list of commonly asked questions and answers.
- Yagna-binaries for aarch64 - Build for 64 bit arm architecture to be able to run as a provider on a system such as a Raspberry Pi.
- Automatically update provider node prices - Script that checks the median of the prices on stats.golem.network and updates all 3 values on the provider node related to price.
- Golem Price Updater - Automatically adjust the price for your Golem node based on the current price of GLM.
Monitoring
- Golem Provider dashboard - ReactJS dashboard made to quickly gather status from your provider nodes without having to SSH into them.
- Golem Provider dashboard backend / GolemBar - Flask backend that collects the data from the provider that's then used with the dashboard project above.
Provisioning
- Ansible ya_provider - Ansible role that deploys a Golem provider automatically with minimal configuration required.
- WSL - Allows Windows users to run Golem within Windows Subsystem for Linux. Removing the requirement of Windows users needing to use a Virtual Machine.
- Golem Provider Terraform - Terraform script to automatically deploy a Golem Provider on a cloud provider and setup monitoring using prometheus.
- Automatic Golem - Setup a Golem Provider with simple instructions and logs guiding you through the process.
- Golem Provider Node - Docker version of a node to help you get started running as a provider in a Docker container quick.
- Golem Provider node - Fork of Alxexandre-abrioux project above that allows to dynamically generate config files from ENV variables and specify how many replicas you'd like to spawn.
- Scalable golem provider - Spawn x amount of providers using Docker.
Learning Resources
Presentations and Workshop Material
- Golem: Architecture, SDKs and tips with Jakub Mazurek at 0xHack - Live workshop diving into how any developer with Python or JS coding experience can start build applications running on Golem.
- Golem: Growing an ecosystem the Golem way with MarΓa Paula FernΓ‘ndez at 0xHack - High-level overview and introduction to Golem as a project.
- Golem Workshop at H3LLO Decentralization - List of resources containing a live-coding hackathon workshop and relevant resources to help developers understand and requesting on Golem.
- Mainnet Requestor quickstart Walk-through - Video walk-through of the requestor quick-start handbook guide to get a request on Golem Network testnet and then mainnet using the Yagna Python API.
- Mainnet Provider quickstart Walk-through - Video walk-through of the provider handbook guide to start sharing computational resources the Golem Network.
Unraveling Golem's The Next Milestone Blog Series
- Unraveling Golem's The Next Milestone - Introduction to the Yagna implementation of Golem.
- Unraveling Golem's The Next Milestone, Part II - Fundamental architectural concepts which constitute the foundations of the new implemenation of Golem, Yagna.
- Unraveling Golem's The Next Milestone, Part III - The elements of Golem's reference architecture, and illustrates how they interact to form a working ecosystem, being the Golem Network.
GitHub Digest Blog Series
- Golem GitHub Digest #1 - Understanding the Golem Repositories.
- Golem GitHub Digest #2 - Diving into the Golem Repositories.
- Golem GitHub Digest #3 - Diving into Pull Requests of the Golem repositories.
- Golem GitHub Digest #4 - Diving into latest releases in the Golem repositories.
- Golem GitHub Digest #5 - Diving into the Golem alpha testnet.
- Golem GitHub Digest #6 - SGX proof-of-concept for Golem.
- Golem GitHub Digest #7 - Decentralization of the Golem marketplace.
- Golem GitHub Digest #8 - Awesome Golem and next steps to Alpha 3.
- Golem GitHub Digest #9 - AMD provider support, network metrics and improved proposal handling.
- Golem GitHub Digest #10 - Improvements from community feedback.
- Golem GitHub Digest #11 - Easy log collection.
- Golem GitHub Digest #12 - We are on MAINNET and gathering feedback.
- Golem GitHub Digest #13 - Progressing faster with the help of the Golem community.
- Golem GitHub Digest #14 - Towards the next major release.
- Golem GitHub Digest #15 - Awesome, Goth improvements and towards Beta 3.
- Golem GitHub Digest #16 - VPN, ARM binaries for requestors, and custom usage counters.
Community
- Golem Network Discussion Group - Community driven Telegram channel.
- Reddit Golem Stat Bot - Scrapes Reddit posts on /r/GolemProject, and replies if specific keywords/commands are found.
- Golem God - Gives out "bot coins" for activity, and lets users exchange and withdraw them to tokens when they have enough.
Contributing
Pull requests and issues with suggestions to Awesome Golem are welcome! Please read the contributing guidelines before submitting a PR.