This application claims the benefit of Japanese Patent Application No. 2018-040392, filed on Mar. 7, 2018, and Japanese Patent Application No. 2018-235719, filed on Dec. 17, 2018, the entirety of the disclosures of which are incorporated by reference herein.
This application generally relates to an autonomous mobile apparatus, an autonomous move method, and a recording medium.
Autonomous mobile apparatuses that autonomously move according to the purpose of use have become in wide use. For example, autonomous mobile apparatuses that autonomously move for indoor cleaning are known. Then, autonomous mobile apparatuses that have the capability of moving to the place where the user is as the destination upon recognition of a call from the user have been developed. For example, Unexamined Japanese Patent Application Kokai Publication No. 2008-46956 discloses a robot guiding system for performing positioning calculation based on signals from the sensor unit and guiding the robot to the location of the user that is obtained by the positioning calculation.
The autonomous mobile apparatus of the present disclosure is an autonomous mobile apparatus that moves based on a predetermined map, and includes a driving unit and a processor. The driving unit is configured to move the autonomous mobile apparatus. The processor is configured to acquire presence indices that are indices indicating a possibility of the presence of an object at different points on the map, select a point for a destination from the points based on the acquired presence indices, set the selected point as the destination; and control the driving unit to cause the autonomous mobile apparatus to move to the set destination.
A more complete understanding of this application can be obtained when the following detailed description is considered in conjunction with the following drawings, in which:
The autonomous mobile apparatus according to embodiments of the present disclosure will be described below with reference to the drawings. Here, in the figures, the same or corresponding pails are referred to by the same reference numbers.
The autonomous mobile apparatus according to Embodiment 1 of the present disclosure is an apparatus that autonomously moves according to the purpose of use while creating maps of the surroundings. The purpose of use includes, for example, use for security monitoring, for indoor cleaning, for pets, for toys, and the like. Then, this autonomous mobile apparatus has the capability of moving to the location where the user is present upon recognition of a call from the user.
As shown in
Moreover, the autonomous mobile apparatus 100 has a shape like a cute animal as shown in
The controller 10 comprises a central processing unit (CPU) and the like and executes programs that are stored in the memory 20 to realize the functions of the parts that are described later (a SLAM processor 11, an environment map creator 12, a sound source locator 13, a location acquirer 14, a presence index updater 15, and a move controller 16). Moreover, comprising a clock (not shown), the controller 10 can acquire the current time and measure the elapsed time.
The memory 20 comprises a read-only memory (ROM), a random access memory (RAM), and the like and functionally includes an image storage 21, a simultaneous localization and mapping (SLAM) map storage 22, an environment map storage 23, and a presence index storage 24. The ROM stores programs that are executed by the CPU of the controller 10 and data necessary preliminary to executing the programs. The RAM stores data that are created/changed while the programs are executed.
The image storage 21 stores images (frames) that are captured by the imager 41. However, for saving the storage volume, it is unnecessary to store all captured images. The autonomous mobile apparatus 100 creates data for the SLAM (data of Map points that are described later) and estimates the location of the autonomous mobile apparatus 100 by the SLAM using multiple images that are stored in the image storage 21. Images that are used in estimating the location of the autonomous mobile apparatus 100 are called key frames and the image storage 21 stores, along with information of key frame images, information of the location of the autonomous mobile apparatus 100 (the location and the orientation of the autonomous mobile apparatus 100) when those key frames are captured.
The SLAM map storage 22 stores information of feature points (that are called Map points) of which the three-dimensional locations (X, Y, Z) are obtained among feature points that are included in key frames that are stored in the image storage 21. A feature point is a point of a featuring part in an image such as an edge part or a corner part in an image. A feature point can be acquired using an algorithm such as scale-invariant feature transform (SIFT) and speeded up robust features (SURF). The SLAM map storage 22 associates and stores, as information of a feature point, its three-dimensional location and a feature quantity of the feature point (for example, a feature quantity that is obtained by the SIFT or the like).
The environment map storage 23 stores an environment map that is created by the environment map creator 12 based on information from the sensor 30. An environment map is, as shown in
The presence index storage 24 stores indices (presence indices) that indicate the possibility of the presence of a person at different points on an environment map, which are acquired based on information from the location acquirer 14. The presence indices are such that, as shown
Moreover,
The sensor 30 comprises an obstacle sensor 31 and a motion sensor 32. The obstacle sensor 31 is a distance sensor that can detect an object (an obstacle) that is around and measure the distance to the object (the obstacle), and for example, an infrared distance sensor or an ultrasonic sensor. Here, it may be possible to detect an obstacle using the imager 41 without installing an independent obstacle sensor 31. In such a case, the imager 41 also serves as the obstacle sensor 31. Moreover, it may be possible to comprise a bumper sensor that detects collision against another object as the obstacle sensor 31 in place of a distance sensor. In such a case, the autonomous mobile apparatus 100 can detect the presence of an obstacle at the location where the bumper sensor detects a collision.
The motion sensor 32 is a sensor that can detect the presence of a person near the autonomous mobile apparatus 100. The motion sensor 32 is, for example, an infrared motion sensor.
The imager 41 comprises a monocular imaging apparatus (the camera 131). The imager 41 captures and acquires images (frames), for example, at 30 frames per second (fps).
The autonomous mobile apparatus 100 autonomously moves while recognizing the location of the autonomous mobile apparatus 100 and the surrounding environment in real time by the SLAM based on the images that are successively acquired by the imager 41.
The driving unit 42 comprises the wheels 135 of an independent two-wheel drive type and motors and is configured to move the autonomous mobile apparatus 100 according to orders (control) from the controller 10. The autonomous mobile apparatus 100 can parallel-shift (translation) back and forth by driving the two wheels 135 in the same direction, rotate (turn) on the spot by driving the two wheels 135 in opposite directions, and circle (translation+rotation (turn)) by driving the two wheels 135 at different speeds. Moreover, each wheel 135 is provided with a rotary encoder. The amount of translation and the amount of rotation can be calculated by measuring the numbers of rotations of the wheels 135 with the rotary encoders and using geometric relationships of the diameter of the wheels 135, the distance between the wheels 135, and the like.
For example, assuming that the diameter of the wheels 135 is D and the number of rotations is C, the amount of translation at the ground contact parts of the wheels 135 is π·D·C. Here, the number of rotations, C, can be measured by the rotary encoders that are provided to the wheels 135. Moreover, assuming that the diameter of the wheels 135 is D, the distance between the wheels 135 is I, the number of rotations of the right wheel 135 is CR, and the number of rotations of the left wheel 135 is CL, the amount of rotation for turning (assuming that the right turn is positive) is 360°×D×(CL−CR)/(2×I). Successively adding the amount of translation and the amount of rotation above, the driving unit 42 functions as so-called mechanical odometry and can measure the location of the autonomous mobile apparatus 100 (the location and the orientation with reference to the location and the orientation at the start of moving). Here, the rotary encoders that are provided to the wheels 135 function as the distance measurer.
Here, the driving unit 42 may comprise crawlers in place of the wheels 135 or may comprise multiple (for example, legs to move by walking with two legs. Also in such cases, the location and the orientation of the autonomous mobile apparatus 100 can be measured based on the movement of the two crawlers or the movement of the two legs as in the case of the wheels 135.
The voice acquirer 43 comprises the microphone array 132 that comprises multiple microphones and acquires voice in the surroundings. The autonomous mobile apparatus 100 can estimate the location of a person who has uttered voice by applying the multiple signal classification (MUSIC) method using voice data that are acquired by the microphone array 132 of the voice acquirer 43.
the voice outputter 44 comprises the speaker 133 and outputs voice. The autonomous mobile apparatus 100 can talk to the user by means of the voice outputter 44. Then, the autonomous mobile apparatus 100 can have a dialogue with the user by acquiring voice that is uttered by the user with the voice acquirer 43, recognizing the voice with the controller 10, and audio-outputting a reply content from the voice outputter 44.
The communicator 45 is a module for communicating with an external apparatus and a wireless module including an antenna when wireless-communicating with an external apparatus. For example, the communicator 45 is a wireless module for near field communication based on Bluetooth (registered trademark). Using the communicator 45, the autonomous mobile apparatus 100 can exchange data with an external source. For example, the autonomous mobile apparatus 100 can communicate with an external server (not shown) with the communicator 45 to execute some of the function of the controller 10 on the external server. Moreover, the autonomous mobile apparatus 100 can store on an external server or acquire from an external server some of the data to store in the memory 20.
Next, the functional configuration of the controller 10 of the autonomous mobile apparatus 100 will be described. The controller 10 realizes the functions of the SLAM processor 11, the environment map creator 12, the sound source locator 13, the location acquirer 14, the presence index updater 15, and the move controller 16 to control the move of the autonomous mobile apparatus 100 and so on. Moreover, the controller 10 has the capability of multithreading and can execute multiple threads (different process flows) in parallel.
The SLAM processor 11 estimates the posture (the location and the orientation) of the autonomous mobile apparatus 100 by the SLAM using multiple images that are captured by the imager 41 and stored in the image storage 21 based on information of feature points that are obtained from those images. In brief, the SLAM processor 11 estimates the location of the autonomous mobile apparatus 100 by acquiring correspondence of the same feature points between multiple key frames that are stored in the image storage 21 and acquiring the three-dimensional locations of the acquired corresponding feature points from the SLAM map storage 22. In performing this SIAM, the SLAM processor 11 extracts a feature point that is included in the image and stores, for the feature point of which the three-dimensional location is successfully calculated (a. Map point), information of the Map point in the SLAM map storage 22. Here, it may be possible to use information of mechanical odometry that can be obtained from the driving unit 42 in estimating the posture (the location and the Orientation) of the autonomous mobile apparatus 100. The autonomous mobile apparatus 100 does not need to perform the SLAM when using information of mechanical odometry in estimating the location and the orientation of the autonomous mobile apparatus 100.
The environment map creator 12 creates an environment map on which the location of the obstacle 302 is recorded using information of the location and the orientation of the autonomous mobile apparatus 100 that are estimated by the SLAM processor 11 and information from the obstacle sensor 31, and writes information of the created environment map in the environment map storage 23.
The sound source locator 13 observes voice that is uttered by the user by means of the microphone array 132 that is provided to the voice acquirer 43 and calculates the location of the origin of the voice by the MUSIC method. Here, although the microphone array 132 can observe sound other than human voice, the sound source locator 13 determines whether it is human voice using frequency components and the like of the voice that is observed by the microphone array 132. Then, the sound source locator 13 calculates where the voice is uttered (the direction in which the voice comes from and the distance to the sound source) by applying the MUSIC method to the human voice (sound). Moreover, performing user identification using frequency components and the like of the observed voice, the sound source locator 13 can identify who's voice that voice is and acquire by whom and where the voice is uttered.
The location acquirer 14 detects a human face in the image that is acquired by the imager 41 to acquire the location where a person is present. The location acquirer 14 estimates the distance to the location where the person is present based on the size of the face in the image and estimates the direction in which the person is present from the imaging direction of the imager 41 and the position of the human face in the image. The location acquirer 14 acquires the location where the person is present from these estimation results. Moreover, the location acquirer 14 can also acquire who is at what location through user identification on the detected face. Here, where the user identification is unnecessary, the location acquirer 14 may acquire the location of a person using the motion sensor 32.
The presence index updater 15 acquires the presence probability of a person at each of multiple points on the environment map that is stored in the environment map storage 23 using information of the location of a person that is acquired by the location acquirer 14, and updates the present index that is stored in the presence index storage 24 using the acquired presence probability.
Receiving a destination order from an upper-layer application program that is described later, the move controller 16 sets a route and a moving speed and controls the driving unit 42 to move the autonomous mobile apparatus 100 along the set route. For setting a route, the move controller 16 sets a route from the current location of the autonomous mobile apparatus 100 to a destination based on the environment map that is created by the environment map creator 12.
The functional configuration of the autonomous mobile apparatus 100 is described above. Next, the call detection/move procedure of the autonomous mobile apparatus 100 will be described with reference to
As the “call detection/move” procedure starts, the controller 10 of the autonomous mobile apparatus 100 initializes various data (the image storage 21, the SLAM map storage 22, the environment map storage 23, and the presence index storage 24) that are stored in the memory 20 (Step S101). As for the initialization of the environment map, the autonomous mobile apparatus 100 starts moving from the location of the charger 301 and therefore, at this point, the environment map is initialized with information that indicates that “the autonomous mobile apparatus 100 is present at the location of the charger.” Moreover, the presence index may be initialized with information that is collected in the past.
Next, the controller 10 starts various threads for the SLAM (Step S102). Specifically, the controller 10 starts an apparatus location estimation thread, a map creation thread, and a loop closing thread. With these threads in parallel operation, the SLAM processor 11 extracts feature points from an image that is captured by the imager 41 to estimate the location of the autonomous mobile apparatus 100. Explanation of the threads for the SLAM is omitted.
Next, the controller 10 determines whether it is operation termination (for example, an operation termination order is received from the upper-layer application program or the user) (Step S103). If it is operation termination (an operation termination order is received) (Step S103; Yes), the “call detection/move” procedure terminates. If it is not operation termination (no operation termination order is received) (Step S103; No), the environment map creator 12 creates and updates the environment map and the presence index updater 15 updates the presence index (Step S104). The procedure to update the presence index will be described later.
Next, the move controller 16 receives a destination order from the upper-layer application program and moves the autonomous mobile apparatus 100 (Step S105). Next, the sound source locator 13 determines whether voice is detected by the voice acquirer 43 (Step S106). If no voice is detected (Step S106; No), the processing returns to the Step S103. If voice is detected (Step S106; Yes), the sound source locator 13 calculates the location where the voice is uttered (Step S107).
Then, the controller 10 turns the imager 41 into the direction in which the voice is uttered (Step S108). In this processing, only the head of the autonomous mobile apparatus 100 may be moved to turn the imager 41 into the direction of the voice or the driving unit 42 may be driven to turn the autonomous mobile apparatus 100 itself into the direction of the voice and thus turn the imager 41 into the direction of the voice.
Then, the location acquirer 14 determines whether a face is detected in the image that is captured by the imager 41 (Step S109). If no face is detected (S109; No), the processing proceeds to Step S115. If a face is detected (Step S109; Yes), the location of the face is estimated and the presence index is updated (Step S110). The method of estimating the location of the face will be described later.
Then, the location acquirer 14 determines the person of that face is looking (paying attention) this way (toward the autonomous mobile apparatus 100) (Step S111). If not looking this way (Step S111; No), the processing proceeds to Step S115.
If the person of the face that is detected by the location acquirer 14 is looking this way (Step S111; Yes), the move controller 16 moves the autonomous mobile apparatus 100 to the location of the person (Step S112). Then, the location acquirer 14 determines whether the distance to the person of the detected face is equal to or smaller than a voice recognizable distance (for example, 1.5 m) (Step S113). If the distance to the person of the detected face is not equal to or smaller than the voice recognizable distance (Step S113; No), the processing returns to the Step S109.
If the distance to the person of the detected face is equal to or smaller than the voice recognizable distance (Step S113; Yes), the controller 10 has a dialogue with the person using the voice acquirer 43 and the voice outputter 44 (Step S114). Then, the processing returns to the Step S103.
On the other hand, if no face is detected in the Step S109 (Step S109; No) and if the person of the detected face is not looking this way in the Step S111 (Step S111; No), the controller 10 creates a “list of locations where a person is possibly present (list of candidates for a point for a destination)” based on information that is stored in the presence index storage 24 (Step S115). For example, assuming that the presence indices (the probabilities of a person being present) shown in
Moreover, it is not always necessary to use a reference presence index value in creating a “list of locations where a person is possibly present.” For example, it may be possible to register the location for which the highest presence index is stored in the presence index storage 24 on the “list of locations where a person is possibly present” or extract a predetermined number (for example, three) of presence indices that are stored in the presence index storage 24 in the order from the highest presence index and register the locations that correspond to those presence indices on the “list of locations where a person is possibly present.”
Then, the controller 10 determines whether the list of locations where a person is possibly present is empty (Step S116). If the list is empty (Step S116; Yes), the processing returns to the Step S103. If the list is not empty (Step S116; No), one of the “locations where a person is possibly present” is picked up (Step S117). Then, the driving unit 42 is controlled to move the autonomous mobile apparatus 100 to a “place in sight of the location where a person is possibly present” (Step S118). A “place in sight of the location where a person is possibly present” is a place that satisfies two conditions, (A) there is no obstacle between the “location where a person is possibly present” and the place and (B) the place is at a distance that make it possible to detect the face when there is a person at the “location where a person is possibly present.”
Here, the condition (A) can be checked based on information of the location of the obstacle 302 that is stored in the environment map storage 23. Moreover, the condition (B) can be checked by the square grid size of the environment map, the minimum face detection size, a standard face size, and the field angle of the imager 41. If multiple places satisfy the two conditions, a location that is at a shorter distance from the current location of the autonomous mobile apparatus 100 or a location where the imager shift angle is smaller is selected.
After the move, the controller 10 captures an image of the “location where a person is possibly present” with the imager 41 and determines whether a face is detected in the captured image (Step S119). If a face is detected (Step S119; Yes), the processing proceeds to the Step S110. If no face is detected (Step S119; No), it is determined whether a predetermined time (waiting time for face detection, for example, three seconds) has elapsed (Step S120). If the predetermined time has not elapsed (Step S120; No), the processing returns to the Step S119. If the predetermined time has elapsed (Step S120; Yes), the proceeding returns to the Step S116 and repeats the move to a “place in sight of the location where a person is possibility present” and the detection of a face until the “list of locations where a person is possibly present” becomes empty.
The process flow of the call detection/move procedure is described above. Next, the presence index update procedure that is performed in the above-described Step S104 will be described with reference to
First, the SLAM processor 11 acquires the current location and direction of the autonomous mobile apparatus 100 by the SLAM (Step S201). Here, when already acquired in Step S301 of the face location estimation procedure that is described later, the current location and direction may be used as they are. Next, the location acquirer 14 determines whether presence of a person around the autonomous mobile apparatus 100 is detected (Step S202). If no person is detected (Step S202 No), the procedure ends.
If presence of a person around the autonomous mobile apparatus 100 is detected (Step S202; Yes), the location acquirer 14 acquires the distance to and the direction of the detected person (Step S203). For these values, when already estimated in Step S303 of the face location estimation procedure that is described later, the direction to the face and the direction of the face may also he used as they are. Then, the presence index updater 15 votes for the location of the person on the environment map based on the current location and direction of the autonomous mobile apparatus 100 that are acquired in the Step S201 and the distance to and the direction of the detected person that are acquired in the Step S203 (Step S204) and ends the procedure.
Here, voting is a type of operation for updating the presence index that is stored in the presence index storage 24 and for example, the value of the presence index (probability) that corresponds to the location of the person is incremented by a predetermined value (for example, 0.1). When expressed in the logarithmic odds, the presence index (probability) is incremented, for example, by 1.
Moreover, it may be possible to keep observing the detected person, measure the time of stay at that location, and increase the value by which the presence index is incremented as the time (the time of stay) is longer (in the case of using the logarithmic odds, for example, incrementing by m when the person stays for m minutes). Moreover, it may be possible to determine the value by which the presence index is incremented based on the likelihood that the person is detected (for example, incrementing by L when the likelihood is L).
Here, when the location acquirer 14 performs user identification through face recognition or the like, the presence index of each user and the presence index independent from the user (of all people) are each updated.
The presence index update procedure is described above. Next, the face location estimation procedure will be described with reference to FIG, 7.
First, the SLAM processor 11 acquires the current location and direction of the autonomous mobile apparatus 100 by the SLAM (Step S301). Next, the location acquirer 14 acquires the coordinates and the size in the image of a face that is detected in the Step S109 of the call detection/move procedure (
Next, the location acquirer 14 estimates the distance to and the direction of the face (Step S303). Their respective estimation methods will additionally be described below.
First, assuming that the width of the average face size when photographed from one meter away is presented by F_WIDTH_IM, the distance to the face, f_dist, can be presented by the following expression (1):
f_dist=F_WIDTH_IM/f_width (1).
Moreover, assuming that the angle that is made with the camera 131 is presented by f_dir; the field angle of the camera 131, by AOV, and the horizontal size of a captured image of the camera 131, by WIDTH, the direction of the face can be presented by the following expression (2):
f_dir=AOV/2×|f_x-WIDTH/2|(WIDTH/2) (2)
Then, the location acquirer 14 calculates the location of the face based on the current location and direction of the autonomous mobile apparatus 100 that are acquired in the Step S301 and the distance to and the direction of the detected face that are estimated in the Step S303 (Step S304) and ends the procedure.
The face location estimation procedure is described above. Here, a simple specific case of the call detection/move procedure (
Then, the controller 10 sorts the “list of locations where a person is possibly present” first in the descending order of probability and then in the ascending order of angular shift from the direction of the voice when seen from the location of the autonomous mobile apparatus 100. In this case, the two locations that are registered on the list have the same probability of 0.7. However, the angular shift from the direction of the voice is smaller with the lower 0.7 than with the upper 0.7 in
Then, in the Step S118, the autonomous mobile apparatus 100 moves to a place in sight of this “location where a person is possibly present.” Here, there are two candidates 100B and 100C for the place in sight of the location where a person is possibly present. The place 100B is closer to the current location 100A. However, the place 100C has the smaller angular shift from the direction of the voice (45 degrees diagonally downward right). Thus, the autonomous mobile apparatus 100 selects the place 100E as a “place in sight of the location where a person is possibly present” when the distance is considered important and selects the place 100C when the angle is considered important and moves there. Then, the autonomous mobile apparatus 100 detects a face in the Step S119, moves to the location of the face (in the Step S112), and has a dialogue with the user (in the Step S114).
With the above processing, the autonomous mobile apparatus 100 can move to a location where a person is possibly present based on the presence index even when no human face can be found in the direction of the voice of the caller. Consequently, the possibility of being able to move to the location of the caller is increased.
Moreover, given that a presence index is stored for each user and the user is identified from voice of a caller, it is possible to create a list using the presence index of the identified user in creating a “list of locations where a person is possibly present,” thereby increasing the possibility of being able to move to the location where that user is present.
Moreover, given that a presence index is stored for each time window, it is possible to create a list using the presence index that corresponds to the time window of the current time in creating a “list of locations where a person is possibly present,” thereby increasing the possibility of being able to move to the location where a person is present.
Furthermore, given that a presence index is stored for each user and for each time window and the user is identified from voice of a caller, it is possible to create a list using the presence index of the identified user that corresponds to the time window of the current time in creating a “list of locations where a person is possibly present,” thereby increasing the possibility of being able to move to the location where that user is present.
In Embodiment 1, in creating “a list of locations where a person is possibly present (a list of candidates for a point for a destination),” a location where the presence index that is stored in the presence index storage 24 is higher than a reference presence index value (for example, 0.65) is a “location where a person is possibility present” However, it is difficult to determine whether a person is present in a region that is behind an obstacle and a blind spot from the location of the autonomous mobile apparatus 100, and thereby the value of the presence index is unlikely to rise. Then, Modified Embodiment 1 in which in creating a “list of locations where a person is possibly present,” a blind spot region is used in addition to or in place of the presence index will be described.
In Modified Embodiment 1, in creating a “list of locations where a person is possibly present” in the Step S115 of the “call detection/move” procedure (
Only the difference between Modified Embodiment 1 and Embodiment 1 is described above. With the points within a blind spot region being added to the “list of locations where a person is possibly present,” if the location that is picked up in the Step S117 is within the blind spot region, a move to a place in sight of the blind spot region is made in the Step S118. Therefore, even if a person is present in a blind spot region, the controller 10 can detect his face in the Step S119.
As described above, in Modified Embodiment 1, the autonomous mobile apparatus 100 can move to a place in sight of a blind spot region where it is initially impossible to determine whether a person is present, whereby it is possible to increase the possibility of being able to move to a location where a person is present even when a person is in a blind spot region.
Embodiment 1, the presence index is updated based on the result of a move before going to search for a person. However, the presence index may be updated based on the result of going to search for a person. Such Embodiment 2 will be described.
An autonomous mobile apparatus 101 according to Embodiment 2 has the same functional configuration as the autonomous mobile apparatus 100 according to Embodiment 1 shown in
In the “call detection/move” procedure of the autonomous mobile apparatus 101 (
In the Step S131, the presence index updater 15 updates the presence index that is stored in the presence index storage 24 based on the location where the user who is approached in the Step S112 is present and dialogue results. The difference between the presence index update in the Step S131 and the presence index update in the Step S110 is as follows. In the presence index update in the Step S110, the value of the probability of the presence index that corresponds to the location of the user whose face is detected this time is simply increased (for example, 0.1 is added) regardless of presence/absence of dialogue.
On the other hand, in the presence index update in the Step S131, the value to add to the probability of the presence index is changed as follows based on dialogue results or user's uttered content (the following may be adopted in whole or only in part):
In Embodiment 2, as described above, the value to update the presence index is finely changed based on the dialogue results, whereby it is possible not only to simply increase the possibility of being able to move to a location where a person is present but also to increase the possibility of being able to move to a location where a person who is willing to have a dialogue with the autonomous mobile apparatus 101 is present.
In Embodiment 1, the presence index storage 24 stores the probability of the presence of a person in each grid square as shown in
The functional configuration of an autonomous mobile apparatus 102 according to Embodiment 3 additionally comprises, as shown in
In the information shown in
In Embodiment 3, the presence index is corrected using the index correction information as described above, whereby it is possible to increase further the possibility of being able to move to the location of a user.
In the above-described embodiments, the autonomous mobile apparatus 100, 101, or 102 that approaches the user in response to a call from the user is described. It is envisaged as Embodiment 4 that an autonomous mobile apparatus that approaches the user even if not called by the user. For example, an autonomous mobile apparatus that moves to the location of the user to wake up the user at 7:00 every morning can be envisaged. The autonomous mobile apparatus according to Embodiment 4 proceeds to the Step S115 of the call detection/move procedure (
In such a case, it is envisaged that the user (who is in sleep) does not look toward the autonomous mobile apparatus in many cases. Therefore, in the call detection,/move procedure according to Embodiment 4, the determination in the Step S111 is skipped and the processing proceeds to the Step S112 after the Step S110. Moreover, in such a case, it is unnecessary to recognize voice of the user, and it is necessary to wake up the user even if the distance to the user is large. Therefore, the determination in the Step S113 is also skipped and a speech to wake up the user is uttered in the Step S114.
As described above, the autonomous mobile apparatus according to Embodiment 4 can move to the location of the user based on the presence index and have a dialogue with the user (utter a speech to the user) even if there is no call from the user (the current location of the user is unknown).
Moreover, as a modified embodiment of Embodiment 4, an autonomous mobile apparatus can be envisaged that moves based on the presence index that is prestored in the presence index storage 24 without detecting a person or updating the presence index. In such a case, the autonomous mobile apparatus sets as a destination and moves to a location where a person is possibly present based on the presence indices that are stored in the presence index storage 24 among multiple points on the environment map. Here, the presence indices that are prestored in the presence index storage 24 may be those that are created based on past statistics information or the like or those that are acquired from an external server via the communicator 45.
Moreover, in the above-described embodiments, the location acquirer 14 acquires the location of a person by detecting a human face in an image that is acquired by the imager 41. However, the location acquirer 14 may acquire the location of not only a person but also an object by recognizing an object such as another robot, a substance (aluminum or iron of empty cans, plastics of containers and straw, hazardous substances, and the like), an animal (pests, destructive animals, birds/animals as food, and the like), a plant (weeds, crops, and the like) in an image that is acquired by the imager 41. Then, the presence index updater 15 can acquire the presence index (the present probability) that indicates the possibility of presence of an object at each of multiple points on the environment map that is stored in the environment map storage 23 using information of the location of the object such as a robot, a substance, an animal, or a plant that is acquired by the location acquirer 14, and update the presence index that is stored in the presence index storage 24 using the acquired presence index. Like the presence index of people, this presence index can also be obtained without distinguishing objects or individuals or may be obtained for each object or each person by identifying each object or person.
The above autonomous mobile apparatus can create a “list of locations where an object such as a robot, a substance, an animal, or a plant is possibly present” in a similar manner to the “list of the location where a person is possibly present.” Then, it is possible to increase the possibility of being able to move to a location where not only a person but also an object such as a robot, a substance, an animal, or a plant is present by moving based on this list.
Here, an autonomous mobile apparatus 103 as a crop harvesting robot is described as Embodiment 5. The functional configuration of the autonomous mobile apparatus 103 according to Embodiment 5 is, as shown in FIG, 12, the same as the functional configuration of the autonomous mobile apparatus 100 (
The crop harvester 46 harvests crops based on an order from the controller 10. Moreover, the location acquirer 14 acquires not only a location of a person but also a location where a crop is present by detecting the crop in an image that is acquired by the imager 41. Moreover, the location acquirer 14 may acquire a location of a crop of each type through image recognition on the crop type.
Moreover, the autonomous mobile apparatus 103 performs the crop harvesting procedure as shown in
The processing in the Steps S101 through S105 of the crop harvesting procedure (
If a crop is detected (Step S151; Yes), the location of the crop is estimated and the presence index is updated (Step S152). The location of the crop can be estimated by the same method as in the above-described face location estimation procedure according to Embodiment 1 (
Moreover, the presence index can be updated by the same method as in the above-described presence index update procedure according to Embodiment 1 (
Then, the move controller 16 moves the autonomous mobile apparatus 103 to the location of the crop that is estimated by the location acquirer 14 (Step S153). Then, the controller 10 controls the crop harvester 46 to perform a crop harvesting operation (Step S154) and returns to the Step S103.
On the other hand, if no crop is detected in the Step S151 (Step S151; No), the controller 10 creates a “list of locations where a crop is possibly present” based on information that is stored in the presence index storage 24 (Step S155). For example, it is assumed that the presence indices (the probabilities of the presence of a crop) shown in
Moreover,
Then, the controller 10 determines whether the list of locations where an object as a crop is possibly present is empty (Step S156). If the list is empty (Step S156; Yes), the processing returns to the Step S103. If the list is not empty (Step S156; No), one of the “locations where an object is possibly present” is picked up from the list (Step S157). Then, the driving unit 42 is controlled to move the autonomous mobile apparatus 103 to a “place in sight of the location where an object is possibly present” (Step S158). A “place in sight of the location where an object is possibly present” is a place from which to the “location where an object is possibly present” there is no obstacle.
Then, the location acquirer 14 determines whether an object (a crop) is detected in an image that is captured by the imager 41 (Step S159). If an object is detected (Step S159; Yes), the processing proceeds to Step S152. If no object is detected (Step S159; No), it is determined whether a predetermined time (waiting time for object detection, for example, three seconds) has elapsed (Step S160). If the predetermined time has not elapsed (Step S160; No), the processing returns to the Step S159. If the predetermined time has elapsed (Step S160; Yes), the processing returns to the Step S156 and repeats the move to a “place in sight of the location where an object is possibly present” and the detection of an object crop) until the “list of locations where an object is possibly present” becomes empty.
With the above processing, the autonomous mobile apparatus 103 can move to a location where a crop as an object is possibly present and harvest a crop based on the presence index even when no object is detected,
Here, when another robot, not a crop, as an object is a target, in the above-described Step S159, instead of simply determining whether an object is detected, it may be possible to determine whether the face of another robot (a part that corresponds to the face of the object) is detected as in the Step S119 of the call detection/move procedure in Embodiment 1 (
Here, in the case of a crop harvesting robot for a farmer who owns multiple fields, for example a field of a crop A, a field of a crop B, and so on, it may be possible to set and update a presence index that corresponds to each of the crops such as a presence index A for harvesting the crop A, a presence index B for harvesting the crop B, and so on.
The autonomous mobile apparatus 103 according to Embodiment 5 detects a crop as an object and updates the presence index based on the location of the detected object. However, an embodiment is also envisaged in which the presence index is updated based on information from an external source without detecting an object. Here, as Embodiment 6, an autonomous mobile apparatus 104 as an agrichemical spraying robot that sprays agrichemicals without detecting pests, weeds, or crops as an object will be described. The functional configuration of the autonomous mobile apparatus 104 according to Embodiment 6 is, as shown in
The agrichemical sprayer 47 sprays agrichemicals in an amount and in a direction that are specified by the controller 10. Here, the autonomous mobile apparatus 104 does not detect an object (pests, weeds, crops). Therefore, the agrichemical sprayer 47 performs an agrichemical spraying operation at a location and in a direction based on an order that is received from the controller 10 regardless of presence/absence of an actual object.
Moreover, the autonomous mobile apparatus 104 performs the agrichemical spraying procedure as shown in
The processing, in the Steps S101 through S105 of the agrichemical spraying procedure (
Here, the autonomous mobile apparatus 104 does not need to perform the presence index update procedure and in this case, the presence indices that are stored in the presence index storage 24 are used as they are. The presence indices that are stored in the presence index storage 24 may be those that are created based on past statistics information or those that are acquired from an external server or the like via the communicator 45.
Then, following the Step S105, the controller 10 creates a “list of locations where an object is possibly present” based on information that is stored in the presence index storage 24 (Step S161). This processing is the same as the processing in the Step S155 of the crop harvesting procedure according to Embodiment 5 (
Then, the controller 10 controls the agrichemical sprayer 47 to perform an agrichemical spraying operation at the “location where an object is possibility present” (Step S165). Then, the processing returns to the Step S162 and repeats the move to a “location where an object is possibly present” and the spraying of agrichemicals until the “list of locations where an object is possibly present” becomes empty.
With the above-described processing, the autonomous mobile apparatus 104 according to Embodiment 6 can move to a location where an object is possibly present and spray agrichemicals based on the presence index that is acquired from an external source (or prestored) without detecting an object (pests, weeds, crops).
Also in Embodiment 6, it is possible to add the index correction information storage 25 to the memory 20 and use index correction information that is preset based not only on behavioral characteristics of people but also on characteristics of an object (pests, weeds, crops) as the index correction information (
Moreover, Embodiment 6 can be used in the case in which a target is an object on which image recognition fails or is difficult. For example, as an autonomous mobile apparatus according to Embodiment 6, a robot can be envisaged that collects microplastics that are floating in the ocean. In such a case, an autonomous mobile apparatus in which the agrichemical sprayer 47 of the autonomous mobile apparatus 104 is replaced with a collector that collects microplastics is provided. Microplastics are fine plastics that are present particularly in the ocean. It is difficult to identify locations of microplastics through image recognition. However, it is possible to statistically calculate their presence probability in the ocean based on the locations of origins, ocean currents, and the like. Then, with the presence index being set based on the so calculated presence probability, the autonomous mobile apparatus according to Embodiment 6 can automatically move to a location where the probability of the presence of microplastics is high and efficiently collect microplastics.
Moreover, the autonomous mobile apparatus 104 according to Embodiment 6 applies to a pest control robot that exterminates pests by replacing the agrichemical sprayer 47 with a pesticide sprayer. Since pests are small and often flying around, it is often difficult to detect pests through image recognition. Moreover, even if detected, pests are soon not where they are detected in many cases (because they are flying around). However, it is possible that a person gives to the autonomous mobile apparatus 104 locations where pests are highly possibly present as presence index data or an external server transmits to the autonomous mobile apparatus 104 locations where pests are frequently present as presence index data (for example, by analyzing posted messages on a social network service (SNS) or the like). In this way, the autonomous mobile apparatus 104 can move to a location where pests are highly possibly present based on the presence index that is given from an external source and spray agrichemicals to exterminate pests.
Furthermore, also with this pest control robot, it is possible to add the index correction information storage 5 to the memory 20 and use index correction information that is preset based not only on behavioral characteristics of people but also on characteristics of pests as the index correction information (
Moreover, the autonomous mobile apparatus 104 according to Embodiment 6 is also applicable to a crop harvesting robot by replacing the agrichemical sprayer 47 with the crop harvester 46. For example, for harvesting rice as a crop, places where rice should be harvested are generally preliminarily known. Therefore, in the case of a crop harvesting robot that harvests rice, if the places where rice should be harvested are prestored in the presence index storage 24, it is possible to harvest rice without acquiring the locations where rice is present through image recognition on rice. Moreover, in such a case, in the case of a crop harvesting robot for a farmer who owns multiple fields, for example a field of a crop A, a field of a crop B, and so on, it is possible to prestore on a server and receiving from the server a presence index that corresponds to each of the crops such as a presence index A for harvesting a crop A, a presence index B for harvesting a crop B, and so on, whereby the crop harvesting robot can harvest each crop using the presence index that corresponds to the crop without acquiring the location through image recognition on the crop.
The above embodiments are described on the assumption that the autonomous mobile apparatus 100, 101, 102, 103, or 104 creates a SLAM map and an environment map using the SLAM processor 11 and the environment map creator 12. However, it is not essential to create a SLAM map and an environment map. When the autonomous mobile apparatus 100, 101, 102, 103, or 104 comprises its own location estimation means such as a global positioning system (GPS) or when the moving range is within a predetermined range, it is possible to prestore in the environment map storage 23 an environment map within the moving range and thereby estimate its own location by means of the GPS without creating a SLAM map and an environment map, or move to a required place with reference to the environment map that is stored in the environment map storage 23. Such Modified Embodiment 2 is also included in the present disclosure.
Here, the functions of the autonomous mobile apparatuses 100, 101, 102, 103, and 104 can also be implemented by a computer such as a conventional personal computer (PC). Specifically, the above embodiments are described on the assumption that the program for the autonomous move control procedure that is performed by the autonomous mobile apparatuses 100, 101, 102, 103, and 104 is prestored on the ROM of the memory 20. However, the program may be saved and distributed on a non-transitory computer-readable recording medium such as a flexible disc, a compact disc read-only memory (CD-ROM), a digital versatile disc (DVD), and a magneto-optical disc (MO), and read and installed on a computer to configure a computer that can realize the above-described functions.
The preceding describes some example embodiments for explanatory purposes. Although the preceding discussion has presented specific embodiments, persons skilled in the art will recognize that changes may be made in form and detail without departing from the broader spirit and scope of the invention. Accordingly, the specification and drawings are to be regarded in an illustrative rather than a restrictive sense. This detailed description, therefore, is not to be taken in a limiting sense, and the scope of the invention is defined only by the included claims, along with the full range of equivalents to which such claims are entitled.
Number | Date | Country | Kind |
---|---|---|---|
2018-040392 | Mar 2018 | JP | national |
2018-235719 | Dec 2018 | JP | national |