Skip to content

Commit

Permalink
Update README.md (#107)
Browse files Browse the repository at this point in the history
* Update README.md

* Update README.md

* Updated Gemini sample code in README

* Update docs/build_docs.py

---------

Co-authored-by: Mark McDonald <macd@google.com>
  • Loading branch information
MarkDaoust and markmcd authored Dec 13, 2023
1 parent 4f05500 commit 0cd555b
Show file tree
Hide file tree
Showing 2 changed files with 124 additions and 20 deletions.
143 changes: 123 additions & 20 deletions README.md
Original file line number Diff line number Diff line change
@@ -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:

```

This comment has been minimized.

Copy link
@AndrewVoirol

AndrewVoirol Dec 13, 2023

import google.generativeai as genai
from pathlib import Path

genai.configure(api_key="YOUR_ACTUAL_API_KEY")

# Ensure that the model ID is correct and that you have access to it
model = genai.GenerativeModel('gemini-pro-vision')

# Read the image as binary data
image_path = Path('image.png')
image_data = image_path.read_bytes()

prompt = "Give me a recipe for this:"
contents = {
    'parts': [
        {'mime_type': 'image/png', 'data': image_data},
        {'text': prompt}
    ]
}

# Send the prompt and image data to the model
response = model.generate_content(contents=contents)

# Print the result
print(response.text)
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).
1 change: 1 addition & 0 deletions docs/build_docs.py
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down

0 comments on commit 0cd555b

Please sign in to comment.