Improvements in autonomous vehicle technology will result in less and less human interaction with the vehicle. Even a fully autonomous vehicle, however, occasionally relies on some human interaction. Accordingly, fully autonomous vehicles are equipped with traditional control interfaces such as a steering wheel, an accelerator pedal, a brake pedal, etc.
At a certain point, autonomous vehicles will require little to no human interaction the vast majority of the time. Thus, certain controllers associated with manually operating the vehicle, such as a steering wheel, an accelerator pedal, a brake pedal, etc., may be omitted from the vehicle to, e.g., increase cabin space.
Removing some of those or other controllers may introduce other challenges, however. For instance, airbags are sometimes incorporated into the steering wheel. Further, there are times when an autonomous vehicle may need to be manually operated such as on a production line or in a service station to, e.g., drive the vehicle onto a lift or if the autonomous vehicle controller malfunctions. Therefore, completely omitting controllers from the vehicle may be too limiting under a very specific, yet significant, set of circumstances.
One way to increase cabin space in fully autonomous vehicles while not completely preventing use of particular controllers includes replacing traditional controllers with removable by-wire (or wireless) controllers. Thus, an example autonomous vehicle controller interface for removable controllers includes communication circuitry programmed to communicate with the removable controller. The system further includes a processor programmed to receive control signals, which are associated with manually controlling the autonomous vehicle in a non-autonomous mode, transmitted from the controller. The processor is further programmed to output commands to at least one vehicle subsystem in accordance with the control signals transmitted from the controller while the vehicle is operating in a non-autonomous mode.
Thus, the vehicle can generally operate in an autonomous mode without relying on inputs from the controllers and without the controllers being inside the vehicle. However, for those infrequent times a controller is needed, a controller can be temporarily installed and used to manually control the otherwise autonomous vehicle.
The elements shown may take many different forms and include multiple and/or alternate components and facilities. The example components illustrated are not intended to be limiting. Indeed, additional or alternative components and/or implementations may be used. Further, the elements shown are not necessarily drawn to scale unless explicitly stated as such.
As illustrated in
The controller interface 105 may communicate with the controller 110 via a wired or wireless communication interface. The controller interface 105 may receive and process control signals output by the controller 110 that are associated with the manual control of the autonomous host vehicle 100. The controller interface 105 may output commands to various other vehicle subsystems 115 (see
In some possible implementations, the controller interface 105 may output commands to the controllers 110. For instance, in the instance where the controller 110 includes a passive restraint with an airbag, which may be a standalone device or integrated into a removable steering wheel, the controller interface 105 may output a command causing the airbag to inflate in response to, e.g., detecting a crash.
Moreover, the controller interface 105 may arbitrate control signals output by the controllers 110 and one or more controllers controlling various operations of the autonomous host vehicle 100. By arbitrating the control signals, the controller interface 105 may determine which control signals should be output to the respective vehicle subsystems 115 to autonomously or non-autonomously (manually) control the host vehicle 100.
The controller interface 105 may include several physical connections for receiving the various controllers 110. For instance, one or more brackets 120 (see
Further, the controller interface 105 may communicate with the controllers 110 via wired communication, wireless communication, or both. For wired communication, the controller interface 105 may include multiple wire harnesses 125 (see
The controller interface 105 may be further programmed to control whether the host vehicle 100 is operating in an autonomous mode, a non-autonomous mode, or a partially autonomous mode. If, for example, the appropriate controllers 110 are plugged into the brackets 120 and wire harnesses 125, or otherwise in communication with the controller interface 105 and ready to control the host vehicle 100 (i.e., able to output control signals), the controller interface 105 may command the host vehicle 100 to operate in a non-autonomous mode meaning that the control signals output by the controller 110 may take precedence over the control signals output by one or more controllers associated with autonomous vehicle operation.
In some instances, the controller interface 105 may only pass control signals output by the controllers 110 to various vehicle subsystems 115 in response to a user input indicating the user's intent to manually control the host vehicle 100.
Although illustrated as a sedan, the autonomous host vehicle 100 may include any passenger or commercial automobile such as a car, a truck, a sport utility vehicle, a crossover vehicle, a van, a minivan, a taxi, a bus, etc., that can operate in an autonomous (e.g., driverless) mode, a partially autonomous mode, and/or a non-autonomous mode.
The user interface 130 may include any number of electronic components that can present information to a vehicle occupant. In addition to presenting information, the user interface 130 may be programmed to receive user inputs. In response to a user input, the user interface 130 may output a signal, representing the user input, to the processor 140. The user interface 130 may be located in the passenger compartment of the autonomous host vehicle 100 and, in some possible approaches, the user interface 130 may include a touch-sensitive display screen. Further, the user interface may be incorporated into the controller interface 105 (as shown in
The communication circuitry 135 may include any number of electronic components, such as an integrated circuit and possibly other components, that facilitate wired or wireless communication between components of the controller interface 105 and the controllers 110. For wireless communication (as shown in
The processor 140 may include any number of electronic components programmed to receive and process the control signals output by the controller 110. The processor 140 may process the control signals and, in some circumstances, generate commands to control the autonomous host vehicle 100 in accordance with the control signals. For instance, the processor 140 may be programmed to ignore the control signals unless a user input has been received indicating that the vehicle occupant is ready to operate the autonomous host vehicle 100 in a non-autonomous mode and that the communication circuitry 135 has already established communication with the controller 110. Under these circumstances, the processor 140 may be programmed to generate and output the commands based on the control signals, effectively causing the autonomous host vehicle 100 to operate in a non-autonomous mode.
In some instances, the processor 140 may command the autonomous mode controller 150, autonomous driving sensors 145, or both, to shut down while the autonomous host vehicle 100 is operating in the non-autonomous mode. Alternatively, the processor 140 may arbitrate the signals output by the controller 110 and autonomous mode controller 150 to determine which signals should be used to control the vehicle subsystems 115 in either an autonomous or non-autonomous mode. In yet another possible implementation, the processor 140 may provide the command signals based on the control signals to the autonomous mode controller 150, which in turn may output the command signals to the various vehicle subsystems 115. In this implementation, the autonomous mode controller 150 may give command signals output by the processor 140 higher priority than the signals the autonomous mode controller 150 would generate on its own to autonomously control the host vehicle 100.
The autonomous driving sensors 145 may include any number of electronic components that generate signals that help navigate the host vehicle 100 while the host vehicle 100 is operating in the autonomous (e.g., driverless) mode. Examples of autonomous driving sensors 145 may include a radar sensor, a lidar sensor, a vision sensor, or the like. Thus, the autonomous driving sensors 145 help the vehicle “see” the roadway and the vehicle surroundings and/or negotiate various obstacles while the vehicle is operating in the autonomous mode.
The autonomous mode controller 150 may include any number of electronic components that can control one or more vehicle subsystems 115 while the host vehicle 100 is operating in the autonomous mode. Examples of subsystems that may be controlled by the autonomous mode controller 150 may include a brake subsystem, a suspension subsystem, a steering subsystem, and a powertrain subsystem. The autonomous mode controller 150 may be programmed to control any one or more of these subsystems by outputting signals to control units associated with these subsystems. The autonomous mode controller 150 may control the subsystems based, at least in part, on signals generated by the autonomous driving sensors 145 or the command signals output by the processor 140, which has discussed above may be based on the control signals output by the controller 110.
Referring now to
The controller interface 105 may include other ports 160 as well. For instance, as shown in
When the controller 110 includes a steering wheel or any other type of steering device, the controller 110 may include an accelerometer or other type of motion sensor 175 programmed to detect movement, including measuring an angle request. The angle request may include, e.g., the desired angle of rotation as if the user were turning a traditional steering wheel. The motion sensor 175 may be programmed to transmit, via a wired or wireless communication link, the angle request to the communication circuitry 135. The communication circuitry 135 may, in turn, transmit the angle request to the processor 140 so that the processor 140 may control one or more vehicle subsystems 115, such as a steering subsystem, in accordance with the angle request.
When the controller 110 includes an accelerator or brake pedal, such as shown in
Referring now to
Wireless communication with the controller 110 may permit the controller 110 to take a different form than a traditional steering wheel. Examples of non-traditional controllers 110 may include, e.g., a game controller, a joystick, a smartphone, a tablet computer, or any other electronic device that can include an accelerometer or other type of motion sensor 175 or directional control and that can wirelessly communicate with the controller interface 105. While the same is true for the implementation shown with respect to
The controller 110 of
Further, even though one controller 110 may wirelessly communicate with the controller interface 105, others, such as the accelerator pedal and brake pedal, may still be connected via the bracket 120 and wired connection. Alternatively, as is the case with
In general, the computing systems and/or devices described may employ any of a number of computer operating systems, including, but by no means limited to, versions and/or varieties of the Ford Sync® application, AppLink/Smart Device Link middleware, the Microsoft Automotive® operating system, the Microsoft Windows® operating system, the Unix operating system (e.g., the Solaris® operating system distributed by Oracle Corporation of Redwood Shores, Calif.), the AIX UNIX operating system distributed by International Business Machines of Armonk, N.Y., the Linux operating system, the Mac OSX and iOS operating systems distributed by Apple Inc. of Cupertino, Calif., the BlackBerry OS distributed by Blackberry, Ltd. of Waterloo, Canada, and the Android operating system developed by Google, Inc. and the Open Handset Alliance, or the QNX® CAR Platform for Infotainment offered by QNX Software Systems. Examples of computing devices include, without limitation, an on-board vehicle computer, a computer workstation, a server, a desktop, notebook, laptop, or handheld computer, or some other computing system and/or device.
Computing devices generally include computer-executable instructions, where the instructions may be executable by one or more computing devices such as those listed above. Computer-executable instructions may be compiled or interpreted from computer programs created using a variety of programming languages and/or technologies, including, without limitation, and either alone or in combination, Java™, C, C++, Visual Basic, Java Script, Perl, etc. Some of these applications may be compiled and executed on a virtual machine, such as the Java Virtual Machine, the Dalvik virtual machine, or the like. In general, a processor (e.g., a microprocessor) receives instructions, e.g., from a memory, a computer-readable medium, etc., and executes these instructions, thereby performing one or more processes, including one or more of the processes described herein. Such instructions and other data may be stored and transmitted using a variety of computer-readable media.
A computer-readable medium (also referred to as a processor-readable medium) includes any non-transitory (e.g., tangible) medium that participates in providing data (e.g., instructions) that may be read by a computer (e.g., by a processor of a computer). Such a medium may take many forms, including, but not limited to, non-volatile media and volatile media. Non-volatile media may include, for example, optical or magnetic disks and other persistent memory. Volatile media may include, for example, dynamic random access memory (DRAM), which typically constitutes a main memory. Such instructions may be transmitted by one or more transmission media, including coaxial cables, copper wire and fiber optics, including the wires that comprise a system bus coupled to a processor of a computer. Common forms of computer-readable media include, for example, a floppy disk, a flexible disk, hard disk, magnetic tape, any other magnetic medium, a CD-ROM, DVD, any other optical medium, punch cards, paper tape, any other physical medium with patterns of holes, a RAM, a PROM, an EPROM, a FLASH-EEPROM, any other memory chip or cartridge, or any other medium from which a computer can read.
Databases, data repositories or other data stores described herein may include various kinds of mechanisms for storing, accessing, and retrieving various kinds of data, including a hierarchical database, a set of files in a file system, an application database in a proprietary format, a relational database management system (RDBMS), etc. Each such data store is generally included within a computing device employing a computer operating system such as one of those mentioned above, and are accessed via a network in any one or more of a variety of manners. A file system may be accessible from a computer operating system, and may include files stored in various formats. An RDBMS generally employs the Structured Query Language (SQL) in addition to a language for creating, storing, editing, and executing stored procedures, such as the PL/SQL language mentioned above.
In some examples, system elements may be implemented as computer-readable instructions (e.g., software) on one or more computing devices (e.g., servers, personal computers, etc.), stored on computer readable media associated therewith (e.g., disks, memories, etc.). A computer program product may comprise such instructions stored on computer readable media for carrying out the functions described herein.
With regard to the processes, systems, methods, heuristics, etc. described herein, it should be understood that, although the steps of such processes, etc. have been described as occurring according to a certain ordered sequence, such processes could be practiced with the described steps performed in an order other than the order described herein. It further should be understood that certain steps could be performed simultaneously, that other steps could be added, or that certain steps described herein could be omitted. In other words, the descriptions of processes herein are provided for the purpose of illustrating certain embodiments, and should in no way be construed so as to limit the claims.
Accordingly, it is to be understood that the above description is intended to be illustrative and not restrictive. Many embodiments and applications other than the examples provided would be apparent upon reading the above description. The scope should be determined, not with reference to the above description, but should instead be determined with reference to the appended claims, along with the full scope of equivalents to which such claims are entitled. It is anticipated and intended that future developments will occur in the technologies discussed herein, and that the disclosed systems and methods will be incorporated into such future embodiments. In sum, it should be understood that the application is capable of modification and variation.
All terms used in the claims are intended to be given their ordinary meanings as understood by those knowledgeable in the technologies described herein unless an explicit indication to the contrary is made herein. In particular, use of the singular articles such as “a,” “the,” “said,” etc. should be read to recite one or more of the indicated elements unless a claim recites an explicit limitation to the contrary.
The Abstract is provided to allow the reader to quickly ascertain the nature of the technical disclosure. It is submitted with the understanding that it will not be used to interpret or limit the scope or meaning of the claims. In addition, in the foregoing Detailed Description, it can be seen that various features are grouped together in various embodiments for the purpose of streamlining the disclosure. This method of disclosure is not to be interpreted as reflecting an intention that the claimed embodiments require more features than are expressly recited in each claim. Rather, as the following claims reflect, inventive subject matter lies in less than all features of a single disclosed embodiment. Thus the following claims are hereby incorporated into the Detailed Description, with each claim standing on its own as a separately claimed subject matter.