WO2022065297A1 - Procédé de planification d'un itinéraire de déplacement autonome - Google Patents

Procédé de planification d'un itinéraire de déplacement autonome Download PDF

Info

Publication number
WO2022065297A1
WO2022065297A1 PCT/JP2021/034563 JP2021034563W WO2022065297A1 WO 2022065297 A1 WO2022065297 A1 WO 2022065297A1 JP 2021034563 W JP2021034563 W JP 2021034563W WO 2022065297 A1 WO2022065297 A1 WO 2022065297A1
Authority
WO
WIPO (PCT)
Prior art keywords
traveling
line segment
travel
region
condition
Prior art date
Application number
PCT/JP2021/034563
Other languages
English (en)
Japanese (ja)
Inventor
遊亀 傳田
Original Assignee
村田機械株式会社
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 村田機械株式会社 filed Critical 村田機械株式会社
Publication of WO2022065297A1 publication Critical patent/WO2022065297A1/fr

Links

Images

Classifications

    • GPHYSICS
    • G05CONTROLLING; REGULATING
    • G05DSYSTEMS FOR CONTROLLING OR REGULATING NON-ELECTRIC VARIABLES
    • G05D1/00Control of position, course, altitude or attitude of land, water, air or space vehicles, e.g. using automatic pilots
    • G05D1/02Control of position or course in two dimensions
    • G05D1/021Control of position or course in two dimensions specially adapted to land vehicles
    • G05D1/0212Control of position or course in two dimensions specially adapted to land vehicles with means for defining a desired trajectory
    • G05D1/0219Control of position or course in two dimensions specially adapted to land vehicles with means for defining a desired trajectory ensuring the processing of the whole working surface
    • GPHYSICS
    • G05CONTROLLING; REGULATING
    • G05DSYSTEMS FOR CONTROLLING OR REGULATING NON-ELECTRIC VARIABLES
    • G05D1/00Control of position, course, altitude or attitude of land, water, air or space vehicles, e.g. using automatic pilots
    • G05D1/02Control of position or course in two dimensions

Definitions

  • the present invention relates to an autonomous travel route planning method for an autonomous vehicle.
  • the present invention relates to a method of planning an autonomous traveling route for an autonomous traveling body that autonomously travels so as to fill a traveling area defined in a moving environment.
  • an autonomous traveling body capable of autonomously traveling on a traveling route (referred to as a filled traveling route) that fills a traveling area defined in a moving environment is known (see, for example, Patent Document 1).
  • the filled travel route is created by defining a travel area on an environmental map showing the travel environment and planning a travel route that combines a straight route and a turning route within the travel area.
  • the longitudinal direction of the traveling region (hereinafter referred to as the main direction) is determined, and the filled traveling route including the straight route parallel to the main direction is planned.
  • the direction change route is a route for the autonomous traveling body to change the traveling direction (for example, a U-turn route)
  • the filled traveling route includes many direction changing routes, it takes time to autonomously travel on the filled traveling route. It takes.
  • the traveling area is rotated by a predetermined angle, and (ii) is parallel to a predetermined reference axis connecting the boundaries of the traveling area in the traveling area after rotation by a predetermined angle.
  • Line segments are defined, (iii) the lengths of the line segments whose length is equal to or greater than a predetermined value are integrated, and (iv) the rotation angle of the traveling region where the integrated value of the line segments is maximized.
  • the main direction of the traveling region was determined by the process of determining the main direction based on the above.
  • the principal direction may be different from the original ideal principal direction depending on the shape of the traveling region.
  • the conventional method for determining the principal direction is used, depending on the shape of the traveling region, it may not be possible to plan a filled traveling route with short traveling time and high traveling efficiency.
  • An object of the present invention is to determine an appropriate principal direction for a traveling area in an autonomous traveling route planning method, and to create a filled traveling route with good traveling efficiency.
  • the seemingly autonomous travel route planning method of the present invention is a travel route planning method for an autonomous vehicle capable of autonomous travel so as to fill a travel area defined in a travel environment.
  • the autonomous travel route planning method includes the following steps. ⁇ A step of rotating the traveling area by a predetermined angle and determining whether or not the first condition that the boundary between the first line segment and the traveling area is orthogonal to each other is satisfied.
  • the first line segment is a line segment connecting two boundaries of the traveling region at each rotation angle of the traveling region, and is a line segment parallel to a predetermined reference axis.
  • the maximum length line segment is a line segment having the longest length among the line segments connecting the two boundaries of the traveling region.
  • a first line segment parallel to a predetermined reference axis connecting two boundaries of the travel region after rotation by a predetermined angle is orthogonal to the boundary of the travel region.
  • the main direction of the traveling region is determined from the rotation angle of the traveling region satisfying the condition that the length of the first line segment is equal to or more than a predetermined ratio of the length of the maximum length line segment.
  • the above-mentioned autonomous travel route planning method may further include a step of arranging a plurality of cells in the travel area.
  • the first line segment is a line segment connecting the representative points of two cells existing on the boundary of the traveling region.
  • the maximum length line segment is a line segment having the longest length among the line segments connecting the representative points of the two cells existing on the boundary of the traveling region. This makes it easy to define the first line segment and the maximum length line segment.
  • the step for determining whether or not the first condition is satisfied may include the following steps.
  • the first intersection is an intersection where one of the two first line segments defined for the traveling region at each angle intersects with the first boundary of the traveling region at that angle.
  • the second intersection is the intersection of the other of the two first line segments and the first boundary.
  • the step for determining whether or not the second condition is satisfied may include the following steps. ⁇ Calculate the integrated value of the length of the first line segment having a length equal to or greater than the predetermined ratio of the length of the maximum length line segment among the plurality of first line segments defined for the traveling area at each angle. Steps to do. ⁇ Step to determine that the second condition is satisfied when the above integrated value is the maximum.
  • the step of calculating the integrated value of the length of the first line segment is the integrated value of the first line segment included in the region defined by the two straight lines parallel to the predetermined reference axis and separated by a predetermined distance. It may include a step to be selected as the first line segment used in the calculation of. As a result, the range including the first line segment used for calculating the integrated value of the length can be fixed, so that the integrated value can be easily calculated.
  • the candidate having the maximum length of the first line segment among the candidates in the main direction satisfying the first condition is set as the candidate in the main direction satisfying the second condition. It may include steps. Thereby, it can be easily determined whether or not the second condition is satisfied.
  • the autonomous travel route planning method may further include a step of dividing the travel region into a plurality of regions.
  • the step of determining the principal direction is performed for each of the plurality of regions.
  • the autonomous travel route planning method may further include a step of joining a plurality of regions having the same principal direction and adjacent to each other when the travel region is divided into a plurality of regions. As a result, it is possible to create a filled running route with good running efficiency.
  • the figure which shows the whole structure of an example of an autonomous traveling device The figure which shows an example of the structure of the traveling route teaching part. The figure which shows an example of the structure of a setting part. The figure which shows the whole functional block composition of a control part. The figure which shows the detailed structure of the functional block of a traveling control part. The figure which shows the detailed structure of the functional block of a control control part.
  • a flowchart showing the basic operation of the autonomous traveling device A flowchart showing the operation of the manual operation teaching mode.
  • the figure which shows an example of a mobile environment A diagram showing an example of a global map and an outer boundary.
  • the figure which shows an example of the 1st line segment defined in the traveling area (the 1).
  • the figure which shows an example of the 1st line segment defined in the traveling area (the 2).
  • the figure which shows an example of the 1st line segment defined in the traveling area (the 3).
  • the flowchart which shows the determination process whether or not the first condition is satisfied The figure which shows an example of the determination method of the 2nd line segment schematically.
  • the figure which shows an example of the definition of the maximum length line segment The figure which shows an example of the case where the integrated value of the length of the first line segment becomes 0.
  • a flowchart showing a traveling area division process The figure which shows an example of the area created by dividing a part of a traveling area. The figure which shows an example of the state which the traveling area is divided into a plurality of areas. The figure which shows an example of the state which made a new area by joining a plurality of areas. The figure which shows an example of the state which the cell is arranged in the area.
  • a flowchart showing how to create a filled travel route The figure which shows an example of the score given to the cell in a region. The figure which shows an example of a filled traveling route.
  • the figure which shows an example of a running schedule. A flowchart showing the operation of the autonomous driving device when the autonomous driving mode is executed.
  • FIG. 1 is a diagram showing an overall configuration of an example of an autonomous traveling device.
  • the autonomous traveling device 100 is a cleaning machine that autonomously reproduces the set cleaning conditions and traveling routes.
  • the autonomous traveling device 100 includes a traveling unit 1.
  • the traveling unit 1 is a device for traveling the autonomous traveling device 100.
  • the traveling unit 1 has a main body B constituting the main body of the autonomous traveling device 100.
  • the traveling unit 1 has a traveling motor 11 at the left and right ends of the bottom of the main body B, and a main wheel 13 attached to an output rotation shaft of the traveling motor 11 and rotating according to the rotation of the traveling motor 11.
  • the autonomous traveling device 100 includes a cleaning unit 3.
  • the cleaning unit 3 is a device provided at the bottom of the main body B and cleans the floor surface F according to designated cleaning conditions.
  • the cleaning unit 3 of the present embodiment has a cleaning liquid discharge port 31, a squeegee 33, and a cleaning member 35.
  • the cleaning liquid discharge port 31 discharges the cleaning liquid (for example, water) supplied by the cleaning liquid supply pump 313 from the cleaning liquid supply tank 311 to the floor surface F on the front side of the main body B.
  • the squeegee 33 is provided behind the bottom surface of the main body B and collects the cleaning liquid remaining on the floor surface F.
  • the cleaning member 35 is provided on the front side of the bottom surface of the main body B, and is rotated on the floor surface F in which the cleaning liquid is present by the rotation of the cleaning member rotation motor 351 to clean the floor surface F.
  • the squeegee 33 may be provided with a suction port 33a.
  • the suction port 33a can suck the cleaning liquid, dust, etc. collected by the squeegee 33 and convey it to the recovery member 333 by putting the recovery member 333 in a negative pressure state by the suction motor 331.
  • the autonomous traveling device 100 has a control unit 5 (an example of a route planning device).
  • the control unit 5 is a computer system including a CPU, a storage device (RAM, ROM, hard disk drive, SSD, etc.), various interfaces, and the like.
  • the control unit 5 performs various controls related to the autonomous traveling device 100 (described later).
  • the autonomous traveling device 100 includes a traveling route teaching unit 7.
  • the travel route teaching unit 7 is a device that receives a movement operation of the travel unit 1 by an operator.
  • the traveling route teaching unit 7 is attached to the upper rear side of the main body B via the attachment member 8. As a result, the operator can operate the traveling route teaching unit 7 to move the traveling unit 1 (described later).
  • the traveling route teaching unit 7 does not have to be attached to the main body B.
  • the traveling route teaching unit 7 is a controller such as a joystick. As a result, the operator can remotely control the autonomous traveling device 100.
  • the autonomous traveling device 100 includes a setting unit 9.
  • the setting unit 9 is an operation panel for making various settings related to the autonomous traveling device 100, and is attached to the upper rear surface of the main body B. Further, the setting unit 9 is provided in the vicinity of the traveling route teaching unit 7. As a result, the operator can operate the setting unit 9 while operating the traveling route teaching unit 7 to operate the traveling unit 1.
  • the setting unit 9 may not be attached to the main body B.
  • the setting unit 9 can be, for example, a console capable of wireless communication such as a portable terminal. As a result, the operator can remotely set the autonomous traveling device 100.
  • FIG. 2 is a diagram showing an example of the configuration of the traveling route teaching unit.
  • the travel route teaching unit 7 has handles 71a and 71b.
  • the handles 71a and 71b are attached to the left and right side surfaces of the housing 73, respectively.
  • the handles 71a and 71b are used when the operator operates the autonomous traveling device 100.
  • the operator holding the handles 71a and 71b may apply either a force for pulling the autonomous traveling device 100 toward the operator or a force for pushing out the autonomous traveling device 100 through the handles 71a and 71b. can.
  • the operator can adjust the traveling direction of the autonomous traveling device 100. For example, if a force for pulling the autonomous traveling device 100 is applied to the steering wheel 71a on the right side when viewed from the front of the autonomous traveling device 100, the autonomous traveling device 100 turns to the left.
  • the handles 71a and 71b are rotatably attached to the housing 73. Further, the handles 71a and 71b are connected to the control unit 5 via the travel control command calculation unit 75.
  • the travel control command calculation unit 75 converts the rotation of the handles 71a and 71b into an electric signal and outputs the rotation to the control unit 5.
  • the operator can operate the autonomous traveling device 100 (traveling unit 1) by rotating the handles 71a and 71b.
  • the operator may be able to switch between forward movement and reverse movement of the autonomous traveling device 100.
  • the traveling speed of the autonomous traveling device 100 may be adjusted by adjusting the rotation amount of the handles 71a and 71b.
  • the traveling direction of the autonomous traveling device 100 may be changed by making the rotation amount of the handle 71a different from the rotation amount of the handle 71b.
  • FIG. 3 is a diagram showing an example of the configuration of the setting unit.
  • the setting unit 9 has a switching unit 91.
  • the switching unit 91 selects the operation mode of the autonomous traveling device 100 and outputs it to the control unit 5.
  • the operation mode of the autonomous traveling device 100 includes an autonomous traveling mode and a manual operation mode.
  • the autonomous traveling mode is an operation mode in which the autonomous traveling device 100 autonomously travels and cleans the floor surface F.
  • the manual operation mode is an operation mode in which the autonomous traveling device 100 is in a state where it can be manually operated by the operator.
  • the switching unit 91 can be configured by, for example, a switching switch as shown in FIG.
  • the setting unit 9 has a manual operation storage switch 92.
  • the manual operation storage switch 92 is a switch for starting or ending the storage of the manual operation of the autonomous traveling device 100 by the operator. Specifically, when the manual operation storage switch 92 is pressed after the operation mode is set to the manual operation mode by the switching unit 91, recording of the cleaning condition and the traveling route executed by the manual operation of the operator is started. .. That is, the teaching of cleaning conditions and traveling routes is started. On the other hand, if the manual operation storage switch 92 is pressed during the recording of the cleaning condition and the traveling route by the manual operation, the recording of the cleaning condition and the traveling route is stopped.
  • the operation mode for recording (teaching) the cleaning conditions and the traveling route by the manual operation of the operator is called the manual operation teaching mode.
  • the manual operation teaching mode is started as a sub-operation mode of the manual operation mode.
  • the manual operation storage switch 92 may be, for example, a push button switch as shown in FIG. In this case, the manual operation storage switch 92 is switched by pressing the push button switch.
  • the setting unit 9 has a setting operation unit 93.
  • the setting operation unit 93 is configured by, for example, a pressing switch, receives input of various settings related to the autonomous traveling device 100, and outputs the input to the control unit 5 via the setting conversion unit 94.
  • the setting conversion unit 94 is a signal conversion circuit or a computer system that converts the input received by the setting operation unit 93 into a signal that can be decoded by the control unit 5.
  • the setting unit 9 has a display 95.
  • the display 95 displays various setting information regarding the currently set autonomous traveling device 100.
  • the display 95 is, for example, a display such as a liquid crystal display or an organic EL display.
  • the display 95 may further display the current operation mode (autonomous travel mode / manual operation mode / manual operation teaching mode), operating time, remaining battery level for driving the autonomous traveling device 100, and the like. ..
  • the display 95 may be provided with a touch panel.
  • the switching unit 91, the manual operation storage switch 92, and / or the setting operation unit 93 may be realized by the touch panel.
  • the setting unit 9 may have a cleaning condition teaching unit 96.
  • the cleaning condition teaching unit 96 receives the input of the cleaning condition by the operator and outputs it to the cleaning control command calculation unit 97.
  • the cleaning control command calculation unit 97 is a signal conversion circuit or a computer system that converts the cleaning conditions received by the cleaning condition teaching unit 96 into a decipherable signal and outputs the signal to the control unit 5.
  • FIG. 4 is a diagram showing the overall functional block configuration of the control unit. All or part of each functional block of the control unit 5 described below may be realized by a program that can be executed by the computer system constituting the control unit 5. In this case, the program may be stored in the memory unit and / or the storage device. All or part of each functional block of the control unit 5 may be realized as a custom IC such as a SoC (System on Chip).
  • SoC System on Chip
  • the control unit 5 may be configured by one computer system or may be configured by a plurality of computer systems.
  • the functions realized by the plurality of functional blocks of the control unit 5 can be distributed to the plurality of computer systems at an arbitrary ratio and executed.
  • the control unit 5 has a cleaning control unit 51.
  • the cleaning control unit 51 supplies electric power for controlling the rotation speed, output, and the like to the cleaning member rotation motor 351, the cleaning liquid supply pump 313, and the suction motor 331.
  • the cleaning control unit 51 inputs the teaching cleaning condition from the cleaning condition teaching unit 96 via the cleaning control command calculation unit 97, and based on the teaching cleaning condition.
  • the cleaning member rotary motor 351, the cleaning liquid supply pump 313, and the suction motor 331 may be controlled.
  • the cleaning control unit 51 when the autonomous driving mode is executed, the cleaning control unit 51 inputs a reproduction cleaning condition indicating a set value of the cleaning condition in the autonomous travel mode from the control control unit 55, and based on the reproduction cleaning condition. , The cleaning unit 3 may be controlled.
  • the control unit 5 has a travel control unit 53.
  • the travel control unit 53 sets the travel motor 11 based on a travel control command based on the rotation amount and rotation direction of the handles 71a and 71b input from the travel route teaching unit 7, or a travel control command input from the control control unit 55. Control. Further, the travel control unit 53 calculates the rotation speed of the travel motor 11 based on the pulse signal output from the encoder 111 attached to the output rotation shaft of the travel motor 11.
  • the control unit 5 has a control control unit 55.
  • the control control unit 55 controls the traveling by the autonomous traveling device 100. Specifically, in the control control unit 55, the autonomous traveling device 100 moves to any position on the floor surface F based on the information acquired by the front detector 41a, the rear detector 41b, and / or the encoder 111. Calculate the position information indicating whether or not it is.
  • the control control unit 55 creates the travel schedule 500 by using the above-mentioned position information at the time of executing the manual operation teaching mode. In another embodiment, the control control unit 55 may calculate the cleaning condition in the autonomous driving mode and associate it with the traveling schedule 500.
  • the control control unit 55 calculates the reproduction driving control command based on the data stored in the traveling schedule 500 and outputs it to the traveling control unit 53.
  • the travel control unit 53 can autonomously move the autonomous travel device 100 by controlling the travel motor 11 based on the reproduction travel control command.
  • the control control unit 55 controls the cleaning control unit 51 based on the cleaning condition stored in the travel schedule 500 when the autonomous travel mode is executed. May be good.
  • the autonomous traveling device 100 can autonomously execute the cleaning work according to the cleaning conditions while autonomously traveling according to the traveling schedule 500.
  • the control unit 5 has a storage unit 57.
  • the storage unit 57 is a part or all of the storage area of the storage device of the computer system constituting the control unit 5, and stores various information about the autonomous traveling device 100. Specifically, the storage unit 57 stores the travel schedule 500 created by the control control unit 55, and various settings related to the autonomous travel device 100 input from the setting operation unit 93 and the setting conversion unit 94.
  • the travel control unit 53 and the control control unit 55 read various settings related to the autonomous travel device 100 stored in the storage unit 57 and / or a travel schedule 500 as necessary, and make various adjustments and adjustments based on these. Control can be performed.
  • control unit 5 may have a data writing device (not shown) for storing information such as the travel schedule 500 stored in the storage unit 57 in another storage medium.
  • FIG. 5 is a diagram showing a detailed configuration of a functional block of the traveling control unit.
  • the travel control unit 53 has a travel switching unit 531.
  • the travel switching unit 531 has three terminals d, e, and f.
  • the terminal d is connected to the traveling route teaching unit 7, the terminal e is connected to the motor control unit 533, and the terminal f is connected to the control control unit 55.
  • the travel switching unit 531 selects either to connect the terminal e and the terminal d or to connect the terminal e and the terminal f based on the operation mode selected by the switching unit 91. Specifically, if the manual operation mode is selected in the switching unit 91, the travel switching unit 531 connects the travel route teaching unit 7 to the motor control unit 533 by connecting the terminal e and the terminal d. .. As a result, the travel switching unit 531 transmits a signal indicating the rotation amount and / or rotation direction of the handles 71a and 71b of the travel route instruction unit 7 to the motor control unit 533 when the manual operation mode or the manual operation instruction mode is executed. can.
  • the travel switching unit 531 connects the control control unit 55 to the motor control unit 533 by connecting the terminal e and the terminal f. As a result, the travel switching unit 531 can transmit the reproduction travel control command output from the control control unit 55 to the motor control unit 533 when the autonomous travel mode is executed.
  • the motor control unit 533 calculates the target rotation speed of the traveling motor 11 based on the input rotation amount / rotation direction of the handles 71a and 71b or the reproduction traveling control command, and the traveling motor at the target rotation speed.
  • the drive power for rotating the 11 is output to the traveling motor 11.
  • the motor control unit 533 calculates the actual rotation speed of the traveling motor 11 based on the pulse signal from the encoder 111, and calculates the driving power to be output to the traveling motor 11.
  • the motor control unit 533 controls the traveling motor 11 by using, for example, a PI (Proportional Integral) control theory, a PID (Proportional Integral Differential) control theory, or the like.
  • a traveling motor 11 and a main wheel 13 are provided at each of the left and right ends of the bottom portion of the main body B.
  • the motor control unit 533 independently controls the rotation speed and the rotation direction of the two left and right traveling motors 11 to determine the traveling direction of the autonomous traveling device 100.
  • FIG. 6 is a diagram showing a detailed configuration of a functional block of the control control unit.
  • the control control unit 55 has a SLAM unit 551.
  • the SLAM unit 551 includes information on obstacles existing in front of the autonomous traveling device 100 acquired by the front detector 41a (FIG. 1) provided in front of the main body B, and rear detection provided in the rear of the main body B.
  • a local map and a global map GM are created using the information on obstacles existing behind the autonomous traveling device 100 acquired by the device 41b (FIG. 1), and these map information and the map information are used.
  • the self-position on the predetermined coordinates of the autonomous traveling device 100 is estimated.
  • the local map is map information showing the existence position of an obstacle existing around the autonomous traveling device 100, and coordinates the information about the obstacle acquired by the front detector 41a and the rear detector 41b as necessary. Created by
  • the global map GM is map information indicating the existence position of an obstacle existing in the moving environment EV, and in the present embodiment, the local map acquired by moving the autonomous traveling device 100 in the moving environment EV is connected. It is created by.
  • the SLAM unit 551 executes position estimation by dead reckoning based on the amount of rotation of the traveling motor 11 from the time of the previous self position estimation to the present, and the estimated position by dead reckoning and a plurality of self around it. Position candidates are determined, the current local map is placed on each of these multiple self-position candidates on the global map GM, and the degree of matching between the current local map placed on each self-position candidate and the global map GM is determined. The candidate for the self-position that has the maximum degree of coincidence between the current local map and the global map GM is estimated as the current self-position.
  • the front detector 41a and the rear detector 41b are, for example, laser range finders (Laser Range Finder, LRF) whose detection range is 180 ° or more.
  • LRF Laser Range Finder
  • the distance between the traveling unit 1 and the obstacle and the direction in which the obstacle exists are acquired as information about the obstacle.
  • the information acquired by the front detector 41a and the rear detector 41b may be two-dimensional information indicating the position of an obstacle on a predetermined plane, or may be the presence of an obstacle in the height direction. It may be three-dimensional information including information indicating the position.
  • the control control unit 55 has a route creation unit 553.
  • the route creation unit 553 creates a travel schedule 500 in which the autonomous travel device 100 travels evenly (as if "filling") the travel area TA in the travel area TA defined in the travel environment EV (global map GM). , Stored in the storage unit 57.
  • the control control unit 55 has a travel reproduction unit 555.
  • the travel reproduction unit 555 executes the autonomous travel mode, the autonomous travel device 100 indicates the travel schedule 500 based on the information stored in the travel schedule 500 and the estimated position information acquired from the SLAM unit 551.
  • a control command (reproduced driving control command) for autonomously traveling on the traveled route is calculated.
  • the travel reproduction unit 555 outputs the calculated reproduction travel control command to the travel control unit 53.
  • the travel reproduction unit 555 may output the cleaning conditions associated with the travel schedule 500 to the cleaning control unit 51.
  • the travel reproduction unit 555 is connected to an obstacle detection unit 43 that detects an obstacle existing in the traveling direction of the autonomous travel device 100.
  • the obstacle detection unit 43 is, for example, an ultrasonic sensor provided in front of the main body B.
  • the front detector 41a may be used as a sensor for detecting an obstacle in the traveling direction.
  • the traveling reproduction unit 555 calculates a reproduction traveling control command for avoiding the obstacle and reproduces the obstacle.
  • the control command is output to the traveling control unit 53.
  • FIG. 7 is a flowchart showing the basic operation of the autonomous traveling device.
  • the control unit 5 confirms the state of the switching unit 91 (step S1).
  • the switching unit 91 selects “automatic” (in the case of “autonomous driving mode” in step S1), the autonomous driving mode is executed (step S2), and autonomously according to the traveling schedule 500 stored in the storage unit 57.
  • the traveling device 100 autonomously executes the cleaning work.
  • the control unit 5 determines that the operation mode to be executed is the manual operation mode.
  • the control unit 5 shifts the operation mode to the manual operation teaching mode (step S4). ..
  • the operation of the autonomous traveling device 100 by the operator after the timing when the manual operation storage switch 92 is pressed is stored.
  • step S4 While executing the manual operation teaching mode in step S4 above, the control unit 5 monitors whether or not the manual operation storage switch 92 is pressed. If the manual operation storage switch 92 is pressed during the execution of the manual operation teaching mode, the manual operation teaching mode ends at that timing. After that, in step S5, the route creation unit 553 creates the travel schedule 500 using the data taught in the manual operation teaching mode.
  • step S3 when the manual operation storage switch 92 is not pressed after shifting to the manual operation mode (in the case of "No" in step S3), the execution of the manual operation mode in which the operator's operation is not stored is maintained in step S6. ..
  • the autonomous traveling device 100 has an autonomous traveling mode, a manual operation mode, depending on the selection of the operation mode in the switching unit 91 and whether or not the manual operation storage switch 92 is pressed. And the manual operation teaching mode can be executed.
  • FIG. 8 is a flowchart showing the operation of the manual operation teaching mode.
  • the creation of the global map GM representing the moving environment EV and the teaching of the outer peripheral BO'of the traveling area TA for autonomously traveling the autonomous traveling device 100 are executed.
  • step S41 the operator of the autonomous traveling device 100 drives the autonomous traveling device 100 along the outer peripheral BO'of the traveling area TA desired to be defined in the moving environment EV.
  • the SLAM unit 551 estimates the passing point passed during the movement along the outer peripheral BO'of the traveling region TA in step S42. Specifically, the SLAM unit 551 creates a local map for each predetermined cycle (for example, the control cycle of the control unit 5) while the autonomous traveling device 100 is traveling by the operation of the operator, and the local map and the local map are combined with the SLAM unit 551.
  • the current self-position of the autonomous traveling device 100 is estimated by using the global map GM created before the execution of this step S42 and stored in the storage unit 57.
  • the SLAM unit 551 After estimating the current self-position, the SLAM unit 551 combines the local map created at the time of this self-position estimation with the global map GM currently stored in the storage unit 57 in step S43 to create a new global.
  • a map GM is created and stored in the storage unit 57.
  • the SLAM unit 551 is, for example, in the coordinate system that defines the global map GM, with respect to the global map GM created before the execution of the current step S42, the local created at the time of the execution of the current step S42. Create a new global map GM by arranging the map at the coordinate position corresponding to the current self-position.
  • the route creation unit 553 creates an outer peripheral boundary BO representing the outer circumference of the traveling region TA as a set of passing points that the autonomous traveling device 100 has passed by the self-position estimation this time. Specifically, the route creation unit 553 acquires the current self-position estimated in step S42 from the SLAM unit 551, and combines the coordinate value of the self-position and the coordinate value of the self-position estimated so far. Then, the outer peripheral boundary BO is created as an aggregate of the coordinate values of the self-position.
  • step S45 the manual operation teaching mode ends (until "Yes” is set in step S45), such as when the manual operation storage switch 92 is pressed.
  • FIG. 9 is a diagram showing an example of a mobile environment.
  • FIG. 10 is a diagram showing an example of a global map and an outer boundary.
  • the mobile environment EV shown in FIG. 9 includes an area surrounded by the wall W.
  • the traveling region TA is set in the region.
  • the global map GM includes an obstacle information WI (shown by a solid line in FIG. 10) representing the wall W, as shown in FIG.
  • the obstacle information WI is a sequence of coordinate values in the coordinate system that defines the global map GM.
  • the outer peripheral boundary BO of the traveling region TA (indicated by a broken line in FIG. 10) is represented as a sequence of coordinate values of passing points passed by the autonomous traveling device 100 while executing the manual operation teaching mode.
  • FIG. 11 is a flowchart showing a running schedule creation operation.
  • an operation of creating a filled running route that fills the inside of the running area TA defined by the outer peripheral boundary BO shown in FIG. 10 created by executing the above steps S41 to S45 as a running schedule 500 will be described as an example. ..
  • the route creation unit 553 defines the outer peripheral boundary BO on the global map GM, and creates a route creation map SM used for creating a filled travel route.
  • the route creation map SM can be created by including the outer peripheral boundary BO represented as a point sequence (coordinate point) separately from the global map GM.
  • the route creation map SM is created independently of the global map GM. That is, the global map GM is used for self-position estimation, and the route creation map SM is used for creating a filled travel route.
  • step S51 the route creation unit 553 searches for a region RA extending in which direction in the traveling region TA.
  • the longitudinal direction in which the region RA extends is referred to as the "main direction”.
  • the route creation unit 553 determines the main direction of the traveling region TA according to the flowchart shown in FIG. FIG. 12 is a flowchart showing a process of determining the main direction of the traveling region.
  • the route creation unit 553 rotates the travel area TA (peripheral boundary BO) included in the route creation map SM by rotating the route creation map SM by a predetermined angle.
  • the rotation of the route creation map SM can be realized, for example, by performing an operation on the coordinate values included in the route creation map SM using a matrix representing the rotation.
  • the route creation unit 553 After rotating the traveling region TA by a predetermined angle, the route creation unit 553 connects the two boundaries of the traveling region TA after rotating by a predetermined angle in step S512, and connects the two boundaries of the traveling region TA, and the first line segment L1 parallel to the predetermined reference axis. Is defined.
  • the route creation unit 553 connects one point of the outer peripheral boundary BO and the outer peripheral boundary BO connecting the two points of the outer peripheral boundary BO. It is generated by connecting one point that interpolates between the two points of the outer boundary BO, or by connecting one point that interpolates between the two points of the outer peripheral boundary BO and another point that interpolates between the other two points of the outer peripheral boundary BO.
  • a line segment parallel to a predetermined reference axis is defined as a first line segment L1. Further, a plurality of first line segments L1 are defined for one traveling region TA after rotation.
  • the first line segment L1 as shown in FIGS. 13A to 13C is defined in the traveling region TA (the region in the outer peripheral boundary BO) according to the rotation angle of the traveling region TA.
  • 13A to 13C are diagrams showing an example of a first line segment defined in the traveling region.
  • FIG. 13A shows the first line segment L1 defined when the specific first axis of the traveling region TA is parallel to the reference axis.
  • FIG. 13B shows the first line segment L1 defined in the traveling region TA after the first axis of the traveling region TA is rotated by ⁇ 1 with respect to the reference axis.
  • FIG. 13C shows the first line segment L1 defined in the traveling region TA after the first axis of the traveling region TA is rotated by ⁇ 2 with respect to the reference axis.
  • first line segment L1 when a plurality of first line segments L1 exist on the same straight line, the longest of them may be the first line segment L1 or a plurality of them existing on the same straight line.
  • the lengths of the first line segment L1 may be integrated and regarded as one first line segment L1.
  • the route creation unit 553 After defining the first line segment L1, the route creation unit 553 satisfies the first condition that the boundary between the first line segment L1 and the traveling region TA (that is, the outer peripheral boundary BO) is orthogonal to each other in step S513. Is determined. Specifically, the determination as to whether or not the first condition is satisfied is executed according to the flowchart shown in FIG. FIG. 14 is a flowchart showing a determination process of whether or not the first condition is satisfied.
  • the route creation unit 553 determines the second line segment L2 in step S601.
  • the second line segment L2 is a line segment representing the boundary of the traveling region TA, and is determined as follows.
  • the route creation unit 553 has two first line segments that intersect the same side of the outer peripheral boundary BO (referred to as the first boundary BO1) from the plurality of first line segments L1 defined by executing the above step S512. Extract the line segment L1.
  • the two first line segments L1 to be extracted may be adjacent to each other or may be separated from each other.
  • the route creation unit 553 has a first intersection CP1 at which one of the two extracted first line segments L1 intersects with the first boundary BO1, and two extracted first lines.
  • the line segment connecting the second intersection CP2 where the other of the segments L1 and the first boundary BO1 intersect is determined to be the second line segment L2.
  • FIG. 15 is a diagram schematically showing an example of a method for determining a second line segment.
  • FIG. 15A shows an example in which the first line segment L1 is substantially orthogonal to the boundary of the traveling region TA
  • FIG. 15B shows an example in which the first line segment L1 is orthogonal to the boundary of the traveling region TA. An example of the case where there is no such thing is shown.
  • the route creation unit 553 determines in step S602 whether or not the first line segment L1 and the second line segment L2 are orthogonal to each other. For example, if the angle between the vector representing the first line segment L1 and the vector representing the second line segment L2 is 90 degrees after expressing the first line segment L1 and the second line segment L2 as vectors. It can be determined that the first line segment L1 and the second line segment L2 are orthogonal to each other.
  • the outer peripheral boundary BO is taught by executing the manual operation teaching mode. Therefore, a part of the point sequence included in the outer peripheral boundary BO may deviate from the actual boundary of the traveling region TA. That is, although the second line segment L2 is substantially parallel to the boundary of the traveling region TA, it may not be exactly parallel.
  • the present embodiment not only when the angle formed by the vector representing the first line segment L1 and the vector representing the second line segment L2 is exactly 90 degrees, but also when the value of the formed angle is close to 90 degrees. Also determines that the first line segment L1 and the second line segment L2 are orthogonal to each other. Thereby, even if the second line segment L2 is not exactly parallel to the boundary of the traveling region TA, it can be appropriately determined whether or not the boundary between the first line segment L1 and the traveling region TA is orthogonal to each other.
  • step S602 when it is determined that the first line segment L1 and the second line segment L2 are (almost) orthogonal to each other (“Yes” in step S602), the route creation unit 553 performs step S603. In, it is determined that the first condition that the boundary between the first line segment L1 and the traveling region TA is orthogonal to each other is satisfied. On the other hand, as shown in FIG. 15B, when it is determined that the first line segment L1 and the second line segment L2 are not orthogonal to each other (“No” in step S602), the route creation unit 553 determines. In step S604, it is determined that the first condition is not satisfied.
  • the first line segment L1 and the traveling region as shown in FIG. 13B above are determined.
  • the rotation angle of the traveling region TA that is not orthogonal to the boundary of TA can be excluded as a candidate for the main direction.
  • the significance of excluding the candidate in the main direction as shown in FIG. 13B will be described.
  • FIG. 16 is a diagram showing an example of a traveling region including a region determined by an inappropriate principal direction.
  • a filled traveling route is created for each region RA1'to RA3'.
  • a filled traveling route having a large number of turns is created.
  • Such a filled traveling route causes the autonomous traveling device 100 to make many turns, and the traveling efficiency is not high.
  • the candidate of the main direction as shown in FIG. 13B can be excluded by determining whether or not the first condition is satisfied, while the candidates of the main direction satisfying the first condition are FIGS. 13A and 13C. Two candidates remain, as shown in.
  • the route creation unit 553 further determines which of the two candidates shown in FIGS. 13A and 13C has the longer first line segment L1. Specifically, in the route creation unit 553, the length of the first line segment L1 is the length of the maximum length line segment LM having the maximum length among the line segments connecting the two boundaries of the traveling region TA. It is determined whether or not the second condition that the ratio is equal to or more than a predetermined ratio is satisfied.
  • step S701 the route creation unit 553 determines the maximum length line segment LM having the maximum length among the line segments connecting the two boundaries of the traveling region TA.
  • the diagonal line of the traveling region TA can be the maximum length line segment LM.
  • FIG. 18 is a diagram showing an example of the definition of the maximum length line segment. As shown in FIG. 18, when the maximum length line segment is divided into a plurality of line segments existing on the same straight line, the longest line segment among them is treated as the maximum length line segment. May be good.
  • step S702 the route creation unit 553 determines the length (referred to as L max ) of the maximum length line segment LM among the first line segment L1 defined by step S512 above.
  • the first line segment L1 having a ratio (referred to as ⁇ ) ( ⁇ * L max ) or more is selected, and the lengths of the selected first line segment L1 are integrated.
  • the above-mentioned predetermined ratio can be 0 or more and 1 or less (that is, 0 ⁇ ⁇ ⁇ 1).
  • 0.9, 0.5, or the like can be used.
  • is set to an intermediate value such as 0.5
  • the first line segment L1 having a length close to the maximum length L max can be selected, so that the optimum main direction can be determined.
  • is set to a large value such as 0.9
  • the length of the first line segment L1 is integrated at a rotation angle having the first line segment L1 that does not satisfy the condition while making it possible to determine an appropriate principal direction. Can be omitted, so that the time required for determining the principal direction can be shortened.
  • the route creation unit 553 calculates 0 as the integrated value of the lengths of the first line segment L1.
  • FIG. 19A is a diagram showing an example of a case where the integrated value of the length of the first line segment is 0.
  • 0 may not be calculated as the integrated value of the length of the first line segment L1, but may be excluded from the candidates for the integrated processing of the length of the first line segment L1.
  • the first line segment L1 included in the range of y1 ⁇ y ⁇ y2 of the axis perpendicular to the predetermined reference axis (referred to as the y-axis).
  • the length of is greater than or equal to ⁇ * L max .
  • the route creation unit 553 integrates the lengths of the first line segment L1 existing in the range of y1 ⁇ y ⁇ y2 among the first line segment L1 included in the traveling region TA of FIG. 13C. That is, a non-zero value is calculated as the integrated value of the length of the first line segment L1.
  • FIG. 19B is a diagram showing an example when the integrated value of the length of the first line segment is not 0.
  • the route creation unit 553 determines in step S703 whether or not the calculated integrated value is the maximum. When the calculated integrated value is not the maximum, for example, when the integrated value of 0 is calculated as shown in FIG. 19A (“No” in step S703), the route creation unit 553 performs the integrated value that is not the maximum in step S704. It is determined that the second condition is not satisfied for the principal direction candidate for which the calculation is performed, for example, the principal direction candidate shown in FIG. 13A.
  • the route creation unit 553 has the maximum in step S705. It is determined that the second condition is satisfied for the candidate in the main direction for which the integrated value of the above is calculated, for example, the candidate in the main direction shown in FIG. 13C. That is, it is determined that the rotation angle of the traveling region TA shown in FIG. 13C is an angle corresponding to the main direction.
  • the route creating unit 553 satisfies both the first condition and the second condition in step S515.
  • the main direction of the traveling region TA is determined based on the rotation angle of the traveling region TA. Specifically, for example, the vehicle travels at an angle ( ⁇ 2) whose sign is opposite to the rotation angle of the traveling region TA (for example, ⁇ 2 shown in FIG. 13C) when both the first condition and the second condition are satisfied. It can be determined as the main direction of the region TA.
  • the route creating unit 553 divides the traveling area TA into the area RA in step S52.
  • the division of the traveling area TA is executed according to the flowchart shown in FIG. 20A.
  • FIG. 20A is a flowchart showing the division processing of the traveling region.
  • the route creation unit 553 determines a region (referred to as a specific region) extending in the main direction determined in step S51. This specific region can be an arbitrary shape region as long as it extends in the main direction.
  • the route creation unit 553 determines in step S522 whether or not there is a small area of a predetermined area or less that is not combined with another specific area around the specific area determined in step S521. To judge.
  • the route creation unit 553 When a small area exists around the determined specific area (“Yes” in step S522), the route creation unit 553 combines the small area with the determined specific area in step S523 to form one area. It is created, and the traveling area TA is divided in the one area. On the other hand, when the small area does not exist around the determined specific area (“No” in step S522), the route creation unit 553 divides the traveling area TA in the specific area determined in step S521.
  • FIG. 20B is a diagram showing an example of an area created by dividing a part of the traveling area.
  • the route creation unit 553 determines in step S53 whether or not there is an region in the travel region TA whose principal direction has not been determined. When there is an area for which the principal direction has not been determined (“Yes” in step S53), the route creation unit 553 repeatedly executes the above steps S51 to S52 until the principal direction is determined for all the regions of the traveling region TA. do.
  • FIG. 21 is a diagram showing an example of a state in which the traveling region is divided into a plurality of regions. As shown in FIG. 21, in the present embodiment, the principal direction is determined for each of the plurality of divided regions. That is, the above step S51 is executed for each of the plurality of regions.
  • the traveling region TA is divided into a plurality of regions RA1 to RA3, and the principal direction is determined for each region RA1 to RA3, so that an appropriate principal direction is determined for each of the divided regions RA1 to RA2. Can be decided.
  • the route creation unit 553 After determining the principal direction for all the regions of the travel region TA (“No” in step S53), the route creation unit 553 has the same principal direction when the travel region TA is divided into a plurality of regions in step S54. And it is determined whether or not there are regions adjacent to each other. When the principal directions are the same and there are no regions adjacent to each other (“No” in step S54), the process of creating the travel schedule 500 proceeds to step S56.
  • the route creation unit 553 joins the regions having the same principal direction and adjacent to each other in step S55. ..
  • the traveling region TA is divided into a plurality of regions RA1 to RA3 as shown in FIG. 21, the regions RA1 and RA2 have the same principal direction and are adjacent to each other.
  • the route creation unit 553 combines the region RA1 and the region RA2 to create a new region RA4.
  • FIG. 22 is a diagram showing an example of a state in which a plurality of regions are combined to create a new region.
  • the route creation unit 553 transfers the main directions to the regions RA3 and RA4 included in the traveling region TA.
  • a filled travel path that fills each area RA3 and RA4 is created. Specifically, the filled travel route is created as follows.
  • the route creation unit 553 arranges the cell C for each area in step S56.
  • the cell C corresponds to a region having a predetermined area in the mobile environment EV.
  • the cell C is assigned to, for example, a parameter relating to the cell C (for example, a parameter for identifying the cell C, the position information of the cell C, valid / invalid of the cell C, and the cell C). It can be defined as a "structure" that includes scores, etc.).
  • a plurality of cells C can be arranged in one region RA.
  • FIG. 23 is a diagram showing an example of a state in which cells are arranged in an area.
  • the route creation unit 553 determines a cell C (referred to as a start point cell SC) that is the start point of the filled travel route in the area for creating the filled travel route.
  • the route creation unit 553 uses, for example, the cell C existing at any of the four corners of the region as the starting point cell SC.
  • the route creation unit 553 After determining the start point cell SC, the route creation unit 553 creates, in step S58, a travel route that starts from the start point cell SC and passes through all the cells C included in the target area RA as a filled travel route.
  • the route creation unit 553 creates a filled travel route according to the process shown in the flowchart of FIG. 24.
  • FIG. 24 is a flowchart showing a method of creating a filled traveling route. In the following description, a method of creating a filled travel path for the region RA shown in FIG. 23 will be described as an example.
  • step S581 the route creation unit 553 assigns a score to the cell C of the region RA. Specifically, the route creation unit 553 gives a higher score to the cell C, which is farther from the starting point cell SC in the direction perpendicular to the main direction. On the other hand, the same score is given to the cells C arranged along the main direction. As a result, the route creation unit 553 gives a score as shown in FIG. 25 to the cell C of the region RA.
  • FIG. 25 is a diagram showing an example of a score given to a cell in the area.
  • a score of "11" is given to the cell C arranged in the direction along the main direction from the starting point cell SC. This means that in the region RA, there are 11 valid cells in the main direction. For the other cells C, the score increases by a multiple of 11 as the distance from the starting cell SC is perpendicular to the main direction. Specifically, a score of "22" is given to the cell C adjacent to the starting point cell SC in the direction perpendicular to the main direction. Further, the cell C arranged in the direction along the main direction with respect to the cell C to which the score of "22" is given is given the same score of "22".
  • the route creation unit 553 extends the route from the starting point cell SC to each cell C in step S582. Specifically, the route creation unit 553 routes a route from the start point cell SC to the cell C to which the maximum score is given among the cells C existing in the principal direction of the start point cell SC or in the direction perpendicular to the principal direction. extend. Further, the route creation unit 553 does not extend the route to the cell C again unless there are special circumstances such as the route cannot be planned unless the route passes through the cell C again. To.
  • step S582 is repeatedly executed.
  • FIG. 26 is a diagram showing an example of a filled travel path.
  • the filled travel path includes a first path extending in the main direction of the region RA and a second path extending perpendicular to the main direction and connected to the start point and / or the end point of the first path. It is created by combining. As a result, a filled travel route that evenly fills the region RA can be created as a route that the autonomous traveling device 100 can travel by a simple operation of going straight and changing direction.
  • the first path extends over a plurality of cells C along the main direction, while the second path is the start point cell SC and the start point of the first path on the opposite side thereof. Except for the route connecting the cells, only one cell C is extended. That is, the filled travel path created by executing the above steps S581 to S583 has a long path along the main direction of the region. By lengthening the path along the principal direction of the region in this way, the number of turns of the autonomous traveling device 100 in the filled traveling path can be reduced.
  • the second path extending by only one cell C connects two adjacent first paths and changes the traveling direction of the autonomous traveling device 100
  • the second path is relative to the main direction. It is not limited to a path extending in a vertical direction.
  • a U-shaped path connecting two adjacent first paths, a path by rotational movement connecting two adjacent first paths, and the like can be used as the second path.
  • the route creating unit 553 determines in step S59 whether or not there is an area for which the filled traveling route has not been created yet. If there is no area for which the filled travel path has not been created (in the case of "No" in step S59), the process of creating the travel schedule 500 proceeds to step S62.
  • the route creation unit 553 sets the new start point cell SC of the filled travel route to be created next in step S60. To decide.
  • the route creation unit 553 determines, for example, the cell C that can be reached at the shortest distance from the end point cell EC, which is the end point of the filled travel path created in the region RA, as the new start point cell SC. Thereby, the area including the new start point cell SC can be determined as the area for creating the next filled travel path.
  • FIG. 27 is a diagram schematically showing an example of a method of determining a new starting point cell and a region for creating a next filled travel path.
  • the cell C that can be connected to the end point cell EC, which is the end point of the created filled travel path, at the shortest distance is determined as the new start point cell SC, and the area RA4 including the new start point cell SC is next filled and traveled.
  • the area for creating a route it is possible to create a travel schedule 500 having a high travel efficiency, which is the shortest distance.
  • the route creation unit 553 After determining the new start point cell SC and the area for creating the next filled travel route, the route creation unit 553 sets the end point cell EC, which is the end point of the created filled travel route, and the determined new start point cell SC in step S61. And are connected by the connection path.
  • step S58 a filled travel path is created in the area including the new starting point cell SC.
  • steps S58 steps S581 to S583) to S61 are repeatedly executed until the filled travel path is created in all the regions RA3 and RA4 (that is, until step S59 becomes "No").
  • FIG. 28 is a diagram showing an example of a filled travel path created in the entire travel area.
  • the route creating unit 553 converts the created filled travel route into a set of passing points through which the autonomous traveling device 100 passes in step S62. Further, the route creation unit 553 associates the time for passing through the passing point with each passing point generated by converting the filled traveling route. Further, by associating the cleaning conditions at each passing point with the corresponding passing points, the traveling schedule 500 as shown in FIG. 29 is created.
  • FIG. 29 is a diagram showing an example of a running schedule.
  • T 0 , T 1 , ... Tn are times for passing through each passing point of the filled travel route.
  • (X 0 , y 0 ), (x 1 , y 1 ), ... (X n , y n ) represent each passing point of the filled travel path as a coordinate value.
  • ⁇ 0 , ⁇ 1 , ... ⁇ n are the postures of the autonomous traveling device 100 at each passing point of the filled traveling path.
  • S 0 , S 1 , ... Sn are the supply amounts of the cleaning liquid at each passing point of the filled running path.
  • W 0 , W 1 , ... W n is the cleaning power of the floor surface F at each passing point of the filled traveling path.
  • P 0 , P 1 , ... P n are suction forces of the suction port 33a at each passing point of the filled traveling path.
  • FIG. 30 is a flowchart showing the operation of the autonomous traveling device when the autonomous traveling mode is executed.
  • the start position of autonomous running is the passing point associated with the elapsed time T0 in the running schedule 500.
  • the autonomous driving mode is started.
  • the travel reproduction unit 555 determines the target position in which the autonomous travel device 100 autonomously travels. Specifically, the travel reproduction unit 555 determines the current elapsed time associated with the passing point closest to the current position in the travel schedule 500, and is associated with the next elapsed time of the current elapsed time. The passing point is determined as the next target position.
  • the travel reproduction unit 555 After determining the target position, the travel reproduction unit 555 starts control for autonomous travel. First, the traveling reproduction unit 555 grasps the current position of the autonomous traveling device 100 in step S22. Specifically, the SLAM unit 551 is based on the rotation amount of the traveling motor 11 between the previous self-position estimation measured by the encoder 111 and the current self-position estimation, and the obstacle information acquired at the current position. Based on the created local map and the global map GM stored in the storage unit 57, the self-position of the current autonomous traveling device 100 is estimated by the process described above. After that, the traveling reproduction unit 555 inputs the self-position estimated by the SLAM unit 551.
  • traveling control from the current position to the target position is executed.
  • the travel reproduction unit 555 determines in step S23 whether or not the obstacle detection unit 43 has detected an obstacle within the detectable range.
  • the traveling reproduction unit 555 travels the autonomous traveling device 100 from the current position to the target position determined in step S21 in step S24.
  • the reproduction running control command to be caused is calculated and output to the running control unit 53.
  • the traveling reproduction unit 555 plans a route for avoiding the detected obstacle in step S25, and the autonomous traveling device.
  • a reproduction travel control command for traveling the route to 100 is calculated and output to the travel control unit 53.
  • the traveling reproduction unit 555 changes the target position determined in step S21 above, depending on the planned avoidance route. For example, among the passing points stored in the traveling schedule 500, a passing point separated by a predetermined distance from the current position is set as a new target position.
  • the travel control unit 53 that has received the above-mentioned reproduction travel control command controls the travel motor 11 based on the received reproduction travel control command, and causes the autonomous travel device 100 to travel in accordance with the reproduction travel control command. Further, the traveling reproduction unit 555 calculates the reproduction cleaning condition based on the cleaning condition associated with the current elapsed time, and outputs the reproduction cleaning condition to the cleaning control unit 51. As a result, the cleaning unit 3 can be controlled according to the calculated reproduction cleaning conditions.
  • the travel reproduction unit 555 determines in step S26 whether or not the autonomous travel device 100 has reached the determined target position. For example, when the current position coincides with the target position or is within a predetermined range, it can be determined that the autonomous traveling device 100 has reached the target position. If the autonomous traveling device 100 has not yet reached the target position (“No” in step S26), the autonomous traveling operation returns to step S22. That is, the above steps S22 to S25 are repeatedly executed until the target position is reached. The above steps S22 to S25 are executed for each control cycle by the control unit 5.
  • the traveling reproduction unit 555 may execute the traveling stored in the traveling schedule 500 in step S27. Determine if all actions have been performed. Whether or not all the traveling operations stored in the traveling schedule 500 have been completed can be determined, for example, by detecting an identifier at the end of the traveling schedule 500 (for example, an identifier indicating an "end of file").
  • step S27 the autonomous traveling operation returns to step S21. That is, the above steps S21 to S26 are repeatedly executed until all the traveling operations stored in the traveling schedule 500 are executed.
  • step S27 when it is determined that all the running operations stored in the running schedule 500 have been executed (“Yes” in step S27), the execution of the autonomous running mode is terminated.
  • the travel schedule 500 (filled travel route) created in this embodiment is created by determining an appropriate main direction of the travel region TA (region). That is, in the travel schedule 500, the number of turning routes that reduce the travel speed of the autonomous travel device 100 is small. Therefore, by executing the above steps S21 to S27 and autonomously traveling in the traveling area TA according to the traveling schedule 500 of the present embodiment, the autonomous traveling device 100 efficiently paints the traveling area TA with a small number of turns. You can drive autonomously on the crushing route.
  • a traveling route is created by filling the traveling area TA in a state where an appropriate principal direction is determined by the method of the present embodiment, traveling in a state where an erroneous principal direction is determined by the conventional principal direction determining method.
  • the time required to autonomously travel all the filled travel routes is reduced by about 20%.
  • the main direction of the traveling region TA is to rotate the traveling region TA by a predetermined angle, and for each rotation angle of the traveling region TA, the first line segment L1 (traveling region TA).
  • the first line segment that connects the two boundaries and is parallel to the predetermined reference axis) and the boundary of the traveling region TA is orthogonal to each other, and whether or not the first condition is satisfied, and the first line segment that satisfies the first condition. It was determined by determining whether or not the second condition that the length of L1 is equal to or more than a predetermined ratio of the length of the maximum length line segment LM is satisfied. Therefore, in the first embodiment, the determination of the first condition and the second condition is performed even at the rotation angle which is likely not to be clearly selected as the main direction. That is, the judgment of the first condition and the second condition was unnecessarily executed.
  • the candidates for the rotation angle that can be the main direction are determined in advance, and then the main direction determination process (that is, steps S511 to S515) described in the first embodiment is executed.
  • the candidate for the rotation angle is determined in advance when determining the main direction, which is different from the first embodiment. Therefore, in the following, a method for determining a candidate for a rotation angle will be described below, and other description regarding the autonomous traveling device 100 will be omitted.
  • the longitudinal direction (that is, the main direction) of the region closed by the plurality of boundary lines, such as the traveling region TA, is generally the direction in which the relatively long boundary line of the plurality of boundary lines extends. .. Therefore, in the second embodiment, the direction in which the relatively long boundary line extends out of the boundary line (outer peripheral boundary BO) of the traveling area TA is used as a candidate for the rotation angle of the traveling area TA in step S511.
  • the rotation angle candidate can be determined by processing according to the flowchart shown in FIG.
  • FIG. 31 is a flowchart showing an operation of determining a candidate for a rotation angle.
  • FIG. 32 is a diagram showing an example of a traveling region.
  • the outer peripheral boundary BO is composed of a point cloud having n-1 points (P1, P2, ... Pk, ... Pn-1).
  • the point P1 can also be expressed as a point Pn.
  • the route creation unit 553 sets a specific point (referred to as a point Pk) among a plurality of points constituting the outer peripheral boundary BO and a point adjacent to the specific point Pk (referred to as a point Pk + 1).
  • a point Pk a point adjacent to the specific point Pk
  • the direction in which the line segment PkPk + 1 connecting the two points extends is calculated from, for example, the arctangent of the ratio of the length in the direction parallel to the reference axis of the line segment PkPk + 1 to the length in the direction perpendicular to the reference axis. can.
  • step S802 the route creation unit 553 calculates the cumulative length of the line segment extending in the same direction (angle) as the line segment PkPk + 1 extends. Specifically, the length of the line segment PkPk + 1 calculated this time is added to the cumulative length calculated so far for the line segment extending in the same direction as the line segment PkPk + 1.
  • the extending direction of the line segment and the cumulative length are calculated for all the points constituting the outer peripheral boundary BO, and the relationship between the angle with respect to the reference axis and the cumulative length of the line segment extending in the direction of the angle is represented.
  • a histogram is generated.
  • a histogram as shown in FIG. 33 is generated.
  • FIG. 33 is a diagram showing an example of a histogram showing the relationship between the angle with respect to the reference axis and the cumulative length of the line segment extending in the direction of the angle.
  • the angle ⁇ 'and the angle ⁇ '+ 180 ° can be regarded as the same as the extending direction of the line segment, and the angle ⁇ '+ 90 ° and the angle ⁇ '+ 270 ° can be regarded as the same as the extending direction of the line segment. can. Therefore, instead of the histogram in which the angle range is 0 ° to 360 ° as shown in FIG. 32, the cumulative length at the angle ⁇ 'and the cumulative length at ⁇ '+ 180 ° are added to obtain the cumulative length of the angle ⁇ '.
  • the cumulative length at ⁇ '+ 90 ° and the cumulative length at ⁇ '+ 270 ° may be added to obtain a cumulative length of ⁇ '+ 90 °, and a histogram may be generated in which the angle range is limited to the range of 0 ° to 180 °.
  • the main direction of the area closed by the plurality of boundary lines is generally the direction in which the relatively long boundary line extends among the plurality of boundary lines.
  • the direction in which a relatively long line out of a plurality of boundary lines extends corresponds to an angle at which the cumulative length is equal to or greater than a predetermined threshold value.
  • step S803 the route creation unit 553 determines an angle at which the cumulative length is equal to or greater than a predetermined threshold value VTH in the histogram created as described above as a candidate for the rotation angle of the traveling region TA in step S511. do.
  • ⁇ '+ 180 ° which can also be regarded as the angle ⁇ '
  • ⁇ '+ 90 ° which can also be regarded as the angle ⁇ '+ 90 °
  • a histogram showing the relationship between the direction (angle) in which the sides constituting the outer peripheral boundary BO extend and the total length of the sides extending in the same direction (that is, the cumulative length) is generated, and the histogram is generated.
  • a direction (angle) in which the total length (cumulative length) of the sides extending in the same direction is equal to or larger than a predetermined threshold value as a candidate for the rotation angle of the traveling region TA "at a plurality of boundary lines".
  • the main direction of the closed region is the direction in which the relatively long boundary line of the plurality of boundary lines extends. ”
  • the candidate rotation angle can be appropriately determined. That is, an angle that is not "a direction in which a relatively long line out of a plurality of boundary lines extends", for example, a diagonal angle that crosses the traveling region TA can be appropriately excluded from the candidates for the rotation angle.
  • the present invention is not limited to this, and a plurality of sides constituting the outer peripheral boundary BO are specified, the extending direction and length are classified for each of the specified plurality of sides, and the side having a length equal to or more than a predetermined threshold is extended.
  • the direction may be a candidate for the rotation angle.
  • the extending direction (angle) of the line segment PkPk + 1 (k 1, 2, ... n-1) and other line segments (line segment Pk + 1Pk + 2, line segment Pk + 2Pk + 3, ... ) And the absolute value of the difference between them is a predetermined angle (for example, within 5 °), a line segment composed of the line segment PkPk + 1 and the other line segment (in the above description).
  • a side composed of a point group of points Pk, Pk + 1, Pk + 2, Pk + 3, ...) Can be determined to be included in the same side of the outer peripheral boundary BO.
  • FIG. 34 is a diagram showing an example of a state in which the sides constituting the outer peripheral boundary are specified.
  • FIG. 35 is generated.
  • FIG. 35 is a diagram showing an example of a histogram in which the extending direction and the length of the sides are classified for each side.
  • the extending direction of the longest side LIN1 is ⁇ '
  • the extending direction of the short sides LIN2, LIN4, and LIN6 is ⁇ '+ 270 °
  • the extending direction of the short sides LIN3, LIN5, and LIN7 is. It can be classified as ⁇ '+ 180 ° and the extension direction of the relatively long side LIN8 is ⁇ '+ 90 °. In this way, by classifying the extending direction and the length for each side constituting the outer peripheral boundary BO, it is possible to generate a histogram in which the shape of the traveling region TA is more accurately reflected.
  • the traveling region TA is composed of a long side extending in a specific direction and a large number of short sides extending in another direction
  • the cumulative length of the line segment in the "other direction” As a result of the fact that the length is larger than the cumulative length of the line segment in the "specific direction”, it is possible to prevent the "other direction” from being mistakenly recognized as a candidate for the rotation direction.
  • the angles ⁇ ', the angle ⁇ '+ 90 °, and the angles ⁇ '+ 180 ° and ⁇ '+ 270 ° are specified as candidates for the rotation angle.
  • the first line segment L1 is a line segment connecting two points of the outer peripheral boundary BO, and one point of interpolating between one point of the outer peripheral boundary BO and two points of the outer peripheral region. It was one of a line segment connecting one point that interpolates between two points of the outer peripheral boundary BO and another one point that interpolates between the other two points of the outer peripheral boundary BO.
  • the present invention is not limited to this, and when defining the first line segment L1, a plurality of cells similar to the cell C arranged when the filled traveling path is generated are arranged in the traveling area TA, and the outer circumference of the traveling area TA is arranged.
  • the line segment connecting the representative points of the two cells existing on the boundary BO may be defined as the first line segment L1.
  • the representative point of the cell is, for example, the center point of the cell.
  • the maximum length line segment LM may be a line segment having the maximum length among the line segments connecting the representative points of the two cells existing on the outer peripheral boundary BO. Thereby, the first line segment L1 and the maximum length line segment LM can be easily defined by using a cell.
  • the second condition that the length of the first line segment L1 is equal to or more than a predetermined ratio of the length of the maximum length line segment LM is satisfied is determined by the first line. It was calculated from the integrated value of the length of the minute L1, but it is not limited to this.
  • the candidate having the maximum length (average value) of the first line segment L1 is selected as the second candidate. It may be a candidate for the main direction that satisfies the conditions. Thereby, it can be easily determined whether or not the second condition is satisfied.
  • the first line segment L1 having a length equal to or more than a predetermined ratio of the length of the maximum length line segment LM is selected, and the length of the first line segment L1 is integrated. The value was calculated, and it was determined whether or not the second condition was satisfied depending on whether or not the integrated value was the maximum.
  • the predetermined ratio ( ⁇ ) for selecting the first line segment L1 used for calculating the integrated value of the length is a fixed value.
  • the present invention is not limited to this, and the above-mentioned predetermined ratio ( ⁇ ) may be made variable for each rotation angle of the traveling region TA.
  • a predetermined ratio ( ⁇ ) is changed for each rotation angle, and the first line segment L1 used for calculating the integrated value of the length is parallel to the predetermined reference axis and is a predetermined distance (rotation). It may be the first line segment L1 included in the region defined by two straight lines separated by a distance (distance that does not change with respect to an angle).
  • the range including the first line segment L1 used for calculating the integrated value of the length can be fixed, so that the integrated value can be easily calculated.
  • the autonomous traveling device 100 may be a traveling device other than the cleaning machine that autonomously executes the cleaning work.
  • the autonomous traveling device 100 may be a promotional robot.
  • the autonomous traveling device 100 may be composed of only a traveling unit (and a control unit that controls the traveling unit) for autonomously traveling.
  • a robot (device) having a desired function can be configured by combining the autonomous traveling device and a robot system for exerting a desired function.
  • the cleaning condition is not stored in the traveling schedule 500.
  • information regarding control according to the application of the autonomous traveling device 100 may be stored.
  • the creation of the global map GM and the outer peripheral boundary BO is performed by executing the manual operation teaching mode and moving the autonomous traveling device 100 along the outer peripheral BO'of the traveling region TA. It was realized by estimating the passing points that passed while moving along the outer peripheral BO'of the traveling region TA, and collecting the passing points to create the outer peripheral boundary BO. That is, the creation of the outer peripheral boundary BO was performed by actually running the autonomous traveling device 100 along the outer peripheral BO'of the traveling region TA. Further, the global map GM was acquired while executing the teaching of the outer peripheral BO'.
  • the present invention is not limited to this, and by drawing the boundary line corresponding to the outer peripheral boundary BO on the global map GM using image editing software such as CAD software, dedicated software for drawing the outer peripheral boundary BO, etc., the outer peripheral boundary BO is drawn. May be created.
  • the global map GM may be created by executing the manual operation teaching mode as in the first embodiment, or image editing software such as CAD software, dedicated software for creating the global map GM, or the like may be used. You may create it.
  • Rotation angle candidates may be determined. This makes it possible to determine rotation angle candidates with high resolution.
  • the present invention can autonomously travel so as to fill a traveling area defined in a moving environment, and can be widely applied to an autonomous traveling device that travels while avoiding obstacles existing in the traveling area.

Landscapes

  • Engineering & Computer Science (AREA)
  • Aviation & Aerospace Engineering (AREA)
  • Radar, Positioning & Navigation (AREA)
  • Remote Sensing (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Automation & Control Theory (AREA)
  • Control Of Position, Course, Altitude, Or Attitude Of Moving Bodies (AREA)

Abstract

La présente invention a pour objet la création d'un itinéraire de déplacement complété ayant une efficacité de déplacement satisfaisante en déterminant une direction principale appropriée pour une zone de déplacement. Le procédé de planification d'un itinéraire de déplacement autonome d'après la présente invention comprend : une étape (S511 à S513) consistant à faire tourner une zone de déplacement (TA) à chaque fois sur un angle prescrit et à déterminer si une première condition est satisfaite, à savoir qu'un premier segment de ligne (L1) joignant deux limites de la zone de déplacement (TA) et parallèle à un axe de référence prescrit et une limite de la zone de déplacement (TA) soient perpendiculaires; une étape (S514) consistant à déterminer si une seconde condition est satisfaite, à savoir que la longueur du premier segment de ligne (L1) soit supérieure ou égale à une proportion prescrite de la longueur (Lmax) d'un segment de ligne de longueur maximale (LM); une étape (S515) consistant à paramétrer une direction principale de la zone de déplacement (TA) sur la base de l'angle de rotation de la zone de déplacement (TA) lorsque les première et seconde conditions sont satisfaites; et une étape (S56 à S62) consistant à combiner un premier trajet s'étendant dans la direction principale et un second trajet relié au point de départ et/ou au point d'arrivée du premier trajet afin de créer un itinéraire de déplacement complété de manière à compléter la zone de déplacement (TA).
PCT/JP2021/034563 2020-09-23 2021-09-21 Procédé de planification d'un itinéraire de déplacement autonome WO2022065297A1 (fr)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
JP2020158881A JP2023164760A (ja) 2020-09-23 2020-09-23 自律走行経路計画方法
JP2020-158881 2020-09-23

Publications (1)

Publication Number Publication Date
WO2022065297A1 true WO2022065297A1 (fr) 2022-03-31

Family

ID=80845443

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/JP2021/034563 WO2022065297A1 (fr) 2020-09-23 2021-09-21 Procédé de planification d'un itinéraire de déplacement autonome

Country Status (2)

Country Link
JP (1) JP2023164760A (fr)
WO (1) WO2022065297A1 (fr)

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2018116614A (ja) * 2017-01-20 2018-07-26 株式会社クボタ 走行経路生成装置及び走行経路生成プログラム
JP2019101932A (ja) * 2017-12-06 2019-06-24 ヤンマー株式会社 作業車両用の目標経路生成システム

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2018116614A (ja) * 2017-01-20 2018-07-26 株式会社クボタ 走行経路生成装置及び走行経路生成プログラム
JP2019101932A (ja) * 2017-12-06 2019-06-24 ヤンマー株式会社 作業車両用の目標経路生成システム

Also Published As

Publication number Publication date
JP2023164760A (ja) 2023-11-13

Similar Documents

Publication Publication Date Title
JP6673486B2 (ja) 走行経路作成方法、自律走行装置、及びプログラム
US9931010B2 (en) Autonomously traveling floor washer, cleaning schedule data structure, storage medium, method for creating cleaning schedule, and program
EP3602223B1 (fr) Système et procédé de planification de trajectoire de robot
KR102504729B1 (ko) 웨이포인트 매칭을 이용한 자율적 맵 주행
CN106535614A (zh) 分离的草坪区块的机器人割刈
EP2296072A2 (fr) Système de vision stéréoscopique asymétrique
JPH09174471A (ja) ロボットの環境認識装置およびその制御方法
JP2011138502A (ja) 区域分解を用いるエリア・カバレッジ・システムおよび方法
JP2004326692A (ja) 自律走行ロボット
US11537141B2 (en) Robotic cleaning device with dynamic area coverage
WO2021106331A1 (fr) Chariot mobile autonome, procédé de commande et programme
WO2022065297A1 (fr) Procédé de planification d'un itinéraire de déplacement autonome
JP7459497B2 (ja) 経路計画装置、経路計画方法及び自律走行台車
WO2022054647A1 (fr) Procédé de détermination de région de déplacement et corps mobile autonome
US20230195121A1 (en) Path generating method, program, path generating device, and autonomous mobile body
WO2022038823A1 (fr) Procédé de planification de trajets de déplacement autonome, procédé de déplacement autonome et programme
EP4242770A1 (fr) Procédé de planification d'un trajet de déplacement autonome
JP7484669B2 (ja) 自律走行体の走行教示記憶方法、自律走行体、記録媒体
JP7461801B2 (ja) 清掃装置、プログラム及び表示端末
JP2024076018A (ja) 自律走行装置およびその妥当性評価方法
CN116687271A (zh) 一种地面垃圾智能检测及快速清扫系统及方法
JP2024062748A (ja) 自律移動体制御システム、自律移動体制御方法、及び自律移動体制御プログラム
Azkune et al. A navigation system for a high-speed professional cleaning robot

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 21872426

Country of ref document: EP

Kind code of ref document: A1

NENP Non-entry into the national phase

Ref country code: DE

122 Ep: pct application non-entry in european phase

Ref document number: 21872426

Country of ref document: EP

Kind code of ref document: A1

NENP Non-entry into the national phase

Ref country code: JP