JP2020534621A - 最適相互衝突回避のコスト−クリティックを用いたダイナミック・ウィンドウ・アプローチ - Google Patents

最適相互衝突回避のコスト−クリティックを用いたダイナミック・ウィンドウ・アプローチ Download PDF

Info

Publication number
JP2020534621A
JP2020534621A JP2020516695A JP2020516695A JP2020534621A JP 2020534621 A JP2020534621 A JP 2020534621A JP 2020516695 A JP2020516695 A JP 2020516695A JP 2020516695 A JP2020516695 A JP 2020516695A JP 2020534621 A JP2020534621 A JP 2020534621A
Authority
JP
Japan
Prior art keywords
robot
speed
candidate
velocity
pose
Prior art date
Legal status (The legal status 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 status listed.)
Granted
Application number
JP2020516695A
Other languages
English (en)
Other versions
JP6987226B2 (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 JP2020534621A publication Critical patent/JP2020534621A/ja
Application granted granted Critical
Publication of JP6987226B2 publication Critical patent/JP6987226B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

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/0214Control of position or course in two dimensions specially adapted to land vehicles with means for defining a desired trajectory in accordance with safety or protection criteria, e.g. avoiding hazardous areas
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B60VEHICLES IN GENERAL
    • B60WCONJOINT CONTROL OF VEHICLE SUB-UNITS OF DIFFERENT TYPE OR DIFFERENT FUNCTION; CONTROL SYSTEMS SPECIALLY ADAPTED FOR HYBRID VEHICLES; ROAD VEHICLE DRIVE CONTROL SYSTEMS FOR PURPOSES NOT RELATED TO THE CONTROL OF A PARTICULAR SUB-UNIT
    • B60W30/00Purposes of road vehicle drive control systems not related to the control of a particular sub-unit, e.g. of systems using conjoint control of vehicle sub-units
    • B60W30/08Active safety systems predicting or avoiding probable or impending collision or attempting to minimise its consequences
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01CMEASURING DISTANCES, LEVELS OR BEARINGS; SURVEYING; NAVIGATION; GYROSCOPIC INSTRUMENTS; PHOTOGRAMMETRY OR VIDEOGRAMMETRY
    • G01C21/00Navigation; Navigational instruments not provided for in groups G01C1/00 - G01C19/00
    • G01C21/20Instruments for performing navigational calculations
    • G01C21/206Instruments for performing navigational calculations specially adapted for indoor navigation
    • 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/0217Control of position or course in two dimensions specially adapted to land vehicles with means for defining a desired trajectory in accordance with energy consumption, time reduction or distance reduction criteria
    • 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/0223Control of position or course in two dimensions specially adapted to land vehicles with means for defining a desired trajectory involving speed control of the vehicle
    • 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/0268Control of position or course in two dimensions specially adapted to land vehicles using internal positioning means
    • G05D1/0272Control of position or course in two dimensions specially adapted to land vehicles using internal positioning means comprising means for registering the travel distance, e.g. revolutions of wheels
    • 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/0276Control of position or course in two dimensions specially adapted to land vehicles using signals provided by a source external to the vehicle
    • G05D1/0278Control of position or course in two dimensions specially adapted to land vehicles using signals provided by a source external to the vehicle using satellite positioning signals, e.g. GPS
    • 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/0287Control of position or course in two dimensions specially adapted to land vehicles involving a plurality of land vehicles, e.g. fleet or convoy travelling
    • G05D1/0289Control of position or course in two dimensions specially adapted to land vehicles involving a plurality of land vehicles, e.g. fleet or convoy travelling with means for avoiding collisions between vehicles
    • GPHYSICS
    • G08SIGNALLING
    • G08GTRAFFIC CONTROL SYSTEMS
    • G08G1/00Traffic control systems for road vehicles
    • G08G1/16Anti-collision systems
    • G08G1/166Anti-collision systems for active traffic, e.g. moving vehicles, pedestrians, bikes
    • 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/0231Control of position or course in two dimensions specially adapted to land vehicles using optical position detecting means
    • G05D1/0234Control of position or course in two dimensions specially adapted to land vehicles using optical position detecting means using optical markers or beacons
    • 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/0268Control of position or course in two dimensions specially adapted to land vehicles using internal positioning means
    • G05D1/0274Control of position or course in two dimensions specially adapted to land vehicles using internal positioning means using mapping information stored in a memory device
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q10/00Administration; Management
    • G06Q10/04Forecasting or optimisation specially adapted for administrative or management purposes, e.g. linear programming or "cutting stock problem"
    • G06Q10/047Optimisation of routes or paths, e.g. travelling salesman problem
    • GPHYSICS
    • G08SIGNALLING
    • G08GTRAFFIC CONTROL SYSTEMS
    • G08G1/00Traffic control systems for road vehicles
    • G08G1/16Anti-collision systems
    • G08G1/164Centralised systems, e.g. external to vehicles

Landscapes

  • Engineering & Computer Science (AREA)
  • Radar, Positioning & Navigation (AREA)
  • Remote Sensing (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Automation & Control Theory (AREA)
  • Aviation & Aerospace Engineering (AREA)
  • Business, Economics & Management (AREA)
  • Human Resources & Organizations (AREA)
  • Strategic Management (AREA)
  • Economics (AREA)
  • Mechanical Engineering (AREA)
  • Transportation (AREA)
  • Game Theory and Decision Science (AREA)
  • Entrepreneurship & Innovation (AREA)
  • Marketing (AREA)
  • Operations Research (AREA)
  • Quality & Reliability (AREA)
  • Tourism & Hospitality (AREA)
  • General Business, Economics & Management (AREA)
  • Theoretical Computer Science (AREA)
  • Development Economics (AREA)
  • Control Of Position, Course, Altitude, Or Attitude Of Moving Bodies (AREA)
  • Electromagnetism (AREA)

Abstract

目標経路に沿ってロボットをナビゲートし、障害物を回避するための方法及びシステム。方法は、1つ又は複数のロボットの目標ポーズを受信するステップと、受信した障害物マップの移動障害物及び固定障害物を回避しながら第1のロボットに関する目標経路を決定するステップと含む。第1の目的関数を評価して、生成された候補速度のセットから推奨速度を選択し、選択するステップは、1つ又は複数の重み付きコスト関数に基づく。1つ又は複数のロボットのポーズ及び推奨速度に基づいて作成された速度障害物のセットは、次の時間サイクルでのロボットの動きを決定するための第2の目的関数を評価する際に使用される。速度オブジェクトのセットを作成するステップは、推奨速度を非ホロノミック速度からホロノミック速度に変換することを含む。

Description

本出願は、2017年9月22日に出願した「Multi−Resolution Scan Matching With Exclusion Zones」という名称の米国出願第15/712,222号に関連する2017年9月22日に出願した米国出願第15/712,256号の優先日の利益を主張するものであり、これらの出願の両方が参照により本明細書に組み込まれる。
本明細書に記載の本発明は、一般に、移動障害物及び静止障害物の存在下でのターゲット位置に向かう目標経路に沿ったロボット・ナビゲーションに関する。詳細には、本発明は、目標経路に沿った進行を最大化すると同時に、障害物との衝突を回避するロボットの増分移動の軌道を決定するための改善された方法である。
多くの用途において、生産性及び効率を高めるために、人間の代わりに機能を実行するための、又は人間を支援するためのロボットが使用される。そのような用途の1つは注文履行であり、これは、典型的には、宅配のためにインターネットを通じて注文した顧客に出荷される製品で満たされた大型倉庫で実行される。そのような注文を適時、正確、且つ効率的な方法で履行することは、控えめに言っても物流上の難問である。
例えば、オンラインのインターネット・ショッピングの用途では、仮想ショッピング・カート内の「清算」ボタンをクリックすると、「注文」が作成される。注文は、特定の住所に出荷される物品のリストを含む。「履行」のプロセスは、これらの物品を大型倉庫から物理的に取ること又は「ピッキング」、それらを梱包すること、及びそれらを指定された住所に出荷することを含む。
したがって、注文履行プロセスの重要な目標は、できるだけ多くの物品をできるだけ短時間で出荷することである。注文を受け、その履行を計画し、保管棚又はビンを見つけ、製品をピックし、注文中の物品ごとにこのプロセスを繰り返し、その後、注文品を出荷ステーションに配送するというプロセスは、反復的で労働集約的である。急速に在庫が変化する何千又は何万もの物品が保管されている倉庫において、ロボットは、適時で効率的な注文履行を確保する上で重要な役割を果たす。さらに、最終的に出荷されることになる製品は、最初に倉庫内に受け入れられ、出荷のために容易に取り出せるように倉庫全体にわたって規則的な方法で保管ビンに保管又は「配置」される必要がある。
ロボットを使用してピッキング及び配置の機能を実行することは、ロボット単独で、又は人間の作業者の支援と共に実施される。人間が介在して実行されるかどうかに関わりなく、ピッキング及び配置又は保管の機能は、ロボットがその現在位置からターゲットの製品保管場所又は「ビン」位置にナビゲートする必要がある。ロボットは、通常、現在位置から製品保管ビンまでのロボットの目標経路に沿って、壁、棚、支持構造、人間、及び他のロボットなどの静止障害物及び移動障害物に遭遇する。さらに、新しい製品が保管されるとき及び在庫がなくなるとき、新しい棚及びビンが追加及び撤去されるとき、並びに多種多様な物体が共有の人間とロボットの空間に導入されるとき、注文履行倉庫の動的な性質上、倉庫及びその内容に関する情報を常に更新する必要がある。
ロボットの目標経路をナビゲートする際の障害物回避は、近くの固定障害物及び移動障害物の情報を使用して、一連の増分移動を計算することを含む。増分移動は、固定された又は移動している障害物にロボットを追突させてはならず、その移動を駆動するためのロボットの軌道は、固定サイクル時間内で計算される必要がある。しかしながら、既知のロボット・ナビゲーションの方法は、固定障害物をナビゲートするのにより適した手法と、移動障害物すなわちロボットをナビゲートするのにより適した手法とのどちらかを選択する。必要とされるのは、移動障害物と固定障害物の両方を考慮したロボット・ナビゲーションの計算効率の高い方法であり、それにより、各増分移動に割り当てられたサイクル時間でロボットがそのターゲット位置に向かって進む能力を向上させる。
Frese,U.、Wagner,R.、Rofer,T.、「A SLAM overview from a user’s perspective」、Kunstliche Intelligenz 24(3)、191〜198頁(2010) Berthold K.P.Horn、「Closed−form solution of absolute orientation using unit quaternions」、Journal of the Optical Society of America、4(4)、1987年4月、629〜642頁 Edwin Olson、「M3RSM:Many−to−many multi−resolution scan matching」、Proceedings of the IEEE International Conference on Robotics and Automation(ICRA)、2015年6月 Sebastian Thrun、「Robotic Mapping:A Survey」、Carnegie−Mellon University、CMU−CS−02−111、2002年2月 Jur van den Berg、Stephen J.Guy、Ming Lin及びDinesh Manocha、「Reciprocal n−body collision avoidance」、Robotics Research:The 14th International Symposium ISRR、Cedric Pradalier、Roland Siegwart及びGerhard Hirzinger(編)、Springer Tracts in Advanced Robotics、Vol.70、Springer−Verlag、2011年5月、3〜19頁 D.Fox、W.Burgard及びS.Thrun、「The Dynamic Window Approach to Collision Avoidance」、Robotics&Automation Magazine、IEEE、vol.4、no.1.(1997年3月)、23〜33頁
本発明の利益及び利点は、以下の発明の概要及び発明を実施するための形態から容易に明らかになるであろう。当業者は、本教示が、以下に要約又は開示されたもの以外の実施例で実現され得ることを理解するであろう。
第1の態様において、目標経路に沿ってロボットをナビゲートし、障害物を回避する方法がある。方法は、第1のロボットに関する目標ポーズを受信すること、第1のロボットに関する目標経路を決定するステップと、障害物マップを受信すること、第1のロボットのポーズを受信すること、1つ又は複数の他のロボットのポーズを受信すること、第1のロボットに関する候補速度のセットを生成すること、第1の目的関数を使用して候補速度の第1のセットを評価すること、第1の目的関数に基づいて第1のロボットの第1の推奨速度を選択すること、1つ又は複数の他のロボットのポーズ及び第1のロボットの第1の推奨速度に基づいて、速度障害物のセットを作成すること、第2の目的関数を使用して候補速度のセットを評価すること、第2の目的関数に基づいて第1のロボットの第2の推奨速度を選択すること、及び第2の推奨速度に基づいて第1のロボットを移動させることを含む。
一実施例において、目標経路は、第1のロボットの現在ポーズから第1のロボットの目標ポーズまでの経路とすることができる。ロボットの目標ポーズは、注文履行倉庫アプリケーションにおける、基準と関連付けられた製品ビンのポーズとすることができる。
いくつかの実施例において、第1のロボットのポーズは、多対多マルチ解像度スキャン・マッチング(M3RSM)、適応モンテ・カルロ位置推定(AMCL)、ジオポジショニング衛星(GPS)、基準情報、及びオドメトリベースのオン・ロボット・センサのうちの1つ又は複数によって決定されてもよい。
好ましい実施例において、第1のロボットの候補速度のセットを生成するステップは、動き、障害物、及び慣性の制約を適用する1つ又は複数の時間ステップにわたる候補速度を想定して、許容軌道を有する候補速度のみを生成することを含む。
別の実施例において、第1の目的関数は、G(v,ω)=α*heading(v,ω)+β*dist(v,ω)+γ*velocity(v,ω)の形式の1つ又は複数のコスト関数から構成され、ここで、G(v,ω)は目的関数、α、β、γは重みであり、heading(v,ω)は目標経路に沿った進行状況の尺度であり、dist(v,ω)は最も近い障害物までの距離(その「間隔」)であり、velocity(v,ω)は所与の候補速度(v,ω)に対するロボットの前進速度である。第1の目的関数は、候補速度が目標経路からどれだけ放射状に広がることになるかをスコア化する経路コスト関数、障害物への近さをスコア化する障害物コスト関数、又は以前の推奨速度からの回転速度の変化に対してより高いコストを割り当てる振動コスト関数のうちの1つ又は複数をさらに含み得る。第1の目的関数のコスト関数は、候補速度に最高のコスト・スコアを割り当てることによって候補速度を無効にすることができる。
さらに別の実施例において、速度オブジェクトのセットを作成するステップは、推奨速度を非ホロノミック速度からホロノミック速度に変換することを含む。推奨速度をホロノミック速度に変換することは、1つ又は複数の他のロボットの半径を、推奨軌道と直線軌道との間の最大距離だけ増加させることを含み得る。
好ましい実施例において、第2の目的関数は、ORCA/DWA=CDWA+αORCA*CORCAの形式の1つ又は複数のコスト関数から構成され、ここで、CDWAはCDWA=α*heading(v,ω)+β*dist(v,ω)+γ*velocity(v,ω)と定義され、α、β、γは重みであり、heading(v,ω)は目標経路に沿った進行状況の尺度であり、dist(v,ω)は最も近い障害物までの距離であり、velocity(v,ω)は所与の候補速度(v,ω)に対するロボットの前進速度であり、ここで、CORCAはCORCA=α(v−vpref)+penalty+α*d(P、v)と定義され、ここで、α及びαは重みであり、vは評価される候補速度であり、vprefは推奨速度であり、PはVOの結合によって形成されるポリゴンであり、d(P,v)は候補速度がVOにどれだけ違反しているかの尺度であり、penaltyは、候補速度vがVOに違反したときに課せられるペナルティ・コストである。さらに、コスト関数d(P,vt)は、ポリゴンPの外周から、候補速度vtが到達する軌道tによって定義される点までの最小距離の関数である。
本発明の第2の態様において、トランシーバ、データ・ストレージ・デバイス、データ・プロセッサ、及びデータ・プロセッサによる実行のための記憶された命令を有するデータ・ストレージ・デバイスを含む、目標経路に沿ってロボットをナビゲートし、障害物を回避するためのロボット・システムがある。そこに記憶された命令は、ロボット・システムに、第1のロボットに関する目標ポーズを受信し、第1のロボットに関する目標経路を決定し、障害物マップを受信し、第1のロボットのポーズを受信し、1つ又は複数の他のロボットのポーズを受信し、第1のロボットに関する候補速度のセットを生成し、第1の目的関数を使用して候補速度の第1のセットを評価し、第1の目的関数に基づいて第1のロボットの第1の推奨速度を選択し、1つ又は複数の他のロボットのポーズ及び第1のロボットの第1の推奨速度に基づいて速度障害物のセットを作成し、第2の目的関数を使用して候補速度のセットを評価し、第2の目的関数に基づいて第1のロボットの第2の推奨速度を選択し、第2の推奨速度に基づいて第1のロボットを移動させるように命令する。
この第2の態様の一実施例において、目標経路は、第1のロボットの現在ポーズから第1のロボットの目標ポーズまでの経路とすることができる。ロボットの目標ポーズは、注文履行倉庫アプリケーションにおける、基準と関連付けられた製品ビンのポーズとすることができる。
好ましい実施例において、第1のロボットの候補速度のセットを生成するステップは、動き、障害物、及び慣性の制約を適用する1つ又は複数の時間ステップにわたる候補速度を想定して、許容軌道を有する候補速度のみを生成することを含む。
別の実施例において、第1の目的関数は、G(v,ω)=α*heading(v,ω)+β*dist(v,ω)+γ*velocity(v、ω)の形式の1つ又は複数のコスト関数から構成され、ここで、G(v,ω)は目的関数、α、β、γは重みであり、heading(v,ω)は、目標経路に沿った進行状況の尺度であり、dist(v,ω)は、最も近い障害物までの距離(その「間隔」)であり、velocity(v、ω)は所与の候補速度(v,ω)に対するロボットの前進速度である。第1の目的関数は、候補速度が目標経路からどれだけ放射状に広がることになるかをスコア化する経路コスト関数、障害物への近さをスコア化する障害物コスト関数、又は以前の推奨速度からの回転速度の変化に対してより高いコストを割り当てる振動コスト関数のうちの1つ又は複数をさらに含み得る。第1の目的関数のコスト関数は、候補速度に最高のコスト・スコアを割り当てることによって候補速度を無効にすることができる。
さらに別の実施例では、速度オブジェクトのセットを作成するステップは、推奨速度を非ホロノミック速度からホロノミック速度に変換することを含む。推奨速度をホロノミック速度に変換することは、1つ又は複数の他のロボットの半径を、推奨軌道と直線軌道との間の最大距離だけ増加させることを含み得る。
好ましい実施例において、第2の目的関数は、ORCA/DWA=CDWA+αORCA*CORCAの形式の1つ又は複数のコスト関数から構成され、ここで、CDWAはCDWA=α*heading(v,ω)+β*dist(v,ω)+γ*velocity(v,ω)と定義され、α、β、γは重みであり、heading(v,ω)は目標経路に沿った進行状況の尺度であり、dist(v,ω)は最も近い障害物までの距離であり、velocity(v,ω)は所与の候補速度(v,ω)に対するロボットの前進速度であり、ここで、CORCAはCORCA=α(v−vpref)+penalty+α*d(P,v)と定義され、ここで、α及びαは重みであり、vは評価される候補速度であり、vprefは推奨速度であり、PはVOの結合によって形成されるポリゴンであり、d(P,v)は候補速度がVOにどれだけ違反しているかの尺度であり、penaltyは候補速度vがVOに違反したときに課せられるペナルティ・コストである。さらに、コスト関数d(P、vt)は、ポリゴンPの外周から候補速度vtが到達する軌道tによって定義される点までの最小距離の関数である。
本発明の第3の態様において、第1の態様の方法を実行するための監視システムの監視下にある複数のロボットを含むロボット・システムがある。
次に、本発明の実施例を、添付の図面を参照して例としてのみ説明する。
注文履行倉庫の上面図である。 図1に示す倉庫内で使用されるロボットのうちの1つのベースの正面図である。 図1に示す倉庫内で使用されるロボットのうちの1つのベースの斜視図である。 アーマチュアが装備され、図1に示す棚の前に駐機された、図2A及び図2Bのロボットの斜視図である。 ロボット上のレーザ・レーダを使用して作成された図1の倉庫の部分マップである。 倉庫全体にわたって分散された基準マーカの位置を特定し、基準マーカのポーズを記憶するためのプロセスを示すフローチャートである。 基準識別情報とポーズとのマッピングの表である。 ビン位置と基準識別情報とのマッピングの表である。 製品SKUとポーズとのマッピング・プロセスを示すフローチャートである。 本発明の方法及びシステムで使用するためのロボット・システムの一実施例を示す図である。 空間マップによって表される環境を通る現在位置からターゲット位置へのロボットの一般化されたナビゲーションを示す図である。 本発明の一態様による、図10の環境のSLAMマップに関連するロボットのナビゲーションを示す図である。 障害物及び他のロボットの近傍でナビゲートするロボットのナビゲーション及び増分移動を示す図である。 本発明による、目標経路に沿ってロボットをナビゲートするための一実施例を示すフローチャートである。 本発明による、ORCA/DWAを実行する一実施例を示すフローチャートである。 ORCA速度オブジェクト分析においてDWA非ホロノミックの推奨速度を使用するための本発明の一態様を示す図である。 ORCAコスト関数で使用するためのORCA速度空間に対する候補速度に適用するための距離及びペナルティ・コスト関数を決定する態様を示す図である。 ORCAコスト関数で使用するためのORCA速度空間に対する候補速度に適用するための距離及びペナルティ・コスト関数を決定する態様を示す図である。 ORCAコスト関数で使用するためのORCA速度空間に対する候補速度に適用するための距離及びペナルティ・コスト関数を決定する態様を示す図である。
本明細書に記載の発明は、障害物及び自由空間を含む環境内の「目標経路」に沿った現在位置からターゲット位置へのロボットの改善されたナビゲーションのための自律型又は半自律型ロボットで使用する方法及びシステムを対象とする。具体的には、本発明の方法及びシステムは、制約ベースの障害物回避方法の組合せを使用してロボットの推進制御に適用する次の瞬間速度を正確に決定するために、従来技術に勝る計算効率の高い向上を提供する。
本開示並びにその様々な特徴及び有利な詳細は、添付の図面で説明及び/又は図示され、以下の説明で詳述される非限定的な実施例及び実例を参照してさらに十分に説明される。図面に示されている特徴は必ずしも一定の縮尺で描かれているわけではなく、一実施例の特徴は、本明細書で明示的に述べられていない場合でも、当業者が認識するような他の実施例と共に使用され得ることに留意されたい。さらに、同一の参照番号は、図面のいくつかの図を通して同様の部分を表すことに留意されたい。
よく知られている構成要素及び処理技法の説明は、本開示の実施例を不必要に不明瞭にしないように省略される場合がある。本明細書で使用される実例は、単に、本開示が実現され得る方法の理解を容易にすること、及び当業者が本開示の実施例を実現することをさらに可能にすることを意図しているにすぎない。したがって、本明細書の実例及び実施例は、本開示の範囲を限定するものとして解釈されるべきではない。
当業者は、本教示が開示されたもの以外の実施例で実現され得ることを理解するであろう。本明細書で提供される説明は、顧客への出荷用に注文を履行するために倉庫内のビン位置から物品をピックすることに焦点が当てられているが、システムは、後から取り出して顧客に出荷するために、倉庫内に受け入れた物品を倉庫全体にわたるビン位置に保管又は配置する場合にも同様に適用される。本発明はまた、製品の統合、集計、検証、検査、及びクリーンアップなどの、そのような倉庫システムに関連する在庫管理タスクにも適用可能である。
本発明の方法及びシステムは、他のタイプの用途のための他のタイプの障害物を伴う他のタイプの環境にも適用され得る。静止の又は動的な、物理的物体又は構造は、本発明の適用例においては「障害物」と見なされ得る。障害物はさらに、環境内で動作する人間及び他のロボットを含む場合があり、人間及び他のロボットの位置は、協調タスクの実行における現在位置又はターゲット位置とすることができる。ターゲット位置は、1つ又は複数のロボットを配置して、タスク若しくは一連のタスクを実行するため、又はその実行において人間を支援するための環境内の、1つ又は複数の位置を含むことができる。
これら及び他の利益若しくは利点は、以下に説明する実例及び図から容易に明らかになろう。
図1を参照すると、典型的な注文履行倉庫10は、注文16に含まれる可能性のある様々な物品で満たされた棚12を含む。動作に際して、倉庫管理サーバ15からの注文16が注文サーバ14に届く。注文サーバ14は、倉庫10を動き回る複数のロボットから選択されたロボット18に、注文16を通信する。また、本発明の一態様による1つ又は複数の充電ステーションが配置され得る充電エリア19も示されている。
好ましい実施例では、図2A及び図2Bに示すロボット18は、レーザ・レーダ22を有する自律型車輪付きベース20を含む。ベース20は、ロボット18が注文サーバ14から命令を受信することを可能にするトランシーバ(図示せず)、及び一対のデジタル光学カメラ24a及び24bも特徴とする。ロボット・ベースは、自律型車輪付きベース20に電力を供給するバッテリを再充電するための充電ポート26も含む。ベース20は、レーザ・レーダ22からデータを受信するプロセッサ(図示せず)、並びにロボットの環境を表す情報を取り込むためのカメラ24a及び24bをさらに特徴とする。図3に示すように、倉庫10内のナビゲーションに関連する様々なタスクを実行するため、並びに棚12上に配置された基準マーカ30にナビゲートするためにプロセッサと共に動作するメモリ(図示せず)が存在する。基準マーカ30(例えば、2次元バーコード)は、注文を受けた物品のビン/位置に対応する。本発明のナビゲーション手法については、図4〜図8を参照して以下で詳細に説明する。基準マーカはまた、本発明の一態様により充電ステーションを識別するために使用され、そのような充電ステーションの基準マーカへのナビゲーションは、注文を受けた物品のビン/位置へのナビゲーションと同じである。ロボットが充電ステーションへナビゲートすると、より正確なナビゲーション手法を使用してロボットが充電ステーションにドッキングされ、このようなナビゲーション手法については以下で説明する。
再び図2Bを参照すると、ベース20は、物品を保持するためのトート又はビンが格納され得る上面32を含む。複数の交換可能なアーマチュア40のいずれか1つと係合するカップリング34も示され、その1つが図3に示されている。図3の特定のアーマチュア40は、物品を受け入れるトート44を保持するためのトート・ホルダ42(この場合は棚)、及びタブレット48を支持するためのタブレット・ホルダ46(又はラップトップ/他のユーザ入力デバイス)を特徴とする。いくつかの実施例では、アーマチュア40は、物品を保持するための1つ又は複数のトートを支持する。他の実施例では、ベース20は、受け入れられた物品を保持するための1つ又は複数のトートを支持する。本明細書で使用する場合、「トート」という用語には、貨物ホルダ、ビン、ケージ、棚、物品を掛けることができる竿、小箱、クレート、ラック、スタンド、架台、コンテナ、ボックス、キャニスタ、容器、収納庫が含まれるが、これらに限定されない。
ロボット18は、倉庫10を動き回ることにおいて優れているが、現在のロボット技術では、物体のロボット操作に関連する技術的な問題により、ロボット18は、棚から物品を迅速に且つ効率的にピックし、それらをトート44に配置することにおいてあまり良好ではない。物品をより効率的にピックする方法は、注文された物品を棚12から物理的に取り出し、それをロボット18上、例えばトート44内に配置するというタスクを実行するために、通常は人間である現場作業者50を使用することである。ロボット18は、現場作業者50が読み取ることができるタブレット48(若しくはラップトップ/他のユーザ入力デバイス)を介して、又は現場作業者50によって使用されるハンドヘルド・デバイスに注文を送信することによって、現場作業者50に注文を通信する。
ロボット18は、注文サーバ14から注文16を受信すると、例えば図3に示すように最初の倉庫位置に進む。ロボット18は、メモリに記憶され、プロセッサによって実行されるナビゲーション・ソフトウェアに基づいて、これを行う。ナビゲーション・ソフトウェアは、レーザ・レーダ22によって収集されるような環境に関するデータと、特定の物品を見つけることができる倉庫10内の位置に対応する基準マーカ30の基準識別情報(「ID」)を識別するメモリ中の内部表と、ナビゲートするためのカメラ24a及び24bとに依拠する。
ロボット18は、正確な位置に到達すると、物品が保管されている棚12の前にそれ自体を駐機し、現場作業者50が棚12から物品を取り出し、それをトート44内に配置するのを待つ。ロボット18が他に取り出すべき物品を有する場合、ロボット18はその位置に進む。次いで、ロボット18によって取り出された物品は、図1の梱包ステーション100に送られ、そこで物品が梱包され、出荷される。
各ロボットが1つ又は複数の注文を履行する場合があり、各注文が1つ又は複数の物品から構成され得ることは、当業者には理解されよう。通常、効率を高めるために何らかの形態のルート最適化ソフトウェアが含まれることになるが、これは本発明の範囲外であり、したがって本明細書では説明されない。
本発明の説明を簡略化するために、単一のロボット18及び作業者50が説明されている。しかしながら、図1から明らかなように、典型的な履行作業は、注文の連続的な流れに対応するために倉庫内で互いに働いている多くのロボット及び作業者を含む。
本発明のナビゲーション手法、及び取り出されるべき物品のSKUと、物品が位置する倉庫内の基準マーカに関連付けられた基準ID/ポーズとのセマンティック・マッピングが、図4〜図8に関して以下に詳細に説明される。上記のように、同じナビゲーション手法を使用して、ロボットがそのバッテリを再充電するために充電ステーションにナビゲートできるようにすることができる。
静的物体と動的物体の両方の位置、及び倉庫全体にわたって分散された様々な基準マーカの位置を決定するために、1つ又は複数のロボット18を使用して、倉庫10のマップが作成され、動的に更新されなければならない。これを行うために、ロボット18のうちの1つは、そのレーザ・レーダ22と、未知の環境のマップを構築又は更新する計算方法である同時位置特定及びマッピング(SLAM:simultaneous localization and mapping)とを使用して、倉庫をナビゲートし、図4のマップ10aを構築/更新する。SLAM近似解法は、ポーズ・グラフ、粒子フィルタ、及び拡張カルマン・フィルタ法を含む。SLAM GMapping手法は好ましい手法であるが、任意の好適なSLAM手法を使用することができる。SLAMに関する考察は、参照により本明細書に組み込まれる、Frese,U.、Wagner,R.、Rofer,T.、「A SLAM overview from a user’s perspective」、Kunstliche Intelligenz 24(3)、191〜198頁(2010)において見出すことができる。
注文履行
ロボット18は、そのレーザ・レーダ22を利用して、ロボット18が空間全体にわたって移動し、レーザ・レーダが環境を走査するときに受け取る反射に基づいて空間内のオープン空間112、壁114、物体116、及び棚12aなどの他の静的障害物を識別するときに、倉庫10のマップ10aを作成/更新する。
1つ又は複数のロボット18は、マップ10aの構築しながら又はそれ以降、倉庫10内をナビゲートし、環境を走査するためのカメラ24a及び24bを使用して、物品が保管されている図3の32及び34などのビンに近接した棚の、倉庫全体にわたって分散された基準マーカ(2次元バーコード)の位置を特定する。ロボット18は、原点110などの既知の基準点又は原点を基準として使用する。ロボット18がそのカメラ24a及び24bを使用することによって、図3及び図4における基準マーカ30などの基準マーカの位置が特定されると、原点110に対する倉庫内の位置が決定される。ロボット18は、図2Aに示すようなロボット・ベースの両側にある2つのカメラを使用することによって、ロボットの両側から広がる比較的広い視野を有することができる。これにより、ロボットは、例えば、棚の通路を行き来するとき、ロボットの両側にある基準マーカを見ることができる。
ホイール・エンコーダ及び進行方向センサを使用することによって、ベクトル120及び倉庫10内のロボットの位置が決定され得る。ロボット18は、基準マーカ/2次元バーコードの取り込まれた画像及びその知られているサイズを使用して、基準マーカ/2次元バーコードのロボットに対する向き及びそこからの距離であるベクトル130を決定することができる。ベクトル120及び130が知られている場合、原点110と基準マーカ30との間のベクトル140を決定することができる。ベクトル140及びロボット18に対する基準マーカ/2次元バーコードの決定された向きから、原点110に対するx,y,z座標によって、及び基準マーカ30の4元数(x,y,z,ω)によって定義されるポーズ(位置及び向き)が決定され得る。4元数を使用して向きを表現し導き出すことに関する考察は、参照により本明細書に組み込まれる、Berthold K.P.Horn、「Closed−form solution of absolute orientation using unit quaternions」、Journal of the Optical Society of America、4(4)、1987年4月、629〜642頁において見出される。当業者は、基準マーカの位置及び向きを決定するための他の座標系及び技法が使用され得ること、並びにポーズが任意の原点からの絶対的又は相対的な位置及び/又は向きを決定できることを認識するであろう。
基準マーカの位置特定プロセスを説明する図5のフローチャート200について説明する。これは、初期マッピング・モードで実行され、ロボット18がピッキング、配置、及び/又は他のタスクを実行している間に倉庫内で新しい基準マーカに遭遇したときに実行される。ステップ202において、ロボット18は、カメラ24a及び24bを使用して画像を取り込み、ステップ204において、取り込まれた画像内で基準マーカを検索する。ステップ206において、画像内で基準マーカが見つけられた場合(ステップ204)、その基準マーカがロボット18のメモリに位置する図6の基準表300にすでに記憶されているかどうかが判定される。その基準情報がすでにメモリに記憶されている場合、フローチャートは別の画像を取り込むためにステップ202に戻る。基準情報がメモリにない場合、上記のプロセスに従ってポーズが決定され、ステップ208において、その基準情報は、基準対ポーズのルックアップ表300に追加される。
各ロボットのメモリに記憶され得るルックアップ表300には、各基準マーカごとに、基準識別情報1、2、3などと、各基準識別情報に関連付けられた基準マーカ/バーコードのポーズとが含まれる。ポーズは、原点110に対する倉庫内のx,y,z座標、及び向き、すなわち4元数(x,y,z,ω)から構成される。
図7の別のルックアップ表400では、ルックアップ表400は、同じく各ロボットのメモリに記憶されてもよく、倉庫10内のビン位置(例えば、402a〜402f)のリストであり、ビン位置は特定の基準ID404、例えば番号「11」と相互に関連付けられている。ビン位置は、この実例では7つの英数字で構成されている。最初の6文字(L01001など)は、倉庫内の棚位置に関係し、最後の文字(例えばA〜F)は棚位置における特定のビンを識別する。この実例では、基準ID「11」に関連付けられた6つの異なるビン位置がある。各基準ID/マーカに関連付けられた1つ又は複数のビンがある場合がある。図1の充電エリア19に位置する充電ステーションは、表400に記憶され、基準IDと相互に関連付けられてもよい。基準IDから、図6の表300において、充電ステーションのポーズが判明し得る。
英数字のビン位置は、物品が保管された倉庫10内の物理的位置に対応するものとして、人間、例えば図3の作業者50にとって理解可能である。しかしながら、英数字のビン位置は、ロボット18にとって意味がない。ロボット18は、位置を基準IDにマッピングすることによって、図6の表300の情報を使用して基準IDのポーズを決定し、次いで、本明細書で説明されるようにポーズにナビゲートすることができる。
本発明による注文履行プロセスが、図8のフローチャート500に示されている。ステップ502において、図1の倉庫管理システム(WMS)15は、取り出すべき1つ又は複数の物品で構成され得る注文を取得する。ステップ504において、倉庫管理システム15によって物品のSKU番号が決定され、ステップ506において、SKU番号からビン位置が決定される。次いで、注文に関するビン位置のリストがロボット18に送信される。ステップ508において、ロボット18はビン位置を基準IDと相互に関連付け、ステップ510において、基準IDから各基準IDのポーズが取得される。ステップ512において、ロボット18は図3に示されるようにそのポーズにナビゲートし、作業者は、取り出すべき物品を適切なビンからピックし、それをロボットに配置することができる。
倉庫管理システム15によって取得されたSKU番号及びビン位置などの物品固有の情報は、ロボット18上のタブレット48に送信され得、それにより、作業者50は、ロボットが各基準マーカ位置に到達したときに取り出されるべき特定の物品を通知され得る。
SLAMマップ及び基準IDのポーズが知られている場合、ロボット18は、様々なロボット・ナビゲーション技法を使用して、基準IDのうちのいずれか1つに容易にナビゲートすることができる。好ましい手法は、倉庫10内のオープン空間112及び壁114、棚(棚12など)、並びに他の障害物116の知識を与えられて、基準マーカ・ポーズへの初期ルートを設定することを含む。ロボットがそのレーザ・レーダ22を使用して倉庫を横断し始めると、ロボットは、何らかの障害物、すなわち固定の障害物、又は他のロボット18及び/若しくは作業者50などの動的障害物がその経路にあるかどうかを判定し、基準マーカのポーズへのその経路を繰り返し更新する。ロボットは、障害物を回避しながら最も効率的且つ効果的な経路を常に探索して、約50ミリ秒ごとにそのルートを再計画する。
一般に、倉庫10a内のロボットの位置特定は、SLAMマップ上で動作する多対多マルチ解像度スキャン・マッチング(M3RSM)によって実現される。総当たりの方法と比較して、M3RSMは、ロボットがスキャン・マッチングを実行してロボットの現在のポーズを決定するための計算時間を大幅に削減する。M3RSMの考察は、参照により本明細書に組み込まれる、Edwin Olson、「M3RSM:Many−to−many multi−resolution scan matching」、Proceedings of the IEEE International Conference on Robotics and Automation(ICRA)、2015年6月において見出すことができる。参照により本明細書に組み込まれる関連する米国特許出願第15/712,222号に開示されている方法によりM3RSM探索空間を最小化することによって、ロボットの位置特定がさらに改善される。
共に明細書に記載の、製品SKU/基準IDと基準ポーズとのマッピング技法を、SLAMナビゲーション技法と組み合わせることで、ロボット18は、通常は倉庫内の位置を決定するためのグリッド線及び中間基準マーカを含むより複雑なナビゲーション手法を使用する必要なく、倉庫空間を非常に効率的且つ効果的にナビゲートすることができる。
一般的に、倉庫内に他のロボット及び移動障害物がある場合のナビゲーションは、ダイナミック・ウィンドウ・アプローチ(DWA)及び最適相互衝突回避(ORCA)を含む衝突回避方法によって実現される。DWAは、実現可能なロボットの動作軌道の中から、障害物との衝突を回避し、ターゲット基準マーカへの所望の経路を推奨する増分移動を計算する。ORCAは、他のロボットとの通信を必要とせずに、他の移動ロボットとの衝突を最適に回避する。ナビゲーションは、約50msの更新間隔で計算された軌道に沿った一連の増分移動として進行する。衝突回避は、本明細書に記載の技法によってさらに改善され得る。
ロボット・システム
図9は、上述の注文履行倉庫アプリケーションで使用するためのロボット18の一実施例のシステム図を示す。ロボット・システム600は、データ・プロセッサ620、データ・ストレージ630、処理モジュール640、及びセンサ・サポート・モジュール660を含む。処理モジュール640は、経路計画モジュール642、駆動制御モジュール644、マップ処理モジュール646、位置特定モジュール648、及び状態推定モジュール650を含み得る。センサ・サポート・モジュール660は、距離センサ・モジュール662、駆動トレイン/ホイール・エンコーダ・モジュール664、及び慣性センサ・モジュール668を含み得る。
データ・プロセッサ620、処理モジュール642、及びセンサ・サポート・モジュール660は、ロボット・システム600について本明細書に示され、又は説明されたコンポーネント、デバイス、又はモジュールのいずれとも通信することができる。トランシーバ・モジュール670は、データを送信及び受信するために含まれ得る。トランシーバ・モジュール670は、監視システムとの間で、又は1つ又は他のロボットとの間で、データ及び情報を送信及び受信することができる。データを送信及び受信することは、マップ・データ、経路データ、検索データ、センサ・データ、位置及び向きデータ、速度データ、並びに処理モジュールの命令又はコード、ロボット・パラメータ及び環境設定、並びにロボット・システム600の動作に必要な他のデータを含む。
いくつかの実施例では、距離センサ・モジュール662は、走査レーザ・レーダ、レーザ距離計、距離計、超音波障害物検出器、ステレオ・ビジョン・システム、単眼ビジョン・システム、カメラ、及び撮像ユニットのうちの1つ又は複数を備え得る。距離センサ・モジュール662は、ロボットの周囲の環境を走査して、ロボットに対する1つ又は複数の障害物の位置を特定することができる。好ましい実施例では、駆動トレイン/ホイール・エンコーダ664は、ホイール位置を符号化するための1つ又は複数のセンサと、1つ又は複数のホイール(例えば、地面係合ホイール)の位置を制御するためのアクチュエータとを備える。ロボット・システム600はまた、速度計又はレーダベースのセンサ若しくは回転速度センサを含む対地速度センサを含み得る。回転速度センサは、加速度計と積分器の組合せを備え得る。回転速度センサは、データ・プロセッサ620又はその任意のモジュールに、観測された回転速度を提供することができる。
いくつかの実施例では、センサ・サポート・モジュール660は、速度、並進、位置、回転、レベル、進行方向、及び慣性の瞬間的な測定値の履歴データを含む、並進データ、位置データ、回転データ、レベル・データ、慣性データ、及び進行方向データを経時的に提供してもよい。並進速度又は回転速度は、ロボット環境内の1つ又は複数の固定基準点又は静止物体を参照して検出され得る。並進速度は、方向の絶対速度として、又は時間に対するロボットの位置の1次導関数として表すことができる。回転速度は、角度単位の速度として、又は時間に対する角度位置の1次導関数として表すことができる。並進速度及び回転速度は、原点0,0(例えば、図1、110)及び絶対座標系又は相対座標系に対する0度の方角に関して表すことができる。処理モジュール640は、検出された回転速度と組み合わされた観測された並進速度(又は時間に対する位置の測定値)を使用して、ロボットの観測された回転速度を推定することができる。
いくつかの実施例では、ロボット・システム600は、GPS受信機、差分補正付きGPS受信機、又は無線信号を送信する衛星又は地上ビーコンに対するロボットの位置を決定するための別の受信機を含み得る。上記の倉庫用途などの屋内用途、又は衛星受信が信頼できない場所においては、ロボット・システム600は、大域的な又は局所的なセンサ又はシステムによって絶対位置情報が確実に提供されない場合の位置特定を改善するために、上記のGPS以外のセンサ及び本明細書に記載の技法を使用することが好ましい。
他の実施例では、図9に示されていないモジュールは、ステアリング・システム、ブレーキ・システム、及び推進システムを含み得る。ブレーキ・システムは、油圧ブレーキ・システム、電気油圧ブレーキ・システム、電気機械ブレーキ・システム、電気機械アクチュエータ、電気ブレーキ・システム、ブレーキ・バイ・ワイヤ・ブレーキ・システム、又は駆動制御644と通信する別のブレーキ・システムを含み得る。推進システムは、電気モータ、駆動モータ、交流モータ、誘導モータ、永久磁石モータ、直流モータ、又はロボットを前進させるための別の好適なモータを含み得る。推進システムは、電気モータのモータ・シャフトの回転の速度、トルク、及び方向の少なくとも1つを制御するためのモータ・コントローラ(例えば、インバータ、チョッパ、波発生器、多相コントローラ、可変周波数発振器、可変電流供給、又は可変電圧供給)を含み得る。駆動制御644及び推進システム(図示せず)は、差動駆動(DD)制御及び推進システムであることが好ましい。DD制御システムにおいて、ロボット制御は、非ホロノミック(NH)であり、所望の並進速度及び角速度が与えられた場合に達成可能な増分経路に対する制約を特徴とする。推進システムと通信する駆動制御644は、経路計画モジュール642又はデータ・プロセッサ620によって決定された1つ又は複数の瞬間速度を変換することによって、ロボットの増分移動を始動させることができる。
当業者は、本明細書に記載の本発明の適用性を失うことなく、ロボット処理、データ・ストレージ、検知、制御、及び推進のための他のシステム及び技法を採用できること理解するであろう。
ナビゲーション
自律型ロボット又は半自律型ロボットによるナビゲーションは、ロボットの環境の何らかの形態の空間モデルを必要とする。空間モデルは、ビットマップ、オブジェクト・マップ、ランドマーク・マップ、及びその他の形態の2次元及び3次元デジタル表現によって表されてもよい。例えば、図10に示すように、倉庫施設の空間モデルは、倉庫、並びに壁、天井、屋根の支柱、窓及びドア、棚及び保管ビンなどの障害物を表し得る。障害物は、例えば、倉庫内で動作する他のロボット若しくは機械などのように、静止若しくは移動しているか、又は、一時的な仕切り、パレット、棚、及びビンなどのように、比較的固定されているが、倉庫の物品が保管され、ピックされ、補充されるときに変化している場合がある。
倉庫施設の空間モデルはまた、ロボットが製品をピックするように若しくは何らかの他のタスクを実行するように指示され得る基準でマークされた棚若しくはビンなどのターゲット位置、又は、一時的な保持位置若しくは充電ステーションの位置を表し得る。例えば、図10は、開始位置702から中間位置704、706、その経路712、714、716に沿った目的地又はターゲット位置708までのロボット18のナビゲーションを示す。ここで、空間モデルは、棚若しくはビン又はロボット充電ステーションであり得る目的地718における構造物の特徴を含む、ロボットがナビゲートしなければならない環境の特徴を取り込む。
ロボットのナビゲーションに最も一般的に使用される空間モデルは、エリア又は施設のビットマップである。例えば、図11は、図10に示される空間モデルの2次元ビットマップを示す。マップ720は、黒若しくは白を表すバイナリ範囲0、1のピクセル値を有するビットマップによって、又は例えば、黒(0)から白(255)のグレースケール範囲を表す0〜255のピクセル値の範囲によって、又はピクセル値で表される位置に特徴が存在するかどうかの不確実性を示し得る色の範囲によって表されてもよい。マップ720の縮尺及び粒度は、環境の範囲及び詳細に適するような任意の縮尺及び寸法としてもよい。例えば、本発明の同じ実施例では、マップの各ピクセルは5平方センチメートル(cm)を表す場合がある。他の実施例では、各ピクセルは、1cmから5cmの範囲を表す場合がある。しかしながら、本発明で使用するためのマップの空間解像度は、その方法の適用に対する一般性又は利益を失うことなく、より大きく又はより小さくなり得る。
図11に示すように、マップ720は、障害物(黒色で示される)を回避しながら、環境内のロボットの位置及び向きを決定し、経路712、714、716に沿ったロボットの動きを計画及び制御するために、ロボットによって使用され得る。このようなマップは、ロボット若しくはターゲット位置の直近の空間的特徴を表す「局所的マップ」、又は1つ若しくは複数のロボットの動作範囲を含むエリア又は施設の特徴を表す「大域的マップ」である場合がある。1つ又は複数のロボットは、共有環境を協調的にマッピングし、ロボットが環境に関する情報をナビゲート、収集、及び共有するとき、結果として生じるマップがさらに強化される。マップは、監視システムからロボットに提供され得るか、又はロボットが、搭載された距離計及び位置センサを使用してそのマップを構築してもよい。
いくつかの実施例では、監視システムは、製造倉庫若しくは他の施設内の複数のロボットの監視を実行する中央サーバを含んでもよく、又は監視システムは、本明細書に記載の方法及びシステムの適用における一般性を失うことなく、施設内若しくは施設なしで、完全に遠隔で若しくは部分的に遠隔で動作する1つ又は複数のサーバで構成される分散型監視システムを備えてもよい。監視システムは、監視システムを実行するための少なくともコンピュータ・プロセッサ及びメモリを有するサーバを含んでもよく、倉庫又は他の施設内で動作する1つ又は複数のロボットに情報を通信するための1つ又は複数のトランシーバをさらに含んでもよい。監視システムは、コンピュータ・サーバでホストされてもよく、又はクラウドでホストされてもよく、インターネット上を含む有線及び/又は無線通信メディア上で、ロボット及び監視システムとの間でメッセージを受信及び送信するように構成されたローカル・トランシーバを介して、ローカル・ロボットと通信する。
当業者は、本発明の目的のためのロボット・マッピングが、一般性を失うことなく、当技術分野で知られている方法を使用して実行され得ることを認識するであろう。ロボット・マッピングに関する方法のさらなる考察は、参照により本明細書に組み込まれる、Sebastian Thrun、「Robotic Mapping:A Survey」、Carnegie−Mellon University、CMU−CS−02−111、2002年2月において見出すことができる。
障害物回避
動的な障害物の存在下で目標経路を首尾よくナビゲートし、ターゲットの製品ビンに到達するために、ロボットは、その軌道を継続的に再較正しなければならない。各再較正では、瞬間速度を使用して、ロボットを目標経路に沿って1つの増分移動ずつ前進させる。例えば、図12に示すように、ロボット18は、経路714(線における各ダッシュが、強調された増分移動を示す)に沿ってターゲット目標ポーズ708に移動する。経路714に沿って、ロボットは障害物722に遭遇する。さらに経路714に沿って、ロボット18は、障害物724の近傍で経路726に沿って移動しているロボット20に遭遇する。障害物722及び724を回避し、ロボット20との衝突を回避すると、ロボット18は最終的にポーズ706に到達し、経路716に沿って目標ポーズ708に進む。同様に、同じく自律的に動作しているロボット20は、障害物724及びロボット18を回避し、経路726に沿って、その目標経路に沿ってロボット20の目標ポーズ(図示せず)までナビゲートする。
他のロボットと衝突する軌道上でのロボットの増分移動は、最適相互衝突回避(ORCA:optimal reciprocal collision avoidance)などの方法によって防止される場合がある。ORCAは、各ロボットもORCAを使用してその次の増分移動を計算していると想定することによって、あるロボットが別のロボットと衝突しないことを保証する。このようにして、ロボットは、完全に自律的にナビゲートすると同時に、それぞれに最適な衝突のない経路を確保することができる。ORCAの考察は、参照により本明細書に組み込まれる、Jur van den Berg、Stephen J.Guy、Ming Lin及びDinesh Manocha、「Reciprocal n−body collision avoidance」、Robotics Research:The 14th International Symposium ISRR、Cedric Pradalier、Roland Siegwart及びGerhard Hirzinger(編)、Springer Tracts in Advanced Robotics、Vol.70、Springer−Verlag、2011年5月、3〜19頁に記載されている。
障害物回避の当技術分野では、ダイナミック・ウィンドウ・アプローチ(DWA)も知られている。DWAは、目標経路に沿ったロボットの増分移動に対して、N個の可能な瞬間速度のセットを考慮する。次いで、DWAは、1つ又は複数の時間ステップで取得された各瞬間速度に従って増分移動を想定して、ロボットによって取得された軌道をスコア化する。各軌道は、ロボット以外の障害及び他の要因を考慮する目的関数に従ってスコア化される。例えば、各軌道は、障害物に極めて接近するのを回避することに対して重み付けされた目標経路への合致性に従ってスコア化されてもよい。さらなる実例として、ロボット間で作業する人間の存在下でロボットの挙動を調整することが望まれる場合がある。DWAの考察は、参照により本明細書に組み込まれる、D.Fox、W.Burgard及びS.Thrun、「The Dynamic Window Approach to Collision Avoidance」、Robotics&Automation Magazine、IEEE、vol.4、no.1.(1997年3月)、23〜33頁において提供される。
DWAはロボットの挙動を制御するための柔軟な手法を提供するが、DWAはそうすることでORCA駆動のロボットに遭遇したときの最適な対応を犠牲にしている。同様に、ORCAは、ロボットの次の瞬間速度を証明可能な方法で最適に計算効率良く決定することを可能にするが、ORCAは、目標経路に沿ってターゲット位置へナビゲートするときのロボットの挙動を最適化するために重要な、ロボット以外の障害及び他の要因を考慮しない。
ORCA/DWA
図13は、本発明の実施例を、ロボットを目標経路に沿ってそのターゲット位置又は「目標ポーズ」に移動させるための方法として示す。フローチャートは、図12のロボット18、20、22、及び24を参照して説明され、各ロボットは、図9を参照して上述したようなロボット・システム600を備える。いくつかの実施例において、「他の」ロボットは、ロボット・システム600の変形で実装されてもよく、いくつかの実施例は、非ORCA駆動ロボットを含んでもよく、ORCAベースの方法を使用する1つ又は複数のロボットを有するロボットのシステムへの本発明の適用に対する一般性を失うことなく、障害物回避の一部の他の方法が採用される。
ステップ802で開始し、ロボット・システム600は、トランシーバ・モジュール670を介して障害物マップを受信し、障害物マップはデータ・ストレージ630に格納されてもよい。障害物マップは、SLAMマップ又は他のマップ(障害物が重ね合わされたコスト・マップなど)であってもよい。代替として、障害物マップは、ロボット環境内の固定された障害物を表すことができる任意の空間モデルとすることができる。障害物マップは、データ・プロセッサ620又はマップ処理モジュール646若しくは経路計画モジュール642によって、データ・ストレージ630に格納されてもよく、その後データ・ストレージ630から検索されてもよい。
ステップ806において、ロボット・システム600は目標ポーズを受信し、次いでステップ808において、経路計画モジュール646を使用してターゲット・ポーズへの目標経路を生成する。経路計画モジュール642は、A*及びD*経路探索アルゴリズムを含む、当業者に知られている様々な技法によって、現在ポーズから目標ポーズへの目標経路を生成することができる。代替として、ロボットは、トランシーバ・モジュール670を介して目標経路を受信するか、又はデータ・ストレージ630から目標経路を検索することができる。障害物マップを受信し、目標経路を生成した後、ロボット・システム600は、以下のように目標経路に沿って増分的にロボットを移動させるように進む。
ステップ810において、ロボット・システム600は、エリア内のすべてのロボットの現在の位置及び速度を受信する。ロボットは、そのポーズに関連する他のすべてのロボットのポーズを把握し、その動作エリアから遠いロボットを無視することができる。代替として、ロボットは、ステップ810の一般性を失うことなく、ロボットの近傍で動作しているロボットのポーズのみを受信してもよい。例えば、再び図12を参照すると、位置704にあるロボット18は、ロボット20、22、及び24の現在の位置及び速度を受信することができる。代替として、ロボット18は、例えば、ポーズ720に極めて接近しているときのみ、又は障害物724の近くのロボット20に接近しているときのみ、ロボット20の位置及び速度を受信してもよい。
さらに、ステップ810において、ロボットはロボット自体のポーズを受信する。ロボットのポーズを含むロボットの状態は、ロボット自体からのオドメトリを使用するロボット・システム600、駆動/トレイン・ホイール・エンコーダ664、及び/又は慣性センサ668若しくは他のセンサ・モジュール660によって、或いは、他のセンサ又は受信した情報で動作する処理モジュール640によって決定され得ることが好ましい。ロボットのポーズは、前述の入力の融合によって、及び/又は多対多マルチ解像度スキャン・マッチング(M3RSM)、適応モンテ・カルロ位置推定(AMCL)、ジオポジショニング衛星(GPS)、基準情報によって決定されてもよく、或いは、ロボットのポーズは、トランシーバ670を介して監視システムから受信されてもよい。
ステップ812において、プロセス800は、ORCA/DWAを実行することによって継続し、図14に関連して以下で具体的に説明するように、目標経路に沿ったロボットの次の増分移動を駆動するための制御として適用する次の速度を見つける。ステップ816において、ロボットは、その目標ポーズに到達するまで、目標経路に沿って増分的に移動する。ステップ818において目標ポーズに到達しない場合、ロボット・システム600は、次の時間サイクルで繰り返し(ステップ820)、目標ポーズに到達する(ステップ818)まで次の時間サイクルで、上記のように他のロボットのポーズを受信し(ステップ810)、ORCA/DWAを実行し(ステップ812)、ロボットを移動させる(ステップ816)。各増分移動に続いて、ロボット・システム600は、上記のようにそのポーズを決定し、その現在のポーズを含むその現在の状態を、トランシーバ670を介して中央サーバに送信することができる。本明細書に記載のようにプロセス800によって動作する図9のロボット18、20、22、及び24のそれぞれは、すべてのロボットのポーズを、次の時間サイクルでの他の各ロボットによる受信に利用できるようにする。
図14は、先に紹介した障害物回避アルゴリズムDWA及びORCAの原理の新規な組合せを使用して最適速度を決定するためのORCA/DWA(図13のステップ812)を実行するプロセスAを示す。
一実施例によれば、ステップ852から開始し、DWAに従って可能な速度又は「候補」速度のセットが生成される。候補速度は、速度ベクトル(v,ω)によって一意に決定される軌道又は「曲率」のセットとして表すことができ、ここで、vはロボットの前進又は直線移動、ωはロボットの回転速度である。候補速度のセットは、ロボットの現在ポーズからロボットを前進させる可能な軌道のセットからサンプリングされた速度の有限セットであってもよく、又は軌道のセットは、1つ又は複数の次の時間間隔にわたって一定速度(v,ω)で前進するロボットの離散的で瞬間的な移動によって定義される曲率を定義してもよい。
したがって、ステップ812の方法は、ロボットが次の時間ステップでの次の移動に対するロボットの制御として採用するN個の可能な瞬時速度のセットを生成する。候補速度のそれぞれを反復することによって、方法は、ロボットがt秒の増分で次のT秒間候補速度を続行するものとして、ロボットの最終ポーズを推定する。一般性を失うことなく、本発明を説明する目的で、Tは1.5秒としてもよく、時間増分tは0.1秒としてもよい。したがって、単に例として、候補速度が線形速度0.25メートル/秒、及び回転速度0.785ラジアン/秒の場合、プロセスは、0.1、0.2、0.3…1.5秒の各時間ステップで、速度ベクトル(v,ω)=(0.25、0.785)をその制御として適用して、ロボットが到達するポーズを推定する。各時間ステップでのポーズのセットは、以下でさらに説明されるORCA/DWA目的関数によってスコア化される軌道を構成する。
候補速度を生成する際のDWAによる離散化は、必然的に、次の一連の時間ステップでロボットが移動し得る、無限数よりも少ない軌道を選択する。ロボットが選択された候補速度で継続すると想定すると、次の時間間隔又は次のn時間間隔で曲率が障害物と交差する速度をセットから削除することによって、候補速度のセットがさらに削減され得る。障害物と衝突しない許容速度まで候補速度のセットを減らすことによって、推奨速度を決定するための検索空間が削減される。候補速度のセットは、許容速度のみを保持することによってさらに削減される。許容速度は、ロボットが障害物と衝突する前に停止すること可能する速度のみを含み得る。許容速度は、ロボットのダイナミック・ウィンドウ内、又はロボットに許容される最大安全速度内の速度のみを含み得る。ロボットの加速が制限されている場合、ロボットのダイナミック・ウィンドウは、次の時間間隔内に到達できる速度のみを含み得る。代替として、候補速度のセットは、モデル予測制御(MPC)又は他の制約ベースのアルゴリズムなどの他の方法によって、生成又は削減されてもよい。
再び図14を参照すると、ステップ854において、候補速度のセット内の各候補速度(v,ω)は、目的関数
G(v,ω)=α*heading(v,ω)+β*dist(v,ω)+γ*velocity(v,ω)
に従って評価され、ここで、G(v,ω)は目的関数、α、β、γは重みであり、heading(v,ω)は目標経路に沿った進行状況の尺度であり、dist(v,ω)は最も近い障害物までの距離(その「間隔」)であり、velocity(v,ω)は所与の候補速度(v,ω)に対するロボットの前進速度である。DWAの下での目的関数G(v,ω)の評価の詳細な考察は、すでに参照により本明細書に組み込まれている、D.Fox他、「The Dynamic Window Approach to Collision Avoidance」において見出される。当業者は、本発明の一般性を失うことなく目的関数の変形が適用され得ること理解するであろう。
候補速度のセットで各候補速度(v,ω)をスコア化することによって、候補速度のそれぞれについて目的関数G(v,ω)を評価すると、推奨速度vprefが決定する。上記のように、各候補速度(v,ω)は軌道又は曲率に関連付けられる。目的関数G(v,ω)は、1つ又は複数のコスト・クリティックを表す重み付けされたコンポーネント関数を有するコスト関数として実装されることが好ましい。コスト・クリティックの実施例では、推奨速度vprefは、図14のステップ856で決定された候補速度のセットにわたる最小G(v,ω)である。したがって、上記の速度と軌道の関係から分かるように、推奨軌道tprefは、T秒の期間にわたる次のt秒の期間のそれぞれにわたって速度vprefでロボットを増分的に移動させるための制御としてvprefが適用されると想定した場合のロボットの軌道である。
いくつかの実施例におけるコスト・クリティックは、すべてのロボットが静的障害物を安全に通り過ぎることを確実にするために、障害物マップ内の膨張された障害物(例えば、ロボットの半径又は直径によって膨張される)を使用するdist(v,ω)コスト関数を含み得る。コスト・クリティックは、回転の大きさ又は方向の変化に対してより高いコストを割り当てる振動コスト関数を含み得る。好ましい実施例において、コスト・クリティックは、目標経路からのロボットの距離及び/若しくは所与の候補速度に対してロボットが目標経路に沿ってどれだけ離れているか、又は、候補速度によってロボットが目標経路からどれだけ放射状に広がることになるかを重み付けする、経路コスト・クリティックをさらに含み得る。
したがって、DWA目的関数G(v,ω)を適用することによって決定される推奨速度vprefは、すべてのDWAコスト・クリティックの評価における最小コスト候補速度である。当業者は、上記のG(v,ω)のコスト関数に対する重みα、β、γが、ロボットの挙動の選好に従って設定され得ることを理解するであろう。目的関数G(v,ω)の各コンポーネント関数は、独自の重みを有する場合があり、又は重み付けされない場合もある(重み=1)。1つ又は複数のコスト・クリティックは、所定の基準に違反する任意の候補速度コスト関数スコアに相対的に高いペナルティ値を追加することによって候補速度を無効にする、「拒否権」を有することが好ましい。
上記で説明したように、図14のステップ858でDWAによって決定された推奨軌道tprefは、連続する時間間隔にわたってロボット制御に適用されるような速度ベクトル(v,ω)によって定義される曲率である。図15は、vprefとtprefの間のこの関係を示す。図示のように、ポーズPでのロボット18の推奨速度vprefは、速度ベクトル(v,ω)である。推奨軌道tprefは、vprefによって増分的に移動されるロボットの経路によって定義される曲率である。したがって、差動駆動(DD)ロボット推進システムに見られるような非ホロノミック・ロボットの制御に適用される速度ベクトル(v,ω)は、ロボット18を曲率P−Pに沿って移動させる。
図13のステップ810においてロボット・システム600が他のロボットのポーズをすでに受信していることを想起し、プロセスは、ORCA速度オブジェクト(又は「VO」)を生成することによってステップ858に続く。上述の知られている方法によれば、ロボット18の推奨速度vprefに基づいて他の各ロボット(例えば、20、22、24)との関連で、VOが生成される。ここで、ロボット18に対してORCA/DWAを実行するために、ロボット・システム600は、ORCA VOを生成するためにステップ856で決定された推奨速度vprefを使用する。
しかしながら、少なくとも1つの実施例では、ORCAは、推奨速度vprefを入力として必要とし、すべての速度(v,ω)をホロノミック速度(x,y)に変換する。すなわち、ORCAは、ロボットが任意の方向(x,y)に移動することができると想定する。当業者が理解するように、ORCAは、ホロノミック速度ベクトルをその分析に使用するが、DWAによって生成されたvprefは、差動駆動ロボットについてのように、非ホロノミック・ロボット制御を想定する。したがって、非ホロノミック推奨速度vprefを、ORCA VOを生成する際に使用するためのホロノミック・ベクトル(x,y)に変換するときに、いくつかの誤差に対する調節がなされなければならない。
図15は、本発明の一態様によるこの調節を示す。ORCAにおいて非ホロノミック速度vprefを使用するための修正は、それぞれのVOを生成するときに他のロボットのサイズを膨張させることによって調節される。図15に示すように、各ロボットの半径の増加量は、直線ベクトル(x,y)と推奨軌道tprefとの間の最大誤差距離dとほぼ等しくなる。ホロノミック軌道と非ホロノミック軌道との間の最大誤差dだけ他のロボットの半径を膨張させることによって、他のロボットの近傍でのロボット18の衝突のない移動が確保される。当業者は、ORCAの非ホロノミック版を含むORCAの修正形態が、例えば、ORCA−NH(非ホロノミック)が非ホロノミック速度vprefとして推奨軌道を使用する際に調節を必要としない、本明細書における方法の適切な修正形態で置き換えられ得ることを理解するであろう。
当業者によって理解されるように、VOを作成し、次いでこれらのVOの結合を取得することにより、各VOの半平面の交差によって定義される速度空間内にポリゴンが形成される。ORCAの適用におけるVOの作成及び結合の取得についての考察は、すでに参照により本明細書に組み込まれている、Jur van den Berg他、「Reciprocal n−body collision avoidance」において見出される。例えば、図16Aは、速度オブジェクトVO〜VOの半平面の結合によって形成されるポリゴンPを示す。VOのそれぞれは、他のロボットa〜eに対応し、それらのポーズは本明細書に記載の方法に従って移動するロボットに把握されている。ORCAの下では、VOの結合によって形成されるポリゴンが速度空間(ポーズ空間ではない)内の衝突を定義することを想起すると、ポリゴン内にあるロボットについてのどの速度も安全であると見なされ、他のロボットとの衝突のない回避を確実にし、ポリゴンから外れているどの速度も安全ではなく、ロボットを1つ又は複数の他のロボットと衝突させる可能性がある。
上記を考慮して、プロセスは図14においてステップ860に進み、組み合わされたORCA/DWA目的関数を使用してDWAによって生成された候補速度を評価する。組み合わされたORCA/DWA目的関数は、次のように、重みαORCAを用いてコスト・クリティックCORCAと組み合わされたコスト関数CDWAで構成される。
ORCA/DWA=CDWA+αORCA*CORCA
DWAは、
DWA=α*heading(v,ω)+β*dist(v,ω)+γ*velocity(v,ω)
と定義され、ここで、α、β、γは重みであり、heading(v,ω)は目標経路に沿った進行状況の尺度であり、dist(v,ω)は最も近い障害物までの距離であり、velocity(v,ω)は所与の候補速度(v,ω)に対するロボットの前進速度である。CDWA及びG(v,ω)は、ORCA VO生成用のvprefを決定するために上で使用されたように、本発明への適用において一般性を失うことなく、同じ重みを用いて同じ関数として、又は異なる重みを用いて若しくは他のコスト関数の組合せによって異なる関数として実装され得る。
ORCAは次のように、
ORCA=α(v−vpref)+penalty+α*d(P,v
と定義され、ここで、α及びαは重みであり、vは評価される候補速度であり、vprefは推奨速度であり、PはVOの結合によって形成されるポリゴンであり、d(P、v)は候補速度がVOにどれだけ違反しているかの尺度であり、penaltyは候補速度vがVOに違反したときに課されるペナルティ・コストである。
コスト・クリティックCORCAの評価において、すべての候補速度vは、推奨速度vprefとどれだけ異なるかの尺度として基本コストα(v−vpref)を取得する。例えば、図16Aに示すように、候補速度vがVOから形成されるポリゴンP内にあるが、vからvprefまでの距離が大きい場合、コストα(v−vpref)は大きいがペナルティは追加されない。図16Bに示すように、候補速度vがポリゴンP内にあり、vprefまでの距離が小さい場合、コストα(v−vpref)は小さく、やはりペナルティは追加されない。しかしながら、候補速度vが少なくとも1つの速度障害物に違反している場合(すなわち、ポリゴンPの外側にあり、したがって「安全でない」)、ペナルティが基本コスト項に追加されるα(v−vpref)+penalty。
さらに、好ましい実施例では、vからポリゴンPのエッジまでの距離d(P、v)に基づいて、vに追加のペナルティが課され得る。例えば、図16cに示すように、コスト関数d(P、v)は、ポリゴンPの外周から候補速度vが到達する軌道tによって定義される点までの最小距離の関数である。示されている実例では、vは、ポリゴンPの外側あるので最初のペナルティが発生すると共に、vprefから比較的遠いのでさらに高いコストα(v−vpref)が発生し、違反の大きさ、すなわちvからポリゴンPまでの距離に基づいて、追加のペナルティがさらに発生する。したがって、この実例のCORCAの評価において、α(v−vpref)+penalty+penalty*d(P,v)は、組み合わされたORCA/DWA目的関数に追加されるときに、vに高いコストをもたらす。
ORCAとDWAのコスト・クリティックを組み合わせて、最小の重み付きコストを取ると、
min(CDWA+αORCA*CORCA
は、候補速度のセットから最適な候補速度を返す。再び図13のステップ816を参照すると、次の制御は、組み合わされたORCA/DWAコスト関数によって決定されるような最小コストを有する候補速度に関連する瞬間速度である。制御をロボット駆動制御に適用すると、ロボットは目標経路に沿って増分的に移動し(ステップ818)、ロボットがその目標ポーズに到達するまでプロセスは繰り返す(ステップ820)。
本発明の前述の説明により、当業者は現在その最良の方式であると考えられるものを作成及び使用することができるが、当業者は、本明細書の特定の実施例及び実例の変形、組合せ、及び均等物が存在することを理解及び認識するであろう。本発明の上記の実施例は、単なる実例であることが意図されている。当業者は、添付の特許請求の範囲によってのみ定義される本発明の範囲から逸脱することなく、特定の実施例に対して変更、修正、及び変形を行うことができる。
本発明は、ソフトウェア及び/又はハードウェアで実施され得ることを理解されたい。したがって、本発明の態様は、完全にハードウェアの実施例、完全にソフトウェアの実施例(ファームウェア、常駐ソフトウェア、マイクロコードなどを含む)、又は本明細書ではすべて「回路」、「モジュール」、若しくは「システム」と総称され得るソフトウェアの態様とハードウェアの態様を組み合わせた実施例の形態を取ることができる。当業者によって理解されるように、本発明の態様は、システム、方法、又はコンピュータ・プログラム製品として具現化され得る。
本発明の態様は、方法及び装置(システム)のフローチャート、図、及び/又はブロック図を参照して説明される。フローチャート及びブロック図は、本発明の様々な実施例によるシステム・アーキテクチャ、機能、又は動作を示し得る。フローチャートにおける各ステップは、指定された機能を実施するための1つ又は複数の実行可能命令を含むモジュールを表す場合がある。いくつかの実施態様では、連続して示されるステップは、実際には実質的に同時に実行され得る。ステップは、指定された機能若しくは動作を実行する専用ハードウェアベースのシステム、又は専用ハードウェアとコンピュータ命令の組合せによって実行され得る。
本発明の動作を実行するプロセッサによる実行のためのコンピュータ命令は、C#、C++、Python、又はJava(登録商標)プログラミング言語などのオブジェクト指向プログラミング言語を含む1つ又は複数のプログラミング言語で記述され得る。コンピュータ・プログラム命令は、本明細書に記載のフローチャート及び/又はシステム・ブロック図で指定されたステップを実施する命令を実行することを含む、データ・プロセッサを介してロボット・システムに特定の方法で機能するように命令することができるコンピュータ可読媒体に記憶され得る。コンピュータ可読ストレージ媒体は、データ・プロセッサによって、又はデータ・プロセッサに関連して使用するための命令を含むか、又は記憶することができる任意の有形の媒体とすることができる。コンピュータ可読媒体は、コンピュータ可読プログラム・コードがその中に具体化された伝搬データ信号も含み得る。
したがって、本発明は、上述の実施例及び実例、実施例、並びに以下に特許請求される本発明の範囲及び精神内の用途によって限定されない。

Claims (25)

  1. 目標経路に沿ってロボットをナビゲートし、障害物を回避するための方法であって、
    第1のロボットに関する目標ポーズを受信するステップと、
    前記第1のロボットに関する目標経路を決定するステップと、
    障害物マップを受信するステップと、
    前記第1のロボットのポーズを受信するステップと、
    1つ又は複数の他のロボットのポーズを受信するステップと、
    前記第1のロボットに関する候補速度のセットを生成するステップと、
    第1の目的関数を使用して候補速度の前記第1のセットを評価するステップと、
    前記第1の目的関数に基づいて前記第1のロボットの第1の推奨速度を選択するステップと、
    前記1つ又は複数の他のロボットの前記ポーズ及び前記第1のロボットの前記第1の推奨速度に基づいて速度障害物のセットを作成するステップと、
    第2の目的関数を使用して候補速度の前記セットを評価するステップと、
    前記第2の目的関数に基づいて前記第1のロボットの第2の推奨速度を選択するステップと、
    前記第2の推奨速度に基づいて前記第1のロボットを移動させるステップと
    を含む、方法。
  2. 前記目標経路が、前記第1のロボットの現在ポーズから前記第1のロボットの前記目標ポーズまでの経路を含む、請求項1に記載の方法。
  3. 前記ロボットの目標ポーズが、注文履行倉庫アプリケーションにおける、基準と関連付けられた製品ビンのポーズである、請求項1に記載の方法。
  4. 前記第1のロボットの前記ポーズが、多対多マルチ解像度スキャン・マッチング(M3RSM)、適応モンテ・カルロ位置推定(AMCL)、ジオポジショニング衛星(GPS)、基準情報、及びオドメトリベースのオン・ロボット・センサのうちの1つ又は複数によって決定される、請求項1に記載の方法。
  5. 前記第1のロボットの候補速度の前記セットを生成する前記ステップが、動き、障害物、及び慣性の制約を適用する1つ又は複数の時間ステップにわたる候補速度を想定して、許容軌道を有する候補速度のみを生成する、請求項1に記載の方法。
  6. 前記第1の目的関数が、
    G(v,ω)=α*heading(v,ω)+β*dist(v,ω)+γ*velocity(v,ω)
    の形式の1つ又は複数のコスト関数から構成され、ここで、G(v,ω)が前記目的関数であり、α、β、γが重みであり、heading(v,ω)が前記目標経路に沿った進行状況の尺度であり、dist(v,ω)が最も近い障害物までの距離(その「間隔」)であり、velocity(v,ω)が所与の候補速度(v,ω)に対する前記ロボットの前進速度である、請求項1に記載の方法。
  7. 前記第1の目的関数が、
    前記候補速度が前記目標経路からどれだけ放射状に広がることになるかをスコア化する経路コスト関数、
    障害物への近さをスコア化する障害物コスト関数、及び
    以前の推奨速度からの回転速度の変化に対してより高いコストを割り当てる振動コスト関数
    のうちの1つ又は複数をさらに含む、請求項6に記載の方法。
  8. 前記1つ又は複数のコスト関数が、前記候補速度に最高のコスト・スコアを割り当てることによって候補速度を無効にする、請求項6に記載の方法。
  9. 速度オブジェクトの前記セットを作成するステップが、前記推奨速度を非ホロノミック速度からホロノミック速度に変換することを含む、請求項1に記載の方法。
  10. 前記推奨速度をホロノミック速度に変換することが、前記1つ又は複数の他のロボットの半径を、推奨軌道と直線軌道との間の最大距離だけ増加させることを含む、請求項9に記載の方法。
  11. 前記第2の目的関数が、
    ORCA/DWA=CDWA+αORCA*CORCA
    の形式の1つ又は複数のコスト関数から構成され、
    ここで、CDWAが、
    DWA=α*heading(v,ω)+β*dist(v,ω)+γ*velocity(v,ω)
    と定義され、ここで、α、β、γが重みであり、heading(v,ω)が前記目標経路に沿った進行状況の尺度であり、dist(v,ω)が最も近い障害物までの距離であり、velocity(v,ω)が所与の候補速度(v,ω)に対する前記ロボットの前進速度であり、CORCAが、
    ORCA=α(v−vpref)+penalty+α*d(P,v
    と定義され、ここで、α及びαが重みであり、vが評価される候補速度であり、vprefが推奨速度であり、PがVOの結合によって形成されるポリゴンであり、d(P,v)が候補速度がVOにどれだけ違反しているかの尺度であり、penaltyが候補速度vがVOに違反したときに課せられるペナルティ・コストである、請求項1に記載の方法。
  12. コスト関数d(P、v)が、ポリゴンPの外周から候補速度vが到達する軌道tによって定義される点までの最小距離の関数である、請求項11に記載の方法。
  13. 目標経路に沿ってロボットをナビゲートし、障害物を回避するためのロボット・システムであって、
    トランシーバと、
    データ・ストレージ・デバイスと、
    データ・プロセッサ及び前記データ・プロセッサによる実行のための記憶された命令を有するデータ・ストレージ・デバイスとを含み、前記命令が、
    第1のロボットに関する目標ポーズを受信すること、
    前記第1のロボットに関する目標経路を決定すること、
    障害物マップを受信すること、
    前記第1のロボットのポーズを受信すること、
    1つ又は複数の他のロボットのポーズを受信すること、
    前記第1のロボットに関する候補速度のセットを生成すること、
    第1の目的関数を使用して候補速度の第1のセットを評価すること、
    前記第1の目的関数に基づいて前記第1のロボットの第1の推奨速度を選択すること、
    前記1つ又は複数の他のロボットの前記ポーズ及び前記第1のロボットの前記第1の推奨速度に基づいて速度障害物のセットを作成すること、
    第2の目的関数を使用して候補速度の前記セットを評価すること、
    前記第2の目的関数に基づいて前記第1のロボットの第2の推奨速度を選択すること、及び
    前記第2の推奨速度に基づいて前記第1のロボットを移動させること
    を実行させる、ロボット・システム。
  14. 前記目標経路が、前記第1のロボットの現在ポーズから前記第1のロボットの前記目標ポーズまでの経路を含む、請求項13に記載のシステム。
  15. 前記ロボットの目標ポーズが、注文履行倉庫アプリケーションにおける、基準と関連付けられた製品ビンのポーズである、請求項13に記載のシステム。
  16. 前記第1のロボットの前記ポーズが、多対多マルチ解像度スキャン・マッチング(M3RSM)、適応モンテ・カルロ位置推定(AMCL)、ジオポジショニング衛星(GPS)、基準情報、及びオドメトリベースのオン・ロボット・センサのうちの1つ又は複数によって決定される、請求項13に記載のシステム。
  17. 前記第1のロボットの候補速度の前記セットを生成するステップが、動き、障害物、及び慣性の制約を適用する1つ又は複数の時間ステップにわたる候補速度を想定して、許容軌道を有する候補速度のみを生成する、請求項13に記載のシステム。
  18. 前記第1の目的関数が、
    G(v,ω)=α*heading(v,ω)+β*dist(v,ω)+γ*velocity(v,ω)
    の形式の1つ又は複数のコスト関数から構成され、ここで、G(v,ω)が前記目的関数であり、α、β、γが重みであり、heading(v,ω)が前記目標経路に沿った進行状況の尺度であり、dist(v,ω)が最も近い障害物までの距離(その「間隔」)であり、velocity(v,ω)が所与の候補速度(v,ω)に対する前記ロボットの前進速度である、請求項13に記載のシステム。
  19. 前記第1の目的関数が、
    前記候補速度が前記目標経路からどれだけ放射状に広がることになるかをスコア化する経路コスト関数、
    障害物への近さをスコア化する障害物コスト関数、及び
    以前の推奨速度からの回転速度の変化に対してより高いコストを割り当てる振動コスト関数
    のうちの1つ又は複数をさらに含む、請求項18に記載のシステム。
  20. 前記1つ又は複数のコスト関数が、前記候補速度に最高のコスト・スコアを割り当てることによって候補速度を無効にする、請求項18に記載のシステム。
  21. 速度オブジェクトの前記セットを作成するステップが、前記推奨速度を非ホロノミック速度からホロノミック速度に変換することを含む、請求項13に記載のシステム。
  22. 前記推奨速度をホロノミック速度に変換することが、前記1つ又は複数のロボットの半径を、推奨軌道と直線軌道との間の最大距離だけ増加させることを含む、請求項21に記載のシステム。
  23. 前記第2の目的関数が、
    ORCA/DWA=CDWA+αORCA*CORCA
    の形式の1つ又は複数のコスト関数から構成され、
    ここで、CDWAが、
    DWA=α*heading(v,ω)+β*dist(v,ω)+γ*velocity(v,ω)
    と定義され、ここで、α、β、γが重みであり、heading(v,ω)が前記目標経路に沿った進行状況の尺度であり、dist(v,ω)が最も近い障害物までの距離であり、velocity(v,ω)が所与の候補速度(v,ω)に対する前記ロボットの前進速度であり、CORCAが、
    ORCA=α(v−vpref)+penalty+α*d(P,v
    と定義され、ここで、α及びαが重みであり、vが評価される候補速度であり、vprefが推奨速度であり、PがVOの結合によって形成されるポリゴンであり、d(P,v)が候補速度がVOにどれだけ違反しているかの尺度であり、penaltyが候補速度vがVOに違反したときに課せられるペナルティ・コストである、請求項13に記載のシステム。
  24. コスト関数d(P、v)が、ポリゴンPの外周から候補速度vが到達する軌道tによって定義される点までの最小距離の関数である、請求項23に記載のシステム。
  25. 複数のロボットと、監視システムとを含み、前記監視システムの監視下にある1つ又は複数のロボットが、請求項1に記載の方法を実行する、システム。
JP2020516695A 2017-09-22 2018-09-21 最適相互衝突回避のコスト−クリティックを用いたダイナミック・ウィンドウ・アプローチ Active JP6987226B2 (ja)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US15/712,256 US10429847B2 (en) 2017-09-22 2017-09-22 Dynamic window approach using optimal reciprocal collision avoidance cost-critic
US15/712,256 2017-09-22
PCT/US2018/052165 WO2019060679A1 (en) 2017-09-22 2018-09-21 DYNAMIC WINDOW APPROACH USING AN OPTIMUM RECIPROCAL COLLISION AVIATION COST CRITICAL

Publications (2)

Publication Number Publication Date
JP2020534621A true JP2020534621A (ja) 2020-11-26
JP6987226B2 JP6987226B2 (ja) 2021-12-22

Family

ID=64500438

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2020516695A Active JP6987226B2 (ja) 2017-09-22 2018-09-21 最適相互衝突回避のコスト−クリティックを用いたダイナミック・ウィンドウ・アプローチ

Country Status (8)

Country Link
US (1) US10429847B2 (ja)
EP (1) EP3684664B1 (ja)
JP (1) JP6987226B2 (ja)
KR (1) KR102385257B1 (ja)
CN (1) CN111511620B (ja)
CA (1) CA3076498C (ja)
ES (1) ES2900495T3 (ja)
WO (1) WO2019060679A1 (ja)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2022209465A1 (ja) * 2021-03-31 2022-10-06 株式会社小松製作所 システム、方法および作業車両

Families Citing this family (61)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11461912B2 (en) 2016-01-05 2022-10-04 California Institute Of Technology Gaussian mixture models for temporal depth fusion
WO2019070839A1 (en) * 2017-10-05 2019-04-11 California Institute Of Technology SIMULTANEOUS REPRESENTATION OF MOBILE AND STATIC OBSTACLES FOR AUTOMATICALLY CONTROLLED VEHICLES
US10831188B2 (en) 2017-11-07 2020-11-10 Zoox, Inc. Redundant pose generation system
US10775790B2 (en) * 2018-02-09 2020-09-15 Baidu Usa Llc Methods and systems for model predictive control of autonomous driving vehicle
CN110941258A (zh) * 2018-09-21 2020-03-31 日本电产株式会社 移动体的控制方法及移动体的控制系统
US11724395B2 (en) 2019-02-01 2023-08-15 Locus Robotics Corp. Robot congestion management
JP7469850B2 (ja) * 2019-03-25 2024-04-17 本田技研工業株式会社 経路決定装置、ロボット及び経路決定方法
WO2020206457A1 (en) * 2019-04-05 2020-10-08 IAM Robotics, LLC Autonomous mobile robotic systems and methods for picking and put-away
CN110162063A (zh) * 2019-06-12 2019-08-23 北京洛必德科技有限公司 一种用于机器人自动充电的路径规划方法和装置
CN111813100B (zh) * 2019-07-04 2022-07-15 中国科学技术大学 一种局部路径规划算法及装置
CN110296698B (zh) * 2019-07-12 2023-04-28 贵州电网有限责任公司 一种以激光扫描为约束的无人机路径规划方法
CN110398964B (zh) * 2019-07-16 2022-02-01 浙江大学 一种低能量损耗机器人全覆盖路径规划方法及系统
CN110470306B (zh) * 2019-08-27 2023-03-10 中山大学 一种可保证连通性约束的基于深度强化学习的多机器人编队导航方法
CN110609559B (zh) * 2019-10-25 2020-08-25 江苏恒澄交科信息科技股份有限公司 用于无人船路径跟随和避障的改进dwa动态窗口法
CN113580155B (zh) * 2019-10-31 2023-07-18 灵动科技(北京)有限公司 自主移动装置及仓储物流系统
CN112744268B (zh) * 2019-10-31 2022-04-15 比亚迪股份有限公司 车辆的控制方法、装置和车辆
JP7450206B2 (ja) 2019-11-08 2024-03-15 三菱重工業株式会社 複数のビークルの移動制御方法、移動制御装置、移動制御システム、プログラム及び記録媒体
CN110727272B (zh) * 2019-11-11 2023-04-18 广州赛特智能科技有限公司 一种多台机器人的路径规划调度系统及方法
CN111060116B (zh) * 2019-12-04 2023-07-18 江西洪都航空工业集团有限责任公司 一种基于视觉的草场自主建图系统
CN111367283B (zh) * 2020-03-11 2023-04-14 郴州职业技术学院 一种基于障碍物构型重构的无人车避障方法及系统
CN111399506B (zh) * 2020-03-13 2023-04-25 大连海事大学 一种基于动力学约束的全局-局部混合无人船路径规划方法
CN111580518B (zh) * 2020-05-12 2022-08-02 哈尔滨工程大学 一种基于改进果蝇优化和动态窗口法的无人艇分层避障方法
CN111709633B (zh) * 2020-06-09 2022-09-06 吉林大学 一种碰撞危险度确定方法、装置、设备以及可存储介质
CN111665847A (zh) * 2020-06-24 2020-09-15 上海应用技术大学 一种基于模糊逻辑的动态窗口避障算法
CN113960995A (zh) * 2020-07-20 2022-01-21 炬星科技(深圳)有限公司 一种避障规划方法、系统及设备
CN111951552B (zh) * 2020-08-11 2021-10-15 腾讯科技(深圳)有限公司 一种自动驾驶中风险管理的方法以及相关装置
US20220083062A1 (en) 2020-09-11 2022-03-17 Locus Robotics Corp. Robot navigation management between zones in an environment
US11741564B2 (en) * 2020-09-11 2023-08-29 Locus Robotics Corp. Sequence adjustment for executing functions on hems in an order
US11550827B2 (en) * 2020-09-22 2023-01-10 International Business Machines Corporation Graph enabled location optimization
CN112241171A (zh) * 2020-10-09 2021-01-19 国网江西省电力有限公司检修分公司 一种可绕障碍的轮式机器人直线轨迹跟踪方法
US11524846B2 (en) 2020-10-19 2022-12-13 Gideon Brothers d.o.o. Pose determination by autonomous robots in a facility context
CN112330959B (zh) * 2020-10-30 2022-02-22 东北大学 一种用于无人驾驶车辆的最优对等碰撞避免方法
CN112526991B (zh) * 2020-11-25 2022-05-24 中国科学技术大学 机器人运动方法、装置、电子设备及存储介质
CN112378408B (zh) * 2020-11-26 2023-07-25 重庆大学 一种实现轮式移动机器人实时避障的路径规划方法
CN112327885B (zh) * 2020-12-01 2024-04-09 大连海事大学 一种无人船自适应全局-局部混合路径规划的方法
CN112798304A (zh) * 2020-12-07 2021-05-14 北京云迹科技有限公司 一种机器人避让性能测试方法及装置
CN112486183B (zh) * 2020-12-09 2022-11-18 上海机器人产业技术研究院有限公司 一种室内移动机器人的路径规划算法
CN112506199B (zh) * 2020-12-12 2022-12-02 江西洪都航空工业集团有限责任公司 一种基于动态窗口法且适用于阿克曼模型机器人的局部路径规划方法
CN112612295B (zh) * 2020-12-23 2022-07-12 长光卫星技术股份有限公司 一种遥感卫星地面站测控和数传资源自动分配方法
CN113156933B (zh) * 2020-12-30 2022-05-03 徐宁 一种机器人行进控制系统和方法
RU2769710C1 (ru) * 2021-01-14 2022-04-05 Автономная некоммерческая образовательная организация высшего образования «Сколковский институт науки и технологий» Способ построения маршрута движения и управления движением мобильного сервисного робота в торговом помещении
CN113253717B (zh) * 2021-03-17 2022-10-11 武汉科技大学 一种基于动态障碍物的室内移动机器人局部路径规划方法
CN113050646B (zh) * 2021-03-22 2022-09-23 西安工业大学 一种用于室内移动机器人动态环境路径规划方法
WO2022232415A1 (en) * 2021-04-28 2022-11-03 Rutgers, The State University Of New Jersey Reactive collision avoidance for autonomous vehicles considering physical constraints
US20220363273A1 (en) * 2021-05-13 2022-11-17 Ford Global Technologies, Llc Scenario Discriminative Hybrid Motion Control for Mobile Robots
CN113295167B (zh) * 2021-05-14 2022-07-15 山东新一代信息产业技术研究院有限公司 一种室内机器人避障方法
CN113296521B (zh) * 2021-05-26 2021-11-05 紫清智行科技(北京)有限公司 一种基于动态窗口的障碍物局部避障方法
CN113341991B (zh) * 2021-06-18 2022-08-09 重庆大学 一种基于动态窗口和冗余节点过滤的路径优化方法
CN114019912B (zh) * 2021-10-15 2024-02-27 上海电机学院 一种群体机器人运动规划控制方法及系统
WO2023076242A1 (en) * 2021-10-29 2023-05-04 Rutgers, The State University Of New Jersey Collision-free dynamic window approach for moving obstacles
CN114200943A (zh) * 2021-12-13 2022-03-18 哈尔滨工业大学芜湖机器人产业技术研究院 一种动态避让方法及移动机器人
CN114326720B (zh) * 2021-12-20 2023-08-22 上海大学 一种无人艇实时避障方法及系统
CN114237256B (zh) * 2021-12-20 2023-07-04 东北大学 一种适用于欠驱动机器人的三维路径规划与导航方法
WO2023136020A1 (en) * 2022-01-13 2023-07-20 Nec Corporation Pathfinding apparatus, pathfinding method, and non-transitory computer-readable storage medium
GB2620909A (en) * 2022-07-04 2024-01-31 Opteran Tech Limited Method and system for determining the structure, connectivity and identity of a physical or logical space or attribute thereof
CN115345450A (zh) * 2022-07-27 2022-11-15 北京极智嘉科技股份有限公司 容器搬运任务的分配方法及装置
CN115016510A (zh) * 2022-08-08 2022-09-06 武汉工程大学 一种机器人导航避障方法、装置以及存储介质
EP4332712A1 (en) * 2022-08-29 2024-03-06 Nokia Technologies Oy Autonomous vehicle control
US20240135585A1 (en) * 2022-10-21 2024-04-25 Dexterity, Inc. Camera calibration process and interface
CN115542953B (zh) * 2022-12-05 2023-03-24 广东电网有限责任公司东莞供电局 一种基于无人机的巡检方法、装置、设备以及介质
CN116533236B (zh) * 2023-05-09 2024-04-12 北京航空航天大学 一种基于离散工作空间的服务机器人操作评估策略

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP2045161A1 (en) * 2007-10-04 2009-04-08 Deere & Company Method and system for obstacle avoidance for a vehicle
US20110304633A1 (en) * 2010-06-09 2011-12-15 Paul Beardsley display with robotic pixels
US20150205298A1 (en) * 2014-01-17 2015-07-23 Knightscope, Inc. Autonomous data machines and systems
US20150284010A1 (en) * 2013-09-16 2015-10-08 Disney Enterprises, Inc. Shared control of semi-autonomous vehicles including collision avoidance in multi-agent scenarios
WO2017023841A1 (en) * 2015-07-31 2017-02-09 Locus Robotics Corporation Robotic navigation utilizing semantic mapping

Family Cites Families (17)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5006988A (en) 1989-04-28 1991-04-09 University Of Michigan Obstacle-avoiding navigation system
KR100843085B1 (ko) 2006-06-20 2008-07-02 삼성전자주식회사 이동 로봇의 격자지도 작성 방법 및 장치와 이를 이용한영역 분리 방법 및 장치
JP5080333B2 (ja) 2007-04-06 2012-11-21 本田技研工業株式会社 自律移動体のための物体認識装置
CA2859112C (en) 2009-08-31 2017-08-15 Neato Robotics, Inc. Method and apparatus for simultaneous localization and mapping of mobile robot environment
US8209143B1 (en) 2009-09-15 2012-06-26 Google Inc. Accurate alignment of multiple laser scans using a template surface
DE102010012749A1 (de) 2010-03-25 2011-09-29 Kuka Laboratories Gmbh Verfahren zum Betreiben eines autonomen Flurförderfahrzeugs
US9067320B2 (en) 2010-06-09 2015-06-30 Disney Enterprises, Inc. Robotic texture
AU2011305154B2 (en) 2010-09-24 2015-02-05 Irobot Corporation Systems and methods for VSLAM optimization
US8688275B1 (en) 2012-01-25 2014-04-01 Adept Technology, Inc. Positive and negative obstacle avoidance system and method for a mobile robot
WO2014202258A1 (en) 2013-06-21 2014-12-24 National University Of Ireland, Maynooth A method for mapping an environment
KR101664582B1 (ko) * 2014-11-12 2016-10-10 현대자동차주식회사 자율주행차량의 주행경로 생성장치 및 방법
JP2017004373A (ja) 2015-06-12 2017-01-05 株式会社リコー 情報処理装置、情報処理プログラム、および情報処理システム
FR3048517B1 (fr) * 2016-03-07 2022-07-22 Effidence Robot autonome motorise avec anticipation d'obstacle
US20170270466A1 (en) 2016-03-18 2017-09-21 Jusda International Logistics (TAIWAN) CO.,LTD Method and system using with automated guided vehicle
CN106156742A (zh) * 2016-07-06 2016-11-23 尚艳燕 一种平衡车障碍物规避方法和装置
US10108194B1 (en) 2016-09-02 2018-10-23 X Development Llc Object placement verification
US10650270B2 (en) 2017-04-21 2020-05-12 X Development Llc Methods and systems for simultaneous localization and calibration

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP2045161A1 (en) * 2007-10-04 2009-04-08 Deere & Company Method and system for obstacle avoidance for a vehicle
US20110304633A1 (en) * 2010-06-09 2011-12-15 Paul Beardsley display with robotic pixels
US20150284010A1 (en) * 2013-09-16 2015-10-08 Disney Enterprises, Inc. Shared control of semi-autonomous vehicles including collision avoidance in multi-agent scenarios
US20150205298A1 (en) * 2014-01-17 2015-07-23 Knightscope, Inc. Autonomous data machines and systems
WO2017023841A1 (en) * 2015-07-31 2017-02-09 Locus Robotics Corporation Robotic navigation utilizing semantic mapping

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2022209465A1 (ja) * 2021-03-31 2022-10-06 株式会社小松製作所 システム、方法および作業車両

Also Published As

Publication number Publication date
EP3684664A1 (en) 2020-07-29
KR102385257B1 (ko) 2022-04-11
EP3684664B1 (en) 2021-11-03
CA3076498C (en) 2022-10-18
US20190094866A1 (en) 2019-03-28
ES2900495T3 (es) 2022-03-17
WO2019060679A1 (en) 2019-03-28
CN111511620B (zh) 2023-06-06
CA3076498A1 (en) 2019-03-28
US10429847B2 (en) 2019-10-01
CN111511620A (zh) 2020-08-07
KR20200089654A (ko) 2020-07-27
JP6987226B2 (ja) 2021-12-22

Similar Documents

Publication Publication Date Title
JP6987226B2 (ja) 最適相互衝突回避のコスト−クリティックを用いたダイナミック・ウィンドウ・アプローチ
JP6937898B2 (ja) 除外区域を用いたマルチ解像度スキャン・マッチング
KR102497430B1 (ko) 로봇 충전기 도킹 제어
KR102442241B1 (ko) 로봇 충전기 도킹 로컬화
US11493925B2 (en) Robot obstacle collision prediction and avoidance
Behrje et al. An autonomous forklift with 3d time-of-flight camera-based localization and navigation
JP2023540813A (ja) 環境内でのゾーン間のロボット誘導管理

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20200428

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20210317

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20210319

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20210617

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20211112

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20211130

R150 Certificate of patent or registration of utility model

Ref document number: 6987226

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150