Skip to content

Latest commit

 

History

History
215 lines (163 loc) · 6.7 KB

README.rst

File metadata and controls

215 lines (163 loc) · 6.7 KB

icon CodeScribe

Code style: black

Overview

Code-Scribe is a tool designed to facilitate incremental translation of Fortran codebases into C++ using generative AI. It automates the process of generating corresponding C++ source files and creating Fortran-C interfaces, simplifying the integration of Fortran and C++. The tool also allows users to interface with large language models (LLMs) through the Transformers API and create custom prompts tailored to the specific needs of the source code.

Read the paper: https://arxiv.org/abs/2410.24119

Key Features

  • Incremental Translation: Translate Fortran codebase into C++ incrementally, creating Fortran-C layers for seamless interoperability.

    fig1

  • Custom Prompts: Automatically generate prompts for generative AI to assist with the conversion process.

  • Language Model Integration: Leverage LLMs through the Transformers API to refine the translation and improve accuracy.

    fig2

  • Fortran-C Interfaces: Generate the necessary interface layers between Fortran and C++ for easy function and subroutine conversion.

Statement of Need

In scientific computing, translating legacy Fortran codebases to C++ is necessary to leverage modern libraries and ensure performance portability across various heterogeneous high-performance computing (HPC) platforms. However, bulk translation of entire codebases often results in broken functionality and unmanageable complexity. Incremental translation, which involves creating Fortran-C layers, testing, and iteratively converting the code, is a more practical approach. Code-Scribe supports this process by automating the creation of these interfaces and assisting with generative AI to improve efficiency and accuracy, ensuring that performance and functionality are maintained throughout the conversion.

Installation

At present we recommened installing Code-Scribe in development mode

./setup develop

Development mode enables testing of features/updates directly from the source code and is an effective method for debugging. Note that the setup script relies on click, which can be installed using,

pip install click

The code-scribe script is installed in $HOME/.local/bin directory and therfore the environment variable, PATH, should be updated to include this location for command line use.

Usage

You can use the --help options with every command to get better understanding of their functionality

▶ code-scribe --help
Usage: code-scribe [OPTIONS] COMMAND [ARGS]...

  Software development tool for converting code from Fortran to C++

Options:
  -v, --version
  --help         Show this message and exit.

Commands:
  draft      Perform a draft conversion from Fortran to C++
  index      Index Fortran files along a project directory tree
  inspect    Perform a generative AI inspection on Fortran files
  translate  Perform a generative AI conversion of Fortran files

Following is a breif overview of different commands:

  1. code-scribe index <project_root_dir> - Parses the project directory tree and creates a scribe.yaml file at each node along the directory tree. These YAML files contain metadata about functions, modules, and subroutines in the source files. This information is used during the conversion process to guide LLM models in understanding the structure of the code.

    # Example contents of scribe.yaml
    directory: src
    files:
      module1.f90:
        modules:
          - module1
        subroutines:
          - subroutine1
          - subroutine2
        functions:
          - function1
    
      module2.f90:
        modules: []
        subroutines:
          - subroutineA
        functions:
          - functionB
  2. code-scribe draft <filelist>: Takes a list of files and generates draft versions of the corresponding C++ files. The draft files are saved with a .scribe extension and include prompts tailored to each statement in the original source code.

  3. code-scribe translate <filelist> -m <model_name_or_path> -p <seed_prompt.toml>: This command performs neural translation using generative AI. You can either download a model locally from huggingface and provide it as an option to -m or you can simply set -m openai to use OpenAI API to perform code translation. Note that -m openai requires the environemnt variable OPENAI_API_KEY to be set. The <prompt.toml> is a chat template that guides AI to perform code translation using the source and draft .scribe files.

    # Example contents of seed_prompt.toml
    
    [[chat]]
    role = "user"
    content = "‹Rules and syntax-related instructions for code conversion>"
    
    [[chat]]
    role = "assistant"
    content = "I am ready. Please give me a test problem."
    
    [[chat]]
    role = "user"
    content = "<Template of contents in a source file>"
    
    [[chat]]
    role = "assistant"
    content = "<Desired contents of the converted file. Syntactically correct code>"
    
    [[chat]]
    role = "user"
    content = "<Append code from a source file>"
  4. code-scribe translate <filelist> -p <seed_prompt.toml> --save-prompts: This command allows generation of file specific json chat template that one can copy/paste to chat interfaces like that of ChatGPT to generate the source code. The json files are created from the seed prompt file and appended with source and draft code.

  5. code-scribe inspect <filelist> -q <query_prompt> -m <model_name_or_path>: Perform a query on a set of source files using a single prompt. This is useful for navigating and understanding the source code.

  6. code-scribe inspect <filelist> -q <query_prompt> --save-prompts: Create a scribe.json that you can copy/paste to chat interfaces.

Citation

@software{akash_dhruv_2024_13879406,
author       = {Akash Dhruv},
title        = {akashdhruv/CodeScribe: 2024.09},
month        = oct,
year         = 2024,
publisher    = {Zenodo},
version      = {2024.09},
doi          = {10.5281/zenodo.13879406},
url          = {https://github.com/akashdhruv/CodeScribe}
}