From 0cd555b7c718fb91a747b910b31f35d15937b0b8 Mon Sep 17 00:00:00 2001 From: Mark Daoust Date: Tue, 12 Dec 2023 23:16:44 -0800 Subject: [PATCH] Update README.md (#107) * Update README.md * Update README.md * Updated Gemini sample code in README * Update docs/build_docs.py --------- Co-authored-by: Mark McDonald --- README.md | 143 ++++++++++++++++++++++++++++++++++++++------- docs/build_docs.py | 1 + 2 files changed, 124 insertions(+), 20 deletions(-) diff --git a/README.md b/README.md index 45d938562..eb13ce4f1 100644 --- a/README.md +++ b/README.md @@ -1,51 +1,154 @@ -Google Generative AI Python Client -================================== +# Google AI Python SDK [![PyPI version](https://badge.fury.io/py/google-generativeai.svg)](https://badge.fury.io/py/google-generativeai) ![Python support](https://img.shields.io/pypi/pyversions/google-generativeai) ![PyPI - Downloads](https://img.shields.io/pypi/dd/google-generativeai) -Get started using the PaLM API in Python. Check out the [developer site](https://developers.generativeai.google/) -for comprehensive documentation. +The Google AI Python SDK enables developers to use Google's state-of-the-art generative AI +models (like Gemini and PaLM) to build AI-powered features and applications. This SDK +supports use cases like: + +- Generate text from text-only input +- Generate text from text-and-images input (multimodal) (for Gemini only) +- Build multi-turn conversations (chat) +- Embedding + +For example, with just a few lines of code, you can access Gemini's multimodal +capabilities to generate text from text-and-image input: + +``` +model = genai.GenerativeModel('gemini-pro-vision') + +cookie_picture = [{ + 'mime_type': 'image/png', + 'data': Path('cookie.png').read_bytes() +}] +prompt = "Give me a recipe for this:" + +response = model.generate_content( + content=[prompt, cookie_picture] +) +print(response.text) +``` -## Installation and usage + +## Try out the API Install from PyPI. -```bash -pip install google-generativeai + +`pip install google-generativeai` + +[Obtain an API key from AI Studio](https://makersuite.google.com/app/apikey), +then configure it here. + +Import the SDK and load a model. + ``` +import google.generativeai as genai + +genai.configure(api_key=os.environ["API_KEY"]) + +model = genai.GenerativeModel('gemini-pro') +``` + +Use `GenerativeModel.generate_content` to have the model complete some initial text. + +``` +response = model.generate_content("The opposite of hot is") +print(response.text) # cold. +``` + +Use `GenerativeModel.start_chat` to have a discussion with a model. + +``` +chat = model.start_chat() +response = chat.send_message('Hello, what should I have for dinner?') +print(response.text) # 'Here are some suggestions...' +response = chat.send_message("How do I cook the first one?") +``` + + + +## Installation and usage + +Run [`pip install google-generativeai`](https://pypi.org/project/google-generativeai). -Get an [API key from MakerSuite](https://makersuite.google.com/app/apikey), then configure it here. -```python +For detailed instructions, you can find a +[quickstart](https://ai.google.dev/tutorials/python_quickstart) for the Google AI +Python SDK in the Google documentation. + +This quickstart describes how to add your API key and install the SDK in your app, +initialize the model, and then call the API to access the model. It also describes some +additional use cases and features, like streaming, embedding, counting tokens, and +controlling responses. + + +## Documentation + +Find complete documentation for the Google AI SDKs and the Gemini model in the Google +documentation: https://ai.google.dev/docs + + +## Contributing + +See [Contributing](https://github.com/google/generative-ai-python/blob/main/CONTRIBUTING.md) for more information on contributing to the Google AI JavaScript SDK. + +## Developers who use the PaLM API + +### Migrate to use the Gemini API + +Check our [migration guide](https://ai.google.dev/docs/migration_guide) in the Google +documentation. + +### Installation and usage for the PaLM API + +Install from PyPI. + +`pip install google-generativeai` + +[Obtain an API key from AI Studio](https://makersuite.google.com/app/apikey), then +configure it here. + +``` import google.generativeai as palm palm.configure(api_key=os.environ["PALM_API_KEY"]) ``` -Use [`palm.generate_text`](https://developers.generativeai.google/api/python/google/generativeai/generate_text) -to have the model complete some initial text. -```python +Use `palm.generate_text` to have the model complete some initial text. + +``` response = palm.generate_text(prompt="The opposite of hot is") print(response.result) # cold. ``` -Use [`palm.chat`](https://developers.generativeai.google/api/python/google/generativeai/chat) -to have a discussion with a model. -```python +Use `palm.chat` to have a discussion with a model. + +``` response = palm.chat(messages=["Hello."]) print(response.last) # 'Hello! What can I help you with?' response.reply("Can you tell me a joke?") ``` -## Documentation +### Documentation for the PaLM API + +- [General PaLM documentation](https://ai.google.dev/docs/palm_api_overview) + +- [Text quickstart](https://github.com/google/generative-ai-docs/tree/main/site/en/tutorials/text_quickstart.ipynb) + +- [Chat quickstart](https://github.com/google/generative-ai-docs/tree/main/site/en/tutorials/chat_quickstart.ipynb) -Checkout the full [API docs](https://developers.generativeai.google/api), the [guide](https://developers.generativeai.google/guide) and [quick starts](https://developers.generativeai.google/tutorials). +- [Tuning quickstart](https://github.com/google/generative-ai-docs/blob/main/site/en/tutorials/tuning_quickstart_python.ipynb) -## Colab magics +### Colab magics -Once installed, use the Python client via the `%%palm` Colab magic. Read the full guide [here](https://developers.generativeai.google/tools/notebook_magic). +Once installed, use the Python client via the `%%palm` Colab magic. Read the [full guide](https://github.com/google/generative-ai-docs/blob/main/site/en/tools/notebook_magic.ipynb). -```python +``` %%palm The best thing since sliced bread is ``` + +## License + +The contents of this repository are licensed under the [Apache License, version 2.0](http://www.apache.org/licenses/LICENSE-2.0). diff --git a/docs/build_docs.py b/docs/build_docs.py index e01c92b57..817803406 100644 --- a/docs/build_docs.py +++ b/docs/build_docs.py @@ -26,6 +26,7 @@ import textwrap import typing +# For showing the conditional imports and types in `content_types.py` typing.TYPE_CHECKING = True from absl import app