Skip to content

Latest commit

 

History

History
87 lines (66 loc) · 3.75 KB

README.md

File metadata and controls

87 lines (66 loc) · 3.75 KB

abstrac

Streaming Abstract Pixel Art

What is This Then ?

Q: The world's most over-engineered screen-saver?
A: I am not sure... there might be even worse.

Live Stream

Why not catch the live stream ?

Schedule: Monday to Saturday 09:00 - 01:00 CET

Goals

What I am trying to achieve here, is to create nifty random algorithmic patterns... but not quite only that. I want to create an infrastructure where I create new abstract animations, and:

  • stream live animations to Twitch (and in the future: Vimeo, YouTube, etc)
  • easily review animations on my desktop, from debugger
  • quickly tweak animation parameters
  • easily deploy the "animation streaming services" to any server, including cloud (e.g. make deploy)
  • configure schedules and layers:
    • Multiple layers, e.g. overlay an animation with a blurred version of itself
  • another aspect of configuration is to record a slightly longer loop, and stream that, to save CPU power, and the planet
  • future animations might be: falling autumn leaves, fun with typography, animated CPU/memory load, etc etc...

System Architecture

The Service

To make the live stream happen the abstrac-engine.service comprises two processes:

  • abstrac (the rendering process)
  • abstrac-ffmpeg.service (the streaming sprocess)

abstrac is the C++ executable that renders the animations to be streamed. For rendering I use raylib, which is a nice C++ wrapper around GLFW, which is an OpenGL wrapper. At some future point in time, it may happen that I will use OpenGL directly. But with my near zero OpenGL experience, raylib gave me a tremendous kickstart.

ffmpeg is just running one of those long ffmpeg-commands that streams the rendered images to Twitch.

Process Inter-Op

There is no intricate communication protocol here! The interface between the two processes, is simply a circular RAM disk buffer.

The rendering service is writing images to a RAM disk (numbered *.00000 - *.01999). It is looping through the 2000 numbers. The streaming service is then looping through the same images. The rich ffmpeg command line interface provides a straightforward way of streaming a loop of images on a wildcard filepath. The file format is uncompressed raw 32-bit RGBA. (Initially I used png, but after a while I noticed that the raylib png conversion was disproportionately CPU-intensive!)

Currently, I have no safeguard to prevent read/write race conditions. But the services seem to cope quite well anyway.

The service file, including the timers and the full ffmpeg command, and stream scheduling, are all in this repo.

The Schedule

To save the planet, the service is sleeping at night. Instead of going into crontab weirdness, I have decided to stay within the domain and rely on systemd timers.

Streaming Format

  • Flash Video container format over the RTMP streaming protocol
  • 800x450 pixels (16x9), 25 fps, 400 kb/s, (ffmpeg ultrafast)
  • Currently, I have not ventured into streaming any audio with the animations

Credits & Dependencies

The awesome raylib
License: zlib/libpng
Copyright (c) 2014-2023 Ramon Santamaria (@raysan5) https://github.com/raysan5/raylib Version: 4.2.0

The great ffmpeg toolset
License: GNU LGPL
Copyright (c) 2000-2023 the FFmpeg developers
http://ffmpeg.org
Version: 5.1.2
(Currently, I am only using the complete executable. Later I might need link directly to the ffmpeg libraries)