forked from google-gemini/generative-ai-android
-
Notifications
You must be signed in to change notification settings - Fork 7
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add documentation snippets to the repo (google-gemini#182)
Internal b/346393026 --------- Co-authored-by: rachelsaunders <[email protected]> Co-authored-by: David Motsonashvili <[email protected]> Co-authored-by: David Motsonashvili <[email protected]>
- Loading branch information
1 parent
fa3380d
commit 771866d
Showing
25 changed files
with
1,773 additions
and
0 deletions.
There are no files selected for viewing
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
# Developing | ||
|
||
The snippets in this directory are organized to simplify their use as documentation. | ||
|
||
## Snippets requirements | ||
|
||
All snippets must compile. | ||
|
||
## Workflow | ||
|
||
1. In Android Studio, import the `generativeai-android-sample` project | ||
2. In the left-hand bar, using the "Android" prespective, you'll | ||
notice that the within the `app` module, there are two packages: | ||
- `com.google.ai.client.generative.samples` which contains the snippets | ||
- `com.google.ai.sample` which contains the actual quickstart app | ||
3. Make all necessary changes to the code in the | ||
`com.google.ai.client.generative.samples` snippets | ||
4. To compile the snippets, compile the `app` module itself. | ||
|
||
**IMPORTANT:** Always add both the Kotlin and the Java versions of the | ||
snippets at the same time to maintain parity. | ||
|
||
### How does it work | ||
|
||
Under the hood, the configuration of the app module, in | ||
`generativeai-android-sample/build.gradle.kts`, has been modified to | ||
include in the main `sourceSet` the code for the samples. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
GenerativeAI sample snippets for Android in Kotlin and Java |
22 changes: 22 additions & 0 deletions
22
samples/src/main/java/com/google/ai/client/generative/samples/BuildConfig.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
// Copyright 2024 Google LLC | ||
// | ||
// Licensed under the Apache License, Version 2.0 (the "License"); | ||
// you may not use this file except in compliance with the License. | ||
// You may obtain a copy of the License at | ||
// | ||
// http://www.apache.org/licenses/LICENSE-2.0 | ||
// | ||
// Unless required by applicable law or agreed to in writing, software | ||
// distributed under the License is distributed on an "AS IS" BASIS, | ||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
// See the License for the specific language governing permissions and | ||
// limitations under the License. | ||
|
||
package com.google.ai.client.generative.samples; | ||
|
||
// This file was manually created for testing purposes only. | ||
// For instructions on how to generate this file automatically, see the section | ||
// "Set up your API Key" in https://ai.google.dev/gemini-api/docs/quickstart?lang=android | ||
public class BuildConfig { | ||
public static String apiKey = "invalidApiKey"; | ||
} |
107 changes: 107 additions & 0 deletions
107
samples/src/main/java/com/google/ai/client/generative/samples/chat.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,107 @@ | ||
/* | ||
* Copyright 2024 Google LLC | ||
* | ||
* Licensed under the Apache License, Version 2.0 (the "License"); | ||
* you may not use this file except in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, software | ||
* distributed under the License is distributed on an "AS IS" BASIS, | ||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
*/ | ||
|
||
package com.google.ai.client.generative.samples | ||
|
||
import android.content.Context | ||
import android.graphics.Bitmap | ||
import android.graphics.BitmapFactory | ||
import com.google.ai.client.generativeai.GenerativeModel | ||
import com.google.ai.client.generativeai.type.content | ||
import com.google.ai.sample.R | ||
|
||
// Set up your API Key | ||
// ==================== | ||
// | ||
// To use the Gemini API, you'll need an API key. To learn more, see | ||
// the "Set up your API Key section" in the [Gemini API | ||
// quickstart](https://ai.google.dev/gemini-api/docs/quickstart?lang=android#set-up-api-key). | ||
|
||
suspend fun chat() { | ||
// [START chat] | ||
val generativeModel = | ||
GenerativeModel( | ||
// Specify a Gemini model appropriate for your use case | ||
modelName = "gemini-1.5-flash", | ||
// Access your API key as a Build Configuration variable (see "Set up your API key" above) | ||
apiKey = BuildConfig.apiKey) | ||
|
||
val chat = | ||
generativeModel.startChat( | ||
history = | ||
listOf( | ||
content(role = "user") { text("Hello, I have 2 dogs in my house.") }, | ||
content(role = "model") { | ||
text("Great to meet you. What would you like to know?") | ||
})) | ||
|
||
val response = chat.sendMessage("How many paws are in my house?") | ||
print(response.text) | ||
// [END chat] | ||
} | ||
|
||
suspend fun chatStreaming() { | ||
// [START chat_streaming] | ||
// Use streaming with multi-turn conversations (like chat) | ||
val generativeModel = | ||
GenerativeModel( | ||
// Specify a Gemini model appropriate for your use case | ||
modelName = "gemini-1.5-flash", | ||
// Access your API key as a Build Configuration variable (see "Set up your API key" above) | ||
apiKey = BuildConfig.apiKey) | ||
|
||
val chat = | ||
generativeModel.startChat( | ||
history = | ||
listOf( | ||
content(role = "user") { text("Hello, I have 2 dogs in my house.") }, | ||
content(role = "model") { | ||
text("Great to meet you. What would you like to know?") | ||
})) | ||
|
||
chat.sendMessageStream("How many paws are in my house?").collect { chunk -> print(chunk.text) } | ||
// [END chat_streaming] | ||
} | ||
|
||
suspend fun chatStreamingWithImages(context: Context) { | ||
// [START chat_streaming_with_images] | ||
// Use streaming with multi-turn conversations (like chat) | ||
val generativeModel = | ||
GenerativeModel( | ||
// Specify a Gemini model appropriate for your use case | ||
modelName = "gemini-1.5-flash", | ||
// Access your API key as a Build Configuration variable (see "Set up your API key" above) | ||
apiKey = BuildConfig.apiKey) | ||
|
||
val chat = | ||
generativeModel.startChat( | ||
history = | ||
listOf( | ||
content(role = "user") { text("Hello, I have 2 dogs in my house.") }, | ||
content(role = "model") { | ||
text("Great to meet you. What would you like to know?") | ||
})) | ||
|
||
val image: Bitmap = BitmapFactory.decodeResource(context.resources, R.drawable.image) | ||
|
||
val inputContent = content { | ||
image(image) | ||
text("This is a picture of them, what breed are they?") | ||
} | ||
|
||
chat.sendMessageStream(inputContent).collect { chunk -> print(chunk.text) } | ||
// [END chat_streaming_with_images] | ||
} |
63 changes: 63 additions & 0 deletions
63
samples/src/main/java/com/google/ai/client/generative/samples/code_execution.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,63 @@ | ||
/* | ||
* Copyright 2024 Google LLC | ||
* | ||
* Licensed under the Apache License, Version 2.0 (the "License"); | ||
* you may not use this file except in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, software | ||
* distributed under the License is distributed on an "AS IS" BASIS, | ||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
*/ | ||
|
||
package com.google.ai.client.generative.samples | ||
|
||
import com.google.ai.client.generativeai.GenerativeModel | ||
import com.google.ai.client.generativeai.type.Tool | ||
|
||
// Set up your API Key | ||
// ==================== | ||
// | ||
// To use the Gemini API, you'll need an API key. To learn more, see | ||
// the "Set up your API Key section" in the [Gemini API | ||
// quickstart](https://ai.google.dev/gemini-api/docs/quickstart?lang=android#set-up-api-key). | ||
|
||
suspend fun codeExecutionBasic() { | ||
// [START code_execution_basic] | ||
|
||
val model = GenerativeModel( | ||
// Specify a Gemini model appropriate for your use case | ||
modelName = "gemini-1.5-pro", | ||
// Access your API key as a Build Configuration variable (see "Set up your API key" above) | ||
apiKey = BuildConfig.apiKey, | ||
tools = listOf(Tool.CODE_EXECUTION) | ||
) | ||
|
||
val response = model.generateContent("What is the sum of the first 50 prime numbers?") | ||
|
||
println(response.text) | ||
// [END code_execution_basic] | ||
} | ||
|
||
suspend fun codeExecutionChat() { | ||
// [START code_execution_chat] | ||
|
||
val model = GenerativeModel( | ||
// Specify a Gemini model appropriate for your use case | ||
modelName = "gemini-1.5-pro", | ||
// Access your API key as a Build Configuration variable (see "Set up your API key" above) | ||
apiKey = BuildConfig.apiKey, | ||
tools = listOf(Tool.CODE_EXECUTION) | ||
) | ||
|
||
val chat = model.startChat() | ||
|
||
val response = chat.sendMessage("What is the sum of the first 50 prime numbers?") | ||
|
||
println(response.text) | ||
// [END code_execution_chat] | ||
} |
50 changes: 50 additions & 0 deletions
50
samples/src/main/java/com/google/ai/client/generative/samples/configure_model_parameters.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,50 @@ | ||
/* | ||
* Copyright 2024 Google LLC | ||
* | ||
* Licensed under the Apache License, Version 2.0 (the "License"); | ||
* you may not use this file except in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, software | ||
* distributed under the License is distributed on an "AS IS" BASIS, | ||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
*/ | ||
|
||
package com.google.ai.client.generative.samples | ||
|
||
import com.google.ai.client.generativeai.GenerativeModel | ||
import com.google.ai.client.generativeai.type.generationConfig | ||
|
||
// Set up your API Key | ||
// ==================== | ||
// | ||
// To use the Gemini API, you'll need an API key. To learn more, see | ||
// the "Set up your API Key section" in the [Gemini API | ||
// quickstart](https://ai.google.dev/gemini-api/docs/quickstart?lang=android#set-up-api-key). | ||
|
||
|
||
suspend fun configureModel() { | ||
// [START configure_model_parameters] | ||
val config = generationConfig { | ||
temperature = 0.9f | ||
topK = 16 | ||
topP = 0.1f | ||
maxOutputTokens = 200 | ||
stopSequences = listOf("red") | ||
} | ||
|
||
val generativeModel = | ||
GenerativeModel( | ||
// Specify a Gemini model appropriate for your use case | ||
modelName = "gemini-1.5-flash", | ||
apiKey = BuildConfig.apiKey, | ||
generationConfig = config) | ||
// [END configure_model_parameters] | ||
|
||
// Added to silence the compiler warning about unused variable. | ||
print(generativeModel) | ||
} |
26 changes: 26 additions & 0 deletions
26
samples/src/main/java/com/google/ai/client/generative/samples/controlled_generation.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
/* | ||
* Copyright 2024 Google LLC | ||
* | ||
* Licensed under the Apache License, Version 2.0 (the "License"); | ||
* you may not use this file except in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, software | ||
* distributed under the License is distributed on an "AS IS" BASIS, | ||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
*/ | ||
|
||
package com.google.ai.client.generative.samples | ||
|
||
// Set up your API Key | ||
// ==================== | ||
// | ||
// To use the Gemini API, you'll need an API key. To learn more, see | ||
// the "Set up your API Key section" in the [Gemini API | ||
// quickstart](https://ai.google.dev/gemini-api/docs/quickstart?lang=android#set-up-api-key). | ||
|
||
// TODO |
94 changes: 94 additions & 0 deletions
94
samples/src/main/java/com/google/ai/client/generative/samples/count_tokens.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,94 @@ | ||
/* | ||
* Copyright 2024 Google LLC | ||
* | ||
* Licensed under the Apache License, Version 2.0 (the "License"); | ||
* you may not use this file except in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, software | ||
* distributed under the License is distributed on an "AS IS" BASIS, | ||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
*/ | ||
|
||
package com.google.ai.client.generative.samples | ||
|
||
import android.content.Context | ||
import android.graphics.Bitmap | ||
import android.graphics.BitmapFactory | ||
import com.google.ai.client.generativeai.GenerativeModel | ||
import com.google.ai.client.generativeai.type.content | ||
import com.google.ai.sample.R | ||
|
||
// Set up your API Key | ||
// ==================== | ||
// | ||
// To use the Gemini API, you'll need an API key. To learn more, see | ||
// the "Set up your API Key section" in the [Gemini API | ||
// quickstart](https://ai.google.dev/gemini-api/docs/quickstart?lang=android#set-up-api-key). | ||
|
||
suspend fun tokensTextOnly() { | ||
// [START tokens_text_only] | ||
val generativeModel = | ||
GenerativeModel( | ||
// Specify a Gemini model appropriate for your use case | ||
modelName = "gemini-1.5-flash", | ||
// Access your API key as a Build Configuration variable (see "Set up your API key" above) | ||
apiKey = BuildConfig.apiKey) | ||
|
||
// For text-only input | ||
val (totalTokens) = generativeModel.countTokens("Write a story about a magic backpack.") | ||
print(totalTokens) | ||
// [END tokens_text_only] | ||
} | ||
|
||
suspend fun tokensChat() { | ||
// [START tokens_chat] | ||
val generativeModel = | ||
GenerativeModel( | ||
// Specify a Gemini model appropriate for your use case | ||
modelName = "gemini-1.5-flash", | ||
// Access your API key as a Build Configuration variable (see "Set up your API key" above) | ||
apiKey = BuildConfig.apiKey) | ||
|
||
val chat = | ||
generativeModel.startChat( | ||
history = | ||
listOf( | ||
content(role = "user") { text("Hello, I have 2 dogs in my house.") }, | ||
content(role = "model") { | ||
text("Great to meet you. What would you like to know?") | ||
})) | ||
|
||
val history = chat.history | ||
val messageContent = content { text("This is the message I intend to send") } | ||
val (totalTokens) = generativeModel.countTokens(*history.toTypedArray(), messageContent) | ||
print(totalTokens) | ||
// [END tokens_chat] | ||
} | ||
|
||
suspend fun tokensMultimodalImageInline(context: Context) { | ||
// [START tokens_multimodal_image_inline] | ||
val generativeModel = | ||
GenerativeModel( | ||
// Specify a Gemini model appropriate for your use case | ||
modelName = "gemini-1.5-flash", | ||
// Access your API key as a Build Configuration variable (see "Set up your API key" above) | ||
apiKey = BuildConfig.apiKey) | ||
|
||
val image1: Bitmap = BitmapFactory.decodeResource(context.resources, R.drawable.image1) | ||
val image2: Bitmap = BitmapFactory.decodeResource(context.resources, R.drawable.image2) | ||
|
||
val multiModalContent = content { | ||
image(image1) | ||
image(image2) | ||
text("What's the difference between these pictures?") | ||
} | ||
|
||
val (totalTokens) = generativeModel.countTokens(multiModalContent) | ||
print(totalTokens) | ||
// [END tokens_multimodal_image_inline] | ||
} |
Oops, something went wrong.