WO2018169589A1 - Grouping for efficient cooperative positioning calculations - Google Patents

Grouping for efficient cooperative positioning calculations Download PDF

Info

Publication number
WO2018169589A1
WO2018169589A1 PCT/US2017/066955 US2017066955W WO2018169589A1 WO 2018169589 A1 WO2018169589 A1 WO 2018169589A1 US 2017066955 W US2017066955 W US 2017066955W WO 2018169589 A1 WO2018169589 A1 WO 2018169589A1
Authority
WO
WIPO (PCT)
Prior art keywords
vehicles
vehicle
selection criteria
module
data
Prior art date
Application number
PCT/US2017/066955
Other languages
French (fr)
Inventor
Olof Eriksson
Christian Svensson
Tobias Aderum
Zhu MEIFANG
Original Assignee
Autoliv Asp, Inc.
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 Autoliv Asp, Inc. filed Critical Autoliv Asp, Inc.
Priority to EP17901184.6A priority Critical patent/EP3596421B1/en
Priority to CN201780088466.3A priority patent/CN110621955B/en
Priority to CN202210634544.8A priority patent/CN115184920A/en
Publication of WO2018169589A1 publication Critical patent/WO2018169589A1/en
Priority to US16/567,353 priority patent/US11092696B2/en

Links

Classifications

    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S19/00Satellite radio beacon positioning systems; Determining position, velocity or attitude using signals transmitted by such systems
    • G01S19/38Determining a navigation solution using signals transmitted by a satellite radio beacon positioning system
    • G01S19/39Determining a navigation solution using signals transmitted by a satellite radio beacon positioning system the satellite radio beacon positioning system transmitting time-stamped messages, e.g. GPS [Global Positioning System], GLONASS [Global Orbiting Navigation Satellite System] or GALILEO
    • G01S19/42Determining position
    • G01S19/48Determining position by combining or switching between position solutions derived from the satellite radio beacon positioning system and position solutions derived from a further system
    • G01S19/485Determining position by combining or switching between position solutions derived from the satellite radio beacon positioning system and position solutions derived from a further system whereby the further system is an optical system or imaging system
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S19/00Satellite radio beacon positioning systems; Determining position, velocity or attitude using signals transmitted by such systems
    • G01S19/38Determining a navigation solution using signals transmitted by a satellite radio beacon positioning system
    • G01S19/39Determining a navigation solution using signals transmitted by a satellite radio beacon positioning system the satellite radio beacon positioning system transmitting time-stamped messages, e.g. GPS [Global Positioning System], GLONASS [Global Orbiting Navigation Satellite System] or GALILEO
    • G01S19/42Determining position
    • G01S19/51Relative positioning
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S13/00Systems using the reflection or reradiation of radio waves, e.g. radar systems; Analogous systems using reflection or reradiation of waves whose nature or wavelength is irrelevant or unspecified
    • G01S13/87Combinations of radar systems, e.g. primary radar and secondary radar
    • G01S13/878Combination of several spaced transmitters or receivers of known location for determining the position of a transponder or a reflector
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B60VEHICLES IN GENERAL
    • B60RVEHICLES, VEHICLE FITTINGS, OR VEHICLE PARTS, NOT OTHERWISE PROVIDED FOR
    • B60R21/00Arrangements or fittings on vehicles for protecting or preventing injuries to occupants or pedestrians in case of accidents or other traffic risks
    • B60R21/01Electrical circuits for triggering passive safety arrangements, e.g. airbags, safety belt tighteners, in case of vehicle accidents or impending vehicle accidents
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B60VEHICLES IN GENERAL
    • B60RVEHICLES, VEHICLE FITTINGS, OR VEHICLE PARTS, NOT OTHERWISE PROVIDED FOR
    • B60R21/00Arrangements or fittings on vehicles for protecting or preventing injuries to occupants or pedestrians in case of accidents or other traffic risks
    • B60R21/01Electrical circuits for triggering passive safety arrangements, e.g. airbags, safety belt tighteners, in case of vehicle accidents or impending vehicle accidents
    • B60R21/013Electrical circuits for triggering passive safety arrangements, e.g. airbags, safety belt tighteners, in case of vehicle accidents or impending vehicle accidents including means for detecting collisions, impending collisions or roll-over
    • B60R21/0134Electrical circuits for triggering passive safety arrangements, e.g. airbags, safety belt tighteners, in case of vehicle accidents or impending vehicle accidents including means for detecting collisions, impending collisions or roll-over responsive to imminent contact with an obstacle, e.g. using radar systems
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B60VEHICLES IN GENERAL
    • B60RVEHICLES, VEHICLE FITTINGS, OR VEHICLE PARTS, NOT OTHERWISE PROVIDED FOR
    • B60R21/00Arrangements or fittings on vehicles for protecting or preventing injuries to occupants or pedestrians in case of accidents or other traffic risks
    • B60R21/02Occupant safety arrangements or fittings, e.g. crash pads
    • B60R21/16Inflatable occupant restraints or confinements designed to inflate upon impact or impending impact, e.g. air bags
    • B60R21/23Inflatable members
    • B60R21/231Inflatable members characterised by their shape, construction or spatial configuration
    • B60R21/23138Inflatable members characterised by their shape, construction or spatial configuration specially adapted for side protection
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B60VEHICLES IN GENERAL
    • B60RVEHICLES, VEHICLE FITTINGS, OR VEHICLE PARTS, NOT OTHERWISE PROVIDED FOR
    • B60R21/00Arrangements or fittings on vehicles for protecting or preventing injuries to occupants or pedestrians in case of accidents or other traffic risks
    • B60R21/34Protecting non-occupants of a vehicle, e.g. pedestrians
    • B60R21/36Protecting non-occupants of a vehicle, e.g. pedestrians using airbags
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B60VEHICLES IN GENERAL
    • B60RVEHICLES, VEHICLE FITTINGS, OR VEHICLE PARTS, NOT OTHERWISE PROVIDED FOR
    • B60R22/00Safety belts or body harnesses in vehicles
    • B60R22/48Control systems, alarms, or interlock systems, for the correct application of the belt or harness
    • 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
    • B60W30/095Predicting travel path or likelihood of collision
    • B60W30/0953Predicting travel path or likelihood of collision the prediction being responsive to vehicle dynamic parameters
    • 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/26Navigation; Navigational instruments not provided for in groups G01C1/00 - G01C19/00 specially adapted for navigation in a road network
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S13/00Systems using the reflection or reradiation of radio waves, e.g. radar systems; Analogous systems using reflection or reradiation of waves whose nature or wavelength is irrelevant or unspecified
    • G01S13/88Radar or analogous systems specially adapted for specific applications
    • G01S13/93Radar or analogous systems specially adapted for specific applications for anti-collision purposes
    • G01S13/931Radar or analogous systems specially adapted for specific applications for anti-collision purposes of land vehicles
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S19/00Satellite radio beacon positioning systems; Determining position, velocity or attitude using signals transmitted by such systems
    • G01S19/38Determining a navigation solution using signals transmitted by a satellite radio beacon positioning system
    • G01S19/39Determining a navigation solution using signals transmitted by a satellite radio beacon positioning system the satellite radio beacon positioning system transmitting time-stamped messages, e.g. GPS [Global Positioning System], GLONASS [Global Orbiting Navigation Satellite System] or GALILEO
    • G01S19/396Determining accuracy or reliability of position or pseudorange measurements
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S19/00Satellite radio beacon positioning systems; Determining position, velocity or attitude using signals transmitted by such systems
    • G01S19/38Determining a navigation solution using signals transmitted by a satellite radio beacon positioning system
    • G01S19/39Determining a navigation solution using signals transmitted by a satellite radio beacon positioning system the satellite radio beacon positioning system transmitting time-stamped messages, e.g. GPS [Global Positioning System], GLONASS [Global Orbiting Navigation Satellite System] or GALILEO
    • G01S19/42Determining position
    • G01S19/48Determining position by combining or switching between position solutions derived from the satellite radio beacon positioning system and position solutions derived from a further system
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S5/00Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations
    • G01S5/0009Transmission of position information to remote stations
    • G01S5/0018Transmission from mobile station to base station
    • G01S5/0036Transmission from mobile station to base station of measured values, i.e. measurement on mobile and position calculation on base station
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S5/00Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations
    • G01S5/0009Transmission of position information to remote stations
    • G01S5/0072Transmission between mobile stations, e.g. anti-collision systems
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S5/00Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations
    • G01S5/02Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations using radio waves
    • G01S5/0205Details
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S5/00Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations
    • G01S5/02Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations using radio waves
    • G01S5/0257Hybrid positioning
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S5/00Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations
    • G01S5/02Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations using radio waves
    • G01S5/0284Relative positioning
    • G01S5/0289Relative positioning of multiple transceivers, e.g. in ad hoc networks
    • 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/0011Control of position, course, altitude or attitude of land, water, air or space vehicles, e.g. using automatic pilots associated with a remote control arrangement
    • G05D1/0022Control of position, course, altitude or attitude of land, water, air or space vehicles, e.g. using automatic pilots associated with a remote control arrangement characterised by the communication link
    • 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/0011Control of position, course, altitude or attitude of land, water, air or space vehicles, e.g. using automatic pilots associated with a remote control arrangement
    • G05D1/0027Control of position, course, altitude or attitude of land, water, air or space vehicles, e.g. using automatic pilots associated with a remote control arrangement involving a plurality of vehicles, e.g. fleet or convoy travelling
    • 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/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/0291Fleet control
    • G05D1/0295Fleet control by at least one leading vehicle of the fleet
    • GPHYSICS
    • G08SIGNALLING
    • G08GTRAFFIC CONTROL SYSTEMS
    • G08G1/00Traffic control systems for road vehicles
    • G08G1/01Detecting movement of traffic to be counted or controlled
    • G08G1/0104Measuring and analyzing of parameters relative to traffic conditions
    • G08G1/0108Measuring and analyzing of parameters relative to traffic conditions based on the source of data
    • G08G1/0112Measuring and analyzing of parameters relative to traffic conditions based on the source of data from the vehicle, e.g. floating car data [FCD]
    • GPHYSICS
    • G08SIGNALLING
    • G08GTRAFFIC CONTROL SYSTEMS
    • G08G1/00Traffic control systems for road vehicles
    • G08G1/01Detecting movement of traffic to be counted or controlled
    • G08G1/0104Measuring and analyzing of parameters relative to traffic conditions
    • G08G1/0125Traffic data processing
    • G08G1/0133Traffic data processing for classifying traffic situation
    • GPHYSICS
    • G08SIGNALLING
    • G08GTRAFFIC CONTROL SYSTEMS
    • G08G1/00Traffic control systems for road vehicles
    • G08G1/16Anti-collision systems
    • G08G1/161Decentralised systems, e.g. inter-vehicle communication
    • GPHYSICS
    • G08SIGNALLING
    • G08GTRAFFIC CONTROL SYSTEMS
    • G08G1/00Traffic control systems for road vehicles
    • G08G1/16Anti-collision systems
    • G08G1/161Decentralised systems, e.g. inter-vehicle communication
    • G08G1/163Decentralised systems, e.g. inter-vehicle communication involving continuous checking
    • GPHYSICS
    • G08SIGNALLING
    • G08GTRAFFIC CONTROL SYSTEMS
    • G08G1/00Traffic control systems for road vehicles
    • G08G1/16Anti-collision systems
    • G08G1/164Centralised systems, e.g. external to 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
    • G08SIGNALLING
    • G08GTRAFFIC CONTROL SYSTEMS
    • G08G1/00Traffic control systems for road vehicles
    • G08G1/22Platooning, i.e. convoy of communicating vehicles
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L43/00Arrangements for monitoring or testing data switching networks
    • H04L43/08Monitoring or testing based on specific metrics, e.g. QoS, energy consumption or environmental parameters
    • H04L43/0852Delays
    • H04L43/0864Round trip delays
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/02Services making use of location information
    • H04W4/023Services making use of location information using mutual or relative location information between multiple location based services [LBS] targets or of distance thresholds
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/06Selective distribution of broadcast services, e.g. multimedia broadcast multicast service [MBMS]; Services to user groups; One-way selective calling services
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/30Services specially adapted for particular environments, situations or purposes
    • H04W4/40Services specially adapted for particular environments, situations or purposes for vehicles, e.g. vehicle-to-pedestrians [V2P]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/30Services specially adapted for particular environments, situations or purposes
    • H04W4/40Services specially adapted for particular environments, situations or purposes for vehicles, e.g. vehicle-to-pedestrians [V2P]
    • H04W4/46Services specially adapted for particular environments, situations or purposes for vehicles, e.g. vehicle-to-pedestrians [V2P] for vehicle-to-vehicle communication [V2V]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/80Services using short range communication, e.g. near-field communication [NFC], radio-frequency identification [RFID] or low energy communication
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W56/00Synchronisation arrangements
    • H04W56/0055Synchronisation arrangements determining timing error of reception due to propagation delay
    • H04W56/006Synchronisation arrangements determining timing error of reception due to propagation delay using known positions of transmitter and receiver
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W56/00Synchronisation arrangements
    • H04W56/0055Synchronisation arrangements determining timing error of reception due to propagation delay
    • H04W56/0065Synchronisation arrangements determining timing error of reception due to propagation delay using measurement of signal travel time
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B60VEHICLES IN GENERAL
    • B60RVEHICLES, VEHICLE FITTINGS, OR VEHICLE PARTS, NOT OTHERWISE PROVIDED FOR
    • B60R21/00Arrangements or fittings on vehicles for protecting or preventing injuries to occupants or pedestrians in case of accidents or other traffic risks
    • B60R21/01Electrical circuits for triggering passive safety arrangements, e.g. airbags, safety belt tighteners, in case of vehicle accidents or impending vehicle accidents
    • B60R2021/0104Communication circuits for data transmission
    • B60R2021/01081Transmission medium
    • B60R2021/01088Transmission medium wireless
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B60VEHICLES IN GENERAL
    • B60RVEHICLES, VEHICLE FITTINGS, OR VEHICLE PARTS, NOT OTHERWISE PROVIDED FOR
    • B60R21/00Arrangements or fittings on vehicles for protecting or preventing injuries to occupants or pedestrians in case of accidents or other traffic risks
    • B60R21/01Electrical circuits for triggering passive safety arrangements, e.g. airbags, safety belt tighteners, in case of vehicle accidents or impending vehicle accidents
    • B60R2021/01204Actuation parameters of safety arrangents
    • B60R2021/01211Expansion of air bags
    • B60R2021/01231Expansion of air bags control of expansion timing or sequence
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B60VEHICLES IN GENERAL
    • B60RVEHICLES, VEHICLE FITTINGS, OR VEHICLE PARTS, NOT OTHERWISE PROVIDED FOR
    • B60R21/00Arrangements or fittings on vehicles for protecting or preventing injuries to occupants or pedestrians in case of accidents or other traffic risks
    • B60R21/01Electrical circuits for triggering passive safety arrangements, e.g. airbags, safety belt tighteners, in case of vehicle accidents or impending vehicle accidents
    • B60R2021/01204Actuation parameters of safety arrangents
    • B60R2021/01252Devices other than bags
    • B60R2021/01265Seat belts
    • B60R2021/01272Belt tensioners
    • 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
    • B60W2554/00Input parameters relating to objects
    • B60W2554/80Spatial relation or speed relative to objects
    • 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
    • B60W2556/00Input parameters relating to data
    • B60W2556/45External transmission of data to or from the vehicle
    • B60W2556/65Data transmitted between vehicles
    • 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/10Navigation; Navigational instruments not provided for in groups G01C1/00 - G01C19/00 by using measurements of speed or acceleration
    • G01C21/12Navigation; Navigational instruments not provided for in groups G01C1/00 - G01C19/00 by using measurements of speed or acceleration executed aboard the object being navigated; Dead reckoning
    • G01C21/16Navigation; Navigational instruments not provided for in groups G01C1/00 - G01C19/00 by using measurements of speed or acceleration executed aboard the object being navigated; Dead reckoning by integrating acceleration or speed, i.e. inertial navigation
    • G01C21/165Navigation; Navigational instruments not provided for in groups G01C1/00 - G01C19/00 by using measurements of speed or acceleration executed aboard the object being navigated; Dead reckoning by integrating acceleration or speed, i.e. inertial navigation combined with non-inertial navigation instruments
    • 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/26Navigation; Navigational instruments not provided for in groups G01C1/00 - G01C19/00 specially adapted for navigation in a road network
    • G01C21/28Navigation; Navigational instruments not provided for in groups G01C1/00 - G01C19/00 specially adapted for navigation in a road network with correlation of data from several navigational instruments
    • G01C21/30Map- or contour-matching
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S13/00Systems using the reflection or reradiation of radio waves, e.g. radar systems; Analogous systems using reflection or reradiation of waves whose nature or wavelength is irrelevant or unspecified
    • G01S13/74Systems using reradiation of radio waves, e.g. secondary radar systems; Analogous systems
    • G01S13/76Systems using reradiation of radio waves, e.g. secondary radar systems; Analogous systems wherein pulse-type signals are transmitted
    • G01S13/765Systems using reradiation of radio waves, e.g. secondary radar systems; Analogous systems wherein pulse-type signals are transmitted with exchange of information between interrogator and responder
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S19/00Satellite radio beacon positioning systems; Determining position, velocity or attitude using signals transmitted by such systems
    • G01S19/38Determining a navigation solution using signals transmitted by a satellite radio beacon positioning system
    • G01S19/39Determining a navigation solution using signals transmitted by a satellite radio beacon positioning system the satellite radio beacon positioning system transmitting time-stamped messages, e.g. GPS [Global Positioning System], GLONASS [Global Orbiting Navigation Satellite System] or GALILEO
    • G01S19/393Trajectory determination or predictive tracking, e.g. Kalman filtering
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S19/00Satellite radio beacon positioning systems; Determining position, velocity or attitude using signals transmitted by such systems
    • G01S19/38Determining a navigation solution using signals transmitted by a satellite radio beacon positioning system
    • G01S19/39Determining a navigation solution using signals transmitted by a satellite radio beacon positioning system the satellite radio beacon positioning system transmitting time-stamped messages, e.g. GPS [Global Positioning System], GLONASS [Global Orbiting Navigation Satellite System] or GALILEO
    • G01S19/42Determining position
    • G01S19/45Determining position by combining measurements of signals from the satellite radio beacon positioning system with a supplementary measurement
    • G01S19/46Determining position by combining measurements of signals from the satellite radio beacon positioning system with a supplementary measurement the supplementary measurement being of a radio-wave signal type
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S13/00Systems using the reflection or reradiation of radio waves, e.g. radar systems; Analogous systems using reflection or reradiation of waves whose nature or wavelength is irrelevant or unspecified
    • G01S13/88Radar or analogous systems specially adapted for specific applications
    • G01S13/93Radar or analogous systems specially adapted for specific applications for anti-collision purposes
    • G01S13/931Radar or analogous systems specially adapted for specific applications for anti-collision purposes of land vehicles
    • G01S2013/932Radar or analogous systems specially adapted for specific applications for anti-collision purposes of land vehicles using own vehicle data, e.g. ground speed, steering wheel direction
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S2205/00Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations
    • G01S2205/001Transmission of position information to remote stations
    • G01S2205/002Transmission of position information to remote stations for traffic control, mobile tracking, guidance, surveillance or anti-collision
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S5/00Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations
    • G01S5/02Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations using radio waves
    • G01S5/0205Details
    • G01S5/0244Accuracy or reliability of position solution or of measurements contributing thereto
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S5/00Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations
    • G01S5/02Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations using radio waves
    • G01S5/0269Inferred or constrained positioning, e.g. employing knowledge of the physical or electromagnetic environment, state of motion or other contextual information to infer or constrain a position
    • G01S5/02695Constraining the position to lie on a curve or surface
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
    • G01S5/00Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations
    • G01S5/02Position-fixing by co-ordinating two or more direction or position line determinations; Position-fixing by co-ordinating two or more distance determinations using radio waves
    • G01S5/0294Trajectory determination or predictive filtering, e.g. target tracking or Kalman filtering
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L43/00Arrangements for monitoring or testing data switching networks
    • H04L43/10Active monitoring, e.g. heartbeat, ping or trace-route
    • H04L43/106Active monitoring, e.g. heartbeat, ping or trace-route using time related information in packets, e.g. by adding timestamps
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W84/00Network topologies
    • H04W84/18Self-organising networks, e.g. ad-hoc networks or sensor networks

Definitions

  • the present invention relates to object positioning generally and, more particularly, to grouping for efficient cooperative positioning calculations.
  • Positioning of objects can be determined using GPS (Global Positioning System) or GNSS (Global Navigation Satellite System).
  • GPS Global Positioning System
  • GNSS Global Navigation Satellite System
  • RTK real-time kinematics
  • Host vehicle gyros can also be used to estimate a future expected trajectory of objects, but if the initial GPS/GNSS position is incorrect the problem cannot be solved correctly.
  • GPS/GNSS does not provide a sufficient degree of accuracy, especially in urban conditions.
  • Using periodic broadcasts to perform inter-vehicle range estimation can be used to obtain a high degree of accuracy regarding relative positioning between obj ects. Determining highly accurate relative positioning between obj ects introduces additional issues. Such issues include high computing costs and excessive communication between all vehicles for determining position accuracy that is precise enough for active intervention. In traffic scenarios with many vehicles in an area close to the host (or ego) vehicle, a high accuracy calculation based on cooperative positioning will use a very large amount of signal processing and radio data transfer to determine a solution.
  • the invention encompasses an aspect concerning an apparatus comprising a transceiver module and a processor.
  • the transceiver may be configured to send/receive data messages to/from a plurality of vehicles.
  • the processor may be configured to (i) determine a plurality of selected vehicles from the plurality of vehicles based on a selection criteria and (ii) calculate relative coordinates of the plurality of vehicles based on the data messages from the selected vehicles.
  • the selection criteria may comprise determining (i) a target vehicle and (ii) at least two complementary vehicles. A predicted traj ectory of the target vehicle may cross paths with a predicted trajectory of the apparatus.
  • the complementary vehicles may be selected based on (i) an arrangement of the plurality of vehicles and (ii) speeds of the plurality of vehicles.
  • the processor comprises a relative positioning module and (ii) the relative positioning module is configured to perform the selection criteria.
  • the selection criteria is implemented to select four of the plurality of vehicles as the selected vehicles, (ii) the selected vehicles comprise a host vehicle, the target vehicle and two of the complementary vehicles and (iii) the apparatus is implemented by the host vehicle.
  • the selection criteria enables a selection of the plurality of selected vehicles to determine a cooperative positioning solution for calculating the relative coordinates.
  • the selection criteria is configured to select the plurality of selected vehicles based on a balance between an accuracy of the relative coordinates calculated and an efficiency of determining the relative coordinates.
  • the efficiency of determining relative coordinates (i) comprises a computation time and an amount of computation power to determine the relative coordinates and (ii) decreases as a number of the selected vehicles increases.
  • one of the complementary vehicles comprises a second target vehicle and (ii) a predicted trajectory of the second target vehicle crosses paths with the predicted trajectory of the apparatus.
  • the complementary vehicles have a higher speed than unselected vehicles in the plurality of vehicles. In some embodiments of the apparatus aspect described above, the selected vehicles have a speed above a pre-determined threshold speed of approximately 3 meters per second.
  • the complementary vehicles have a greater distance from the apparatus than a distance of unselected vehicles in the plurality of vehicles from the apparatus.
  • the arrangement of the apparatus, the target vehicle and at least one of the complementary vehicles form an angle of approximately 90 degrees.
  • the speeds of the plurality of vehicles, the arrangement of the plurality of vehicles and the trajectory of the target vehicle are determined based on a GPS heading, a GPS speed and a GPS position.
  • the predicted trajectory of the target vehicle potentially crosses paths with the apparatus within 10 seconds.
  • the apparatus is further configured to communicate the relative coordinates determined by the processor to the plurality of the vehicles.
  • the arrangement of the apparatus, the target vehicle and two of the complementary vehicles approximates four corners of a rectangle and (ii) the four corners of the rectangle have a sufficient distance from each other.
  • FIG. 1 is a diagram illustrating an embodiment of the present invention
  • FIG. 2 is a diagram illustrating a module configured to determine high-precision range estimation
  • FIG. 3 is a diagram illustrating inter-vehicle range estimation
  • FIG. 4 is a diagram illustrating a selection criteria for an example traffic scenario
  • FIG. 5 is a diagram illustrating a selection criteria for an example traffic scenario
  • FIG. 6 is a diagram illustrating a selection criteria for an example traffic scenario
  • FIG. 7 is a flow diagram illustrating a method for determining an efficient cooperative positioning solution
  • FIG. 8 is a flow diagram illustrating a method for selecting a target vehicle
  • FIG. 9 is a flow diagram illustrating a method for selecting complementary vehicles according to a selection criteria.
  • Embodiments of the present invention include providing grouping for efficient cooperative positioning calculations that may (i) calculate a relative position of vehicles, (ii) improve an accuracy of vehicle locations over GPS/GNSS solutions, (iii) implement a selection criteria for calculations, (iv) balance an accuracy of output calculations against an amount of processing to generate the calculations, (v) provide a solution that reduces overhead and/or (vi) be easy to implement.
  • Grouping and/or clustering may be used in telecommunication. Additionally, grouping and/or clustering may be implemented in the area of cooperative positioning, which is described in "Improving Cooperative Positioning for Vehicular Networks", IEEE Transactions of Vehicular Technology, Vol 60, no. 6 July 2011, appropriate portions of which are incorporated by reference. In an example, grouping may be performed by approximate position and/or vehicle kinetics. A propagation delay of a wireless signal from a transmitter to a receiver may be used to estimate a distance. In one example, a round-trip time (RTT) (e.g., a round-trip delay time) may be used for estimating a distance accurately by sending a wireless signal between vehicles and/or objects (e.g., one at a time).
  • RTT round-trip time
  • MDS Multi-Dimensional Scaling
  • the system 20 may comprise a number of objects 30a- 30n and/or a number of communication satellites 40a-40n.
  • the objects may comprise a combination of vehicles and/or base stations (e.g., infrastructure).
  • two of the communication satellites 40a-40n are shown as a representation of a Global Positioning System (GPS) and/or Global Navigation Satellite System (GNSS) located around the world.
  • GPS Global Positioning System
  • GNSS Global Navigation Satellite System
  • the objects 30a, 30b and/or 3 On may be vehicles and the object 30i may be a base station (e.g., a road side unit (RSU)).
  • RSU road side unit
  • each of the objects 30a-30n may be a vehicle (e.g., no base stations).
  • the number of vehicles and/or base stations 30a-30n and/or communication satellites 40a-40n may be varied according to the design criteria of a particular implementation.
  • the system 20 may be configured to adjust and/or self-correct for various numbers of the vehicles and/or base stations 30a-30n and/or communication satellites 40a-40n.
  • Each of the objects 30a-30n may comprise a respective apparatus (or circuit or module) 100a-100n.
  • the modules 100a-100n may be described in more detail in connection with FIG. 2.
  • the modules lOOa-lOOn may be implemented within and/or attached to the objects 30a-3 On.
  • the module 100a is shown within the vehicle 30a and the module lOOi is attached to the base station 30i.
  • the modules 100a-100n may be located within a dashboard and/or with other electronics of the vehicles 30a-30n.
  • the modules 100a-100n may be implemented in a mobile device (e.g., a cell phone, tablet computing device, a computer, a standalone GPS device, a fitness monitoring device, a smartwatch, etc.).
  • the mobile device implementing the modules 100a-100n may be operated within a vehicle that is moving.
  • the location of and/or how the modules 100a-100n are connected to the objects 30a-30n may be varied according to the design criteria of a particular implementation.
  • the objects 30a-30n and/orthe respective modules 100a-100n may be configured to communicate with the communication satellites 40a-40n.
  • the communication satellites 40a-40n may be connected (e.g., via wireless communication signals).
  • the connection to the satellites 40a-40n may be implemented through a GPS-type connection.
  • the satellites 40a-40n may present signals (e.g., GA-GN).
  • GA-GN Global Navigation Satellite System
  • An example implementation uses a Global Navigation Satellite System (GNSS) or Global Positioning System (GPS).
  • Location information (e.g., coordinates) may be calculated (e.g., by the modules 100a-100n and/or other components of the objects 30a-30n) from the signals GA-GN received from GNSS or GPS.
  • the positional accuracy of the location information may be determined by the modules 100a- 100 ⁇ .
  • the modules 100a-100n may be configured to receive the signals GA-GN sent by the satellites 40a-40n.
  • the modules 100a-100n may be configured to calculate the location information (e.g., position data, coordinates, etc.) of the respective vehicles 30a-30n based on the data in the signals GA-GN.
  • the objects 30a-30n e.g., a GPS module
  • the positional accuracy of the location information calculated from the signals GA-GN may be within an acceptable tolerance to provide one independently calculated source of positional data.
  • Local conditions may be any type of interference and/or multipath factor that may affect a determination of location information (e.g., position coordinates) using the signals GA-GN.
  • the local conditions may be due to ionospheric interference, noise, signal degradation caused by dense urban areas, signal degradation caused by tall buildings, etc.
  • the modules 100a- 100 ⁇ may be configured to supplement and/or enhance the accuracy of the location data of the objects 30a-30n determined from the signals GA-GN by using cooperative positioning.
  • the modules 100a-100n may be configured to provide location data that is more accurate than location data calculated using the signals GA-GN.
  • infrastructure e.g., the base station 30i, in the example shown
  • the base station 30i since the base station 30i may be at a known and fixed location, the base station 30i may be connected to the satellites 40a-40n, calculate location information from the signals GA-GN and provide a verification of the signals GA-GN compared to the known and fixed location of the base station 30i.
  • the modules 100a-100n are shown located in the vehicles 30a-30n.
  • the modules 100a-100n may be implemented as a single unit (e.g., an installed device and/or module) and/or a distributed unit.
  • various components of the modules 100a- 100 ⁇ may be implemented at various locations in and/or on the vehicles 30a-30n and connected by an electronic network connecting one or more of the components and enabling a sharing of information in the form of digital signals (e.g., a serial bus, an electronic bus connected by wiring and/or interfaces, a wireless interface, etc.).
  • the modules 100a-100n may be implemented in an infotainment module of the vehicles 30a-30n.
  • the vehicles 30a-30n may each comprise a number of blocks (or circuits) 102a-102n and/or blocks (or circuits) 104a-104n.
  • the circuits 102a-102n may be configured to implement sensors.
  • the circuits 104a- 104n may be configured to implement actuators.
  • the sensors 102a- 102n and/or the actuators 104a-104n may be connected through an electronic bus (to be described in association with FIG. 2) and/or a wireless connection.
  • the sensors 102a-102n and/or the actuators 104a-104n may be configured to communicate with the modules 100a-100n.
  • the sensors 102a-102n may be configured to capture information from the environment near the vehicles 30a-30n.
  • the actuators 104a-104n maybe configured to cause the vehicles 30a-30n and/or components of the vehicles 30a-30n to perform an action.
  • the sensors 102a- 102n and/or the actuators 104a- 104n may be configured to read data to detect obj ects and/or perform actions in response to the detected objects to cause the vehicles 30a-30n to implement functions such as speed control, collision prediction, collision prevention, automatic alignment, online bumper fascia calibration, motion estimation, dead reckoning, Intersection Movement Assist (EVIA), Left Turn Assist (LTA), Forward Collision Warning (FCW), Lane Change Warning (LCW) and/or scene understanding.
  • EVIA Intersection Movement Assist
  • LTA Left Turn Assist
  • FCW Forward Collision Warning
  • LCW Lane Change Warning
  • the modules 100a-100n may be configured to communicate signals (e.g., RAA- RNN).
  • the signals RAA-RNN may be communicated between the modules 100a- 100 ⁇ to determine a relative distance between the objects 30a-30n.
  • each of the modules 100a-100n may transmit one of the signals RAA-RNN to each of the modules 100a-100n (e.g., within a particular range).
  • the module 100a may transmit the signal RAB to the module 100b, the signal RAI to the module lOOi and the signal RAN to the module 100 ⁇ .
  • the module 100b may transmit the signal RAB to the module 100a, the signal RBI to the module lOOi and the signal RBN to the module 100 ⁇ .
  • the number of the signals RAA-RNN may be varied according to the design criteria of a particular implementation.
  • the signals RAA-RNN may be used by the modules 100a-100n to calculate a value of the range between the obj ects 30a-30n.
  • the signals RAA-RNN may be configured similarly to a radar to measure the amount of time a transmitted signals takes to be sent to a destination and/or return from a destination.
  • the module 100a may perform ranging (e.g., determine the absolute distance between the objects 30a and 30b) by transmitting the signal RAB to the module 100b and measuring how long before the signal RAB returns to the module 100a (e.g., a round-trip time).
  • the communication used to transmit the signal RAA-RNN may be implemented through a cellular network connection (e.g., 3G, 4G, 5G LTE, etc.), a Wi-Fi connection, a GPS-type connection, a radio signal, an ultrasonic signal and/or another type of wireless connection.
  • the signals RAA-RNN may be implemented on a particular wireless frequency spectrum (e.g., 5.9 GHz Dedicated Short Range Communication spectrum).
  • the signals RAA-RNN may be implemented as and/or alongside a Basic Safety Message (BSM).
  • BSM Basic Safety Message
  • Wi-Fi may be implementing and the signals RAA-RNN may be part of a lower layer protocol configured to transmit timestamps (e.g., MAC and/or PHY).
  • the signals RAA-RNN may be used to implement vehicle-to- vehicle (e.g., V2V) and/or vehicle-to- infrastructure (e.g., V2I) communication (e.g., V2X communication).
  • vehicle-to- vehicle e.g., V2V
  • V2I vehicle-to- infrastructure
  • V2X communication e.g., V2X communication
  • the type of wireless connection used to communicate between the modules 100a-100n may be varied according to the design criteria of a particular implementation.
  • the relative positioning values (e.g., coordinates) calculated by the modules 100a- 100 ⁇ using the signals RAA-RNN may be configured to enable an implementation of cooperative positioning.
  • the cooperative positioning and/or relative coordinates determined by the modules 100a-100n may have a greater accuracy than the location information determined using the signals GA-GN (e.g., using GNSS data).
  • the cooperative positioning information may be fused with data acquired using the sensors 102a-102n and/or data generated using the signals GA-GN.
  • the higher accuracy and/or precision of the relative position between the objects 30a-30n may reduce uncertainty, reduce a number of false positives, reduce erroneous data calculations and/or enable an improved Automotive Safety Integrity Level (ASIL) classification.
  • ASIL Automotive Safety Integrity Level
  • the cooperative positioning may be used together with map information to provide improved navigation information.
  • the modules 100a-100n may be configured to enable sensor and/or data fusion.
  • the modules 100a-100n may be configured to receive data from one or more (e.g., disparate) sources (e.g., the signals GA-GN, the signals RAA-RNN, the sensors 102a-102n, etc.).
  • the modules 100a-100n may combine and/or analyze the data from the different sources to make inferences about the environment surrounding the objects 30a-30n.
  • the inferences made by the module lOOa-lOOn may provide a greater accuracy and/or precision of data (e.g., relative positioning) than using one of the sources of data alone.
  • the module 100 is shown as a representative example of one of the modules 100a-100n.
  • the module 100 may be configured to generate and/or calculate a position relative to other vehicles.
  • the module 100 is shown transmitting/receiving the signals RAA-RNN.
  • the module may send/receive other signals (not shown).
  • the module 100 may receive one or more of the signals GA-GN.
  • the number and/or type of signals sent and/or received by the module 100 may be varied according to the design criteria of a particular implementation.
  • the module 100 may be connected to a block (or circuit) 106.
  • the circuit 106 may implement an electronic bus.
  • the electronic bus 106 may be configured to transfer data between the module 100 and the sensors 102a-102n and/or the actuators 104a-104n.
  • the electronic bus 106 may be implemented as a vehicle CAN bus.
  • the electronic bus 106 may be implemented as an electronic wired network and/or a wireless network.
  • the electronic bus 106 may connect one or more components of the vehicle 30 to enable a sharing of information in the form of digital signals (e.g., a serial bus, an electronic bus connected by wiring and/or interfaces, a wireless interface, etc.).
  • the module 100 generally comprises a block (or circuit) 120, ablock (or circuit) 122, a block (or circuit) 124, a block (or circuit) 126, a block (or circuit) 128, a block (or circuit) 130 and/or a block (or circuit) 132.
  • the circuit 120 may implement a GNSS antenna.
  • the circuit 122 may implement a transceiver.
  • the circuit 124 may implement a processor.
  • the circuit 126 may implement a communication port.
  • the circuit 128 may implement a filter.
  • the circuit 130 may implement a clock.
  • the circuit 132 may implement a memory.
  • Other blocks (not shown) may be implemented (e.g., I/O ports, power connectors, interfaces, etc.).
  • the number and/or types of circuits implemented by the module 100 may be varied according to the design criteria of a particular implementation.
  • the antenna 120 may be implemented as a dual band antenna capable of connecting to both a cellular network (e.g., to provide a potential connection option to the base stations 30i) and/or a GNSS network (e.g., the communication satellites 40a-40n).
  • the antenna 120 may be implemented as two antennas.
  • one antenna may be specifically designed to connect to the base station(s) (e.g., 30i), while another antenna may be implemented to connect to the GNSS network satellites 40a-40n.
  • the antenna 120 may be implemented as discrete antenna modules and/or a dual band antenna module.
  • the antenna 120 may be implemented as an off-board circuit (e.g., a component that is not part of the module 100).
  • the antenna 120 may send/receive data to/from the module 100 via the electronic bus 106.
  • the implementation of the antenna 120 may be varied according to the design criteria of a particular implementation.
  • the transceiver 122 may be configured to communicate (e.g., send and/or receive) data (e.g., radio signals).
  • the transceiver 122 may be configured to generate and/or receive one or more of the signals RAA-RNN.
  • the transceiver 122 may receive data from the processor 124 to communicate with external devices (e.g., other of the modules 1 OOa-100 ⁇ ).
  • the transceiver 122 may receive communications from external devices (e.g., other of the modules 100a-100n) and transmit the communication signals to the processor 124.
  • the transceiver 122 may be configured to communicate a Basic Safety Message (BSM) protocol and/or data outside the BSM protocol.
  • BSM Basic Safety Message
  • the transceiver 122 may send and/or receive the signals RAA-RNN through the communication port 126 and/or the sensors 102a-102n.
  • the transceiver 122 may be configured to be compatible with one or more communications protocols (e.g., a Wi-Fi transceiver configured to perform dedicated short-range communication (DSRC), vehicle to vehicle (V2V) and/or vehicle to infrastructure (V2I) communication).
  • DSRC dedicated short-range communication
  • V2V vehicle to vehicle
  • V2I vehicle to infrastructure
  • the implementation of the transceiver 122 may be varied according to the design criteria of a particular implementation.
  • Theprocessor 124 maybeimplemented as amicrocontroller.
  • Theprocessor 124 may comprise a block (or circuit) 150 and/or a block (or circuit) 152.
  • the circuit 150 may implement a GNSS module and/or chipset.
  • the circuit 152 may implement a relative positioning module.
  • the processor 124 may comprise other components (not shown).
  • the processor 124 may be a combined (e.g., integrated) chipset implementing processing functionality, the relative positioning chipset 152 and/orthe GNSS chipset 150.
  • theprocessor 124 may be comprised of a number of separate circuits (e.g., the microcontroller, the GNSS chipset 150 and/or the relative positioning chipset 152).
  • the GNSS module 150 and/or the relative positioning module 152 may each be an optional component of the processor 124.
  • an off-board circuit e.g., a component that is not part of the module 100
  • an off-board circuit e.g., a component that is not part of the module 100 such as a distributed and/or scalable computing service
  • the design of the processor 124 and/or the functionality of various components of the processor 124 may be varied according to the design criteria of a particular implementation.
  • the processor 124 is shown sending data to and/or receiving data from the antenna 120, the transceiver 122, the memory 132 and/orthe communication port 126.
  • the memory 132 may comprise a block (or circuit) 160 and a block (or circuit) 162.
  • the block 160 may store vehicle position data.
  • the block 162 may store computer readable instructions (e.g., instructions readable by the processor 124).
  • the vehicle position data 160 may store various data sets 170a-170n.
  • the data sets 170a-170n may comprise position coordinates 170a, calibration data 170b, a time stamp/delay 170c, relative position data 170d, dead reckoning data 170e and/or other data 170n.
  • the position coordinates 170a may store location information data calculated and/or received by the module 100 from the signal s GA-GN presented by the GNSS satellites 40a-40n.
  • the signals GA-GN may provide data from which a particular resolution of location information positional accuracy may be calculated.
  • the position coordinates 170a may not provide sufficient positional accuracy for particular applications (e.g., lane detection, autonomous driving, etc.).
  • the relative position data 170d may be used to improve the accuracy of the position coordinates 170a.
  • the position coordinates 170a may be calculated by the filter 128 and/or a component external to the module 100.
  • the position coordinates 170a may be calculated by the GNSS module 150.
  • the calibration data 170b may comprise parameters (e.g., coefficients) used to transform data received from the sensors 102a-102n and/or presented to the actuators 104a-104n.
  • the calibration data 170b may provide many sets of coefficients (e.g., one set of coefficients for each of the sensors 102a-102n and/or the actuators 104a-104n).
  • the calibration data 170b may be updatable.
  • the calibration data 170b may store current values as coefficients for the sensors 102a-102n and/orthe actuators 104a- 104n and as the data from the sensors 102a-102n and/or the actuators 104a-104n drifts the module 100 may update the calibration data 170b in order to maintain accuracy.
  • the format of the calibration data 170b may vary based on the design criteria of a particular implementation.
  • the time stamp/delay 170c may be used to determine an age of the vehicle position data 160, the time of flight of the signals RAA-RNN and/or the round-trip time of the signals RAA- RNN. In one example, the time stamp 170c may be used to determine if the vehicle position data 160 should be considered reliable or unreliable (e.g., data older than a pre-determined threshold amount of time may be unreliable). In one example, the time stamp 170c may be appended to the signals RAA-RNN. For example, the time stamp 170c may record a time in Coordinated Universal Time (UTC) and/or in a local time. The implementation of the time stamp 170c may be varied according to the design criteria of a particular implementation.
  • UTC Coordinated Universal Time
  • the relative position data 170d may be used to augment (e.g., improve) a precision of the position coordinates 170a (e.g., the GNSS position) and/or provide an independent set of position data (e.g., cooperative position information).
  • the relative position data 170d may comprise ranging data corresponding to the relative position of the vehicle 30 (e.g., the ego vehicle) to other vehicles.
  • the relative position data 170d may represent a cooperative position solution (e.g., CoP).
  • the relative position data 170d may be used to account (e.g., compensate) for the local conditions that may affect an accuracy of the position coordinates 170a.
  • the relative position data 170d may provide higher precision location information than the position coordinates 170a.
  • the relative position data 170d may be calculated by the relative positioning module 152.
  • the dead reckoning data 170e may be used to store past and/or present information to determine positions traveled by the vehicle 30.
  • the dead reckoning data 170e may store a previously determined position of the vehicle 30 (e.g., estimated speed, estimated time of travel, estimated location, etc.). The previously determined position may be used to help determine a current position of the vehicle 30.
  • the dead reckoning data 170e may be determined based on data from the sensors 102a-102n of the vehicle 52 (e.g., an on-board gyroscope and/or wheel click messages). The implementation and/or the information stored to determine the dead reckoning data 170e may be varied according to the design criteria of a particular implementation.
  • the other data 170n may be stored as part of the vehicle position data 160.
  • the other data 170n may store trend information for the calibration data 170b.
  • the other data 170n may store past data values of the calibration data 170b and/or current data values of the calibration data 170b. The past and current data values of the calibration data 170b may be compared to determine trends used to extrapolate and/or predict potential future values forthe calibration data 170b.
  • the trend information may be used to continue to refine the calibration data 170b when the module 100 is operating in a pure dead reckoning mode (e.g., the location information fails the quality check).
  • the other data 170n may store various coordinate systems determined using a procrusting procedure and/or multi-dimensional scaling operations.
  • the processor 124 may be configured to execute stored computer readable instructions (e.g., the instructions 162 stored in the memory 132). The processor 124 may perform one or more steps based on the stored instructions 162. In an example, the processor 124 may calculate the location information (e.g., based on the received signals GA-GN). In another example, one of the steps of the instructions 162 may be executed/performed by the processor 124 and may determine the relative position data 170d based on the signals RAA-RNN. The instructions executed and/or the order of the instructions 162 performed by the processor 124 may be varied according to the design criteria of a particular implementation.
  • the communication port 126 may allow the module 100 to communicate with external devices such as the sensors 102a-102n and/or the actuators 104a-104n.
  • the module 100 is shown connected to the external electronic bus 106.
  • the communication port 126 may allow the module 100 to share the cooperative position data 170d with various infrastructure and/or components of the vehicle 30 (e.g., the sensors 102a-102n and/or the actuators 104a-104n).
  • the communication port 126 may allow the module 100 to receive information from the sensors 102a-102n of the vehicle 30 (e.g., an on-board gyroscope data, wheel click messages, LIDAR, etc.).
  • information from the module 100 may be communicated to an infotainment device for display to a driver.
  • a wireless connection e.g., Wi-Fi, Bluetooth, cellular, etc.
  • a portable computing device e.g., a smartphone, a tablet computer, a notebook computer, a smart watch, etc.
  • a portable computing device e.g., a smartphone, a tablet computer, a notebook computer, a smart watch, etc.
  • the filter 128 may be configured to perform a linear quadratic estimation.
  • the filter 128 may implement a Kalman filter.
  • the filter 128 may operate recursively on input data to produce a statistically optimal estimate.
  • the filter 128 may be used to calculate the position coordinates 170a and/or estimate the accuracy of the position coordinates 170a.
  • the filter 128 may be implemented as a separate module.
  • the filter 128 may be implemented as part of the memory 132 (e.g., the stored instructions 162). The implementation of the filter 128 may be varied according to the design criteria of a particular implementation.
  • the clock 130 may be configured to determine and/or track a time.
  • the time determined by the clock 130 may be stored as the time stamp data 170c.
  • the clock 130 may be configured to compare time stamps received in the signals RAA-RNN to determine a delay (e.g., a round-trip time).
  • the module 100 may be configured to calculate a position and/or broadcast data (e.g. , via the transceiver 122 and/or the communication port 126) such as the positional coordinates 170a, an age of the data (e.g., when the data was last updated such as the time stamp 170c), the relative position data 170d and/or other data 170n.
  • a position and/or broadcast data e.g. , via the transceiver 122 and/or the communication port 126) such as the positional coordinates 170a, an age of the data (e.g., when the data was last updated such as the time stamp 170c), the relative position data 170d and/or other data 170n.
  • a method of communication implemented by the transceiver 122 and/or the communication port 126 and/or the type of data transmitted maybe varied according to the design criteria of a particular implementation.
  • the module 100 may be configured as a chipset, a system on chip (SoC) and/or a discrete device.
  • the module 100 may be implemented as an electronic control unit (ECU).
  • the module 100 may be configured to calculate a position, velocity and time (PVT) solution, a relative positioning solution and/or a dead reckoning solution.
  • the module 100 may transmit received data (e.g., the signals GA-GN and/or the signals RAA-RNN) to other components external to the module 100 to perform calculations (e.g., the relative position data 170d may be sent to another component to determine the cooperative positioning solution).
  • PVT may be considered a bare minimum output for navigation.
  • the module 100 may comprise the GNSS chipset 150 and calculate a PVT solution and/or the dead reckoning solution.
  • the module 100 may be configured to receive a data stream that provides the PVT solution and may not determine the dead reckoning solution (e.g., the module 100 receives PVT data from an off-board component, determines the calibration data 170b and sends the calibration data 170b to an off-board component to determine the dead reckoning solution).
  • the module 100 may be configured to receive a data stream that provides the PVT solution and be configured to calculate the dead reckoning solution.
  • the module 100 may be configured to supplement the PVT solution with the cooperative positioning solution determined based on the relative position 170d.
  • the module 100 may use an external processor (e.g., an off- board processor) to perform the calculations to determine the relative position data 170d.
  • the external processor may be implemented as a distributed computing service configured to scale and/or provision resources on demand (e.g., cloud computing).
  • the module 100 may receive the signals RAA-RNN and/or do range measurement, transmit the data to the cloud computing service and one or more processors of the cloud computing service may perform the calculations for generating the relative position data 170d.
  • the module 100 may receive the calculations (e.g., the relative position data 170d) from the cloud computing service and store the data in the memory 132.
  • the instructions 162 may be stored on an external memory.
  • the implementation of using the external components to supplement a capability of the module 100 may be varied according to the design criteria of a particular implementation.
  • the module 100 receives and/or determines a PVT solution, a dead reckoning solution and/or a cooperative positioning solution (e.g., CoP).
  • the module 100 may be configured to separate and/or extract the data component of the dead reckoning data 170e, the data component of the PVT solution (e.g., the location data) and/or the relative position data 170d.
  • the instructions 162 may be executed by the processor 124 to provide responses to requests from other components of the vehicle 30.
  • a brake system of the vehicle 30 e.g., one of the actuators 104a-104n
  • the sensors 102a-102n may be configured to capture information from the environment surrounding the vehicle 30.
  • the sensors 102a-102n may be vehicle sensors (e.g., speedometer, fluid sensors, temperature sensors, etc.).
  • data from the sensors 102a-102n may be used to determine the dead reckoning data 170e.
  • the sensors 102a-102n may be various types of sensors configured to determine vehicle movement (e.g., magnetometers, accelerometers, wheel click sensors, vehicle speed sensors, gyroscopes, etc.).
  • data from the sensors 102a-102n may be used to determine distances and/or directions traveled from a reference point.
  • the types of sensors 102a-102n implemented may be varied according to the design criteria of a particular implementation.
  • the actuators 104a-104n may be components of the vehicle 30 configured to cause an action, move and/or control an aspect of the vehicle 30.
  • the actuators 104a-104n may be one or more of a braking system, a steering system, a lighting system, windshield wipers, a heating/cooling system, etc.
  • the actuators 104a-104n may be configured to respond to information received from the module 100 and/or the sensors 102a-102n.
  • the steering system may receive information from the module 100 indicating that a collision with a nearby vehicle is likely and the steering system may respond by causing the vehicle 30 to change direction.
  • the types of actuators 104a-104n implemented may be varied according to the design criteria of a particular implementation.
  • the sensors 102a-102n and/or the actuators 104a-104n may be implemented to enable autonomous driving of the vehicle 30.
  • the sensors 102a- 102n may receive and/or capture input to provide information about the nearby environment.
  • the information captured by the sensors 102a-102n maybe used by components of the vehicle 30 and/or the module 100 to perform calculations and/or make decisions.
  • the calculations and/or decisions may determine what actions the vehicle 30 should take.
  • the actions that the vehicle 30 should take may be converted into signals readable by the actuators 104a-104n.
  • the actuators 104a-104n may cause the vehicle 30 to move and/or respond to the environment.
  • the module 100 may present an output that provides a relative position of the vehicle 30 to other vehicles.
  • the module 100 may provide the relative position data 170d (e.g., the cooperative positioning solution) to increase an ASIL classification of the vehicle 30.
  • Other components may be configured to use the data provided by the module 100 to make appropriate decisions for autonomous driving.
  • the modules 100a-100n may be configured to use round-trip time for estimating relative positions. Using round-trip time to estimate relative positions may result in a multitude of solutions (e.g., since there may be more unknowns than the number of equations). The modules 100a-100n may be configured to reliably and/or unambiguously obtain relative distances between objects (e.g., the objects 30a-30n) by means of round-trip time measurements.
  • the modules 100a-100n may be configured to perform a position estimation.
  • the modules 100a-100n may each comprise the transceiver 122 configured to send and/or receive the radio signals RAA-RNN.
  • the processor 124 of each of the modules 100a-100n may be configured to repeatedly perform a number of steps according to the instructions 162.
  • the processor 124 may execute one or more of the instructions 162 to calculate a time of flight (TOF) for the signals RAA-RNN.
  • the signals RAA-RNN may be sent pair-wise between two of the transceivers 122 (e.g., a transceiver 122 implemented by the module 100a and a transceiver 122 implemented by the module 100b).
  • the processor 124 may execute one or more of the instructions 162 to calculate possible positions for the modules 100a- 100 ⁇ , which may result in many possible positions for each of the modules 100a-100n.
  • the processor 124 may execute one or more of the instructions 162 to perform multi-dimensional scaling (MDS) calculations in order to obtain relative positions of the modules 100a-100n in a particular coordinate system.
  • MDS multi-dimensional scaling
  • the processor 124 may be configured to repeatedly perform a procrusting procedure (e.g., after two initial MDS calculations and between every two consecutive MDS calculations).
  • the procrusting procedure may comprise translation, scaling and/or rotation of the particular coordinate system to generate a corrected coordinate system.
  • the procrusting procedure may be configured to determine the corrected present coordinate system such that a smallest change for the relative positions of the modules 1 OOa-100 ⁇ (e.g., the relative position data 170d) between the consecutive MDS calculations may be obtained.
  • the processor 124 may be configured to calculate time of flight as the time for one of the signals RAA-RNN to travel from the transmitting transceiver (e.g., the transceiver 122 of the module 100a) to a receiving transceiver (e.g., the transceiver 122 of the module 100b).
  • the processor 124 may be configured to calculate time of flight as the time for one of the signals RAA-RNN to travel from a transmitting transceiver to a receiving transceiver and back to the transmitting transceiver (e.g., at least one time, such that round-trip time (RTT) may be determined for each pair of the modules 100a-100n).
  • the processor 124 maybe configured to calculate time of flight either with knowledge of a delay time between each re-transmission and/or by repeated transmissions that comprise time stamps generated by the different modules 100a-100n (e.g., to indicate when the signals RAA-RNN were received by each of the modules 100a-100n).
  • the method of determining the time of flight may be varied according to the design criteria of a particular implementation.
  • the signals RAA-RNN may be configured to be compatible with a mobile base system protocol.
  • the protocol implemented by the signals RAA-RNN may be a basic safety message (BSM) plus additional information.
  • BSM type messages may broadcast similar information.
  • the modules 100a-100n may be configured to send a small message outside of the standard BSM type message protocol.
  • the round-trip time and/or the time stamp 170c may be transmitted as part of the signals RAA-RNN but outside of the BSM message.
  • the signals RAA-RNN may be transmitted at a pre-determined update rate.
  • the update rate of the signals RAA-RNN may be 10Hz (e.g., 100ms).
  • the signals RAA-RNN may be transmitted as BSM signals via a standard service channel.
  • the signals RAA-RNN may be transmitted to a cluster head for the objects 30a-30n. If a target object is outside a range of the service channel, multihopping may be implemented (e.g., transmitting the signals RAA-RNN from a local cluster head to another cluster head and then to the target vehicle).
  • the protocol(s) implemented by the signals RAA-RNN may be varied according to the design criteria of a particular implementation.
  • FIG. 3 a diagram illustrating inter-vehicle range estimation is shown.
  • An example system 200 is shown.
  • the example system 200 may be implemented by four objects 30a-30d at an intersection of a road 202a and a road 202b.
  • Each of the objects 30a-30d may comprise a corresponding one of the modules lOOa-lOOd.
  • the objects 30a-30c may be vehicles and the object 30d may be infrastructure (e.g., a cell phone tower, a traffic sign, a traffic light, part of a building, etc.).
  • the transceiver 122a and the processor 124a are shown on the vehicle 30a.
  • the objects 30b-30d may comprise transceivers 122b-122d and/or processors 124b-124d.
  • the example system 200 comprises four of the modules 100a-100n. However, the number of the modules 100a-100n may be varied according to the design criteria of a particular implementation.
  • the modules lOOa-lOOd may communicate between at least two other of the modules 100a- 1 OOd.
  • the signal RAB is shown being transmitted between the vehicle 30a and the vehicle 30b
  • the signal RAC is shown being transmitted between the vehicle 30a and the vehicle 30c
  • the signal RAD is shown being transmitted between the vehicle 30a and the object 30d
  • the signal RBC is shown being transmitted between the vehicle 30b and the vehicle 30c
  • the signal RBD is shown being transmitted between the vehicle 30b and the object 30d
  • the signal RCD is shown being transmitted between the vehicle 30c and the object 30d.
  • the signals RAA-RNN may be transmitted simultaneously, in a particular order, in response to one of the signals RAA-RNN and/or periodically.
  • the signals RAA-RNN may be transmitted back and forth between each of the modules 100a- 100 ⁇ .
  • each of the modules 100a- 1 OOd may be configured to calculate the round-trip time for each of the signals RAB-RCD sent between each of the modules 100a- 1 OOd.
  • the module 100a may be configured to calculate the round-trip time for each of the signals RAB-RAD sent from the module 100a to the other modules 100b- 1 OOd, as well as the round- trip times for the signals RAB, RBC and/or RBD sent by the module 100b to the other modules 100a, 100c and/or lOOd, the signals RAC, RBC and/or RCD sent by the module 100c to the other modules 100a, 100b and/or 1 OOd and/or the signals RAD, RBD and/orRCD sent by the module lOOd to the other modules 100a- 100c.
  • each of the processing units 124a-124d may be configured to calculate possible positions for the modules 100a- 1 OOd (and the objects 30a-30d), which may result in multiple possible positions for each of the modules 100a- 1 OOd (e.g., since there are more unknowns than the number of equations).
  • the modules 100a- 1 OOd maybe configured to calculate a time of flight (TOF) (e.g., pair-wise) between two of the modules (e.g., lOOa-lOOb) among the modules 100a- 1 OOd, one or more times.
  • TOF time of flight
  • the processors 124a-124d may be configured to determine the time of travel of the signals RAB-RCD from a transmitting one of the modules 100a- 1 OOd to a receiving one of the modules 100a- 1 OOd (e.g. , a time of travel of the signal RAB from the transmitting module 100a to the receiving module 100b).
  • the modules lOOa-lOOd may have synchronized clocks (e.g., the clocks 130 may be synchronized).
  • the processors 124a- 124d may be configured to determine the round-trip time of travel of the signals RAB-RCD from a transmitting one of the modules lOOa-lOOd to a receiving one of the modules 100a- 1 OOd and back to the transmitting one of the modules 100a- 1 OOd (e.g., a time of travel of the signal RBC from the transmitting module 100b to the receiving module 100c and back to the transmitting module 100b from the receiving module 100c, possibly including a delay time).
  • the clocks 130 may not need to be synchronized, but the delay 170c may be known. If the delay time 170c is not known, repeated transmissions maybe implemented (e.g., with 5 time stamps at the different modules 100a- lOOd).
  • Each of the processors 124a-124d may determine the possible positions for the modules lOOa-lOOd.
  • the processors 124a-124d may be configured to perform a multi-dimensional scaling (MDS) operation.
  • the MDS operation may be implemented to calculate relative positions of the modules lOOa-lOOd in a coordinate system.
  • the processors 124a-124d may be configured to perform another MDS operation (e.g., at a later time).
  • the MDS operation may be implemented to calculate another set of relative positions of the modules lOOa-lOOd in another coordinate system. For example, a first MDS operation may determine relative positions in a first coordinate system and a second MDS operation may determine relative positions in a second coordinate system.
  • Each of the processors 124a-124d may be configured to perform a procrusting procedure.
  • the procrusting procedure may comprise one or more of translation operations, scaling operations and/or rotation operations of one of the coordinate systems used by the MDS operations.
  • the procrusting procedure may be configured to generate a corrected coordinate system.
  • the corrected coordinate system may be implemented to determine a smallest change for the relative positions of the modules lOOa-lOOd between the first MDS operation and the second MDS operation.
  • the modules 100a- lOOd may be configured to continually perform MDS operations. For each of the following MDS operations, the procrusting procedure may be performed to generate an updated (e.g., current) corrected coordinate system.
  • the processors 124a-124d may be configured to continually and/or repeatedly calculate a TOF and/or RTT for the signals RAB-RCD sent between the modules lOOa-lOOd, calculate possible positions for the modules 100a- 1 OOd (e.g., which may result in numerous possible positions for each of the modules lOOa-lOOd), and/or perform MDS operations in order to obtain relative positions of the modules 100a- 1 OOd in a coordinate system.
  • the processors 124a-124d may be configured to repeatedly perform a procrusting procedure between MDS calculations. In one example, the procrusting procedure may be performed between every two consecutive MDS calculations.
  • the procrusting procedures may generate the corrected coordinate system (e.g., corresponding to the current location of the vehicles 30a-30d).
  • the procrusting procedure may be performed using a Maximum Likelihood Estimation (MLE) computation.
  • the procrusting procedure may be performed using a Least Squares Estimation (LSE) computation.
  • vehicle dynamics comprising gyro data, acceleration data and/or velocity data (e.g., data from the sensors 102a-102n, the dead reckoning data 170d and/or the position coordinates 170a) may be used by the processors 124a-124d (e.g., to enhance the accuracy of the calculated solution).
  • the modules lOOa-lOOd may be connected to a warning and/or information device (e.g., a heads up display, an infotainment unit, an audio system, etc.) implemented in a corresponding one of the objects 30a-30d.
  • the warning and/or information device may be configured to send a notification and/or alert to the driver of a vehicle based on the cooperative positioning data calculated by the modules lOOa-lOOd (e.g., a warning if a collision is likely).
  • the modules 100a- 1 OOd may be configured to communicate (e.g., via the electronic bus 106) to other vehicle environment detection devices (e.g., the sensors 102a-102n).
  • the sensors 102a- 102n may comprise devices (e.g., radar devices, camera devices, LIDAR devices, etc.) configured to determine a position of one of the objects 30a-30d.
  • the objects 30a-30d may not each implement one of the modules 100a- 1 OOd.
  • the vehicle 30a may implement the module 100a- 1 OOd and the objects 30b-30d may implement the transceivers 122b-122d.
  • Implementing the transceivers 122b- 122d without the modules 122b-122d may enable the objects 30b-30d to communicate the signals RAB-RCD but the calculations for the cooperative positioning solution may be performed by the module 100a.
  • the module 100a may determine the cooperative position solution from the signals RAB-RCD and send the data to each of the transceivers 122b-122d to provide the cooperative position solution to the other objects 30b-30d.
  • the processors 124a-124d may be configured to repeatedly perform at least five procrusting procedures with intermediate MDS calculations. In some embodiments, the processors 124a-124d may be configured to calculate time of flight either with knowledge of a delay time between each re-transmission and/or by repeated transmissions with time stamps at the different transceivers.
  • the MDS operations may be performed.
  • the output generated in response to the MDS operations may present a true relative position between the objects 30a-30d.
  • the procrusting procedure may be configured to rotate (e.g., rotating an X-Y diagram) the relative positioning (e.g., mirrored and/or translated) to provide additional compensation.
  • the additional compensation performed by the procrusting procedure may provide a correct relative positioning (e.g., the relative position data 170d).
  • four objects are shown transmitting the signals RAB-RCD.
  • the number of signals and/or obj ects may be varied according to the design criteria of a particular implementation. Increasing the number of objects (e.g., 30a-30n) may improve an accuracy of the cooperative positioning solution calculated at the cost of computational efficiency. Decreasing the number of objects (e.g., less than four of the objects 30a-30d) may decrease a computational cost but may not provide sufficient accuracy (e.g., the accuracy of the cooperative positioning solution may not be an improvement over a GNSS solution).
  • determining a cooperative positioning solution using four of the objects 30a-30n may provide a balanced tradeoff between an accuracy of the relative positioning coordinates 170d and the computational processing power of the processor 124. For example, using more than four of the objects 30a-30n may provide diminishing returns on the accuracy of the relative positioning coordinates 170d.
  • the modules lOOa-lOOd may be configured to predict a trajectory (e.g., path) of the objects 30a-30d.
  • the modules lOOa-lOOd may calculate and/or receive an associated location and/or velocity (e.g., a low accuracy position, speed and/or heading) for each of the objects 30a-30d.
  • the predicted trajectory may be calculated using the GPS heading and/or GPS speed information.
  • the predicted trajectory may be calculated using the time of flight and/or round-trip time information.
  • the predicted trajectory may be calculated based on the shape and/or path of the roads 202a-202b.
  • one or more of the objects 30a-30d may not have a predicted trajectory and/or have a null value for the predicted trajectory (e.g., the obj ect 30d may be stationary).
  • the predicted trajectory maybe communicated to/from the modules lOOa-lOOd as data messages using the signals RAB-RCD and/or stored in the memory 132.
  • FIG. 4 a diagram illustrating a selection criteria for an example traffic scenario 300 is shown.
  • a road 302a and a road 302b are shown.
  • the roads 302a-302b may meet at an intersection 304.
  • the vehicles 30a-30i may be driving on the roads 302a-302b.
  • the apparatus 100a may be implemented in (or on) the vehicle 30a (e.g., the hose vehicle).
  • the other vehicles 30b-30i may implement one of the modules (e.g., lOOb-lOOi).
  • the number of vehicles in a vicinity when determining the selection criteria may be varied according to the design criteria of a particular implementation.
  • the apparatus 100a may be configured to select information from remote vehicles to use for the cooperative positioning calculations (e.g., CoP). To improve computational efficiency and/or reduce uncertainty to an acceptable level (e.g., a level allowable according to various autonomous driving standards), the apparatus 100a may be configured to determine which of the vehicles 30a-30i that may provide the most useful information in order to achieve a minimum amount of uncertainty (e.g., reduce uncertainty as much as possible using the available data). The apparatus 100a may be configured to implement a selection criteria to determine which of the vehicles provide the most useful information for efficiently determining a solution. In one example, the selection criteria may be implemented as part of the instructions 162. In another example, the selection criteria may be implemented as part of the relative positioning module 152. In yet another example, the selection criteria may be implemented as a firmware component of the processor 124. The selection criteria may be varied according to the design criteria of a particular implementation.
  • CoP cooperative positioning calculations
  • the selection criteria implemented by the module 100a may determine which combinations of information may provide a low computational cost (e.g., efficient calculations in terms of processing power and/or an amount of time to determine a solution) and a low amount of uncertainty of the relative positioning solution.
  • the selection criteria may select some of the information from the vehicles 30a-30i to achieve a balance between a computation time, an amount of power usage and an accuracy of the relative positioning solution.
  • the selection criteria may select four of the vehicles 30a-30i. Selecting four of the vehicles 30a-30i may be sufficient to achieve the balance between a computation time, an amount of power usage and/or an accuracy of the relative positioning solution. For example, selecting more than four of the vehicles 30a-30i may provide diminishing returns on an improvement (e.g., accuracy) of the relative positioning solution, while increasing power usage and/or computation time. To achieve an acceptable level of accuracy (e.g., approximately less than +/- 1 meter) the selection criteria may select (e.g., select four) from the nearby vehicles 30a-30i based on a distance, an arrangement (e.g., orientation) between the vehicles 30a-30i and/or a speed (or velocity) of the vehicles 30a-30i.
  • an arrangement e.g., orientation
  • the apparatus 100a may be configured to group and/or track the vehicles 30a-3 On and select from the vehicles 30a-30i (e.g., select four vehicles) that may provide the best/optimal output (e.g., by considering the balance between computation time, computation cost, amount of uncertainty of the solution and/or the information available) for the cooperative positioning solution.
  • the relative positioning module 152 may group and/or track the vehicles 30a-30i based on a low accuracy positions (e.g., GNSS solutions).
  • the signals RAA-RNN may comprise the low accuracy positions of the vehicles 30a-30i.
  • each vehicle of the vehicles 30a-30i may implement one of the modules lOOa-lOOi and calculate the GNSS solution (e.g., the position coordinates 170a) based on the signals GA-GN and communicate the GNSS solution using the signals RAA-RNN.
  • the information in the signals RAA-RNN may be used to calculate time of flight information and/or round-trip time information.
  • the implementation of the communication and/or the calculation of the low accuracy positions may be varied according to the design criteria of a particular implementation.
  • the GNSS solution may have a low accuracy in terms of positioning compared to the cooperative positioning solution.
  • the GPS heading and/or speed information may be accurate.
  • the selection criteria may use the GPS heading and/or GPS speed information to identify which of the vehicles 30a-30i to select to perform the cooperative positioning calculations.
  • the selection criteria analysis performed by the relative positioning module 152 may determine which of the vehicles may intercept the predicted travel path of the host vehicle 30a.
  • At least one of the vehicles 30b-30i may be considered a target vehicle (e.g., a vehicle likely to cross the predicted path of the host vehicle 30a within a particular amount of time).
  • the vehicle considered to be the target vehicle may be likely to collide with the host vehicle 30a (e.g., based on the low accuracy solution).
  • the target vehicle may be one of the vehicles 30b-30n that crosses the predicted travel path of the host vehicle 30a within 10 seconds.
  • the target vehicle and the host vehicle 30a may converge at the same location within a pre- determined amount of time.
  • the selection criteria may select the target vehicle as one of the vehicles from which to receive information in order to determine the cooperative positioning solution.
  • the selection criteria analysis performed by the relative positioning module 152 may select at least two other of the vehicles 30b-30i (e.g., the complementary vehicles) to receive information from to use for the cooperative positioning solution.
  • the selection criterial may be used to determine the complementary vehicle based on a distance and/or relative speed compared to the host vehicle 30a.
  • the selection criteria may define a selection for the host vehicle 30a, the target vehicle and the vehicles that are furthest away and have the highest relative speed (e.g., complementary vehicles).
  • the selection criteria analysis may select the data messages from the vehicles 3 Oa-3 On to provide information for the relative positioning module 152 to perform the cooperative positioning calculations.
  • the cooperative positioning calculations may generate the relative position data 170d that may have a higher precision than the position coordinates 170a (e.g., low accuracy results) determined using GNSS data.
  • the remaining vehicles e.g., the vehicles 30b-30i
  • each of the vehicles 30a-30i may have an associated location and/or velocity 310a-3 lOi (e.g., low accuracy position, speed and/or heading).
  • the velocity information 310a-31 Oi may be calculated using the GPS heading and/or GPS speed information.
  • the velocity information 310a-3 lOi may be calculated using the time of flight and/or round-trip time information.
  • the velocity information 310a-31 Oi may be communicated to/from the modules lOOa-lOOi as data messages using the signals RAA-RNN.
  • the vehicle 30a may have the velocity 310a of 50mph heading north
  • the vehicle 30b may have the velocity 310b of lmph heading south
  • the vehicle 30c may have the velocity 310c of Omph heading south (not shown)
  • the vehicle 30d may have the velocity 3 lOd of 60mph heading north
  • the vehicle 30e may have the velocity 3 lOe of 30mph heading east
  • the vehicle 3 Of may have the velocity 31 Of of 50mph heading east
  • the vehicle 30g may have the velocity 31 Og of 40mph heading east
  • the vehicle 3 Oh may have the velocity 31 Oh of 5mph heading west
  • the vehicle 30i may have the velocity 3 lOi of 35mph heading east.
  • the selection criteria implemented by the module 100a may select from the vehicles 30a-30i based on the velocity information 310a-3 lOi and/or the arrangement and distance with respect to the host vehicle 30a.
  • the dotted shapes 320a-320d may represent the selected vehicles determined by the selection criteria analysis implemented by the module 100a.
  • the selected vehicles 320a-320d may comprise four vehicles (e.g., the vehicle 30a, the vehicle 30d, the vehicle 30f and the vehicle 30i).
  • the selected vehicle 320a may be the host vehicle 30a (e.g., the module 100a may be implementing the selection criteria).
  • the selected vehicle 320b may be the target vehicle 30f.
  • the selected vehicle 320c may be the vehicle 30d and the selected vehicle 320d may be the vehicle 30i (e.g., the complementary vehicles).
  • the vehicle 30f maybe selected as the targetvehicle (e.g., the selected vehicle 320b).
  • the analysis performed by the selection criteria may determine that the vehicle 30f may be the most likely of the vehicles 30b-30i to cross the predicted path of the host vehicle 30a. In the example shown, the vehicle 30a and the vehicle 3 Of may cross the intersection 304 at approximately the same time from the road 302a and the road 302b, respectively (e.g., both vehicles are approximately the same distance from the intersection 304 and traveling at the same speed).
  • the analysis by the selection criteria may determine that the vehicles 30g and 30i may not cross the predicted paths with the vehicle 30a (e.g., traveling away from the intersection 304 on the road 302b).
  • the analysis by the selection criteria may determine that the vehicle 30e may not cross predicted paths with the vehicle 30a (e.g., the vehicle 30e is farther away from the intersection 304 and traveling behind and slower than the vehicle 3 Of).
  • the analysis by the selection criteria may determine that the vehicle 30d may not cross predicted paths with the vehicle 30a (e.g., the vehicle 30d is traveling away from the intersection 304 on the road 302a and is traveling faster to the north than the vehicle 30a).
  • the analysis by the selection criteria may determine that the vehicles 30b and 30c may not cross predicted paths with the vehicle 30a (e.g., both are nearly stopped at the intersection 304).
  • the analysis by the selection criteria may not be able to determine that the vehicles 30b and 30c are in the opposite lane (e.g., the low accuracy position results may not provide sufficient evidence that the vehicles are in different lanes).
  • the selection criteria may determine that the vehicles 30b and 30c may not cross predicted paths with the vehicle 30a on the basis of traveling in opposite lanes.
  • the analysis by the selection criteria may determine that the vehicle 3 Oh may be a candidate for the target vehicle.
  • the vehicle 30h is approaching the intersection 304 at a low speed (e.g., 5mph), is farther away from the vehicle 30a than the distance between the vehicle 30f and the vehicle 30a, and may be slowing down to stop before entering the intersection 304 (e.g., the vehicle 30f may be a better candidate for the target vehicle than the vehicle 30h).
  • the selection criteria implemented by the relative positioning module 152 may determine that the target vehicle 320b may be the vehicle 30f.
  • the relative positioning module 152 may select the complementary selected vehicles 320c-320d.
  • the complementary selected vehicles 320c-320d may be selected with respect to the selected vehicles 320a-320b.
  • the selection criteria may prefer the complementary selected vehicles 320c-320d to be furthest away and/or at approximately 90 degrees to the two selected vehicles 320a-320b (e.g., to form four corners of a rectangular shape with each corner having a sufficient distance from each other).
  • the selection criteria may prefer vehicles that are traveling at a higher speed and at least at a speed of approximately 7mph (e.g., 3 meters per second).
  • the relative positioning module 152 may select the vehicle 30d as the selected vehicle 320c and the vehicle 30i as the selected vehicle 320d.
  • the vehicles 30d and 30i may be the complementary selected vehicles 320c-320d based on the distance and/or speed relative to the selected vehicles 320a-320b.
  • the analysis by the selection criteria may determine that the vehicle 30e is far from the selected vehicle 320a but close to the selected vehicle 320b.
  • the analysis by the selection criteria may determine that the vehicle 30c is not moving (e.g., an elimination factor).
  • the analysis by the selection criteria may determine that the vehicle 30g is close to both the selected vehicles 320a-320b (e.g., an elimination factor).
  • the analysis by the selection criteria may determine that the vehicle 30b and the vehicle 30d are both far from the selected vehicles 320a-320b.
  • the velocity information 310b indicates the vehicle 30b is traveling at lmph (e.g., an elimination factor) and the velocity information 3 lOd indicates the vehicle 30d is traveling at 60mph (e.g., the vehicle 30d may be a better candidate).
  • the analysis by the selection criteria may select the vehicle 30d as the selected vehicle 320c.
  • the analysis by the selection criteria may determine that the vehicle 30h and the vehicle 30i are both far from the selected vehicles 320a-320c. Furthermore, the vehicle 30h and the vehicle 30i both make approximately a 90 degree angle with the selected vehicles 320a-320c. However, the velocity information 3 lOh indicates the vehicle 30h is traveling at 5mph and the velocity information 3 lOi indicates the vehicle 30i is traveling at 35mph.
  • the selection criteria may determine that the vehicle 30i may be a better candidate since the vehicle 30h may be traveling below a minimum speed threshold (e.g., below 7mph may be an elimination factor).
  • the analysis by the selection criteria may select the vehicle 30i as the selected vehicle 320d.
  • the selection criteria implemented by the relative positioning module 152 may select the vehicles 30a, 30f, 30d and 30i as the selected vehicles 320a-320d.
  • Four of the vehicles 30a-30i may be used for the selected vehicles 320a-320d to provide a solution with sufficient accuracy while balancing computation time and/or computation power.
  • the selected vehicles 320a-320d may provide the efficient combination of nearby vehicles to generate the cooperative positioning solution.
  • FIG. 5 a diagram illustrating a selection criteria for an example traffic scenario 350 is shown.
  • the road 302a, the road 302b and the intersection 304 are shown.
  • the vehicles 30a-30i may be driving on the roads 302a-302b.
  • the apparatus 100a may be implemented in (or on) the vehicle 30a.
  • the other vehicles 30b-30i may implement one of the modules (e.g., lOOb-lOOi).
  • the example traffic scenario 350 may be similar to the example traffic scenario 300 (described in association with FIG. 4) with some alterations.
  • each of the vehicles 30a-30i may have an associated velocity 310a'-310i' (e.g., speed and/or heading).
  • the vehicle 30a may have the velocity 310a' of 50mph heading north
  • the vehicle 30b may have the velocity 310b' of lmph heading south
  • the vehicle 30c may have the velocity 310c' of 50mph heading south
  • the vehicle 30d may have the velocity 310d' of 15mph heading north
  • the vehicle 30e may have the velocity 310e' of 60mph heading east
  • the vehicle 3 Of may have the velocity 31 Of of 5mph heading east
  • the vehicle 30g may have the velocity 310g' of 40mph heading east
  • the vehicle 3 Oh may have the velocity 31 Oh' of45mph heading west
  • the vehicle 3 Oi may have the velocity 310i' of35mph heading east.
  • the selection criteria implemented by the module 100a may select from the vehicles 30a-30i based on the velocity information 310a'-310i' and/or the arrangement and distance with respect to the host vehicle 30a
  • the selected vehicles 320a' -320d' may comprise four vehicles (e.g., the vehicle 30a, the vehicle 30c, the vehicle 30e and the vehicle 30h).
  • the selected vehicle 320a' may be the host vehicle 30a (e.g., the module 100a may be implementing the selection criteria).
  • the selected vehicle 320b' may be the target vehicle 30h.
  • the selected vehicle 320c' may be the vehicle 30c and the selected vehicle 320d' may be the vehicle 30e.
  • the vehicle 30h may be selected as the target vehicle (e.g., the selected vehicle 320b').
  • the analysis performed using the selection criteria may determine that the vehicle 30h may be the most likely of the vehicles 30b-30i to cross the predicted path of the host vehicle 30a.
  • the vehicle 30a and the vehicle 3 Oh may cross the intersection 304 at approximately the same time from the road 302a and the road 302b, respectively (e.g., both vehicles are approximately similar distances from the intersection 304 and traveling at similar speeds).
  • the analysis by the selection criteria may determine that the vehicles 30g and 30i may not cross the predicted paths with the vehicle 30a (e.g., traveling away from the intersection 304 on the road 302b).
  • the analysis by the selection criteria may determine that the vehicle 30e may not cross the predicted paths with the vehicle 30a (e.g., the vehicle 30e is farther away from the intersection 304 and traveling behind the vehicle 30f). In some embodiments, the analysis by the selection criteria may determine that the vehicle 30d may not cross the predicted paths with the vehicle 30a (e.g., the vehicle 30d is traveling away from the intersection 304 on the road 302a and is traveling the same direction as the vehicle 30a).
  • the analysis by the selection criteria may determine that the vehicle 30d may cross the predicted paths with the vehicle 30a (e.g., the vehicle 30d is traveling away from the intersection 304 on the road 302a and in the same direction of the vehicle 30a but at a slower speed, which could result in the vehicle 30a colliding with the vehicle 30d from behind). Whether the analysis by the selection criteria determines that the vehicle 30d may collide with the vehicle 30a may depend on the particular amount of time of the time frame for determining the target vehicle 30b. For example, the vehicle 30d may be a candidate for the target vehicle.
  • the analysis by the selection criteria may determine that the vehicle 30b and the vehicle 30c may not cross predicted paths with the vehicle 30a (e.g., both are in the opposite lane). In some embodiments, the analysis by the selection criteria may not be able to determine that the vehicles 30b and 30c are in the opposite lane (e.g., the low accuracy position results may not provide sufficient evidence that the vehicles are in different lanes). If there is sufficient accuracy from the low accuracy result to determine the vehicles 30b and/or 30c are in an opposite lane to the host vehicle 30a, then the selection criteria may determine that the vehicles 30b and 30c may not cross predicted paths with the vehicle 30a on the basis of traveling in opposite lanes. Since the vehicle 30c may collide with the vehicle 30a and the velocity 310c' is relatively high, the vehicle 30c may be a candidate for the target vehicle.
  • the analysis by the selection criteria may determine that the vehicle 30f may be a candidate for the target vehicle. However, the vehicle 30f is approaching the intersection 304 at a low speed (e.g., 5mph, which is below the selection threshold), and may be slowing down to stop before entering the intersection 304 (e.g., the vehicle 30h may be a better candidate for the target vehicle than the vehicle 30f). The vehicle 30f may be eliminated from candidacy based on having a speed below the threshold speed. By analyzing the velocity information 310a' -310i' and/or the position of the vehicles 30a-30i, the selection criteria implemented by the relative positioning module 152 may determine that the target vehicle 320b' may be the vehicle 30h.
  • a low speed e.g., 5mph, which is below the selection threshold
  • the vehicle 30f may be eliminated from candidacy based on having a speed below the threshold speed.
  • the relative positioning module 152 may select the two complementary vehicles 320c'-320d'.
  • the complementary selected vehicles 320c'-320d' may be selected with respect to the selected vehicles 320a'-320b'.
  • the selection criteria may prefer the two complementary vehicles 320c'-320d' to be furthest away and/or at approximately 90 degrees with respect to the two selected vehicles 320a'-320b' (e.g., the host vehicle 320a', the target vehicle 320b', and the two complementary vehicles 320c'-320d' may approximate four corners of a rectangular shape and the four corners may have a sufficient distance from each other).
  • the selection criteria may prefer vehicles that are traveling at least at a speed of approximately 7mph (e.g., 3 meters per second).
  • the relative positioning module 152 may select the vehicle 30c as the complementary vehicle 320c' and the vehicle 30e as the selected vehicle 320d' .
  • the vehicles 30c and 30e maybe the complementary vehicles 320c'-320d' based on the distance and/or speed relative to the selected vehicles 320a' -320b' .
  • the analysis by the selection criteria may determine that the vehicle 30i is far from the selected vehicle 320a' but close to the selected vehicle 320b'.
  • the analysis by the selection criteria may determine that the velocity information 3 lOf (e.g., 5mph) of vehicle 30f is below the speed threshold (e.g., an elimination factor).
  • the analysis by the selection criteria may determine that the vehicle 30g is close to both the selected vehicles 320a' -320b' .
  • the analysis by the selection criteria may determine that the vehicle 30b, the vehicle 30c, and the vehicle 30d are each far from the selected vehicles 320a' -320b ' .
  • the velocity information 310b' indicates the vehicle 30b is traveling at lmph and the velocity information 310d' indicates the vehicle 30d is traveling at 15mph (e.g., the vehicle 30d may be a better candidate).
  • the analysis by the selection criteria may select the vehicle 30c as the selected vehicle 320c' because the velocity information 310c' indicates the vehicle 30c is traveling at 50mph and the velocity information 310d' indicates the vehicle 30d is traveling at 15mph (e.g., the vehicle 30c may be a better candidate, even though the vehicle 30d is farther away from the selected vehicles 320a' -320b').
  • the analysis by the selection criteria may determine that the vehicle 30e and the vehicle 3 Of are both far from the selected vehicles 320a'-320c' . Furthermore, the vehicle 30e and the vehicle 3 Of both make approximately a 90 degree angle with the selected vehicles 320a'-320c'. However, the velocity information 3 lOf indicates the vehicle 30f is traveling at 5mph and the velocity information 310e' indicates the vehicle 30e is traveling at 60mph.
  • the selection criteria may determine that the vehicle 30e may be a better candidate since the vehicle 30f may be traveling below a minimum speed threshold (e.g., below 7mph) and the vehicle 30e is farther away from the selected vehicles 320a'- 320c' than the vehicle 30f.
  • the analysis by the selection criteria may select the vehicle 30e as the complementary vehicle 320d' .
  • the example traffic scenario 350 and the example traffic scenario 300 (shown in association with FIG. 4) describe a 4-way intersection on level terrain.
  • the selection criteria implemented by the relative positioning module 152 may be configured to select from the vehicles 30a-30i for the efficient cooperative positioning solution regardless of the road types and/or a shape of the terrain.
  • a layout of the roads that the vehicles 30a-30i drive on may not hinder determining the efficient vehicles for calculations since the selection criteria may analyze relative speed and/or relative distance.
  • the layout of the roads may be relevant to the selection criteria to determine which of the vehicles 30a-30i may be the target vehicle (e.g., the path of the roads may indicate which vehicles may be on paths that may meet).
  • the selection criteria may take the path and/or direction of the roads when selecting the target vehicle.
  • an altitude may also be used to determine a likelihood of a collision.
  • Altitude may be used by the selection criteria as an elimination factor for determining the target vehicle when altitude is indicative of vehicles not colliding (e.g., in an overpass scenario).
  • the ranging implemented by the module 100a and/or the relative positioning module 152 may determine an absolute distance between the host vehicle 30a and/or the other vehicles 30b-30i. For example, an absolute distance may take altitude into account.
  • the selection criteria may implement a restriction on selecting a particular vehicle if the height distance is above a pre-determined threshold.
  • the selection criteria may be configured to analyze as many factors as are available (e.g., vehicle speed, vehicle distance, vehicle altitude, road layout, road conditions, traffic conditions, construction detours, weather conditions, etc.) to determine the target vehicle and/or the complementary vehicles used for determining the cooperative positioning solution.
  • factors e.g., vehicle speed, vehicle distance, vehicle altitude, road layout, road conditions, traffic conditions, construction detours, weather conditions, etc.
  • FIG. 6 a diagram illustrating a selection criteria for an example traffic scenario 400 is shown.
  • the road 302a, the road 302b and the intersection 304 are shown.
  • the vehicles 30a-30i may be driving on the roads 302a-302b.
  • the apparatus 100a may be implemented in (or on) the vehicle 30a.
  • the other vehicles 30b-30i may implement one of the modules (e.g., lOOb-lOOi).
  • the example traffic scenario 400 may have an arrangement similar to the example traffic scenario 300 (described in association with FIG. 4) with some alterations.
  • the vehicle 30a may have the velocity 310a" of 50mph heading north
  • the vehicle 30b may have the velocity 310b" of lmph heading south
  • the vehicle 30c may have the velocity 310c" of Omph heading south (not shown)
  • the vehicle 30d may have the velocity 310d" of 60mph heading north
  • the vehicle 30e may have the velocity 310e" of 30mph heading east
  • the vehicle 3 Of may have the velocity 3 lOf ' of 35mph heading east
  • the vehicle 30g may have the velocity 3 lOg" of 40mph heading east
  • the vehicle 3 Oh may have the velocity 3 lOh" of 35mph heading west
  • the vehicle 30i may have the velocity 3 lOi" of 70mph heading east.
  • the selection criteria implemented by the module 100a may select from the vehicles 30a-30i based on the velocity information 310a"-310i" and/or the arrangement and distance with respect to the host vehicle 30a.
  • the velocity information 310a" -3 lOi" may be similar to the velocity information 310a-3 lOi shown in the example traffic scenario 300 (described in association with FIG. 4).
  • the vehicles 30a, 30b, 30c, 30d, 30e and 30g have the same velocity (e.g., the velocity information 310a", 310b", 310c", 31 Od", 31 Oe" and 31 Og" are the same as the corresponding velocity information 310a, 310b, 310c, 3 lOd, 3 lOe and 3 lOg).
  • the velocity information 3 lOf ' has changed to 35mph (from the velocity information 31 Of of 50mph) the velocity information 31 Oh” has changed to 35mph (from the velocity information 31 Oh of 5mph) and the velocity information 310i" has changed to 70mph (from the velocity information 31 Oi of 35mph).
  • the selected vehicles 320a"-320d' ' may comprise four vehicles (e.g., the vehicle 30a, the vehicle 30d, the vehicle 30f and the vehicle 30h).
  • the selected vehicle 320a' ' may be the host vehicle 30a (e.g., the module 100a may be implementing the selection criteria).
  • the selected vehicle 320b" may be the target vehicle 30f.
  • the selected vehicle 320c" may be the vehicle 30d and the selected vehicle 320d" may be the vehicle 30h.
  • the complementary vehicle 320d' ' has changed to the vehicle 30h (from the complementary vehicle 320d of 30i in the traffic scenario 300) despite the vehicle 30i being farther away and traveling faster than the vehicle 3 Oh.
  • the vehicle 30f may be selected as the target vehicle (e.g., the selected vehicle
  • the selection criteria analysis performed by the relative positioning module 152 may determine that the vehicle 3 Of may be the most likely of the vehicles 30b-30i to cross the predicted path of the host vehicle 30a. In the example shown, the vehicle 30a and the vehicle 3 Of may cross the intersection 304 at approximately the same time from the road 302a and the road 302b, respectively (e.g., both vehicles are approximately the same distance from the intersection 304 and converging towards the same position).
  • the selection criteria analysis performed by the relative positioning module 152 may determine that the vehicle 30h may also be a candidate for the target vehicle.
  • the vehicle 30h may be approaching the intersection 304 at the same speed (e.g., 35mph) as the vehicle 30f, but is slightly farther away from the vehicle 30a than the distance between the vehicle 3 Of and the vehicle 30a.
  • the vehicle 30f may be a good candidate for the target vehicle 320b" and the vehicle 30h may also be a good candidate for the target vehicle 320b" .
  • the selection criteria may identify the vehicle 3 Of as a better candidate than the vehicle 3 Oh.
  • the selection criteria may determine that the vehicle 30f is a most likely target and select the vehicle 30f as the selected vehicle 320b".
  • the relative positioning module 152 may select the complementary vehicles 320c" -320d" . Similar to the analysis performed by the relative positioning module 152 for the traffic scenario 300 (described in association with FIG. 4), the vehicle 30d may be selected as one of the complementary vehicles (e.g., 320c"). However, in the example traffic scenario 400, the vehicle 30h may be selected as one of the complementary vehicles 320d" (as opposed to the vehicle 30i in the traffic scenario 300).
  • the selection criteria analysis by the relative positioning module 152 may determine that the vehicle 30h and the vehicle 30i are both sufficiently far from the selected vehicles 320a"-320c" . Furthermore, the vehicle 3 Oh and the vehicle 30i both make approximately a 90 degree angle with the selected vehicles 320a"-320c" .
  • the velocity information 310h” indicates the vehicle 30h is traveling at 35mph and the velocity information 3 lOi" indicates the vehicle 30i is traveling at 70mph.
  • the selection criteria may determine that the vehicle 3 Oh may be a better candidate for the complementary selected vehicle 320d" .
  • the vehicle 30i may be a good candidate because the speed and/or distance parameters of the vehicle 30i may be better (e.g., farther away and faster) compared to the speed and/or distance of the vehicle 30h.
  • the selection criteria may prefer the vehicle 30h because the vehicle 3 Oh may have been determined as a potential candidate for the target vehicle.
  • the vehicle 30h may not be the best candidate based on speed and/or distance, but the vehicle 3 Oh may fit the selection criteria because the vehicle 3 Oh may be a candidate for the target vehicle.
  • the relative positioning module 152 may select the vehicle 30h as the complementary vehicle 320d" .
  • the lines 402a-402d may represent an arrangement (e.g., orientation) of the selected vehicles 320a"-320d' ' .
  • the line 402a may be between the selected vehicle 320a" (e.g., the vehicle 30a) and the selected vehicle 320b" (e.g., the vehicle 30f).
  • the line 402b may be between the selected vehicle 320a" (e.g., the vehicle 30a) and the selected vehicle 320d" (e.g., the vehicle 30h).
  • the line 402c may be between the selected vehicle 320d" (e.g., the vehicle 30h) and the selected vehicle 320c' ' (e.g., the vehicle 30d).
  • the line 402d may be between the selected vehicle 320c" (e.g., the vehicle 30d) and the selected vehicle 320b" (e.g., the vehicle 30f).
  • the lines 402a-402d form a generally rectangular shape.
  • the selected vehicles 320a"-320d" may be located at approximately the four corners of the rectangular shape.
  • the host vehicle 320a' ' and the target vehicle 320b" may form approximately a 90 degree angle with the complementary vehicle 320c" (e.g., the lines 402a and 402d).
  • the host vehicle 320a" and the target vehicle 320b" may form approximately a 90 degree angle with the complementary vehicle 320d" (e.g., the lines 402a and 402b).
  • the arrangement of the selected vehicles 320a" -320d" may be a rectangular shape with each of the selected vehicles 320a"-320d' ' at different corners.
  • the host vehicle 320a", the target vehicle 320b", and the two complementary vehicles 320c"-320d' ' may approximate four corners of a rectangular shape (e.g., the lines 402a-402d) and the four corners (e.g., the selected vehicles 320a"-320d") may have a sufficient distance from each other.
  • the sufficient distance may be a relative distance between 5m and 100m.
  • the vehicles 30a-30i may be tracked from 45m-75m (e.g., depending on the speed of the host vehicle 320a' ' and/or the time that the vehicles may cross paths).
  • a maximum radio range may be 100m in a non-line of sight scenario. The amount for the sufficient distance may be varied according to the design criteria of a particular implementation and/or communication protocols and/or technology implemented.
  • the arrangement of the vehicles 30a-30i may be used as part of the selection criteria for determining the selected vehicles 320a"-320d' ' .
  • Vehicles that form the rectangular arrangements 402a-402d may be better (e.g., preferred) candidates for the selected vehicles 320a"-320d" (e.g., a rectangular arrangement may result in a more efficient calculation of the cooperative positioning solution).
  • the method 500 may determine an efficient cooperative positioning solution.
  • the method 500 generally comprises a step (or state) 502, a step (or state) 504, a step (or state) 506, a step (or state) 508, a decision step (or state) 510, a decision step (or state) 512, a step (or state) 514, and a step (or state) 516.
  • the state 502 may start the method 500.
  • the transceiver 122 may receive data (e.g., the signals RAA-RNN) from the nearby vehicles 30a-30n.
  • the processor 124 e.g., the relative positioning module 152
  • the processor 124 may determine the speeds, trajectories and/or arrangement of the nearby vehicles 30a-30n using the low accuracy data (e.g., the position coordinates 170a).
  • the low accuracy data may be one component of the signals RAA- RNN.
  • the relative positioning module 152 may determine the velocity information 310a-3 lOi (e.g., shown in association with FIG. 4).
  • the processor 124 may compare the data (e.g., the velocity information 310a-3 lOi and/or other information in the low accuracy data) from each of the vehicles 30a-30n to the selection criteria.
  • the method 500 may move to the decision state 510.
  • the processor 124 may determine whether one of the vehicles 30a-30n meets the selection criteria. In one example, the processor 124 may determine which of the vehicles 30a-30n may be the target vehicle 320b. In another example, the processor 124 may determine which of the vehicles 30a-30n may be the complementary selected vehicles 320c- 320d. If the vehicle does not meet selection criteria, the method 500 may return to the state 508. If the vehicle does meet the selection criteria, the method 500 may move to the decision state 512. In the decision state 512, the processor 124 may determine whether enough of the vehicles 30a-30n have been selected to provide sufficient accuracy. In one example, selecting four of the vehicles 30a-30n may provide sufficient accuracy.
  • the method 500 may return to the state 508. If enough of the vehicles have been selected, the method 500 may move to the state 514. While the vehicle selection steps 508, 510 and/or 512 are shown as separate steps, the vehicle selection may be performed in parallel (e.g., the selected vehicles 320a-320d may be selected at or near the same time rather than selected one at a time).
  • the processor 124 may use the data (e.g., from the signals RAA- RNN) from the selected vehicles 320a-320d to calculate the cooperative positioning solution.
  • the apparatus 100 may present the relative coordinates 170d to each of the nearby vehicles 30a-30n.
  • the method 500 may return to the state 504.
  • the method 550 may select the target vehicle 320b.
  • the method 550 generally comprises a step (or state) 552, a step (or state) 554, a step (or state) 556, a decision step (or state) 558, a step (or state) 560, a decision step (or state) 562, a step (or state) 564, a step (or state) 566, a step (or state) 568, a step (or state) 570, and a step (or state) 572.
  • the state 552 may start the method 550.
  • the transceiver 122 may receive data (e.g., the signals RAA-RNN) from the nearby vehicles 30a-30n.
  • the processor 124 e.g., the relative positioning module 152
  • the processor 124 may compare a trajectory of one of the vehicles 30b-30n with the trajectory of the host vehicle 30a.
  • the method 550 may move to the decision state 558.
  • the processor 124 may determine whether the traj ectories indicate a collision. If not, the method 550 may return to the state 556. If the trajectories indicate a collision, the method 550 may move to the state 560.
  • the processor 124 may identify the vehicle that has a predicted trajectory indicating a potential collision as a potential candidate for the target vehicle 320b.
  • the method 550 may move to the decision state 562. While the steps 556, 558 and/or 560 for identifying a potential target vehicle are shown as separate steps, the vehicles may be analyzed and/or selected in parallel (e.g., the vehicles 30a-30n identified as being on a possible collision course may be identified at or near the same time rather than analyzed one at a time).
  • the processor 124 may determine whether there are more than one potential target vehicles. If there are not more than one target vehicles, the method 550 may move to the state 570. In the state 570, the processor 124 may use the potential target vehicle as one of the selected vehicles 320a-320d (e.g., as the target vehicle 320b). Next, the method 550 may move to the state 572. In the decision state 562, if there are more than one potential target vehicles, the method 550 may move to the state 564. In the state 564, the processor 124 may select the vehicle most likely to collide with the host vehicle 320a as the most likely target vehicle.
  • the processor 124 may use the most likely target vehicle as one of the selected vehicles 320a- 320d (e.g., the target vehicle 320b).
  • the processor 124 may select the complementary vehicles 320c-320d from the other potential target vehicles based on the selection criteria. For example, the other potential target vehicles may have a higher probability of being one of the selected vehicles 320a-320d than vehicles that are not potentially on a collision course with the host vehicle 30a.
  • the method 550 may move to the state 572.
  • the state 572 may end the method 550.
  • the method 600 may select the complementary vehicles 320c-320d according to a selection criteria.
  • the method 600 generally comprises a step (or state) 602, a decision step (or state) 604, a step (or state) 606, a step (or state) 608, a decision step (or state) 610, a step (or state) 612, a decision step (or state) 614, a step (or state) 616, a decision step (or state) 618, a step (or state) 620, a decision step (or state) 622, a step (or state) 624, a decision step (or state) 626, a step (or state) 628, a step (or state) 630, a step (or state) 632, and a step (or state) 634.
  • the state 602 may start the method 600.
  • the processor 124 may determine whether the target vehicle 320b has been selected. If target vehicle 320b has not been selected, the method 600 may move to the state 606.
  • the state 606 may end the method 600. For example, the complementary vehicles 320c-320d may not be selected until after the target vehicle 320b has been selected.
  • the method 600 may move to the state 608.
  • the processor 124 may determine the relative speed and/or location of the vehicles 30a-30n with respect to the host vehicle 320a and the target vehicle 320b.
  • the method 600 may proceed through a series of checks and/or threshold tests to determine which of the vehicles 30a-30n may be the best candidates for the complementary vehicles 320c-320d.
  • the decision states 610, 614, 618, 622 and/or 626 may represent some of the checks and/or threshold tests for selecting the complementary vehicles 320c-320d.
  • the decision states 610, 614, 618, 622 and/or 626 may be performed in any order and/or in parallel. Other checks and/or threshold tests may be performed.
  • Each of the checks and/or threshold tests may have a weighted value applied to determine which of the vehicles 30a-30n fit the selection criteria.
  • the number, order and/or importance of each of the checks and/or threshold tests may be varied according to the design criteria of a particular implementation.
  • the method 600 may next move to the decision state 610.
  • the processor 124 may determine whether the speed of one or more of the vehicles 30a-30n are below a threshold speed (e.g., 3 meters per second). If the speed is below the threshold speed, the method 600 may move to the state 612. In the state 612, the vehicles 30a-30n that are below the threshold speed may be eliminated from contention (e.g., for the complementary vehicles 320c-320d) by the processor 124. Next, the method 600 may return to the state 608. In the decision state 610, if the speed is above the threshold speed, the method 600 may move to the decision state 614.
  • a threshold speed e.g. 3 meters per second
  • the processor 124 may determine whether one or more of the vehicles 30a-30n was determined to be a potential target vehicle (e.g., as shown in association with FIG. 8). If one of the vehicles 30a-30n was determined to be a potential target vehicle, the method 600 may move to the state 616. In the state 616, the processor 124 may increase the likelihood of selection for the vehicle that was determined to be a potential target vehicle (or decrease the likelihood of selection for other vehicles that are not potential target vehicles). Next, the method 600 may move to the decision state 618. In the decision state 612, if the vehicle is not a potential target vehicle, the method 600 may move to the decision state 618.
  • the processor 124 may determine whether one or more of the vehicles 30a-30n has high speed (e.g., based on the velocity information 310a-310n). For example, the velocity information 310a-310n of the vehicles 30a-30n may be compared and the highest speeds (e.g., relative to the selected vehicles 320a-320b) may be preferred. If one of the vehicles 30a-30n has a high speed (or the highest speed), the method 600 may move to the state 620. In the state 620, the processor 124 may increase the likelihood of selection for the vehicle that was determined to have the high speed (or decrease the likelihood of selection for other vehicles that may not have a high speed). Next, the method 600 may move to the decision state 622. In the decision state 618, if the vehicle does not have the high speed, the method 600 may move to the decision state 622.
  • the processor 124 may determine whether one or more of the vehicles 30a-30n has a large distance from the host vehicle 320a and/or the target vehicle 320b (e.g., based on the velocity and location information 310a-310n and/or the low accuracy position information 170a). For example, the low accuracy position information 170a ofthe vehicles 30a-30n may be compared and the largest relative distances from the selected vehicles 320a-320b may be preferred. If one of the vehicles 30a-30n has a large distance (or the largest relative distance), the method 600 may move to the state 624.
  • the processor 124 may increase the likelihood of selection for the vehicle that was determined to have the large distance (or decrease the likelihood of selection for other vehicles that may not have a large distance).
  • the method 600 may move to the decision state 626.
  • the decision state 622 if the vehicle does not have the large distance, the method 600 may move to the decision state 626.
  • the processor 124 may determine whether one or more of the vehicles 30a-30n forms a corner of a rectangular shape with respect to the host vehicle 320a and/or the target vehicle 320b (e.g., as shown by the lines 402a-402d in association with FIG. 6). For example, the low accuracy position information 170a of the vehicles 30a-30n may be checked relative to the selected vehicles 320a-320b to determine whether a rectangular shape may be formed. If one of the vehicles 30a-30n forms a corner of a rectangle, the method 600 may move to the state 628.
  • the processor 124 may increase the likelihood of selection for the vehicle that was determined to form the corner of the rectangular shape (or decrease the likelihood of selection for other vehicles that may not form the rectangular shape).
  • the method 600 may move to the decision state 630.
  • the decision state 626 if the vehicle does not form the corner of a rectangle, the method 600 may move to the decision state 630.
  • the processor 124 may apply a weight to each of the factors (e.g., compare the weight values applied corresponding to the checks and/or threshold tests). For example, the weights may be checked for each of the vehicles 30a-30n to determine a most suitable combination for the selection criteria.
  • the processor 124 may select two of the vehicles 30a-30n as the complementary vehicles 320c-320d (e.g., based on the weights applied).
  • the method 600 may move to the state 634.
  • the state 634 may end the method 600.
  • FIGS. 7-9 may be implemented using one or more of a conventional general purpose processor, digital computer, microprocessor, microcontroller, RISC (reduced instruction set computer) processor, CISC (complex instruction set computer) processor, SF D (single instruction multiple data) processor, signal processor, central processing unit (CPU), arithmetic logic unit (ALU), video digital signal processor (VDSP) and/or similar computational machines, programmed according to the teachings of the specification, as will be apparent to those skilled in the relevant art(s).
  • RISC reduced instruction set computer
  • CISC complex instruction set computer
  • SF D single instruction multiple data
  • signal processor central processing unit
  • CPU central processing unit
  • ALU arithmetic logic unit
  • VDSP video digital signal processor
  • the invention may also be implemented by the preparation of ASICs (application specific integrated circuits), Platform ASICs, FPGAs (field programmable gate arrays), PLDs (programmable logic devices), CPLDs (complex programmable logic devices), sea-of-gates, RFICs (radio frequency integrated circuits), ASSPs (application specific standard products), one or more monolithic integrated circuits, one or more chips or die arranged as flip-chip modules and/or multi- chip modules or by interconnecting an appropriate network of conventional component circuits, as is described herein, modifications of which will be readily apparent to those skilled in the art(s).
  • ASICs application specific integrated circuits
  • FPGAs field programmable gate arrays
  • PLDs programmable logic devices
  • CPLDs complex programmable logic devices
  • sea-of-gates RFICs (radio frequency integrated circuits)
  • ASSPs application specific standard products
  • monolithic integrated circuits one or more chips or die arranged as flip-chip modules and/or multi- chip modules
  • the invention thus may also include a computer product which may be a storage medium or media and/or a transmission medium or media including instructions which may be used to program a machine to perform one or more processes or methods in accordance with the invention.
  • a computer product which may be a storage medium or media and/or a transmission medium or media including instructions which may be used to program a machine to perform one or more processes or methods in accordance with the invention.
  • Execution of instructions contained in the computer product by the machine, along with operations of surrounding circuitry, may transform input data into one or more files on the storage medium and/or one or more output signals representative of a physical object or substance, such as an audio and/or visual depiction.
  • the storage medium may include, but is not limited to, any type of disk including floppy disk, hard drive, magnetic disk, optical disk, CD-ROM, DVD and magneto- optical disks and circuits such as ROMs (read-only memories), RAMs (random access memories), EPROMs (erasable programmable ROMs), EEPROMs (electrically erasable programmable ROMs), UVPROMs (ultra-violet erasable programmable ROMs), Flash memory, magnetic cards, optical cards, and/or any type of media suitable for storing electronic instructions.
  • ROMs read-only memories
  • RAMs random access memories
  • EPROMs erasable programmable ROMs
  • EEPROMs electrically erasable programmable ROMs
  • UVPROMs ultra-violet erasable programmable ROMs
  • Flash memory magnetic cards, optical cards, and/or any type of media suitable for storing electronic instructions.
  • the elements of the invention may form part or all of one or more devices, units, components, systems, machines and/or apparatuses.
  • the devices may include, but are not limited to, servers, workstations, storage array controllers, storage systems, personal computers, laptop computers, notebook computers, palm computers, cloud servers, personal digital assistants, portable electronic devices, battery powered devices, set-top boxes, encoders, decoders, transcoders, compressors, decompressors, pre-processors, post-processors, transmitters, receivers, transceivers, cipher circuits, cellular telephones, digital cameras, positioning and/or navigation systems, medical equipment, heads-up displays, wireless devices, audio recording, audio storage and/or audio playback devices, video recording, video storage and/or video playback devices, game platforms, peripherals and/or multi-chip modules.
  • Those skilled in the relevant art(s) would understand that the elements of the invention may be implemented in other types of devices to meet the criteria of a particular application.

Landscapes

  • Engineering & Computer Science (AREA)
  • Radar, Positioning & Navigation (AREA)
  • Remote Sensing (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Automation & Control Theory (AREA)
  • Mechanical Engineering (AREA)
  • Aviation & Aerospace Engineering (AREA)
  • Chemical & Material Sciences (AREA)
  • Analytical Chemistry (AREA)
  • Transportation (AREA)
  • Environmental & Geological Engineering (AREA)
  • Electromagnetism (AREA)
  • Multimedia (AREA)
  • Traffic Control Systems (AREA)
  • Position Fixing By Use Of Radio Waves (AREA)
  • Navigation (AREA)
  • Mobile Radio Communication Systems (AREA)

Abstract

An apparatus comprising a transceiver module and a processor. The transceiver may be configured to send/receive data messages to/from a plurality of vehicles. The processor may be configured to (i) determine a plurality of selected vehicles from the plurality of vehicles based on a selection criteria and (ii) calculate relative coordinates of the plurality of vehicles based on the data messages from the selected vehicles. The selection criteria may comprise determining (i) a target vehicle and (ii) at least two complementary vehicles. A predicted trajectory of the target vehicle may cross paths with a predicted trajectory of the apparatus. The complementary vehicles may be selected based on (i) an arrangement of the plurality of vehicles and (ii) speeds of the plurality of vehicles.

Description

GROUPING FOR EFFICIENT COOPERATIVE POSITIONING CALCULATIONS
Field of the Invention
The present invention relates to object positioning generally and, more particularly, to grouping for efficient cooperative positioning calculations.
Background of the Invention
Positioning of objects (i.e., vehicles, buildings, pedestrians, etc.) can be determined using GPS (Global Positioning System) or GNSS (Global Navigation Satellite System). Some applications that use positioning, such as assisted driving, need high precision data to be implemented safely. To calculate high precision data with GPS/GNSS, real-time kinematics (RTK) with base-stations are used, which is currently not viable for commercial use. Host vehicle gyros can also be used to estimate a future expected trajectory of objects, but if the initial GPS/GNSS position is incorrect the problem cannot be solved correctly.
In assisted driving applications, such as active intervention, knowledge of the positions of surrounding vehicles with high accuracy is utilized, which is currently implemented using many different sensors covering 360 degrees around a vehicle. There are many vehicle environment detection systems, such as camera systems, Doppler radar systems and LID AR systems. Inaccuracies can lead to both false-positives and false-negatives. GPS/GNSS does not provide a sufficient degree of accuracy, especially in urban conditions.
Using periodic broadcasts to perform inter-vehicle range estimation can be used to obtain a high degree of accuracy regarding relative positioning between obj ects. Determining highly accurate relative positioning between obj ects introduces additional issues. Such issues include high computing costs and excessive communication between all vehicles for determining position accuracy that is precise enough for active intervention. In traffic scenarios with many vehicles in an area close to the host (or ego) vehicle, a high accuracy calculation based on cooperative positioning will use a very large amount of signal processing and radio data transfer to determine a solution.
It would be desirable to implement grouping for efficient cooperative positioning calculations. Summary of the Invention
The invention encompasses an aspect concerning an apparatus comprising a transceiver module and a processor. The transceiver may be configured to send/receive data messages to/from a plurality of vehicles. The processor may be configured to (i) determine a plurality of selected vehicles from the plurality of vehicles based on a selection criteria and (ii) calculate relative coordinates of the plurality of vehicles based on the data messages from the selected vehicles. The selection criteria may comprise determining (i) a target vehicle and (ii) at least two complementary vehicles. A predicted traj ectory of the target vehicle may cross paths with a predicted trajectory of the apparatus. The complementary vehicles may be selected based on (i) an arrangement of the plurality of vehicles and (ii) speeds of the plurality of vehicles.
In some embodiments of the apparatus aspect described above, (i) the processor comprises a relative positioning module and (ii) the relative positioning module is configured to perform the selection criteria.
In some embodiments of the apparatus aspect described above, the selection criteria is implemented to select four of the plurality of vehicles as the selected vehicles, (ii) the selected vehicles comprise a host vehicle, the target vehicle and two of the complementary vehicles and (iii) the apparatus is implemented by the host vehicle.
In some embodiments of the apparatus aspect described above, the selection criteria enables a selection of the plurality of selected vehicles to determine a cooperative positioning solution for calculating the relative coordinates. In some embodiments implementing the selection of the plurality of selected vehicles, the selection criteria is configured to select the plurality of selected vehicles based on a balance between an accuracy of the relative coordinates calculated and an efficiency of determining the relative coordinates. In some embodiments implement the efficiency of determining relative coordinates, the efficiency of determining the relative coordinates (i) comprises a computation time and an amount of computation power to determine the relative coordinates and (ii) decreases as a number of the selected vehicles increases.
In some embodiments of the apparatus aspect described above, (i) one of the complementary vehicles comprises a second target vehicle and (ii) a predicted trajectory of the second target vehicle crosses paths with the predicted trajectory of the apparatus.
In some embodiments of the apparatus aspect described above, the complementary vehicles have a higher speed than unselected vehicles in the plurality of vehicles. In some embodiments of the apparatus aspect described above, the selected vehicles have a speed above a pre-determined threshold speed of approximately 3 meters per second.
In some embodiments of the apparatus aspect described above, the complementary vehicles have a greater distance from the apparatus than a distance of unselected vehicles in the plurality of vehicles from the apparatus.
In some embodiments of the apparatus aspect described above, the arrangement of the apparatus, the target vehicle and at least one of the complementary vehicles form an angle of approximately 90 degrees.
In some embodiments of the apparatus aspect described above, the speeds of the plurality of vehicles, the arrangement of the plurality of vehicles and the trajectory of the target vehicle are determined based on a GPS heading, a GPS speed and a GPS position.
In some embodiments of the apparatus aspect described above, the predicted trajectory of the target vehicle potentially crosses paths with the apparatus within 10 seconds.
In some embodiments of the apparatus aspect described above, the apparatus is further configured to communicate the relative coordinates determined by the processor to the plurality of the vehicles.
In some embodiments of the apparatus aspect described above, (i) the arrangement of the apparatus, the target vehicle and two of the complementary vehicles approximates four corners of a rectangle and (ii) the four corners of the rectangle have a sufficient distance from each other.
Brief Description of the Drawings
Embodiments of the invention will be apparent from the following detailed description and the appended claims and drawings in which:
FIG. 1 is a diagram illustrating an embodiment of the present invention;
FIG. 2 is a diagram illustrating a module configured to determine high-precision range estimation;
FIG. 3 is a diagram illustrating inter-vehicle range estimation;
FIG. 4 is a diagram illustrating a selection criteria for an example traffic scenario;
FIG. 5 is a diagram illustrating a selection criteria for an example traffic scenario; FIG. 6 is a diagram illustrating a selection criteria for an example traffic scenario;
FIG. 7 is a flow diagram illustrating a method for determining an efficient cooperative positioning solution; FIG. 8 is a flow diagram illustrating a method for selecting a target vehicle; and FIG. 9 is a flow diagram illustrating a method for selecting complementary vehicles according to a selection criteria. Detailed Description of the Preferred Embodiments
Embodiments of the present invention include providing grouping for efficient cooperative positioning calculations that may (i) calculate a relative position of vehicles, (ii) improve an accuracy of vehicle locations over GPS/GNSS solutions, (iii) implement a selection criteria for calculations, (iv) balance an accuracy of output calculations against an amount of processing to generate the calculations, (v) provide a solution that reduces overhead and/or (vi) be easy to implement.
Grouping and/or clustering may be used in telecommunication. Additionally, grouping and/or clustering may be implemented in the area of cooperative positioning, which is described in "Improving Cooperative Positioning for Vehicular Networks", IEEE Transactions of Vehicular Technology, Vol 60, no. 6 July 2011, appropriate portions of which are incorporated by reference. In an example, grouping may be performed by approximate position and/or vehicle kinetics. A propagation delay of a wireless signal from a transmitter to a receiver may be used to estimate a distance. In one example, a round-trip time (RTT) (e.g., a round-trip delay time) may be used for estimating a distance accurately by sending a wireless signal between vehicles and/or objects (e.g., one at a time). Using periodic broadcasts is described in the paper "Inter- vehicle range estimation from periodic broadcasts" by Urs Niesen, Venkatesan N. Ekambaram, Jubin Jose, and Xinzhou Wu, appropriate portions of which are incorporated by reference. In order to establish initial positions from the measured ranges, Multi-Dimensional Scaling (MDS) may be used. MDS is described in the paper "Joint relative position and velocity estimation for an anchorless network of mobile nodes" by Raj Thilak Raj an, Geert Leus, and Alle-Jan van der Veen, appropriate portions of which are incorporated by reference.
Referring to FIG. 1, a diagram illustrating an embodiment of the present invention is shown. An example system 20 is shown. The system 20 may comprise a number of objects 30a- 30n and/or a number of communication satellites 40a-40n. In the example shown, the objects may comprise a combination of vehicles and/or base stations (e.g., infrastructure). In the example shown, two of the communication satellites 40a-40n are shown as a representation of a Global Positioning System (GPS) and/or Global Navigation Satellite System (GNSS) located around the world. In the example shown, the objects 30a, 30b and/or 3 On may be vehicles and the object 30i may be a base station (e.g., a road side unit (RSU)). In some embodiments, each of the objects 30a-30n may be a vehicle (e.g., no base stations). The number of vehicles and/or base stations 30a-30n and/or communication satellites 40a-40n may be varied according to the design criteria of a particular implementation. The system 20 may be configured to adjust and/or self-correct for various numbers of the vehicles and/or base stations 30a-30n and/or communication satellites 40a-40n.
Each of the objects 30a-30n may comprise a respective apparatus (or circuit or module) 100a-100n. The modules 100a-100n may be described in more detail in connection with FIG. 2. The modules lOOa-lOOn may be implemented within and/or attached to the objects 30a-3 On. In the example shown, the module 100a is shown within the vehicle 30a and the module lOOi is attached to the base station 30i. For example, the modules 100a-100n may be located within a dashboard and/or with other electronics of the vehicles 30a-30n. In some embodiments, the modules 100a-100n may be implemented in a mobile device (e.g., a cell phone, tablet computing device, a computer, a standalone GPS device, a fitness monitoring device, a smartwatch, etc.). In an example, the mobile device implementing the modules 100a-100n may be operated within a vehicle that is moving. The location of and/or how the modules 100a-100n are connected to the objects 30a-30n may be varied according to the design criteria of a particular implementation.
In the example shown, the objects 30a-30n and/orthe respective modules 100a-100n may be configured to communicate with the communication satellites 40a-40n. Generally, four or more of the communication satellites 40a-40n may be connected (e.g., via wireless communication signals). In another example, the connection to the satellites 40a-40n may be implemented through a GPS-type connection. The satellites 40a-40n may present signals (e.g., GA-GN). An example implementation uses a Global Navigation Satellite System (GNSS) or Global Positioning System (GPS). Location information (e.g., coordinates) may be calculated (e.g., by the modules 100a-100n and/or other components of the objects 30a-30n) from the signals GA-GN received from GNSS or GPS. The positional accuracy of the location information may be determined by the modules 100a- 100η.
In some embodiments, the modules 100a-100n may be configured to receive the signals GA-GN sent by the satellites 40a-40n. The modules 100a-100n may be configured to calculate the location information (e.g., position data, coordinates, etc.) of the respective vehicles 30a-30n based on the data in the signals GA-GN. In some embodiments, the objects 30a-30n (e.g., a GPS module) may present the calculated location data to the modules 100a-100n. In some embodiments, (e.g., clear sky conditions with limited and/or no interference and/or multipath errors), the positional accuracy of the location information calculated from the signals GA-GN may be within an acceptable tolerance to provide one independently calculated source of positional data.
Local conditions may be any type of interference and/or multipath factor that may affect a determination of location information (e.g., position coordinates) using the signals GA-GN. For example, the local conditions may be due to ionospheric interference, noise, signal degradation caused by dense urban areas, signal degradation caused by tall buildings, etc. The modules 100a- 100η may be configured to supplement and/or enhance the accuracy of the location data of the objects 30a-30n determined from the signals GA-GN by using cooperative positioning. For example, the modules 100a-100n may be configured to provide location data that is more accurate than location data calculated using the signals GA-GN.
In some embodiments, infrastructure (e.g., the base station 30i, in the example shown) may be implemented as a fixed base station, such as a cellular tower, a user installed fixed base station, and/or another type of fixed base station. While only the base station 30i is shown, generally more than one of the base stations 30i may be implemented to provide signals used to calculate the location information. In some embodiments, since the base station 30i may be at a known and fixed location, the base station 30i may be connected to the satellites 40a-40n, calculate location information from the signals GA-GN and provide a verification of the signals GA-GN compared to the known and fixed location of the base station 30i.
In one example, the modules 100a-100n are shown located in the vehicles 30a-30n.
The modules 100a-100n may be implemented as a single unit (e.g., an installed device and/or module) and/or a distributed unit. For example, various components of the modules 100a- 100η may be implemented at various locations in and/or on the vehicles 30a-30n and connected by an electronic network connecting one or more of the components and enabling a sharing of information in the form of digital signals (e.g., a serial bus, an electronic bus connected by wiring and/or interfaces, a wireless interface, etc.). In some embodiments, the modules 100a-100n may be implemented in an infotainment module of the vehicles 30a-30n.
The vehicles 30a-30n may each comprise a number of blocks (or circuits) 102a-102n and/or blocks (or circuits) 104a-104n. The circuits 102a-102n may be configured to implement sensors. The circuits 104a- 104n may be configured to implement actuators. The sensors 102a- 102n and/or the actuators 104a-104n may be connected through an electronic bus (to be described in association with FIG. 2) and/or a wireless connection. In some embodiments, the sensors 102a-102n and/or the actuators 104a-104n may be configured to communicate with the modules 100a-100n. The sensors 102a-102n may be configured to capture information from the environment near the vehicles 30a-30n. The actuators 104a-104n maybe configured to cause the vehicles 30a-30n and/or components of the vehicles 30a-30n to perform an action. In some embodiments, the sensors 102a- 102n and/or the actuators 104a- 104n may be configured to read data to detect obj ects and/or perform actions in response to the detected objects to cause the vehicles 30a-30n to implement functions such as speed control, collision prediction, collision prevention, automatic alignment, online bumper fascia calibration, motion estimation, dead reckoning, Intersection Movement Assist (EVIA), Left Turn Assist (LTA), Forward Collision Warning (FCW), Lane Change Warning (LCW) and/or scene understanding.
The modules 100a-100n may be configured to communicate signals (e.g., RAA- RNN). The signals RAA-RNN may be communicated between the modules 100a- 100η to determine a relative distance between the objects 30a-30n. Generally, each of the modules 100a-100n may transmit one of the signals RAA-RNN to each of the modules 100a-100n (e.g., within a particular range). In the example shown, the module 100a may transmit the signal RAB to the module 100b, the signal RAI to the module lOOi and the signal RAN to the module 100η. Similarly, in the example shown, the module 100b may transmit the signal RAB to the module 100a, the signal RBI to the module lOOi and the signal RBN to the module 100η. The number of the signals RAA-RNN may be varied according to the design criteria of a particular implementation.
The signals RAA-RNN may be used by the modules 100a-100n to calculate a value of the range between the obj ects 30a-30n. In an example, the signals RAA-RNN may be configured similarly to a radar to measure the amount of time a transmitted signals takes to be sent to a destination and/or return from a destination. For example, the module 100a may perform ranging (e.g., determine the absolute distance between the objects 30a and 30b) by transmitting the signal RAB to the module 100b and measuring how long before the signal RAB returns to the module 100a (e.g., a round-trip time). The communication used to transmit the signal RAA-RNN may be implemented through a cellular network connection (e.g., 3G, 4G, 5G LTE, etc.), a Wi-Fi connection, a GPS-type connection, a radio signal, an ultrasonic signal and/or another type of wireless connection. In one example, the signals RAA-RNN may be implemented on a particular wireless frequency spectrum (e.g., 5.9 GHz Dedicated Short Range Communication spectrum). In another example, the signals RAA-RNN may be implemented as and/or alongside a Basic Safety Message (BSM). In yet another example, Wi-Fi may be implementing and the signals RAA-RNN may be part of a lower layer protocol configured to transmit timestamps (e.g., MAC and/or PHY). The signals RAA-RNN may be used to implement vehicle-to- vehicle (e.g., V2V) and/or vehicle-to- infrastructure (e.g., V2I) communication (e.g., V2X communication). The type of wireless connection used to communicate between the modules 100a-100n may be varied according to the design criteria of a particular implementation.
The relative positioning values (e.g., coordinates) calculated by the modules 100a- 100η using the signals RAA-RNN may be configured to enable an implementation of cooperative positioning. The cooperative positioning and/or relative coordinates determined by the modules 100a-100n may have a greater accuracy than the location information determined using the signals GA-GN (e.g., using GNSS data). The cooperative positioning information may be fused with data acquired using the sensors 102a-102n and/or data generated using the signals GA-GN. The higher accuracy and/or precision of the relative position between the objects 30a-30n may reduce uncertainty, reduce a number of false positives, reduce erroneous data calculations and/or enable an improved Automotive Safety Integrity Level (ASIL) classification. For example, in urban scenarios with poor GNSS coverage, there may be GPS uncertainty and relying on GPS information may generate a large number of false positives and/or false negatives. The cooperative positioning may be used together with map information to provide improved navigation information.
The modules 100a-100n may be configured to enable sensor and/or data fusion. For example, the modules 100a-100n may be configured to receive data from one or more (e.g., disparate) sources (e.g., the signals GA-GN, the signals RAA-RNN, the sensors 102a-102n, etc.). The modules 100a-100n may combine and/or analyze the data from the different sources to make inferences about the environment surrounding the objects 30a-30n. The inferences made by the module lOOa-lOOnmay provide a greater accuracy and/or precision of data (e.g., relative positioning) than using one of the sources of data alone.
Referring to FIG. 2, a diagram illustrating an example one of the modules 100a-100n configured to determine high-precision range estimation is shown. The module 100 is shown as a representative example of one of the modules 100a-100n. The module 100 may be configured to generate and/or calculate a position relative to other vehicles. The module 100 is shown transmitting/receiving the signals RAA-RNN. The module may send/receive other signals (not shown). For example, the module 100 may receive one or more of the signals GA-GN. The number and/or type of signals sent and/or received by the module 100 may be varied according to the design criteria of a particular implementation. The module 100 may be connected to a block (or circuit) 106. The circuit 106 may implement an electronic bus. The electronic bus 106 may be configured to transfer data between the module 100 and the sensors 102a-102n and/or the actuators 104a-104n. In some embodiments, the electronic bus 106 may be implemented as a vehicle CAN bus. The electronic bus 106 may be implemented as an electronic wired network and/or a wireless network. Generally, the electronic bus 106 may connect one or more components of the vehicle 30 to enable a sharing of information in the form of digital signals (e.g., a serial bus, an electronic bus connected by wiring and/or interfaces, a wireless interface, etc.).
The module 100 generally comprises a block (or circuit) 120, ablock (or circuit) 122, a block (or circuit) 124, a block (or circuit) 126, a block (or circuit) 128, a block (or circuit) 130 and/or a block (or circuit) 132. The circuit 120 may implement a GNSS antenna. The circuit 122 may implement a transceiver. The circuit 124 may implement a processor. The circuit 126 may implement a communication port. The circuit 128 may implement a filter. The circuit 130 may implement a clock. The circuit 132 may implement a memory. Other blocks (not shown) may be implemented (e.g., I/O ports, power connectors, interfaces, etc.). The number and/or types of circuits implemented by the module 100 may be varied according to the design criteria of a particular implementation.
The antenna 120 may be implemented as a dual band antenna capable of connecting to both a cellular network (e.g., to provide a potential connection option to the base stations 30i) and/or a GNSS network (e.g., the communication satellites 40a-40n). In another example, the antenna 120 may be implemented as two antennas. For example, one antenna may be specifically designed to connect to the base station(s) (e.g., 30i), while another antenna may be implemented to connect to the GNSS network satellites 40a-40n. The antenna 120 may be implemented as discrete antenna modules and/or a dual band antenna module. In some embodiments, the antenna 120 may be implemented as an off-board circuit (e.g., a component that is not part of the module 100). For example, the antenna 120 may send/receive data to/from the module 100 via the electronic bus 106. The implementation of the antenna 120 may be varied according to the design criteria of a particular implementation.
The transceiver 122 may be configured to communicate (e.g., send and/or receive) data (e.g., radio signals). The transceiver 122 may be configured to generate and/or receive one or more of the signals RAA-RNN. The transceiver 122 may receive data from the processor 124 to communicate with external devices (e.g., other of the modules 1 OOa-100η). The transceiver 122 may receive communications from external devices (e.g., other of the modules 100a-100n) and transmit the communication signals to the processor 124. The transceiver 122 may be configured to communicate a Basic Safety Message (BSM) protocol and/or data outside the BSM protocol. In some embodiments, the transceiver 122 may send and/or receive the signals RAA-RNN through the communication port 126 and/or the sensors 102a-102n. The transceiver 122 may be configured to be compatible with one or more communications protocols (e.g., a Wi-Fi transceiver configured to perform dedicated short-range communication (DSRC), vehicle to vehicle (V2V) and/or vehicle to infrastructure (V2I) communication). The implementation of the transceiver 122 may be varied according to the design criteria of a particular implementation.
Theprocessor 124 maybeimplemented as amicrocontroller. Theprocessor 124 may comprise a block (or circuit) 150 and/or a block (or circuit) 152. The circuit 150 may implement a GNSS module and/or chipset. The circuit 152 may implement a relative positioning module. The processor 124 may comprise other components (not shown). In some embodiments, the processor 124 may be a combined (e.g., integrated) chipset implementing processing functionality, the relative positioning chipset 152 and/orthe GNSS chipset 150. In some embodiments, theprocessor 124 may be comprised of a number of separate circuits (e.g., the microcontroller, the GNSS chipset 150 and/or the relative positioning chipset 152). The GNSS module 150 and/or the relative positioning module 152 may each be an optional component of the processor 124. In an example, an off-board circuit (e.g., a component that is not part of the module 100) may perform the functions of the GNSS chipset 150 and send information to the module 100 (e.g., via the bus 106). In another example, an off-board circuit (e.g., a component that is not part of the module 100 such as a distributed and/or scalable computing service) may perform functions for determining the cooperative positioning data and send information to the module 100 (e.g., via the bus 106). The design of the processor 124 and/or the functionality of various components of the processor 124 may be varied according to the design criteria of a particular implementation. The processor 124 is shown sending data to and/or receiving data from the antenna 120, the transceiver 122, the memory 132 and/orthe communication port 126.
The memory 132 may comprise a block (or circuit) 160 and a block (or circuit) 162. The block 160 may store vehicle position data. The block 162 may store computer readable instructions (e.g., instructions readable by the processor 124). The vehicle position data 160 may store various data sets 170a-170n. For example, the data sets 170a-170n may comprise position coordinates 170a, calibration data 170b, a time stamp/delay 170c, relative position data 170d, dead reckoning data 170e and/or other data 170n.
The position coordinates 170a may store location information data calculated and/or received by the module 100 from the signal s GA-GN presented by the GNSS satellites 40a-40n. The signals GA-GN may provide data from which a particular resolution of location information positional accuracy may be calculated. In some embodiments, the position coordinates 170a may not provide sufficient positional accuracy for particular applications (e.g., lane detection, autonomous driving, etc.). The relative position data 170d may be used to improve the accuracy of the position coordinates 170a. In some embodiments, the position coordinates 170a may be calculated by the filter 128 and/or a component external to the module 100. In some embodiments, the position coordinates 170a may be calculated by the GNSS module 150.
The calibration data 170b may comprise parameters (e.g., coefficients) used to transform data received from the sensors 102a-102n and/or presented to the actuators 104a-104n. The calibration data 170b may provide many sets of coefficients (e.g., one set of coefficients for each of the sensors 102a-102n and/or the actuators 104a-104n). The calibration data 170b may be updatable. For example, the calibration data 170b may store current values as coefficients for the sensors 102a-102n and/orthe actuators 104a- 104n and as the data from the sensors 102a-102n and/or the actuators 104a-104n drifts the module 100 may update the calibration data 170b in order to maintain accuracy. The format of the calibration data 170b may vary based on the design criteria of a particular implementation.
The time stamp/delay 170c may be used to determine an age of the vehicle position data 160, the time of flight of the signals RAA-RNN and/or the round-trip time of the signals RAA- RNN. In one example, the time stamp 170c may be used to determine if the vehicle position data 160 should be considered reliable or unreliable (e.g., data older than a pre-determined threshold amount of time may be unreliable). In one example, the time stamp 170c may be appended to the signals RAA-RNN. For example, the time stamp 170c may record a time in Coordinated Universal Time (UTC) and/or in a local time. The implementation of the time stamp 170c may be varied according to the design criteria of a particular implementation.
The relative position data 170d may be used to augment (e.g., improve) a precision of the position coordinates 170a (e.g., the GNSS position) and/or provide an independent set of position data (e.g., cooperative position information). The relative position data 170d may comprise ranging data corresponding to the relative position of the vehicle 30 (e.g., the ego vehicle) to other vehicles. The relative position data 170d may represent a cooperative position solution (e.g., CoP). The relative position data 170d may be used to account (e.g., compensate) for the local conditions that may affect an accuracy of the position coordinates 170a. The relative position data 170d may provide higher precision location information than the position coordinates 170a. The relative position data 170d may be calculated by the relative positioning module 152.
The dead reckoning data 170e may be used to store past and/or present information to determine positions traveled by the vehicle 30. For example, the dead reckoning data 170e may store a previously determined position of the vehicle 30 (e.g., estimated speed, estimated time of travel, estimated location, etc.). The previously determined position may be used to help determine a current position of the vehicle 30. In some embodiments, the dead reckoning data 170e may be determined based on data from the sensors 102a-102n of the vehicle 52 (e.g., an on-board gyroscope and/or wheel click messages). The implementation and/or the information stored to determine the dead reckoning data 170e may be varied according to the design criteria of a particular implementation.
Various other types of data (e.g., the other data 170n) may be stored as part of the vehicle position data 160. For example, the other data 170n may store trend information for the calibration data 170b. For example, the other data 170n may store past data values of the calibration data 170b and/or current data values of the calibration data 170b. The past and current data values of the calibration data 170b may be compared to determine trends used to extrapolate and/or predict potential future values forthe calibration data 170b. For example, the trend information may be used to continue to refine the calibration data 170b when the module 100 is operating in a pure dead reckoning mode (e.g., the location information fails the quality check). In some embodiments, the other data 170n may store various coordinate systems determined using a procrusting procedure and/or multi-dimensional scaling operations.
The processor 124 may be configured to execute stored computer readable instructions (e.g., the instructions 162 stored in the memory 132). The processor 124 may perform one or more steps based on the stored instructions 162. In an example, the processor 124 may calculate the location information (e.g., based on the received signals GA-GN). In another example, one of the steps of the instructions 162 may be executed/performed by the processor 124 and may determine the relative position data 170d based on the signals RAA-RNN. The instructions executed and/or the order of the instructions 162 performed by the processor 124 may be varied according to the design criteria of a particular implementation. The communication port 126 may allow the module 100 to communicate with external devices such as the sensors 102a-102n and/or the actuators 104a-104n. For example, the module 100 is shown connected to the external electronic bus 106. The communication port 126 may allow the module 100 to share the cooperative position data 170d with various infrastructure and/or components of the vehicle 30 (e.g., the sensors 102a-102n and/or the actuators 104a-104n). The communication port 126 may allow the module 100 to receive information from the sensors 102a-102n of the vehicle 30 (e.g., an on-board gyroscope data, wheel click messages, LIDAR, etc.). For example, information from the module 100 may be communicated to an infotainment device for display to a driver. In another example, a wireless connection (e.g., Wi-Fi, Bluetooth, cellular, etc.) to a portable computing device (e.g., a smartphone, a tablet computer, a notebook computer, a smart watch, etc.) may allow information from the module 100 to be displayed to a user.
The filter 128 may be configured to perform a linear quadratic estimation. For example, the filter 128 may implement a Kalman filter. Generally, the filter 128 may operate recursively on input data to produce a statistically optimal estimate. For example, the filter 128 may be used to calculate the position coordinates 170a and/or estimate the accuracy of the position coordinates 170a. In some embodiments, the filter 128 may be implemented as a separate module. In some embodiments, the filter 128 may be implemented as part of the memory 132 (e.g., the stored instructions 162). The implementation of the filter 128 may be varied according to the design criteria of a particular implementation.
The clock 130 may be configured to determine and/or track a time. The time determined by the clock 130 may be stored as the time stamp data 170c. In some embodiments, the clock 130 may be configured to compare time stamps received in the signals RAA-RNN to determine a delay (e.g., a round-trip time).
The module 100 may be configured to calculate a position and/or broadcast data (e.g. , via the transceiver 122 and/or the communication port 126) such as the positional coordinates 170a, an age of the data (e.g., when the data was last updated such as the time stamp 170c), the relative position data 170d and/or other data 170n. A method of communication implemented by the transceiver 122 and/or the communication port 126 and/or the type of data transmitted maybe varied according to the design criteria of a particular implementation.
The module 100 may be configured as a chipset, a system on chip (SoC) and/or a discrete device. For example, the module 100 may be implemented as an electronic control unit (ECU). In some embodiments, the module 100 may be configured to calculate a position, velocity and time (PVT) solution, a relative positioning solution and/or a dead reckoning solution. In some embodiments, the module 100 may transmit received data (e.g., the signals GA-GN and/or the signals RAA-RNN) to other components external to the module 100 to perform calculations (e.g., the relative position data 170d may be sent to another component to determine the cooperative positioning solution). For example, PVT may be considered a bare minimum output for navigation. In some embodiments, the module 100 may comprise the GNSS chipset 150 and calculate a PVT solution and/or the dead reckoning solution. In some embodiments, the module 100 may be configured to receive a data stream that provides the PVT solution and may not determine the dead reckoning solution (e.g., the module 100 receives PVT data from an off-board component, determines the calibration data 170b and sends the calibration data 170b to an off-board component to determine the dead reckoning solution). In some embodiments, the module 100 may be configured to receive a data stream that provides the PVT solution and be configured to calculate the dead reckoning solution. The module 100 may be configured to supplement the PVT solution with the cooperative positioning solution determined based on the relative position 170d.
In some embodiments, the module 100 may use an external processor (e.g., an off- board processor) to perform the calculations to determine the relative position data 170d. In one example, the external processor may be implemented as a distributed computing service configured to scale and/or provision resources on demand (e.g., cloud computing). For example, the module 100 may receive the signals RAA-RNN and/or do range measurement, transmit the data to the cloud computing service and one or more processors of the cloud computing service may perform the calculations for generating the relative position data 170d. The module 100 may receive the calculations (e.g., the relative position data 170d) from the cloud computing service and store the data in the memory 132. In some embodiments, the instructions 162 may be stored on an external memory. The implementation of using the external components to supplement a capability of the module 100 may be varied according to the design criteria of a particular implementation.
Generally, the module 100 receives and/or determines a PVT solution, a dead reckoning solution and/or a cooperative positioning solution (e.g., CoP). The module 100 may be configured to separate and/or extract the data component of the dead reckoning data 170e, the data component of the PVT solution (e.g., the location data) and/or the relative position data 170d. In some embodiments, the instructions 162 may be executed by the processor 124 to provide responses to requests from other components of the vehicle 30. For example, a brake system of the vehicle 30 (e.g., one of the actuators 104a-104n) may request information from the module 100 before performing a particular response (e.g., to slow down).
The sensors 102a-102n may be configured to capture information from the environment surrounding the vehicle 30. The sensors 102a-102n may be vehicle sensors (e.g., speedometer, fluid sensors, temperature sensors, etc.). In some embodiments, data from the sensors 102a-102n may be used to determine the dead reckoning data 170e. In one example, the sensors 102a-102n may be various types of sensors configured to determine vehicle movement (e.g., magnetometers, accelerometers, wheel click sensors, vehicle speed sensors, gyroscopes, etc.). In another example, data from the sensors 102a-102n may be used to determine distances and/or directions traveled from a reference point. The types of sensors 102a-102n implemented may be varied according to the design criteria of a particular implementation.
The actuators 104a-104n may be components of the vehicle 30 configured to cause an action, move and/or control an aspect of the vehicle 30. For example, the actuators 104a-104n may be one or more of a braking system, a steering system, a lighting system, windshield wipers, a heating/cooling system, etc. In some embodiments, the actuators 104a-104n may be configured to respond to information received from the module 100 and/or the sensors 102a-102n. For example, if one of the actuators 104a-104n is a steering system, the steering system may receive information from the module 100 indicating that a collision with a nearby vehicle is likely and the steering system may respond by causing the vehicle 30 to change direction. The types of actuators 104a-104n implemented may be varied according to the design criteria of a particular implementation.
In some embodiments, the sensors 102a-102n and/or the actuators 104a-104n may be implemented to enable autonomous driving of the vehicle 30. For example, the sensors 102a- 102n may receive and/or capture input to provide information about the nearby environment. The information captured by the sensors 102a-102n maybe used by components of the vehicle 30 and/or the module 100 to perform calculations and/or make decisions. The calculations and/or decisions may determine what actions the vehicle 30 should take. The actions that the vehicle 30 should take may be converted into signals readable by the actuators 104a-104n. The actuators 104a-104n may cause the vehicle 30 to move and/or respond to the environment. For example, the module 100 may present an output that provides a relative position of the vehicle 30 to other vehicles. In some embodiments, the module 100 may provide the relative position data 170d (e.g., the cooperative positioning solution) to increase an ASIL classification of the vehicle 30. Other components may be configured to use the data provided by the module 100 to make appropriate decisions for autonomous driving.
The modules 100a-100n may be configured to use round-trip time for estimating relative positions. Using round-trip time to estimate relative positions may result in a multitude of solutions (e.g., since there may be more unknowns than the number of equations). The modules 100a-100n may be configured to reliably and/or unambiguously obtain relative distances between objects (e.g., the objects 30a-30n) by means of round-trip time measurements.
The modules 100a-100n may be configured to perform a position estimation. For example, the modules 100a-100n may each comprise the transceiver 122 configured to send and/or receive the radio signals RAA-RNN. The processor 124 of each of the modules 100a-100n may be configured to repeatedly perform a number of steps according to the instructions 162. In one example, the processor 124 may execute one or more of the instructions 162 to calculate a time of flight (TOF) for the signals RAA-RNN. For example, the signals RAA-RNN may be sent pair-wise between two of the transceivers 122 (e.g., a transceiver 122 implemented by the module 100a and a transceiver 122 implemented by the module 100b). In another example, the processor 124 may execute one or more of the instructions 162 to calculate possible positions for the modules 100a- 100η, which may result in many possible positions for each of the modules 100a-100n. In yet another example, the processor 124 may execute one or more of the instructions 162 to perform multi-dimensional scaling (MDS) calculations in order to obtain relative positions of the modules 100a-100n in a particular coordinate system. In some embodiments, the processor 124 may be configured to repeatedly perform a procrusting procedure (e.g., after two initial MDS calculations and between every two consecutive MDS calculations). The procrusting procedure may comprise translation, scaling and/or rotation of the particular coordinate system to generate a corrected coordinate system. For example, the procrusting procedure may be configured to determine the corrected present coordinate system such that a smallest change for the relative positions of the modules 1 OOa-100η (e.g., the relative position data 170d) between the consecutive MDS calculations may be obtained.
In some embodiments, for each pair of the modules 100a-100n, the processor 124 may be configured to calculate time of flight as the time for one of the signals RAA-RNN to travel from the transmitting transceiver (e.g., the transceiver 122 of the module 100a) to a receiving transceiver (e.g., the transceiver 122 of the module 100b). In some embodiments, the processor 124 may be configured to calculate time of flight as the time for one of the signals RAA-RNN to travel from a transmitting transceiver to a receiving transceiver and back to the transmitting transceiver (e.g., at least one time, such that round-trip time (RTT) may be determined for each pair of the modules 100a-100n). In some embodiments, the processor 124 maybe configured to calculate time of flight either with knowledge of a delay time between each re-transmission and/or by repeated transmissions that comprise time stamps generated by the different modules 100a-100n (e.g., to indicate when the signals RAA-RNN were received by each of the modules 100a-100n). The method of determining the time of flight may be varied according to the design criteria of a particular implementation.
The signals RAA-RNN may be configured to be compatible with a mobile base system protocol. In one example, the protocol implemented by the signals RAA-RNN may be a basic safety message (BSM) plus additional information. Generally, BSM type messages may broadcast similar information. The modules 100a-100n may be configured to send a small message outside of the standard BSM type message protocol. For example, the round-trip time and/or the time stamp 170c may be transmitted as part of the signals RAA-RNN but outside of the BSM message. The signals RAA-RNN may be transmitted at a pre-determined update rate. In one example, the update rate of the signals RAA-RNN may be 10Hz (e.g., 100ms). In some embodiments, the signals RAA-RNN may be transmitted as BSM signals via a standard service channel. For example, using the standard service channel, the signals RAA-RNN may be transmitted to a cluster head for the objects 30a-30n. If a target object is outside a range of the service channel, multihopping may be implemented (e.g., transmitting the signals RAA-RNN from a local cluster head to another cluster head and then to the target vehicle). The protocol(s) implemented by the signals RAA-RNN may be varied according to the design criteria of a particular implementation.
Referring to FIG. 3 a diagram illustrating inter-vehicle range estimation is shown. An example system 200 is shown. The example system 200 may be implemented by four objects 30a-30d at an intersection of a road 202a and a road 202b. Each of the objects 30a-30d may comprise a corresponding one of the modules lOOa-lOOd. In the example system 200, the objects 30a-30c may be vehicles and the object 30d may be infrastructure (e.g., a cell phone tower, a traffic sign, a traffic light, part of a building, etc.). On the vehicle 30a, the transceiver 122a and the processor 124a are shown. Similarly, the objects 30b-30d may comprise transceivers 122b-122d and/or processors 124b-124d. Generally, the example system 200 comprises four of the modules 100a-100n. However, the number of the modules 100a-100n may be varied according to the design criteria of a particular implementation. In the example system 200, the modules lOOa-lOOd may communicate between at least two other of the modules 100a- 1 OOd. The signal RAB is shown being transmitted between the vehicle 30a and the vehicle 30b, the signal RAC is shown being transmitted between the vehicle 30a and the vehicle 30c, the signal RAD is shown being transmitted between the vehicle 30a and the object 30d, the signal RBC is shown being transmitted between the vehicle 30b and the vehicle 30c, the signal RBD is shown being transmitted between the vehicle 30b and the object 30d, and the signal RCD is shown being transmitted between the vehicle 30c and the object 30d. The signals RAA-RNN may be transmitted simultaneously, in a particular order, in response to one of the signals RAA-RNN and/or periodically. The signals RAA-RNN may be transmitted back and forth between each of the modules 100a- 100η.
In some embodiments, each of the modules 100a- 1 OOd may be configured to calculate the round-trip time for each of the signals RAB-RCD sent between each of the modules 100a- 1 OOd. For example, the module 100a may be configured to calculate the round-trip time for each of the signals RAB-RAD sent from the module 100a to the other modules 100b- 1 OOd, as well as the round- trip times for the signals RAB, RBC and/or RBD sent by the module 100b to the other modules 100a, 100c and/or lOOd, the signals RAC, RBC and/or RCD sent by the module 100c to the other modules 100a, 100b and/or 1 OOd and/or the signals RAD, RBD and/orRCD sent by the module lOOd to the other modules 100a- 100c. Using the calculated round-trip times, each of the processing units 124a-124d may be configured to calculate possible positions for the modules 100a- 1 OOd (and the objects 30a-30d), which may result in multiple possible positions for each of the modules 100a- 1 OOd (e.g., since there are more unknowns than the number of equations).
In some embodiments, the modules 100a- 1 OOd maybe configured to calculate a time of flight (TOF) (e.g., pair-wise) between two of the modules (e.g., lOOa-lOOb) among the modules 100a- 1 OOd, one or more times. In one example, for each pair of the modules 100a- 1 OOd, the processors 124a-124d may be configured to determine the time of travel of the signals RAB-RCD from a transmitting one of the modules 100a- 1 OOd to a receiving one of the modules 100a- 1 OOd (e.g. , a time of travel of the signal RAB from the transmitting module 100a to the receiving module 100b). To determine the time of travel (e.g., for time of flight), the modules lOOa-lOOd may have synchronized clocks (e.g., the clocks 130 may be synchronized). In another example, for each pair ofthe modules 100a- 1 OOd, the processors 124a- 124d may be configured to determine the round-trip time of travel of the signals RAB-RCD from a transmitting one of the modules lOOa-lOOd to a receiving one of the modules 100a- 1 OOd and back to the transmitting one of the modules 100a- 1 OOd (e.g., a time of travel of the signal RBC from the transmitting module 100b to the receiving module 100c and back to the transmitting module 100b from the receiving module 100c, possibly including a delay time). To determine the time of travel (e.g., for round-trip time), the clocks 130 may not need to be synchronized, but the delay 170c may be known. If the delay time 170c is not known, repeated transmissions maybe implemented (e.g., with 5 time stamps at the different modules 100a- lOOd).
Each of the processors 124a-124d may determine the possible positions for the modules lOOa-lOOd. The processors 124a-124d may be configured to perform a multi-dimensional scaling (MDS) operation. The MDS operation may be implemented to calculate relative positions of the modules lOOa-lOOd in a coordinate system. The processors 124a-124d may be configured to perform another MDS operation (e.g., at a later time). The MDS operation may be implemented to calculate another set of relative positions of the modules lOOa-lOOd in another coordinate system. For example, a first MDS operation may determine relative positions in a first coordinate system and a second MDS operation may determine relative positions in a second coordinate system.
Each of the processors 124a-124d may be configured to perform a procrusting procedure. The procrusting procedure may comprise one or more of translation operations, scaling operations and/or rotation operations of one of the coordinate systems used by the MDS operations. The procrusting procedure may be configured to generate a corrected coordinate system. The corrected coordinate system may be implemented to determine a smallest change for the relative positions of the modules lOOa-lOOd between the first MDS operation and the second MDS operation. The modules 100a- lOOd may be configured to continually perform MDS operations. For each of the following MDS operations, the procrusting procedure may be performed to generate an updated (e.g., current) corrected coordinate system.
The processors 124a-124d may be configured to continually and/or repeatedly calculate a TOF and/or RTT for the signals RAB-RCD sent between the modules lOOa-lOOd, calculate possible positions for the modules 100a- 1 OOd (e.g., which may result in numerous possible positions for each of the modules lOOa-lOOd), and/or perform MDS operations in order to obtain relative positions of the modules 100a- 1 OOd in a coordinate system. After two initial MDS operations, the processors 124a-124d may be configured to repeatedly perform a procrusting procedure between MDS calculations. In one example, the procrusting procedure may be performed between every two consecutive MDS calculations. The procrusting procedures may generate the corrected coordinate system (e.g., corresponding to the current location of the vehicles 30a-30d). In one example, the procrusting procedure may be performed using a Maximum Likelihood Estimation (MLE) computation. In another example, the procrusting procedure may be performed using a Least Squares Estimation (LSE) computation. In some embodiments, vehicle dynamics comprising gyro data, acceleration data and/or velocity data (e.g., data from the sensors 102a-102n, the dead reckoning data 170d and/or the position coordinates 170a) may be used by the processors 124a-124d (e.g., to enhance the accuracy of the calculated solution).
The modules lOOa-lOOd may be connected to a warning and/or information device (e.g., a heads up display, an infotainment unit, an audio system, etc.) implemented in a corresponding one of the objects 30a-30d. For example, the warning and/or information device may be configured to send a notification and/or alert to the driver of a vehicle based on the cooperative positioning data calculated by the modules lOOa-lOOd (e.g., a warning if a collision is likely). In some embodiments, the modules 100a- 1 OOd may be configured to communicate (e.g., via the electronic bus 106) to other vehicle environment detection devices (e.g., the sensors 102a-102n). For example, the sensors 102a- 102n may comprise devices (e.g., radar devices, camera devices, LIDAR devices, etc.) configured to determine a position of one of the objects 30a-30d.
In some embodiments, the objects 30a-30d may not each implement one of the modules 100a- 1 OOd. For example, the vehicle 30a may implement the module 100a- 1 OOd and the objects 30b-30d may implement the transceivers 122b-122d. Implementing the transceivers 122b- 122d without the modules 122b-122d may enable the objects 30b-30d to communicate the signals RAB-RCD but the calculations for the cooperative positioning solution may be performed by the module 100a. For example, the module 100a may determine the cooperative position solution from the signals RAB-RCD and send the data to each of the transceivers 122b-122d to provide the cooperative position solution to the other objects 30b-30d.
In some embodiments, in order to acquire an estimate of the relative position data 170d of the modules 100a- 1 OOd within an acceptable tolerance, the processors 124a-124d may be configured to repeatedly perform at least five procrusting procedures with intermediate MDS calculations. In some embodiments, the processors 124a-124d may be configured to calculate time of flight either with knowledge of a delay time between each re-transmission and/or by repeated transmissions with time stamps at the different transceivers.
To determine the relative positions of the modules lOOa-lOOd, the MDS operations may be performed. The output generated in response to the MDS operations may present a true relative position between the objects 30a-30d. The procrusting procedure may be configured to rotate (e.g., rotating an X-Y diagram) the relative positioning (e.g., mirrored and/or translated) to provide additional compensation. The additional compensation performed by the procrusting procedure may provide a correct relative positioning (e.g., the relative position data 170d).
In the example shown, four objects (e.g., 30a-30d) are shown transmitting the signals RAB-RCD. The number of signals and/or obj ects may be varied according to the design criteria of a particular implementation. Increasing the number of objects (e.g., 30a-30n) may improve an accuracy of the cooperative positioning solution calculated at the cost of computational efficiency. Decreasing the number of objects (e.g., less than four of the objects 30a-30d) may decrease a computational cost but may not provide sufficient accuracy (e.g., the accuracy of the cooperative positioning solution may not be an improvement over a GNSS solution). Generally, determining a cooperative positioning solution using four of the objects 30a-30n may provide a balanced tradeoff between an accuracy of the relative positioning coordinates 170d and the computational processing power of the processor 124. For example, using more than four of the objects 30a-30n may provide diminishing returns on the accuracy of the relative positioning coordinates 170d.
In some embodiments, the modules lOOa-lOOd may be configured to predict a trajectory (e.g., path) of the objects 30a-30d. The modules lOOa-lOOd may calculate and/or receive an associated location and/or velocity (e.g., a low accuracy position, speed and/or heading) for each of the objects 30a-30d. In one example, the predicted trajectory may be calculated using the GPS heading and/or GPS speed information. In another example, the predicted trajectory may be calculated using the time of flight and/or round-trip time information. In yet another example, the predicted trajectory may be calculated based on the shape and/or path of the roads 202a-202b. In still another example, one or more of the objects 30a-30d may not have a predicted trajectory and/or have a null value for the predicted trajectory (e.g., the obj ect 30d may be stationary). The predicted trajectory maybe communicated to/from the modules lOOa-lOOd as data messages using the signals RAB-RCD and/or stored in the memory 132.
Referring to FIG. 4, a diagram illustrating a selection criteria for an example traffic scenario 300 is shown. A road 302a and a road 302b are shown. The roads 302a-302b may meet at an intersection 304. In the example traffic scenario 300 shown, the vehicles 30a-30i may be driving on the roads 302a-302b. In the example shown, the apparatus 100a may be implemented in (or on) the vehicle 30a (e.g., the hose vehicle). Similarly the other vehicles 30b-30i may implement one of the modules (e.g., lOOb-lOOi). The number of vehicles in a vicinity when determining the selection criteria may be varied according to the design criteria of a particular implementation. The apparatus 100a may be configured to select information from remote vehicles to use for the cooperative positioning calculations (e.g., CoP). To improve computational efficiency and/or reduce uncertainty to an acceptable level (e.g., a level allowable according to various autonomous driving standards), the apparatus 100a may be configured to determine which of the vehicles 30a-30i that may provide the most useful information in order to achieve a minimum amount of uncertainty (e.g., reduce uncertainty as much as possible using the available data). The apparatus 100a may be configured to implement a selection criteria to determine which of the vehicles provide the most useful information for efficiently determining a solution. In one example, the selection criteria may be implemented as part of the instructions 162. In another example, the selection criteria may be implemented as part of the relative positioning module 152. In yet another example, the selection criteria may be implemented as a firmware component of the processor 124. The selection criteria may be varied according to the design criteria of a particular implementation.
Using different combinations of information (e.g., data messages) received from the vehicles 30a-30i, different amounts of computation (or processing) may be performed and/or different amounts of uncertainty of the relative positioning solution for the vehicles 30a-30i may result. The selection criteria implemented by the module 100a may determine which combinations of information may provide a low computational cost (e.g., efficient calculations in terms of processing power and/or an amount of time to determine a solution) and a low amount of uncertainty of the relative positioning solution. In one example, the selection criteria may select some of the information from the vehicles 30a-30i to achieve a balance between a computation time, an amount of power usage and an accuracy of the relative positioning solution.
In some embodiments, the selection criteria may select four of the vehicles 30a-30i. Selecting four of the vehicles 30a-30i may be sufficient to achieve the balance between a computation time, an amount of power usage and/or an accuracy of the relative positioning solution. For example, selecting more than four of the vehicles 30a-30i may provide diminishing returns on an improvement (e.g., accuracy) of the relative positioning solution, while increasing power usage and/or computation time. To achieve an acceptable level of accuracy (e.g., approximately less than +/- 1 meter) the selection criteria may select (e.g., select four) from the nearby vehicles 30a-30i based on a distance, an arrangement (e.g., orientation) between the vehicles 30a-30i and/or a speed (or velocity) of the vehicles 30a-30i.
The apparatus 100a may be configured to group and/or track the vehicles 30a-3 On and select from the vehicles 30a-30i (e.g., select four vehicles) that may provide the best/optimal output (e.g., by considering the balance between computation time, computation cost, amount of uncertainty of the solution and/or the information available) for the cooperative positioning solution. The relative positioning module 152 may group and/or track the vehicles 30a-30i based on a low accuracy positions (e.g., GNSS solutions). For example, the signals RAA-RNN may comprise the low accuracy positions of the vehicles 30a-30i. In one example, each vehicle of the vehicles 30a-30i may implement one of the modules lOOa-lOOi and calculate the GNSS solution (e.g., the position coordinates 170a) based on the signals GA-GN and communicate the GNSS solution using the signals RAA-RNN. In another example, the information in the signals RAA-RNN may be used to calculate time of flight information and/or round-trip time information. The implementation of the communication and/or the calculation of the low accuracy positions may be varied according to the design criteria of a particular implementation.
Generally, the GNSS solution may have a low accuracy in terms of positioning compared to the cooperative positioning solution. However, the GPS heading and/or speed information may be accurate. The selection criteria may use the GPS heading and/or GPS speed information to identify which of the vehicles 30a-30i to select to perform the cooperative positioning calculations.
The selection criteria analysis performed by the relative positioning module 152 may determine which of the vehicles may intercept the predicted travel path of the host vehicle 30a. At least one of the vehicles 30b-30i may be considered a target vehicle (e.g., a vehicle likely to cross the predicted path of the host vehicle 30a within a particular amount of time). The vehicle considered to be the target vehicle may be likely to collide with the host vehicle 30a (e.g., based on the low accuracy solution). In one example, the target vehicle may be one of the vehicles 30b-30n that crosses the predicted travel path of the host vehicle 30a within 10 seconds. In another example, the target vehicle and the host vehicle 30a may converge at the same location within a pre- determined amount of time. The selection criteria may select the target vehicle as one of the vehicles from which to receive information in order to determine the cooperative positioning solution.
The selection criteria analysis performed by the relative positioning module 152 may select at least two other of the vehicles 30b-30i (e.g., the complementary vehicles) to receive information from to use for the cooperative positioning solution. The selection criterial may be used to determine the complementary vehicle based on a distance and/or relative speed compared to the host vehicle 30a. Generally, the selection criteria may define a selection for the host vehicle 30a, the target vehicle and the vehicles that are furthest away and have the highest relative speed (e.g., complementary vehicles).
The selection criteria analysis may select the data messages from the vehicles 3 Oa-3 On to provide information for the relative positioning module 152 to perform the cooperative positioning calculations. The cooperative positioning calculations may generate the relative position data 170d that may have a higher precision than the position coordinates 170a (e.g., low accuracy results) determined using GNSS data. For a limited number of vehicles, the remaining vehicles (e.g., the vehicles 30b-30i) may use the improved positioning of the relative position data 170d as anchors to improve a position based on either relative GPS and/or the time-of-flight data coming from the cooperative positioning solution.
In the example traffic scenario 300 shown, each of the vehicles 30a-30i may have an associated location and/or velocity 310a-3 lOi (e.g., low accuracy position, speed and/or heading). In one example, the velocity information 310a-31 Oi may be calculated using the GPS heading and/or GPS speed information. In another example, the velocity information 310a-3 lOi may be calculated using the time of flight and/or round-trip time information. The velocity information 310a-31 Oi may be communicated to/from the modules lOOa-lOOi as data messages using the signals RAA-RNN.
In the example shown, the vehicle 30a may have the velocity 310a of 50mph heading north, the vehicle 30b may have the velocity 310b of lmph heading south, the vehicle 30c may have the velocity 310c of Omph heading south (not shown), the vehicle 30d may have the velocity 3 lOd of 60mph heading north, the vehicle 30e may have the velocity 3 lOe of 30mph heading east, the vehicle 3 Of may have the velocity 31 Of of 50mph heading east, the vehicle 30g may have the velocity 31 Og of 40mph heading east, the vehicle 3 Oh may have the velocity 31 Oh of 5mph heading west, and the vehicle 30i may have the velocity 3 lOi of 35mph heading east. The selection criteria implemented by the module 100a may select from the vehicles 30a-30i based on the velocity information 310a-3 lOi and/or the arrangement and distance with respect to the host vehicle 30a.
A number of dotted shapes 320a-320d are shown. The dotted shapes 320a-320d may represent the selected vehicles determined by the selection criteria analysis implemented by the module 100a. In the example traffic scenario 300, the selected vehicles 320a-320d may comprise four vehicles (e.g., the vehicle 30a, the vehicle 30d, the vehicle 30f and the vehicle 30i). The selected vehicle 320a may be the host vehicle 30a (e.g., the module 100a may be implementing the selection criteria). The selected vehicle 320b may be the target vehicle 30f. The selected vehicle 320c may be the vehicle 30d and the selected vehicle 320d may be the vehicle 30i (e.g., the complementary vehicles).
The vehicle 30f maybe selected as the targetvehicle (e.g., the selected vehicle 320b). The analysis performed by the selection criteria may determine that the vehicle 30f may be the most likely of the vehicles 30b-30i to cross the predicted path of the host vehicle 30a. In the example shown, the vehicle 30a and the vehicle 3 Of may cross the intersection 304 at approximately the same time from the road 302a and the road 302b, respectively (e.g., both vehicles are approximately the same distance from the intersection 304 and traveling at the same speed). The analysis by the selection criteria may determine that the vehicles 30g and 30i may not cross the predicted paths with the vehicle 30a (e.g., traveling away from the intersection 304 on the road 302b). The analysis by the selection criteria may determine that the vehicle 30e may not cross predicted paths with the vehicle 30a (e.g., the vehicle 30e is farther away from the intersection 304 and traveling behind and slower than the vehicle 3 Of).
The analysis by the selection criteria may determine that the vehicle 30d may not cross predicted paths with the vehicle 30a (e.g., the vehicle 30d is traveling away from the intersection 304 on the road 302a and is traveling faster to the north than the vehicle 30a). The analysis by the selection criteria may determine that the vehicles 30b and 30c may not cross predicted paths with the vehicle 30a (e.g., both are nearly stopped at the intersection 304). In some embodiments, the analysis by the selection criteria may not be able to determine that the vehicles 30b and 30c are in the opposite lane (e.g., the low accuracy position results may not provide sufficient evidence that the vehicles are in different lanes). If there is sufficient accuracy from the low accuracy result to determine the vehicles 30b and/or 30c are in an opposite lane to the host vehicle 30a, then the selection criteria may determine that the vehicles 30b and 30c may not cross predicted paths with the vehicle 30a on the basis of traveling in opposite lanes. The analysis by the selection criteria may determine that the vehicle 3 Oh may be a candidate for the target vehicle. However, the vehicle 30h is approaching the intersection 304 at a low speed (e.g., 5mph), is farther away from the vehicle 30a than the distance between the vehicle 30f and the vehicle 30a, and may be slowing down to stop before entering the intersection 304 (e.g., the vehicle 30f may be a better candidate for the target vehicle than the vehicle 30h). By analyzing the velocity information 310a-3 lOi and/or the position of the vehicles 30a-30i, the selection criteria implemented by the relative positioning module 152 may determine that the target vehicle 320b may be the vehicle 30f. In the example traffic scenario 300 with the vehicle 3 Of selected as the target vehicle 320b by the selection criteria, the relative positioning module 152 may select the complementary selected vehicles 320c-320d. The complementary selected vehicles 320c-320d may be selected with respect to the selected vehicles 320a-320b. For example, the selection criteria may prefer the complementary selected vehicles 320c-320d to be furthest away and/or at approximately 90 degrees to the two selected vehicles 320a-320b (e.g., to form four corners of a rectangular shape with each corner having a sufficient distance from each other). The selection criteria may prefer vehicles that are traveling at a higher speed and at least at a speed of approximately 7mph (e.g., 3 meters per second).
In the example traffic scenario 300 with the vehicle 3 Of selected as the target vehicle
320b by the selection criteria, the relative positioning module 152 may select the vehicle 30d as the selected vehicle 320c and the vehicle 30i as the selected vehicle 320d. The vehicles 30d and 30i may be the complementary selected vehicles 320c-320d based on the distance and/or speed relative to the selected vehicles 320a-320b. The analysis by the selection criteria may determine that the vehicle 30e is far from the selected vehicle 320a but close to the selected vehicle 320b. The analysis by the selection criteria may determine that the vehicle 30c is not moving (e.g., an elimination factor).
The analysis by the selection criteria may determine that the vehicle 30g is close to both the selected vehicles 320a-320b (e.g., an elimination factor). The analysis by the selection criteria may determine that the vehicle 30b and the vehicle 30d are both far from the selected vehicles 320a-320b. However, the velocity information 310b indicates the vehicle 30b is traveling at lmph (e.g., an elimination factor) and the velocity information 3 lOd indicates the vehicle 30d is traveling at 60mph (e.g., the vehicle 30d may be a better candidate). The analysis by the selection criteria may select the vehicle 30d as the selected vehicle 320c.
In the example traffic scenario 300 with the vehicle 3 Of selected as the target vehicle 320b and the vehicle 30d as the complementary selected vehicle 320c by the selection criteria, the analysis by the selection criteria may determine that the vehicle 30h and the vehicle 30i are both far from the selected vehicles 320a-320c. Furthermore, the vehicle 30h and the vehicle 30i both make approximately a 90 degree angle with the selected vehicles 320a-320c. However, the velocity information 3 lOh indicates the vehicle 30h is traveling at 5mph and the velocity information 3 lOi indicates the vehicle 30i is traveling at 35mph. The selection criteria may determine that the vehicle 30i may be a better candidate since the vehicle 30h may be traveling below a minimum speed threshold (e.g., below 7mph may be an elimination factor). The analysis by the selection criteria may select the vehicle 30i as the selected vehicle 320d.
The selection criteria implemented by the relative positioning module 152 may select the vehicles 30a, 30f, 30d and 30i as the selected vehicles 320a-320d. Four of the vehicles 30a-30i may be used for the selected vehicles 320a-320d to provide a solution with sufficient accuracy while balancing computation time and/or computation power. The selected vehicles 320a-320d may provide the efficient combination of nearby vehicles to generate the cooperative positioning solution.
Referring to FIG. 5, a diagram illustrating a selection criteria for an example traffic scenario 350 is shown. The road 302a, the road 302b and the intersection 304 are shown. In the example traffic scenario 350 shown, the vehicles 30a-30i may be driving on the roads 302a-302b. In the example shown, the apparatus 100a may be implemented in (or on) the vehicle 30a. Similarly the other vehicles 30b-30i may implement one of the modules (e.g., lOOb-lOOi). The example traffic scenario 350 may be similar to the example traffic scenario 300 (described in association with FIG. 4) with some alterations.
In the example traffic scenario 350 shown, each of the vehicles 30a-30i may have an associated velocity 310a'-310i' (e.g., speed and/or heading). In the example shown, the vehicle 30a may have the velocity 310a' of 50mph heading north, the vehicle 30b may have the velocity 310b' of lmph heading south, the vehicle 30c may have the velocity 310c' of 50mph heading south, the vehicle 30d may have the velocity 310d' of 15mph heading north, the vehicle 30e may have the velocity 310e' of 60mph heading east, the vehicle 3 Of may have the velocity 31 Of of 5mph heading east, the vehicle 30g may have the velocity 310g' of 40mph heading east, the vehicle 3 Oh may have the velocity 31 Oh' of45mph heading west, and the vehicle 3 Oi may have the velocity 310i' of35mph heading east. The selection criteria implemented by the module 100a may select from the vehicles 30a-30i based on the velocity information 310a'-310i' and/or the arrangement and distance with respect to the host vehicle 30a.
In the example traffic scenario 350, the selected vehicles 320a' -320d' may comprise four vehicles (e.g., the vehicle 30a, the vehicle 30c, the vehicle 30e and the vehicle 30h). The selected vehicle 320a' may be the host vehicle 30a (e.g., the module 100a may be implementing the selection criteria). The selected vehicle 320b' may be the target vehicle 30h. The selected vehicle 320c' may be the vehicle 30c and the selected vehicle 320d' may be the vehicle 30e.
The vehicle 30h may be selected as the target vehicle (e.g., the selected vehicle 320b'). The analysis performed using the selection criteria may determine that the vehicle 30h may be the most likely of the vehicles 30b-30i to cross the predicted path of the host vehicle 30a. In the example shown, the vehicle 30a and the vehicle 3 Oh may cross the intersection 304 at approximately the same time from the road 302a and the road 302b, respectively (e.g., both vehicles are approximately similar distances from the intersection 304 and traveling at similar speeds). The analysis by the selection criteria may determine that the vehicles 30g and 30i may not cross the predicted paths with the vehicle 30a (e.g., traveling away from the intersection 304 on the road 302b).
The analysis by the selection criteria may determine that the vehicle 30e may not cross the predicted paths with the vehicle 30a (e.g., the vehicle 30e is farther away from the intersection 304 and traveling behind the vehicle 30f). In some embodiments, the analysis by the selection criteria may determine that the vehicle 30d may not cross the predicted paths with the vehicle 30a (e.g., the vehicle 30d is traveling away from the intersection 304 on the road 302a and is traveling the same direction as the vehicle 30a). In some embodiments, the analysis by the selection criteria may determine that the vehicle 30d may cross the predicted paths with the vehicle 30a (e.g., the vehicle 30d is traveling away from the intersection 304 on the road 302a and in the same direction of the vehicle 30a but at a slower speed, which could result in the vehicle 30a colliding with the vehicle 30d from behind). Whether the analysis by the selection criteria determines that the vehicle 30d may collide with the vehicle 30a may depend on the particular amount of time of the time frame for determining the target vehicle 30b. For example, the vehicle 30d may be a candidate for the target vehicle.
The analysis by the selection criteria may determine that the vehicle 30b and the vehicle 30c may not cross predicted paths with the vehicle 30a (e.g., both are in the opposite lane). In some embodiments, the analysis by the selection criteria may not be able to determine that the vehicles 30b and 30c are in the opposite lane (e.g., the low accuracy position results may not provide sufficient evidence that the vehicles are in different lanes). If there is sufficient accuracy from the low accuracy result to determine the vehicles 30b and/or 30c are in an opposite lane to the host vehicle 30a, then the selection criteria may determine that the vehicles 30b and 30c may not cross predicted paths with the vehicle 30a on the basis of traveling in opposite lanes. Since the vehicle 30c may collide with the vehicle 30a and the velocity 310c' is relatively high, the vehicle 30c may be a candidate for the target vehicle.
The analysis by the selection criteria may determine that the vehicle 30f may be a candidate for the target vehicle. However, the vehicle 30f is approaching the intersection 304 at a low speed (e.g., 5mph, which is below the selection threshold), and may be slowing down to stop before entering the intersection 304 (e.g., the vehicle 30h may be a better candidate for the target vehicle than the vehicle 30f). The vehicle 30f may be eliminated from candidacy based on having a speed below the threshold speed. By analyzing the velocity information 310a' -310i' and/or the position of the vehicles 30a-30i, the selection criteria implemented by the relative positioning module 152 may determine that the target vehicle 320b' may be the vehicle 30h.
In the example traffic scenario 350 with the vehicle 3 Oh selected as the target vehicle 320b' by the selection criteria, the relative positioning module 152 may select the two complementary vehicles 320c'-320d'. The complementary selected vehicles 320c'-320d' may be selected with respect to the selected vehicles 320a'-320b'. For example, the selection criteria may prefer the two complementary vehicles 320c'-320d' to be furthest away and/or at approximately 90 degrees with respect to the two selected vehicles 320a'-320b' (e.g., the host vehicle 320a', the target vehicle 320b', and the two complementary vehicles 320c'-320d' may approximate four corners of a rectangular shape and the four corners may have a sufficient distance from each other). The selection criteria may prefer vehicles that are traveling at least at a speed of approximately 7mph (e.g., 3 meters per second).
In the exampl e traffi c scenari o 350 with the vehi cl e 3 Oh sel ected as the target vehi cl e 320b' by the selection criteria, the relative positioning module 152 may select the vehicle 30c as the complementary vehicle 320c' and the vehicle 30e as the selected vehicle 320d' . The vehicles 30c and 30e maybe the complementary vehicles 320c'-320d' based on the distance and/or speed relative to the selected vehicles 320a' -320b' . The analysis by the selection criteria may determine that the vehicle 30i is far from the selected vehicle 320a' but close to the selected vehicle 320b'. The analysis by the selection criteria may determine that the velocity information 3 lOf (e.g., 5mph) of vehicle 30f is below the speed threshold (e.g., an elimination factor).
The analysis by the selection criteria may determine that the vehicle 30g is close to both the selected vehicles 320a' -320b' . The analysis by the selection criteria may determine that the vehicle 30b, the vehicle 30c, and the vehicle 30d are each far from the selected vehicles 320a' -320b ' . However, the velocity information 310b' indicates the vehicle 30b is traveling at lmph and the velocity information 310d' indicates the vehicle 30d is traveling at 15mph (e.g., the vehicle 30d may be a better candidate). The analysis by the selection criteria may select the vehicle 30c as the selected vehicle 320c' because the velocity information 310c' indicates the vehicle 30c is traveling at 50mph and the velocity information 310d' indicates the vehicle 30d is traveling at 15mph (e.g., the vehicle 30c may be a better candidate, even though the vehicle 30d is farther away from the selected vehicles 320a' -320b').
In the example traffic scenario 350 with the vehicle 3 Oh selected as the target vehicle 320b' and the vehicle 30c as the complementary vehicle 320c' by the selection criteria, the analysis by the selection criteria may determine that the vehicle 30e and the vehicle 3 Of are both far from the selected vehicles 320a'-320c' . Furthermore, the vehicle 30e and the vehicle 3 Of both make approximately a 90 degree angle with the selected vehicles 320a'-320c'. However, the velocity information 3 lOf indicates the vehicle 30f is traveling at 5mph and the velocity information 310e' indicates the vehicle 30e is traveling at 60mph. The selection criteria may determine that the vehicle 30e may be a better candidate since the vehicle 30f may be traveling below a minimum speed threshold (e.g., below 7mph) and the vehicle 30e is farther away from the selected vehicles 320a'- 320c' than the vehicle 30f. The analysis by the selection criteria may select the vehicle 30e as the complementary vehicle 320d' .
The example traffic scenario 350 and the example traffic scenario 300 (shown in association with FIG. 4) describe a 4-way intersection on level terrain. The selection criteria implemented by the relative positioning module 152 may be configured to select from the vehicles 30a-30i for the efficient cooperative positioning solution regardless of the road types and/or a shape of the terrain. In an example, a layout of the roads that the vehicles 30a-30i drive on may not hinder determining the efficient vehicles for calculations since the selection criteria may analyze relative speed and/or relative distance. The layout of the roads may be relevant to the selection criteria to determine which of the vehicles 30a-30i may be the target vehicle (e.g., the path of the roads may indicate which vehicles may be on paths that may meet). The selection criteria may take the path and/or direction of the roads when selecting the target vehicle.
Similar to the path of the roads, an altitude may also be used to determine a likelihood of a collision. Altitude may be used by the selection criteria as an elimination factor for determining the target vehicle when altitude is indicative of vehicles not colliding (e.g., in an overpass scenario). Generally, the ranging implemented by the module 100a and/or the relative positioning module 152 may determine an absolute distance between the host vehicle 30a and/or the other vehicles 30b-30i. For example, an absolute distance may take altitude into account. In another example, the selection criteria may implement a restriction on selecting a particular vehicle if the height distance is above a pre-determined threshold. The selection criteria may be configured to analyze as many factors as are available (e.g., vehicle speed, vehicle distance, vehicle altitude, road layout, road conditions, traffic conditions, construction detours, weather conditions, etc.) to determine the target vehicle and/or the complementary vehicles used for determining the cooperative positioning solution.
Referring to FIG. 6, a diagram illustrating a selection criteria for an example traffic scenario 400 is shown. The road 302a, the road 302b and the intersection 304 are shown. In the example traffic scenario 400 shown, the vehicles 30a-30i may be driving on the roads 302a-302b. In the example shown, the apparatus 100a may be implemented in (or on) the vehicle 30a. Similarly the other vehicles 30b-30i may implement one of the modules (e.g., lOOb-lOOi). The example traffic scenario 400 may have an arrangement similar to the example traffic scenario 300 (described in association with FIG. 4) with some alterations.
In the example shown, the vehicle 30a may have the velocity 310a" of 50mph heading north, the vehicle 30b may have the velocity 310b" of lmph heading south, the vehicle 30c may have the velocity 310c" of Omph heading south (not shown), the vehicle 30d may have the velocity 310d" of 60mph heading north, the vehicle 30e may have the velocity 310e" of 30mph heading east, the vehicle 3 Of may have the velocity 3 lOf ' of 35mph heading east, the vehicle 30g may have the velocity 3 lOg" of 40mph heading east, the vehicle 3 Oh may have the velocity 3 lOh" of 35mph heading west, and the vehicle 30i may have the velocity 3 lOi" of 70mph heading east. The selection criteria implemented by the module 100a may select from the vehicles 30a-30i based on the velocity information 310a"-310i" and/or the arrangement and distance with respect to the host vehicle 30a.
In the example traffic scenario 400, the velocity information 310a" -3 lOi" may be similar to the velocity information 310a-3 lOi shown in the example traffic scenario 300 (described in association with FIG. 4). For example, the vehicles 30a, 30b, 30c, 30d, 30e and 30g have the same velocity (e.g., the velocity information 310a", 310b", 310c", 31 Od", 31 Oe" and 31 Og" are the same as the corresponding velocity information 310a, 310b, 310c, 3 lOd, 3 lOe and 3 lOg). The velocity information 3 lOf ' has changed to 35mph (from the velocity information 31 Of of 50mph) the velocity information 31 Oh" has changed to 35mph (from the velocity information 31 Oh of 5mph) and the velocity information 310i" has changed to 70mph (from the velocity information 31 Oi of 35mph).
In the example traffic scenario 400, the selected vehicles 320a"-320d' ' may comprise four vehicles (e.g., the vehicle 30a, the vehicle 30d, the vehicle 30f and the vehicle 30h). The selected vehicle 320a' ' may be the host vehicle 30a (e.g., the module 100a may be implementing the selection criteria). The selected vehicle 320b" may be the target vehicle 30f. The selected vehicle 320c" may be the vehicle 30d and the selected vehicle 320d" may be the vehicle 30h. For example, the complementary vehicle 320d' ' has changed to the vehicle 30h (from the complementary vehicle 320d of 30i in the traffic scenario 300) despite the vehicle 30i being farther away and traveling faster than the vehicle 3 Oh.
The vehicle 30f may be selected as the target vehicle (e.g., the selected vehicle
320b"). The selection criteria analysis performed by the relative positioning module 152 may determine that the vehicle 3 Of may be the most likely of the vehicles 30b-30i to cross the predicted path of the host vehicle 30a. In the example shown, the vehicle 30a and the vehicle 3 Of may cross the intersection 304 at approximately the same time from the road 302a and the road 302b, respectively (e.g., both vehicles are approximately the same distance from the intersection 304 and converging towards the same position).
The selection criteria analysis performed by the relative positioning module 152 may determine that the vehicle 30h may also be a candidate for the target vehicle. The vehicle 30h may be approaching the intersection 304 at the same speed (e.g., 35mph) as the vehicle 30f, but is slightly farther away from the vehicle 30a than the distance between the vehicle 3 Of and the vehicle 30a. The vehicle 30f may be a good candidate for the target vehicle 320b" and the vehicle 30h may also be a good candidate for the target vehicle 320b" . In an example, the selection criteria may identify the vehicle 3 Of as a better candidate than the vehicle 3 Oh. The selection criteria may determine that the vehicle 30f is a most likely target and select the vehicle 30f as the selected vehicle 320b".
In the example traffic scenario 400 with the vehicle 3 Of selected as the target vehicle
320b" by the selection criteria, the relative positioning module 152 may select the complementary vehicles 320c" -320d" . Similar to the analysis performed by the relative positioning module 152 for the traffic scenario 300 (described in association with FIG. 4), the vehicle 30d may be selected as one of the complementary vehicles (e.g., 320c"). However, in the example traffic scenario 400, the vehicle 30h may be selected as one of the complementary vehicles 320d" (as opposed to the vehicle 30i in the traffic scenario 300).
In the example traffic scenario 400 with the vehicle 3 Of selected as the target vehicle 320b" and the vehicle 30d as the complementary selected vehicle 320c" by the selection criteria, the selection criteria analysis by the relative positioning module 152 may determine that the vehicle 30h and the vehicle 30i are both sufficiently far from the selected vehicles 320a"-320c" . Furthermore, the vehicle 3 Oh and the vehicle 30i both make approximately a 90 degree angle with the selected vehicles 320a"-320c" . The velocity information 310h" indicates the vehicle 30h is traveling at 35mph and the velocity information 3 lOi" indicates the vehicle 30i is traveling at 70mph.
Despite the vehicle 30i traveling at a higher speed than the vehicle 3 Oh, the selection criteria may determine that the vehicle 3 Oh may be a better candidate for the complementary selected vehicle 320d" . The vehicle 30i may be a good candidate because the speed and/or distance parameters of the vehicle 30i may be better (e.g., farther away and faster) compared to the speed and/or distance of the vehicle 30h. However, the selection criteria may prefer the vehicle 30h because the vehicle 3 Oh may have been determined as a potential candidate for the target vehicle. For example, the vehicle 30h may not be the best candidate based on speed and/or distance, but the vehicle 3 Oh may fit the selection criteria because the vehicle 3 Oh may be a candidate for the target vehicle. The relative positioning module 152 may select the vehicle 30h as the complementary vehicle 320d" .
Lines 402a-402d are shown. The lines 402a-402d may represent an arrangement (e.g., orientation) of the selected vehicles 320a"-320d' ' . The line 402a may be between the selected vehicle 320a" (e.g., the vehicle 30a) and the selected vehicle 320b" (e.g., the vehicle 30f). The line 402b may be between the selected vehicle 320a" (e.g., the vehicle 30a) and the selected vehicle 320d" (e.g., the vehicle 30h). The line 402c may be between the selected vehicle 320d" (e.g., the vehicle 30h) and the selected vehicle 320c' ' (e.g., the vehicle 30d). The line 402d may be between the selected vehicle 320c" (e.g., the vehicle 30d) and the selected vehicle 320b" (e.g., the vehicle 30f).
The lines 402a-402d form a generally rectangular shape. The selected vehicles 320a"-320d" may be located at approximately the four corners of the rectangular shape. In one example, the host vehicle 320a' ' and the target vehicle 320b" may form approximately a 90 degree angle with the complementary vehicle 320c" (e.g., the lines 402a and 402d). In another example, the host vehicle 320a" and the target vehicle 320b" may form approximately a 90 degree angle with the complementary vehicle 320d" (e.g., the lines 402a and 402b). In yet another example, the arrangement of the selected vehicles 320a" -320d" may be a rectangular shape with each of the selected vehicles 320a"-320d' ' at different corners. In some embodiments, the host vehicle 320a", the target vehicle 320b", and the two complementary vehicles 320c"-320d' ' may approximate four corners of a rectangular shape (e.g., the lines 402a-402d) and the four corners (e.g., the selected vehicles 320a"-320d") may have a sufficient distance from each other. In one example, the sufficient distance may be a relative distance between 5m and 100m. For example, in an urban environment, the vehicles 30a-30i may be tracked from 45m-75m (e.g., depending on the speed of the host vehicle 320a' ' and/or the time that the vehicles may cross paths). In some embodiments, a maximum radio range may be 100m in a non-line of sight scenario. The amount for the sufficient distance may be varied according to the design criteria of a particular implementation and/or communication protocols and/or technology implemented.
The arrangement of the vehicles 30a-30i may be used as part of the selection criteria for determining the selected vehicles 320a"-320d' ' . Vehicles that form the rectangular arrangements 402a-402d may be better (e.g., preferred) candidates for the selected vehicles 320a"-320d" (e.g., a rectangular arrangement may result in a more efficient calculation of the cooperative positioning solution).
Referring to FIG. 7, a method (or process) 500 is shown. The method 500 may determine an efficient cooperative positioning solution. The method 500 generally comprises a step (or state) 502, a step (or state) 504, a step (or state) 506, a step (or state) 508, a decision step (or state) 510, a decision step (or state) 512, a step (or state) 514, and a step (or state) 516.
The state 502 may start the method 500. Next, in the state 504, the transceiver 122 may receive data (e.g., the signals RAA-RNN) from the nearby vehicles 30a-30n. In the state 506, the processor 124 (e.g., the relative positioning module 152) may determine the speeds, trajectories and/or arrangement of the nearby vehicles 30a-30n using the low accuracy data (e.g., the position coordinates 170a). For example, the low accuracy data may be one component of the signals RAA- RNN. In one example, from the low accuracy data, the relative positioning module 152 may determine the velocity information 310a-3 lOi (e.g., shown in association with FIG. 4). Next, in the state 508, the processor 124 may compare the data (e.g., the velocity information 310a-3 lOi and/or other information in the low accuracy data) from each of the vehicles 30a-30n to the selection criteria. Next, the method 500 may move to the decision state 510.
In the decision state 510, the processor 124 may determine whether one of the vehicles 30a-30n meets the selection criteria. In one example, the processor 124 may determine which of the vehicles 30a-30n may be the target vehicle 320b. In another example, the processor 124 may determine which of the vehicles 30a-30n may be the complementary selected vehicles 320c- 320d. If the vehicle does not meet selection criteria, the method 500 may return to the state 508. If the vehicle does meet the selection criteria, the method 500 may move to the decision state 512. In the decision state 512, the processor 124 may determine whether enough of the vehicles 30a-30n have been selected to provide sufficient accuracy. In one example, selecting four of the vehicles 30a-30n may provide sufficient accuracy. If enough of the vehicles have not been selected, the method 500 may return to the state 508. If enough of the vehicles have been selected, the method 500 may move to the state 514. While the vehicle selection steps 508, 510 and/or 512 are shown as separate steps, the vehicle selection may be performed in parallel (e.g., the selected vehicles 320a-320d may be selected at or near the same time rather than selected one at a time).
In the state 514, the processor 124 may use the data (e.g., from the signals RAA- RNN) from the selected vehicles 320a-320d to calculate the cooperative positioning solution. Next, in the state 516, the apparatus 100 may present the relative coordinates 170d to each of the nearby vehicles 30a-30n. Next, the method 500 may return to the state 504.
Referring to FIG. 8, a method (or process) 550 is shown. The method 550 may select the target vehicle 320b. The method 550 generally comprises a step (or state) 552, a step (or state) 554, a step (or state) 556, a decision step (or state) 558, a step (or state) 560, a decision step (or state) 562, a step (or state) 564, a step (or state) 566, a step (or state) 568, a step (or state) 570, and a step (or state) 572.
The state 552 may start the method 550. In the state 554, the transceiver 122 may receive data (e.g., the signals RAA-RNN) from the nearby vehicles 30a-30n. In the state 556, the processor 124 (e.g., the relative positioning module 152) may compare a trajectory of one of the vehicles 30b-30n with the trajectory of the host vehicle 30a. Next, the method 550 may move to the decision state 558. In the decision state 558, the processor 124 may determine whether the traj ectories indicate a collision. If not, the method 550 may return to the state 556. If the trajectories indicate a collision, the method 550 may move to the state 560. In the state 560, the processor 124 may identify the vehicle that has a predicted trajectory indicating a potential collision as a potential candidate for the target vehicle 320b. Next, the method 550 may move to the decision state 562. While the steps 556, 558 and/or 560 for identifying a potential target vehicle are shown as separate steps, the vehicles may be analyzed and/or selected in parallel (e.g., the vehicles 30a-30n identified as being on a possible collision course may be identified at or near the same time rather than analyzed one at a time).
In the decision state 562, the processor 124 may determine whether there are more than one potential target vehicles. If there are not more than one target vehicles, the method 550 may move to the state 570. In the state 570, the processor 124 may use the potential target vehicle as one of the selected vehicles 320a-320d (e.g., as the target vehicle 320b). Next, the method 550 may move to the state 572. In the decision state 562, if there are more than one potential target vehicles, the method 550 may move to the state 564. In the state 564, the processor 124 may select the vehicle most likely to collide with the host vehicle 320a as the most likely target vehicle. Next, in the state 566, the processor 124 may use the most likely target vehicle as one of the selected vehicles 320a- 320d (e.g., the target vehicle 320b). In the state 568, the processor 124 may select the complementary vehicles 320c-320d from the other potential target vehicles based on the selection criteria. For example, the other potential target vehicles may have a higher probability of being one of the selected vehicles 320a-320d than vehicles that are not potentially on a collision course with the host vehicle 30a. Next, the method 550 may move to the state 572. The state 572 may end the method 550.
Referring to FIG. 9, a method (or process) 600 is shown. The method 600 may select the complementary vehicles 320c-320d according to a selection criteria. The method 600 generally comprises a step (or state) 602, a decision step (or state) 604, a step (or state) 606, a step (or state) 608, a decision step (or state) 610, a step (or state) 612, a decision step (or state) 614, a step (or state) 616, a decision step (or state) 618, a step (or state) 620, a decision step (or state) 622, a step (or state) 624, a decision step (or state) 626, a step (or state) 628, a step (or state) 630, a step (or state) 632, and a step (or state) 634.
The state 602 may start the method 600. Next, in the decision state 604, the processor 124 may determine whether the target vehicle 320b has been selected. If target vehicle 320b has not been selected, the method 600 may move to the state 606. The state 606 may end the method 600. For example, the complementary vehicles 320c-320d may not be selected until after the target vehicle 320b has been selected. In the decision state 604, if the target vehicle 320b has been selected, the method 600 may move to the state 608.
In the state 608, the processor 124 may determine the relative speed and/or location of the vehicles 30a-30n with respect to the host vehicle 320a and the target vehicle 320b. Next, the method 600 may proceed through a series of checks and/or threshold tests to determine which of the vehicles 30a-30n may be the best candidates for the complementary vehicles 320c-320d. The decision states 610, 614, 618, 622 and/or 626 may represent some of the checks and/or threshold tests for selecting the complementary vehicles 320c-320d. The decision states 610, 614, 618, 622 and/or 626 may be performed in any order and/or in parallel. Other checks and/or threshold tests may be performed. Each of the checks and/or threshold tests may have a weighted value applied to determine which of the vehicles 30a-30n fit the selection criteria. The number, order and/or importance of each of the checks and/or threshold tests may be varied according to the design criteria of a particular implementation.
In the example shown, the method 600 may next move to the decision state 610. In the decision state 610, the processor 124 may determine whether the speed of one or more of the vehicles 30a-30n are below a threshold speed (e.g., 3 meters per second). If the speed is below the threshold speed, the method 600 may move to the state 612. In the state 612, the vehicles 30a-30n that are below the threshold speed may be eliminated from contention (e.g., for the complementary vehicles 320c-320d) by the processor 124. Next, the method 600 may return to the state 608. In the decision state 610, if the speed is above the threshold speed, the method 600 may move to the decision state 614.
In the decision state 614, the processor 124 may determine whether one or more of the vehicles 30a-30n was determined to be a potential target vehicle (e.g., as shown in association with FIG. 8). If one of the vehicles 30a-30n was determined to be a potential target vehicle, the method 600 may move to the state 616. In the state 616, the processor 124 may increase the likelihood of selection for the vehicle that was determined to be a potential target vehicle (or decrease the likelihood of selection for other vehicles that are not potential target vehicles). Next, the method 600 may move to the decision state 618. In the decision state 612, if the vehicle is not a potential target vehicle, the method 600 may move to the decision state 618.
In the decision state 618, the processor 124 may determine whether one or more of the vehicles 30a-30n has high speed (e.g., based on the velocity information 310a-310n). For example, the velocity information 310a-310n of the vehicles 30a-30n may be compared and the highest speeds (e.g., relative to the selected vehicles 320a-320b) may be preferred. If one of the vehicles 30a-30n has a high speed (or the highest speed), the method 600 may move to the state 620. In the state 620, the processor 124 may increase the likelihood of selection for the vehicle that was determined to have the high speed (or decrease the likelihood of selection for other vehicles that may not have a high speed). Next, the method 600 may move to the decision state 622. In the decision state 618, if the vehicle does not have the high speed, the method 600 may move to the decision state 622.
In the decision state 622, the processor 124 may determine whether one or more of the vehicles 30a-30n has a large distance from the host vehicle 320a and/or the target vehicle 320b (e.g., based on the velocity and location information 310a-310n and/or the low accuracy position information 170a). For example, the low accuracy position information 170a ofthe vehicles 30a-30n may be compared and the largest relative distances from the selected vehicles 320a-320b may be preferred. If one of the vehicles 30a-30n has a large distance (or the largest relative distance), the method 600 may move to the state 624. In the state 624, the processor 124 may increase the likelihood of selection for the vehicle that was determined to have the large distance (or decrease the likelihood of selection for other vehicles that may not have a large distance). Next, the method 600 may move to the decision state 626. In the decision state 622, if the vehicle does not have the large distance, the method 600 may move to the decision state 626.
In the decision state 626, the processor 124 may determine whether one or more of the vehicles 30a-30n forms a corner of a rectangular shape with respect to the host vehicle 320a and/or the target vehicle 320b (e.g., as shown by the lines 402a-402d in association with FIG. 6). For example, the low accuracy position information 170a of the vehicles 30a-30n may be checked relative to the selected vehicles 320a-320b to determine whether a rectangular shape may be formed. If one of the vehicles 30a-30n forms a corner of a rectangle, the method 600 may move to the state 628. In the state 628, the processor 124 may increase the likelihood of selection for the vehicle that was determined to form the corner of the rectangular shape (or decrease the likelihood of selection for other vehicles that may not form the rectangular shape). Next, the method 600 may move to the decision state 630. In the decision state 626, if the vehicle does not form the corner of a rectangle, the method 600 may move to the decision state 630.
In the state 630, the processor 124 may apply a weight to each of the factors (e.g., compare the weight values applied corresponding to the checks and/or threshold tests). For example, the weights may be checked for each of the vehicles 30a-30n to determine a most suitable combination for the selection criteria. Next, in the state 632, the processor 124 may select two of the vehicles 30a-30n as the complementary vehicles 320c-320d (e.g., based on the weights applied). Next, the method 600 may move to the state 634. The state 634 may end the method 600.
The functions performed by the diagrams of FIGS. 7-9 may be implemented using one or more of a conventional general purpose processor, digital computer, microprocessor, microcontroller, RISC (reduced instruction set computer) processor, CISC (complex instruction set computer) processor, SF D (single instruction multiple data) processor, signal processor, central processing unit (CPU), arithmetic logic unit (ALU), video digital signal processor (VDSP) and/or similar computational machines, programmed according to the teachings of the specification, as will be apparent to those skilled in the relevant art(s). Appropriate software, firmware, coding, routines, instructions, opcodes, microcode, and/or program modules may readily be prepared by skilled programmers based on the teachings of the disclosure, as will also be apparent to those skilled in the relevant art(s). The software is generally executed from a medium or several media by one or more of the processors of the machine implementation.
The invention may also be implemented by the preparation of ASICs (application specific integrated circuits), Platform ASICs, FPGAs (field programmable gate arrays), PLDs (programmable logic devices), CPLDs (complex programmable logic devices), sea-of-gates, RFICs (radio frequency integrated circuits), ASSPs (application specific standard products), one or more monolithic integrated circuits, one or more chips or die arranged as flip-chip modules and/or multi- chip modules or by interconnecting an appropriate network of conventional component circuits, as is described herein, modifications of which will be readily apparent to those skilled in the art(s).
The invention thus may also include a computer product which may be a storage medium or media and/or a transmission medium or media including instructions which may be used to program a machine to perform one or more processes or methods in accordance with the invention. Execution of instructions contained in the computer product by the machine, along with operations of surrounding circuitry, may transform input data into one or more files on the storage medium and/or one or more output signals representative of a physical object or substance, such as an audio and/or visual depiction. The storage medium may include, but is not limited to, any type of disk including floppy disk, hard drive, magnetic disk, optical disk, CD-ROM, DVD and magneto- optical disks and circuits such as ROMs (read-only memories), RAMs (random access memories), EPROMs (erasable programmable ROMs), EEPROMs (electrically erasable programmable ROMs), UVPROMs (ultra-violet erasable programmable ROMs), Flash memory, magnetic cards, optical cards, and/or any type of media suitable for storing electronic instructions.
The elements of the invention may form part or all of one or more devices, units, components, systems, machines and/or apparatuses. The devices may include, but are not limited to, servers, workstations, storage array controllers, storage systems, personal computers, laptop computers, notebook computers, palm computers, cloud servers, personal digital assistants, portable electronic devices, battery powered devices, set-top boxes, encoders, decoders, transcoders, compressors, decompressors, pre-processors, post-processors, transmitters, receivers, transceivers, cipher circuits, cellular telephones, digital cameras, positioning and/or navigation systems, medical equipment, heads-up displays, wireless devices, audio recording, audio storage and/or audio playback devices, video recording, video storage and/or video playback devices, game platforms, peripherals and/or multi-chip modules. Those skilled in the relevant art(s) would understand that the elements of the invention may be implemented in other types of devices to meet the criteria of a particular application.
While the invention has been particularly shown and described with reference to the preferred embodiments thereof, it will be understood by those skilled in the art that various changes in form and details may be made without departing from the scope of the invention.

Claims

1. An apparatus comprising:
a transceiver module configured to send/receive data messages to/from a plurality of vehicles; and
a processor configured to (i) determine a plurality of selected vehicles from said plurality of vehicles based on a selection criteria and (ii) calculate relative coordinates of said plurality of vehicles based on said data messages from said selected vehicles, wherein (a) said selection criteria comprises determining (i) a target vehicle and (ii) at least two complementary vehicles, (b) a predicted traj ectory of said target vehicle crosses paths with a predicted traj ectory of said apparatus and (c) said complementary vehicles are selected based on (i) an arrangement of said plurality of vehicles and (ii) speeds of said plurality of vehicles.
2. The apparatus according to claim 1, wherein (i) said processor comprises a relative positioning module and (ii) said relative positioning module is configured to perform said selection criteria.
3. The apparatus according to claims 1 or 2, wherein (i) said selection criteria is implemented to select four of said plurality of vehicles as said selected vehicles, (ii) said selected vehicles comprise a host vehicle, said target vehicle and two of said complementary vehicles and (iii) said apparatus is implemented by said host vehicle.
4. The apparatus accordingto any of claims 1 to 3, wherein said selection criteria enables a selection of said plurality of selected vehicles to determine a cooperative positioning solution for calculating said relative coordinates.
5. The apparatus according to claim 4, wherein said selection criteria is configured to select said plurality of selected vehicles based on a balance between an accuracy of said relative coordinates calculated and an efficiency of determining said relative coordinates.
6. The apparatus according to claim 5, wherein said efficiency of determining said relative coordinates (i) comprises a computation time and an amount of computation power to determine said relative coordinates and (ii) decreases as a number of said selected vehicles increases.
7. The apparatus according to any of claims 1 to 6, wherein (i) one of said complementary vehicles comprises a second target vehicle and (ii) a predicted trajectory of said second target vehicle crosses paths with said predicted trajectory of said apparatus.
8. The apparatus according to any of claims 1 to 7, wherein said complementary vehicles have a higher speed than unselected vehicles in said plurality of vehicles.
9. The apparatus according to any of claims 1 to 8, wherein said selected vehicles have a speed above a pre-determined threshold speed of approximately 3 meters per second.
10. The apparatus according to any of claims 1 to 9, wherein said complementary vehicles have a greater distance from said apparatus than a distance of unselected vehicles in said plurality of vehicles from said apparatus.
11. The apparatus according to any of claims 1 to 10, wherein said arrangement of said apparatus, said target vehicle and at least one of said complementary vehicles form an angle of approximately 90 degrees.
12. The apparatus according to any of claims 1 to 11, wherein said speeds of said plurality of vehicles, said arrangement of said plurality of vehicles and said trajectory of said target vehicle are determined based on a GPS heading, a GPS speed and a GPS position.
13. The apparatus according to any of claims 1 to 12, wherein said predicted trajectory of said target vehicle potentially crosses paths with said apparatus within 10 seconds.
14. The apparatus according to any of claims 1 to 13, wherein said apparatus is further configured to communicate said relative coordinates determined by said processor to said plurality of said vehicles.
15. The apparatus according to any of claims 1 to 14, wherein (i) said arrangement of said apparatus, said target vehicle and two of said complementary vehicles approximates four corners of a rectangle and (ii) said four corners of said rectangle have a sufficient distance from each other.
PCT/US2017/066955 2017-03-17 2017-12-18 Grouping for efficient cooperative positioning calculations WO2018169589A1 (en)

Priority Applications (4)

Application Number Priority Date Filing Date Title
EP17901184.6A EP3596421B1 (en) 2017-03-17 2017-12-18 Grouping for efficient cooperative positioning calculations
CN201780088466.3A CN110621955B (en) 2017-03-17 2017-12-18 Grouping for efficient cooperative positioning computation
CN202210634544.8A CN115184920A (en) 2017-03-17 2017-12-18 Grouping for efficient cooperative positioning computation
US16/567,353 US11092696B2 (en) 2017-03-17 2019-09-11 Grouping for efficient cooperative positioning calculations

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
EP17161659.2 2017-03-17
EP17161659.2A EP3376249A1 (en) 2017-03-17 2017-03-17 Enhanced object position detection

Related Child Applications (1)

Application Number Title Priority Date Filing Date
US16/567,353 Continuation US11092696B2 (en) 2017-03-17 2019-09-11 Grouping for efficient cooperative positioning calculations

Publications (1)

Publication Number Publication Date
WO2018169589A1 true WO2018169589A1 (en) 2018-09-20

Family

ID=58358501

Family Applications (5)

Application Number Title Priority Date Filing Date
PCT/US2017/066955 WO2018169589A1 (en) 2017-03-17 2017-12-18 Grouping for efficient cooperative positioning calculations
PCT/US2017/066964 WO2018169590A1 (en) 2017-03-17 2017-12-18 Improved asil-classification by cooperative positioning
PCT/US2017/067187 WO2018169591A1 (en) 2017-03-17 2017-12-19 V2v clustering and multi-hop communication
PCT/US2018/018163 WO2018169634A1 (en) 2017-03-17 2018-02-14 Communication for high accuracy cooperative positioning solutions
PCT/EP2018/056449 WO2018167175A1 (en) 2017-03-17 2018-03-14 Enhanced object position detection

Family Applications After (4)

Application Number Title Priority Date Filing Date
PCT/US2017/066964 WO2018169590A1 (en) 2017-03-17 2017-12-18 Improved asil-classification by cooperative positioning
PCT/US2017/067187 WO2018169591A1 (en) 2017-03-17 2017-12-19 V2v clustering and multi-hop communication
PCT/US2018/018163 WO2018169634A1 (en) 2017-03-17 2018-02-14 Communication for high accuracy cooperative positioning solutions
PCT/EP2018/056449 WO2018167175A1 (en) 2017-03-17 2018-03-14 Enhanced object position detection

Country Status (5)

Country Link
US (5) US11262459B2 (en)
EP (6) EP3376249A1 (en)
JP (1) JP2020509368A (en)
CN (6) CN115184920A (en)
WO (5) WO2018169589A1 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE102021212130A1 (en) 2021-10-27 2023-04-27 Robert Bosch Gesellschaft mit beschränkter Haftung Device and method for operating a communication system

Families Citing this family (56)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11235777B2 (en) * 2015-10-15 2022-02-01 Harman International Industries, Incorporated Vehicle path prediction and target classification for autonomous vehicle operation
DE112017007365T5 (en) * 2017-03-29 2019-12-19 Intel IP Corporation MESSAGE DISTRIBUTION FOR MULTI-COUNCIL TRANSFER
EP3596991B1 (en) * 2017-03-31 2021-05-26 Huawei Technologies Co., Ltd. Radio system with uplink beacon transmission
DE102017213333A1 (en) * 2017-08-02 2019-02-07 Continental Teves Ag & Co. Ohg Antenna module, control unit and motor vehicle
US10757485B2 (en) 2017-08-25 2020-08-25 Honda Motor Co., Ltd. System and method for synchronized vehicle sensor data acquisition processing using vehicular communication
JP6909440B2 (en) * 2017-09-19 2021-07-28 いすゞ自動車株式会社 Vehicle pedestrian protection device
US20190196025A1 (en) * 2017-12-21 2019-06-27 Honda Motor Co., Ltd. System and method for vehicle path estimation using vehicular communication
US11163317B2 (en) 2018-07-31 2021-11-02 Honda Motor Co., Ltd. System and method for shared autonomy through cooperative sensing
US11181929B2 (en) 2018-07-31 2021-11-23 Honda Motor Co., Ltd. System and method for shared autonomy through cooperative sensing
KR20200028217A (en) * 2018-09-06 2020-03-16 현대자동차주식회사 Apparatus for controlling driving of a vehicle and method thereof
EP3657197B1 (en) 2018-11-22 2022-12-21 Arriver Software AB Vehicle positioning based on wireless signal transmission
EP3672286B1 (en) 2018-12-20 2022-04-27 BlackBerry Limited Method and system for internet of things asset tracking within an intelligent transportation system
US20200202706A1 (en) * 2018-12-20 2020-06-25 Qualcomm Incorporated Message Broadcasting for Vehicles
IL270540A (en) * 2018-12-26 2020-06-30 Yandex Taxi Llc Method and system for training machine learning algorithm to detect objects at distance
CN111464978A (en) * 2019-01-22 2020-07-28 岳秀兰 Vehicle remote driving system established by connection of primary wireless equipment and secondary wireless equipment through Internet of things
US11697410B2 (en) * 2019-03-07 2023-07-11 Toyota Jidosha Kabushiki Kaisha Vehicle-to-everything communication-based lane change collision avoidance warning
US11654926B2 (en) * 2019-03-18 2023-05-23 Mobileye Vision Technologies Ltd. Secure system that includes an open source operating system
JP6892474B2 (en) * 2019-03-26 2021-06-23 本田技研工業株式会社 Communications system
US10887928B2 (en) 2019-04-24 2021-01-05 Here Global B.V. Lane aware clusters for vehicle to vehicle communication
US11200431B2 (en) * 2019-05-14 2021-12-14 Here Global B.V. Method and apparatus for providing lane connectivity data for an intersection
CN110245565A (en) * 2019-05-14 2019-09-17 东软集团股份有限公司 Wireless vehicle tracking, device, computer readable storage medium and electronic equipment
DE102019209355A1 (en) 2019-06-27 2020-12-31 Audi Ag Control device for a motor vehicle and motor vehicle
CN110533941B (en) * 2019-07-09 2022-07-19 平安科技(深圳)有限公司 Vehicle communication method, device, electronic equipment and computer medium
GB2590115B (en) * 2019-09-13 2023-12-06 Motional Ad Llc Extended object tracking using radar
CN110839209B (en) * 2019-10-18 2020-10-27 东南大学 Method for direct-view path discrimination and cooperative positioning among vehicles suitable for Internet of vehicles
US11194008B2 (en) * 2019-10-25 2021-12-07 Toyota Motor Engineering And Manufacturing North America, Inc. Triangulation and calibration of electronic control units
CN112788519B (en) * 2019-11-11 2022-07-22 大唐移动通信设备有限公司 Method, terminal and network side equipment for positioning
US11860634B2 (en) * 2019-12-12 2024-01-02 Baidu Usa Llc Lane-attention: predicting vehicles' moving trajectories by learning their attention over lanes
CN111132257B (en) * 2019-12-24 2022-02-15 中国联合网络通信集团有限公司 C-V2X communication method and device
CN111060945B (en) * 2020-01-13 2021-10-19 东南大学 GNSS/5G tight combination fusion positioning method and device
US20210221390A1 (en) * 2020-01-21 2021-07-22 Qualcomm Incorporated Vehicle sensor calibration from inter-vehicle communication
WO2021146891A1 (en) * 2020-01-21 2021-07-29 Qualcomm Incorporated Methods for embedding protected vehicle identifier information in cellular vehicle-to-everything (c-v2x) messages
CN111163419B (en) * 2020-02-07 2020-11-27 北京大学 Malicious user detection method based on state mean value in vehicle cooperation dynamic tracking
WO2021167393A1 (en) * 2020-02-20 2021-08-26 엘지전자 주식회사 Method for positioning sidelink and device therefor
US11495131B2 (en) * 2020-02-21 2022-11-08 Qualcomm Incorporated Vehicle to vehicle safety messaging congestion control for platooning vehicles
WO2021184144A1 (en) * 2020-03-16 2021-09-23 Qualcomm Incorporated Method of efficiently providing pathhistory in c-v2x
US11348695B2 (en) 2020-03-23 2022-05-31 International Business Machines Corporation Machine logic for recommending specialized first aid services
US20210327280A1 (en) * 2020-04-21 2021-10-21 Qualcomm Incorporated Cluster-based approach to positioning of vehicles in vehicle platooning or autonomous trucking
CN111583715B (en) * 2020-04-29 2022-06-03 宁波吉利汽车研究开发有限公司 Vehicle track prediction method, vehicle collision early warning method, device and storage medium
CN111665530B (en) * 2020-05-18 2023-06-02 北京踏歌智行科技有限公司 GPS diagnosis method based on vehicle state
CN113771845B (en) * 2020-06-09 2024-07-26 奥迪股份公司 Method and device for predicting vehicle track, vehicle and storage medium
JP7177804B2 (en) * 2020-07-27 2022-11-24 本田技研工業株式会社 Vehicle control system and vehicle control method
US11718320B1 (en) * 2020-08-21 2023-08-08 Aurora Operations, Inc. Using transmission sensor(s) in localization of an autonomous vehicle
CN112346103A (en) * 2020-10-29 2021-02-09 清华大学 V2X-based intelligent networking automobile dynamic co-location method and device
SE2051399A1 (en) * 2020-12-01 2022-06-02 Toyota Mat Handling Manufacturing Sweden Ab Warehouse system and material handling vehicle
CN112763995B (en) * 2020-12-24 2023-09-01 阿波罗智联(北京)科技有限公司 Radar calibration method and device, electronic equipment and road side equipment
CN113071517B (en) * 2021-04-12 2022-05-13 南京航空航天大学 Automatic driving obstacle avoidance method and system based on vehicle behavior prediction
DE102021002910B3 (en) * 2021-06-07 2022-04-21 Daimler Ag Method and device for evaluating the performance of at least one environmental sensor of a vehicle and vehicle with such a device
CN113490177B (en) * 2021-06-16 2024-02-13 北京邮电大学 Vehicle networking high-efficiency communication method based on cloud wireless access network architecture and related equipment
CN113776491B (en) * 2021-09-26 2023-06-02 中国联合网络通信集团有限公司 Multi-dimensional ranging method, MEC and ranging unit based on B-M2M
CN113640739B (en) * 2021-10-14 2022-01-28 南昌奇眸科技有限公司 Cooperative positioning method and device in three-dimensional scene
US11915584B2 (en) * 2021-10-27 2024-02-27 GM Global Technology Operations LLC Reverse operation detection systems and methods
US12117540B2 (en) * 2021-11-03 2024-10-15 Toyota Research Institute, Inc. Systems and methods for improving localization accuracy by sharing mutual localization information
US20230300774A1 (en) * 2022-03-18 2023-09-21 Mitsubishi Electric Research Laboratories, Inc. Distributed Estimation System
CN115314995B (en) * 2022-08-08 2023-08-04 深圳市海曼科技股份有限公司 Wireless cascading fire-fighting positioning method and device, electronic equipment and storage medium
CN117912245B (en) * 2024-01-12 2024-09-27 东南大学 AVI detector flow distribution method based on maximum likelihood estimation

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20110087433A1 (en) * 2009-10-08 2011-04-14 Honda Motor Co., Ltd. Method of Dynamic Intersection Mapping
US20150262487A1 (en) * 2010-06-25 2015-09-17 Cellco Partnership D/B/A Verizon Wireless Collision avoidance system using telematics unit

Family Cites Families (72)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US3774215A (en) * 1970-11-23 1973-11-20 Gen Systems Dev Corp Position locating system
US6720920B2 (en) * 1997-10-22 2004-04-13 Intelligent Technologies International Inc. Method and arrangement for communicating between vehicles
EP1005627B1 (en) * 1997-08-19 2003-10-29 Siemens VDO Automotive Corporation Vehicle information system
US6304556B1 (en) * 1998-08-24 2001-10-16 Cornell Research Foundation, Inc. Routing and mobility management protocols for ad-hoc networks
US6870846B2 (en) * 2002-04-29 2005-03-22 Harris Corporation Hierarchical mobile ad-hoc network and methods for performing reactive routing therein using dynamic source routing (DSR)
US7711375B2 (en) * 2002-08-06 2010-05-04 Hang Liu Method and system for determining a location of a wireless transmitting device and guiding the search for the same
US6925378B2 (en) * 2003-05-12 2005-08-02 Circumnav Networks, Inc. Enhanced mobile communication device with extended radio, and applications
US6941246B2 (en) * 2003-09-18 2005-09-06 Intel Corporation Method for three-dimensional position calibration of audio sensors and actuators on a distributed computing platform
US7639159B2 (en) * 2007-10-29 2009-12-29 Kapsch Trafficcom Ag System and method for determining intersection right-of-way for vehicles
JP4798168B2 (en) * 2008-04-23 2011-10-19 トヨタ自動車株式会社 Relative position detection device and relative position detection system
US20090271112A1 (en) * 2008-04-29 2009-10-29 Gm Global Technology Operations, Inc. Dedicated short range communication (dsrc) sender validation using gps precise positioning techniques
CN101350635A (en) * 2008-09-05 2009-01-21 清华大学 Method for self-locating sensor network node within sparseness measuring set base on shortest path
US8831869B2 (en) * 2009-03-31 2014-09-09 GM Global Technology Operations LLC Using V2X-based in-network message generation, aggregation, distribution and processing protocols to enable road hazard condition warning applications
US8676466B2 (en) * 2009-04-06 2014-03-18 GM Global Technology Operations LLC Fail-safe speed profiles for cooperative autonomous vehicles
US8521412B2 (en) 2010-03-26 2013-08-27 Honda Motor Co., Ltd. Method of determining absolute position for a motor vehicle
US8843290B2 (en) * 2010-07-22 2014-09-23 Qualcomm Incorporated Apparatus and methods for calibrating dynamic parameters of a vehicle navigation system
US9846046B2 (en) * 2010-07-30 2017-12-19 Ford Global Technologies, Llc Vehicle navigation method and system
US8775029B2 (en) * 2011-03-16 2014-07-08 Infineon Technologies Ag System and method for bit error rate monitoring
FR2973518A1 (en) * 2011-03-31 2012-10-05 Thales Sa POSITIONING SYSTEM WITH FRAUD DETECTION MECHANISM FOR CRITICAL APPLICATION
KR20130007754A (en) * 2011-07-11 2013-01-21 한국전자통신연구원 Apparatus and method for controlling vehicle at autonomous intersection
CN102914784A (en) * 2011-08-01 2013-02-06 福特全球技术公司 Navigation method and system for vehicle
US9173156B2 (en) * 2011-08-05 2015-10-27 GM Global Technology Operations LLC Method and system for transferring information in vehicular wireless networks
US9495870B2 (en) 2011-10-20 2016-11-15 At&T Intellectual Property I, L.P. Vehicular communications using a scalable ad hoc geographic routing protocol
US20150094904A1 (en) * 2012-02-22 2015-04-02 The Government Of The United States, As Represented By The Secretary Of Navy System and method for underwater vehicle simulation
JP5846020B2 (en) * 2012-04-03 2016-01-20 株式会社デンソー Driving assistance device
US20130278441A1 (en) * 2012-04-24 2013-10-24 Zetta Research and Development, LLC - ForC Series Vehicle proxying
US9300423B2 (en) * 2012-04-24 2016-03-29 Zetta Research and Development LLC—ForC Series Device for synchronizing a time base for V2V communictation
JP2015514202A (en) * 2012-04-26 2015-05-18 インテル コーポレイション Determination of relative positioning information
US8493198B1 (en) * 2012-07-11 2013-07-23 Google Inc. Vehicle and mobile device traffic hazard warning techniques
CN102883263B (en) * 2012-09-19 2015-11-18 合肥工业大学 A kind of VANET sub-clustering maintaining method based on Adjacent vehicles distance
US9234758B2 (en) * 2012-12-20 2016-01-12 Caterpillar Inc. Machine positioning system utilizing position error checking
US9213093B2 (en) * 2012-12-21 2015-12-15 Qualcomm Incorporated Pairwise measurements for improved position determination
US9307432B2 (en) * 2013-01-03 2016-04-05 Qualcomm Incorporated Processing delay estimate based on crowdsourcing data
US9092986B2 (en) * 2013-02-04 2015-07-28 Magna Electronics Inc. Vehicular vision system
AU2014223584B9 (en) * 2013-02-26 2017-03-02 Polaris Industries Inc. Recreational vehicle interactive telemetry, mapping, and trip planning system
US20140302774A1 (en) * 2013-04-04 2014-10-09 General Motors Llc Methods systems and apparatus for sharing information among a group of vehicles
JP6159473B2 (en) * 2013-04-22 2017-07-05 テレフオンアクチーボラゲット エルエム エリクソン(パブル) Cellular network control for inter-vehicle communication channel assignment
US9594159B2 (en) * 2013-07-15 2017-03-14 Texas Instruments Incorporated 2-D object detection in radar applications
WO2015019234A1 (en) * 2013-08-05 2015-02-12 Universidade De Aveiro Method and apparatus for multi-network communication in vehicular networks
CN105684508B (en) * 2013-09-06 2019-08-27 瑞典爱立信有限公司 The resource allocation based on cluster for vehicle-to-vehicle communication
JP6312304B2 (en) * 2014-01-28 2018-04-18 三菱重工機械システム株式会社 Position measuring method, self-position measuring device, and vehicle-mounted device
WO2015139026A2 (en) 2014-03-14 2015-09-17 Go Tenna Inc. System and method for digital communication between computing devices
FR3018941B1 (en) * 2014-03-21 2017-07-07 Thales Sa PILOTAGE OF VEHICLES IN CONVOI
US9888344B2 (en) * 2014-08-05 2018-02-06 Viavi Solutions Uk Limited Techniques for multiple pass geolocation
US9704409B2 (en) * 2014-08-05 2017-07-11 Qualcomm Incorporated Piggybacking unmanned aerial vehicle
US9494430B2 (en) * 2014-10-27 2016-11-15 Caterpillar Inc. Positioning system implementing multi-sensor pose solution
KR101634879B1 (en) * 2014-12-26 2016-06-29 네이버비즈니스플랫폼 주식회사 Method and apparatus for providing wireless location service using the beacon
US9651655B2 (en) * 2015-01-03 2017-05-16 Autotalks Ltd. Positioning enhancement through time-of-flight measurement in WLAN
FR3031406B1 (en) * 2015-01-05 2017-07-28 Valeo Schalter & Sensoren Gmbh ARCHITECTURE FOR CONDITIONAL AUTOMATION DRIVING ASSISTANCE SYSTEM
US20160205656A1 (en) * 2015-01-13 2016-07-14 GM Global Technology Operations LLC Determination of object-to-object position using data fusion techniques
US20160260328A1 (en) 2015-03-06 2016-09-08 Qualcomm Incorporated Real-time Occupancy Mapping System for Autonomous Vehicles
US9801019B2 (en) * 2015-03-16 2017-10-24 Qualcomm Incorporated Adaptive triggering of RTT ranging for enhanced position accuracy
JP6344275B2 (en) * 2015-03-18 2018-06-20 トヨタ自動車株式会社 Vehicle control device
JP6133345B2 (en) * 2015-03-23 2017-05-24 本田技研工業株式会社 Vehicle collision avoidance support device
TWI557421B (en) * 2015-04-21 2016-11-11 金寶電子工業股份有限公司 Method for assisting positioning and movablie electronic device thereof
US20160313450A1 (en) * 2015-04-27 2016-10-27 Autoliv Asp, Inc. Automotive gnss real time kinematic dead reckoning receiver
JP6532126B2 (en) * 2015-06-22 2019-06-19 本田技研工業株式会社 Positioning apparatus, navigation apparatus, positioning method, and positioning program
CN105137390B (en) * 2015-09-14 2017-11-14 上海工程技术大学 A kind of indoor orientation method based on adjustable transmission power AP
US10082797B2 (en) * 2015-09-16 2018-09-25 Ford Global Technologies, Llc Vehicle radar perception and localization
US20170199912A1 (en) * 2016-01-08 2017-07-13 Qualcomm Incorporated Behavior topic grids
CN106412820B (en) * 2016-05-23 2020-02-07 北京邮电大学 Method and device for determining cluster head of mobile ad hoc network
US10266175B2 (en) * 2016-05-31 2019-04-23 Ford Global Technologies, Llc Vehicle collision avoidance
US10244360B2 (en) * 2016-06-12 2019-03-26 Apple Inc. Determining location of mobile device using sensor space to physical space mapping
US10081357B2 (en) * 2016-06-23 2018-09-25 Honda Motor Co., Ltd. Vehicular communications network and methods of use and manufacture thereof
US10257647B2 (en) * 2016-08-01 2019-04-09 Nokia Technologies Oy Methods and apparatuses relating to determination of locations of portable devices
US20180054706A1 (en) * 2016-08-19 2018-02-22 Abl Ip Holding Llc System for auto-commissioning of luminaires and asset tracking
KR102573303B1 (en) * 2016-09-01 2023-08-31 삼성전자 주식회사 Autonomous driving method and apparatus
US20180107473A1 (en) * 2016-10-13 2018-04-19 GM Global Technology Operations LLC Determining whether to install a vehicle system update in a vehicle
EP3316001B1 (en) * 2016-10-25 2024-06-12 Centre National d'Etudes Spatiales Collaborative improvement of a vehicle's positioning
DE102016221688A1 (en) * 2016-11-04 2018-05-09 Robert Bosch Gmbh Method of locating a vehicle
US10928522B2 (en) * 2018-12-18 2021-02-23 Continental Teves Ag & Co. Ohg Method and device for determining navigation information
US11346959B2 (en) * 2020-02-21 2022-05-31 Qualcomm Incorporated Method and apparatus to determine relative location using GNSS carrier phase

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20110087433A1 (en) * 2009-10-08 2011-04-14 Honda Motor Co., Ltd. Method of Dynamic Intersection Mapping
US20150262487A1 (en) * 2010-06-25 2015-09-17 Cellco Partnership D/B/A Verizon Wireless Collision avoidance system using telematics unit

Non-Patent Citations (4)

* Cited by examiner, † Cited by third party
Title
"Improving Cooperative Positioning for Vehicular Networks", IEEE TRANSACTIONS OF VEHICULAR TECHNOLOGY, vol. 60, no. 6, July 2011 (2011-07-01)
RAJ THILAK RAJANGEERT LEUSALLE-JAN VAN DER VEEN, JOINT RELATIVE POSITION AND VELOCITY ESTIMATION FOR AN ANCHORLESS NETWORK OF MOBILE NODES
See also references of EP3596421A4
URS NIESENVENKATESAN N. EKAMBARAMJUBIN JOSEXINZHOU WU, INTER-VEHICLE RANGE ESTIMATION FROM PERIODIC BROADCASTS

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE102021212130A1 (en) 2021-10-27 2023-04-27 Robert Bosch Gesellschaft mit beschränkter Haftung Device and method for operating a communication system

Also Published As

Publication number Publication date
US11194057B2 (en) 2021-12-07
CN110418980B (en) 2023-05-09
US11262459B2 (en) 2022-03-01
JP2020509368A (en) 2020-03-26
CN110418980A (en) 2019-11-05
CN110383100A (en) 2019-10-25
EP3596507A1 (en) 2020-01-22
EP3596947B1 (en) 2024-01-17
WO2018169634A1 (en) 2018-09-20
US20200003861A1 (en) 2020-01-02
US20200013281A1 (en) 2020-01-09
EP3376249A1 (en) 2018-09-19
EP3596421A1 (en) 2020-01-22
EP3596718A4 (en) 2020-12-30
WO2018169590A1 (en) 2018-09-20
CN115184920A (en) 2022-10-14
EP3596947A4 (en) 2021-01-27
US11204428B2 (en) 2021-12-21
CN110447245A (en) 2019-11-12
EP3596947A1 (en) 2020-01-22
CN110447245B (en) 2021-08-06
US11092696B2 (en) 2021-08-17
CN110621955A (en) 2019-12-27
US20200019176A1 (en) 2020-01-16
CN110431606B (en) 2022-07-26
EP3596421A4 (en) 2021-01-20
CN110621955B (en) 2022-06-24
EP4365695A2 (en) 2024-05-08
US10656286B2 (en) 2020-05-19
US20200011960A1 (en) 2020-01-09
CN110431606A (en) 2019-11-08
EP3596718A1 (en) 2020-01-22
EP3596421B1 (en) 2023-06-07
EP3596507A4 (en) 2021-01-20
US20200003907A1 (en) 2020-01-02
WO2018167175A1 (en) 2018-09-20
EP4365695A3 (en) 2024-08-14
WO2018169591A1 (en) 2018-09-20

Similar Documents

Publication Publication Date Title
US11092696B2 (en) Grouping for efficient cooperative positioning calculations
KR101755944B1 (en) Autonomous driving method and system for determing position of car graft on gps, uwb and v2x
US11686582B2 (en) Sensor plausibility using GPS road information
US10725144B2 (en) Transmitters-based localization on freeway
Williams et al. Evaluation of GPS-based methods of relative positioning for automotive safety applications
JP2018520335A (en) GNSS real-time kinematic dead reckoning receiver for automobile
CN107430198B (en) Self-organizing real-time dynamic roaming network for automobile
US10694485B2 (en) Method and apparatus for correcting multipath offset and determining wireless station locations
JP2024516328A (en) Positioning method, device, vehicle-mounted positioning system, and roadside equipment for roadway coordination
Yusuf et al. Vehicle-to-everything (V2X) in the autonomous vehicles domain–A technical review of communication, sensor, and AI technologies for road user safety
CN113747354A (en) Method for vehicle positioning, vehicle-mounted UWB device, roadside UWB device, and medium
EP4095488A1 (en) Positioning method and apparatus
US10877156B2 (en) Localization by light sensors
Tang et al. Precise Pedestrian Positioning by Using Vehicles as Mobile Anchors
WO2024138110A2 (en) Method and system for map building using radar and motion sensors

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: 17901184

Country of ref document: EP

Kind code of ref document: A1

NENP Non-entry into the national phase

Ref country code: DE

WWE Wipo information: entry into national phase

Ref document number: 2017901184

Country of ref document: EP

ENP Entry into the national phase

Ref document number: 2017901184

Country of ref document: EP

Effective date: 20191017