Skip to content

Latest commit

 

History

History
110 lines (87 loc) · 6.59 KB

readme.md

File metadata and controls

110 lines (87 loc) · 6.59 KB

GPTGodIcon Gemini AI God Bukkit Plugin

Modified version of the ChatGPT bukkit plugin by "BigYous" which uses the google gemini (within free-tier limits) to provide an improved AI roleplay experience free of charge. Join a world ruled by the AI and hope that your new overlord is having a good day. You will be sent on missions from God, have your buildings and photos judged, be rewarded greatly, or explode spectacularly. Tread carefully....... it see's and hears everything....

demo image of photography and decree features

What's Changed:

  • Ported to google gemini from chatgpt

    • scrapped all openai support at the moment in favour of full gemini consistency for now
    • context window is now one million for gemini-1.5-flash and 2 million for gemini-1.5-pro
    • Voice transcription requests are now bundled (to avoid api spam) and using the gemini 1.5 flash model
  • Ported voice synthesis to Speechify (super godly narrator voice for free! IT EVEN BREATHES!)

  • Improved context handling (cured the AI god of dementia)

  • separated model usage into "primary" and "secondary" model so that a cheaper model may be used for medial tasks

  • decreased call count to primary model and unified commands and communication behaviour to one context

  • Added real multi-turn mode (including model responses in context)

  • Improved system instruction prompt design for better roleplay output

  • Gave the AI a better sense of time using minecraft time of day timestamps

  • various bug fixes and codebase improvements

  • added new decree function for the ai to drop floating commandments in the world if it is displeased

  • added model temperature configuration control to improve model creativity

  • Rolling context expiry for new multi-turn when token limit is approaching

  • Give the AI eyes using the papermc ImageryAPI and gemini vision api (so the AI can decide if your monuments to its honor are ugly or not)

    • Added player camera item (get with /givecamera) for fun photography for god missions
    • Functioning structure rendering with automatic camera positioning
  • Created sequential but non-blocking thread queue for the api wrapper class (AsyncTaskQueue in GptAPI)

Todo:

  • Maybe add option to choose between gemini and open ai?
  • Fix bug with events coming in after round restart (cut off async threadpool of logger on reset or associate events with some kind of session id)
  • selfie mode for god camera
  • spawn sound and particle effects on camera shutter
  • Add ability to save favourite structures and scatter them across the new map on round start
  • Add option to renderer to ignore all blocks not in a structure (so that trees don't block the view and make the ai think you built a bush)
  • Give god a tool to give a user the camera they would otherwise get from /givecamera

Local Setup

Config

  • Get a free gemini api key from aistudio.google.com/
  • Get a free speechify api key from console.sws.speechify.com/tts
  • configure primary model to be model-name: gemini-1.5-pro for smarter role-play output at slower speeds. Both models are fun, so give them both a try
  • configure primary model to be model-name: gemini-1.5-flash if you want fast model times such as rate: 30 or below.
    • NOTE: Do not go below 30-32 on the free tier pro model or you will hit your 2 requests per minute and 50 requests per day fast
    • NOTE: if you set your primary model to gemini-1.5-flash then set secondary to gemini-1.5-flash-8b as free-tier rate limits are per-model name
    • do not use the 1.0 models or other models which are not multimodal for secondary model. This program relies on the audio and visual processing of the latest Gemini 1.5 models.
    • the flash model can go below 20 and performs quite nicely with the rapid feedback
    • for a fast-feedback experience try setting both models to gemini-1.5-flash and try a rate of about rate: 20 to rate: 30
    • do NOT use gemini-1.5-pro as the secondary model

game-play example photo 2

Building

  • use the shadowjar task to build
  • the jar will appear in build/libs
  • place this jar in the plugins folder of the server

Development

development requires jdk 21 and gradle version 7.4

Workspace has been setup for VSCode as well.

plugin jar releases show up under <project_dir>\build\libs

Windows

A release build may be generated with the included bat file for convenience.

I:\DEVELOPER\PROJECTS\minecraft-gpt-god-plugin>gradlew shadowJar
Starting a Gradle Daemon, 2 incompatible and 1 stopped Daemons could not be reused, use --status for details

BUILD SUCCESSFUL in 3s
3 actionable tasks: 3 up-to-date
I:\DEVELOPER\PROJECTS\minecraft-gpt-god-plugin>

*Nix

install gradle 7.4, and jdk 21 then:

~> gradle shadowJar

Running

  • run the server once then go to plugins/gptgodmc/config.yml
  • paste in your OpenAi API or Gemini key
  • run the server again
  • launch minecraft with fabric (make sure voice chat mod is installed)
  • NOTE: on MacOS you need to use a launcher such as prisim to allow microphone access permission to for the plugin
  • finally, connect to the server at localhost