Autonomous vehicles require large-scale development and testing before they can be deployed. However, for developers, driving the necessary number of miles in the real-world to perform such development and testing can be very time consuming. Recently, developers have turned to driving simulation software to test and develop code for self-driving vehicles. As an example, the driving simulation software can be used to test a piece of code while reducing the need for real world driving. However, there are still drawbacks with this process. Most notably, the amount of time that it takes to “simulate” the vehicle's movements on the road is equal to the amount of driving time within the data being simulated. For example, ten hours of driving data takes ten hours to simulate.
The example embodiments are directed to a open-loop simulation system in which vehicles on the road upload their driving data to a host platform, such as a cloud platform, a web server, a blockchain network, or the like. The driving data may include physical sensor data captured during a single run of a vehicle (or multiple runs) as well as planning decisions and intermediate calculations made by the vehicle when making such decisions. Furthermore, the users of the system can request to use previously uploaded driving data to test new self-driving code. In one example, a vehicle may capture driving and store it to a host platform. When a software update is ready for the vehicle, the developer may request that driving data from that vehicle (or another vehicle) be used to test the software update via a vehicle simulation system.
However, rather than run the code and the driving data as part of one large task, the example embodiments break-up the driving data into smaller data chunks. In some cases, the data chunks may be mutually exclusive segments of driving data that are not overlapping in time. For example, as driving data is uploaded to the host platform, the host may organize the data automatically into these smaller data chunks. As one example, the host may organize each data chunk into its own respective file (or files) such as a bag file (.bag), or the like, into chunks of files. In other words, the original file may be divided into smaller chunks (smaller files) for more efficient execution. Furthermore, the code may be compressed based on specifics of the simulation task that can be analyzed by the host. The data may be labeled within a data store where it is held. Furthermore, users of the system may search through the data based on the labels and request simulation from any of the accessible data.
When a new piece of code is to be tested for a vehicle, the developer may send a request to the host platform which identifies the code and data (or a previous run) of a vehicle to be used to simulate the vehicle and test the code against the simulation. In response, the host may divide the data from the previous run into many smaller-sized data chunks. As a non-limiting example, the developer may request five (5) hours of driving data be used to test the new code. Here, the host may break-up the five hours of data into smaller ten-second chunks of driving data. For example, the host may break up the five hours (18000 seconds) of driving data into 1800 chunks of driving data at ten (10) seconds each, etc. Furthermore, the host can spawn the same number of workers/threads for performing the simulations (e.g., 1800 workers) and execute the simulation of the 1800 chunks of driving data at the same time (in parallel) which reduces the overall simulation time from five hours to ten seconds.
According to an aspect of an example embodiment, provided is an apparatus that may include a network interface configured to receive a request to simulate self-driving code against previously-captured driving data via a host platform, and a processor configured to divide the driving data into a plurality of data chunks, generate a plurality of simulation tasks for testing the self-driving code based on the plurality of driving data chunks, respectively, execute the plurality of simulation tasks in parallel via a plurality of workers of the host platform, respectively, and store execution results of the plurality of simulation tasks via a data store.
According to an aspect of another example embodiment, provided is a method that may include receiving a request to simulate self-driving code against previously-captured driving data via a host platform, dividing the driving data into a plurality of data chunks, generating a plurality of simulation tasks for testing the self-driving code based on the plurality of driving data chunks, respectively, executing the plurality of simulation tasks in parallel via a plurality of workers of the host platform, respectively, and storing execution results of the plurality of simulation tasks via a data store.
According to an aspect of another example embodiment, provided is a non-transitory computer-readable medium with instructions which when executed by a processor cause a computer to perform a method that may include receiving a request to simulate self-driving code against previously-captured driving data via a host platform, dividing the driving data into a plurality of data chunks, generating a plurality of simulation tasks for testing the self-driving code based on the plurality of driving data chunks, respectively, executing the plurality of simulation tasks in parallel via a plurality of workers of the host platform, respectively, and storing execution results of the plurality of simulation tasks via a data store.
Features and advantages of the example embodiments, and the manner in which the same are accomplished, will become more readily apparent with reference to the following detailed description taken in conjunction with the accompanying drawings.
Throughout the drawings and the detailed description, unless otherwise described, the same drawing reference numerals will be understood to refer to the same elements, features, and structures. The relative size and depiction of these elements may be exaggerated or adjusted for clarity, illustration, and/or convenience.
In the following description, specific details are set forth in order to provide a thorough understanding of the various example embodiments. It should be appreciated that various modifications to the embodiments will be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other embodiments and applications without departing from the spirit and scope of the disclosure. Moreover, in the following description, numerous details are set forth for the purpose of explanation. However, one of ordinary skill in the art should understand that embodiments may be practiced without the use of these specific details. In other instances, well-known structures and processes are not shown or described in order not to obscure the description with unnecessary detail. Thus, the present disclosure is not intended to be limited to the embodiments shown, but is to be accorded the widest scope consistent with the principles and features disclosed herein.
The example embodiments are directed to a simulation system that can be used to test self-driving code using driving data previously uploaded from the road. The system can be hosted on a central platform such as a cloud platform, a web server, a blockchain network, or the like. In some embodiments, the system may be an open-loop system in which sensor data from the vehicle (or another vehicle) is used to test and verify control functions or the like which are performed by the self-driving code.
The driving data used during the simulation process may be driving data from the road that is previously captured by the same vehicle that is being tested or by or one or more other/different vehicles. Here, a developer may specify a new code segment (self-driving code) to be tested and a trip of driving data (single run) that the developer wants to test the self-driving code against. For example, a unique identifier may be mapped to each run that is stored by the host system.
In response, the host platform may divide the requested driving data into many small-sized segments of data based on driving time of the driving data. For example, driving data segments of predetermined intervals (e.g., 10 second intervals, or the like) may be sliced off of the driving data and added as a task to a queue at the host platform. A cloud service or other control program may spawn the same number of worker threads (workers) as there are data segments, and simultaneously execute/simulate the same piece of self-driving code based on the plurality of driving data segments at the same time.
For convenience and ease of exposition, a number of terms may be used herein. For example, the term “vehicle” may be used to refer to different types of vehicles in which systems of the example embodiments may be used. For example, a vehicle may refer to an autonomous vehicle such as a car, a truck, a semi-truck, a tractor, a boat or other floating apparatus such as a ship, a submersible, and the like.
Light detection and ranging (lidar) sensors are used by vehicles to measure a surrounding area by obtaining a sparse point cloud using distances to points in the point cloud that are measured by light beams from the lidar sensors. The illumination works independently from ambient light and can be used in any conditions. Furthermore, the lidar sensors can capture data that can be used to generate a map of the world in three-dimensions (3D). Meanwhile, vehicle cameras can capture images (e.g., RGB images, black and white images, etc.) of the world around the vehicle and provide complimentary data to the lidar data captured by the lidar sensors. For example, cameras can capture data such as color, texture, appearance, etc., while lidar is able to capture and model structural aspects of the data.
In many vehicles, the perception of the vehicle is created based on a combination (i.e., jointly) of lidar data from the lidar sensors and image data captured by the cameras. For accurate perception, these two systems must be aligned with respect to each other. Calibration can be performed to align a coordinate frame of a lidar sensor(s) with a coordinate frame of a camera by changing extrinsic parameters such as rotation and translation between the coordinate frames of the lidar sensor and the camera. These extrinsic parameters can be used to fuse information together from the lidar sensors and the image sensors when visualizing the vehicle interprets visual data from the road.
With the calibrated sensors, the vehicle can capture images and lidar readings of the area surrounding the vehicle and build/modify a three-dimensional map that is stored internally within a computer of the vehicle (or remotely via a web server). The vehicle can localize itself within the map and make decisions on how to steer, turn, slow down, etc. based on other objects, lane lines, entrance lanes, exit lanes, etc. within the map. Autonomous vehicles may use one or more computer systems to control the vehicle to move autonomously without user input. For example, the vehicle may be equipped with an autonomous vehicle (AV) system that generates signals for controlling the engine, the steering wheel, the brakes, and the like, based on other objects, lane lines, entrance lanes, and exit lanes, within the map.
In the example embodiments, a network of vehicles may be connected to a shared host platform, such as a cloud platform, a web server, or the like. The vehicles may use hardware sensor, for example, lidar, cameras, radar, and the like, to sense the world around them while they are driving. In addition, the vehicles may store decisions made by an autonomous vehicle (AV) system such as a planner, as well as intermediate calculations made by the planner, when making control decisions for the vehicle. This information may be uploaded to the host platform and labeled with a particular ID. For example, a driving data from a ten-hour trip/run may be labeled with an identifier of the trip, an identifier of the vehicle that performed the trip, and the like.
Furthermore, users can also access/connect to the shared host platform via a user interface, or the like. Here, the users can request a piece of self-driving code be tested based on previously-captured driving data from one or more of the vehicles that have uploaded data to the shared host platform, including the same vehicle where the self-driving code is being tested. The user may also specify a run/trip of driving data (for example by providing the ID of the run, etc.) to be used for testing the self-driving code. In response, the host may break-up the testing into a plurality of simulation tasks where each simulation task simulates a different small segment of driving data from the run/trip. By breaking up the simulation into many small simulations, the simulations can be run in parallel via a plurality of workers on the host platform. As a result, the testing of the self-driving code may be reduced from ten hours of time to a few seconds of time.
In some of the examples herein, the vehicle is illustrated as a semi-truck. However, it should be appreciated that the example embodiments are applicable to any kind of autonomous vehicle and not just trucks or semi-trucks but instead may include cars, boats, tractors, motorcycles, and the like, as well as trucks of all kinds. Furthermore, in the examples herein, terms like “minimum”, “maximum”, “safe”, “conservative”, and the like, may be used. These terms should not be construed as limiting any type of distance or speed in any way.
The computer system 140 may be configured with one or more central processing units (CPUs) 142 to perform processing including processing to implement features of embodiments of the present invention as described elsewhere herein as well as to receive sensor data from sensors 110 for use in generating control signals to control one or more actuators or other controllers associated with systems of the vehicle (including, for example, actuators or controllers allowing control of a throttle 184, steering systems 186, brakes 188 or the like). In general, the control system 100 may be configured to operate the semi-truck 00 in an autonomous (or semi-autonomous) mode of operation.
In operation, the control system 100 may be operated to capture images from one or more cameras 112 mounted on various locations of the semi-truck 200 and perform processing (such as image processing) on those images to identify objects proximate or in a path of the semi-truck 200. Further, lidar 114 and radar 116 sensors may be positioned to sense or detect the presence and volume of objects proximate or in the path of the semi-truck 200. Other sensors may also be positioned or mounted on various locations of the semi-truck 200 to capture other information such as position data. For example, the sensors may include one or more satellite positioning sensors and/or inertial navigation systems such as GNSS/IMU 118. A Global Navigation Satellite System (GNSS) is a space-based system of satellites that provide the location information (longitude, latitude, altitude) and time information in all weather conditions, anywhere on or near the Earth to devices called GNSS receivers. GPS is the world's most used GNSS system. An inertial measurement unit (“IMU”) is an inertial navigation system. In general, an inertial navigation system (“INS”) measures and integrates orientation, position, velocities, and accelerations of a moving object. An INS integrates the measured data, where a GNSS is used as a correction to the integration error of the INS orientation calculation. Any number of different types of GNSS/IMU 118 sensors may be used in conjunction with features of the present invention. The data collected by each of these sensors may be processed by the computer system 140 to generate control signals that control the operation of the semi-truck 200. The images and location information may be processed to identify or detect objects around or in the path of the semi-truck 200 and control signals may be emitted to adjust the throttle 184, steering 186 or brakes 188 as needed to safely operate the semi-truck 200. While illustrative example sensors and actuators or vehicle systems are shown in
The control system 100 may include a computer system 140 (such as a computer server) which is configured to provide a computing environment in which one or more software or control applications (such as items 160-182) may be executed to perform the processing described herein. In some embodiments, the computer system 140 includes components which are deployed on a semi-truck 200 (e.g., they may be deployed in a systems rack 240 positioned within a sleeper compartment 212 as shown in
In some examples, the computer system 140 may be implemented as a server. Furthermore, the computer system 140 may configured using any of a number of well-known computing systems, environments, and/or configurations such as, but not limited to, personal computer systems, cloud platforms, server computer systems, thin clients, thick clients, hand-held or laptop devices, tablets, smart phones, databases, multiprocessor systems, microprocessor-based systems, set top boxes, programmable consumer electronics, network PCs, minicomputer systems, mainframe computer systems, distributed cloud computing environments, and the like, which may include any of the above systems or devices, and the like.
A number of different software applications or components may be executed by the computer system 140 and the control system 100. For example, as shown, applications may be provided which perform active learning machine processing (active learning component 160) to process images captured by one or more cameras 112 and information obtained by lidar 114. For example, image data may be processed using deep learning segmentation models 162 to identify objects of interest in those images (such as, for example, other vehicles, construction signs, etc.). Lidar data may be processed by the machine learning applications 164 to draw or identify bounding boxes on image data to identify objects of interest located by the lidar sensors. Information output from the machine learning applications may be provided as inputs to object fusion 168 and vision map fusion 170 software components which may perform processing to predict the actions of other road users and to fuse local vehicle poses with global map geometry in real-time, enabling on-the-fly map corrections. The outputs from the machine learning applications may be supplemented with information from radars 116 and map localization 166 application data (as well as with positioning data). These applications allow the control system 100 to be less map reliant and more capable of handling a constantly changing road environment. Further, by correcting any map errors on the fly, the control system 100 can facilitate safer, more scalable and more efficient operations as compared to alternative map-centric approaches. Information is provided to prediction and planning application 172 which provides input to trajectory planning 174 components allowing a trajectory 176 to be generated in real time based on interactions and predicted interactions between the semi-truck 200 and other relevant vehicles in the environment. In some embodiments, for example, the control system 100 generates a sixty second planning horizon, analyzing relevant actors and available trajectories. The plan that best fits multiple criteria (including safety, comfort and route preferences) is selected and any relevant control inputs needed to implement the plan are provided to controllers 182 to control the movement of the semi-truck 200.
These applications or components (as well as other components or flows described herein) may be implemented in hardware, in a computer program executed by a processor, in firmware, or in a combination of the above. A computer program may be embodied on a computer readable medium, such as a storage medium or storage device. For example, a computer program may reside in random access memory (“RAM”), flash memory, read-only memory (“ROM”), erasable programmable read-only memory (“EPROM”), electrically erasable programmable read-only memory (“EEPROM”), registers, hard disk, a removable disk, a compact disk read-only memory (“CD-ROM”), or any other form of storage medium known in the art.
A storage medium may be coupled to the processor such that the processor may read information from, and write information to, the storage medium. In an alternative, the storage medium may be integral to the processor. The processor and the storage medium may reside in an application specific integrated circuit (“ASIC”). In an alternative, the processor and the storage medium may reside as discrete components. For example,
The computer system 140 may be described in the general context of computer system-executable instructions, such as program modules, being executed by a computer system. Generally, program modules may include routines, programs, objects, components, logic, data structures, and so on that perform particular tasks or implement particular abstract data types. The computer system 140 may be embodied in distributed cloud computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed cloud computing environment, program modules may be located in both local and remote computer system storage media including memory storage devices.
As shown in
The storage device 150 may include a variety of types and forms of computer readable media. Such media may be any available media that is accessible by computer system/server, and it may include both volatile and non-volatile media, removable and non-removable media. System memory, in one embodiment, implements the flow diagrams of the other figures. The system memory can include computer system readable media in the form of volatile memory, such as random-access memory (RAM) and/or cache memory. As another example, storage device 150 can read and write to a non-removable, non-volatile magnetic media (not shown and typically called a “hard drive”). Although not shown, the storage device 150 may include one or more removable non-volatile disk drives such as magnetic, tape or optical disk drives. In such instances, each can be connected to the bus by one or more data media interfaces. Storage device 150 may include at least one program product having a set (e.g., at least one) of program modules that are configured to carry out the functions of various embodiments of the application.
In the examples further described herein, the control system 100 in the example of
In the example embodiments, autonomous vehicles may upload driving data from a trip or a route which includes sensor data, log data, decisions made by the AV system, calculations made by the AV system, intermediate determinations, such as planner inputs, outputs, etc., and the like. Code developers may access the data and use it to test newly developed self-driving code such as a new code module or an update to an existing code module. The driving data may be stored in a distributed storage environment where it is made accessible at each of a plurality of different computers/endpoints with different/distributed geographical locations making the driving data more easily accessible.
Driving data may include, but is not limited to, sensor data captured by a vehicle using any of the equipment or devices shown and described in
According to various embodiments, within the computing environment 300, code developers that develop the code (e.g., self-driving code, etc.) for the vehicles 330, 332, and 334 may use the driving data uploaded by the vehicles 330, 332, and 334, to test the code via a simulation application hosted by the host platform 320 (or possibly on another host system that is electrically connected to the host platform 320. For example, a user such as a code developer may use a user device 310 to submit a simulation request to the host platform. The driving data uploaded by the vehicles 330, 332, and 334 may be made available to the public or to permissioned users with registered access by the host platform 320. Furthermore, the host platform 320 may be a distributed platform such as a distributed cloud platform that provides different geographical access points to make the data even more accessible. The driving data may be captured by the vehicles 330, 332, 334, and then stored at the vehicles 330, 332, and 334, respectively, or transferred from the vehicles 330, 332, and 334, and stored elsewhere such as a server, a distributed storage platform, or the like. When the driving data is requested by a code developer, the driving data may be retrieved from the vehicles 330, 332, 334 themselves, or it may be retrieved from the storage elsewhere such as the server or distribute storage platform and delivered to the developer via a computer network.
As an example, the request 312 may be sent from a user interface that enables a user to search for and select previous trips performed by any of the vehicles 330, 332, and 334, such as the user interface 500 shown in
As just one example, a user may select a particular vehicle using an input field such as field 502 (e.g., a drop-down box, a text content field, etc.) and input the name or other identifier of the vehicle. In response, the possible trips that are available in the trip ID input field 504 (such as another drop down box, radio button, or the like) may be refined to show only the trip IDs of that particular vehicle from among all the available vehicles on the system. Thus, a developer may choose the same vehicle where the self-driving code is to be uploaded. In this case, the developer may choose previous driving data of the same vehicle to thereby test the new self-driving code.
Referring again to
According to various embodiments, each simulation task from among the plurality of simulation tasks 351-355 may test the self-driving code (code 314) using a different subset of the driving data. For example, the driving data may be sliced into predefined chunks or segments each having a predetermined amount (of driving time) of driving data. As an example, each chunk may include 10 seconds of driving data, but embodiments are not limited thereto. It should also be appreciated that the chunk size may be configured dynamically. For example, one software may be tested using 10 second intervals of data chunks and another software may be tested using 60 second intervals of data chunks.
As shown in
In the example of
In some embodiments, the host platform 320 may compress the code 314 that is used to execute the simulation tasks 351-355 via the plurality of workers 361-365.
Referring to
In the example of
In this example, the binary code that the workers are going to run is compressed. The data itself is already compressed. Compressing the actual runtime executable that these workers are going to be using can save significant processing time. To perform this process, the host platform 320 may analyze software that the simulation task is going to run which may be defined in a launch file. Here, the host platform may inspect the launch file and determine the pieces of software to be built, the dependencies among the pieces of software, what codes needs to be built, and files to be included and accessed by the code at runtime. In the example of
In this simple example, the vehicle 402 captures 65 seconds of driving data and stores the driving data as a trip on the host platform. Here, the chunk size is equal to 10 seconds. Thus, seven (7) files is needed to hold the 65 seconds of data with the seventh file only having five seconds of data. In this example, the most recently captured data (i.e., the seventh file 470) is actually a current time.
Referring to
The files 410-470 may include a header which identifies information about the file such as op codes which can be used to distinguish between different types of header and also identify the types of data within the file. For example, each file may include an identifier of the data chunk, connection data including a name of a topic where the data is to be stored, etc., message data, index data, chunk information, worker information, and the like. The driving data may initially be stored in files of the predetermined size (e.g., 10 seconds). Thus, the initial process of storing the data may prepare it for a subsequent request to simulate self-driving code using the data.
In 620, the method may include dividing the driving data into a plurality of data chunks. In some embodiments, the dividing of the driving data may be performed in advance based on storage characteristics of the file protocol used by the host platform to the store the driving data. In 630, the method may include compressing the self-driving code to create compressed self-driving code. Here, the host may analyze attributes of the self-driving code such as the tasks and functions stored within a launch file of the self-driving code. In 640, the method may include generating a plurality of simulation tasks for testing the self-driving code based on the plurality of driving data chunks, respectively. In 650, the method may include executing the plurality of simulation tasks in parallel via a plurality of workers of the host platform, respectively. In 660, the method may include storing execution results of the plurality of simulation tasks via a memory.
In some embodiments, the receiving may include receiving the driving data over a computer network from a vehicle on a road, and storing the received driving data in a plurality of files corresponding to the plurality of data chunks. In some embodiments, the dividing may include breaking-up the driving data into equal-sized data chunks based on driving time of the driving data, and storing each equal-sized data chunk in a different file from among the plurality of files. In some embodiments, the method may further include executing a script which pulls the plurality of simulation tasks from a queue and assigns the plurality of simulation tasks to the plurality of workers based on predefined instructions within the script.
In some embodiments, the self-driving code comprises an update to a previously-created self-driving code previously stored on a vehicle, and the driving data is captured from a single run of the vehicle. In some embodiments, the method may further include spawning the plurality of workers, compiling the self-driving code into an executable file, and executing the executable file with the self-driving code on each of the plurality of workers.
In some embodiments, the executing may include assigning the mutually exclusive data chunks from the driving data to each worker from among the plurality of workers. In some embodiments, the driving data comprises sensor data captured and recorded by a vehicle, decisions made by an autonomous vehicle (AV) system of the vehicle, and planning data created by the AV system of the vehicle.
As will be appreciated based on the foregoing specification, the above-described examples of the disclosure may be implemented using computer programming or engineering techniques including computer software, firmware, hardware or any combination or subset thereof. Any such resulting program, having computer-readable code, may be embodied or provided within one or more non transitory computer-readable media, thereby making a computer program product, i.e., an article of manufacture, according to the discussed examples of the disclosure. For example, the non-transitory computer-readable media may be, but is not limited to, a fixed drive, diskette, optical disk, magnetic tape, flash memory, external drive, semiconductor memory such as read-only memory (ROM), random-access memory (RAM), and/or any other non-transitory transmitting and/or receiving medium such as the Internet, cloud storage, the Internet of Things (IoT), or other communication network or link. The article of manufacture containing the computer code may be made and/or used by executing the code directly from one medium, by copying the code from one medium to another medium, or by transmitting the code over a network.
The computer programs (also referred to as programs, software, software applications, “apps”, or code) may include machine instructions for a programmable processor, and may be implemented in a high-level procedural and/or object-oriented programming language, and/or in assembly/machine language. As used herein, the terms “machine-readable medium” and “computer-readable medium” refer to any computer program product, apparatus, cloud storage, internet of things, and/or device (e.g., magnetic discs, optical disks, memory, programmable logic devices (PLDs)) used to provide machine instructions and/or data to a programmable processor, including a machine-readable medium that receives machine instructions as a machine-readable signal. The “machine-readable medium” and “computer-readable medium,” however, do not include transitory signals. The term “machine-readable signal” refers to any signal that may be used to provide machine instructions and/or any other kind of data to a programmable processor.
The above descriptions and illustrations of processes herein should not be considered to imply a fixed order for performing the process steps. Rather, the process steps may be performed in any order that is practicable, including simultaneous performance of at least some steps. Although the disclosure has been described in connection with specific examples, it should be understood that various changes, substitutions, and alterations apparent to those skilled in the art can be made to the disclosed embodiments without departing from the spirit and scope of the disclosure as set forth in the appended claims.