Draft: Networked Procedural Generation as a Sidecar to the Godot Engine Server

Metadata

  • Status: Draft
  • Deciders: V-Sekai, fire
  • Tags: V-Sekai, Chatbot GPT4 assistance

Context and Problem Statement

Enable creation of more dynamic and engaging environments within V-Sekai.

Proposed Solution

V-Sekai, an open-source virtual reality platform, aims to deliver a user-friendly experience for the VR community. To boost its functionality and compatibility with other tools, we propose integrating networked procedural generation as a sidecar to the Godot engine server, allowing for more dynamic and immersive environments in V-Sekai.

To further address V-Sekai’s limitations, we suggest incorporating the Membrane Framework along with other relevant technologies such as Godot Engine, OpenMfx Support, Elixir Phoenix, and Elixir Nx. This comprehensive integration will not only enhance V-Sekai’s capabilities but also increase its versatility across various use cases.

The implementation involves connecting V-Sekai with the components mentioned in the Membrane Framework diagram below:

sequenceDiagram
  participant MembraneFramework
  participant WebAndGodotEngineAndBlenderClient
  participant ElixirNx
  participant AIMLFramework
  participant Yugabyte

  rect rgb(240, 248, 255)
    note over MembraneFramework, Yugabyte: Toggle Actions
    MembraneFramework->>WebAndGodotEngineAndBlenderClient: TOGGLE_GAME_ENGINE_AND_CLIENTS
    MembraneFramework->>ElixirNx: ACCELERATE_MEMBRANE_FRAMEWORK
    MembraneFramework->>AIMLFramework: TOGGLE_AIML_FRAMEWORK
    MembraneFramework->>Yugabyte: TOGGLE_YUGABYTE
  end

  box "Source" #CCFFCC
    participant MembraneFramework
    participant WebAndGodotEngineAndBlenderClient
  end

  box "Filter" #FFFFCC
    participant ElixirNx
    participant AIMLFramework
  end

  box "Sink & Source of Data" #FFCCCC
    participant Yugabyte
  end

Using Read Replicas

We propose using read replicas for applications needing single-zone writes and multi-region reads. Benefits include:

  • Resilience: Zone-level resilience with primary cluster nodes across multiple zones.
  • Consistency: Timeline consistency in replica clusters, better than eventual consistency.
  • Latency: Quick reads from primary and replica clusters; write latency depends on client-primary cluster distance.

Positive Consequences

  • Improved functionality and versatility of V-Sekai
  • Enhanced compatibility with other tools and platforms
  • Greater potential for collaboration and community involvement

Negative Consequences

  • Increased complexity in implementation and maintenance
  • Potential performance overhead due to integration of multiple components

Option Graveyard

  1. Standalone procedural generation: Implementing procedural generation as a standalone feature without integrating it with the Godot Engine server. This option was discarded because it would not provide the same level of compatibility and versatility as the proposed solution.

  2. Using pre-built assets: Relying on pre-built assets for creating environments instead of implementing networked procedural generation. This option was discarded due to the limited flexibility and potential for repetitive content, which could negatively impact user engagement.

  3. Third-party procedural generation tools: Integrating third-party procedural generation tools instead of developing a custom solution. This option was discarded because it may not offer the same level of control and customization required for V-Sekai’s specific needs.

  4. Static environment design: Focusing on static environment design rather than dynamic, procedurally generated content. This option was discarded because it would not provide the desired level of immersion and interactivity for V-Sekai users.

If this enhancement will be used infrequently, can it be worked around with a few lines of script?

No, the proposed solution involves integrating multiple technologies and cannot be achieved with a simple script workaround.

Is there a reason why this should be core and done by us?

Yes, addressing the limitations of V-Sekai is crucial for its success and adoption within the VR community. By integrating the proposed technologies, we can ensure that V-Sekai remains competitive and relevant in the rapidly evolving VR landscape.

References