Konveyor AI (Kai) simplifies the process of modernizing application source code to a new platform. It uses Large Language Models (LLMs) guided by static code analysis, along with data from Konveyor. This data provides insights into how similar problems were solved by the organization in the past, helping streamline and automate the code modernization process.
Pronunciation of 'kai': https://www.howtopronounce.com/ka%C3%AC-4
Kai implements a Retrieval Augmented Generation (RAG) approach that leverages data from Konveyor to help generate code suggestions to aid migrating legacy code bases to a different technology. The intent of this RAG approach is to shape the code suggestions to be similar to how an organization has solved problems in the past, without additional fine-tuning of the model.
The approach begins with using static code analysis via the Kantra tool to find areas in the source code that need attention. 'kai' will iterate through analysis information and work with LLMs to generate code changes to resolve incidents identified from analysis.
-
Read more about our technical approach here: docs/Technical_Background.md
-
Presentation slides introducing Konveyor AI: 2024_May GenAI Application Migration
- See Generative AI Applied to Application Modernization with Konveyor AI (~15 minute demo with voice)
- 2024 May 07: Apply generative AI to app modernization with Konveyor AI
- 2024 May 07: Kai - Generative AI Applied to Application Modernization
- 2024 July 23: Embracing the Future of Application Modernization with KAI
- Run the kai backend image locally with sample data
- Walk through a guided scenario to evaluate how Kai works
The quickest way to get running is to leverage sample data committed into the Kai repo along with the podman compose up
workflow
-
git clone https://github.com/konveyor/kai.git
-
cd kai
-
git checkout stable
- NOTE: Until we fix Issue #264 there is a need to be on
stable
branch of code
- NOTE: Until we fix Issue #264 there is a need to be on
-
Edit
compose.yaml
diff --git a/compose.yaml b/compose.yaml index c0f2a9e..69a3be8 100644 --- a/compose.yaml +++ b/compose.yaml @@ -1,7 +1,7 @@ version: "3" x-kai-variables: &kai-variables - KAI__DEMO_MODE: "False" + KAI__DEMO_MODE: "True" HUB_URL: ${HUB_URL:-https://tackle-konveyor-tackle.apps.example.com/hub} IMPORTER_ARGS: LOG_LEVEL: info
- NOTE: The above edit of
compose.yaml
will not be needed once Issue #257 is fixed
- NOTE: The above edit of
-
Run
GENAI_KEY="something" podman compose up
. The first time this is run it will take several minutes to download images and to populate sample data.- NOTE: We need to provide some/any value to
GENAI_KEY
environment variable until we address Issue #287 - You will need to install podman and podman-compose if you do not already have it installed. This allows your system to run containers.
- After the first run the DB will be populated and subsequent starts will be much faster, as long as the kai_kai_db_data volume is not deleted.
- To clean up all resources run
podman compose down && podman volume rm kai_kai_db_data
.
- NOTE: We need to provide some/any value to
-
Kai backend is now running and ready to serve requests
After you have the kai backend running via podman compose up
you can run through a guided scenario we have to show Kai in action at: docs/scenarios/demo.md
- docs/scenarios/demo.md walks through a guided scenario of using Kai to complete a migration of a Java EE app to Quarkus.
The above information is a quick path to enable running Kai quickly to see how it works. If you'd like to take a deeper dive into running Kai against data in Konveyor or your own custom data, please see docs/Getting_Started.md
- Kai backend will write logging information to the
logs
directory.- You can adjust the level via
kai/config.toml
and change thefile_log_level = "debug"
value
- You can adjust the level via
- Tracing information is written to disk to aid deeper explorations of Prompts and LLM Results. See docs/contrib/Tracing.md
- See our technical design related information at docs/design
- Kai is in it's early development phase and is NOT ready for production usage.
- See ROADMAP.md to learn about the project's goals and milestones
- Please see docs/Evaluation_Builds.md for information on early builds.
Our project welcomes contributions from any member of our community. To get started contributing, please see our Contributor Guide.
Refer to Konveyor's Code of Conduct here.