Skip to content
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Next Next commit
automl: add base model samples for automl ga
  • Loading branch information
nnegrey committed Dec 12, 2019
commit aa30bc7dbe63ef15da6423469f7f8251104afc7e
33 changes: 33 additions & 0 deletions automl/cloud-client/delete_model.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
#!/usr/bin/env python

# Copyright 2019 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.


def delete_model(project_id, model_id):
"""Delete a model."""
# [START automl_delete_model]
from google.cloud import automl

# TODO(developer): Uncomment and set the following variables
# project_id = 'YOUR_PROJECT_ID'
# model_id = 'YOUR_MODEL_ID'

client = automl.AutoMlClient()
# Get the full path of the model.
model_full_id = client.model_path(project_id, 'us-central1', model_id)
response = client.delete_model(model_full_id)

print(u'Model deleted. {}'.format(response.result()))
# [END automl_delete_model]
33 changes: 33 additions & 0 deletions automl/cloud-client/delete_model_test.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
#!/usr/bin/env python

# Copyright 2019 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.

import os

import delete_model

PROJECT_ID = os.environ["GCLOUD_PROJECT"]


def test_delete_model(capsys):
# As model creation can take many hours, instead try to delete a
# nonexistent model and confirm that the model was not found, but other
# elements of the request were valid.
try:
delete_model.delete_model(PROJECT_ID, 'TRL0000000000000000000')
out, _ = capsys.readouterr()
assert 'The model does not exist' in out
except Exception as e:
assert 'The model does not exist' in e.message
33 changes: 33 additions & 0 deletions automl/cloud-client/deploy_model.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
#!/usr/bin/env python

# Copyright 2019 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.


def deploy_model(project_id, model_id):
"""Deploy a model."""
# [START automl_deploy_model]
from google.cloud import automl

# TODO(developer): Uncomment and set the following variables
# project_id = 'YOUR_PROJECT_ID'
# model_id = 'YOUR_MODEL_ID'

client = automl.AutoMlClient()
# Get the full path of the model.
model_full_id = client.model_path(project_id, 'us-central1', model_id)
response = client.deploy_model(model_full_id)

print(u'Model deployment finished. {}'.format(response.result()))
# [END automl_deploy_model]
45 changes: 45 additions & 0 deletions automl/cloud-client/deploy_model_test.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
#!/usr/bin/env python

# Copyright 2018 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.

import os

import pytest

import deploy_model

PROJECT_ID = os.environ['GCLOUD_PROJECT']
MODEL_ID = 'TEN5112482778553778176'


@pytest.fixture(scope="function")
def verify_model_state():
from google.cloud import automl
client = automl.AutoMlClient()
model_full_id = client.model_path(PROJECT_ID, 'us-central1', MODEL_ID)

model = client.get_model(model_full_id)
if model.deployment_state == automl.enums.Model.DeploymentState.DEPLOYED:
# Undeploy model if it is deployed
response = client.undeploy_model(model_full_id)
response.result()


@pytest.mark.slow
def test_deploy_undeploy_model(capsys, verify_model_state):
verify_model_state
deploy_model.deploy_model(PROJECT_ID, MODEL_ID)
out, _ = capsys.readouterr()
assert 'Model deployment finished.' in out
46 changes: 46 additions & 0 deletions automl/cloud-client/get_model.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
#!/usr/bin/env python

# Copyright 2019 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.


def get_model(project_id, model_id):
"""Get a model."""
# [START automl_get_model]
from google.cloud import automl

# TODO(developer): Uncomment and set the following variables
# project_id = 'YOUR_PROJECT_ID'
# model_id = 'YOUR_MODEL_ID'

client = automl.AutoMlClient()
# Get the full path of the model.
model_full_id = client.model_path(project_id, 'us-central1', model_id)
model = client.get_model(model_full_id)

# Retrieve deployment state.
if model.deployment_state == automl.enums.Model.DeploymentState.DEPLOYED:
deployment_state = 'deployed'
else:
deployment_state = 'undeployed'

# Display the model information.
print(u'Model name: {}'.format(model.name))
print(u'Model id: {}'.format(model.name.split('/')[-1]))
print(u'Model display name: {}'.format(model.display_name))
print(u'Model create time:')
print(u'\tseconds: {}'.format(model.create_time.seconds))
print(u'\tnanos: {}'.format(model.create_time.nanos))
print(u'Model deployment state: {}'.format(deployment_state))
# [END automl_get_model]
78 changes: 78 additions & 0 deletions automl/cloud-client/get_model_evaluation.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,78 @@
#!/usr/bin/env python

# Copyright 2019 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.


def get_model_evaluation(project_id, model_id, model_evaluation_id):
"""Get model evaluation."""
# [START automl_language_entity_extraction_get_model_evaluation]
# [START automl_language_sentiment_analysis_get_model_evaluation]
# [START automl_language_text_classification_get_model_evaluation]
# [START automl_translate_get_model_evaluation]
# [START automl_vision_classification_get_model_evaluation]
# [START automl_vision_object_detection_get_model_evaluation]
from google.cloud import automl

# TODO(developer): Uncomment and set the following variables
# project_id = 'YOUR_PROJECT_ID'
# model_id = 'YOUR_MODEL_ID'
# model_evaluation_id = 'YOUR_MODEL_EVALUATION_ID'

client = automl.AutoMlClient()
# Get the full path of the model evaluation.
model_evaluation_full_id = client.model_evaluation_path(
project_id, 'us-central1', model_id, model_evaluation_id
)

# Get complete detail of the model evaluation.
response = client.get_model_evaluation(model_evaluation_full_id)

print(u'Model evaluation name: {}'.format(response.name))
print(u'Model annotation spec id: {}'.format(response.annotation_spec_id))
print('Create Time:')
print(u'\tseconds: {}'.format(response.create_time.seconds))
print(u'\tnanos: {}'.format(response.create_time.nanos / 1e9))
print(u'Evaluation example count: {}'.format(
response.evaluated_example_count))
# [END automl_language_sentiment_analysis_get_model_evaluation]
# [END automl_language_text_classification_get_model_evaluation]
# [END automl_translate_get_model_evaluation]
# [END automl_vision_classification_get_model_evaluation]
# [END automl_vision_object_detection_get_model_evaluation]
print('Entity extraction model evaluation metrics: {}'.format(
response.text_extraction_evaluation_metrics))
# [END automl_language_entity_extraction_get_model_evaluation]

# [START automl_language_sentiment_analysis_get_model_evaluation]
print('Sentiment analysis model evaluation metrics: {}'.format(
response.text_sentiment_evaluation_metrics))
# [END automl_language_sentiment_analysis_get_model_evaluation]

# [START automl_language_text_classification_get_model_evaluation]
# [START automl_vision_classification_get_model_evaluation]
print('Classification model evaluation metrics: {}'.format(
response.classification_evaluation_metrics))
# [END automl_language_text_classification_get_model_evaluation]
# [END automl_vision_classification_get_model_evaluation]

# [START automl_translate_get_model_evaluation]
print('Translation model evaluation metrics: {}'.format(
response.translation_evaluation_metrics))
# [END automl_translate_get_model_evaluation]

# [START automl_vision_object_detection_get_model_evaluation]
print('Object detection model evaluation metrics: {}'.format(
response.image_object_detection_evaluation_metrics))
# [END automl_vision_object_detection_get_model_evaluation]
76 changes: 76 additions & 0 deletions automl/cloud-client/list_model_evaluations.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
#!/usr/bin/env python

# Copyright 2019 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.


def list_model_evaluations(project_id, model_id):
"""List model evaluations."""
# [START automl_language_entity_extraction_list_model_evaluations]
# [START automl_language_sentiment_analysis_list_model_evaluations]
# [START automl_language_text_classification_list_model_evaluations]
# [START automl_translate_list_model_evaluations]
# [START automl_vision_classification_list_model_evaluations]
# [START automl_vision_object_detection_list_model_evaluations]
from google.cloud import automl

# TODO(developer): Uncomment and set the following variables
# project_id = 'YOUR_PROJECT_ID'
# model_id = 'YOUR_MODEL_ID'

client = automl.AutoMlClient()
# Get the full path of the model.
model_full_id = client.model_path(project_id, 'us-central1', model_id)

print('List of model evaluations:')
for evaluation in client.list_model_evaluations(model_full_id, ''):
print(u'Model evaluation name: {}'.format(evaluation.name))
print(
u'Model annotation spec id: {}'.format(
evaluation.annotation_spec_id))
print(u'Create Time:')
print(u'\tseconds: {}'.format(evaluation.create_time.seconds))
print(u'\tnanos: {}'.format(evaluation.create_time.nanos / 1e9))
print(u'Evaluation example count: {}'.format(
evaluation.evaluated_example_count))
# [END automl_language_sentiment_analysis_list_model_evaluations]
# [END automl_language_text_classification_list_model_evaluations]
# [END automl_translate_list_model_evaluations]
# [END automl_vision_classification_list_model_evaluations]
# [END automl_vision_object_detection_list_model_evaluations]
print('Entity extraction model evaluation metrics: {}'.format(
evaluation.text_extraction_evaluation_metrics))
# [END automl_language_entity_extraction_list_model_evaluations]

# [START automl_language_sentiment_analysis_list_model_evaluations]
print('Sentiment analysis model evaluation metrics: {}'.format(
evaluation.text_sentiment_evaluation_metrics))
# [END automl_language_sentiment_analysis_list_model_evaluations]

# [START automl_language_text_classification_list_model_evaluations]
# [START automl_vision_classification_list_model_evaluations]
print('Classification model evaluation metrics: {}'.format(
evaluation.classification_evaluation_metrics))
# [END automl_language_text_classification_list_model_evaluations]
# [END automl_vision_classification_list_model_evaluations]

# [START automl_translate_list_model_evaluations]
print('Translation model evaluation metrics: {}'.format(
evaluation.translation_evaluation_metrics))
# [END automl_translate_list_model_evaluations]

# [START automl_vision_object_detection_list_model_evaluations]
print('Object detection model evaluation metrics: {}\n\n'.format(
evaluation.image_object_detection_evaluation_metrics))
# [END automl_vision_object_detection_list_model_evaluations]
47 changes: 47 additions & 0 deletions automl/cloud-client/list_models.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
#!/usr/bin/env python

# Copyright 2019 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.


def list_models(project_id):
"""List models."""
# [START automl_list_models]
from google.cloud import automl

# TODO(developer): Uncomment and set the following variables
# project_id = 'YOUR_PROJECT_ID'
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If you're adopting double-quotes, use them consistently.


client = automl.AutoMlClient()
# A resource that represents Google Cloud Platform location.
project_location = client.location_path(project_id, 'us-central1')
response = client.list_models(project_location, '')

print('List of models:')
for model in response:
# Display the model information.
if model.deployment_state == \
automl.enums.Model.DeploymentState.DEPLOYED:
deployment_state = 'deployed'
else:
deployment_state = 'undeployed'

print(u'Model name: {}'.format(model.name))
print(u'Model id: {}'.format(model.name.split('/')[-1]))
print(u'Model display name: {}'.format(model.display_name))
print(u'Model create time:')
print(u'\tseconds: {}'.format(model.create_time.seconds))
print(u'\tnanos: {}'.format(model.create_time.nanos))
print(u'Model deployment state: {}'.format(deployment_state))
# [END automl_list_models]
Loading