GithubHelp home page GithubHelp logo

thomassuedbroecker / caikit Goto Github PK

View Code? Open in Web Editor NEW

This project forked from caikit/caikit

0.0 0.0 0.0 999 KB

Caikit is an AI toolkit that enables users to manage models through a set of developer friendly APIs.

License: Apache License 2.0

Shell 0.12% Python 99.88%

caikit's Introduction

Caikit

Caikit is an AI toolkit that enables users to manage models through a set of developer friendly APIs. It provides a consistent format for creating and using AI models against a wide variety of data domains and tasks.

Caikit Overview

Capabilities

Caikit streamlines the management of AI models for application usage by letting AI model authors focus on solving well known problems with novel technology. With a set of model implementations based on Caikit, you can:

  • Run training jobs to create models from your data
  • Run model inference using data APIs that represent data as structures rather than tensors
  • Implement the right training techniques to fit the model, from static regexes to multi-GPU distribution
  • Merge models from diverse AI communities into a common API (e.g. transformers, tensorflow, sklearn, etc...)
  • Update applications to newer models for a given task without client-side changes

What Differentiates Caikit from Other AI Model Runtimes?

Developers who write applications that consume AI models are not necessarily AI experts who understand the intricate details of the AI models that they use. Some would like to treat AI as a "black box function" where they give it input and it returns the output. This is similar in cloud computing whereby some users would like to deploy their applications to the cloud without detailed knowledge of the cloud infrastructure. The value for them is in their application and that is what is of most interest to them.

Caikit provides an abstraction layer for application developers where they can consume AI models through APIs independent of understanding the data form of the model. In other words, the input and output to the model is in a format which is easily programmable and does not require data transformations. This facilitates the model and the application to evolve independently of each other.

When deploying a small handful of models, this benefit is minimal. The benefits are generally realized when consuming 10s or hundreds of AI models, or maintaining an application over time as AI technology evolves. Caikit simplifies the scaling and maintenance of such integrations compared to other runtimes. This is because other runtimes require an AI centric view of the model (for example, the common interface of “tensor in, tensor out”) which means having to code different data transformations into the application for each model. Additionally, the data form of the model may change from version to version.

User Profiles

There are 2 user profiles who leverage Caikit:

  • AI Model Author:
    • Model Authors build and train AI models for data analysis
    • They bring data and tuning params to a pre-existing model architecture and create a new concrete model using APIs provided by Caikit
    • Examples of model authors are machine learning engineers, data scientists, and AI developers
  • AI Model Operator:
    • Model operators use an existing AI model to perform a specific function within the context of an application
    • They take trained models, deploy them, and then infer the models in applications through APIs provided by Caikit
    • Examples of operators are cloud and embedded application developers whose applications need analysis of unstructured data

AI Model Operator Example

Check out the Text Sentiment example to understand how to load and infer a model using Caikit.

Code of conduct

Participation in the Caikit community is governed by the Code of Conduct.

caikit's People

Contributors

alex-jw-brooks avatar aluu317 avatar dependabot[bot] avatar evaline-ju avatar gabe-l-hart avatar gkumbhat avatar hickeyma avatar joerunde avatar prashantgupta24 avatar thomassuedbroecker avatar tjohnson31415 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.