diff --git a/cohere-openapi.yaml b/cohere-openapi.yaml index 946a97d91..f11568eb3 100644 --- a/cohere-openapi.yaml +++ b/cohere-openapi.yaml @@ -8078,7 +8078,11 @@ paths: import ( "context" + "encoding/base64" + "fmt" + "io" "log" + "net/http" cohere "github.com/cohere-ai/cohere-go/v2" client "github.com/cohere-ai/cohere-go/v2/client" @@ -8086,12 +8090,31 @@ paths: func main() { + // Fetch the image + resp, err := http.Get("https://cohere.com/favicon-32x32.png") + if err != nil { + log.Println("Error fetching the image:", err) + return + } + defer resp.Body.Close() + + // Read the image content + buffer, err := io.ReadAll(resp.Body) + if err != nil { + log.Println("Error reading the image content:", err) + return + } + + stringifiedBuffer := base64.StdEncoding.EncodeToString(buffer) + contentType := resp.Header.Get("Content-Type") + imageBase64 := fmt.Sprintf("data:%s;base64,%s", contentType, stringifiedBuffer) + co := client.NewClient(client.WithToken("<>")) - resp, err := co.Embed( + embed, err := co.Embed( context.TODO(), &cohere.EmbedRequest{ - Images: []string{""}, + Images: []string{imageBase64}, Model: cohere.String("embed-english-v3.0"), InputType: cohere.EmbedInputTypeImage.Ptr(), EmbeddingTypes: []cohere.EmbeddingType{cohere.EmbeddingTypeFloat}, @@ -8102,7 +8125,7 @@ paths: log.Fatal(err) } - log.Printf("%+v", resp) + log.Printf("%+v", embed) } - sdk: typescript name: Images @@ -8116,13 +8139,17 @@ paths: (async () => { + const image = await fetch('https://cohere.com/favicon-32x32.png'); + const buffer = await image.arrayBuffer(); + const stringifiedBuffer = Buffer.from(buffer).toString('base64'); + const contentType = image.headers.get('content-type'); + const imageBase64 = `data:${contentType};base64,${stringifiedBuffer}`; + const embed = await cohere.embed({ model: 'embed-english-v3.0', inputType: 'image', embeddingTypes: ['float'], - images: [ - '', - ], + images: [imageBase64], }); console.log(embed); })(); @@ -8131,17 +8158,33 @@ paths: code: > import cohere + import requests + + import base64 + co = cohere.Client("<>") + image = requests.get("https://cohere.com/favicon-32x32.png") + + stringified_buffer = + base64.b64encode(image.content).decode('utf-8') + + content_type = image.headers['Content-Type'] + + image_base64 = + f"data:{content_type};base64,{stringified_buffer}" + + response = co.embed( model="embed-english-v3.0", input_type="image", embedding_types=["float"], - images=[""] + images=[image_base64] ) + print(response) - sdk: java name: Images @@ -8159,6 +8202,16 @@ paths: import com.cohere.api.types.EmbeddingType; + import java.io.InputStream; + + import java.net.HttpURLConnection; + + import java.net.URI; + + import java.net.URL; + + import java.util.Base64; + import java.util.List; @@ -8166,12 +8219,25 @@ paths: public static void main(String[] args) { Cohere cohere = Cohere.builder().token("<>").clientName("snippet").build(); + URL url = + URI.toUrl( + "https://cohere.com/favicon-32x32.png"); + HttpURLConnection connection = (HttpURLConnection) url.openConnection(); + connection.connect(); + + InputStream inputStream = connection.getInputStream(); + byte[] buffer = inputStream.readAllBytes(); + inputStream.close(); + + String imageBase64 = + String.format( + "data:%s;base64,%s", + connection.getHeaderField("Content-Type"), Base64.getEncoder().encodeToString(buffer)); + EmbedResponse response = cohere.embed( EmbedRequest.builder() - .images( - List.of( - "")) + .images(List.of(imageBase64)) .model("embed-english-v3.0") .inputType(EmbedInputType.IMAGE) .embeddingTypes(List.of(EmbeddingType.FLOAT)) @@ -11602,7 +11668,11 @@ paths: import ( "context" + "encoding/base64" + "fmt" + "io" "log" + "net/http" cohere "github.com/cohere-ai/cohere-go/v2" client "github.com/cohere-ai/cohere-go/v2/client" @@ -11610,12 +11680,31 @@ paths: func main() { + // Fetch the image + resp, err := http.Get("https://cohere.com/favicon-32x32.png") + if err != nil { + log.Println("Error fetching the image:", err) + return + } + defer resp.Body.Close() + + // Read the image content + buffer, err := io.ReadAll(resp.Body) + if err != nil { + log.Println("Error reading the image content:", err) + return + } + + stringifiedBuffer := base64.StdEncoding.EncodeToString(buffer) + contentType := resp.Header.Get("Content-Type") + imageBase64 := fmt.Sprintf("data:%s;base64,%s", contentType, stringifiedBuffer) + co := client.NewClient(client.WithToken("<>")) - resp, err := co.V2.Embed( + embed, err := co.V2.Embed( context.TODO(), &cohere.V2EmbedRequest{ - Images: []string{""}, + Images: []string{imageBase64}, Model: "embed-english-v3.0", InputType: cohere.EmbedInputTypeImage, EmbeddingTypes: []cohere.EmbeddingType{cohere.EmbeddingTypeFloat}, @@ -11626,27 +11715,31 @@ paths: log.Fatal(err) } - log.Printf("%+v", resp) + log.Printf("%+v", embed) } - sdk: typescript name: Images code: > - const { CohereClientV2 } = require('cohere-ai'); + const { CohereClient } = require('cohere-ai'); - const cohere = new CohereClientV2({ + const cohere = new CohereClient({ token: '<>', }); (async () => { + const image = await fetch('https://cohere.com/favicon-32x32.png'); + const buffer = await image.arrayBuffer(); + const stringifiedBuffer = Buffer.from(buffer).toString('base64'); + const contentType = image.headers.get('content-type'); + const imageBase64 = `data:${contentType};base64,${stringifiedBuffer}`; + const embed = await cohere.v2.embed({ model: 'embed-english-v3.0', inputType: 'image', embeddingTypes: ['float'], - images: [ - '', - ], + images: [imageBase64], }); console.log(embed); })(); @@ -11655,15 +11748,30 @@ paths: code: > import cohere + import requests + + import base64 + + + co = cohere.ClientV2("<>") + + + image = requests.get("https://cohere.com/favicon-32x32.png") + + stringified_buffer = + base64.b64encode(image.content).decode('utf-8') - co = cohere.ClientV2(api_key="<>") + content_type = image.headers['Content-Type'] + + image_base64 = + f"data:{content_type};base64,{stringified_buffer}" response = co.embed( model="embed-english-v3.0", input_type="image", embedding_types=["float"], - images=[""] + images=[image_base64] ) @@ -11671,36 +11779,62 @@ paths: - sdk: java name: Images code: > - package embedpost; /* (C)2024 */ + package embedv2post; /* (C)2024 */ - import com.cohere.api.Cohere; + import java.io.InputStream; - import com.cohere.api.requests.EmbedRequest; + import java.net.HttpURLConnection; - import com.cohere.api.types.EmbedInputType; + import java.net.URI; - import com.cohere.api.types.EmbedResponse; + import java.net.URL; - import com.cohere.api.types.EmbeddingType; + import java.util.Base64; import java.util.List; + import com.cohere.api.Cohere; + + import com.cohere.api.resources.v2.requests.V2EmbedRequest; + + import com.cohere.api.types.EmbedByTypeResponse; + + import com.cohere.api.types.EmbedInputType; + + import com.cohere.api.types.EmbeddingType; + + public class EmbedImagePost { public static void main(String[] args) { Cohere cohere = Cohere.builder().token("<>").clientName("snippet").build(); - EmbedResponse response = - cohere.embed( - EmbedRequest.builder() - .images( - List.of( - "")) - .model("embed-english-v3.0") - .inputType(EmbedInputType.IMAGE) - .embeddingTypes(List.of(EmbeddingType.FLOAT)) - .build()); + URL url = + URI.toUrl( + "https://cohere.com/favicon-32x32.png"); + HttpURLConnection connection = (HttpURLConnection) url.openConnection(); + connection.connect(); + + InputStream inputStream = connection.getInputStream(); + byte[] buffer = inputStream.readAllBytes(); + inputStream.close(); + + String imageBase64 = + String.format( + "data:%s;base64,%s", + connection.getHeaderField("Content-Type"), Base64.getEncoder().encodeToString(buffer)); + + EmbedByTypeResponse response = + cohere + .v2() + .embed( + V2EmbedRequest.builder() + .model("embed-english-v3.0") + .inputType(EmbedInputType.IMAGE) + .images(List.of(imageBase64)) + .embeddingTypes(List.of(EmbeddingType.FLOAT)) + .build()); System.out.println(response); } @@ -12855,31 +12989,34 @@ paths: - sdk: java name: Texts code: > - package embedpost; /* (C)2024 */ + package embedv2post; /* (C)2024 */ - import com.cohere.api.Cohere; + import java.util.List; - import com.cohere.api.requests.EmbedRequest; - import com.cohere.api.types.EmbedInputType; + import com.cohere.api.Cohere; - import com.cohere.api.types.EmbedResponse; + import com.cohere.api.resources.v2.requests.V2EmbedRequest; - import java.util.List; + import com.cohere.api.types.EmbedByTypeResponse; + + import com.cohere.api.types.EmbedInputType; public class EmbedPost { public static void main(String[] args) { Cohere cohere = Cohere.builder().token("<>").clientName("snippet").build(); - EmbedResponse response = - cohere.embed( - EmbedRequest.builder() - .texts(List.of("hello", "goodbye")) - .model("embed-english-v3.0") - .inputType(EmbedInputType.CLASSIFICATION) - .build()); + EmbedByTypeResponse response = + cohere + .v2() + .embed( + V2EmbedRequest.builder() + .model("embed-english-v3.0") + .texts(List.of("hello", "goodbye")) + .inputType(EmbedInputType.CLASSIFICATION) + .build()); System.out.println(response); } diff --git a/snippets/snippets/go/embed-post/embed-image-post/main.go b/snippets/snippets/go/embed-post/embed-image-post/main.go index ae753984c..bbc3f4f42 100644 --- a/snippets/snippets/go/embed-post/embed-image-post/main.go +++ b/snippets/snippets/go/embed-post/embed-image-post/main.go @@ -2,19 +2,42 @@ package main import ( "context" + "encoding/base64" + "fmt" + "io" "log" + "net/http" cohere "github.com/cohere-ai/cohere-go/v2" client "github.com/cohere-ai/cohere-go/v2/client" ) func main() { + // Fetch the image + resp, err := http.Get("https://cohere.com/favicon-32x32.png") + if err != nil { + log.Println("Error fetching the image:", err) + return + } + defer resp.Body.Close() + + // Read the image content + buffer, err := io.ReadAll(resp.Body) + if err != nil { + log.Println("Error reading the image content:", err) + return + } + + stringifiedBuffer := base64.StdEncoding.EncodeToString(buffer) + contentType := resp.Header.Get("Content-Type") + imageBase64 := fmt.Sprintf("data:%s;base64,%s", contentType, stringifiedBuffer) + co := client.NewClient(client.WithToken("<>")) - resp, err := co.Embed( + embed, err := co.Embed( context.TODO(), &cohere.EmbedRequest{ - Images: []string{""}, + Images: []string{imageBase64}, Model: cohere.String("embed-english-v3.0"), InputType: cohere.EmbedInputTypeImage.Ptr(), EmbeddingTypes: []cohere.EmbeddingType{cohere.EmbeddingTypeFloat}, @@ -25,5 +48,5 @@ func main() { log.Fatal(err) } - log.Printf("%+v", resp) + log.Printf("%+v", embed) } diff --git a/snippets/snippets/go/embed-v2-post/embed-image-post/main.go b/snippets/snippets/go/embed-v2-post/embed-image-post/main.go index b34b765e0..061b34e31 100644 --- a/snippets/snippets/go/embed-v2-post/embed-image-post/main.go +++ b/snippets/snippets/go/embed-v2-post/embed-image-post/main.go @@ -2,19 +2,42 @@ package main import ( "context" + "encoding/base64" + "fmt" + "io" "log" + "net/http" cohere "github.com/cohere-ai/cohere-go/v2" client "github.com/cohere-ai/cohere-go/v2/client" ) func main() { + // Fetch the image + resp, err := http.Get("https://cohere.com/favicon-32x32.png") + if err != nil { + log.Println("Error fetching the image:", err) + return + } + defer resp.Body.Close() + + // Read the image content + buffer, err := io.ReadAll(resp.Body) + if err != nil { + log.Println("Error reading the image content:", err) + return + } + + stringifiedBuffer := base64.StdEncoding.EncodeToString(buffer) + contentType := resp.Header.Get("Content-Type") + imageBase64 := fmt.Sprintf("data:%s;base64,%s", contentType, stringifiedBuffer) + co := client.NewClient(client.WithToken("<>")) - resp, err := co.V2.Embed( + embed, err := co.V2.Embed( context.TODO(), &cohere.V2EmbedRequest{ - Images: []string{""}, + Images: []string{imageBase64}, Model: "embed-english-v3.0", InputType: cohere.EmbedInputTypeImage, EmbeddingTypes: []cohere.EmbeddingType{cohere.EmbeddingTypeFloat}, @@ -25,5 +48,5 @@ func main() { log.Fatal(err) } - log.Printf("%+v", resp) + log.Printf("%+v", embed) } diff --git a/snippets/snippets/java/app/src/main/java/embedpost/EmbedImagePost.java b/snippets/snippets/java/app/src/main/java/embedpost/EmbedImagePost.java index c1a425456..0db61f204 100644 --- a/snippets/snippets/java/app/src/main/java/embedpost/EmbedImagePost.java +++ b/snippets/snippets/java/app/src/main/java/embedpost/EmbedImagePost.java @@ -5,18 +5,36 @@ import com.cohere.api.types.EmbedInputType; import com.cohere.api.types.EmbedResponse; import com.cohere.api.types.EmbeddingType; +import java.io.InputStream; +import java.net.HttpURLConnection; +import java.net.URI; +import java.net.URL; +import java.util.Base64; import java.util.List; public class EmbedImagePost { public static void main(String[] args) { Cohere cohere = Cohere.builder().token("<>").clientName("snippet").build(); + URL url = + URI.toUrl( + "https://cohere.com/favicon-32x32.png"); + HttpURLConnection connection = (HttpURLConnection) url.openConnection(); + connection.connect(); + + InputStream inputStream = connection.getInputStream(); + byte[] buffer = inputStream.readAllBytes(); + inputStream.close(); + + String imageBase64 = + String.format( + "data:%s;base64,%s", + connection.getHeaderField("Content-Type"), Base64.getEncoder().encodeToString(buffer)); + EmbedResponse response = cohere.embed( EmbedRequest.builder() - .images( - List.of( - "")) + .images(List.of(imageBase64)) .model("embed-english-v3.0") .inputType(EmbedInputType.IMAGE) .embeddingTypes(List.of(EmbeddingType.FLOAT)) diff --git a/snippets/snippets/java/app/src/main/java/embedv2post/EmbedImagePost.java b/snippets/snippets/java/app/src/main/java/embedv2post/EmbedImagePost.java new file mode 100644 index 000000000..e042b3d65 --- /dev/null +++ b/snippets/snippets/java/app/src/main/java/embedv2post/EmbedImagePost.java @@ -0,0 +1,48 @@ +package embedv2post; /* (C)2024 */ + +import java.io.InputStream; +import java.net.HttpURLConnection; +import java.net.URI; +import java.net.URL; +import java.util.Base64; +import java.util.List; + +import com.cohere.api.Cohere; +import com.cohere.api.resources.v2.requests.V2EmbedRequest; +import com.cohere.api.types.EmbedByTypeResponse; +import com.cohere.api.types.EmbedInputType; +import com.cohere.api.types.EmbeddingType; + +public class EmbedImagePost { + public static void main(String[] args) { + Cohere cohere = Cohere.builder().token("<>").clientName("snippet").build(); + + URL url = + URI.toUrl( + "https://cohere.com/favicon-32x32.png"); + HttpURLConnection connection = (HttpURLConnection) url.openConnection(); + connection.connect(); + + InputStream inputStream = connection.getInputStream(); + byte[] buffer = inputStream.readAllBytes(); + inputStream.close(); + + String imageBase64 = + String.format( + "data:%s;base64,%s", + connection.getHeaderField("Content-Type"), Base64.getEncoder().encodeToString(buffer)); + + EmbedByTypeResponse response = + cohere + .v2() + .embed( + V2EmbedRequest.builder() + .model("embed-english-v3.0") + .inputType(EmbedInputType.IMAGE) + .images(List.of(imageBase64)) + .embeddingTypes(List.of(EmbeddingType.FLOAT)) + .build()); + + System.out.println(response); + } +} diff --git a/snippets/snippets/java/app/src/main/java/embedv2post/EmbedPost.java b/snippets/snippets/java/app/src/main/java/embedv2post/EmbedPost.java new file mode 100644 index 000000000..953f5ae59 --- /dev/null +++ b/snippets/snippets/java/app/src/main/java/embedv2post/EmbedPost.java @@ -0,0 +1,26 @@ +package embedv2post; /* (C)2024 */ + +import java.util.List; + +import com.cohere.api.Cohere; +import com.cohere.api.resources.v2.requests.V2EmbedRequest; +import com.cohere.api.types.EmbedByTypeResponse; +import com.cohere.api.types.EmbedInputType; + +public class EmbedPost { + public static void main(String[] args) { + Cohere cohere = Cohere.builder().token("<>").clientName("snippet").build(); + + EmbedByTypeResponse response = + cohere + .v2() + .embed( + V2EmbedRequest.builder() + .model("embed-english-v3.0") + .texts(List.of("hello", "goodbye")) + .inputType(EmbedInputType.CLASSIFICATION) + .build()); + + System.out.println(response); + } +} diff --git a/snippets/snippets/node/embed-post/embed-image-post.ts b/snippets/snippets/node/embed-post/embed-image-post.ts index 7b0734e41..cf1d5355c 100644 --- a/snippets/snippets/node/embed-post/embed-image-post.ts +++ b/snippets/snippets/node/embed-post/embed-image-post.ts @@ -5,13 +5,17 @@ const cohere = new CohereClient({ }); (async () => { + const image = await fetch('https://cohere.com/favicon-32x32.png'); + const buffer = await image.arrayBuffer(); + const stringifiedBuffer = Buffer.from(buffer).toString('base64'); + const contentType = image.headers.get('content-type'); + const imageBase64 = `data:${contentType};base64,${stringifiedBuffer}`; + const embed = await cohere.embed({ model: 'embed-english-v3.0', inputType: 'image', embeddingTypes: ['float'], - images: [ - '', - ], + images: [imageBase64], }); console.log(embed); })(); diff --git a/snippets/snippets/node/embed-v2-post/embed-image-post.ts b/snippets/snippets/node/embed-v2-post/embed-image-post.ts index f1d11a856..84d725dd2 100644 --- a/snippets/snippets/node/embed-v2-post/embed-image-post.ts +++ b/snippets/snippets/node/embed-v2-post/embed-image-post.ts @@ -1,17 +1,21 @@ -const { CohereClientV2 } = require('cohere-ai'); +const { CohereClient } = require('cohere-ai'); -const cohere = new CohereClientV2({ +const cohere = new CohereClient({ token: '<>', }); (async () => { + const image = await fetch('https://cohere.com/favicon-32x32.png'); + const buffer = await image.arrayBuffer(); + const stringifiedBuffer = Buffer.from(buffer).toString('base64'); + const contentType = image.headers.get('content-type'); + const imageBase64 = `data:${contentType};base64,${stringifiedBuffer}`; + const embed = await cohere.v2.embed({ model: 'embed-english-v3.0', inputType: 'image', embeddingTypes: ['float'], - images: [ - '', - ], + images: [imageBase64], }); console.log(embed); })(); diff --git a/snippets/snippets/python/embed-post/embed-image-post.py b/snippets/snippets/python/embed-post/embed-image-post.py index 5b1bdb26f..a5d405117 100644 --- a/snippets/snippets/python/embed-post/embed-image-post.py +++ b/snippets/snippets/python/embed-post/embed-image-post.py @@ -1,11 +1,19 @@ import cohere +import requests +import base64 co = cohere.Client("<>") +image = requests.get("https://cohere.com/favicon-32x32.png") +stringified_buffer = base64.b64encode(image.content).decode('utf-8') +content_type = image.headers['Content-Type'] +image_base64 = f"data:{content_type};base64,{stringified_buffer}" + response = co.embed( model="embed-english-v3.0", input_type="image", embedding_types=["float"], - images=[""] + images=[image_base64] ) + print(response) diff --git a/snippets/snippets/python/embed-v2-post/embed-image-post.py b/snippets/snippets/python/embed-v2-post/embed-image-post.py index 43ddcca3e..dc35355f4 100644 --- a/snippets/snippets/python/embed-v2-post/embed-image-post.py +++ b/snippets/snippets/python/embed-v2-post/embed-image-post.py @@ -1,12 +1,19 @@ import cohere +import requests +import base64 -co = cohere.ClientV2(api_key="<>") +co = cohere.ClientV2("<>") + +image = requests.get("https://cohere.com/favicon-32x32.png") +stringified_buffer = base64.b64encode(image.content).decode('utf-8') +content_type = image.headers['Content-Type'] +image_base64 = f"data:{content_type};base64,{stringified_buffer}" response = co.embed( model="embed-english-v3.0", input_type="image", embedding_types=["float"], - images=[""] + images=[image_base64] ) print(response)