All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.ibm.watson.visual_recognition.v3.VisualRecognition Maven / Gradle / Ivy

There is a newer version: 9.3.1
Show newest version
/*
 * (C) Copyright IBM Corp. 2016, 2020.
 *
 * 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.ibm.watson.visual_recognition.v3;

import com.ibm.cloud.sdk.core.http.RequestBuilder;
import com.ibm.cloud.sdk.core.http.ResponseConverter;
import com.ibm.cloud.sdk.core.http.ServiceCall;
import com.ibm.cloud.sdk.core.security.Authenticator;
import com.ibm.cloud.sdk.core.security.ConfigBasedAuthenticatorFactory;
import com.ibm.cloud.sdk.core.service.BaseService;
import com.ibm.cloud.sdk.core.util.RequestUtils;
import com.ibm.cloud.sdk.core.util.ResponseConverterUtils;
import com.ibm.watson.common.SdkCommon;
import com.ibm.watson.visual_recognition.v3.model.ClassifiedImages;
import com.ibm.watson.visual_recognition.v3.model.Classifier;
import com.ibm.watson.visual_recognition.v3.model.Classifiers;
import com.ibm.watson.visual_recognition.v3.model.ClassifyOptions;
import com.ibm.watson.visual_recognition.v3.model.CreateClassifierOptions;
import com.ibm.watson.visual_recognition.v3.model.DeleteClassifierOptions;
import com.ibm.watson.visual_recognition.v3.model.DeleteUserDataOptions;
import com.ibm.watson.visual_recognition.v3.model.GetClassifierOptions;
import com.ibm.watson.visual_recognition.v3.model.GetCoreMlModelOptions;
import com.ibm.watson.visual_recognition.v3.model.ListClassifiersOptions;
import com.ibm.watson.visual_recognition.v3.model.UpdateClassifierOptions;
import java.io.InputStream;
import java.util.Map;
import java.util.Map.Entry;
import okhttp3.MultipartBody;

/**
 * The IBM Watson™ Visual Recognition service uses deep learning algorithms to identify scenes
 * and objects in images that you upload to the service. You can create and train a custom
 * classifier to identify subjects that suit your needs.
 *
 * @version v3
 * @see Visual Recognition
 */
public class VisualRecognition extends BaseService {

  private static final String DEFAULT_SERVICE_NAME = "visual_recognition";

  private static final String DEFAULT_SERVICE_URL =
      "https://gateway.watsonplatform.net/visual-recognition/api";

  private String versionDate;

  /**
   * Constructs a new `VisualRecognition` client using the DEFAULT_SERVICE_NAME.
   *
   * @param versionDate The version date (yyyy-MM-dd) of the REST API to use. Specifying this value
   *     will keep your API calls from failing when the service introduces breaking changes.
   */
  public VisualRecognition(String versionDate) {
    this(
        versionDate,
        DEFAULT_SERVICE_NAME,
        ConfigBasedAuthenticatorFactory.getAuthenticator(DEFAULT_SERVICE_NAME));
  }

  /**
   * Constructs a new `VisualRecognition` client with the DEFAULT_SERVICE_NAME and the specified
   * Authenticator.
   *
   * @param versionDate The version date (yyyy-MM-dd) of the REST API to use. Specifying this value
   *     will keep your API calls from failing when the service introduces breaking changes.
   * @param authenticator the Authenticator instance to be configured for this service
   */
  public VisualRecognition(String versionDate, Authenticator authenticator) {
    this(versionDate, DEFAULT_SERVICE_NAME, authenticator);
  }

  /**
   * Constructs a new `VisualRecognition` client with the specified serviceName.
   *
   * @param versionDate The version date (yyyy-MM-dd) of the REST API to use. Specifying this value
   *     will keep your API calls from failing when the service introduces breaking changes.
   * @param serviceName The name of the service to configure.
   */
  public VisualRecognition(String versionDate, String serviceName) {
    this(versionDate, serviceName, ConfigBasedAuthenticatorFactory.getAuthenticator(serviceName));
  }

  /**
   * Constructs a new `VisualRecognition` client with the specified Authenticator and serviceName.
   *
   * @param versionDate The version date (yyyy-MM-dd) of the REST API to use. Specifying this value
   *     will keep your API calls from failing when the service introduces breaking changes.
   * @param serviceName The name of the service to configure.
   * @param authenticator the Authenticator instance to be configured for this service
   */
  public VisualRecognition(String versionDate, String serviceName, Authenticator authenticator) {
    super(serviceName, authenticator);
    setServiceUrl(DEFAULT_SERVICE_URL);
    com.ibm.cloud.sdk.core.util.Validator.isTrue(
        (versionDate != null) && !versionDate.isEmpty(), "version cannot be null.");
    this.versionDate = versionDate;
    this.configureService(serviceName);
  }

  /**
   * Classify images.
   *
   * 

Classify images with built-in or custom classifiers. * * @param classifyOptions the {@link ClassifyOptions} containing the options for the call * @return a {@link ServiceCall} with a response type of {@link ClassifiedImages} */ public ServiceCall classify(ClassifyOptions classifyOptions) { com.ibm.cloud.sdk.core.util.Validator.notNull( classifyOptions, "classifyOptions cannot be null"); com.ibm.cloud.sdk.core.util.Validator.isTrue( (classifyOptions.imagesFile() != null) || (classifyOptions.url() != null) || (classifyOptions.threshold() != null) || (classifyOptions.owners() != null) || (classifyOptions.classifierIds() != null), "At least one of imagesFile, url, threshold, owners, or classifierIds must be supplied."); String[] pathSegments = {"v3/classify"}; RequestBuilder builder = RequestBuilder.post(RequestBuilder.constructHttpUrl(getServiceUrl(), pathSegments)); builder.query("version", versionDate); Map sdkHeaders = SdkCommon.getSdkHeaders("watson_vision_combined", "v3", "classify"); for (Entry header : sdkHeaders.entrySet()) { builder.header(header.getKey(), header.getValue()); } builder.header("Accept", "application/json"); if (classifyOptions.acceptLanguage() != null) { builder.header("Accept-Language", classifyOptions.acceptLanguage()); } MultipartBody.Builder multipartBuilder = new MultipartBody.Builder(); multipartBuilder.setType(MultipartBody.FORM); if (classifyOptions.imagesFile() != null) { okhttp3.RequestBody imagesFileBody = RequestUtils.inputStreamBody( classifyOptions.imagesFile(), classifyOptions.imagesFileContentType()); multipartBuilder.addFormDataPart( "images_file", classifyOptions.imagesFilename(), imagesFileBody); } if (classifyOptions.url() != null) { multipartBuilder.addFormDataPart("url", classifyOptions.url()); } if (classifyOptions.threshold() != null) { multipartBuilder.addFormDataPart("threshold", String.valueOf(classifyOptions.threshold())); } if (classifyOptions.owners() != null) { multipartBuilder.addFormDataPart("owners", RequestUtils.join(classifyOptions.owners(), ",")); } if (classifyOptions.classifierIds() != null) { multipartBuilder.addFormDataPart( "classifier_ids", RequestUtils.join(classifyOptions.classifierIds(), ",")); } builder.body(multipartBuilder.build()); ResponseConverter responseConverter = ResponseConverterUtils.getValue( new com.google.gson.reflect.TypeToken() {}.getType()); return createServiceCall(builder.build(), responseConverter); } /** * Classify images. * *

Classify images with built-in or custom classifiers. * * @return a {@link ServiceCall} with a response type of {@link ClassifiedImages} */ public ServiceCall classify() { return classify(null); } /** * Create a classifier. * *

Train a new multi-faceted classifier on the uploaded image data. Create your custom * classifier with positive or negative example training images. Include at least two sets of * examples, either two positive example files or one positive and one negative file. You can * upload a maximum of 256 MB per call. * *

**Tips when creating:** * *

- If you set the **X-Watson-Learning-Opt-Out** header parameter to `true` when you create a * classifier, the example training images are not stored. Save your training images locally. For * more information, see [Data collection](#data-collection). * *

- Encode all names in UTF-8 if they contain non-ASCII characters (.zip and image file names, * and classifier and class names). The service assumes UTF-8 encoding if it encounters non-ASCII * characters. * * @param createClassifierOptions the {@link CreateClassifierOptions} containing the options for * the call * @return a {@link ServiceCall} with a response type of {@link Classifier} */ public ServiceCall createClassifier(CreateClassifierOptions createClassifierOptions) { com.ibm.cloud.sdk.core.util.Validator.notNull( createClassifierOptions, "createClassifierOptions cannot be null"); String[] pathSegments = {"v3/classifiers"}; RequestBuilder builder = RequestBuilder.post(RequestBuilder.constructHttpUrl(getServiceUrl(), pathSegments)); builder.query("version", versionDate); Map sdkHeaders = SdkCommon.getSdkHeaders("watson_vision_combined", "v3", "createClassifier"); for (Entry header : sdkHeaders.entrySet()) { builder.header(header.getKey(), header.getValue()); } builder.header("Accept", "application/json"); MultipartBody.Builder multipartBuilder = new MultipartBody.Builder(); multipartBuilder.setType(MultipartBody.FORM); multipartBuilder.addFormDataPart("name", createClassifierOptions.name()); for (Map.Entry entry : createClassifierOptions.positiveExamples().entrySet()) { String partName = String.format("%s_positive_examples", entry.getKey()); okhttp3.RequestBody part = RequestUtils.inputStreamBody(entry.getValue(), "application/octet-stream"); multipartBuilder.addFormDataPart(partName, entry.getKey() + ".zip", part); } if (createClassifierOptions.negativeExamples() != null) { okhttp3.RequestBody negativeExamplesBody = RequestUtils.inputStreamBody( createClassifierOptions.negativeExamples(), "application/octet-stream"); String negativeExamplesFilename = createClassifierOptions.negativeExamplesFilename(); if (!negativeExamplesFilename.contains(".")) { negativeExamplesFilename += ".zip"; } multipartBuilder.addFormDataPart( "negative_examples", negativeExamplesFilename, negativeExamplesBody); } builder.body(multipartBuilder.build()); ResponseConverter responseConverter = ResponseConverterUtils.getValue( new com.google.gson.reflect.TypeToken() {}.getType()); return createServiceCall(builder.build(), responseConverter); } /** * Retrieve a list of classifiers. * * @param listClassifiersOptions the {@link ListClassifiersOptions} containing the options for the * call * @return a {@link ServiceCall} with a response type of {@link Classifiers} */ public ServiceCall listClassifiers(ListClassifiersOptions listClassifiersOptions) { String[] pathSegments = {"v3/classifiers"}; RequestBuilder builder = RequestBuilder.get(RequestBuilder.constructHttpUrl(getServiceUrl(), pathSegments)); builder.query("version", versionDate); Map sdkHeaders = SdkCommon.getSdkHeaders("watson_vision_combined", "v3", "listClassifiers"); for (Entry header : sdkHeaders.entrySet()) { builder.header(header.getKey(), header.getValue()); } builder.header("Accept", "application/json"); if (listClassifiersOptions != null) { if (listClassifiersOptions.verbose() != null) { builder.query("verbose", String.valueOf(listClassifiersOptions.verbose())); } } ResponseConverter responseConverter = ResponseConverterUtils.getValue( new com.google.gson.reflect.TypeToken() {}.getType()); return createServiceCall(builder.build(), responseConverter); } /** * Retrieve a list of classifiers. * * @return a {@link ServiceCall} with a response type of {@link Classifiers} */ public ServiceCall listClassifiers() { return listClassifiers(null); } /** * Retrieve classifier details. * *

Retrieve information about a custom classifier. * * @param getClassifierOptions the {@link GetClassifierOptions} containing the options for the * call * @return a {@link ServiceCall} with a response type of {@link Classifier} */ public ServiceCall getClassifier(GetClassifierOptions getClassifierOptions) { com.ibm.cloud.sdk.core.util.Validator.notNull( getClassifierOptions, "getClassifierOptions cannot be null"); String[] pathSegments = {"v3/classifiers"}; String[] pathParameters = {getClassifierOptions.classifierId()}; RequestBuilder builder = RequestBuilder.get( RequestBuilder.constructHttpUrl(getServiceUrl(), pathSegments, pathParameters)); builder.query("version", versionDate); Map sdkHeaders = SdkCommon.getSdkHeaders("watson_vision_combined", "v3", "getClassifier"); for (Entry header : sdkHeaders.entrySet()) { builder.header(header.getKey(), header.getValue()); } builder.header("Accept", "application/json"); ResponseConverter responseConverter = ResponseConverterUtils.getValue( new com.google.gson.reflect.TypeToken() {}.getType()); return createServiceCall(builder.build(), responseConverter); } /** * Update a classifier. * *

Update a custom classifier by adding new positive or negative classes or by adding new * images to existing classes. You must supply at least one set of positive or negative examples. * For details, see [Updating custom classifiers] (https://cloud.ibm.com/docs/visual-recognition * ?topic=visual-recognition-customizing#updating-custom-classifiers). * *

Encode all names in UTF-8 if they contain non-ASCII characters (.zip and image file names, * and classifier and class names). The service assumes UTF-8 encoding if it encounters non-ASCII * characters. * *

**Tips about retraining:** * *

- You can't update the classifier if the **X-Watson-Learning-Opt-Out** header parameter was * set to `true` when the classifier was created. Training images are not stored in that case. * Instead, create another classifier. For more information, see [Data * collection](#data-collection). * *

- Don't make retraining calls on a classifier until the status is ready. When you submit * retraining requests in parallel, the last request overwrites the previous requests. The * `retrained` property shows the last time the classifier retraining finished. * * @param updateClassifierOptions the {@link UpdateClassifierOptions} containing the options for * the call * @return a {@link ServiceCall} with a response type of {@link Classifier} */ public ServiceCall updateClassifier(UpdateClassifierOptions updateClassifierOptions) { com.ibm.cloud.sdk.core.util.Validator.notNull( updateClassifierOptions, "updateClassifierOptions cannot be null"); com.ibm.cloud.sdk.core.util.Validator.isTrue( (updateClassifierOptions.positiveExamples() != null) || (updateClassifierOptions.negativeExamples() != null), "At least one of positiveExamples or negativeExamples must be supplied."); String[] pathSegments = {"v3/classifiers"}; String[] pathParameters = {updateClassifierOptions.classifierId()}; RequestBuilder builder = RequestBuilder.post( RequestBuilder.constructHttpUrl(getServiceUrl(), pathSegments, pathParameters)); builder.query("version", versionDate); Map sdkHeaders = SdkCommon.getSdkHeaders("watson_vision_combined", "v3", "updateClassifier"); for (Entry header : sdkHeaders.entrySet()) { builder.header(header.getKey(), header.getValue()); } builder.header("Accept", "application/json"); MultipartBody.Builder multipartBuilder = new MultipartBody.Builder(); multipartBuilder.setType(MultipartBody.FORM); if (updateClassifierOptions.positiveExamples() != null) { for (Map.Entry entry : updateClassifierOptions.positiveExamples().entrySet()) { String partName = String.format("%s_positive_examples", entry.getKey()); okhttp3.RequestBody part = RequestUtils.inputStreamBody(entry.getValue(), "application/octet-stream"); multipartBuilder.addFormDataPart(partName, entry.getKey(), part); } } if (updateClassifierOptions.negativeExamples() != null) { okhttp3.RequestBody negativeExamplesBody = RequestUtils.inputStreamBody( updateClassifierOptions.negativeExamples(), "application/octet-stream"); multipartBuilder.addFormDataPart( "negative_examples", updateClassifierOptions.negativeExamplesFilename(), negativeExamplesBody); } builder.body(multipartBuilder.build()); ResponseConverter responseConverter = ResponseConverterUtils.getValue( new com.google.gson.reflect.TypeToken() {}.getType()); return createServiceCall(builder.build(), responseConverter); } /** * Delete a classifier. * * @param deleteClassifierOptions the {@link DeleteClassifierOptions} containing the options for * the call * @return a {@link ServiceCall} with a response type of Void */ public ServiceCall deleteClassifier(DeleteClassifierOptions deleteClassifierOptions) { com.ibm.cloud.sdk.core.util.Validator.notNull( deleteClassifierOptions, "deleteClassifierOptions cannot be null"); String[] pathSegments = {"v3/classifiers"}; String[] pathParameters = {deleteClassifierOptions.classifierId()}; RequestBuilder builder = RequestBuilder.delete( RequestBuilder.constructHttpUrl(getServiceUrl(), pathSegments, pathParameters)); builder.query("version", versionDate); Map sdkHeaders = SdkCommon.getSdkHeaders("watson_vision_combined", "v3", "deleteClassifier"); for (Entry header : sdkHeaders.entrySet()) { builder.header(header.getKey(), header.getValue()); } builder.header("Accept", "application/json"); ResponseConverter responseConverter = ResponseConverterUtils.getVoid(); return createServiceCall(builder.build(), responseConverter); } /** * Retrieve a Core ML model of a classifier. * *

Download a Core ML model file (.mlmodel) of a custom classifier that returns * "core_ml_enabled": true in the classifier details. * * @param getCoreMlModelOptions the {@link GetCoreMlModelOptions} containing the options for the * call * @return a {@link ServiceCall} with a response type of {@link InputStream} */ public ServiceCall getCoreMlModel(GetCoreMlModelOptions getCoreMlModelOptions) { com.ibm.cloud.sdk.core.util.Validator.notNull( getCoreMlModelOptions, "getCoreMlModelOptions cannot be null"); String[] pathSegments = {"v3/classifiers", "core_ml_model"}; String[] pathParameters = {getCoreMlModelOptions.classifierId()}; RequestBuilder builder = RequestBuilder.get( RequestBuilder.constructHttpUrl(getServiceUrl(), pathSegments, pathParameters)); builder.query("version", versionDate); Map sdkHeaders = SdkCommon.getSdkHeaders("watson_vision_combined", "v3", "getCoreMlModel"); for (Entry header : sdkHeaders.entrySet()) { builder.header(header.getKey(), header.getValue()); } builder.header("Accept", "application/octet-stream"); ResponseConverter responseConverter = ResponseConverterUtils.getInputStream(); return createServiceCall(builder.build(), responseConverter); } /** * Delete labeled data. * *

Deletes all data associated with a specified customer ID. The method has no effect if no * data is associated with the customer ID. * *

You associate a customer ID with data by passing the `X-Watson-Metadata` header with a * request that passes data. For more information about personal data and customer IDs, see * [Information * security](https://cloud.ibm.com/docs/visual-recognition?topic=visual-recognition-information-security). * * @param deleteUserDataOptions the {@link DeleteUserDataOptions} containing the options for the * call * @return a {@link ServiceCall} with a response type of Void */ public ServiceCall deleteUserData(DeleteUserDataOptions deleteUserDataOptions) { com.ibm.cloud.sdk.core.util.Validator.notNull( deleteUserDataOptions, "deleteUserDataOptions cannot be null"); String[] pathSegments = {"v3/user_data"}; RequestBuilder builder = RequestBuilder.delete(RequestBuilder.constructHttpUrl(getServiceUrl(), pathSegments)); builder.query("version", versionDate); Map sdkHeaders = SdkCommon.getSdkHeaders("watson_vision_combined", "v3", "deleteUserData"); for (Entry header : sdkHeaders.entrySet()) { builder.header(header.getKey(), header.getValue()); } builder.header("Accept", "application/json"); builder.query("customer_id", deleteUserDataOptions.customerId()); ResponseConverter responseConverter = ResponseConverterUtils.getVoid(); return createServiceCall(builder.build(), responseConverter); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy