From 3be178eef88a438877a1590050bdb79dac3fa0d6 Mon Sep 17 00:00:00 2001 From: Ryan Newell Date: Mon, 26 Nov 2018 02:07:45 +0000 Subject: [PATCH] Add camera node during deployment doc fixes --- README.md | 16 +- roboMakerSettings.json | 7 +- .../cloudformation_template.yaml | 702 ------------------ .../config/cloudwatch_metrics_config.yaml | 4 +- .../launch/deploy_person_detection.launch | 18 +- .../launch/kinesis.launch | 6 +- .../launch/person_detection.launch | 6 +- .../src/person_detection_robot/package.xml | 3 +- .../CMakeLists.txt | 2 +- .../CMakeLists.txt | 2 +- .../launch/small_house.launch | 2 +- .../small_house_turtlebot_navigation.launch | 2 +- .../CMakeLists.txt | 2 +- .../launch/small_house.launch | 2 +- .../small_house_turtlebot_navigation.launch | 2 +- 15 files changed, 55 insertions(+), 721 deletions(-) delete mode 100644 robot_ws/src/person_detection_robot/cloudformation_template.yaml diff --git a/README.md b/README.md index 61dcf94..700cd23 100644 --- a/README.md +++ b/README.md @@ -115,8 +115,22 @@ colcon build Launch the application with the following commands: - *Running Robot Application on a Robot* + + Once the bundle has been created, it can be deployed using RoboMaker. For information about deploying using RoboMaker, see [this documentation](https://docs.aws.amazon.com/robomaker/latest/dg/gs-deploy.html). + + You must also complete the Raspberry Pi camera setup for the TurtleBot WafflePi, outlined + [here](http://emanual.robotis.com/docs/en/platform/turtlebot3/appendix_raspi_cam/#raspberry-pi-camera). + + You must run the following command before running the Robot Application on the robot. ```bash - source robot_ws/install/local_setup.sh + sudo chmod 777 /dev/video0 + ``` + + You may also upload and run the bundle manually. Once the bundle has been manually uploaded to the target TurtleBot WafflePi, ssh into the TurtleBot and run + + ```bash + export BUNDLE_CURRENT_PREFIX=/path/to/bundle/ + source $BUNDLE_CURRENT_PREFIX/setup.sh roslaunch person_detection_robot deploy_person_detection.launch ``` diff --git a/roboMakerSettings.json b/roboMakerSettings.json index d4104b2..a68a475 100644 --- a/roboMakerSettings.json +++ b/roboMakerSettings.json @@ -84,7 +84,12 @@ "outputLocation":"", "failureBehavior":"Fail", "maxJobDurationInSeconds":28800, - "iamRole":"" + "iamRole":"", + "vpcConfig": { + "assignPublicIp": true, + "securityGroups": [ "" ], + "subnets": [ "" ] + } } } }, diff --git a/robot_ws/src/person_detection_robot/cloudformation_template.yaml b/robot_ws/src/person_detection_robot/cloudformation_template.yaml deleted file mode 100644 index 2d38d19..0000000 --- a/robot_ws/src/person_detection_robot/cloudformation_template.yaml +++ /dev/null @@ -1,702 +0,0 @@ -AWSTemplateFormatVersion: 2010-09-09 -Parameters: - BucketName: - Type: String - AllowedPattern: '[a-z][a-z0-9\-]*' - Description: Name of the Amazon S3 bucket containing images of faces - Default: persondetectionsample - SourceBucket: - Type: String - AllowedPattern: '[a-z][a-z0-9\-]*' - Description: Initial bucket to copy images from - Default: b9-private-beta-assets - CollectionId: - Type: String - AllowedPattern: '[a-zA-Z0-9_.\-]+' - Description: Name of Amazon Rekognition collection name - Default: personDetectionCollection - RekognitionRoleName: - Type: String - AllowedPattern: '[a-zA-Z0-9_.\-]+' - Description: >- - Name of role that will be created for Amazon Rekognition to read data from - Amazon Kinesis Video Streams and write data to a Kinesis Data Stream - Default: personDetectionRekognitionServiceRole - StreamProcessorName: - Type: String - AllowedPattern: '[a-zA-Z0-9_.\-]+' - Description: >- - The name of the Amazon Rekognition stream processor that will process the - incoming video stream - Default: personDetectionProcessor - KinesisVideoStreamName: - Type: String - AllowedPattern: '[a-zA-Z0-9_.\-]+' - Description: >- - The name of the incoming Amazon Kinesis video stream. This must match the - "stream_name" given in the config/kvs_config.yaml file. - Default: personDetectionStream - RekognitionDataStreamName: - Type: String - AllowedPattern: '[a-zA-Z0-9_.\-]+' - Description: >- - The name of the Amazon Kinesis data stream to output Rekognition results. - This must match the "rekognition_data_stream" given in the - config/kvs_config.yaml file. - Default: AmazonRekognitionPersonDetectionSample -Metadata: - 'AWS::CloudFormation::Designer': - 2db7b804-2928-46ab-b53e-a9aaa56380d8: - size: - width: 60 - height: 60 - position: - x: 930 - 'y': 250 - z: 0 - embeds: [] - dependson: - - 50d77c80-d79e-4cb3-84b2-3d00afff7e00 - e92430d9-2179-4e81-87c1-811622bdbfa1: - size: - width: 60 - height: 60 - position: - x: 1090 - 'y': 450 - z: 0 - embeds: [] - 2fc044ca-96ab-4a07-86b4-8f9186e7e564: - size: - width: 60 - height: 60 - position: - x: 660 - 'y': 160 - z: 0 - embeds: [] - dependson: - - 2008979f-e28d-4a37-98f4-261ec1bcae3a - be8cf4e7-ebff-4724-9071-2ad4e1b88ab0: - size: - width: 60 - height: 60 - position: - x: 1090 - 'y': 190 - z: 0 - embeds: [] - cb2cb419-bb65-4baa-b2a7-7c7744847d84: - size: - width: 60 - height: 60 - position: - x: 1130 - 'y': 100 - z: 0 - embeds: [] - 2c1d4f3c-3f87-4fbc-a197-d2ade101b01a: - size: - width: 60 - height: 60 - position: - x: 670 - 'y': 260 - z: 0 - embeds: [] - dependson: - - 2fc044ca-96ab-4a07-86b4-8f9186e7e564 - - 2db7b804-2928-46ab-b53e-a9aaa56380d8 - d373b10c-325f-4a30-af55-37b9ab8ee6a6: - size: - width: 60 - height: 60 - position: - x: 670 - 'y': 360 - z: 0 - embeds: [] - 469e14f9-1a5c-46c4-a9cb-84df0ee65eb9: - size: - width: 60 - height: 60 - position: - x: 860 - 'y': 180 - z: 0 - embeds: [] - 50d77c80-d79e-4cb3-84b2-3d00afff7e00: - size: - width: 60 - height: 60 - position: - x: 1150 - 'y': 280 - z: 0 - embeds: [] - b0ef56ea-5123-4ebf-b88c-bbbfa81fd29f: - size: - width: 60 - height: 60 - position: - x: 1300 - 'y': 250 - z: 0 - embeds: [] - 2008979f-e28d-4a37-98f4-261ec1bcae3a: - size: - width: 60 - height: 60 - position: - x: 770 - 'y': 160 - z: 0 - embeds: [] - isassociatedwith: - - 2c1d4f3c-3f87-4fbc-a197-d2ade101b01a - 6ccaab09-a72b-46a1-b59e-4853395ec197: - size: - width: 60 - height: 60 - position: - x: 510 - 'y': 370 - z: 0 - embeds: [] - 608d5a75-777b-40d8-94d2-5d23f5ed40e4: - size: - width: 60 - height: 60 - position: - x: 510 - 'y': 470 - z: 0 - embeds: [] - f1c96a35-67fd-41db-aea9-3c4e19e13157: - size: - width: 60 - height: 60 - position: - x: 510 - 'y': 270 - z: 0 - embeds: [] - dependson: - - 2c1d4f3c-3f87-4fbc-a197-d2ade101b01a - - 2fc044ca-96ab-4a07-86b4-8f9186e7e564 - ac3c1068-6753-42d2-856e-bb5aed235863: - source: - id: 2db7b804-2928-46ab-b53e-a9aaa56380d8 - target: - id: 50d77c80-d79e-4cb3-84b2-3d00afff7e00 - z: 11 -Resources: - CreateRekognitionResources: - Type: 'AWS::Lambda::Function' - Properties: - FunctionName: - 'Fn::Join': - - '-' - - - !Ref 'AWS::StackName' - - CreateRekognitionResources - Handler: index.lambda_handler - Role: !GetAtt - - CreateRekognitionResourcesRole - - Arn - Runtime: python2.7 - Timeout: 10 - Environment: - Variables: - DataStreamArn: !GetAtt DataStream.Arn - StreamProcessorRole: !GetAtt StreamProcessorRole.Arn - Code: - ZipFile: !Sub | - import boto3 - import json - import logging - import traceback - import os - import cfnresponse - - def lambda_handler(event, context): - - print ('received event:' + json.dumps(event, indent=2)) - - rekognition_client = boto3.client('rekognition') - kinesis_video_client = boto3.client('kinesisvideo') - logger = logging.getLogger() - - if event['RequestType'] == 'Delete': - deletion_failed = False - - try: - rekognition_client.delete_stream_processor(Name='${StreamProcessorName}') - except rekognition_client.exceptions.ResourceNotFoundException: - logging.warning('Stream Processor %s was not found while trying to delete' % '${StreamProcessorName}') - except: - deleteion_failed = True - logger.error("error: {0}".format(traceback.format_exc())); - - try: - kinesis_video_stream_arn = kinesis_video_client.describe_stream(StreamName='${KinesisVideoStreamName}')['StreamInfo']['StreamARN'] - kinesis_video_client.delete_stream(StreamArn=kinesis_video_stream_arn) - except kinesis_video_client.exceptions.ResourceNotFoundException: - logging.warning('Kinesis Video Stream %s was not found while trying to delete' % '${KinesisVideoStreamName}') - except: - deletion_failed = True - logger.error("error: {0}".format(traceback.format_exc())); - - if deletion_failed: - cfnresponse.send(event, context, "FAILED", {}) - else: - cfnresponse.send(event, context, "SUCCESS", {}) - else: - #Create Video Stream - try: - response = kinesis_video_client.create_stream(StreamName='${KinesisVideoStreamName}') - if response['ResponseMetadata']['HTTPStatusCode'] == 200: - logger.info('Kinesis Video Stream with name %s created' % '${KinesisVideoStreamName}') - except kinesis_video_client.exceptions.ResourceInUseException: - logger.warning('Kinesis Video Stream with name %s already exists' % '${KinesisVideoStreamName}') - except: - logger.error("error: {0}".format(traceback.format_exc())); - cfnresponse.send(event, context, "FAILED", {}) - try: - kinesis_video_response = kinesis_video_client.describe_stream(StreamName='${KinesisVideoStreamName}') - kinesis_video_stream_arn = kinesis_video_response["StreamInfo"]["StreamARN"] - except: - logger.error("error: {0}".format(traceback.format_exc())); - cfnresponse.send(event, context, "FAILED", {}) - - #Create Stream Processor - try: - rekognition_input = {"KinesisVideoStream":{"Arn":kinesis_video_stream_arn}} - rekognition_output = {"KinesisDataStream":{"Arn":os.environ['DataStreamArn']}} - rekognition_settings = {"FaceSearch":{"CollectionId":'${CollectionId}',"FaceMatchThreshold":80}} - processor_resp = rekognition_client.create_stream_processor(Input=rekognition_input, - Output=rekognition_output, - Name='${StreamProcessorName}', - Settings=rekognition_settings, - RoleArn=os.environ['StreamProcessorRole']) - rekognition_client.start_stream_processor(Name='${StreamProcessorName}') - except rekognition_client.exceptions.ResourceAlreadyExistsException: - logger.warning('Stream Processor with name %s already exists' & '${StreamProcessorName}') - except: - logger.error("error: {0}".format(traceback.format_exc())); - cfnresponse.send(event, context, "FAILED", {}) - cfnresponse.send(event, context, "SUCCESS", {}) - Metadata: - 'AWS::CloudFormation::Designer': - id: 2db7b804-2928-46ab-b53e-a9aaa56380d8 - DependsOn: - - CreateCollection - DataStream: - Type: 'AWS::Kinesis::Stream' - Properties: - Name: !Ref RekognitionDataStreamName - ShardCount: 1 - Metadata: - 'AWS::CloudFormation::Designer': - id: e92430d9-2179-4e81-87c1-811622bdbfa1 - UploadBucket: - Type: 'AWS::S3::Bucket' - DependsOn: - - RekognitionLambdaPermission - Properties: - BucketName: !Ref BucketName - NotificationConfiguration: - LambdaConfigurations: - - Event: 's3:ObjectCreated:*' - Function: !GetAtt LambdaIndexFace.Arn - Metadata: - 'AWS::CloudFormation::Designer': - id: 2fc044ca-96ab-4a07-86b4-8f9186e7e564 - CreateRekognitionResourcesRole: - Type: 'AWS::IAM::Role' - Properties: - AssumeRolePolicyDocument: - Version: 2012-10-17 - Statement: - - Effect: Allow - Principal: - Service: - - lambda.amazonaws.com - Action: - - 'sts:AssumeRole' - Path: /service-role/ - Policies: - - PolicyName: AmazonRekognition - PolicyDocument: - Version: 2012-10-17 - Statement: - - Effect: Allow - Action: - - 'rekognition:StartStreamProcessor' - - 'rekognition:CreateStreamProcessor' - - 'kinesisvideo:CreateStream' - - 'kinesisvideo:DeleteStream' - - 'kinesisvideo:DescribeStream' - - 'rekognition:CreateCollection' - - 'rekognition:DeleteCollection' - - 'rekognition:ListCollections' - - 'iam:PassRole' - Resource: '*' - - PolicyName: AWSLambdaLogs - PolicyDocument: - Version: 2012-10-17 - Statement: - - Effect: Allow - Action: - - 'logs:CreateLogGroup' - - 'logs:CreateLogStream' - - 'logs:PutLogEvents' - Resource: 'arn:aws:logs:*:*:*' - Metadata: - 'AWS::CloudFormation::Designer': - id: be8cf4e7-ebff-4724-9071-2ad4e1b88ab0 - StreamProcessorRole: - Type: 'AWS::IAM::Role' - Properties: - AssumeRolePolicyDocument: - Version: 2012-10-17 - Statement: - - Effect: Allow - Principal: - Service: - - rekognition.amazonaws.com - Action: - - 'sts:AssumeRole' - Path: /service-role/ - Policies: - - PolicyName: AmazonRekognitionKinesis - PolicyDocument: - Version: 2012-10-17 - Statement: - - Effect: Allow - Action: - - 'kinesis:PutRecord' - - 'kinesis:PutRecords' - Resource: '*' - - PolicyName: AmazonRekognitionVideo - PolicyDocument: - Version: 2012-10-17 - Statement: - - Effect: Allow - Action: - - 'kinesisvideo:GetDataEndpoint' - - 'kinesisvideo:GetMedia' - Resource: '*' - Metadata: - 'AWS::CloudFormation::Designer': - id: cb2cb419-bb65-4baa-b2a7-7c7744847d84 - LambdaIndexFace: - Type: 'AWS::Lambda::Function' - DependsOn: - - CreateRekognitionResources - Properties: - Description: >- - Triggered by S3, indexes faces against a collection in Amazon - Rekognition - Handler: index.lambda_handler - MemorySize: 128 - Role: !GetAtt LambdaIndexFacesRole.Arn - Runtime: python2.7 - Timeout: 5 - FunctionName: !Join - - '-' - - - !Ref 'AWS::StackName' - - IndexFaces - Code: - ZipFile: !Sub | - from __future__ import print_function - - import boto3 - from decimal import Decimal - import json - import urllib - - print('Loading function') - - s3 = boto3.client('s3') - rekognition = boto3.client('rekognition') - - - # --------------- Helper Functions ------------------ - - def index_faces(bucket, key): - image_name = key.split("/")[-1] - image_name = image_name.split(".")[0] - response = rekognition.index_faces( - Image={"S3Object": - {"Bucket": bucket, - "Name": key}}, - CollectionId="${CollectionId}", - ExternalImageId=image_name) - return response - - # --------------- Main handler ------------------ - - def lambda_handler(event, context): - - # Get the object from the event - bucket = event['Records'][0]['s3']['bucket']['name'] - key = urllib.unquote_plus( - event['Records'][0]['s3']['object']['key'].encode('utf8')) - - try: - - # Calls Amazon Rekognition IndexFaces API to detect faces in S3 object - # to index faces into specified collection - - response = index_faces(bucket, key) - - # Print response to console. - print(response) - - return response - except Exception as e: - print(e) - print("Error processing {} from bucket {}. ".format(key, bucket)) - raise e - Metadata: - 'AWS::CloudFormation::Designer': - id: 2c1d4f3c-3f87-4fbc-a197-d2ade101b01a - LambdaIndexFacesRole: - Type: 'AWS::IAM::Role' - Properties: - AssumeRolePolicyDocument: - Version: 2012-10-17 - Statement: - - Effect: Allow - Principal: - Service: - - lambda.amazonaws.com - Action: - - 'sts:AssumeRole' - Path: / - Policies: - - PolicyName: LambdaIndexFaces - PolicyDocument: - Version: 2012-10-17 - Statement: - - Effect: Allow - Action: - - 'logs:CreateLogGroup' - - 'logs:CreateLogStream' - - 'logs:PutLogEvents' - Resource: 'arn:aws:logs:*:*:*' - - Effect: Allow - Action: - - 's3:GetObject' - Resource: !Join - - '' - - - !Join - - ':' - - - arn - - aws - - s3 - - '' - - '' - - !Ref BucketName - - /* - - Effect: Allow - Action: - - 'rekognition:IndexFaces' - Resource: '*' - Metadata: - 'AWS::CloudFormation::Designer': - id: d373b10c-325f-4a30-af55-37b9ab8ee6a6 - PopulateCreateRekognitionResources: - Type: 'AWS::CloudFormation::CustomResource' - Properties: - ServiceToken: !GetAtt CreateRekognitionResources.Arn - Metadata: - 'AWS::CloudFormation::Designer': - id: 469e14f9-1a5c-46c4-a9cb-84df0ee65eb9 - CreateCollection: - Type: 'AWS::Lambda::Function' - Properties: - FunctionName: - 'Fn::Join': - - '-' - - - !Ref 'AWS::StackName' - - CreateCollection - Handler: index.lambda_handler - Role: !GetAtt - - CreateRekognitionResourcesRole - - Arn - Runtime: python2.7 - Timeout: 10 - Environment: - Variables: - DataStreamArn: !GetAtt DataStream.Arn - StreamProcessorRole: !GetAtt StreamProcessorRole.Arn - Code: - ZipFile: !Sub | - import boto3 - import json - import logging - import traceback - import cfnresponse - - def lambda_handler(event, context): - - print ('received event:' + json.dumps(event, indent=2)) - - rekognition_client = boto3.client('rekognition') - kinesis_video_client = boto3.client('kinesisvideo') - logger = logging.getLogger() - - if event['RequestType'] == 'Delete': - - try: - rekognition_client.delete_collection(CollectionId='${CollectionId}') - except rekognition_client.exceptions.ResourceNotFoundException: - logging.warning('Collection %s was not found while trying to delete' % '${CollectionId}') - except: - logger.error("error: {0}".format(traceback.format_exc())); - cfnresponse.send(event, context, "FAILED", {}) - cfnresponse.send(event, context, "SUCCESS", {}) - - else: - # Create Collection - try: - ret = rekognition_client.create_collection(CollectionId='${CollectionId}') - if ret['ResponseMetadata']['HTTPStatusCode'] == 200: - logger.info('Collection with name %s created' % '${CollectionId}') - except rekognition_client.exceptions.ResourceAlreadyExistsException: - logger.warning('Collection with name %s already exists' % '${CollectionId}') - except: - logger.error("error: {0}".format(traceback.format_exc())); - cfnresponse.send(event, context, "FAILED", {}) - - cfnresponse.send(event, context, "SUCCESS", {}) - Metadata: - 'AWS::CloudFormation::Designer': - id: 50d77c80-d79e-4cb3-84b2-3d00afff7e00 - PopulateCreateCollection: - Type: 'AWS::CloudFormation::CustomResource' - Properties: - ServiceToken: !GetAtt CreateCollection.Arn - Metadata: - 'AWS::CloudFormation::Designer': - id: b0ef56ea-5123-4ebf-b88c-bbbfa81fd29f - RekognitionLambdaPermission: - Type: 'AWS::Lambda::Permission' - Properties: - Action: 'lambda:invokeFunction' - FunctionName: !GetAtt LambdaIndexFace.Arn - Principal: s3.amazonaws.com - SourceArn: !Join - - ':' - - - arn - - aws - - s3 - - '' - - '' - - !Ref BucketName - Metadata: - 'AWS::CloudFormation::Designer': - id: 2008979f-e28d-4a37-98f4-261ec1bcae3a - LambdaCopyImages: - Type: 'AWS::Lambda::Function' - Properties: - FunctionName: - 'Fn::Join': - - '-' - - - !Ref 'AWS::StackName' - - CopyImages - Handler: index.lambda_handler - Role: !GetAtt - - LambdaCopyImagesRole - - Arn - Runtime: python2.7 - Timeout: 10 - Code: - ZipFile: !Sub | - import boto3 - import json - import logging - import traceback - import cfnresponse - - keys = ["1.0/person-detection/assets/asimov.jpg"] - - def lambda_handler(event, context): - - s3_client = boto3.client('s3') - logger = logging.getLogger() - - if event['RequestType'] == 'Create': - try: - for key in keys: - source = { - 'Bucket':'${SourceBucket}', - 'Key':key - } - s3_client.copy(source, '${BucketName}', key) - except: - logger.error("error: {0}".format(traceback.format_exc())); - cfnresponse.send(event, context, "FAILED", {}) - cfnresponse.send(event, context, "SUCCESS", {}) - - else: - cfnresponse.send(event, context, "SUCCESS", {}) - Metadata: - 'AWS::CloudFormation::Designer': - id: 6ccaab09-a72b-46a1-b59e-4853395ec197 - LambdaCopyImagesRole: - Type: 'AWS::IAM::Role' - Properties: - AssumeRolePolicyDocument: - Version: 2012-10-17 - Statement: - - Effect: Allow - Principal: - Service: - - lambda.amazonaws.com - Action: - - 'sts:AssumeRole' - Path: / - Policies: - - PolicyName: LambdaCopyImages - PolicyDocument: - Version: 2012-10-17 - Statement: - - Effect: Allow - Action: - - 'logs:CreateLogGroup' - - 'logs:CreateLogStream' - - 'logs:PutLogEvents' - Resource: 'arn:aws:logs:*:*:*' - - Effect: Allow - Action: - - 's3:PutObject' - Resource: !Join - - '' - - - !Join - - ':' - - - arn - - aws - - s3 - - '' - - '' - - !Ref BucketName - - /* - - Effect: Allow - Action: - - 's3:GetObject' - Resource: '*' - Metadata: - 'AWS::CloudFormation::Designer': - id: 608d5a75-777b-40d8-94d2-5d23f5ed40e4 - PopulateCopyImages: - Type: 'AWS::CloudFormation::CustomResource' - Properties: - ServiceToken: !GetAtt LambdaCopyImages.Arn - Metadata: - 'AWS::CloudFormation::Designer': - id: f1c96a35-67fd-41db-aea9-3c4e19e13157 - DependsOn: - - LambdaIndexFace - - UploadBucket diff --git a/robot_ws/src/person_detection_robot/config/cloudwatch_metrics_config.yaml b/robot_ws/src/person_detection_robot/config/cloudwatch_metrics_config.yaml index c80457b..598af45 100644 --- a/robot_ws/src/person_detection_robot/config/cloudwatch_metrics_config.yaml +++ b/robot_ws/src/person_detection_robot/config/cloudwatch_metrics_config.yaml @@ -1,6 +1,6 @@ # An optional metric namespace parameter. If provided it will set the namespace for all metrics provided by this node to -# the provided value. If the node is running on a B9 system then the provided launch file will ignore this parameter in -# favor of the namespace specified by the B9 ecosystem +# the provided value. If the node is running on a AWS RoboMaker system then the provided launch file will ignore this parameter in +# favor of the namespace specified by the AWS RoboMaker ecosystem aws_metrics_namespace: "roboMakerSampleAppCloudWatchRobotMetrics" # An optional list of topics to listen to. If not provided or is empty the node will just listen on the global "metrics" diff --git a/robot_ws/src/person_detection_robot/launch/deploy_person_detection.launch b/robot_ws/src/person_detection_robot/launch/deploy_person_detection.launch index 1ce39fd..4ab274b 100644 --- a/robot_ws/src/person_detection_robot/launch/deploy_person_detection.launch +++ b/robot_ws/src/person_detection_robot/launch/deploy_person_detection.launch @@ -2,10 +2,20 @@ + + + + + + + + + + - - + + + - - + \ No newline at end of file diff --git a/robot_ws/src/person_detection_robot/launch/kinesis.launch b/robot_ws/src/person_detection_robot/launch/kinesis.launch index 2bb240b..02dfcdb 100644 --- a/robot_ws/src/person_detection_robot/launch/kinesis.launch +++ b/robot_ws/src/person_detection_robot/launch/kinesis.launch @@ -1,6 +1,6 @@ - + @@ -12,6 +12,9 @@ + + + @@ -21,6 +24,7 @@ + $(arg image_topic) diff --git a/robot_ws/src/person_detection_robot/launch/person_detection.launch b/robot_ws/src/person_detection_robot/launch/person_detection.launch index 1ed8d23..3d2eaf1 100644 --- a/robot_ws/src/person_detection_robot/launch/person_detection.launch +++ b/robot_ws/src/person_detection_robot/launch/person_detection.launch @@ -8,14 +8,16 @@ Note: set to false for deploying to a real robot. --> - + - + + + diff --git a/robot_ws/src/person_detection_robot/package.xml b/robot_ws/src/person_detection_robot/package.xml index 3913048..165d002 100644 --- a/robot_ws/src/person_detection_robot/package.xml +++ b/robot_ws/src/person_detection_robot/package.xml @@ -27,8 +27,9 @@ turtlebot3 turtlebot3_msgs - + message_generation message_runtime message_runtime + turtlebot3_bringup diff --git a/simulation_ws/src/aws_robomaker_simulation_common/CMakeLists.txt b/simulation_ws/src/aws_robomaker_simulation_common/CMakeLists.txt index d1d515d..628efbf 100644 --- a/simulation_ws/src/aws_robomaker_simulation_common/CMakeLists.txt +++ b/simulation_ws/src/aws_robomaker_simulation_common/CMakeLists.txt @@ -19,7 +19,7 @@ catkin_install_python(PROGRAMS DESTINATION ${CATKIN_PACKAGE_BIN_DESTINATION} ) -# Copy the rviz models for easier access in B9 RViz +# Copy the rviz models for easier access in AWS RoboMaker RViz install(FILES ${turtlebot3_navigation_DIR}/../rviz/turtlebot3_navigation.rviz DESTINATION ${CATKIN_PACKAGE_SHARE_DESTINATION}/rviz RENAME turtlebot3_navigation.rviz diff --git a/simulation_ws/src/aws_robomaker_simulation_small_house/CMakeLists.txt b/simulation_ws/src/aws_robomaker_simulation_small_house/CMakeLists.txt index 90bc76c..763ecec 100644 --- a/simulation_ws/src/aws_robomaker_simulation_small_house/CMakeLists.txt +++ b/simulation_ws/src/aws_robomaker_simulation_small_house/CMakeLists.txt @@ -13,7 +13,7 @@ install(DIRECTORY launch models worlds maps photos DESTINATION ${CATKIN_PACKAGE_SHARE_DESTINATION} ) -# Copy the rviz model for easier access in B9 RViz +# Copy the rviz model for easier access in AWS RoboMaker RViz install(FILES ${turtlebot3_navigation_DIR}/../rviz/turtlebot3_navigation.rviz DESTINATION ${CATKIN_PACKAGE_SHARE_DESTINATION}/rviz RENAME turtlebot3_navigation.rviz diff --git a/simulation_ws/src/aws_robomaker_simulation_small_house/launch/small_house.launch b/simulation_ws/src/aws_robomaker_simulation_small_house/launch/small_house.launch index 230b6cd..b4e0311 100644 --- a/simulation_ws/src/aws_robomaker_simulation_small_house/launch/small_house.launch +++ b/simulation_ws/src/aws_robomaker_simulation_small_house/launch/small_house.launch @@ -1,5 +1,5 @@ - diff --git a/simulation_ws/src/aws_robomaker_simulation_small_house/launch/small_house_turtlebot_navigation.launch b/simulation_ws/src/aws_robomaker_simulation_small_house/launch/small_house_turtlebot_navigation.launch index 3e2c2f0..e51402e 100644 --- a/simulation_ws/src/aws_robomaker_simulation_small_house/launch/small_house_turtlebot_navigation.launch +++ b/simulation_ws/src/aws_robomaker_simulation_small_house/launch/small_house_turtlebot_navigation.launch @@ -11,7 +11,7 @@ diff --git a/simulation_ws/src/person_detection_simulation/CMakeLists.txt b/simulation_ws/src/person_detection_simulation/CMakeLists.txt index b3ba05a..c13290d 100644 --- a/simulation_ws/src/person_detection_simulation/CMakeLists.txt +++ b/simulation_ws/src/person_detection_simulation/CMakeLists.txt @@ -14,7 +14,7 @@ install(DIRECTORY launch routes DESTINATION ${CATKIN_PACKAGE_SHARE_DESTINATION} ) -# Copy the rviz model for easier access in B9 RViz +# Copy the rviz model for easier access in AWS RoboMaker RViz install(FILES ${turtlebot3_description_DIR}/../rviz/model.rviz DESTINATION ${CATKIN_PACKAGE_SHARE_DESTINATION}/rviz RENAME turtlebot3_model.rviz diff --git a/simulation_ws/src/person_detection_simulation/launch/small_house.launch b/simulation_ws/src/person_detection_simulation/launch/small_house.launch index 49f50ad..6c2b355 100644 --- a/simulation_ws/src/person_detection_simulation/launch/small_house.launch +++ b/simulation_ws/src/person_detection_simulation/launch/small_house.launch @@ -1,5 +1,5 @@ - diff --git a/simulation_ws/src/person_detection_simulation/launch/small_house_turtlebot_navigation.launch b/simulation_ws/src/person_detection_simulation/launch/small_house_turtlebot_navigation.launch index 8bd7877..a61b72e 100644 --- a/simulation_ws/src/person_detection_simulation/launch/small_house_turtlebot_navigation.launch +++ b/simulation_ws/src/person_detection_simulation/launch/small_house_turtlebot_navigation.launch @@ -12,7 +12,7 @@