RESTRICTING MOBILE DEVICE USAGE
TECHNICAL FIELD OF THE INVENTION
This disclosure relates generally to the field of mobile device identification, and, in particular, to computer-implemented systems and methods for determining roles relating to and usages of a mobile device.
BACKGROUND OF THE INVENTION
There are approximately 4.6 billion cellular phone subscriptions in the world over which it is estimated that more than 2 trillion text (SMS) messages are sent annually. There are also over 800 million transportation vehicles in the world. The magnitude of these statistics indicates that cellular phone use in vehicles is inevitable and is likely to remain quite common, unless preventative measures are taken.
Drivers using a hand-held cellular phone or smartphone for talking, text messaging, and/or for executing other applications or 'apps' while driving has become a problem of near-epidemic proportions. Studies on distracted driving have shown that by talking on a cell phone, a driver increases his/her risk of an accident by a factor of four. Even worse, sending text messages increases a driver's accident risk 23- fold. Additionally, studies have shown that the temptation to use a cellular phone for texting, talking, and other activities while operating a vehicle is not limited to younger drivers - adult drivers have been shown to text more often than younger ones.
In response to this growing concern and danger, numerous regulatory actions have been put in place to attempt to mitigate such phone-based distractions to drivers. For example, in ths United States, thirty states have banned drivers of vehicles from texting, and many have subsequently increased the penalties for such violations. Driving-while-texting has also been banned throughout Europe and manyother countries around the world. Additionally, talking on a hand-held cellular phone while driving a vehicle has been banned in eight US states, and such cell phone use has been banned in all of Europe and in other countries.
The effectiveness of these laws alone, without an effective means of enforcement, is questionable. Being that cellular phones are generally small and discreet and drivers are frequently in motion, it is often difficult for law enforcement personnel to effectively police for such violations. Indeed, statistics show that accidents arising from cellular phone-based distractions are increasing as the popularity of such devices increases.
Given the easy accessibility of cell phones to drivers, many drivers' apparent desire to operate their cellular phones -while driving, and the difficulties attendant with enforcing laws prohibiting cellular phone use, it is likely that drivers will continue to use cellular phones for texting, talking, and/or other activities (e.g., playing gam^s or running applications), for the foreseeable future.
Moreover, it can be appreciated that the usage of mobile devices in various locations and/or settings can be detrimental on a number of levels. For instance, anecdotal evidence suggests that the
proliferation of mobile devices such as smartphones has resulted in an increase of mobile device usage by students during classes/lectures, serving to distract such students from properly absorbing the material being taught. Additionally, many students have become adept at using such devices discreetly, resulting in many instances of cheating being facilitated through the use of mobile devices.
It is with respect to these and other considerations that the disclosure made herein is presented.
SUMMARY OF THE INVENTION
Technologies are presented herein in support of a system and method for determining an in- vehicle role of a user of a mobile device. According to one aspect, a computer-implemented method for selectively restricting a mobile device is provided. The method includes: receiving a visual capture, the visual capture originating at the mobile device; processing the visual capture with one or more processors to identify one or more indicators within the visual capture; and, based on the one or more indicators, adjusting an implementation of a restriction at the mobile device.
According to another aspect, a computer-implemented method for selectively restricting a mobile device using a central machine. The method includes: receiving a visual capture, the visual capture originating at the mobile device; processing the visual capture with one or more processors to identify one or moire indicators wit!xhi the visual capture; and, based on the one or more indicators, adjusting an implementation of a restriction in relation to the mobile device.
According to another aspect, a computer-implemented method for selectively modifying a first restriction employed at a mobile device is provided. The method includes: receiving one or more inputs; processing, with one or more processors, the one or more inputs to compute one or more trends; and modifying an implementation of the first restriction based on the one or more trends.
According to another aspect, a computer-implemented method for selectively modifying, with a central machine, a first restriction employed at a mobile device is provided. The method includes: receiving one or more inputs; processing, with one or more processors, the one or more inputs to compute one or more trends; and modifying an implementation of the first restriction in relation to the mobile d¾wice based o.'\the onc or more trends.
According tc ano$¾ers aspect, a computer-implemented method for authenticating an in vehicle rob of a user of a mobile 'device is provided. The method includes: receiving one or more first inputs; processing, with one or more processors, the one or more first inputs to compute a first determination, the first determination reflecting at least one of the in-vehicle role of the user as a driver and the in-vehicle role of the user as a passenger; and modifying at least one operation state of the mobile device based on the first determination.
According to . another aspect, a computer- implemented method for authenticating an in vehicle role of a user of a mobile device using a central machine is provided. The method includes: receiving one or.more first inputs; ocessing, with one or more processors, the one or more first inputs to compute a first' determination, the first determination -reflecting at least one of the in-vehicle role of the user as a driver and the in-vshicle role of the user as a passenger; and causing a modification to at least one operation state of the mobile device based on the first determination.
According to another aspect, a computer-implemented method for eliciting an authentication at a mobile device is provided, the mobile device having a first authentication mode and a second authentication mode. The method includes: receiving one or more inputs; processing, with one or more
v
processors, the one or more inputs to compute a determination, the determination reflecting a degree of distraction; and, based on the determination, employing at least one of the first authentication mode and the second authentication mode at the mobile device.
According to another aspect, a computer-implemented method for configuring, using a central machine, one or more authentication modes employed at a mobile device is provided, the mobile device having a first authentication mode and a second authentication mode. The method includes: receiving one or more inputs; processing, with one or more processors, the one or more inputs to compute a determination, the determination reflecting a degree of distraction; and, based on the determination, configuring, in relation to the mobile device, an employment of at least one of the first authentication mode and the second authentication mode.
According to another aspect, a computer-implemented method for eliciting an authentication at a mobile device is provided, the mobile device having a first authentication mode and a second authentication mode. The method includes: employing, with one or more processors, the first authentication mode; receiving a first authentication attempt; and, based on the first authentication attempt, employing the second authentication mode.
According to another aspect, a computer-implemented method for selectively restricting a mobile device is provided. The method includes: receiving one or more inputs; processing, with one or more processors, the one or more inputs to determine a presence of a passenger within a vehicle; and adjusting an implementation of a restriction at the mobile device.
According to another aspect, a computer-implemented method for selectively restricting a mobile device using a central machine is provided. The method includes: receiving one or more inputs; processing, with one or more processors, the one or more inputs to determine a presence of a passenger within a vehicle; and adjusting an implementation of a restriction in relation to the mobile device.
According to another aspect, a computer implemented method for selectively modifying a restriction employed at a mobile device is provided. The method includes: projecting one or more outputs; receiving one or more inputs; processing, with one or more processors, the one or more outputs and the one or more inputs to determine a correlation between the one or more outputs and the one or more inputs; and modifying the restriction based on the correlation.
According to another aspect, a computer implemented method for selectively modifying a restriction employed at a mobile device using a central machine is provided. The method includes: configuring the mobile device to project one or more outputs; receiving one or more inputs; processing, with one or more processors, the one or more outputs and the one or more inputs to determine a correlation between the one or more outputs and the one or more inputs; and modifying the restriction based on the correlation.
According to another aspect, a computer implemented method for selectively projecting outputs at a mobile device is provided. The method includes: receiving one or more inputs; processing, with one or more processors, the one or more inputs with one or more operation signatures to determine a first correlation, the first correlation comprising a correlation between the one or more inputs and the one or more operation signatures; and projecting one or more outputs based on the first correlation.
According to another aspect, a computer implemented method for selectively configuring overt operation of a mobile device is provided. The method includes: employing a first restriction at the mobile device, the first restriction configuring the mobile device to operate in an overt mode; receiving one or more first inputs; processing, with one or more processors, the one or more inputs to compute a determination that reflects an operation state of the mobile device; and modifying an employment of the first restriction based on the determination.
According to another aspect, a method for selectively restricting an operation of a mobile device within a vehicle is provided, the mobile device having a first sensor. The method includes: receiving a first input from the first sensor, the first input corresponding to a visual capture; processing the first input to determine at least one of an orientation of the device and a relative location of the device within the vehicle; based on the determination of at least one of the orientation of the device and the relative location of the device within the vehicle, at least one of: employing one or more restrictions of the mobile device, modifying one or more previously employed restrictions of the mobile device, and removing one or more of the previously employed restrictions of the mobile device.
According to another aspect, a method for selectively restricting an operation of a mobile device within a vehicle is provided, the mobile device having a first sensor, a second sensor, and a third sensor. The method includes: receiving a first input from the first sensor, the first input corresponding to an GPS heading of the mobile device; receiving a second input from the second sensor, the second input corresponding to an absolute directional orientation of the mobile device; receiving a third input from the third sensor, the third input corresponding to a visual capture; processing the first input, the second input, and the third input to determine a relative location of the device within the vehicle; based on the , determination of the relative location of the device within the vehicle, at least one of: employing one or more restrictions of the mobile device, modifying one or more previously employed restrictions of the mobile device, and removing one or more previously employed restrictions of the mobile device.
According to another aspect, a method for modifying a restriction of a mobile device is provided, the mobile device having at least a first sensor. The method includes: receiving a first input from a first sensor, the first input corresponding to a first visual capture; processing at least the first input to identify at least one in-vehicle role indicator; and, based on the at least one in-vehicle role indicator, modifying the restriction, of the mobile device.
According to anoiher aspect, a method for selectively restricting an operation of a mobile device within at least one of (a) a geographic area; and (b) a date/time window is provided. The method includes: determining at least one of: a presence of an audio input while the device is within the geographic area and/or date/time window, an absence of the audio input while the device is at least one of
present within the geographic area and operating within the date/time window, and an absence of a correlation between a first input and a second input while the device is at least one of present within the geographic area and operating within the date/time window, a presence of a correlation between a first input and a second input while the device is at least one of present within the geographic area and operating within the date/time window; and based on the determining, at least one of: employing one or more restrictions of the mobile device, modifying one or more previously employed restrictions of the mobile device, and removing one or more previously employed restrictions of the mobile device.
These and other aspects, features, and advantages can be appreciated from the accompanying description of certain embodiments of the invention and the accompanying drawing figures.
BRIEF DESCRIPTION OF THE DRAWINGS
FIG. 1 is a high-level diagram illustrating an exemplary configuration of an in-vehicle determination system;
FIGs. 2A-2C are flow diagrams showing routines that illustrate broad aspects of methods for determining an in-vehicle role of a user and/or an in-vehicle location of a mobile device in accordance with various exemplary embodiments disclosed herein;
FIG 3 is a flow diagram showing a routing that illustrates a broad aspect of a method for enabling, disabling and/or modifying at least a feature of a mobile device in accordance with at least one exemplary embodiment disclosed herein;
FIG. 4 is a flow diagram showing a routine that illustrates a broad aspect of a method for determining an in-vehicle role of a user of a mobile device and/or a handheld state of a mobile device and/or a vehicle class of a vehicle containing the first mobile device using a central machine in accordance with at least one exemplary embodiment disclosed herein;
FIG. 5 is a flow diagram showing a routine that illustrates a broad aspect of a method for determining a vehicle class of a vehicle using a mobile device in accordance with at least one exemplary embodiment disclosed herein;
FIG. 6 is a flow diagram showing a routine that illustrates a broad aspect of a method of determining a handheld state a mobile device in accordance with at least one embodiment disclosed herein;
FIG. 7 is a flow diagram showing a routine that illustrates a broad aspect of a method of restricting operation of a mobile device in accordance with at least one embodiment disclosed herein;
FIG. 8 is a flow diagram showing a routine that illustrates a broad aspect of another method of restricting operation of a mobile device in accordance with at least one embodiment disclosed herein;
FIG. 9A is a diagram depicting an exemplary relative coordinate system of a mobile device;
FIG. 9B is a diagram depicting exemplary relative accelerations and gyroscopic rotations of a mobile device;
FIG. 9C is a diagram depicting an exemplary gyroscopic sign convention, as used herein;
FIG. 10 is a diagram depicting an exemplary coordinate system used in relation to a vehicle;
FIGs. 11A-B are diagrams depicting a mobile device and its respective exemplary coordinate system in various orientations in relation to a car and its exemplary respective coordinate system;
FIG, 12 is a flow diagram showing a routine that illustrates a broad aspect of another method of restricting operation of a mobile device in accordance with at least one embodiment disclosed herein;
FIG. 13 is a flow diagram showing a routine that illustrates a broad aspect of another method of restricting operation of a mobile device in accordance with at least one embodiment disclosed herein;
FIG. 14 is a flow diagram showing a routine that illustrates a broad aspect of a method for orienting a coordinate system of a mobile device in accordance with at least one embodiment disclosed herein;
FIG. 15 is a flow diagram is described showing a routine that illustrates a broad aspect of a method for selectively restricting an operation of a mobile device in accordance with at least one embodiment disclosed herein;
FIG. 15A is an exemplary lock screen, in accordance with at least one embodiment disclosed herein;
FIG. 15B is an exemplary visual capture that can be processed to identify a presence of a fastened seatbelt, in accordance with at least one embodiment disclosed herein;
FIG. 15C depicts the "required orientation" of a mobile device, in accordance with at least one embodiment disclosed herein;
FIG. 15D depicts an exemplary screenshot showing visual feedback that can be provided to a user during authentication in accordance with at least one embodiment disclosed herein;
FIG. 15E depicts an exemplary screenshot showing visual feedback that can be provided to a user during authentication in accordance with at least one embodiment disclosed herein;
FIG. 15F depicts a mobile device, and specifically the locations of the forward-facing and rear- facing cameras of the mobile device, in accordance with at least one embodiment disclosed herein;
FIG. 15G is an illustration depicting a 90 degree angle of incidence between the user's eyes/gaze/face/smile etc. and a mobile device, in accordance with at least one embodiment disclosed herein;
FIG. 16 is a flow diagram showing a routine that illustrates a broad aspect of a method for selectively restricting operation of a mobile device in accordance with at least one embodiment disclosed herein;
FIG. 17 is a flow diagram showing a routine that illustrates a broad aspect of a method for authenticating an in vehicle role of a user of a mobile device and/or modifying a restriction of a mobile device in accordance with at least one embodiment disclosed herein;
FIG. 17A is a flow diagram showing particular aspects of the validation step of FIG. 17, in accordance with at least one embodiment disclosed herein;
FIG. 17B is n illustration depicting an orientation of a mobile device in relation to a typical line of sight of the driver ;.n a moving car, in accordance with at least one embodiment disclosed herein,
FIG. 18 is a flow diagram is described showing a routine that illustrates a broad aspect of a method for selectively restricting an operation of and/or selectively modifying a restriction employed at mobile device, in accordance with at least one embodiment disclosed herein;
FIG. 19 depicts an exemplary determination of orientation of a device based on visual capture(s) in accordance with at least one embodiment disclosed herein;
FIG. 20 depicts the orientation and/or location of mobile device in order to provide the requisite stability described herein, in accordance with at least one embodiment disclosed herein;
FIG. 21 is a flow diagram showing a routine that illustrates a broad aspect of a method for selectively restricting a mobile device, in accordance with at least one embodiment disclosed herein;
FIG. 22 is a flow diagram showing a routine that illustrates a broad aspect of a method for eliciting an authentication at a mobile device, in accordance with at least one embodiment disclosed herein;
FIG. 23 is a flow diagram showing a routine that illustrates a broad aspect of a method for eliciting an authentication at a mobile device, in accordance with at least one embodiment disclosed herein;
FIG. 24 is a flow diagram showing a routine that illustrates a broad aspect of a method for selectively modifying a restriction employed at a mobile device, in accordance with at least one embodiment disclosed herein;
FIG. 25 is a flow diagram showing a routine that illustrates a broad aspect of a method for selectively projecting outputs at a mobile device, in accordance with at least one embodiment disclosed herein; and
FIG. 26 is a flow diagram showing a routine that illustrates a broad aspect of a method for selectively configuring overt operation of a mobile device, in accordance with at least one embodiment disclosed herein.
DETAILED DESCRIPTION OF CERTAIN EMBODIMENTS OF THE INVENTION
By way of overview and introduction, the present disclosure details systems and methods for determining various user roles and actions as they relate to the operation of a mobile device within a vehicle such as a car. Being that the usage of mobile devices while driving has been identified as a significant cause of car accidents, in addition to laws that have been enacted preventing certain use of mobile phones while driving, various systems and methods are provided herein which serve to identify the user of a particular mobile device (for instance, with respect to their role as a driver or passenger in the car), to identify various aspects of the usage of the device itself (for instance that the device is executing a text messaging application), and to identify instances when a mobile device deviates from its expected or regular operation.
As will be described in detail herein, many of these identifications and/or determinations are made possible through various sensors, components, and elements that are integrated within and/or accessible to a mobile device. As is well known to those of ordinary skill in the art, contemporary
smartphones incorporate a plethora of sensors, including accelerometers, GPS receivers, and gyroscopes. Various inputs and/or notifications can be received from these sensors, components, and elements, and can further be processed in a number of ways in order to arrive at various conclusions regarding, among others, the user of the mobile device (such as whether the user is a driver or passenger in a car) and/or the status of the mobile device itself, and various probabilities can be ascribed to the conclusions. The operation of the mobile device can further be adjusted based on such conclusions, for example, disabling or limiting the operation of a mobile device upon reaching a likely conclusion that the device is being operated by a user who is driving a car.
It will also be appreciated that the systems and methods disclosed herein can be arranged and/or deployed across a number of scenarios. In one scenario, the systems and methods can be principally employed at a mobile device itself, such as in the form of a mobile application or 'app' executing on the mobile device. In other scenarios, a central machine such as a server in communication with a mobile device can employ the present systems and methods. Such a centralized architecture can enable efficient processing and use of a larger database of user determination characteristics, eliminates power constraints and enables third parties, such as law-enforcement agencies and/or insurance companies, to easily monitor and/or adjust the operation of various mobile devices.
Moreover, it can be appreciated that today, over 70% of teenagers in the developed world own mobile devices, and most bring those devices to school every day. The ability to use these devices clandestinely in class results in student distraction, cheating on tests, and frequent disruptions of the learning environment. The inappropriate use of mobile devices in class has become one of the major problems in western educational systems today, affecting many millions of students and teachers in a very direct way.
The systems and methods described herein define a solution that renders the surreptitious use of mobile devices in school impossible, directly improving student attention and learning, and empowering educators to decide how (if at all) they may be used in classrooms. In doing so, the present systems and methods can limit distraction without interfering with legitimate device use, which until now has been a major barrier to the adoption of other proposed solutions.
The following detailed description is directed to systems and methods for determining an in- vehicle role of a user of a mobile device, selectively restricting a mobile device, and/or configuring various operations of a mobile device. The referenced systems and methods are now described more fully with reference to the accompanying drawings, in which one or more illustrated embodiments and/or arrangements of the systems and methods are shown. The systems and methods are not limited in any way to the illustrated embodiments and/or arrangements as the illustrated embodiments and/or arrangements described below are merely exemplary of the systems and methods, which can be embodied in various forms, as appreciated by one skilled in the art. Therefore, it is to be understood that any structural and functional details disclosed herein are not to be interpreted as limiting the systems and methods, but rather are provided as a representative embodiment and/or arrangement for teaching one skilled in the art one or more ways to implement the systems and methods. Accordingly, aspects of the
present systems and methods can take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware. One of skill in the art can appreciate that a software process can be transformed into an equivalent hardware structure, and a hardware structure can itself be transformed into an equivalent software process. Thus, the selection of a hardware implementation versus a software implementation is one of design choice and left to the implementer. Furthermore, the terms and phrases used herein are not intended to be limiting, but rather are to provide an understandable description of the systems and methods.
The terms "determining," "determine," and "determination" as used herein are intended to encompass the determination, identification, computation, calculation, and/or selection, with any degree of certainty or precision, and/or any other such operation, function, or action as it relates to the determination, identification, and/or selection of a user of a device such as a mobile device, an in-vehicle role of a user of a device such as a mobile device, a vehicle or vehicle model/type/class, a device or device model/type/class (e.g., handheld or wired), an operation and/or operation state of a device, and/or any other such similar or related operation, function, or action.
The terms "identifying event" and "identifying events" as used herein are intended to encompass one or more occurrences or instances of events, stimuli, or phenomena, including explicitly the perceived coordinated or correlated occurrence or instance of two or more such events, stimuli, and/or phenomena, such as those originating at one or more devices. It should be understood that the referenced occurrences or instances of events, stimuli, or phenomena include single/singular events, stimuli, or phenomena as well as a set or series of multiple events, stimuli, or phenomena over a period of time. In addition, the referenced occurrences or instances of events, stimuli, or phenomena should also be understood to include one or more coordinations or correlations of the occurrence or instance of any number of such events, stimuli, and/or phenomena over any period of time.
The terms "user interface" and "user interfaces" as used herein are intended to encompass one or more input devices, software modules executing in conjunction with one or more operating systems and/or input devices, or any other such similar or related device, accessory, apparatus, and/or software application or module that enable or facilitate input and/or interaction with a computing device.
The terms "detect," "detected," "detects," "detecting," "detection," and "detections" as used herein are intended to encompass the detection, measurement, and/or receipt, with any degree of certainty or precision, one or more occurrences or instances of events, stimuli, phenomena, or any other such similar or related inputs that are detectable through one or more devices, implements or apparatuses.
The term "processing" as used herein is intended to encompass comparing, analyzing, weighing, correlating and/or computing one or more data items, elements, or structures, individually or in conjunction with one another, using a digital processor in conjunction with one or more software modules and/or applications.
The term "communicatively coordinated" as used herein is intended to encompass direct or indirect communication between two or more devices, accessories, and/or apparatuses, expressly
including communications between a first device and a central machine, wherein the central machine is in turn in communication at some interval with a second device. In such a scenario, though the first device and the second device are not, necessarily, in direct or indirect communication with one another, it can be said that they are communicatively coordinated with one another by virtue of their mutual connection to the referenced central machine.
The terms "feature" and "features" as used herein are intended to encompass operations, functions, activities, or any other such similar or related actions, whether automated/automatic or user- initiated, that occur at or in conjunction with one or more devices, machines, applications, and/or apparatuses.
The terms "notification" and "notifications" as used herein are intended to encompass one or more messages, transmissions, and/or data packets, such as electronic messages, which contain one or more data elements (such as inputs) related or relevant to one or more of the steps, operations, and/or processes disclosed herein. An illustration of one such notification can be one or more electronic messages which contain information or data reflecting a first input from an accelerometer, a gyroscope, and/or a GPS receiver at a mobile device. Such inputs can be grouped together into one or more notifications, and these notifications can in turn be transmitted to and/or received by other devices (such as a central machine) where they can be further processed.
The terms "vehicle class" and "vehicle classes" as used herein are intended to encompass one or more types, categories, and/or models of vehicle. By way of example, airplanes, trains, automobiles, motorcycles, and boats can all be said to be different vehicle classes. By way of further example, subcategories within a given vehicle class can also be understood to be different vehicle classes. Thus, the automobile vehicle class can be further sub-divided into further vehicle classes such as sedans, vans, sport utility vehicles (SUVs), and convertibles. These sub-categories can also be said to be vehicle classes within the meaning of the term as used herein.
The terms "operation state" and "operation states" as used herein are intended to encompass the states of a device, including any and all operations, functions, capacities, and/or capabilities, including, explicitly, a set and/or series of any number of operations, functions, capacities, and/or capabilities, that can be achieved by and/or in conjunction with a device, such as a mobile device. Examples of an operation state include, but are not limited to: an execution of an application (such as an internet browser application) at a mobile device, a transmission of a notification (such as sending a text message or email message), a capacity to receive text messages, and a capability to type text using a keyboard. Accordingly, the various transformations, adjustments, and/or modifications disclosed herein that relate to an operation state and/or operation states should be understood to refer to such transformations, adjustments, and/or modifications that pertain to practically any and all operations, functions, capacities, and/or capabilities that can be achieved by and/or in conjunction with a device, such as a mobile device.
The terms "handheld state" and "handheld states" as used herein are intended to encompass one or more states of a mobile device with respect to whether or not a user is in direct or indirect physical contact with the device. For example, the handheld state of a device in instances where a user holds the
device in his/her hand, carries the device in his/her pocket, and/or balances the device on his/her knee can all be said to be "handheld." By way of further example, the handheld state of a device in instances where the device is positioned in a dock or cradle, and/or is otherwise not in direct or indirect contact with a user can be said to be "non-handheld."
The terms "operational capacity" and "operational capacities" as used herein are intended to encompass one or more operation states of a mobile device, particularly with respect to a central machine such as a server. By way of example, an operational capacity of a mobile device can be a voice or data connection that is provided to a mobile device through a central machine, such as that of a voice/data service provider. Accordingly, it can be appreciated that a transformation, modification, and/or adjustment of such an operational capacity preferably entails such a transformation, modification, and/or adjustment that is initiated and/or effected by a central machine, preferably in relation to a mobile device. For example, a central machine can transmit an instruction and/or notification to a mobile device, such instruction/notification directing the transformation, modification, and/or adjustment be implemented at the mobile device. By way of further example, a central machine can implement a transformation, modification, and/or adjustment at the central machine itself, wherein such a transformation, modification, and/or adjustment - such as the stopping of voice and/or data connections to a mobile device - ultimately effect the functionality of the device itself, In both such cases it can be said that the central machine has transformed, modified, and/or adjusted the operational capacity of the mobile device.
The terms "user" and "users" as used herein are intended to encompass one or more individuals, persons, and/or entities whose presence a device or machine can preferably be directly or indirectly aware. It should be understood that while in certain scenarios a user can interact with a device, in other scenarios a particular individual, person, and/or entity can be said to be a "user" within the context of the present disclosure, despite not interacting with a particular device.
The terms "tactile sensor" and "tactile sensor(s)" as used herein are intended to encompass one or more buttons, touchscreens, and/or components that enable a user to interact with a device in a tactile fashion. Examples of such tactile sensors include, but are not limited to, buttons (such as those that comprise a keyboard), switches, as well as touch screen displays (such as capacitive and resistive displays) which both display information and allow the tactile interaction with such information. It should be further understood that such tactile sensors are preferably further capable of perceiving a plurality of simultaneous tactile interactions. Examples of such functionality include mutlitouch technologies, as are known to those of ordinary skill in the art.
The terms "visual capture" and "visual captures" as used herein are intended to encompass one or more operations, functions, and/or actions that relate to the optical perception and/or documentation of one or more visual items, elements, and/or phenomena. Examples of such visual captures include, but are not limited to, photographs, images, videos, and/or any other such method of visual perception and/or documentation. Accordingly, it can be appreciated that certain visual captures correspond to a single instance (such as a photograph) while other visual captures correspond to multiple instances (such as a series of photographs and/or a video).
The term "in-vehicle role indicator" as used herein is intended to encompass one or more items, elements, and/or indicators that relate to one or more aspects associated with and/or corresponding to the in-vehicle role of a user in a vehicle (e.g., whether a user is or is not a driver, is or is not a passenger, etc.). For example, one such in-vehicle role indicator is identifying in a picture of two hands of a driver grasping the steering wheel of a vehicle. Using one or more optical recognition methods, such as those known to one of ordinary skill in the art, one or more images and/or videos can be processed in order to identify the presence of two hands grasping a steering wheel, thus indicating that a particular vehicle is being operated by a driver using two hands and therefore it can be reasonable concluded that the user who took such an image is not the driver. By way of further example, another such in-vehicle role indicator can be capturing a picture that can be processed to identify that a seatbelt extends from the right shoulder to left thigh of the wearer. Such an identification also reasonably suggests that the wearer is not a driver (as the seatbelt of a driver traditionally extends from the left shoulder to the right thigh).
It should be further understood that while the various computing devices and machines referenced herein, including but not limited to the first mobile device, the second mobile device, the central machine, or any other such similar or related devices or machines are referred to herein in a as individual/single devices and/or machines, in certain arrangements the referenced devices and machines, and their associated and/or accompanying operations, features, and/or functionalities can be arranged or otherwise employed across any number of devices and/or machines, such as over a network connection, as is known to those of skill in the art.
In addition, it should be understood that while the term "input" is used herein in the singular form, this is merely for the sake of clarity and convention. However, the referenced terms should be understood to encompass both singular inputs as well as a plurality (two or more) inputs, such as a set of inputs.
It should be understood that the terms "lateral acceleration," "x-acceleration," and "x-axis acceleration" as used herein are used interchangeably, and should thus be understood to possess the same meaning and connotation. Additionally, the terms "forward acceleration," "y-acceleration," and "y-axis acceleration" as used herein are used interchangeably and should thus be understood to possess the same meaning and connotation. In addition, the terms "upward acceleration," "z-axis acceleration," "z- acceleration" as used herein are used interchangeably and should thus be understood to possess the same meaning and connotation.
It should also be understood that the terms "yaw," "gyroscopic yaw," "angular velocity around the z-axis," and "rotation around the z-axis" as used herein are used interchangeably, and should thus be understood to possess the same meaning and connotation. In addition, the terms "roll," "gyroscopic roll," "angular velocity around the y-axis," and "rotation around the y-axis," as used herein are used interchangeably, and should thus be understood to possess the same meaning and connotation. Additionally, the terms "pitch," "gyroscopic pitch," "angular velocity around the x-axis," and "rotation around the x-axis" as used herein are used interchangeably, and should thus be understood to possess the same meaning and connotation.
An exemplary computer system is shown as a block diagram in FIG. 1 which is a high-level diagram illustrating an exemplary configuration of a determination system 100. In one arrangement, mobile device 105 can be a portable computing device such as a mobile phone, smartphone, or PDA. In other arrangements, mobile device 105 can be a tablet computer, a laptop computer, a personal computer, or an in-vehicle computer (e.g., ECU/OBD) though it should be understood that mobile device 105 of determination system 100 can be practically any computing device capable of embodying the systems and/or methods described herein.
Mobile device 105 of determination system 100 includes a control circuit 140 which is operatively connected to various hardware and software components that serve to enable operation of the determination system 100. The control circuit 140 is operatively connected to a processor 110 and a memory 120. Processor 110 serves to execute instructions for software that can be loaded into memory 120. Processor 110 can be a number of processors, a multi-processor core, or some other type of processor, depending on the particular implementation. Further, processor 110 can be implemented using a number of heterogeneous processor systems in which a main processor is present with secondary processors on a single chip. As another illustrative example, processor 110 can be a symmetric multiprocessor system containing multiple processors of the same type.
Preferably, memory 120 and/or storage 190 are accessible by processor 110, thereby enabling processor 110 to receive and execute instructions stored on memory 120 and/or on storage 190. Memory 120 can be, for example, a random access memory (RAM) or any other suitable volatile or non- volatile computer readable storage medium. In addition, memory 120 can be fixed or removable. Storage 190 can take various forms, depending on the particular implementation. For example, storage 190 can contain one or more components or devices. For example, storage 190 can be a hard drive, a flash memory, a rewritable optical disk, a rewritable magnetic tape, or some combination of the above. Storage 190 also can be fixed or removable.
One or more software modules 130 are encoded in storage 190 and/or in memory 120. The software modules 130 can comprise one or more software programs or applications having computer program code or a set of instructions executed in processor 110. Such computer program code or instructions for carrying out operations for aspects of the systems and methods disclosed herein can be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++ or the like and conventional procedural programming languages, such as the "C" programming language or similar programming languages. The program code can execute entirely on the mobile device 105, partly on mobile device 105, as a standalone software package, partly on mobile device 105 and partly on a remote computer/device or entirely on the remote computer/device or server. In the latter scenario, the remote computer can be connected to mobile device 105 through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection can be made to an external computer (for example, through the Internet using an Internet Service Provider).
Software modules 130, including program code/instructions, are located in a functional form on one or more computer readable storage devices (such as memory 120 and/or storage 190) that can be selectively removable. The software modules 130 can be loaded onto or transferred to mobile 105 for execution by processor 110. It can also be said that the program code of software modules 130 and one or more computer readable storage devices (such as memory 120 and/or storage 190) form a computer program product.
It should be understood that in some illustrative embodiments, one or more of software modules 130 can be downloaded over a network to storage 190 from another device or system via communication interface 150 for use within determination system 100. For instance, program code stored in a computer readable storage device in a server can be downloaded over a network from the server to determination system 100.
Preferably, included among the software modules 130 is a determination module 170 that is executed by processor 110, During execution of the software modules 130, and specifically the determination module 170, the processor 110 configures the control circuit 140 to determine an in- vehicle role of a user of the mobile device 105, as will be described in greater detail below. It should be understood that while software modules 130 and/or determination module 170 can be embodied in any number of computer executable formats, preferably software modules 130 and/or determination module 170 comprise one or more applications or 'apps' that are configured to be executed at mobile device 105 and/or in relation to mobile device 105. In other arrangements, software modules 130 and/or determination module 170 are incorporated and/or integrated within operating system 176. Furthermore, in certain arrangements, software modules 130 and/or determination module 170 can be configured to execute at the request or selection of a user of mobile device 105 (or any other such user having the ability to execute a program in relation to mobile device 105, such as a network administrator), while in other arrangements mobile device 105 can be configured to automatically execute software modules 130 and/or determination module 170, without requiring an affirmative request to execute. The advantages of such an automatic arrangement can be appreciated in context of a regulatory scheme that mandates or recommends that software modules 130 and/or determination module 170 be executed by a mobile device 105 some or all of the time, in furtherance of a campaign to improve driver safety. It should also be noted that while FIG. 1 depicts memory 120 oriented on control circuit 140, in an alternate arrangement, memory 120 can be operatively connected to the control circuit 140. In addition, it should be noted that other software modules (such as user interface 172 and operating system 176) and other information and/or data relevant to the operation of the present systems and methods (such as database 174) can also be stored on storage 190, as will be discussed in greater detail below.
A communication interface 150 is also operatively connected to control circuit 140. Communication interface 150 can be any interface that enables communication between the mobile device 105 and external devices, machines and/or elements. Preferably, communication interface 150 includes, but is not limited to, a modem, a Network Interface Card (NIC), an integrated network interface, a radio frequency transmitter/receiver (e.g., Bluetooth, cellular, NFC), a satellite communication
transmitter/receiver, an infrared port, a USB connection, or any other such interfaces for connecting mobile device 105 to other computing devices and/or communication networks such as the Internet. Such connections can include a wired connection or a wireless connection (e.g. 802.11) though it should be understood that communication interface 150 can be practically any interface that enables communication to/from the control circuit 140.
At various points during the operation of determination system 100, mobile device 105 can communicate with one or more mobile devices 160A-N (collectively mobile devices 160). The mobile devices 160 transmit and/or receive data to/from the mobile device 105, thereby preferably enhancing the operation of the determination system 100, as will be described in greater detail below. It should be understood that mobile devices 160 can be in direct communication with mobile device 105, indirect communication with mobile device 105, and/or can be communicatively coordinated with mobile device 105, as will be described in greater detail below. While mobile device 160 can be practically any device capable of communication with mobile machine 105, in the preferred embodiment mobile device 160 is a handheld/portable computer, smartphone, personal digital assistant (PDA), tablet computer, and/or any portable device that is capable of transmitting and receiving data to/from mobile device 105. It should also be appreciated that in many arrangements, mobile device 160 will be substantially identical, from a structural and functional perspective, to mobile device 105.
It should be noted that while the FIG. 1 depicts the determination system 100 with respect to mobile device 160 A and mobile device 160N, it should be understood that any number of mobile devices 160 can interact with determination system 100 in the manner described herein.
Also preferably connected to and/or in communication with control circuit 140 are one or more sensors 145A-145N (generically sensors 145). Generally, sensors 145 are various components, devices, and/or receivers that are preferably incorporated within and/or in communication with mobile device 105. Sensors 145 preferably detect one or more stimuli, phenomena, or any other such inputs, as will be described in greater detail below. Examples of such sensors 145 include, but are not limited to, an accelerometer 145A, a gyroscope 145B, a GPS receiver 145C, a microphone 145D, a magnetometer 145E, a camera 145F, a light sensorl45G, a temperature sensor 145H, an altitude sensor 1451, a pressure sensor 145 J, a proximity sensor 145K, a near-field communication (NFC) device 145L, a compass 145M, and a tactile sensor 145N. As will be described in greater detail below, mobile device 105 can preferably receive one or more Inputs from one or more sensors 145 in order to determine an in- vehicle role of a user of mobile device 105 and/or to selectively restrict the operation of the mobile device.
In certain arrangements, one or more external databases and/or servers 162 are also in communication with mobile device 105. As will be described in greater detail below, database/server 162 is preferably a computing and/or storage device, and/or a plurality of computing and/or storage devices, that contain(s) information, such as determination characteristics, that can be relevant to the determination of an in-vehicle role of a user of mobile device 105.
Additionally, in certain arrangements a vehicle data system 164, such as an on board diagnostic (OBD) computer or computing device (e.g., OBD-I, OBD-II), an engine control unit (ECU), a roll
system, an airbag system, a seat-weight sensor system, a seat-belt sensor system, and/or an anti-lock braking system (ABS) can also be in communication with mobile device 105. Vehicle data system 164 preferably provides data and/or information from the vehicle itself that can also be relevant to various determinations disclosed herein, such as the determination of an in- vehicle role of a user of mobile device 105, as will be described in greater detail below.
At this juncture it should be noted that in certain arrangements, such as the one depicted in FIG. 1, mobile devices 160, database/server 162, and/or vehicle data system 164 can be in periodic or ongoing communication with mobile device 105 thorough a computer network such as the Internet 166. Although not depicted in FIG. 1, it should be understood that in certain other arrangements, mobile devices 160, database/server 162, and/or vehicle data system 164 can be in periodic or ongoing direct communication with mobile device 105, such as through communications interface 150, thus not requiring the presence of a network (such as the Internet 166) in order to initiate and maintain communications.
In the description that follows, certain embodiments and/or arrangements are described with reference to acts and symbolic representations of operations that are performed by one or more devices, such as the determination system 100 of FIG. 1. As such, it will be understood that such acts and operations, which are at times referred to as being computer-executed, include the manipulation by the processor of the computer of electrical signals representing data in a structured form. This manipulation transforms the data and/or maintains them at locations in the memory system of the computer, which reconfigures and/or otherwise alters the operation of the computer in a manner understood by those skilled in the art. The data structures in which data is maintained are physical locations of the memory that have particular properties defined by the format of the data. However, while an embodiment is being described in the foregoing context, it is not meant to provide architectural limitations to the manner in which different embodiments can be implemented. The different illustrative embodiments can be implemented in a system including components in addition to or in place of those illustrated for the determination system 100. Other components shown in FIG. 1 can be varied from the illustrative examples shown. The different embodiments can be implemented using any hardware device or system capable of running program code. In another illustrative example, determination system 100 can take the form of a hardware unit that has circuits that are manufactured or configured for a particular use. This type of hardware can perform operations without needing program code to be loaded into a memory from a computer readable storage device to be configured to perform the operations.
For example, mobile device 105 can take the form of a circuit system, an application specific integrated circuit (ASIC), a programmable logic device, or some other suitable type of hardware configured to perform a number of operations. With a programmable logic device, the device is configured to perform any number of operations. The device can be reconfigured at a later time or can be permanently configured to perform any number of operations. Examples of programmable logic devices include, for example, a programmable logic array, programmable array logic, a field programmable logic array, a field programmable gate array, and other suitable hardware devices. With this type of
implementation, software modules 130 can be omitted because the processes for the different embodiments are implemented in a hardware unit.
In still another illustrative example, determination system 100 and/or mobile device 105 can be implemented using a combination of processors found in computers and hardware units. Processor 110 can have a number of hardware units and a number of processors that are configured to execute software modules 130. In this example, some of the processors can be implemented in the number of hardware units, while other processors can be implemented in the number of processors.
In another example, a bus system can be implemented and can be comprised of one or more buses, such as a system bus or an input/output bus. Of course, the bus system may be implemented using any suitable type of architecture that provides for a transfer of data between different components or devices attached to the bus system. Additionally, communications interface 150 can include one or more devices used to transmit and receive data, such as a modem or a network adapter.
Embodiments and/or arrangements can be described in a general context of computer-executable instructions, such as program modules, being executed by a computer. Generally, program modules include routines, programs, objects, components, data structures, etc., that perform particular tasks or implement particular abstract data types.
The operation of the determination system 100 and the various elements and components described above will be further appreciated with reference to the method for determining an in-vehicle role of a user of a mobile device as described below, in conjunction with FIGs. 2A-2C.
Turning now to FIG. 2A, a flow diagram is described showing a routine 201 that illustrates a broad aspect of a method for determining an in-vehicle role of a user of a mobile device 105 in accordance with at least one embodiment disclosed herein. It should be appreciated that several of the logical operations described herein are implemented (1) as a sequence of computer implemented acts or program modules running on determination system 100 and/or (2) as interconnected machine logic circuits or circuit modules within the determination system 100. The implementation is a matter of choice dependent on the requirements of the device (e.g., size, energy, consumption, performance, etc.). Accordingly, the logical operations described herein are referred to variously as operations, structural devices, acts, or modules. Various of these operations, structural devices, acts and modules can be implemented in software, in firmware, in special purpose digital logic, and any combination thereof. It should also be appreciated that more or fewer operations can be performed than shown in the figures and described herein. These operations can also be performed in a different order than those described herein.
The process begins at step 210 where processor 110 executing one or more of software modules 130, including, preferably, determination module 170, receives a first input, such as from one or more of sensors 145, software modules 130, user interface 172, operating system 176, and/or communication interface 150. Preferably, the first input originates from one or more identifying events that are perceptible to at least one of sensors 145, user interface 172, operating system 176, and/or communication interface 150. Examples of such an input include, but are not limited to, an acceleration input that originates from an acceleration event (e.g., the speeding up or slowing down of a car) that is perceived by
accelerometer 145 A, a change in geographic location input that originates from a location changing event (e.g., the movement from one place to another) that is perceived by GPS receiver 145C, and/or one or more instances or user interaction (e.g., typing) that are detected by user interface 172.
Then, at step 220, processor 110 executing one or more of software modules 130, including, preferably, determination module 170, analyzes at least the first input, such as to identify one or more determination characteristics within the first input, including but not limited to user determination characteristics. As will be described in greater detail below, user determination characteristics are one or more aspects originating at and/or derived from an input that provide insight regarding the in-vehicle role and/or identity of the user that is exerting control over and/or otherwise associated with a mobile device, such as mobile device 105. For example, where the first input (received at step 210) is the typing of one or more letters into user interface 172 (such as to compose a SMS message), determination module 170 can analyze the typing to identify one or more user determination characteristics (that is, characteristics that contribute to a determination of the identity of the particular user that is associated with mobile device 105, as will be described below). In this case, determination module 170 can analyze the typing patterns within the first input (such as the time interval in between the typing of individual letters in the SMS message, the average time interval in between the typing of individual letters in the SMS message, and/or the variability among one or more time intervals between the typing of individual letters in the SMS message). If there are substantial time intervals in between the typing of various letters, and/or if the time intervals in between typed letters vary widely, these factors can indicate that the user of mobile device 105 is likely distracted and thus unable to type consistently. Additional examples of analyzing an input to identify one or more determination characteristics are provided below in EXAMPLE 1.
Upon identifying one or more determination characteristics, such as user determination characteristics, based on the analysis of an input, at step 230 the processor 110 executing one or more of software modules 130, including, preferably, determination module 170, computes one or more determination factors (that is, factors that reflect and/or suggest one or more determinations that can be arrived at with respect to one or more of the mobile device, its location, the user, and/or the vehicle). By way of example, a probability can be computed, based on the user determination characteristics, that the in-vehicle role of the user of mobile device 105 is a driver and/or that the in-vehicle role of the user of the mobile device 105 is a passenger. That is, in certain arrangements the user determination characteristics identified at step 220 can provide varying degrees of certitude as to the identity or role of a user. So, continuing the example provided with regard to step 220, while, on the one hand, significant time intervals between typed letters can indicate that the in-vehicle role of the user is a driver, on the other hand if the time intervals in between the various letters are, on average, consistent and/or substantially similar this can indicate that the user is not necessarily distracted (due to being a driver), but rather is a passenger and is simply not adept at typing. Accordingly, in such a case, in one arrangement the computed probability for such user determination characteristic(s) is preferably a lesser degree of certainty that the user is a driver (and/or a passenger), accounting for the potentially conflicting indications from the various user determination characteristics. By way of further example, when the user
determination characteristics indicate that a lesser degree of typing inconsistency and/or shorter intra- character time intervals exists, processor 110 executing software modules 130 preferably computes a probability that the in-vehicle role of the user of mobile device 105 is a passenger. Similarly, when a greater degree of typing inconsistency and/or longer intra-character time intervals exists, processor 110 executing software modules 130 preferably computes a probability that the in-vehicle role of the user of mobile device 105 is a driver (being that the user determination characteristics appear consistent with the activity of a driver within a vehicle). It should be appreciated that because ranges exist for a particular user determination characteristic (such as typing consistency), a probability of an in-vehicle role is preferably computed, reflecting a degree of certainty that the user of mobile device is a driver and/or that the user of mobile device is a passenger.
Then, at step 240, the processor 110 executing one or more of software modules 130, including, preferably, determination module 170, transforms an operation state of the mobile device 105 based on the determination factors (such as the probability computed at step 230), and/or outputs at least one operation state based on the at least one determination factor, and/or outputs at least one in-vehicle role of the user based on at least one determination factor, and/or outputs at least one in-vehicle location of the mobile device 105 based on at least one determination factor, and/or outputs at least one result based on the at least one determination factor, Various of these operations will be described in greater detail herein. For example, if the computed probability indicates that the in-vehicle role of a user of mobile device 105 is likely to be a driver, processor 1 10 can coordinate the disabling of one or more features of the mobile device 105, such as the disabling of any and/or all features that enable the entry of text into mobile device 105. In doing so, existing safety risks can be reduced by preventing a user who has been determined to be likely to be a driver of a vehicle from using various regular functions of mobile device 105 that are likely to distract the user and increase safety risks while driving and/or are restricted and/or prohibited based on the vehicle's current (or most recently known) location, as preferably determined in conjunction with GPS 145C. In other arrangements, one or more other transformations to the operation state of mobile device can be similarly applied based on the computed probability. For example, notifications (such as warning notifications) can be provided at the mobile device 105, notifications can be transmitted to third parties (notifying a third party, such as a law enforcement agency, of the in-vehicle role of the user of mobile device 105 and/or of the particular operation of the mobile device 105, such as that typing is being performed upon mobile device 105), instructions can be provided to third parties (such as a cellular service provider) to change an operation state of mobile device 105 (such as temporarily disabling the communication ability of mobile device 105), and/or one or more applications executing or executable on mobile device 105 can be disabled (such as a text messaging application),
At this juncture, it can be appreciated that the operations corresponding to transforming step 240 can be customized and/or configured in relation to various probabilities computed at step 230. That is, certain transformations of the operation state of mobile device 105 (for example, notifying law enforcement authorities) may only be appropriate when there is a high probability (such as greater than 90%) that the in-vehicle role of a user of mobile device 105 is a driver (and further that the driver is
interacting with mobile device 105 in an illegal manner while driving), while other transformations may be appropriate even for lower degrees of probability (for example, it may be appropriate to provide a warning notification at mobile device 105 even for a 60% probability that the user is a driver), Yet other transformations can be employed preemptively, wherein the transformation is applied even before a prohibited interaction (e.g., typing into an SMS program) occurs, thereby avoiding restricted or prohibited interaction with mobile device 105, even at the first instance. Furthermore, as referenced above, in certain arrangements the user can configure how (that is, the type of transformation) and when (that is, the probability threshold that must be met in order to trigger the transformation) the operation of mobile device 105 is to be transformed. In other arrangements, a third party can establish such configurations. For example, a regulatory agency can dictate that one or more transformations be employed on some or all mobile devices when a particular probability threshold that a user of the device is a driver is met. By way of further example, a car insurance provider can provide incentives to its customers who utilize one or more transformations and/or probability thresholds suggested and/or dictated by the insurance company.
Turning now to FIG. 2B, a flow diagram is described showing a routine 202 that illustrates a further aspect of a method for determining an in-vehicle role of a user of a mobile device 105 in accordance with at least one embodiment disclosed herein. Though already noted above, it should be particularly appreciated with reference to FIG. 2B that more or fewer operations can be performed than shown in the figures and described herein, and that these operations can be performed in a different order than those described herein. Thus, in certain arrangements certain of the operations of FIG; 2B can be performed while others are not, and further that in certain arrangements can be performed in a sequence other than that depicted in FIG. 2B.
The process begins at step 210 where a first input of a first device 105 is received, and proceeds to step 220 where the first input is analyzed. Steps 210 and 220 have already been described above with reference to FIG. 2A and thus will not be further elaborated upon here as their operation is substantially identical to steps 210 and 220 described above.
Then, at step 221, processor 110 executing one or more of software modules 130, including, preferably, determination module 170, receives a second input from one or more of sensors 145, software modules 130, user interface 172, operating system 176, and/or communication interface 150. As described above with reference to step 210, examples of such an input include, but are not limited to, an input corresponding to an acceleration perceived by accelerometer 145A, and/or an input corresponding to a change in geographic location as perceived by GPS receiver 145C.
At step 222, the second input is analyzed by processor 110 executing determination module 170, in a manner substantially similar to that described above with reference to step 220, in order to identify one or more determination characteristics such as user determination characteristics within the second input. For example, where the second input (received at step 221) comprises one or more accelerations detected by accelerometer 145 A, determination module 170 can analyze the accelerations to identify one or more user determination characteristics within the second input. Here, determination module 170 can
analyze various patterns within the second input (such as the time and duration of acceleration and deceleration). Certain patterns, such as frequent periods of sustained forward acceleration interspersed with periodic intervals of rapid and/or brief forward deceleration can indicate that the user of mobile device 105 is likely traveling in, if not operating, a car which often follows such an acceleration/deceleration pattern. As described in detail herein, by identifying one or more user determination characteristics (such as identifying that the user of mobile device 105 is likely traveling in a car, as described above), the context and significance of one or more other user determination characteristics can be better evaluated and/or quantified. For example, the typing patterns of a user determined to be traveling in a moving car are, on average, of greater significance in determining whether the user of the device is a driver/passenger. On the other hand, the typing patterns of a user of a mobile device 105 that has been determined not to be traveling in a moving car can be understood to be, on average, of lesser significance in determining whether the user of the device is a driver/passenger.
Then, at step 223, the processor 1 10 executing one or more of software modules 130, including, preferably, determination module 170, can compare the determination characteristics such as user determination characteristics identified within the first input (such as those identified at step 220) with the determination characteristics such as user determination characteristics identified within the second input (such as those identified at step 222). In doing so, one or more patterns, correlations and/or relationships can be identified between the user determinations characteristics of the first input and the user determination characteristics of the second input. By way of illustration, referring to the examples discussed above, the typing patterns identified at step 220 can be compared with the acceleration/deceleration patterns identified at step 222. In doing so, patterns, correlations, and/or relationships between the typing patterns and acceleration/deceleration patterns can be identified. For example, if time intervals between typed characters and/or typing inconsistencies increase at the same time as substantial and/or sudden forward and/or lateral acceleration and/or deceleration, this can further indicate that the user of a mobile device 105 is a driver. Being that for a driver to engage in a maneuver with sudden acceleration and/or deceleration the driver is expected to have temporarily stopped typing due to the increased attention a driver must pay to his driving activities, if such accelerations correlate closely with inconsistent typing speeds and/or slower typing speed and/or such accelerations are just prior to typing delays, this can be a strong indication that the user of mobile device 105 is a driver.
Additional illustrations of scenarios and/or arrangements wherein multiple inputs are analyzed, compared, correlated, and/or processed in order to determine various aspects of the roles of one or more users of a mobile device 105, are provided throughout the present disclosure.
At step 224, the processor 110 executing one or more of software modules 130, including, preferably, determination module 170, compares determination characteristics such as user determination characteristics (including, but not limited to, the user determination characteristics from the first input, as identified at step 220, and/or the user determination characteristics from the second input, as identified at step 222) with stored determination characteristics such as user determination characteristics, such as those stored at one or more databases, such as database 174 (that is local to mobile device 105) and/or
database/server 162 (that is external to mobile device 105). Stored user determination characteristics can be archived user determination characteristics that have been retained from previous user determinations that have been performed, can be generated based on statistical analyses of previous user determinations, and/or can be defined or established independent of any particular previous user determination. In comparing user determination characteristics (such as those identified at step 220 and/or step 222) with stored user determination characteristics (such as stored user determination characteristics that have historically demonstrated a high degree of prediction accuracy in determining an in-vehicle role of a user), the processor 110 can more accurately compute the probability that the in-vehicle role of the user of mobile device 105 is a driver or that the in-vehicle role of the user of mobile device 105 is a passenger. For instance, following the example referenced above with regard to typing inconsistencies, if certain typing patterns have historically been demonstrated as very reliable in determining the in-vehicle role, of the user, various identified user determination characteristics (such as those identified at step 220 and/or step 222) can be compared to such stored determination characteristics (e.g., highly predictive typing patterns). If the identified determination characteristics closely correlate to highly reliable/predictive stored determination characteristics, the identified determination characteristics can be similarly considered highly reliable and this correlation can further enhance the reliability of the computation of a probability regarding the in-vehicle role of a particular user. Additional examples and illustrations of such comparisons are provided below at EXAMPLE 1.
At step 225, processor 1 10 executing one or more of software modules 130, including, preferably, determination module 170, receives an input from another device, such as one of mobile devices 160. It should be understood that the input received from mobile device 160 is preferably from among the various types of inputs referenced above at steps 210 and 221 (for example, an acceleration input that originates from an acceleration event that is perceived by accelerometer 145 A, and/or a change in geographic location input that originates from a location changing event that is perceived by GPS receiver 145C), and thus will not be described at length here. However, it should be appreciated that this input originates at mobile device 160 (that is, a device external to mobile device 105), and thus the input from mobile device 160 is preferably received by mobile device 105 through communication interface 150.
Then, at step 226, processor 110 executing one or more of software modules 130, including, preferably, determination module 170, processes an input of mobile device 105 against an input of one or more mobile devices 160. In doing so, one or more determination characteristics such as user determination characteristics can be identified within the input of the first mobile device 105. By way of example, various typing patterns and/or tendencies (referenced above) of mobile device 160 can be processed against similar typing patterns/tendencies of mobile device 105 (or, alternatively, various typing patterns and/or tendencies of mobile device 105 can be processed against similar typing patterns/tendencies of mobile device 160). In doing so, processor 110 can analyze and/or identify the degree to which the input from mobile device 105 deviates from the input received from mobile device(s) 160, in a manner similar to the comparison discussed above at step 224 (except that here the input of mobile device 105 is being processed against an input received from another mobile device 160, as
opposed to comparing one user determination characteristic with stored characteristics). Thus, continuing with the provided example, in a case where the typing tendencies of mobile device 105 are relatively inconsistent, if, when processing the typing tendencies received from mobile device(s) 160 against those of mobile device 105 it is revealed that the typing across many or all of the devices 105 and 160 is similarly inconsistent, this can indicate that it there is not necessarily a high probability that the user of mobile device 105 is a driver, despite the inconsistent typing inputs received at the device 105 (rather, such inconsistent typing may be the result of the various devices 105 and 160 traveling along an off-road or bumpy road, which would make consistent typing difficult, even for passengers in a vehicle). Additionally, if the typing tendencies of mobile device 105 are relatively consistent, however when processing such input(s) against inputs from mobile device(s) 160 it is revealed that the typing tendencies of the user of mobile device 105 are actually relatively inconsistent, this can indicate a higher probability that the user of mobile device 105 is a driver of a vehicle (even though the input from mobile device 105, in-and-of-itself, may not have generated the same conclusion).
It should be noted that various limitations and/or filters can be imposed upon the receiving at step 225 and/or the processing at step 226, to ensure the most accurate results possible. That is, while in certain arrangements it can be beneficial to receive inputs from practically any mobile device 160 that is capable of communication with mobile device 105, in other arrangements it can be preferably to limit the number of devices and/or inputs that are received by mobile device 105 on the basis of one or more factors to ensure that the inputs being received by mobile device 105 from such external devices 160 are those that can be expected to be of greatest relevance. Examples of factors that can be considered in imposing such limitations and/or filters include proximity to mobile device 105 and/or similarity/compatibility with mobile device 105. To illustrate, in processing the typing tendencies of device 105 against those of another device 160, it can be preferable to ensure that device 160 is in close proximity to mobile device 105 (such as through a comparison of the location coordinates obtained from their respective GPS receivers or by causing one or more of the mobile devices to emit one or more tones and/or signals (e.g., an audio tone) that can then be received on other mobile devices that are in close proximity, as described in detail in EXAMPLE 2), thereby establishing a high likelihood that mobile device 105 and mobile device 160 are operating within the same vehicle (and are thus subjected to substantially identical conditions). To further illustrate, being that various mobile devices such as smartphones utilize different user interfaces and button configurations, it can be advantageous in certain arrangements to compare inputs from one mobile device 105 with those of another mobile device 160 that is either identical to or at least highly compatible with mobile device 105 (such as a device using the same operating system). Due to differences across various mobile devices and operating systems, ensuring that mobile device 105 and mobile device(s) 160 are similar (if not identical) ensures that the inputs received from each can be assumed to be highly comparable.
Additional examples of processing inputs from one device 105, 160 against those of one or more other devices to identify one or more determination characteristics are provided below in EXAMPLE 2.
In addition, in certain arrangements it is preferable that the inputs from mobile device 105 and those of mobile device 160 that are to be processed against one another/compared are substantially synchronized from a chronological standpoint. That is, it is preferable that each of the various inputs be associated with a particular time (and that the source of such time be a central clock, such as a server, which can synchronize the various devices, though it should be understood that in other arrangements one or more of devices 105, 160 can broadcast timing data that enables the calibration of the various devices), thereby enabling the processing of inputs from mobile device 105 with inputs from mobile device 160 that correspond to the same point in time. Doing so ensures that the various inputs being processed/compared are highly comparable, in that they reflect the operations of the various devices 105 and 160 in response to the same events (e.g, accelerating/decelerating over the course of a driver).
Additional examples and illustrations of such further processing operations are provided below in
EXAMPLE 3.
At step 227, processor 110 executing one or more of software modules 130, including, preferably, determination module 170, receives an input from vehicle data system 164, such as an on board diagnostic (OBD) computer or computing device (e.g., OBD-I, OBD-II, ECU, roll system, airbag system, and/or an ABS), preferably through communication interface 150. As noted above, vehicle data system 164 preferably provides data and/or information originating at the vehicle itself. For example, vehicle data system 164 can provide one or more inputs that reflect various actions or events, such as a car's acceleration and/or deceleration, steering, braking, and/or any other such car-related operations. Such inputs can provide further insight into determining the in- vehicle role of a user of mobile device 105, as will be described below.
Then, at step 228, processor 110 executing one or more of software modules 130, including, preferably, determination module 170, processes an input of mobile device 105 against an input of vehicle data system 164, in a manner similar to that described above with respect to step 226. However, here an input of mobile device 105, such as various typing tendencies (as illustrated above) is processed against an input from vehicle data system 164 that preferably pertains to an operation of a car (e.g., the car accelerating, braking, and/or swerving) and which is qualitatively different than the input of mobile device 105 because vehicle data system 164 cannot necessarily detect the various stimuli perceptible to mobile device 105, owing in part to the fact that mobile device 105 is preferably not fixed relative to the car's coordinate system. As such, the various inputs (that is, the inputs from mobile device 105 and those from vehicle data system 164) are compared and/or synchronized from a chronological standpoint, substantially in the manner described above with respect to step 226. In doing so, inputs from mobile device 105 can be processed against inputs from vehicle data system 164 (which, in turn, originate at the car itself), thereby enabling the association of various inputs from mobile device 105 with events such as the accelerating, braking, and/or swerving of the car. Thus, following the typing tendencies example provided, if certain highly erratic typing tendencies perceived at mobile device 160, occur just prior and/or closely correlate to various driving operations (reflected in the inputs from vehicle data system 164) such as accelerating, braking, and/or swerving, one or more user determination characteristics can be
identified with regard to the input(s) from mobile device 105, indicating that there is a high likelihood that the in-vehicle role of the user of mobile device 105 is a driver.
At this juncture, it can be appreciated that although several sections of the forgoing disclosure have referenced the processing and/or comparison of various inputs against one another in context of inputs that are qualitatively comparable (such as at steps 224 and 226, above, referring to the comparison of typing tendencies from various sources), in other arrangements various inputs that are not necessarily qualitatively comparable (or, at least, do not appear to be qualitatively comparable). For example, in a manner similar to that described above with respect to step 223, an input of typing tendencies from one source (such as mobile device 105) can be compared with/analyzed against an input of accelerations/decelerations originating at mobile device 160. The respective inputs preferably have a timestamp to enable the chronological comparison between the inputs, as described in greater detail above with respect to step 226.
At step 230, processor 110 executing one or more of software modules 130, including, preferably, determination module 170, computes one or more determination factors, such as a probability, based on the various determination characteristics, that the in-vehicle role of the user of mobile device 105 is a driver and/or a probability that the in-vehicle role of the user of the mobile device 105 is a passenger, substantially in the manner described in detail above with regard to step 230. Then, at step 240, the processor 110 executing one or more of software modules 130, including, preferably, determination module 170, transforms an operation state of the mobile device 105 and/or outputs at least one operation state based on the at least one determination factor, and/or outputs at least one in-vehicle role of the user based on at least one determination factor, and/or outputs at least one in-vehicle location of the mobile device 105 based on at least one determination factor, and/or outputs at least one result based on the at least one determination factor, as also described in detail above.
Turning now to FIG. 2C, a flow diagram is described showing a routine 203 that illustrates a further aspect of a method for determining an in-vehicle role of a user of a mobile device 105 in accordance with at least one embodiment disclosed herein. The process begins at step 210 where an input is received from mobile device 105, and proceeds to step 220 where the first input is analyzed. At step 230, a determination factor such as a probability is computed, based on the various determination characteristics, as referenced above. Steps 210, 220, and 230 have already been described above with reference to FIG. 2A and thus will not be further elaborated upon here as their operation is substantially identical to steps 210, 220, and 230 described above.
Then, at step 250, processor 110 executing one or more of software modules 130, including, preferably, determination module 170, outputs one or more results based on the determination factor(s) computed at step 230. Such results can include, but are not limited to, one or more files, notifications, and/or communications that contain and/or reflect operations of the mobile device 105, and/or one or more operation states of the first mobile device 105, and the outputting of such results can be dependent upon a certain probability threshold, as described in detail herein. For example, in a scenario where mobile device 105 is configured to output results (such as that the in-vehicle role of a user is a
driver/passenger) when the probability (that is, the reliability) of such results are greater than 75%, when mobile device 105 determines with a probability of 80% that the in-vehicle role of a user of mobile device 105 is a driver, a corresponding notification can be outputted reflecting such results. Thus, it can be appreciated that the referenced results can be output based on the calculated probability that the user of mobile device 105 is a driver or that the user of mobile device 105 is a passenger. It should be understood that the outputting referenced at this step can be employed in a number of ways depending on the particular arrangement. For example, in certain arrangements the referenced results can be transmitted to an external device or third-party, such as a law enforcement agency, insurance company, and/or other device 160 (for example, a parent receiving results from a child's device 105), via communication interface 150. It can be appreciated that, as referenced above with regard to step 240, the outputting of such results to a law enforcement agency, insurance company, and/or another device 160 can ensure that such entities are notified of the various operations and/or operation states of a particular mobile device 105, especially when it has been determined that it is highly probable that device 105 is being operated by a driver of a car. In another arrangement, such results can be outputted to mobile device 105 itself in any number of ways, such as by logging the operations and/or operation state(s) of mobile device 105 at times/intervals when it has been determined, for instance, that there is a high probability that the user of mobile device 105 is a driver. Irrespective of whether the results are output to a third-party or to the device 105 itself, it should be appreciated that the outputting of such results can provide insight regarding the operations of the mobile device 105 at a particular moment and/or interval, which can be utilized later, such as in investigating car accidents. For example, if a car accident occurs, a law-enforcement agency can review such outputted results to determine whether the driver was engaged in various distracting activities during and/or near the time of the accident (e.g., mobile device 105 was being used by driver with 93% certainty, was being used in a hand-held state with 94% certainty, and was being used for texting with 100% certainty at least30 seconds prior to the crash). As such, it can be further appreciated in certain arrangements the various referenced results can be outputted across any and/or all degrees of probability, thereby ensuring a comprehensive log of a user results, reflecting the various operations and/or operation states throughout the course of operation of the mobile device 105.
Turning now to FIG. 3, a flow diagram is described showing a routine 300 that illustrates an aspect of a method for enabling, disabling and/or modifying at least a feature of a mobile device 105 in accordance with at least one embodiment disclosed herein.
The process begins at step 310 where processor 110 executing one or more of software modules 130, including, preferably, determination module 170, monitors one or more inputs from one or more of sensors 145, software modules 130, user interface 172, operating system 176, and/or communication interface 150. As described in detail above with reference to step 210, examples of such inputs include, but are not limited to, an acceleration input, a geographic location input, and/or one or more instances or user interaction (e.g., typing).
Then, at step 320, processor 110 executing one or more of software modules 130, including, preferably, determination module 170 defines an operation signature based on the inputs monitored at
step 310. The defined operation signature preferably reflects a normal operation state and/or a range of normal operation states of the mobile device 105. That is, based on the various inputs monitored at mobile device 105, over a defined time interval (for example, a day, a week, and/or a month) an operation signature or profile can be defined that reflects one or more values or ranges of values that have been identified as the normal or regular operation of the device 105, the normal or regular usage of the device 105 by a particular user, and/or the normal or regular usage of device 105 and/or a series or class of such devices by a particular user and/or a series or range of users. For example, after monitoring inputs from the accelerometer 145A of mobile device 105 for a period of time, a range of normal acceleration inputs of the device 105 can be determined. Similarly, upon monitoring inputs from the user interface 172 of mobile device 105, a range of normal typing tendencies (e.g., typing speeds, typing consistency, etc., as described herein) can be determined. These various inputs can be used to define an operation signature for the mobile device 105 that reflects the normal operation and/or operating range of the device 105. It should be appreciated that the referenced operation signature is not limited to a single input or type of input, but rather in certain arrangements can be made up of signatures of two or more types of inputs. For example, in one arrangement a normal operation signature can be made up of a range normal accelerometer inputs together with a range of normal typing tendencies.
At step 330, processor 110 executing one or more of software modules 130, including, preferably, determination module 170, further monitors one or more second inputs from one or more of sensors 145, software modules 130, user interface 172, operating system 176, and/or communication interface 150, substantially in the manner described above with respect to step 310.
Then, at step 340, processor 110 executing one or more of software modules 130, including, preferably, determination module 170, processes one or more of the second input(s) (monitored at step 330) against one or more of the operation signature(s) (defined at step 320). In doing so, processor 1 10 executing one or more of software modules 130, including, preferably, determination module 170, can identify a degree of deviation and/or a degree of correlation between the second input(s) and the operation signature(s). By way of example, various typing patterns and/or tendencies (referenced above) of mobile device 105 can be processed against an operation signature reflecting a range of normal typing tendencies of mobile device 105, as referenced above with respect to step 320 and described in detail herein. In doing so, processor 1 10 can analyze and/or identify the degree to which the one or more second input(s) (monitored at step 330) deviate from the operation signature of mobile device 105 (defined at step 320). Thus, continuing with the provided example, even in a case where the monitored typing tendencies of mobile device 105 are not necessarily highly inconsistent, from an objective standpoint, upon processing such inputs against an operation signature (such as an operation signature reflecting that the typing tendencies of the user of mobile device 105 are generally highly consistent/accurate), it can be revealed that the monitored typing tendencies/inputs actually deviate substantially from the mobile device's 105 operation signature. In this example, such a deviation from the operation signature (which reflects the normal and/or expected operation of mobile device 105) can indicate that the mobile device 105 is being operated under conditions that distract the user from interacting normally with the device 105, such as
during driving. Similarly, in an alternative example, in a case where the monitored typing tendencies of mobile device 105 are relatively inconsistent, from an objective standpoint, upon processing such inputs against an operation signature (such as an operation signature reflecting that the typing tendencies of the user of mobile device 105 are also generally inconsistent, such as in the case of a new user who is not adept at typing), it can be revealed that the monitored typing tendencies/inputs (which otherwise reflect significantly inconsistent typing tendencies) actually correlate substantially with the mobile device's 105 operation signature. In such an example, the correlation with the operation signature (which reflects the normal and/or expected operation of mobile device 105) can indicate that the mobile device 105 is actually being operated under relatively normal/consistent conditions, and thus should not be assumed to be operated under distracting conditions, such as driving, as may have otherwise been concluded based on the inconsistent typing tendencies alone.
At this juncture, it should be noted that steps 310 and 320 can be repeated on a periodic and/or constant basis, in order to further refine the operation signature defined at step 320. That is, it can be appreciated that in certain scenarios a user's interaction with mobile device 105 can change and/or improve over time (such as in the case of a new user whose typing skills gradually improve with repeated use of device 105), and thus the operation signature of mobile device 105 should be adjusted, modified, and/or refined accordingly. It can be appreciated that this process can be achieved in any number of ways. In one arrangement, mobile device 105 can be configured to periodically reset its operation signature (such as every month), such that only recent operations are accounted for in defining the operation signature. In other arrangements, further inputs that are monitored can be factored into and/or averaged with previously monitored inputs, thereby updating an existing operation signature. In yet other arrangements, further inputs can be factored into and/or averaged with previously monitored inputs, and the more recent inputs can be weighted to place greater emphasis upon them, thereby updating an existing operation signature while accounting for the fact that more recent inputs are of greater value in defining an accurate operation signature of a mobile device 105.
At step 350, processor 1 10 executing one or more of software modules 130, including, preferably, determination module 170, adjusts one or more operations of mobile device 105. Preferably, this adjustment corresponds to the degree of deviation and/or the degree of correlation between one or more monitored inputs (such as the input monitored at step 330) and one or more operation signature(s) of mobile device 105 (such as the operation signature defined at step 320). It should be understood that in certain arrangements, this adjustment is similar to the transformation of the operation state of mobile device 105 discussed in detail above with respect to step 240, and/or the outputting of one or more results discussed in detail above with respect to step 250. For example, in certain arrangements, processor 110 can coordinate the disabling of one or more features of the mobile device 105, such as the disabling of any and/or all features that enable the entry of text into mobile device 105, while in other arrangements notifications (such as warning notifications) can be provided at or transmitted to mobile device 105. Various other examples of adjustments to one or more operations of mobile device 105 are described in greater detail above with reference to steps 240 and 250.
As also described in detail above with respect to step 240, it should be noted that various of the adjustments employed at step 350 can be customized and/or configured in relation to various degrees of correlation and/or deviation identified at step 340. Thus, it can be appreciated that certain adjustments of the operation of mobile device 105 (for example, notifying law enforcement authorities) may only be appropriate when a high degree of deviation from a normal operation state (that is, from the operation signature) is identified (and, preferably, further that such a deviation is indicative of restricted or prohibited activity on the part of the user of mobile device 105). Other adjustments, such as providing a notification at mobile device 105, may be appropriate even for lower degrees of correlation/deviation, as described in detail above.
Turning now to FIG. 4, a flow diagram is described showing a routine 400 that illustrates an aspect of a method of determining at least one of an in-vehicle role of a user of a first mobile device and/or a handheld state of the first mobile device and/or a vehicle class of a vehicle containing the first mobile device using a central machine in accordance with at least one embodiment disclosed herein. As will be described in greater detail below, various of the steps and operations that make up routine 400 share substantial similarities to those described above in connection with FIGs. 2A-C and 3. However, it should be understood that while FIGs. 2A-C and 3 principally concern determinations occurring at mobile device 105, routine 400 is primarily directed to determinations performed at central machine 168, as will be described in greater detail below. It should be further noted that, as described in greater detail below, while any one of the particular steps, operations, and/or functions are described throughout the present disclosure as being performed at and/or upon a particular machine or device (such as mobile device 105, mobile device 160, and/or central machine 168), such description should be understood as being exemplary and/or illustrative and not limiting. Accordingly, it can be appreciated that any and all steps, operations, and/or functions described herein with regard to a particular device and/or machine (such as central machine 168) should be similarly understood to be similarly capably of employment at another device and/or machine (such as mobile device 105), substantially in the manner described herein, without departing from the scope of the present disclosure.
The process begins at step 410 where processor 4110 of central machine 168 (depicted in FIG. 1) executing one or more of software modules 4130, including, preferably, determination module 4170, receives (preferably through communication interface 4150) a first notification from mobile device 105, the first notification preferably corresponding to an input originating from one or more of sensors 145, software modules 130, user interface 172, operating system 176, and/or communication interface 150 of mobile device 105. As described in detail above with respect to step 210, the first input originates from one or more identifying events that are perceptible to at least one of sensors 145, user interface 172, operating system 176, and/or communication interface 150 of mobile device 105, such as an acceleration input perceived by accelerometer 145 A, a change in geographic location input perceived by GPS receiver 145C, and/or one or more instances or user interaction (e.g., typing) detected by user interface 172. A notification, such as a computer readable file containing information that reflects the input itself as well as information that is pertinent to the input (such as the time, date, and a unique identifier such as a MAC
address of mobile device 105) is preferably generated by mobile device 105 based on the input, and is transmitted by communication interface 150 of mobile device 105 to central machine 168, preferably via communications network 166. As noted above, it should be recognized that while FIG. 1 depicts central machine 168 communicating with mobile device 105 via network/Internet 166, it should be understood that in other arrangements central machine 168 communicates with mobile device 105 directly, such as through a direct Bluetooth pairing and/or through an ah-hoc wireless network.
Then, at step 420, processor 4110 of central machine 168 executing one or more of software modules 4130, including, preferably, determination module 4170, analyzes at least the first notification to identify one or more determination characteristics, such as one or more of user determination characteristics and/or one or more handheld state characteristics and/or one or more vehicle determination characteristics within the notification. As described in detail above with respect to step 220, user determination characteristics are one or more aspects originating at and/or derived from one or more input(s) and/or notification(s) that provide insight regarding the in- vehicle role, and/or identity of the user that is exerting control over and/or otherwise associated with a mobile device, such as mobile device 105. Similarly, handheld state characteristics are one or more aspects originating at and/or derived from one or more input(s) and/or notification(s) that provide insight regarding the handheld state of a mobile device, such as mobile device 105, such as whether mobile device 105 is being operated by a user in a handheld or non-handheld state (for example, various angles and/or sudden changes perceived by gyroscope 145B can indicate that mobile device 105 is being operated in a handheld state by a user). It can thus be appreciated that while the underlying analysis performed at the present step 420 and at step 220, as described above, are substantially similar, here the analysis is performed by central machine 168 based on notifications received from mobile device 105, while at step 220 the analysis is preferably performed by mobile device 105 itself. Having this analysis performed at central machine 168 (as opposed to at mobile device 105, from which the notification analyzed at this step originates) provides several advantages in certain scenarios over having the analysis performed at mobile device 105, as described at step 220. For example, the analysis performed at the present step can be quite resource intensive, and shifting this analysis to central machine 168 ensures that the system resources of mobile device 105 remain relatively free. Additionally, in certain arrangements central machine 168 can be operated by a law enforcement agency, and, as such, a centralized approach, such as the one described with respect to FIG. 4, can provide such an agency with the ability to monitor and/or adjust the operational capacity of mobile device 105 as necessary, as will be described in greater detail below. Moreover, in certain scenarios this centralized approach can be easier to implement with respect to regulatory compliance and preventing tampering. It is expected that both regulatory authorities who are interested in implementing a solution such as that described with reference to FIG. 4 are more likely to succeed in obtaining compliance from mobile device manufacturers and/or mobile communications providers when requiring a solution that primarily only requires, from the standpoint of the mobile device 105, periodic notification transmissions from mobile device 105 to central machine 168. In addition, such a solution can be more difficult for
users to manipulate, modify, and/or 'hack,' given that the primary analysis is performed by central machine 168, as opposed to mobile device 105.
At step 430, processor 4110 of central machine 168 executing one or more of software modules 4130, including, preferably, determination module 4170, computes one or more determination factor(s), such as probabilities, based on the determination characteristics identified at step 420. It should be understood that, for instance, based on the particular inputs upon which a notification (which is analyzed at step 420) is based, various user determination characteristics and/or handheld state characteristics are generated. For example, as referenced above, in certain arrangements user determination characteristics are identified (such as typing tendencies, as referenced above), while in other arrangements handheld state characteristics (such as one or more angles detected by mobile device 105, as referenced above) can be identified, while in yet other arrangements both user determination characteristics and handheld state characteristics can be identified. In any event, at step 430, one or more probabilities are computed by central machine 168, reflecting a probability that the in- vehicle role of the user of mobile device 105 is a driver, a probability that the in- vehicle role of the user of the mobile device 105 is a passenger, a probability that the handheld state of the mobile device 105 is handheld, and/or a probability that the handheld state of the mobile device 105 is non-handheld, all in a manner substantially similar to that described in detail above with respect to step 230. It should be understood that, as described in detail above, in certain arrangements the user determination characteristics and/or handheld state characteristics identified at step 420 can provide varying degrees of certitude as to the identity/role of a user and/or the handheld state of mobile device 105. Accordingly, it should be appreciated that because ranges exist across the spectrum of a particular user determination and/or handheld state characteristic (such as typing consistency and/or device angle), a probability that an in- vehicle role of the user of mobile device 105 is a driver/passenger and/or a probability that a handheld state of mobile device 105 is handheld/non-handheld preferably reflects a degree of certainty across such a probability spectrum, as described in detail above.
Then, at step 440, processor 4110 of central machine 168 executing one or more of software modules 4130, including, preferably, determination module 4170, adjusts an operational capacity of mobile device 105 based on the one or more determination factor(s), such as at least one of the probabilities computed at step 430, substantially in the manner described in detail above with respect to step 240. However, it should again be understood that while the description pertaining to step 240 above relates to adjustments and transformations initiated by mobile device 105 upon itself, here the adjustments to the operation of mobile device 105 are initiated by central machine 168. For example, in certain arrangements central machine 168 can transmit an operation command, such as a command in the form of one or more notifications, messages, and/or instructions that reflect various adjustments that are to be made to the operational capacity of mobile device 105, and such adjustments can then be applied to mobile device 105 upon its receipt of the transmitted operation command(s), and/or their application/execution, effecting similar and/or identical results as those described in detail above with respect to step 240 (e.g., providing notifications at mobile device 105, restricting operation of mobile device 105, and/or transmitting notifications from mobile device 105 to third parties). In other
arrangements, central machine 168 can adjust the operational capacity of mobile device 105 based primarily and/or exclusively on adjustments made at and/or by central machine 168 which, in turn, preferably effect or otherwise adjust the operational capacity of mobile device 105. For instance, in an arrangement where central machine 168 is controlled by a mobile communications provider such as a cellular communications provider, an adjustment can be implemented at central machine 168 whereby one or more of the services provided by mobile communications provider to mobile device 105 (such as phone, SMS, and/or data services) can be interrupted and/or otherwise adjusted or modified, thereby effecting the operation of mobile device 105 through an adjustment occurring at central machine 168 based on the probability computed at step 430. It should be noted that in other arrangements, substantially similar adjustments can be implemented upon and/or through one or more service providers that provide one or more services, whether directly or indirectly, to mobile device 105. By way of illustration, various voice over IP (VoIP) providers, such as Skype, enable users to achieve voice communications (akin to telephone calls) over data connections (such as an internet connection). By way of further illustrations, the 'Viber' app enables similar SMS capabilities over an internet connection. In any event, it should be understood that the methods and systems disclosed herein can be configured such that any necessary adjustment can be implemented upon and/or through the requisite service provider (for example, by limiting the calling capabilities of Skype and/or the SMS capabilities of Viber) substantially in the manner described in detail above.
At step 450, processor 4110 of central machine 168 executing one or more of software modules 4130, including, preferably, determination module 4170, outputs one or more results and/or operation states of mobile device 105 based on the one or more determination factor(s), such as the probability or probabilities computed at step 430, substantially in the same manner as described in detail above with respect to step 250. But again, as noted above, it should be understood that while the description provided above with respect to step 250 pertains to one or more operations performed at mobile device 105, step 450 primarily pertains to operations initiated and/or performed by central machine 168. Accordingly, it can be appreciated that the one or more operation state(s) outputted by central machine 168 reflect the operation state(s) of mobile device 105 (for example, that the device is being used in a handheld state and/or that the device is being used by a driver). As noted in detail above with respect to step 250, the outputting of the operation state(s) can be further based upon one or more determination factor(s), such as one or more probabilities computed at step 430, which reflects the likelihood or degree of certainty that a user of mobile device 105 is a driver/passenger and/or that mobile device 105 is being used in a handheld/non-handheld state. As also noted in detail above, in certain arrangements the operation state of mobile device 105 can be outputted by central machine 168 to an external device or third-party, such as a law enforcement agency, insurance company, and/or other device 160, via communication interface 4150. Such functionality can be advantageous in jurisdictions where administrative regulations recommend and/or require that entities such as mobile communications providers provide information to law enforcement agencies that reflects the unauthorized usage of mobile devices such as mobile device 105 while the user of the device is driving. Similarly, such functionality
can be advantageous to insurance companies when processing an insurance claim. Even in situations where the user of a mobile device, such as mobile device 105, is uncooperative in providing information to the insurance company, and/or in situations where the mobile device associated with an involved party is no longer available or has been destroyed, central machine 168 (which receives and retains the various pertinent notifications/inputs provided by the various devices such as mobile device 105) can output the necessary data, such as the operation state of mobile device 105, thereby assisting the insurance company to make necessary decisions regarding the validity of a particular insurance claim.
Turning now to FIG. 5, a flow diagram is described showing a routine 500 that illustrates an aspect of a method of determining a vehicle class of a vehicle using a first mobile device in accordance with at least one embodiment disclosed herein. As will be described in greater detail below, determining the vehicle class of a particular vehicle can provide further insight and accuracy in the determination of an in- vehicle role of a user of a mobile device. In addition, it should be understood that the various steps and/or operations that make up routine 500 share substantial similarities to those described above in connection with FIGs. 2A-C and 3-4.
The process begins at step 510 where processor 110 executing one or more of software modules
130, including, preferably, determination module 170, receives a first input from one or more of sensors 145, software modules 130, user interface 172, operating system 176, and/or communication interface 150.
Then, at step 520, processor 110 executing one or more of software modules 130, including, preferably, determination module 170, analyzes at least the first input to identify one or more vehicle determination characteristics within the first input. As will be described in greater detail below, vehicle determination characteristics are one or more aspects originating at and/or derived from an input that provide insight regarding the vehicle class within or upon which and/or in relation to mobile device 105 is traveling.
Upon identifying one or more vehicle determination characteristics based on the analysis of an input, at step 530 processor 110 executing one or more of software modules 130, including, preferably, determination module 170, computes at least one determination factor based on the vehicle determination characteristic(s), such as a probability that the vehicle corresponds to a particular vehicle class.
Then, at step 550, processor 110 executing one or more of software modules 130, including, preferably, determination module 170, outputs a vehicle class based on the one or more determination factor(s), such as the probability or probabilities computed at step 530.
It should also be noted that, in certain arrangements, the processor 110 executing one or more of software modules 130, including, preferably, determination module 170, can transform an operation state of mobile device 105 based in whole or in part on the determination factor(s), such as the probability computed at step 530. This operation can be further appreciated when employed in conjunction with a determination of an in-vehicle role of a user of mobile device 105, such as that depicted in FIGs. 2A-C and described in detail above. For example, in certain arrangements, upon determining (preferably to a
certain minimum probability) that a mobile device 105 is traveling within a certain class of vehicle, there can be little need to further determine the in-vehicle role of the user of the device 105 (e.g., if the vehicle is an airplane, all device usage can be prohibited, irrespective of a particular user's in-vehicle role). By way of further example, in other arrangements, a transformation (substantially similar to that described in detail above with respect to step 240) can be employed based upon both the computed probability that mobile device 105 is traveling in a car, together with the computed probability (such as that described in detail above with respect to step 230) that the in-vehicle role of a user of mobile device 105 is a driver. In such a scenario, processor 110 can coordinate various transformations and/or adjustments to the operation(s) of mobile device 105, as described in detail above with respect to step 240. As also noted above, in certain arrangements various of the referenced transformations can be employed only when either one or both of the probabilities pertaining to the vehicle class within which mobile device 105 is traveling and/or the in-vehicle role of the user of mobile device 105 is a driver meet and/or exceed a certain minimum threshold.
Turning now to FIG. 6, a flow diagram is described showing a routine 600 that illustrates an aspect of a method of determining a handheld state a mobile device in accordance with at least one embodiment disclosed herein. As will be described in greater detail below, various of the steps and operations that make up routine 600 share substantial similarities to those described above in connection with FIGs. 2A-C, 3, 4, and 5. However, it should be understood that while at least FIG. 4 principally concerns determinations occurring at central machine 168, routine 600 is primarily directed to determinations performed at mobile device 105, as will be described in greater detail below.
The process begins at step 610 where processor 110 executing one or more of software modules 130, including, preferably, determination module 170, receives a first input from one or more of sensors 145, software modules 130, user interface 172, operating system 176, and/or communication interface 150. Preferably, the first input originates from one or more identifying events that are perceptible to at least one of sensors 145, user interface 172, operating system 176, and/or communication interface 150. As described in detail above with respect to step 210, the first input originates from one or more identifying events that are perceptible to at least one of sensors 145, user interface 172, operating system 176, and/or communication interface 150 of mobile device 105, such as an acceleration input perceived by accelerometer 145A and/or a change in orientation input perceived by gyroscope 145B. It should be noted that in certain arrangements a series of inputs (such as a number of acceleration inputs over a certain period of time) and/or a combination of inputs (such as a number of acceleration inputs and orientation inputs over a period of time) are received, such as one or more inputs that reflect the incidence of shaking or vibration at mobile device 105.
Then, at step 620, processor 110 executing one or more of software modules 130, including, preferably, determination module 170, analyzes at least the first input to identify one or more handheld state characteristics within the notification. As described in detail above with respect to step 420, handheld state characteristics are one or more aspects originating at and/or derived from one or more input(s) that provide insight regarding the handheld state of a mobile device, such as mobile device 105,
such as whether mobile device 105 is being operated by a user in a handheld or non-handheld state. For example, various orientations and/or sudden changes perceived by gyroscope 145B (preferably, in certain scenarios, in combination with one or more inputs from various other sensors 145 such as accelerometer 145A, GPS 145C, and/or magnetometer 145E) can indicate that mobile device 105 is being operated in a handheld state by a user. By way of further example, a relatively constant pattern of inputs from accelerometer 145A and/or gyroscope 145B can indicate that mobile device 105 is positioned in a relatively stable manner, thus indicating that it is being operated in a non-handheld state.
At step 630, processor 110 executing one or more of software modules 130, including, preferably, determination module 170, computes one or more determination factor(s), based on the handheld state determination characteristic(s), such as a probability that that the handheld state of mobile device 105 is handheld, or that the handheld state of mobile device 105 is non-handheld. By way of example, based on a series of accelerometer 145A and gyroscope 145B inputs, the pattern of which indicates ongoing vibration and/or movement, it can be computed that there is a high probability (e.g., greater than 90%) that mobile device 105 is being operated in a handheld state. This is because a user of handheld mobile device 105 - and particularly a driver who is further distracted by his/her driving responsibilities - is liable to produce far more vibration/shaking that is perceptible by mobile device 105, especially as compared to a non-handheld device that is stationed in a dock, for instance. In any event, at step 630, such probabilities are computed, reflecting a probability that the handheld state of the mobile device 105 is handheld, and/or a probability that the handheld state of the mobile device 105 is non-handheld, in a manner substantially similar to that described in detail above with respect to steps 230 and 430. It should be understood that, as described in detail above, in certain arrangements the handheld state characteristics identified at step 620 can provide varying degrees of certitude as to the handheld state of mobile device 105. Accordingly, it should be appreciated that because ranges exist of a particular handheld state characteristic (such as device shake patterns), a probability that a handheld state of mobile device 105 is handheld/non-handheld preferably reflects a degree of certainty across such a probability spectrum, as described in detail above.
At step 650, processor 110 executing one or more of software modules 130, including, preferably, determination module 170, outputs one or more handheld states of mobile device 105 based on the one or more determination factor(s), such as the probability or probabilities computed at step 630, substantially in the same manner as described in detail above with respect to steps 250, 450,and 550. For example, if, at step 630, it is computed that it is 90% likely that mobile device 105 is being operated in a handheld state, at step 650 a notification can be provided at mobile device 105 indicating that it has been determined that the device is being so operated. In certain arrangements such a notification can further include a suggestion/instruction that the user of the device 105 refrain from further use of the device, in deference to regulatory guidelines. In other arrangements, the handheld state of mobile device 105 can be output to a third-party, such as a law enforcement agency, under appropriate circumstances. Additionally, as noted in detail above with respect to step 250, such outputting can, in certain arrangements, be contingent upon a certain minimum probability being computed (e.g., a 90% or greater probability that a
mobile device 105 is operating in a handheld state), while in other arrangements the handheld state can be outputted across any and/or all degrees of probability.
It should also be noted that, as noted above in detail with respect to FIG. 5, in certain arrangements, the processor 110 executing one or more of software modules 130, including, preferably, determination module 170, can transform an operation state of mobile device 105 based in whole or in part on the one or more determination factor(s), such as the probability computed at step 630. This operation can be further appreciated when employed in conjunction with a determination of an in-vehicle role of a user of mobile device 105, such as that depicted in FIGs. 2A-C and described in detail above. For example, in certain arrangements, upon determining (preferably to a certain minimum probability) that a mobile device 105 is under the control of a driver of a vehicle (such as by processing the inputs from accelerometer 145A and gyroscope 145B of mobile device 105 against those of other mobile devices 160 within the same vehicle, thereby identifying the driver of the vehicle, as described in detail herein), it can then be further determined whether mobile device 105, which has been determined to be under the control of a driver, is being operated in a handheld state (generally prohibited in most places) or in a non-handheld state (generally permitted). Accordingly, in such an arrangement (where mobile device 105 has been determined to be under the control of a driver and is being used in a handheld state), a transformation (substantially similar to that described in detail above with respect to step 240) can be employed In such a scenario, processor 110 can coordinate various transformations and/or adjustments to the operation(s) of mobile device 105, as described in detail above with respect to step 240. As also noted above, in certain arrangements various of the referenced transformations can be employed only when either one or both of the probabilities pertaining to the user role of the user of mobile device 105 is a driver and/or the handheld state of mobile device 105 is handheld meet and/or exceed a certain minimum threshold.
Moreover, in certain implementations, a mobile device 105 that is positioned in a cradle or dock (whether a 'dumb' cradle that simply holds a device or a 'smart' cradle that provides power and/or other connectivity to a device) that has not already been authenticated to be operated by a user that is a passenger (such as in the manner described in detail herein) can be configured to employ a particular restriction and/or set of restrictions (such as those described in detail herein) thereto, such restriction/set of restrictions preferably being different than restrictions that are employed at a device that has also not been authenticated as being operated by a passenger but is not in a cradle. Being that positioning a device in a cradle entails some degree of additional safety in relation to operation of the device on the part of the driver (being that the driver is not holding the device in his/her hand), in addition to the fact that in certain jurisdictions it is permitted to operate mobile devices in certain manners when positioned in a cradle, it can be appreciated that in certain implementations, it can be preferable to implement restrictions that account for these factors. For example, in such a scenario a cradled device can be employed with a restriction that still allows the user to make and/or to receive calls in geographic locations (e.g., a particular state or country) that allow the use of hands-free devices for calling, whereas a comparable non-cradled device can be restricted from even making such calls. It can be further appreciated that in
certain implementations, such restriction(s) (and/or any of the other restrictions referenced herein) can be employed, for example, on/at the mobile device, on the SIM card, and/or by the cellular carrier (that is, in relation to the mobile device).
It should also be appreciated that in certain implementations, one or more restrictions can be employed at/in relation to a mobile device, based on a geographical determination, as referenced above. That is, in light of differences in laws regulating mobile device usage by drivers in difference jurisdictions, one or more restrictions can be selectively employed at a mobile device based on a determination of the location of the device (e.g., based on inputs received from the GPS). Thus, in a scenario where State A prohibits texting while driving, while State B prohibits texting while driving and talking while driving, the appropriate corresponding restriction (effectively preventing/precluding the mobile device from performing the prohibited operation) can be employed based on the location of the mobile device (as determined by the GPS, cell towers and/or wifi transceivers seen/detected, as is known to those of ordinary skill in the art).
In certain implementations, a device can be determined to be positioned in a cradle or dock based on the level of movement of the device. For example, a device that is held in a cradle will tend to move less than a device that is not held fixed in a cradle - as can be determined based on an analysis of inputs originating at the accelerometer and/or gyroscope of the device, and, for example, the tightness (e.g., standard deviation) of the distribution of accelerometer readings or changes thereto, such as in a manner described herein and known to those of ordinary skill in the art.
In other implementations, the orientation of the device can be used to determine if a device is in a cradle or not. For example, a device that is in a cradle will have a fixed and known orientation (e.g., generally the y-axis accelerometer, as shown in FIG. 9A) will pick-up a large component of gravity and/or the X-axis accelerometer will pick up a large component of gravity, as can be appreciated by those of ordinary skill in the art..
In certain implementations, the presence/existence of connections to the device ('smart' cradles supply power and/or connectivity to the device) can be used to determine if a device is in a cradle or not.
In yet other implementations, the orientation of a device relative to the vehicle in which it is present can be used to determine if the device is in a cradle or not. If such orientation is fixed over some time period, then it can be determined that the device is fixed (e.g., is positioned in a cradle/dock). If such orientation is not fixed (e.g., the device is actually hand-held), then it can be determined that the device is not in a cradle. For example, the orientation of the device relative to the vehicle can be determined at any point in time using (a) the device's GPS bearing, which measures the direction of movement of the device with respect to the Earth (denoted G), regardless of the orientation of the device within the vehicle; and (b) the device's magnetometer/compass, which measures the orientation of the device with respect to the Earth's magnetic field (denoted M), which depends on the orientation of the device in the vehicle and the bearing of the vehicle. For a device whose orientation with respect to the vehicle is fixed (e.g., a device in a cradle), a constant rotation matrix, R, can be found/computed, such that G*R=M, such as in a manner
known to those of ordinary skill in the art. However, for a device whose orientation with respect to the vehicle is not fixed (e.g., a hand-held device), such rotation matrix is not constant.
It should also be understood that the identification of a device as being in a cradle/dock, as referred to herein, can be configured/expanded to any device whose position relative to the vehicle's is static and/or any device that is not hand-held.
Various of the referenced implementations and functionalities relating to the cradle/dock status of the mobile device are described in greater detail below, specifically with respect to FIG. 24.
Turning now to FIG. 7, a flow diagram is described showing a routine 700 that illustrates a broad aspect of a method restricting operation of a mobile device 105 in accordance with at least one embodiment disclosed herein. As will be described in greater detail below, various of the steps and operations that make up routine 700 share substantial similarities to those described above in connection with FIGs. 2A-C, 3, 4, 5, and 6. It should be noted at the outset that while the following description of routing 700 will be directed primarily to operations occurring at mobile device 105, such description is exemplary and intended for the sake of clarity and consistency. However, it should be understood that any and/or all of the steps in routine 700 can be similarly employed at another device/machine, such as at central machine 168, such as in the manner described in detail above with respect to FIG. 4. Furthermore, the same principle should be understood and appreciated with respect to any and all of the various steps, operations, and/or functions described throughout the present disclosure. That is, while any one of the particular steps, operations, and/or functions are described herein as being performed at and/or upon a particular machine or device (such as mobile device 105, mobile device 160, and/or central machine 168), such description should be understood as being exemplary and/or illustrative and not limiting. Accordingly, it can be appreciated that any and all steps, operations, and/or functions described herein with regard to a particular device and/or machine (such as mobile device 105) should be similarly understood to be similarly capably of employment at another device and/or machine (such as central machine 168), substantially in the manner described herein, without departing from the scope of the present disclosure.
At step 701, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171 determines whether mobile device 105 is present with a vehicle, such as through one or more of the various determination methods described in detail herein.
Upon determining the mobile device 105 is within a vehicle (such as a car, a truck, a van, a motorcycle and a jeep.), at step 703, processor 1 10 executing one or more of software modules 130, including, preferably, restriction module 171 determines whether the vehicle is in motion, such as through one or more of the various determination methods described in detail herein.
At step 705 where processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, employs a first restriction at mobile device 105 and/or in relation to mobile device 105. As will be described in greater detail herein, the first restriction is preferably one or more instructions that dictate at least one operation state of the mobile device. Examples of such restrictions include but are not limited to: instructions that disable a particular feature or functionality of a
mobile device 105 (such as the ability to type text), instructions that disable multiple features or functionalities of a mobile device 105 (such as the ability to launch certain applications and the ability to receive text messages), and instructions that functionally "lock" mobile device 105 by effectively disabling many or all of the functionalities of the device. It should be understood that in many arrangements, the referenced first restriction is preferably a default restriction. That is, in such arrangements the first restriction is employed by default, such as upon powering on and/or activating mobile device 105. It should be appreciated that in certain arrangements such restriction can be employed in relation to mobile device 105, such as by a central machine 168, such as in the manner disclosed in detail herein, for example with respect to FIG. 4. By way of illustration, the referenced restriction can be imposed by a communications provided (which preferably operates central machine 168) to prevent transmission of one or more communications (e.g., SMS messages) to a mobile device 105, until an identification determination is made, such as identifying that two or more users are in a vehicle, such as in the manner disclosed in detail herein.
It should be understood that in various arrangements, including many of those described herein, the various restrictions employed at mobile device 105 are directed towards configuring mobile device 105 in such a manner that operation of and/or interaction with the device is difficult, inconvenient, and/or impossible (that is, it can be said that operation of mobile device 105 is impeded) for a user who is also simultaneously operating a vehicle. At the same time, such restrictions are also preferably configured to create minimal, if any, difficulty and/or inconvenience when operated by and/or interacted with by a user who is not simultaneously operating a vehicle. In other words, it can be said that such restrictions preferably impede operation of the mobile device by a user who is a driver moreso than they impede operation of the mobile device by a user who is a passenger. As such, it should be further understood that in certain arrangements it can be preferably for mobile device 105 to initially determine that the device is present within a vehicle (such as through one or more of the various determination methods described in detail herein) prior to employing such a first restriction. Accordingly, it can be further appreciated that the various steps and operations described herein with reference to FIGs. 7-8 can be further implemented, in certain arrangements, in conjunction with one or more of the various other methods and systems described in detail herein, such as those described with reference to FIGs. 2A-6. Furthermore, it should be recognized that any one or more of the various steps, operations, routines, functions, and/or figures disclosed herein can preferably employed in conjunction within any one or more of the various steps, operations, routines, functions, and/or figures disclosed herein. Thus, for example, the various restrictions described in conjunction with FIG. 7 can be employed in conjunction with the various determination operations described above. By way of example, one or more of the referenced restrictions can be employed before the occurrence of and/or in response to one or more of the determinations described in detail herein.
It should be understood that in various arrangements, at least one of the one or more restrictions that dictate the at least one operating state of mobile device 105 are determined based on inputs originating at at least one of the various sensors 145, etc., as described in greater detail herein.
At step 707, mobile device 105 preferably prompts one or more users to initiate and/or provide one or more stimuli that can be received as inputs at mobile device 105. By way of example, mobile device 105 can prompt each of the one or more users in a vehicle to repeat a particular word or series of words projected by mobile device 105. It should be understood that in certain arrangements such a prompt can request for the words to be repeated sequentially while in other arrangements such a prompt can request for the words to be repeated simultaneously, while in yet other arrangements the timing of the repetition is of no consequence. It should be appreciated that such prompting can request practically any stimulus that can be received and/or analyzed as an input in the manner described herein.
At step 710, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171 receives at least a first input and a second input (e.g., the referenced stimuli), in the manner disclosed in detail herein. As has already been described in detail herein, each of the first input and the second input preferably originate at one or more of sensors 145, software modules 130, user interface 172, operating system 176, and/or communication interface 150, though it should be understood that the first input and the second input need not originate from the same source.
It should be understood that, as referred to herein, such inputs are referred to as originating at one or more of sensors 145, software modules 130, user interface 172, operating system 176, and/or communication interface 150 in the sense that such inputs are initially perceived - from the perspective of mobile device 105 - at such components. However, it should be recognized, as will be appreciated in connection with the following examples, that in many arrangements and scenarios such inputs (and/or the stimuli and/or phenomena that trigger them) can ultimately originate at sources other than at various components of mobile device 105. Accordingly, it should be appreciated that within the context of the discussion of the subject matter encompassed by FIG. 7, various inputs are referred to as originating at a particular component in the sense that they originate from such a component with respect to mobile device 105. However, it is acknowledge that such inputs can, in turn, have ultimate origins beyond mobile device 105 itself, such as from the voice of a particular user and/or from an external system or device, as illustrated below.
For example, a first input corresponding to the audio tones of the voice of a first user can be received at microphone 145D, and a second input corresponding to the audio tones of the voice of a second user can also be received at microphone 145D. It should also be understood that in certain arrangements, one or more of the various inputs can be received at and/or originate from a source external to mobile device 105, such as vehicle data system 164 and or another mobile device 160. By way of example, vehicle data system 164 can provide an input to mobile device 105 (preferably received via communication interface 150) indicating the weight measured on one or more seats of a vehicle, and/or the usage of seat belts at one or more seats of a vehicle, etc - which can in turn, indicate that more than one user is within a vehicle. By way of further example, a detection of mobile device 160 within a vehicle (using one or more of the methods described herein) can also indicate that more than one user is within a vehicle.
At this juncture, it should be noted that while the first input and the second input have been described herein as being discrete inputs, such description is merely exemplary and for the sake of clarity and illustration. Accordingly, while in certain arrangements the first input and the second input are separate inputs in the conventional sense - that is, inputs that originate at two independent sources, in other arrangements the first input and the second input are actually aspects found within a single input. For example, a single audio input (such as an audio recording) that contains two distinct voices (such as the voices of a first user and a second user) can be processed (in the manner described herein) to identify such distinct voices within the single audio input, which are understood to be a first input and a second input within the context of the present disclosure.
Then, at step 720, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, analyzes the first input and the second input, hi doing so, the presence of at least one of two or more users and/or two or more mobile devices can be determined, such as a determination of the presence of a first user and the presence of a second user, such as in the manner described in detail herein. By way of illustration, continuing with the example referenced above at step 710, the first and second inputs (that is, the audio tones of the voices of the first user and the second user) can be analyzed to identify an audio signature for each of the respective inputs, in a manner known to those of ordinary skill in the art, and such audio signatures can then be compared to determine if they are substantially similar and/or identical (indicating that both inputs likely originate from the same source, i.e., the same user) or substantially dissimilar (indicating that each of the inputs likely originate from different users). Thus, upon identifying that first input (here, the voice of the first user) is substantially distinct from the second input (here, the voice of the second user), it can be concluded at minimum that the device 105 is in the presence of (if not in close proximity to) a first user and a second user. Additional illustrations of such inputs to determine the presence of at least one of two or more users and/or two or more mobile devices are presented below at EXAMPLE 4,
Upon determining that mobile device 105 is in the presence of at least one of (a) two or more users and/or (b) two or more mobile devices, such as by determining the presence of at least a first user and a second user, at step 742 processor 1 10 executing one or more of software modules 130, including, preferably, restriction module 171 modifies an employment of at least one restriction such as the first restriction. That is, being that a determination (at step 720) that the device is in the presence of at least two users necessarily indicates that at least one of such users is not a driver of a vehicle, this conclusion can preferably trigger and/or initiate the modification of the first restriction. In certain arrangements, such modification can include the employment of a second restriction, strengthening of the first restriction, and/or the easing of the first restriction. In one arrangement, such a second restriction can include one or more instructions that dictate one or more operational states of the mobile device 105 with respect to one or more of the various sensors 145 of the device, That is, as noted above, such a restriction can configure mobile device 105 to operate in a manner that is relatively difficult/inconvenient for a driver while being relatively unobtrusive for a passenger. Put differently, it can be said that such restrictions impeded operation of mobile device 105 by a user who is a driver moreso than the same
restrictions impede operation of a mobile device 105 by a user who is a passenger. Examples of such restrictions include but are not limited to: requiring that the device only operate in 'landscape' mode (which generally requires two hands for efficient interaction/navigation - a demand that is relatively simple for a passenger to comply with but relatively difficult for a driver, who needs at least one hand to steer the vehicle, to comply with), requiring that the device operate only at certain orientations (as detected by one or more of sensors 145, such as gyroscope 145B, accelerometer 145A, GPS 145C, and magnetometer 145E) such as a completely upright orientation which is relatively simple for a passenger to comply with but which is inconvenient for a driver who will not find such an orientation as comfortable while driving and who will generally wish to hold the device at alternate orientations in order to obscure the device from the view of law enforcement officials), and that the device not operate in a manner/pattern that is consistent with that of a driver (such as the various in-vehicle role determinations described in detail herein). It should be noted that although such restrictions are generally effective, on average, in impeding operation of a device by a driver moreso than a passenger, it is recognized that certain individual drivers may not find such restrictions particularly inconvenient, while other passengers may find them highly inconvenient. Nevertheless, on average, such restrictions impede the operation of mobile device 105 by drivers moreso that they impede such operation of mobile device by passengers.
In the event that the presence of at least one of (a) two or more users and/or (b) two or more mobile devices, such as the presence of a first user and a second user, are not determined and/or one or more users not in the set of users known to be users of the mobile device, is not determined (at step 720), at step 744 processor 110 executing one or more of software modules 130, including, preferably, restriction module 171 maintains the employment of the first restriction.
Turning now to FIG. 8, a flow diagram is described showing a routine 800 that illustrates a broad aspect of a method restricting operation of a mobile device 105 in accordance with at least one embodiment disclosed herein. As will be described in greater detail below, various of the steps and operations that make up routine 800 share substantial similarities to those described in detail herein.
At step 801, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171 determines whether mobile device 105 is present with a vehicle, such as through one or more of the various determination methods described in detail herein.
Upon determining that mobile device 105 is within a vehicle (such as a car, a truck, a van, a motorcycle and a jeep.), at step 803, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171 determines whether the vehicle is in motion, such as through one or more of the various determination methods described in detail herein.
At step 805, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, employs one or more restrictions at mobile device 105 and/or in relation to mobile device 105, substantially in the manner described above with respect to step 705. It should be understood that such restriction(s) are preferably configured to impede operation of mobile device 105 by a user that is a driver moreso than the restriction(s) impede operation of mobile device 105 by a user that is a passenger, as described in detail herein. Examples of scenarios where the operations of routine 800 can
be implemented include teenage drivers (wherein a parent/guardian wishes to employ such restrictions, which make it difficult to operate a mobile device 105 while driver, at all times) and/or phones that are fixed in vehicles, such as car phones (wherein it is always desirable to implement such restrictions). It should be appreciated that in certain arrangements such restriction can be employed in relation to mobile device 105, such as by a central machine 168, such as in the manner disclosed in detail herein, for example with respect to FIG. 4. By way of illustration, the referenced restriction can be imposed by a communications provided (which preferably operates central machine 168) to prevent transmission of one or more communications (e.g., SMS messages) to a mobile device 105, until an identification/determination is made, such as identifying that two or more users are in a vehicle, such as in the manner disclosed in detail herein.
It should be further understood that in certain arrangements, such restriction can be further configured to impede operation of the mobile device, and/or be more likely to be applied to a mobile device used by a driver than to a mobile device used by a passenger. By way of example, consider a scenario where a particular restriction is employed such that if the 'shake' perceived at mobile device 105 exceeds a certain threshold level, SMS messages cannot be sent from the device. It can be appreciated that employment of such a restriction does not impede drivers more than passengers (being that, once employed, it will impede a driver and a passenger equally), however such a restriction is more likely, on average, to be employed for drivers than for passengers (being that drivers, on average, shake their devices more than passengers). Further such examples are provided at EXAMPLE 4.
It should be further understood that, as described in detail above, such restriction(s) can be configured to be applied to a mobile device as used by a first user moreso than such restrictions are applied to a mobile device used by a second user. By way of example, such restrictions can be configured to impede a user who uses the mobile device in an unauthorized operation state moreso than a user who uses the mobile device in an authorized operation state. By way of illustration, one such example, which is preferably directed to preventing students from using their mobile devices while they are in a classroom setting, can impose a restriction such that the mobile device is only operable and/or functional if the device is held upright and/or at a certain altitude (as can be determined based on one or more of sensors 145, as described in detail herein). In doing so, students will effectively have to hold their mobile devices upright and in a certain conspicuous orientation, such that it will be very difficult for such students to operate their mobile devices inconspicuously during a class, such as underneath a desk. Accordingly, it can be appreciated that such a restriction impedes users (here, students) who use their mobile devices in an unauthorized operation state (that is, for example, during class), which such a restriction does not impede users who use their mobile devices in an authorized operation state (that is, when not in class) to the same degree. It should be further understood that the referenced examples and illustrations are merely exemplary, and that many other such restrictions within the scope of the present disclosure are similarly possible.
Additionally, a device that is located in a vehicle can be used to determine whether the vehicle's engine is on or off. One manner in which this is useful, is when considering that a vehicle that has
recently stopped moving, but whose engine is still on, may likely continue its present trip (e.g., stopped at a red light), whereas a vehicle that has recently stopped moving and whose engine is off has likely finished its present trip. Differentiating between these two states in useful, among other reasons, in order to know when usage restrictions on a driver's device should be lifted, such as in the manner described herein.
In one implementation, the device's accelerometer and/or gyroscope and/or magnetometer can be used to determine whether the engine is running or not. For example, the accelerometer and/or gyroscope and/or magnetometer show larger movements and/or movement at different frequencies, when the engine is running as opposed to not running.
In another implementation, the device's microphone(s) is used to determine whether the engine is running or not. For example, the microphones will show signals at different frequencies, including harmonics of the base frequency which can be more easily detected by the microphones used on popular devices, when the engine is running than if the engine is not running.
In yet another implementation, the event of starting or stopping the ignition can be captured by the accelerometer, gyroscope and/or microphone. For example, the magnitude of the acceleration at the time the ignition is started or stopped is considerably larger than the previous and subsequent accelerations in a stationary vehicle.
In yet another implementation that may be particularly useful for electric vehicles, the event of starting or stopping the ignition may be captured by the magnetometer because the magnetic field created by an electric car will change when the car is turned on or off.
It can be appreciated that in certain situations it may be useful (a) to restrict driver devices in vehicles that are temporarily stopped, for example at a stop light (i.e., not moving, but that have been moving recently and whose engines are still on and/or whose ignition hasn't been turned off); but (b) to not restrict device's in vehicles that were just turned on, for example, still in their parking spot (i.e., not moving, and were not moving recently, but whose engines has been started recently).
Additionally, it can be useful to measure the accelerometer reading and/or magnetometer readings across the 3 -axes using an orientation-invariant, for example, using the RMS of the accelerations on each of the 3 axes or other techniques known to those of ordinary skill in the art of signal processing and time- series analysis.
Additionally, it should be appreciated that various time parameters can be associated with many of the above methods so as to effectively differentiate between events or states that are recent and ones that are not.
Turning now to FIG. 12, a flow diagram is described showing a routine 1200 that illustrates a broad aspect of a method for restricting operation of a mobile device 105 in accordance with at least one embodiment disclosed herein. As will be described in greater detail below, various of the steps and operations that make up routine 1200 share substantial similarities to those described in detail herein.
At step 1201, processor 1 10 executing one or more of software modules 130, including, preferably, restriction module 171 determines whether a first mobile device 105 is present within a vehicle, and/or receives one or more first inputs from at least one of a vehicle data system 164 and/or at least one of a second mobile device 160, the one or more first inputs pertaining to a presence of the first mobile device 105 within a vehicle, such as through one or more of the various determination methods described in detail herein.
Then, at step 1207, mobile device 105 preferably prompts one or more users to initiate and/or provide one or more stimuli that can be received as inputs at mobile device 105 and/or receives one or more second inputs in response to the prompting, and/or receives one or more third inputs from vehicle data system 164, and/or receives one or more fourth inputs from at least one of the second mobile device 160, all in the manner described in detail herein.
At step 1220, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, analyzes at least one of the first inputs, the second inputs, the third inputs, and the fourth inputs to determine a presence of at least one of more than one user, more than one mobile device 105, 160, and/or one or more users not in the set of users known to be users of the first mobile device, substantially in the manner described in detail herein.
At step 1242, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171 employs one or more restrictions at a mobile device 105, substantially in the manner described in detail herein.
Turning now to FIG. 13, a flow diagram is described showing a routine 1300 that illustrates a broad aspect of a method for restricting operation of a mobile device 105 in accordance with at least one embodiment disclosed herein. As will be described in greater detail below, various of the steps and operations that make up routine 1300 share substantial similarities to those described in detail herein.
At step 1305, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, employs one or more restrictions at mobile device 105, substantially in the manner described above with respect to step 705.
In certain implementations, such a restriction can be employed whereby the device can prompt/require the user is to authenticate that s/he is a passenger in a vehicle (such as a moving vehicle) by performing an action or a set of actions such as a CAPTCHA, a game, a puzzle, lock screen etc., as described in detail herein. It can be appreciated that such authentication can be configured to require sufficient concentration/attention such that the authentication can be difficult to perform by a driver of a moving vehicle, who must concentrate on driving. This authentication can be further strengthened by requiring that (a) in order to complete the action the user must use both hands (for example, by requiring multitouch input, as described in detail herein and illustrated with respect to FIG. 15A), and/or (b) configuring the restriction to require the user to tilt his/her head and/or eyes down or up or right or left (for example, by requiring that the device be held flat, placed in the user's lap or on the seat between the user's legs, in the manners described herein) thereby preventing the user from being able to see the road
ahead while performing the authentication, and/or by requiring that the user look directly in to the device, as described in detail herein.
At step 1310, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171 receives one or more inputs, preferably from at least one of the mobile device 105, a vehicle data system 164, and/or one or more other mobile devices 160, substantially in the manner described above with respect to step 710, By way of further illustration, in certain implementations, such inputs correspond to one or more inputs provided by the user to the device in response to an authentication prompt (it should be understood that the term "authentication prompt" as used herein is intended to encompass one or more prompts, instructions, and/or directions that inform a user in some manner as to the manner in which inputs should be provided to a device, and/or that otherwise provide information to the user relating to the authentication of such a device).
At step 1320, processor 1 10 executing one or more of software modules 130, including, preferably, restriction module 171, analyzes at least one of the inputs. It should be understood that in certain implementations, such analysis can be performed in order to determine a presence of one or more users that are not known users of the first mobile device 105, substantially in the manner described in detail herein. In other implementations, such analysis can be performed in order to determine whether and/or to what degree one or more inputs (such as those received at step 1310) successfully and/or unsuccessfully authenticated a mobile device 105, as is also described in detail herein.
At step 1342, processor 1 10 executing one or more of software modules 130, including, preferably, restriction module 171, modifies an employment of one or more restrictions at a mobile device 105, substantially in the manner described in detail herein.
Turning now to FIG. 14, a flow diagram is described showing a routine 1400 that illustrates a broad aspect of a method for orienting a coordinate system of a mobile device 105 in accordance with at least one embodiment disclosed herein. As will be described in greater detail below, various of the steps and operations that make up routine 1400 can share substantial similarities to those described in detail herein. It should be understood that the various steps of routine 1400 will be appreciated with reference to EXAMPLE 3 below and FIGs. 9-1 IB, and their accompanying descriptions.
At step 1410, processor 110 executing one or more of software modules 130, including, preferably, determination module 170 receives one or more inputs, preferably from at least one of (i) at least one of the user interface, the operating system, the accelerometer, the gyroscope, the GPS receiver, the microphone, the magnetometer, the camera, the light sensor, the temperature sensor, the altitude sensor, the pressure sensor, the proximity sensor, the NFC device, the compass, and the communications interface of the mobile device 105 and (ii) a vehicle data system 164, substantially in the manner described in detail herein.
At step 1430, processor 110 executing one or more of software modules 130, including, preferably, determination module 170 computes, based on the one or more inputs, an orientation of the mobile device 105 relative to a coordinate system of a vehicle, such as a vehicle within which mobile device 105 is traveling.
At step 1440 based on the orientation, processor 110 executing one or more of software modules
130, including, preferably, determination module 170 interprets one or more subsequent inputs of the mobile device 105 in relation to the coordinate system of the vehicle and/or transforms the one or more subsequent inputs originating at the first device into values that are comparable with the coordinate system of the vehicle. See, for example, FIGs. 11A-B and EXAMPLE 3, below.
It should be understood that mobile device 105 is preferably communicatively coordinated with the vehicle data system, that vehicle data system is preferably configured (e.g., installed) with the vehicle
(e.g., within the vehicle such as a car) and/or that mobile device is positioned within the vehicle, as described in detail herein.
By way of illustration, consider that based on the x, y and z accelerometers, the exact orientation of the device 105 can be determined relative to the ground (e.g, based on the gravitational force shown on the three accelerometers 145A, as is known to those of skill in the art based on such disciplines as trigonometry). When the device is within a moving car with additional forces, the inputs can be averaged over time and/or inputs from the gyroscope 145B can further assist this computation.
The orientation of the mobile device 105 can be detected relative to the car, for example, by using the angle between the device's magnetic north (e.g, from the 3-axis compass sensor) and the vehicle's GPS heading (as can be shown on the mobile device).
Accordingly, it can be appreciated that in the case of a moving car there are also additional forces (other than gravity). These forces can be accounted for, for example, through averaging over time and/or by using the mobile device's gyroscope 145B, as described herein and using methods known to those of ordinary skill in the art.
In the case that there are movements at the mobile device 105 that are unrelated to the car (say the user moved the device), these can be accounted for through time averaging and/or using the gyroscope 145B and or filtering out these higher frequency events, as described herein and using methods known to those of ordinary skill in the art.
By way of further illustration, consider that in a mobile device on a flat table, the Z-accelerometer shows gravity and the X-accelerometer and Y-accelerometer show 0.
If the mobile device is rolled or pitched (so that one side or one corner of the device remains in contact with the table), the value read by the z-accelerometer goes down (some of the gravity that it felt in stage one is handed over to the other accelerometers)and the X-accelerometer (for roll) and Y- accelerometer (for pitch) go up. The total sum of squares of the 3 -accelerometers is always gravity. So we know the exact orientation of the device with regard to the ground.
To orient/align the device 105 with the coordinates of a car, the device's 105 north (detected, e.g., via its compass sensor) can be compared with the vehicle's GPS (such as from vehicle data system 164) heading (as read on the device). For example, (if the device screen is facing up, i.e., the device is not upside down) and its compass sensor shows that magnetic north is due north and the GPS heading sensor shows the vehicle is travelling due west, then the device is rotated 90 degrees to the right with regard to
the car. Accordingly, the exact orientation of the device with respect to the coordinates of the car, as disclosed herein and described in greater detail at EXAMPLE 3 and with regard to FIGs. 9-1 IB.
By way of further illustration, in the case of a 2.5g lateral acceleration detected at the mobile device 105, that could be because the mobile device 105 was in a very tight turn (right or left) or because there was very strong forward acceleration or deceleration - or some combination thereof. We cannot know what the car did (if anything) to cause this 2.5g acceleration until we understand the orientation of the device 105 within the car and can transform the 2.5g lateral acceleration felt on the phone into the acceleration in the vehicle's coordinate system, which is achieved through implementation of routine 1400.
It should be noted that, for the purpose of the simplicity of the description and without any loss of generality, in one or more of the examples below, it will be assumed that the various mobile device(s) 105, 160 is (are) aligned with the vehicle within which they are traveling, such as as shown in FIG. 11 A. That is, the coordinate system of a particular mobile device 105, 160 should be understood to be coincident with the vehicle's coordinate system, as depicted in FIG. 11A and described in greater detail in EXAMPLE 3. It should be further recognized that in practice, such as in various arrangements, such as that shown in FIG. 11B, mobile device 105, 160 is rotated with respect to the coordinate system of the vehicle in up to three dimensions. In order to correctly analyze the various inputs originating at sensors 145 of mobile device 145 within the context of the coordinate system of the vehicle, the rotation of the particular mobile device 105, 160 relative to the vehicle is preferably computed and the inputs originating at sensors 145 of the particular mobile device 105, 160 are preferably transformed into values for the coordinate system of the vehicle. This may be achieved in various ways, examples of which are provided below.
It should also be noted the several of the examples provided herein are presented from an event- centric perspective for the purpose of clarity. That is, various of the inputs originating at sensors 145 of mobile device 105, 160 have been described as corresponding to various real- world events such as turns, bumps, and/or stops. Accordingly, it should be appreciated that such event-centric descriptions are provided herein for the purposes of illustration and clarity, and are not intended in any way to be understood as limiting the scope of the present disclosure. Additionally, is should be appreciated that the various determinations described herein can also be performed from a sensor-centric perspective, wherein the various inputs originating at sensors 145 are considered, irrespective of a particular real-world event to which they correspond. It should be understood that the various approaches described herein can be employed in both even-centric and sensor-centric perspectives.
It should be understood that the following examples encompass further arrangements and embodiments of the systems and methods disclosed herein.
EXAMPLE 1
There are a number of inputs that can be utilized in various arrangements in order to identify one or more user determination characteristics, such as the location of a mobile device 105 and/or if a mobile device 105 is being operated by the driver or by the passenger of a car/truck/bus, such as:
As also noted above, various arrangements preferably incorporate identification of one or more of the user determination characteristics referenced above and herein. In certain arrangements, each user determination characteristic (e.g. error proportion, correlation of typing speed to acceleration etc.) can be considered as a point in a K-dimensional space. Classification algorithms based on supervised learning, as are well known to those of ordinary skill in the art, can then be applied to the resulting K-dimensional signature(s) to determine the probability that the in-vehicle role of the user of mobile device 105 is a driver or a passenger.
Text Reading/Screen Viewing - User determination characteristic(s) can be identified based on patterns in the reading of text messages (or any other such text item such as an email or webpage, or any other such viewing of items on a display screen, such as during the playing of a video game) on a mobile device 105, thereby serving to distinguish between a driver and a passenger. For example, drivers tend to change the orientation of and/or move (e.g. rotate in his/her palm) mobile device 105 more frequently when attempting to read a message of a given length (in order to periodically glance back at the road), whereas a passenger will read such a message in a comparatively more constant state. This is especially true during road maneuvers that require more driver concentration, such as turns and accelerations. This phenomenon can be observed as a high degree of correlation between vehicle accelerations and/or gyroscopic rotations as detected by accelerometer 145 A and gyroscope 145B, respectively, of mobile device 105 and the changes in orientation of the mobile device 160 (unrelated to movements in the vehicle) as measured by one or more of accelerometer 145 A, gyroscope 145B, GPS 145C and magnetometer 145E and, in particular, the presence or absence of a (non- vehicle related) mobile device movements just prior to vehicle movements. Preferably, once this correlation reaches or exceeds a certain threshold, the in-vehicle role of the user of mobile device 105 can be determined to be a driver and/or once this correlation reaches or exceeds another certain threshold, the in-vehicle role of the user of mobile device 105 can be determined to be a passenger.
Driver-Specific Movements - Various movements and/or forces can be detected by one or more of sensors 145 of mobile device 105 that can be determined to be unique to a driver. In the alternative, a lack of perception of such unique forces, such as "signature" forces at a mobile device 105 can indicate that the user of such a device is not a driver and is thus a passenger. When in contact with a device 105 (such as when holding it), a driver influences the movement of a mobile device 105 through driver-related actions that include pressing and releasing the gas/brake/clutch pedals and by moving his/her foot from one pedal to another over the course of driving. For example, prior to a period of strong and prolonged acceleration perceived by accelerometer 145 A of mobile device 105 (which is typically due to acceleration, braking, and/or wheel rotation), there is a smaller, different acceleration and/or angular movement perceived slightly (in the 100's of milliseconds) in advance, such as at one or more of sensors 145, that originates at the driver's body maneuver (such as the pressing of a gas pedal) that initiates the acceleration of the vehicle. A driver also causes a mobile device 105 to move by rotating the steering wheel. Thus, in a case where a mobile device 105 is in contact with a driver turning a steering wheel, various of sensors 145, such as accelerometers 145A and/or gyroscope 145B of mobile device 105
can detect certain accelerations and rotations. Based on a retrospective analysis of such inputs - for instance, analyzing inputs corresponding to acceleration of a car with inputs perceived immediately prior
- it can be determined whether the user operating such a mobile device 105 is a driver or a passenger. If such unique/signature forces are perceived in close proximity (generally, immediately before) acceleration, etc., it can be determined that the user is a driver. Conversely, if such inputs are not detected immediately prior to acceleration, it can be determined that the user is a passenger (provided that the user is in physical contact or communication with mobile device 105).
By way of further illustration, prior to a period of strong and prolonged lateral acceleration and/or gyroscopic yaw perceived by accelerometer 145 A and gyroscope 145B of mobile device 105 due to turning, there is a smaller, different acceleration and/or angular movement perceived slightly (in the 100's of milliseconds) in advance that originates at the driver's body maneuver that initiates the turning of the steering wheel and that is unlikely to be that of a passenger.
This approach can be also applied to other driver movements (e.g., looking in the mirrors, turning on the directional signal), wherein the driver's movements will be detected on mobile device 105 that is in contact with the driver slightly before another signal is detected (e.g., accelerometer 145A or gyroscope 145B for looking in mirrors, microphone 145D for turning on directional), on mobile device
105, whereas these serial relationships will not be present if mobile device 105 is being operated by a passenger. In another approach, the mobile device of a driver will, on average, display larger movements than that of a passenger measurable by sensors 145 of mobile device 105 due to the fact that the driver is likely to be holding the mobile device 105 in only one hand, whereas a passenger is more likely to be using both hands to hold a mobile device 105, or is capable of increased focus even when using only one hand to operate mobile device 105. This can preferably be done by taking the Fourier transform of a 3D acceleration function and integrating it (squared, i.e. L2-norms) over N disjoint frequency intervals, as is well known to those of ordinary skill in the art. The resulting 3N numbers are preferably a "signature". The signature corresponding to a driver can be distinguished from that of a passenger using a classification algorithm, such as SVM, which has preferably been trained on sufficiently large pre- classified signature bank, as is also known to those of ordinary skill in the art.
GPS - GPS 145C of mobile device 105 can be used, preferably, in certain arrangements, in conjunction with other sensors, to identify the in-vehicle position of mobile device 105, Γη certain arrangements this is achieved in part based on knowledge of the lane boundaries of the road on which the vehicle is driving (based on map data or computation/observation), together with a determination of mobile device's 105 location, using GPS 145C, to be on the right or left side of such lane. If mobile device 105 is in the left part of its current lane, then it can be determined to be on the left side of the vehicle within which it is traveling, while if it is in the right part of its current lane, then it is on the right side of the vehicle. Such in-lane location calculations can further be averaged over time to increase the
accuracy of the location of the mobile device 105 within its then current lane and, as a result, the accuracy of the determination of the location of mobile device 105 inside the vehicle.
It should be understood that the term "turn" as used herein can refer to a turn or any angle and/or curvature and/or any change in lateral acceleration and/or gyroscopic yaw, no matter how large or small and the comparisons described above can be applied discretely or continuously. It should also be appreciated that such inputs can be perceived at practically any time and/or interval, even those that do not necessarily correspond to "turns" as conventionally understood, and such inputs should be understood to be within the meaning of the term "turns" as used herein.
It should be understood that the term "bump" as used herein can refer to a change of any size in the upward acceleration, irrespective of positive or negative change and irrespective of how large or small and the comparisons and filtering described above can be applied discretely or continuously at regular or irregular sampling rates.
Magnetic Field - A vehicle's metallic and electrical parts influence the magnetic field in the vicinity of and inside such vehicle. A 3-axis magnetometer 145E of mobile device 105 can be used to detect these influences by measuring such magnetic field(s) at various times before and during a vehicle's operation (e.g., a car that has not yet been started will have a different magnetic signature than one in which the electric systems are operating) and by comparing them with known magnetic signatures of different in- vehicle locations in order to determine the in- vehicle location of mobile device 105. Such signatures can be universal and/or can depend on additional parameters such as vehicle model, vehicle location, etc.
For example, the major metallic component in most vehicles is the motor and in most vehicles (e.g., cars, buses), and it is normally situated in the front part of the vehicle, near the center. The magnetic field sensed by magnetometer 145E of mobile device 105 can be compared with the magnetic field that is otherwise present absent the magnetic disturbances— thereby indicating the direction of the motor. The lateral component of that direction is preferably the opposite of the left-right in-car location of mobile device 105.
User Baseline vs. Population Baseline - As described in detail above, such as with respect to step 224, in the identification of many of the user determination characteristics described above, the values and signatures measured on and/or computed with and/or in relation to mobile device 105 are compared to baseline values (which are preferably stored in one or more databases 174, 162) in order to determine if mobile device 105 is that of a driver or a passenger, h certain arrangements, such baseline values can be independent of the user (e.g., the standard deviation of the time between keystrokes for all people in the country using a particular model phone), while in other arrangements such values can be user dependent (e.g., this mobile device 105 (or this user of this mobile device 105, if such is available) usually texts at 100 characters per minute, currently he is texting at the rate of 10 characters per minute - thus the person holding it is likely driving).
EXAMPLE 2
As noted above, such as at steps 222 and 223, considering multiple inputs can increase the accuracy of one or more of the determinations described herein, such as the determination of an in-vehicle role of a user of a mobile device 105, 160. This advantage is further illustrated above at steps 225 and 226, wherein inputs from multiple devices are considered in order to compute such determinations. Further illustrations of such inputs/determinations include, but are not limited to:
In-Vehicle Location - In the United States and in most other countries in the world, drivers are the left-front most occupant in a vehicle, relative to the front end of the vehicle. By identifying whether a particular mobile device 105, 160 is or is not the left-front most device within a vehicle, a determination can be made that such device 105, 160 is or is not being operated by the driver.
It should be understood that the referenced in-vehicle identification/determination is preferably achieved in conjunction with communication between mobile device 105 and one or more of mobile devices 160, whether through direct communication or through network 166. It should also be appreciated that in certain arrangements such identification(s)/determination(s) can be performed in a server-side configuration, while in other arrangements such identification(s)/determination(s) can be performed in a client-side configuration. In one such server-side configuration, one or more software modules 130 are preferably executing at the various mobile devices 105, 160. One or more of the modules configure the each of the respective devices 105, 160 to transmit its absolute location coordinates (such as those provided by GPS 145C and/or an inertial navigation system (INS) and/or its relative location (e.g., 3 meters from WiFi device #1234) to central machine 168. Central machine 168 can then process the various locations coordinates and/or relative locations received from the various devices 105, 160 in order to determine which of the various devices 105, 160 are sufficiently close to one another, over a period of time (e.g., 1 minute, 1 hour, etc.), based on which it can be determined that such devices 105, 160 are present within the same vehicle. In a client-side configuration, the mobile devices 105, 160 communicate between one another (such as through communication interface 150), exchanging absolute location and/or relative location and determining which other devices 105, 160 are in within the same vehicle, substantially in the manner described above with regard to the server-side configuration. By way of further example, in certain arrangements one of devices 105, 160 can emit a tone and/or signal (such as an audio tone), and only those devices 105, 160 that perceive the emitted tone are determined to be within close proximity of the device that emitted the tone.
In both server-side and client-side configurations, upon determining which mobile devices 105, 160 are within a particular vehicle, sensor data (that is, data originating at one or more of sensors 145, such as location coordinates from GPS 145C, or lateral accelerations during a turn) from the various devices 105, 160 can be compared with one another to determine a relative in-vehicle location of one or more of the devices 105, 160. Such relative location can be subsequently filtered to generate a real-time driver-passenger determination, providing increasing accuracy in driver/passenger identification.
Driver-Anticipatory Movements - The driver of a vehicle is generally better able to anticipate the movements of the vehicle he/she is driving as compared to the passengers because the driver is the
initiator of many of the movements that the vehicle undergoes, and can thus anticipate the forces that are created as a result of the vehicle's movement. Such predictive actions can be detected by one or more of sensors 145 of mobile devices 105, 160 (e.g., accelerometer 145A and/or gyroscope 145B), and can be further processed to identify whether a particular mobile device 105, 160 is being used by a driver or a passenger. A driver instinctively tenses and/or flexes certain of his/her muscles to adjust for the vehicle movements that are about to occur on average, more adroitly (less sudden with less corrective body movement) and more quickly than a passenger does. By way of illustration, a driver anticipates and compensates for the forces experienced during a turn quicker and more accurately than a passenger in the vehicle does. Similarly, a driver anticipates and compensates for the forces experienced during sharp deceleration (braking) more quickly and more accurately than a passenger. A driver also anticipates and compensates for the forces of a lane change more quickly and more accurately than a passenger. By way of further illustration, the driver can be thought of as a dampening system which performs better than a corresponding "passenger" system, due to the driver's higher degree of consciousness, awareness, and/or anticipation. In one arrangement, one or more of the listed effects/phenomena can be detected/identified by processing one or more inputs from one or more sensors 145, such as by measuring the change in acceleration (i.e. the L2 norm of the derivative of the acceleration) over the relevant time window. In this case the acceleration is preferably further band-pass filtered to focus only on frequencies relevant to this determination, and to further exclude other driver-acceleration effects (e.g., hand-shaking, etc.) as discussed herein.
Magnetic Field: A vehicle's metallic and electrical parts influence the magnetic field in the vicinity of and inside such vehicle. Inputs originating at a 3-axis magnetometer 145E of a mobile device 105, 160 can be used to detect and determine these influences by processing such inputs to determine a magnetic field at various times before and during such vehicle's operation (e.g., a car that has not yet been started will have a different magnetic signature than one in which the electric systems are operating) and by comparing them with known magnetic signatures of different in-vehicle locations in order to determine the in-vehicle location of such device 105, 160. The presence of two or more devices within a single vehicle can influence each other's magnetic readings in a way that can be determined based on their comparison. It should be understood that in certain arrangements, such signatures are universal while in other arrangements they depend on additional parameters such as vehicle model, vehicle location, etc. In addition, comparing the magnetometer 145E inputs from more than one mobile device 105, 160 located within the same vehicle can enable a more accurate determination of the in-vehicle location of one or more of such devices.
EXAMPLE 3
As noted above, the processing of the various inputs discussed herein is preferably enhanced by incorporating various additional processing operations which serve to further enhance the accuracy of the determinations that are made. Examples of such further processing operations include, but are not limited to:
Clock synchronization - As noted above, in arrangements where inputs originating from multiple devices 105, 160 are processed together (such as several of those referenced above in EXAMPLE 2), it is preferable that simultaneous timing measurements originating at the respective devices 105, 160 are compared as well. Γη one arrangement, this can be effectively achieved by synchronizing the internal clocks of the respective devices 105, 160. By way of illustration, a relative displacement can be estimated, and this estimate can be used to process all relevant inputs such that they are synchronized to the same clock.
Examples of such synchronization methods include: (A) processing time inputs from GPS 145C to compute a mean time displacement between GPS clock and each the clock of each device 105, 160. The difference between those displacements can be determined to be the displacement between the devices. (B) Configuring one of the devices 105, 160 to emit a sound and receiving the sound at a second device (such as at microphone 145D), and further noting the time the respective events occurred at each device (that is, the time of the emitting of the sound and the time of the receipt of the sound) and then repeating same process in reverse. The noted times can then be subtracted from one another, reflecting the time that it takes to the sound to travel, and such values will cancel themselves out, leaving twice the relevant time displacement remaining.
Orientation Detection - In discussing the processing of various inputs, such as those of accelerometer 145A and other sensors 145, it is preferably that various inputs be identified and/or separated into elements such as "forward acceleration", "lateral acceleration" and such. These terms are relative to the car's coordinate system (e.g. "forward" is the direction of car's movement) while the raw inputs from the various sensors 145 are relative to the coordinate system of a mobile device 105, 160 (it should be understood that while the present example is described with respect to a car, substantially similar approaches can be applied to other vehicles as well). In order to transition (rotate) such inputs, the relative orientation of the mobile device 105, 160 within the coordinate system of the car is preferably established. The following figures depict the various relative coordinates of mobile device 105, 160, of a car, and of a mobile device 105, 160 within a car:
FIG. 9A depicts the relative coordinate system of mobile device 105, as is known to those of ordinary skill in the art and referenced herein.
FIG. 9B depicts the relative accelerations and gyroscopic rotations of a mobile device, as is known to those of ordinary skill in the art and referenced herein. It should be understood that although mobile device 105 is not shown in FIG. 9B for the sake of clarity, the various relative acceleration and rotations shown in this figure are relative to a mobile device in the same position as that shown in FIG. 9A.
FIG. 9C depicts the gyroscopic sign convention used herein, as is known to those of ordinary skill in the art and reference herein.
FIG. 10 depicts the coordinate system used in relation to a vehicle (such as at vehicle data system 164) as is known to those of ordinary skill in the art and reference herein.
P T/US2012/030017
FIGs. 11A-B depict mobile device 105 and its respective coordinate system in relation to a car and its respective coordinate system. For example, as will be described in greater detail below, in certain arrangements the respective coordinate systems can be transitioned, such that it is recognized, for example, that the +Z coordinate of the car corresponds to the +Y coordinate of the mobile device 105, and the +Y coordinate of the can corresponds to the -Z coordinate of the mobile device 105, as can be appreciated with reference to FIG. 1 IB.
Establishing the orientation of a mobile device 105, 160 within the coordinate system of a car can be accomplished in a number of ways, By way of illustration, in a 'static' approach, wherein it is assumed that the relative orientation of device 105, 160 is constant (e.g., if the device is attached to a cradle or is in the pocket of unmoving passenger), the mean acceleration vector can be determined and be identified as the "down" axis. The "forward" axis can be determined by comparing/processing inputs from GPS 145C that correspond to direction angles with inputs from magnetometer 145E that reflect 'north.' The third axis can be computed based on the first two determined axes using vector multiplication as is known to those of ordinary skill in the art. By way of further example, inputs from the accelerometer 145A, the magnetometer 145E and the GPS 145C (e.g., heading data) can be averaged, substantially in the manner described above.
In a dynamic arrangement, inputs originating at accelerometer 145A, gyroscope 145B and/or other sensors 145 can be processed to identify real-time changes in the orientation of a device 105, 160. In addition, acceleration/magnetic/GPS figures can be generated, preferably using "sensor fusion" algorithms, as is known to those of ordinary skill in the art. In doing so, the above-referenced "static" approach can be utilized to dynamically determine the relative orientation of the device 105, 160.
It should be noted that the gyroscopic sign convention adopted herein is preferably such that if an observer positioned on the positive part of the axis of rotation sees the rotation as counterclockwise, it is deemed to be positive.
Low-Pass filtering - The values derived and/or computed from the various inputs originating at the various sensors 145 of mobile device 105, 160 can be frequently compromised by the vibration(s) present in car's environment (originating at the car's engine, road bumps, imperfect wheels, wind blowing through the windows, or even car audio sounds). Such vibrations can inject "noise" into the inputs originating at the various sensors 145, and can adversely affect the precision of the processing of the various algorithms disclosed here, both in terms of efficiency and final accuracy.
There are various ways that this problem can be addressed. In one arrangement, one or more of devices 105, 160 within the vehicle are attached to a dampening device. In certain arrangements such a dampening device can include one or more weight(s) that can be attached to the mobile device 105, 160 to effectively increase its mass and thus make it more vibration resistant. Additionally, dampening materials (e.g. sorbothane pads) can be attached to a device 105, 160 to prevent high frequency vibrations from passing to the mobile device 105, 160. In any event, the inputs can be preferably processed with a bounded pass filter. On such example is an FIR with 128 taps with Hamming windows.
Sensor Fusion - As has already been noted and illustrated above, various determinations can be made by processing inputs from several sensors 145 together (e.g. forward velocity inputs originating at both the accelerometer 145A and GPS 145C).
EXAMPLE 4
The following scenarios illustrate additional examples of the analyzing of a first and second input and identifying the presence of a first user and a second user (such as at step 720, above):
Using one or more biometric authentication methods (as are known to those of ordinary skill in the art) to identify the presence of a first user and a second user. Such biometric authentication methods include, but are not limited to, voice recognition, fingerprint recognition, face recognition, DNA identification, and retina identification.
The following are further examples of restrictions that can be employed at a mobile device 105, such as in the manner described in detail above with reference to FIG. 7. Various of these examples impede operation of mobile device 105 by a driver moreso than they impede operation of the device by a passenger:
(a) If talking, the device is restricted to being held on the left side (right side for U.K.) of the head/face of the user and with an upright orientation, so that driver usage cannot be hidden from external observers.
(b) If texting, mailing, browsing etc., mobile device 105 is restricted to operating when having straight orientation (no yaw) (adjustment can be necessary, in certain arrangements, for a vertical/horizontal keyboard) and at least close to upright orientation (cannot be on knee or low down so that driver cannot "hide" the device use from external observers).
(c) The device interface will only function horizontally (more difficult for driver to use).
(d) The device 105 is restricted to operating in one or more ways only when camera 145F perceives a frequently moving background (e.g., be held high, not hidden low in the driver's lap or blocked by the steering wheel).
(e) The device 105 is restricted to operating in one or more ways that can be determined to correspond to operation by a passenger (and/or correspond to operation by a passenger of a particular device), such as the various determinations described in detail herein. By way of example, if no correlation (or, alternatively, no negative correlation) is identified between various typing tendencies and the speed, acceleration, and/or maneuvering of a traveling vehicle, and/or a certain typing accuracy threshold it met and/or maintained over a period of time, it can be concluded that the user is likely a passenger.
(f) The device 105 is restricted to operating only when it can be determined based on one or more inputs that the device is under the control of a passenger and/or under the control of a passenger using this particular device, such as the various determinations described in detail herein. By way of example, if relatively little "shake" is perceived at mobile device 105 over a period of time, it can be determined that the device is under the control of a passenger, as a passenger has the ability to control "shake" by using both hands to steady the device - an
option not always available to drivers who generally need their second hand to steer the vehicle.
It should also be understood that the various restrictions referenced herein can also be dependent upon the presence and/or absence of certain of the determinations disclosed herein. Thus, for example, various restrictions can be employed only when a device cannot be definitively determined to be in the rear or on the right side of a vehicle (thus suggesting that a driver can potentially be operating the device). EXAMPLE 5
Bi determining vehicle class or type, in certain arrangements a determination is made as to whether one or more mobile devices 105, 160 is/are present and/or in use in a vehicle. If such a determination is affirmatively made, a further determination can then be made regarding the general type or class of the vehicle (e.g., motorcycle, car, bus, train, boat, plane, etc.). This determination can then be used to further determine if there are restrictions on the mobile device usage on the part of a driver or the passenger in the vehicle. For example, if it is determined through a signature analysis (that is, an analysis of various patterns in various inputs) of an accelerometer 145A and/or gyroscope 145B and/or GPS 145C of mobile devices 105 and/or 160 that there is a high-likelihood that a particular mobile device 105, 160 is located on a train, then that the mobile device 105, 160 can remain fully operational without any operation state restrictions (assuming that no restrictions apply to anyone on the train including the conductor). If however, it is determined that a mobile device 105, 160 is being used within a car, restrictions can be applied (e.g., no phone use at all or just no texting), particularly if it is determined that the user of the mobile device 105, 160 is the driver of the car, and not a passenger.
As described in detail above, the type or class of vehicle in which a mobile device 105, 160 is located can preferably be identified and/or determined by using one or more of sensors 145 of mobile device 105. In certain arrangements, this identification/determination can be improved by using the onboard sensors of other mobile devices 160 and/or the onboard sensors (e.g., vehicle data system 164) of the vehicle in which mobile device 105 is traveling. As noted above, being that different vehicles operate in perceptibly different ways (which, in turn, reflect different patterns that are perceptible to one or more of sensors 145), the signature of one or more of sensors 145 of mobile device 105 (and/or other mobile devices 160) present and/or used in relation to each of the following vehicles is identifiable within a certain degree of accuracy:
It should be understood that in certain implementations, a device can be authenticated (e.g., determined to be likely to be operated by a user who is a passenger) if it can be determined that the user of the device is able to perform one or more actions (such as providing certain inputs) and/or demonstrate/provide evidence of certain situations (such as providing photographic/videographic documentation of such situations) that a user who is simultaneously driving a vehicle would not be reasonably capable of doing. As described in detail herein, examples of such methods of authentication include: if, while having determined that the vehicle (within which the mobile device is present) is in motion, the user of the device can be determined to be capable of (a) performing an action in a different
part of the vehicle (such as in an area of the vehicle where the driver could not reasonably sit and/or reach); (b) holding his/her look/gaze (i.e., maintain focus of his/her eyes) in a direction (such as towards the mobile device) that is not towards the road ahead, for a defined/sufficiently long long period of time;
(c) using/interacting with the device with two hands for a sufficiently long period of time/performing one or more tactile gestures that require substantially simultaneous use of both hands of the user (it should be noted that the terms "tactile gesture" and "tactile gestures" as used herein are intended to encompass inputs and/or interactions that are provided by a user in a tactile manner, such as through physical interaction with one or more media, elements, and/or components with one or more fingers or hands of a user, examples of which including pressing buttons, and performing gestures such as taps, swipes, and/or other such interactions with a touchscreen or touchpad) ; (d) configuring the device to record a visual capture (e.g., take a picture or video) within which one or more indicators (that is, elements or aspects that can be perceived within the visual capture) that would be difficult/impossible for a driver to capture, are present (examples of such indicators include: (i) the presence of a passenger's seatbelt, as described herein, (ii) the presence of a steering wheel with two hands on it, as described herein, (iii) the presence of the eyes/face/smile etc. of the user, as captured from below, above, and/or from the side (it can be appreciated that in scenarios where there is little or no external light other than the interior overhead lighting of the vehicle, such as at night, it can be preferable to take a picture from above and/or from the side, such that the overhead interior lighting within the vehicle does not interfere considerably with the visual capture) wherein the steering wheel of the vehicle is not present in the visual capture, and/or (iv) the presence of the feet of the user in a position that is difficult/impossible for a driver to achieve, etc.), etc..
As described herein, in certain implementations, the device user can be prompted to provide one or more inputs in order to authenticate that s/he is a passenger. Examples of such authentication methods/approaches include performing an action or a set of actions, such as providing one or more alphanumeric inputs in response to a CAPTCHA prompt (as is known to those of ordinary skill in the art), providing one or more inputs during the course of interacting with a game, providing one or more inputs in attempting to solve a puzzle, a lock screen, etc. It can be appreciated that such authentication approaches/methods can be configured to require a significant degree of concentration (and/or prolonged concentration) on the part of the user, such that such authentication approaches/methods are too difficult to be successfully performed (and/or consistently successfully performed) by a driver of a moving vehicle (who, presumably, must concentrate on the road ahead). Such authentication approaches/methods can be further improved by configuring them to require that (a) the authentication can only be successfully completed (e.g., authenticating the user of the device as the passenger) when the user uses both hands simultaneously (as described in detail herein); and/or (b) the authentication can only be successfully completed when the required inputs are provided such that the user cannot simultaneously see the road ahead while performing the authentication (such as by making the user tilt his/her head and/or eyes down or up or right or left, e.g., by requiring that the device be held flat and/or placed in the user's lap or on the
seat between the user's legs, as described herein, and/or by requiring that the user look directly in to the device in the manners described herein).
In another implementation, in order to provide the necessary inputs in order to authenticate the mobile device (e.g., to authenticate a user of the device as a passenger in a vehicle), various restrictions can configure the mobile device to require that the device be placed or held flat (such that the z- accelerometer of the device indicates the approximate value of gravity, e.g., when the device is positioned in the user's lap or on the seat between the user's legs,), and user tilts his/her head so that the camera(s) of the device can detect the eyes, gaze, face, and/or smile etc. of a person (not necessarily limited to a particular person), preferably for a certain minimum period of time (controlling, in certain implementations, for blinking and similar effects). It can be appreciated that such authentications can be achieved using a forward-facing camera (e.g., a camera on the side of the device that the screen is on in contemporary devices, such as the iPhone 4S produced by Apple of Cupertino, California, USA, and as is depicted in FIG. 15F, wherein 145Fi corresponds to a forward-facing camera and 145F2 corresponds to a rear-facing camera) and/or a rear-facing camera (e. g., a camera on the side of the device that the screen is not on in contemporary devices such as the iPhone 4s produced by Apple of Cupertino, California, USA).
It should be understood that in certain implementations, the authentication methods/approaches described herein can be configured to authenticate a user of a mobile device as a passenger upon determining the presence of the eyes/gaze/face/smile of the user, such as from within a visual capture, only when such a visual capture can be determined to have been recorded while the mobile device was positioned in a manner/orientation that precludes/prevents the user from simultaneously seeing/focusing on the road ahead. (It can be appreciated that a driver operating the mobile device would generally only be capable of positioning the device in a manner/orientation whereby, the device is able to capture his/her eyes/gaze/face/smile etc. while the user is also able to see some portion of the road ahead.) This can be determined by (i) searching, such as with image processing techniques known to those of ordinary skill in the art, for the eyes/gaze/face/smile etc. of the user within a field of view that is smaller than the camera's field of view; and/or (ii) by requiring the angle of incidence between the user's eyes/gaze/face/smile etc. and the device be as close to (or as far from) 90 degrees (indicating that the user is directly facing the device) as desired, such as in the manner depicted in FIG. 15G; and/or (iii) requiring that the ratio of horizontal pixels to vertical pixels of the user's eyes/gaze/face/smile etc. is consistent with the ratio present when a user looks directly into the device (and/or that the number of horizontal pixels and/or vertical pixels of the user's eyes/gaze/face/smile etc. is consistent with the number present when a user looks directly into the device), as is known to those of ordinary skill in the art.
Moreover, in certain implementations, the authentication methods/approaches described herein can be configured to authenticate a user of a mobile device as a passenger only if the user holds the device within a certain range of distance from her eyes/gaze/face/smile etc. In doing so, it will be difficult, if not impossible, for a driver to fraudulently authenticate him/herself as a passenger by attempting to authenticate the device by holding the device close to his/her head such that the resulting visual capture recorded by the device does not contain any part of the steering wheel (as described
herein). The distance can be determined, for example, based on the number of pixels in the eyes/gaze/face/smile etc., relative to the resolution of the camera and/or relative to the angle of incidence and/or using other distance measurement techniques known to those of ordinaiy skill in the art.
In certain implementations, the authentication methods/approaches described herein can be configured to authenticate a user of a mobile device as a passenger upon determination that the user performed (and/or is capable of performing) one or more actions/provided one or more inputs that can be determined to require(s) the use of one or two hands (e.g., swipe gestures at a touchscreen, including one or more times) such as in an implementation utilizing a forward-facing camera is used, and/or requiring a user to press a touchscreen with one or more fingers and/or touch one or more buttons on the device, irrespective of whether the camera is rear-facing or forward-facing), such as is described with reference to FIG. 15A.
It should also be noted that in certain implementations, when performing the referenced authentication, it can be useful to configure the device such that the user is required to (a) hold the device at a certain orientation, e.g., in landscape orientation, thereby making it more difficult for a driver trying to falsely authenticate/unlock the device (which would otherwise allow the driver to perform certain actions), and/or (b) to encourage the user to hold the device in such orientation by having the device's screen display in landscape mode (that is, displaying the user interface in landscape mode, as described in detail herein), regardless of whether the device is actually held in a landscape orientation. It can be appreciated that such a configuration is relatively less of a burden on a passenger, as described in detail herein.
As referenced herein, in certain implementations, the authentication methods/approaches described herein can be configured to authenticate a user of a mobile device as a passenger only if no part of a steering wheel is present in a visual capture, such as a visual capture of a portion of the user.
It should also be noted that in certain implementations, during the authentication process, the mobile device can be configured to providing audio and/or vibrational/tactile feedback to the user (such as in the case of a forward-facing or rear-facing cameras, whereby the user can be directed/instructed as to how to tilt/orient the device/camera in order to achieve the requisite angle required by the particular authentication method, as described in detail herein) and/or visual feedback (such as in the case of a rear- facing cameras and/or a forward facing camera) during the authentication process. In doing so, the user can be provided with guidance/feedback, as needed, in order to enable the user to achieve the requisite input (such as a particular visual capture) in order to authenticate the device, as described herein. FIGS. 15D and 15E depict various examples of visual feedback that can be provided to a user during authentication.
It should also be noted that in certain implementations a user of a mobile device can be authenticated as being a passenger even if the vehicle within which the device is present is not moving, e.g., by recording a visual capture within which the driver's hand and the steering wheel can be determined to be present, as described in detail herein.
Turning now to FIG. 15, a flow diagram is described showing a routine 1500 that illustrates a broad aspect of a method for selectively restricting operation of a mobile device 105 in accordance with at least one embodiment disclosed herein. It should be understood that in certain implementations, such selective restriction of a mobile device can be employed in order to restrict operation of the device by a user who is a driver of a vehicle, while not restricting operation of the device (or, restricting operation of the device relatively less) by a user who is a passenger of a vehicle. Accordingly, it should be appreciated that various of the determinations and identifications described herein are directed towards one or more factors and/or aspects that are indicative in various ways of whether the user of the particular device is a drive or a passenger of the vehicle. Additionally, it should be further understood that the referenced method is preferably implemented in situations, scenarios, and/or settings where mobile device 105 is present within a vehicle, such as a moving vehicle. Various methods for determining a presence of the device within a vehicle and/or a moving vehicle are described in detail herein.
At step 1505, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, employs one or more restrictions at mobile device 105 and/or in relation to mobile device 105, substantially in the manner described above with respect to step 705. It should be understood that in certain arrangements, such restriction(s) are preferably configured, on average, to impede operation of mobile device 105 by a user that is a driver moreso than the restriction(s) impede operation of mobile device 105 by a user that is a passenger, as described in detail herein. It should also be understood that a single restriction can be understood and/or configured to be a combination and/or composite of multiple restrictions. It should also be understood that in certain implementations the methods described herein can be applied to a device that is already restricted, such as a device that is configured, by default, to operate, in a restricted state.
At step 1510, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171 receives one or more inputs, such as one or more visual captures originating at mobile device 105 and/or mobile devices 160 (e.g., from camera 145F), such as an image, a series of images, and/or a video, substantially in the manner described above with respect to step 710.
Then, at step 1520, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, processes at least one of the visual captures (such as those received at step 1510) to identify one or more indicators within the visual capture. It should be understood that the terms "indicator" and/or "indicators" as used in context of the referenced visual capture(s) are intended to encompass one or more items, elements, and/or aspects that can be distinguished, determined, and or identified within a visual capture, as is known to those of ordinary skill in the art. That is, it can be appreciated that in processing the one or more visual capture(s),, the visual captures (e.g., images and/or videos) can be analyzed using one or more image processing techniques, as are known to those of ordinary skill in the art. In doing so, one or more indicators can be identified within the visual capture, and such indicators can preferably be further utilized to determine if/how one or more restrictions are to be adjusted at/in relation to the mobile device 105, as will be described in greater detail below.
The following are exemplary and non-limiting illustrations of various visual captures that can be received, and indicators that can be identified within the respective visual capture:
In one implementation, a visual capture can include an image of at least a portion of a face of a user, and such a visual capture can be processed to identify one or more indicators that reflect a steady gaze of the user. It can be appreciated that while a vehicle is in motion, a passenger in a vehicle is more likely to be able to maintain an ongoing steady gaze into a camera of a mobile device than a driver who will necessarily divert his/her gaze in order to see the road while driving.
In another implementation, a visual capture can include an image of at least a portion of a face of a user, and such a visual capture can be processed to identify an absence of a steering wheel in the visual capture. It can be appreciated that a visual capture that contains the presence of a steering wheel together with at least a portion of a face of a user indicates that it is likely that the user is in close proximity to the steering wheel, and is thus more likely to be a driver of the vehicle. Thus, in visual captures where the steering wheel has been determined to be absent, it can be determine that the user of the device which captured such a visual capture is likely to be a passenger.
In another implementation, a visual capture can include an image of one or more feet of a user, and such a visual capture can be processed to identify a position of the one or more feet. That is, it can be appreciated that a visual capture of the feet of a driver is likely to include one or more pedals (e.g., gas, brake, and/or clutch), and/or the positioning of the feet of the driver, either on or around such pedals.
Conversely, the absence of such pedals and/or the foot positioning that they entails, indicates that the user of the device which captured the image capture is likely to be a passenger.
Pn another implementation, a visual capture can include an image of at least a portion of a body of a user, and such a visual capture can be processed to identify a presence of a fastened seatbelt in a passenger orientation, as depicted in FIG. 15B and as will be described in greater detail below with respect to step 1720.
In another implementation, a visual capture can include an image of an interior of a vehicle, and such a visual capture can be processed to identify at least two hands and a steering wheel, as will be described in greater detail below with respect to step 1542.
By way of further illustration in another implementation, a video capture that reflects the scenery outside of a vehicle can be processed, such as using image/video analysis, to determine the orientation of the mobile device. In order to do so, indicators such as the position of the sk and/or horizon can be identified within the in the visual capture, such as using image processing methods and approaches known to those of ordinary skill in the art. It can be appreciated that various aspects of the visual capture will necessarily change based on the orientation of device 105 and/or the relative location of the device within the vehicle. It can thus be appreciated that in doing so, the orientation of mobile device 105 and/or the relative location of the device within a vehicle can be determined, as will be described in greater detail below.
At step 1522, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171 receives one or more inputs, preferably from at least one of the sensors
145 of mobile device 105, a vehicle data system 164, and/or one or more other mobile devices 160, substantially in the manner described above with respect to step 710. It should also be understood that various inputs can be received from multiple sources (e.g., various sensors, devices, etc.). For example, inputs from accelerometer 145 A and/or gyroscope 145B can be received, such inputs corresponding to an orientation of mobile device 105. By way of further example, one or more input(s) from one or more tactile sensor(s) 145N, such as the simultaneous depressing of one or more buttons, and/or the simultaneous tactile interaction of multiple points and/or locations on a touchscreen display.
At step 1524, processor 1 10 executing one or more of software modules 130, including, preferably, restriction module 171 processes the one or more inputs, such as those received at step 1522, to determine a presence of a passenger within a vehicle. By way of example, inputs can be received from vehicle data system 164, such as those originating at various sensors deployed within a vehicle, such as weight/heat sensors that are positioned within one or more seats, and/or sensors that can detect whether one or more seatbelts are/are not fastened. Such inputs can be processed in order to determine a presence of, and/or the likelihood of the presence of, one or more passengers within a vehicle.
At step 1526, processor 1 10 executing one or more of software modules 130, including, preferably, restriction module 171 processes the one or more inputs with the visual capture and/or the indicators to determine a relationship between the inputs and the visual capture and/or the indicators. That is, it can be appreciated that the processing of inputs from one or more of sensors 145 (and/or from other sources) together with the visual capture/indicators can further enhance the accuracy of determinations made and/or actions taken, such as the determination of the orientation and/or location of device 105, as referenced above. For example, inputs from accelerometer 145 A and/or gyroscope 145B can be processed together with the referenced visual capture/indicators in order to determine an orientation of the device 105 and/or a relative location of the device with increased accuracy. That is, it can be appreciated that if the visual capture/indicators reflect scenery outside the vehicle, such visual capture/indicators can be processed to determine the direction in which the mobile device 105 is traveling. For instance, if a stationary item (and/or an item moving at a speed slower than the vehicle within which the user is traveling) identified in the visual capture moves from left to right over the course of the visual capture (such as the progression from Frame 1 to Frame 3 as depicted in FIG. 19), it can be determined that such a visual capture was taken with the mobile device 105 being oriented such that the visual capture is taken from the right side of the vehicle. Accordingly, it can be reasonably concluded that the user capturing such a visual capture is not the driver of the vehicle (who would be seated on the left side of the vehicle). Similarly, a stationary item identified in the visual capture moves from right to left over the course of the visual capture (such as the progression from Frame l a to Frame 3 a as depicted in FIG. 19), it can be determined that such a visual capture was taken with the mobile device 105 being oriented such that the visual capture is taken from the left side of the vehicle, and thus it cannot be determined with certainty that the user is not the driver of the vehicle. It can be said that such determinations reflect a relationship between the inputs and the visual capture/indicators.
By way of further illustration, in one implementation, a relationship can be determined wherein preferably while the vehicle is in motion, the user presses the device against the vehicle's right-side window with the device oriented so that the Y axis of the device (as shown in FIGs. 9A-9B and described in detail herein) is pointed in the forward direction that the car is traveling in, the device is oriented so that the positive part of the X-axis (as shown in FIGs. 9A-9B) is facing up and the rear-facing camera of the device is facing out (together referred to as the "required orientation", as shown in FIG. 15C) - something that in most circumstances only a passenger can do (it can also be appreciated that the "required orientation" can be configured to account for cameras in other positions on the mobile device, such as a camera on the front face of the device - wherein it can be appreciated that the negative side of the X-axis is to be facing up). Indicators can be identified, such as by processing the one or more visual captures originating from the camera of the device to determine if the movement of pixels or blocks of pixels or features of interest in one or more successive visual captures are consistent with the device being on the right window (e.g., if pixels in successive frame are moving from left-to-right as opposed to right- to-left if the device were on the left window), as are known to those of ordinary skill in the art. The referenced visual capture and/or indicators can be processed with the one or more inputs to determine a relationship therebetween.
At this juncture, it can be appreciated that while implementations such as those where the processing of a visual capture/indicators to identify the direction in which stationary objects (and/or objects moving at a speed slower than the vehicle within which the user is traveling) move over the course of several frames (that is, left to right or right to left) can enable a determination with a certain degree of certainty as to whether the visual capture was taken from the right side of a moving vehicle (indicating that the visual capture was taken by a passenger) or the left side of a moving vehicle (indicating that the visual capture was not necessarily taken by a passenger), in certain situations further validation can be advantageous. This is because, in certain scenarios, a driver, though seated on the left side of the moving vehicle, can still take a visual capture that shows stationary objects moving from left to right. Accordingly, it can be appreciated that analyzing additional inputs and/or factors can be advantageous in order to further determine that a driver is not actually skewing the determinations referenced above.
By way of example, in certain implementations, one or more inputs (e.g., inputs originating at an accelerometer, gyroscope, magnetometer, camera, etc.) can also be processed (such as in the manner described in detail herein) in order to determine a stability of mobile device 105. It should be understood that any number of inputs and/or combinations of inputs can be processed in order to determine the stability of device 105. It can be appreciated that the degree of stability of device 105 can be indicative of whether a user of the mobile device is a driver or a passenger in that in a scenario where a driver points device 105 towards the right-hand window of the vehicle, it is likely that the mobile device 105 is supported only by the hand of the driver within the interior of the vehicle (it should also be recognized that given the fact that the driver must remain on the extreme left-hand side of the vehicle in order to operate the vehicle whose controls are situated on that side, it is exceedingly difficult, if not impossible,
for the driver to effectively operate the vehicle while also reaching across the width of the car to the right- hand window). Given this positioning, a mobile device 105 operated by a driver of a vehicle is generally subject to considerable instability, especially when the vehicle is moving. A passenger, conversely, who can be seated on the right side of the vehicle, generally has the ability to hold and/or position his/her mobile device 105 against the window, wall panel, and/or door of the vehicle. Doing so provides an additional measure of stability which is generally unattainable by a driver, as discussed above. As such, it can be appreciated that by determining the stability of mobile device 105, and additionally, by identifying a relationship between the one or more inputs and the visual capture/indicators, the systems and methods disclosed herein can better identify and/or account for operation of the device by drivers and/or passengers.
As noted in the example above, any number of inputs (both individually as wells as when processed in combination) can be analyzed in order to determine the stability of mobile device 105. By way of further illustration, the visual capture/indicators themselves can be analyzed/processed in order to identify the degree of "shake" present, in a manner known to those of ordinary skill in the art. That is, it can be appreciated that multiple indicators can be identified from a single visual capture. For example, it can be appreciated that if an amount or degree of "shake" can be detected in a visual capture (in addition to other indicators that can be identified in the same visual capture, such as those described in detail above). In determining such an amount/degree of shake, it can be further determined that mobile device 105 is likely positioned in an unstable manner (such as by being held in a manner other than by being positioned against a window of the vehicle), and thus has a significant likelihood of being operated by a driver of the vehicle. Various other inputs, such as inputs from the gyroscope 145B and/or the accelerometer 145A can also be processed/analyzed to determine the stability of the mobile device 105.
By way of further illustration, in certain implementations, in addition to identifying one or more indicators within a visual capture, as describe in detail above, determinations (such as those that can be computed based on the indicators, such as that the user of the device is a driver or passenger of the vehicle) can be further confirmed/ verified by processing the* visual capture(s)/indicator(s) with one or more other inputs in order to determine a relationship between them. For example, it can be appreciated that a determination that the mobile device is pressed against the window (as opposed to held by the user just looking out of the window), in the required orientation, can be computed based on inputs originating at the accelerometer and/or gyroscope and/or other sensors. In doing so, any number of determinations can be computed, in part in order to confirm that the device is being held in a manner consistent with being pressed against a window. For example, (i) if it can be determined that the device moves/shakes relatively less than it would if it were held in a hand that is not supported by a window and/or door; (ii) if the device vibrates consistently with being held against a window; and/or (iii) if the visual capture(s) of the mobile device do not contain pixel blocks indicative of the device not being against window (e.g., near-fixed pixels on the borders of the visual capture showing the door or the roof or the window frame of the vehicle, etc.) in the preferred/required orientation that is consistent with a user pointing the rear-facing camera of the device out the window of a vehicle (wherein the camera sees light, the camera sees moving
pixels, and/or the inward facing light sensor shows an amount of light consistent with pointing inward in the required orientation, as is known to those of ordinary skill in the art),
In certain implementations, the device being pressed against the right-side window of the vehicle in the required orientation (as described above) can be verified by processing one or more inputs, such as those originating at the accelerometer, by tracking the movement of the device immediately prior to its being pressed against a window. If, before determining/validating that the device is pressed against a window in the required orientation, and/or after accounting for changes in the orientation of the device during such period of movement, the device moved to the right relative to the direction in which the vehicle is heading, then it can be determined that the device has moved to the right-side window. This determination can preferably be computed based on inputs originating at the accelerometer, the gyroscope, the GPS and/or the magnetometer, as is known to those of ordinary skill in the art. It should be understood that such approaches can operate independently and/or in conjunction with one or more of the various implementations and approaches described in detail herein.
In other implementations, the user can be required to perform one or more simultaneous tactile interactions with the device. One or more inputs can be processed in order to determine the number of instances of simultaneous tactile interaction. As referenced above, examples of such tactile interactions include the depressing of one or more buttons, and/or the simultaneous tactile interaction of multiple points and/or locations on a touchscreen display (commonly known as "multitouch"), as is known to those of ordinary skill in the art. It can be appreciated that in certain circumstances, in order to provide two (or more) such simultaneous tactile interactions, a single user must use both of his/her hands. In other implementations, in order to provide six (or more) such simultaneous tactile interactions, a single user must use both of his/her hands (assuming that a single hand is capable of at most five simultaneous tactile interactions).
By way of further illustration, FIG. 15A depicts an exemplary lock screen, in accordance with at least one embodiment disclosed herein. It should be understood that while FIG 15A is exemplary, it illustrates various aspects of the various approaches described in detail herein. For example, area 1560 depicts various blocks where numbers are presented to the user (such as at random). The user is prompted to input each respective number (e.g., '3 ') as the number is presented. In randomizing the numbers presented, the user is effectively required to be attentive to the numbers being presented (as opposed to repeatedly inputting the same user-defined lock code). Area 1565 (depicting an image of a fingerprint) corresponds to an area within which the user must maintain constant contact throughout the authentication/unlock process with at least one finger (as described in detail herein), hi doing so, the user effectively must dedicate one hand to such constant contact, thereby necessitating that the other unlock procedures (e.g., the inputting of the numbers, as referenced above) be performed with the other hand of the user - thus effectively requiring the user of both of the hands of a user (and thereby creating a situation whereby such a procedure is difficult, if not impossible, for a driver of a vehicle to achieve, especially while driving). Moreover, a timer 1570 is employed, requiring that the user perform the required authentication within a specified time period (as described in detail herein). Moreover, an
'Emergency Call' button 1575 enables the user to initiate emergency communications even without authenticating unlocking the device, as is also described herein.
As referenced above, in certain implementations, various of the referenced approaches can be employed in combination and/or in parallel. Such arrangements entail the processing of multiple inputs, and/or determining one or more characteristics associated with the operation state of mobile device 105, including but not limited to: an orientation of mobile device 105, the relative location of mobile device 105 within the vehicle, a relative movement of mobile device 105, a stability of mobile device 105, and/or a number of simultaneous tactile interactions with mobile device 105. More particularly, it can be appreciated that the implementation of multiple approaches can further increase the accuracy of the collective determinations above that of a single determination, and ultimately ensuring that operation of mobile device 105 by a driver of the vehicle is prevented and/or restricted, while operation by a passenger is permitted. Moreover, such inputs and/or determinations can be processed with other such determinations, visual captures, and or indicators, in order to identify relationships therebetween.
For example, a visual capture can be processed to identify one or more indicators, and/or to determine the orientation of mobile device 105 and/or the relative location of the device 105 within a vehicle (using the various image analysis techniques described in detail above). The visual capture/indicators and/or other inputs can be processed to determine the stability of device 105, as described in detail above (thus further ensuring that the device is not being operated by a driver), while also determining a number of instances of simultaneous tactile interaction, as also described above. In particular, given that mobile device 105 will generally need to be supported against a vehicle's window in order to achieve both a) the proper orientation to obtain a suitable visual capture that confirms the orientation and/or location of mobile device 105, and b) the requisite stability (provided by lodging and/or supporting mobile device 105 against the window, wall panel, and/or door of the vehicle), it can be appreciated that achieving even this degree of orientation/stability requires substantial ongoing control of at least one of a user's hands, as depicted in FIG. 20. Accordingly, it can be appreciated that a user must generally use most, if not all of, the fingers from one of their two hands to orient the device in such a way for any period of time. Thus, it can be further appreciated that practically any simultaneous tactile interactions with device 105 would be exceedingly difficult for a driver of the vehicle who also needs at least one hand to steer. As such, requiring further interaction with device 105 (e.g., a multi-finger swipe motion in order to unlock or otherwise unrestrict the device), in combination with the above referenced determination(s), can further confirm that such a device is being operated only by a passenger.
In certain implementations, a device can be verified to be operated by a passenger by requiring the user to physically interact with the device (e.g., perform a multi-touch or swipe) while the user is pressing the device against a window of the vehicle in the required orientation in a manner that is likely to require the use of a second hand. It can be appreciated that a driver of a moving vehicle cannot easily (if at all) press a device against the window in the required orientation, hold it stably and interact with it. Let alone on the window on the opposite side of the vehicle (s)he is driving.
Then, at step 1542, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, adjusts an implementation of one or more restrictions at/in relation to mobile device 105. It should be understood that in various scenarios, adjusting an implementation of a restriction can entail employing one or more restrictions, modifying an implementation of one or more previously employed restrictions, and/or removing one or more previously employed restrictions. It should be further understood that the adjusting, employing of, modifying of, and/or removing of one or more restrictions at/in relation to mobile device 105 is/are preferably effected based on one or more of the visual captures, indicators, relationship(s), and presences, and/or determinations referenced above. For example, based on the identification of one or more indicators (e.g., identifying the presence/absence of a steering wheel in a visual capture, such as a visual capture of the face of the user while the device is held in a horizontal orientation), one or more restrictions can be employed (e.g., if a steering wheel is present in the visual capture, indicating that the user is likely a driver) and/or removed (e.g., if no steering wheel is present, indicating that the user is likely to be a passenger). By way of further illustration, based on a determination that device 105 is on the left (driver's) side of the vehicle, a restriction can be employed whereby the mobile device is no longer receptive to user inputs. By way of further example, based on a determination that device 105 is facing out the right-hand window of the vehicle and is relatively stable, one or more previously employed restrictions of mobile device 105 can be removed.
At this juncture, it should be understood that in various implementations, the accuracy and/or efficacy of certain of the referenced inputs that are received and/or processed can be compromised when the vehicle within which the mobile device is present is engaged in a turn (as determined, for example, based on inputs originating at accelerometer 145A, gyroscope 145B, or the magnetometerl45E and/or compass 145M, and as described in greater detail herein), This is in part due to the various forces that are present in a turning vehicle that are perceptible by various sensors such as an accelerometer (e.g., through the centripetal force shown on its z-accelerometer) and/or gyroscope, which are not present when the vehicle is traveling substantially straight. Thus, in certain implementations, the various systems and methods described herein can be configured such that various operations, such as the receipt and/or processing of various inputs is precluded (and/or the results of any processing or determination that incorporated such results is discounted, discarded, and/or ignored) when it can be determined that the referenced vehicle is engaged in a turn, such as in a manner described in detail herein.
It should be noted that in certain implementations it can be useful to loosen one or more restrictions (e.g., have them appear intermittently - either at random, at some fixed rate or dynamically according to certain events) after the device user (who has already passenger authenticated) has and/or continues to interact with the device in a manner that further suggests that the user is the passenger by, for example, (a) using the keyboard at a good speed; (b) using the keyboard with low and/or consistent inter- key time variations; (c) using the keyboard with a low level of typographical mistakes; (d) exhibiting device movement that is consistent with that of a passenger.
Moreover, in certain of the implementations described herein, as long as a vehicle occupant does not successfully authenticate as a passenger (and, optionally, even if the user does), it can be useful to
allow the user to operate and/or interact with the device via voice (e.g., voice-to-text, voice-to-command, text-to-voice). This feature can optionally be limited to devices that are in a cradle and/or are being used in a hands-free manner.
Turning now to FIG. 16, a flow diagram is described showing a routine 1600 that illustrates a broad aspect of a method for selectively restricting operation of a mobile device 105 in accordance with at least one embodiment disclosed herein.
At step 1610, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171 receives one or more visual captures, substantially in the manner described above with respect to step 1510.
Then, at step 1620, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, processes at least one of the visual captures (such as those received at step 1510) to identify one or more indicators within the visual capture, substantially in the manner described above with respect to step 1620 .
At step 1622, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171 receives one or more inputs, such as a directional heading of mobile device 105 originating at from GPS receiver 145C, substantially in the manner described above with respect to step 710.
At step 1623, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171 receives one or more inputs, such as a directional input 105 originating at from magnetometer 145E and/or compass 145M, substantially in the manner described above with respect to step 710.
At step 1623 A, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, computes one or more determinations, such as determinations reflecting orientation/position of mobile device 105. By way of example, an input from the accelerometer can be received, preferably reflecting the X-axis position, and such input can be processed to confirm that the device is being held in the required position with respect to the X-axis, such as in the manner described herein. Moreover, in certain implementations various of the methods described herein can be employed which determine the degree of stability and/or the amount of "shake" present at the mobile device, based on which it can be determined whether the device is oriented against a door/window of a vehicle, such as in the manner described above with respect to FIG. 15.
Then, at step 1624, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, processes the received inputs, including the directional heading and the directional input, and such input can be processed to confirm that the device is being held in the required orientation with respect to its Y-axis. That is, it can be appreciated that the directional heading originating at the GPS can be correlated with the directional input(s) from the magnetometer/compass in order determine the orientation of the Y-axis of mobile device 105, as is known to those of ordinary skill in the art.
At step 1626, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171 further processes the relative orientation of a mobile device, such as of a device held in the required orientation with respect to its x-axis (such as that determined at step 1623 A), with at least one of the visual capture (such as that received at step 1610) and the one or more indicators (such as those identified at step 1620) to determine the device's relative orientation. It should be understood that in certain implementations, in doing so, it can be confirmed that the device is being held in the proper Y-axis orientation, i.e., if the device's positive Y-axis is pointed in the direction of the vehicle. It certain implementations, it may be useful to compare the device's Y-axis orientation as determined in step 1624 with the device's Y-axis orientation determined in this step. Such would be particularly useful in correcting a situation where the device was incorrectly placed on the left window of the vehicle in the required X-axis orientation and with the rear facing camera point out (i.e., to the left side), but which rear facing camera was incorrectly identified from the visual capture to be pointing to the right because a vehicle that was moving faster than the vehicle in which the device is present was seen in the visual capture. It should be further understood that in certain implementations the required orientation of the rear-facing camera of the device facing out against the window can be confirmed, and/or can be confirmed/determined to not be held facing out of the window based upon evidence in the visual capture originating at the device (e.g., by determining whether or that one or more interior components of the vehicle, e.g., the window pane, door, etc., are present in the visual capture) and can be confirmed to be facing out against the right window based upon the direction of movement of objects as is described in detail herein. It should also be understood that various additional confirmation approaches can be employed, such as various multi-touch and/or 2nd camera methods, such as those described in detail herein. It can be further appreciated that computing such a correlation enables the further determination of the relative location of device 105 within the vehicle. In determining the orientation of device 105, such as a mobile device held in the required orientation referenced above (as determined based on the GPS and compass headings), the perspective of the visual capture can be further appreciated, thereby enabling the determination of where the user is/is not seated within the vehicle, and thus to what degree of likelihood the user is/is not the driver and/or passenger of the vehicle.
The required orientation consists of three parts: (1) X-axis, (2) Y-axis, (3) pressed against (right) window, (forward-facing camera pointing out).
Accordingly, it should be understood that the operations described with respect to steps 1623A-
1626 pertain to various aspects of the "required orientation" as described herein. It should be understood that the "required orientation" preferably consists of/incorporates three parts/aspects/determinations: (1) X-axis, (2) Y-axis, and (3) that the device is pressed against the window of a vehicle, preferably with the rear-facing camera of the device facing out,
Accordingly, it should be understood that inputs originating at the X-axis accelerometer can be processed to confirm that the device is being held in the required X-axis orientation, i.e., landscape orientation, as described herein, Moreover, inputs originating at the camera (i.e., visual captures) can be processed, wherein generally stationary/slower moving objects should move from left to right, and/or
GPS heading can be processed against the magnetometer direction to confirm the required Y-axis orientation, i.e., positive Y-axis in direction of vehicle's movement. It can be appreciated that doing so also establishes that the camera (i.e., the rear facing camera) is pointing to the right. Moreover, the degree of "shake" perceived/determined at the device (as it can be appreciated that a device shakes relatively less when held against a window than when held by hand) and/or aspects determined based on the visual capture (being that a device held against window will not show interior components of vehicle) can be processed to confirm that the device is pressed against window. Based on the combined processing of these elements, it can be determined that the device is oriented at the right-hand side window of the vehicle, as described herein.
By way of further illustrations, it should be understood that one or more of the above referenced implementations (e.g., the visual capture processing, the stability determination, etc.) can be further enhanced (or, alternatively, the present implementation can be employed independently, without connection to any other of the implementations described herein) by verifying that the device is pressed against the right window in the required orientation by using the GPS sensor and the magnetometer and/or compass to verify that the orientation of the mobile device is consistent with being pressed against the right window of a vehicle in the correct orientation (as described in detail above). For example, it can be appreciated that in a scenario where a device is pressed against the left-hand side window of a vehicle window in an attempt to fraudulently authenticate the device in the manner described herein, such a device would still provide a GPS heading that is discemibly different than a device comparably positioned against the right-hand window of the vehicle Accordingly, even in a scenario where other of the above-referenced implementations do not accurately determine the identity of the use of the device (as a driver or passenger), the present approach can provide an accurate determination/authentication of the identity of the user of the device as a driver or passenger.
Then, at step 1642, processor 1 10 executing one or more of software modules 130, including, preferably, restriction module 171, adjusts an implementation of one or more restrictions at/in relation to mobile device 105 (that is, employs one or more restrictions, modifies an implementation of one or more previously employed restrictions, and/or removes one or more previously employed restrictions) based on the correlation, , substantially in the manner described in detail above with respect to step 1542.
Turning now to FIG. 17, a flow diagram is described showing a routine 1700 that illustrates a broad aspect of a method for authenticating an in vehicle role of a user of a mobile device and/or modifying a restriction of a mobile device 105 in accordance with at least one embodiment disclosed herein.
It can be appreciated that in order for a user to utilize the functionality of the integrated camera 145F of mobile device 105, such a user must grasp and/or come into contact with mobile device 105 with at least one hand. As such, it can be further appreciated that a visual capture taken by camera 145F that depicts two hands of a driver can be determined to be likely to have been taken by a user other than the driver of a vehicle, as will be described in greater detail below.
At step 1705, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, employs one or more restrictions at mobile device 105 and/or in relation to mobile device 105, substantially in the manner described above with respect to step 1505. By way of illustration, in certain implementations such restrictions can configure the mobile device 105 to operate only in landscape mode (that is, depicting the content/user interface shown on the display of the mobile device be depicted only in a landscape, i.e., lengthwise fashion) and/or in landscape orientation (that is, requiring that the X-axis of the mobile device must detect gravity, as is known to those of ordinary skill in the art - e.g., when held lengthwise - an orientation that generally requires two hands to effectively navigate and/or provide inputs to), as is known to those of ordinary skill in the art. By way of further illustration, in certain implementations such restrictions can configure mobile device 105 to receive various inputs only when the mobile device is oriented at a defined orientation and/or within a defined range of orientations (as can be determined using the accelerometer and/or gyroscope of the device). It should also be noted that in certain implementations, the various restrictions employed at/in relation to the mobile device 105 do not preclude partial and/or full operation of the device using voice commands, as is known to those of ordinary skill in the art. Moreover, in certain implementations, the restrictions do not preclude operation of the device for emergency purposes, such as to call or text '911,' as is also known to those of ordinary skill in the art.
At step 1707, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, prompts a user of the mobile device 105 to initiate and/or provide one or more first inputs at mobile device 105, substantially in the manner described above with respect to step 707. At this juncture, it should be noted that in certain implementations, such prompting includes the presentation, display and/or projection of prompts to the user in an obfuscated and/or obscured manner. That is, such prompts are preferably presented, displayed, and/or projected in one or more ways that require increased concentration and/or attention in order for a user to properly observe and comprehend/appreciate the prompting. Such obscuring/obfuscating of the various prompts/prompting serves to convey the information contained in the prompting (e.g., a word or string that the user must type) in such a way that is relatively more difficult for a driver to appreciate/understand (given that the driver is likely to be distracted by and/or concentrating on various ongoing driving-related tasks) than for a passenger to appreciate/understand (given that the passenger is less likely to be so distracted/concentrated).
By way of illustration, in certain implementations, such as those in which at least some portion of the referenced prompting is conveyed to the user visually (e.g., through the screen of the device), it can be useful to have some or all of such information presented, displayed, and/or projected in a manner that makes it more difficult for someone that is less able to pay close attention to the existence and/or content of such visual information that is required to successfully complete the required action(s), thereby increasing the difficulty for a user who is driving to successfully complete the requested stimulus/input. For example, such visual information can appear for only a short period of time and/or a non-constant time interval (including intervals of time that contain random components) so that a driver of a moving
vehicle, who is relatively less able to focus on such visual information, is more likely to miss and/or not see it and/or not process such prompting information (or at least not comprehend/understand it as quickly as a passenger would, on average); thereby further preventing a driver of a device from successfully unlocking such a device (and/or fraudulently authenticating such a device as if the user were a passenger). Moreover, in other implementations, such prompting information can be displayed in a different manner (e.g., in a different location, orientation, color, font and/or shape), consistently and/or periodically. In doing so, it can be appreciated that the ongoing changing of the manner or manners in which such prompts are presented, displayed, and/or projected introduces greater unpredictability for the user viewing/expecting the prompting, thereby increasing the difficulty to the driver in anticipating/appreciating the prompting, as described.
At step 1710, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171 receives at least a first input. Such inputs can include, but are not limited to: alphanumeric inputs provided in response to a prompt (such as a CAPTCHA prompt, as is known to those of ordinary skill in the art), inputs provided during the course of an interactive game, inputs provided in a lock screen, inputs provided during the course of an interactive puzzle, one or more tactile gestures (such as one or more swipe gestures) provided at a tactile sensor such as a touchscreen of the mobile device 105, one or more visual capture(s) and/or one or more inputs from one or more of an accelerometer a gyroscope, a GPS receiver, a microphone, a magnetometer, a camera, a light sensor, a temperature sensor, an altitude sensor, a pressure sensor, a proximity sensor, a near-field communication (NFC) device, a compass, user interface, device buttons, a communications interface, and a vehicle data system.
Then, at step 1720, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, processes the one or more first inputs (such as those received at step 1710) to compute a first determination, the first determination reflecting at least one in-vehicle role indicator which relates to the in-vehicle role of the user of the device as being either a driver or a passenger. This determination, reflecting an in-vehicle role of the user as a driver/passenger, preferably reflects an indication, such as one present in a a particular interaction with the mobile device 105, that the user of mobile device 105 is/is not reflecting behavior that conforms with that which can be determined to be associated with drivers and/or passengers. As will be illustrated in greater detail below, it should be understood that certain in-vehicle role indicators can enable determinations regarding the role of a first user based on inputs such as visual captures that reflect aspects of another user (for example, if a first user takes a picture of a second user who is driving a car, it can be determined, based on an identification of the second user as a driver, that the first user is not a driver, and thus is a passenger), while other in- vehicle role indicators can enable determinations based on inputs such as visual captures that reflect aspects of the user him/herself.
By way of example, in one arrangement a visual capture (e.g., a digital image or video) can be processed, such as using image recognition techniques known to those of ordinary skill in the art, to identify, within the visual capture, two hands grasping a steering wheel. It can be appreciated that a user
grasping the steering wheel of a vehicle can be determined to be likely to be the driver of the vehicle. However, based on the identification of two hands on the steering wheel, it can be further determined that only a passenger in the vehicle is likely to be capable of capturing such a picture using mobile device 105. (It should be understood that in certain implementations, further advanced image processing techniques can be employed, whereby the two hands identified on the steering wheel can be analyzed to determine that the two hands are substantially similar, and thus are likely to belong to the driver - as opposed to the driver placing one hand on the wheel, and the passenger placing another or the angle of the visual capture can be processed/analyzed to determine that the device is not likely to have been in a cradle or to require that the second camera of the device, if available, also record a visual capture which can be processed to make sure there are no signs therein indicating that the driver performed the visual capture, such as in the manner described herein.) Thus, it can be appreciated that in such implementations, while the visual capture itself depicts the hands of a driver, based on such a visual capture one or more determinations can be computed regarding the likelihood that the identify of the user that captured the picture (that is, the user of the mobile device 105) is a passenger.
By way of further example, in another implementation a visual capture can be received and processed, such as by using image recognition techniques known to those of ordinary skill in the art, to identify, within the visual capture, the positioning and/or orientation of a seat belt in relation to a user. For instance, if the visual capture depicts a seatbelt as stretching from the right shoulder of a user to the left thigh of a user, it can be reasonably determined that the pictured user is a passenger and not a driver.
By way of further example, in certain embodiments, a an in-vehicle role of a user can be determined if, the user can configure the device to capture a visual capture that can be processed to identify one or more indicators which, implicitly or explicitly indicate that there is a passenger in the car. (It should be understood that such visual capture(s) are preferably captured while the vehicle is in motion, as described in detail above). For example, as referenced above, if the user is able to take a visual capture of two hands on the steering wheel, the user of such device can be determined to be a passenger (as a driver generally cannot both take a visual capture with the device and hold the steering wheel with two hands). By way of further example, if the user of the device takes a visual capture within which a seatbelt going from the right shoulder of the user to left thigh of the user can be identified, the user of such a device can be determined to be a passenger (being that a visual capture that a driver would take of him/herself is likely to show a seatbelt going in the opposite direction).
At this juncture, it should be noted that in certain implementations, various other inputs, including but not limited to visual capture(s), can be received and/or processed in order to determine an in-vehicle role of a user of mobile device 105. For example, mobile device 105 can be positioned (such as in a dock) such that visual capture(s) received by/at the mobile device relate to a user's gaze (captured using a front-facing and/or rear- facing camera of the mobile device, depending on the orientation of the device, as can be appreciated by those of ordinary skill in the art). That is, the visual capture can be analyzed/processed using image processing techniques known to those of ordinary skill in the art, to identify the movements of a user's eyes, preferably while the vehicle is in motion (as can be determined
based on various inputs, such as the accelerometer 145 A). By way of illustration, if analysis of the visual capture reveals that the gaze of the eyes of the user of the device constantly and quickly returns to the direction of the windshield, it can be determined that the user is likely the driver (as such a pattern would be typical of a driver who needs to maintain ongoing view of the road while driving).
By way of further illustration, in certain implementations, an in-vehicle role of a user of a mobile device can be determined to be a passenger if, while the vehicle is in motion, the user is able to configure the device to take a visual capture based upon which it can be identified (such as through image processing techniques as referenced herein) that the user is able to look (i.e., focus his head and/or gaze/vision) in a manner that only a passenger can and/or a driver cannot. For example, if it can be determined, such as through the referenced image processing analysis of the visual capture, that the user of the device is capable of maintaining a substantially consistent/continuous look/gaze in the direction of the device for a defined period or certain periods of time, the in-vehicle role of such a user can be determined to be a passenger. At step 1725, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, validates one or more determinations, such as the determinations computed at step 1720. That is, as referenced herein, it can be appreciated that under certain circumstances and/or scenarios, any number of determination approaches can be susceptible to error and/or fraud. As such, it can be advantageous to further validate such determinations, thereby increasing the respective accuracy of each determination. The particulars of such validations will be described with reference to FIG. 17 A.
Turning now to FIG. 17A, at step 1726, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, receives one or more second inputs, substantially in the manner described in detail above with respect to step 1710. In certain implementations, such second inputs are preferably different inputs from those received at step 1710 (by virtue of the second inputs originating from a different sensor and/or source, or by virtue of the second inputs being a separate input instance from the first input). By way of example, such second inputs can be received from the accelerometer and/or the gyroscope of mobile device 105.
At step 1727, processor 1 10 executing one or more of software modules 130, including, preferably, restriction module 171, processes the second inputs (such as those received at step 1726) to compute a second determination, substantially in the manner described in detail above with respect to step 1720. In certain implementations (even those where the second input originates from the same source as the first input) the second determination is preferably independent of the first determination, such as the determination computed at step 1720, By way of illustration, the second determination (computed based upon inputs received from the gyroscope and/or accelerometer of the device) can reflect an orientation of the device, such as an orientation of the device with respect to the ground/earth. By way of further illustration, the second determination (computed based upon inputs received from the gyroscope, accelerometer, and/or GPS/magnetometer of the device) can reflect an orientation of the device, such as
an orientation of the device with respect to the vehicle within which the device is present, as described herein. By way of further illustration, the second determination (computed based upon inputs received from the gyroscope and/or accelerometer of the device) can reflect a pattern or trend that reflects the manner in which the vehicle within which the device is present is moving (e.g., reflecting acceleration, deceleration, stability, etc.). By way of further illustration, in an implementation where it can be determined that the focus of the user's gaze towards the windshield (as identified based on the processing of a visual capture, as described herein) tends to increase during periods of acceleration, fast speed, and/or other movements, this correlation can indicate that the user is a driver (as a driver is likely to pay additional attention to the road as such driving events occur). (It should be noted that mobile devices 105 having dual cameras - that is, cameras on both their anterior and posterior sides, as are well known to those of ordinary skill in the art, are well suited for the referenced determinations, as they enable visual captures of both a user's gaze as well as the scenery outside the vehicle's windshield.)
At step 1728, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, determines a validity of at least one of the first determination and/or the second determination. In certain implementations, the validity is determined by comparing the determinations and/or identifying correlations, relationships, patterns, correspondences, and/or discrepancies between them. By way of further illustration, in certain implementations, if it can be determined, such as through the referenced image processing analysis of the visual capture, that the user of the device is capable of maintaining a substantially consistent/continuous look/gaze in the direction of the device for a defined period or certain periods of time, while the device is held in a certain manner, such as at a particular orientation (as can be determined, for example, using the accelerometer/gyroscope of the mobile device 105), the in- vehicle role of such a user can be determined to be a passenger. It can be appreciated that by requiring that the user maintain his/her look/gaze towards the mobile device while the device is positioned at a particular orientation, such as an orientation and/or a range of orientations that entails the device being positioned substantially horizontally, a user can effectively be prevented from simultaneously looking at the device and also looking at the road ahead. For example, in a scenario where the angle of the device (as can be measured/determined, for example, using inputs originating from the accelerometer and/or gyroscope of the device) is oriented more than a defined threshold amount/number of degrees (e.g., 10, 20, or 30 degrees) (upward/downward/rightward/leftward or some combination thereof) from the typical line of sight of the driver in a moving car, such as is depicted, for example, in FIG. 17B, the in-vehicle role of a user who is capable of maintaining a substantially consistent look/gaze toward the mobile device (as determined through an analysis of the visual capture, as described above) while the device maintains such an orientation can be determined to be a passenger (since it is highly unlikely that a driver of a moving vehicle is capable of maintaining such a gaze towards the mobile device while the mobile device is so oriented, while also effectively driving a moving vehicle). It should be understood that the referenced examples are merely exemplary, and that numerous other implementations are also contemplated, utilizing other inputs, as can be appreciated by those of ordinary skill in the art.
At this juncture, it should be noted that in certain implementations, the various visual capture(s) referenced herein can be processed against one or more databases, such as databases that maintain images/photographs, and such processing can be further utilized in determining the in-vehicle role of a user of a mobile device. For example, it can be appreciated that many regulatory agencies (such as a department of motor vehicles) maintain databases of images of all licensed drivers within a particular jurisdiction. Moreover, it can be appreciated that certain mobile device users, such as children, the visually impaired, and/or the elderly, can frequently travel in vehicles despite the fact that these individuals do not drive, by virtue of the fact that they are not licensed to drive. Thus, in certain implementations, the visual capture of the face of a user can be processed against such a database that maintains photographs of licensed drivers. Using image recognition techniques known to those of ordinary skill in the art, if one (or more) photographs from the licensed driver database are identified as substantially similar to the image capture of the face of the user of the mobile device, it can be determined that the user is more likely to be a driver (by virtue of the fact that such a user is known to at least possibly be a licensed driver, and thus can have a propensity to drive). Conversely, if no photographs from such a database are identified as being substantially similar y to the image capture of the face of the user of the mobile device, it can be determined that the user is more likely to be a passenger (by virtue of the fact that such a user may not even possess a license to drive).
By way of further illustration, the above referenced approach (identifying an in-vehicle role of a user based on the degree to which the user can focus his/her look or gaze) can be further implemented in conjunction with one or more of the other approaches described herein. For example, in a scenario where mobile device 105 is equipped with two cameras (e.g., a forward- facing camera which faces the user when operating the phone, and a rear-facing camera which faces away from the user like most traditional cameras), by processing visual captures from a first camera facing the user and visual captures from a second camera facing away from the user (and preferably outside a vehicle window). Based on the processing of such visual captures, a determination that the device is on the right-side of the vehicle can be computed (as described in detail above), and/or a determination that the user is able to maintain a prolonged gaze towards the device can be computed (as also described in detail above). In such a scenario, it can be further determined that the in-vehicle role of such a user of the device is not a driver, and one or more restrictions of the device can be adjusted accordingly.
Then, at step 1742, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171 , adjusts an implementation of one or more restrictions at/in relation to mobile device 105 (that is, employs one or more restrictions, modifies an implementation of one or more previously employed restrictions, and/or removes one or more previously employed restrictions) based on the determination and/or the validation, substantially in the manner described in detail above with respect to step 1642.
Turning now to FIG. 21, a flow diagram is described showing a routine 2100 that illustrates a broad aspect of a method for selectively restricting a mobile device 105 in accordance with at least one embodiment disclosed herein. It should be understood that in certain implementations, including any and
all of the implementations and approaches described herein, it can be advantageous to initially determine (e.g., by and/or based on inputs originating at vehicle data system 164) that there is a passenger present in the vehicle. It can be appreciated that if the presence of a passenger within a vehicle cannot be initially determined, it can be more efficient to preclude any/all of the various methods and approaches described herein, such as those which serve to identify the in-vehicle role of the particular user, and thus simply employ one or more restrictions based upon a determination that the user is likely to be the driver. Moreover, in certain implementations, it can be advantageous to initially determine (e.g., based on inputs originating at the mobile device 105 and/or external sources such as vehicle data system 164) that the vehicle within which the mobile device 105 is present is in motion (being that certain restrictions may be preferable/appropriate/necessary only when the vehicle is in motion).
At step 2110, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171 receives one or more inputs, substantially in the manner described in detail above with respect to step 1710, For example, inputs originating at various sensors within a vehicle (e.g., seatbelt sensors, weight/movement/heat sensors at a passenger seat, etc.) can indicate and/or be processed to determine that a passenger is present within the vehicle. Put differently, one or more sensors or sources (e.g., vehicle data system 164) can provide inputs and/or other such information that indicate and/or can be processed to determine that a vehicle is moving and/or that there are occupants in the vehicle other than a driver. In certain implementations, if no such inputs/notifications, etc. are received, and thus the presence of a passenger in the vehicle cannot be confirmed), any or all of the various methods described in detail herein will effectively be precluded, as referenced above, such as by not adjusting any restriction/unlocking the device.
At step 2120, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, process the inputs (such as those received at step 2110) in order to determine a presence of a passenger within the vehicle. That is, as referenced above, in certain implementations (which, as noted, can be employed independently or in conjunction with one or more of the various other implementations and approaches described herein) one or more inputs originating at a vehicle data system (e.g., OBDii or other in-car computer systems such as seatbelt sensors, weight/movement/heat sensors in a passenger seat, etc.) can be processed to determining that there are one or more passenger occupants in the vehicle (and/or a degree of likelihood of such) and/or that more than one occupant is present in the vehicle (and/or a degree of likelihood of such).
Then, at step 2142, processor 110 executing one or more of software modules 130, including, preferably, restriction module adjusts an implementation of one or more restrictions at/in relation to mobile device 105 (that is, employs one or more restrictions, modifies an implementation of one or more previously employed restrictions, and/or removes one or more previously employed restrictions) based on the determination. That is, it can be appreciated that if the presence of at least one passenger within the vehicle cannot be determined, the various methods and authentication approaches described herein can be precluded/prohibited from commencing and/or made to fail regardless of the result of the other
12 030017 components, accounting for the fact that it is unlikely that a passenger is actually present in the vehicle, and thus the user of the device within the vehicle is likely to be the driver.
It should also be noted that in certain implementations, various of the methods and approaches described herein, such as various approaches for determining an in-vehicle role of a user, can operate based on a default assumption/setting reflecting that the in-vehicle role of the user of the device is a driver, until proven otherwise (through one or more of the various methods described herein). In certain implementations such a default setting can optionally allow the device user unrestricted access until such time as such user wants to perform certain interactions that require passenger authentication.
It should also be understood that the references provided above to holding/maintaining the mobile device at a particular orientation (such as substantially horizontal) are non-limiting, and in certain implementations various other restrictions, methods, approaches, etc. can be employed without requiring such orientation constraint.
It should also be noted that many of the implementations described herein can be implemented alone and/or in different combinations.
It should also be noted that in certain implementations, any of the passenger authentication methods/approaches described herein can be configured to require that certain components/aspects of the authentication methods/approaches be performed at certain times within the process and/or within certain amounts of time and/or for certain amounts of time (e.g., the user must begin a swipe gesture within 1 second of the phone being placed in the required orientation and must be complete the gesture within 0.8 seconds thereafter during which time, for example, the user must place a finger in a certain location of the device for at least 1 second).
It should also be noted that the calculations, computations, and/or processing operations that are required in such authentication processes can be performed at the device itself and/or can be performed at a remote device (such as at central machine 168) - or in some combination thereof, in a manner known to those of ordinary skill in the art.
It should also be noted that in certain implementations, the authentication approaches/methods described herein are configured to prevent/preclude requiring a passenger to re-authenticate his/her device when a vehicle temporarily stops or slows down (e.g., reduces its speed below a certain threshold), during the course of a journey. This can be done, for example, by requiring that a the user of the device re- authenticate only if the vehicle within which the device is present can be determined to have stopped and/or maintained a slow speed (e.g., as can be determined based on inputs originating at the GPS, accelerometer, gyroscope, vehicle data system, antennas, radio frequencies/signals, such as those originating at one or more radio towers, such as those utilized in implementing cellular communication networks, as is known to those of ordinary skill in the art, and/or other sensors), for more than a certain amount of time. In other implementations, the referenced requirement for re-authentication can be correlated with a determination that the engine of the vehicle within which the device is present is still operating (e.g., based on a determination computed by processing one or more of inputs originating at the accelerometer, gyroscope, magnetometer and/or microphone, as described herein),
Turning now to FIG. 22, a flow diagram is described showing a routine 2200 that illustrates a broad aspect of a method for eliciting an authentication at a mobile device 105 in accordance with at least one embodiment disclosed herein. It should be understood that in certain implementations, such mobile device preferably has one or more authentication modes, such as a first authentication mode and a second authentication mode. Moreover, in certain implementations, such a mobile device preferably has a single authentication mode having a range of settings/parameters that can be adjusted, as described in detail herein.
At step 2205, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, employs one a first authentication mode at/in relation to mobile device 105. By way of example, a first authentication mode can include a lock screen or mode (such as those referenced above at step 1710) wherein a user is prompted/required to provide alphanumeric input(s) in completion of a CAPTCHA exercise, complete an interactive puzzle, etc.
At step 2210, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, receives a first authentication attempt. For example, such a first authentication attempt can include an input provided by the user in attempting to authenticate/unlock the device, such as alphanumeric input(s) (in the case of a CAPTCHA prompt), an input attempting to perform an interactive puzzle, etc.
At step 2220, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, processes the first authentication attempt to determine a degree of authentication success. For example, in the case of a CAPTCHA prompt, the first authentication attempt (that is, the alphanumeric characters input by the user) can be processed to determine the degree to which the input was successful in performing the task required to authenticate the device (such as the percentage of characters in the CAPTCHA prompt that were properly input by the user).
At step 2225, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, employs a second authentication mode based on the first authentication attempt. That is, it can be appreciated that in a scenario where the first authentication attempt did not successfully authenticate the device and/or where the first authentication attempt did not meet a certain degree of authentication success (e.g., inputting at least 70% of the characters in the CAPTCHA prompt correctly), a second authentication mode can be employed. In certain implementations, such a second authentication mode preferably entails an authentication mode that is more restrictive and/or more difficult to authenticate than the first authentication mode. For example, the second authentication mode can require a certain delay (e.g., 30 seconds) before another authentication attempt can be received at the mobile device. By way of further example, a second CAPTCHA prompt can be presented requiring the user to input more letters than the first CAPTCHA prompt, and/or to input such letters more accurately, in order to authenticate/unlock the device.
At step 2226, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, maintains a log of authentication attempts. At step 2230, processor 1 10 executing one or more of software modules 130, including, preferably, restriction module 171,
transmits one or more notifications regarding one or more authentication attempts, such as to a third party. It can be appreciated that in doing so, such authentication attempts can be monitored, and users who consistently fail to authenticate their devices can be identified as potentially attempting to authenticate their devices while driving.
By way of further illustration, it can be appreciated that in certain implementations, such as those described above, it can be advantageous to make passenger authentication attempts, which come after failures to authenticate, increasingly/progressively difficult. In certain implementations, this can be achieved by requiring that a certain amount/duration of time elapse before a device, whose authentication has failed, can elicit and/or receive a re-authentication attempt. Such time can also be configured to increase progressively after each authentication failure. Moreover, in certain implementations, such authentication failures can be reported one or more third parties. Moreover, in certain implementations, such authentication failures can entail one or more dynamic changes/adjustments to the parameters of the various techniques required to successfully authenticate (e.g., the device must be more stable on successive attempts in order to authenticate).
It should also be noted that in certain implementations the details of the passenger authentication can be reported/transmitted to one or more third parties, and corresponding logs can be established/maintained for them.
Turning now to FIG. 23, a flow diagram is described showing a routine 2300 that illustrates a broad aspect of a method for eliciting an authentication at a mobile device 105 in accordance with at least one embodiment disclosed herein. It should be understood that in certain implementations, such mobile device preferably has one or more authentication modes, such as a first authentication mode and a second authentication mode. Moreover, in certain implementations, such a mobile device preferably has a single authentication mode having a range of settings/parameters that can be adjusted, as described in detail herein.
At step 2310, processor 1 10 executing one or more of software modules 130, including, preferably, restriction module 171, receives one or more inputs, substantially in the manner describe in detail above with respect to step 1710. Examples of such inputs include, but are not limited to, inputs relating to speed, location, road type, time of day, weather conditions, traffic conditions, (as received, perceived and/or determined based on one or more inputs of the sensors of a particular device, information and/or data received from one or more external sensors and/or devices, such as, for example, external data streams, RSS feeds, and/or databases, such as those accessible over a GPRS data connection, and/or computations and/or determinations that are computed based on one or more of such inputs, information, data, etc.).
At step 2320, processor 1 10 executing one or more of software modules 130, including, preferably, restriction module 171, processes the input(s) to compute one or more determinations. Preferably the determinations reflect a degree to which a user, such as a user in a moving vehicle, is likely to be capable of multitasking and/or is distracted and/or is potentially distracted or distractible. For example, it can be determined that a user of a device present within a vehicle moving at a high rate of
speed is likely to be more distracted (such as in scenario where such a user is the driver, on account of the increased concentration that the driver must dedicate to driving at a higher speed) and/or subject to the increasing force(s) (such as in a scenario where such a user is a passenger, especially while the vehicle is moving laterally), moreso than a user in a vehicle moving at a relatively lower rate of speed.
At step 2330, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, employs an authentication mode at the mobile device based on the determination. It should be understood that in certain implementations such an authentication mode can include multiple parameters, settings, and or configurations, while in other implementations such an authentication mode can be selected from among multiple distinct authentication modes, such as a first authentication mode and a second authentication mode. For example, as referenced above, it can be appreciated that a driver present in a vehicle moving at a relatively high rate of speed is likely to be potentially more distracted, and thus relatively less able than a driver present in a vehicle moving at a relatively low rate of speed to provide even a relatively simple authentication (while, at the same time, a passenger in such a vehicle can be similarly limited, on account of the forces imposed on the user while riding in such a fast moving vehicle). It can be similarly appreciated that a user traveling within a vehicle moving at a relatively slower rate of speed is likely to be more capable of multitasking, even while driving, than a comparable user traveling within a vehicle moving at a relatively faster rate of speed, and thus can be determined to be relatively less distracted than such a comparable user traveling in a vehicle moving at a relatively faster rate of speed. As such, in certain implementations, one of the various authentication modes and/or settings thereto can be employed/selected based on a determination that reflects the likelihood that the user is/is not distracted/able to multitask. Thus, by way of illustration, in certain implementations, when the vehicle is moving at a relatively slower rate of speed, an authentication mode/setting requiring relatively more concentration/attention can be employed (such as a CAPTCHA prompt requiring six letters to be correctly/accurately input in order to authenticate/unlock the device), and when the vehicle is moving at a relatively faster rate of speed, an authentication mode/setting requiring relatively less concentration/attention can be employed (such as a CAPTCHA prompt requiring only four letters to be correctly/accurately input in order to authenticate/unlock the device) can be employed.
By way of further illustration, it should be noted that any and all of the implementations, methods, and approaches described herein, including those enumerated above, can also be employed in a manner whereby the difficulty of the task presented to and/or required of a user in order to authenticate the in-vehicle role of a user as a passenger (including the time needed for a user to perform an action in order to so authenticate his/her identity as a driver or passenger, and/or the time limit within which the user is required to so authenticate), can be determined and/or adjusted dynamically based upon any number of factors. By way of example, factors such as speed, location, road type, time of day, weather conditions, traffic conditions, (as perceived and/or determined based on one or more inputs of the sensors of a particular device, information and/or data received from one or more external sensors and/or devices, such as, for example, external data streams, RSS feeds, and/or databases, such as those accessible over a
GPRS data connection, and/or computations and/or determinations that are computed based on one or more of such inputs, information, data, etc., such as in the manner described in detail herein) can be considered and/or processed in order to determine and/or adjust one or more operational parameters of a particular authentication task/mode or tasks/modes, as described above. For example, in a scenario where the vehicle within which the user is traveling is moving at a relatively slow speed, the user can be required to complete an authentication task within a relatively shorter time limit (as compared to when the vehicle is moving at a relatively faster speed), thereby accounting for the fact that when traveling at a slower speed, a driver may be able to. divert his/her attention from driving for a relatively longer time interval (as compared to when driving faster). As such, the time limit within which the authentication task must be completed can be reduced at lower speeds. (Similarly, it can be appreciated that when traveling at faster speeds, a passenger may require additional time to complete an authentication task, accounting for the additional forces attendant with travel at higher speeds.) By way of further illustration, in certain implementations the duration of time during which a particular authentication task must be performed can also be adjusted dynamically based on any number of factors, such as those referenced above. For example, when a vehicle is traveling at a relatively slower speed, a user can be required to hold his/her gaze into a camera of a mobile device for a relatively longer period of time than such authentication may require when traveling at relatively faster speeds. Being that at slower speeds a driver may be able to divert his/her attention from driving for relatively longer periods of time (as referenced above), the authentication task/mode can be adjusted (such as by requiring that the task be performed continuously for a longer period of time) in order to account for this discrepancy/difference. It should also be noted that in certain implementations, the particular authentication task required of a user (e.g., a swipe unlock gesture, a puzzle, etc.) can be changed or substituted depending on the various factors referenced above. Thus, for example, at one speed a swipe unlock gesture can be required in order to authenticate the user as a passenger, while at another speed a puzzle must be completed in order to complete such authentication.
It should also be noted that, in certain implementations, it can be advantageous to allow passengers to be authenticated by 3rd parties, despite previous failed, inconclusive, incomplete, or nonexistent authentication attempts, such as the results of one or more of the above referenced methods. For example, if mobile device 105 is damaged or malfunctions (e.g., due to a broken sensor, environmental disturbances such as weather conditions affecting the performance of the GPS, etc.) thereby precluding various of the authentication methods/approaches (such as those described herein ) from being employed effectively, a third party such as an employer or a parent can remotely provide such authentication, such as in a manner known to those of ordinary skill in the art.
It should also be noted that various of the methods described herein are described with reference to a road system where the cars travel on the right-side of the road and where drivers are seated on the left-side of the vehicle. However, it should be understood that the methods described herein are not so limited, and can be similarly employed/ transferred to other road systems (such as that of the United Kingdom).
U 2012/030017
Turning now to FIG. 24, a flow diagram is described showing a routine 2400 that illustrates a broad aspect of a method for selectively modifying a restriction employed at a mobile device 105 in accordance with at least one embodiment disclosed herein.
At step 2410, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, receives one or more inputs, substantially in the manner describe in detail above with respect to step 1710. For example, such inputs can originate at the accelerometer and/or gyroscope of the mobile device 105, and reflect the movement/motion that the device perceives.
At step 2420, processor 1 10 executing one or more of software modules 130, including, preferably, restriction module 171, processes the input(s) to compute one or more trends/patterns. By way of example, inputs, such as those received at step 2410, can be processed to determine one or more patterns, such as those that correspond to driving and/or walking (e.g., by comparing the various inputs to operation signatures that correspond to such activities, as is known to those of ordinary skill in the art). In doing so, one or more trends/patterns can be computed, such as a trend/pattern that reflects that the user of the device is now walking. By way of further illustration, a trend/pattern can be computed reflecting the docking status of a mobile device, such as in the manner described in detail herein.
At step 2442, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, adjusts an implementation of one or more restrictions at/in relation to mobile device 105 (that is, employs one or more restrictions, modifies an implementation of one or more previously employed restrictions, and/or removes one or more previously employed restrictions) based on the one or more trends/patterns. For example, in certain implementations, despite having previously determined that the user of mobile device 105 is a driver of a vehicle (and thus employing one or more restrictions on such a device), upon computing one or more trends/patterns that indicate that the user of the device is now walking (and thus is no longer driving a vehicle), such previously imposed restrictions can be adjusted, eased, removed, etc. By way of further illustration, based on a determination of the docking status of a device, as described in detail herein, one or more restrictions appropriate for a docked device (e.g., a restriction that prohibits voice calls to be made/conducted) can be modified/eased/lifted.
By way of further illustration, in certain implementations, after a device is placed in driver mode (e.g., the user of the device been authenticated as a driver and/or the device and/or restriction are configured such that the device operates by default in driver mode, until the user can prove otherwise by way of one or more authentications, such as through the methods described herein) a further determination can be made with regard to whether the device remains or is no longer in a moving vehicle. In doing so, some or all of various restrictions referenced herein, e.g., operation of a mobile device in a 'driver mode,' can be suspended and/or canceled, thus returning the device to its default, un-restricted operation. In various implementations, such a determination can be computed (for example, using inputs originating at one or more of the GPS, the accelerometer, the gyroscope, and/or the RF transceiver/antenna to know which cell towers the device is in communication) based on (a) whether the vehicle has not moved above a certain speed for more than a certain period of time; and/or (b) whether the vehicle has not moved above a certain speed for more than a certain portion over a period of time (the
'timeout period'). Additionally, in certain implementations, a user who was previously identified as a driver can be enabled to authenticate that he/she is no longer the driver of a moving vehicle in order not to have to wait the full timeout period before regaining full control over the device. In certain implementations, this can be achieved, for example, (a) by holding the device so that the camera of the device can capture (and recognize, such as with face recognitions methods, as are known to those of ordinary skill in the art) the presence of a face (or eyes or gaze etc.) and by then rotating 360 (or more or fewer) degrees, as measured by device's sensors (e.g., magnetometer, gyroscope, accelerometer, etc.), during which time the camera perceives the face (or eyes or gaze etc.); (b) by touching the device in a manner that can be detected (e.g., touching the screen, holding a button, etc.) and by then rotating 360 (or more or fewer) degrees, while the user maintains his/her touch or hold on the device; (c) by moving the device (e.g., up, down, sideways) a distance greater than the distance that a driver in a moving vehicle is able to as measured by the device's sensors (e.g., accelerometer, gyroscope, etc.); and/or (d) by taking a visual capture from close range of a license plate(such a visual capture can be processed to identify an indication of a degree of close proximity of a license plate. It can be appreciated that a driver of a moving vehicle is likely to be incapable of capturing a visual capture within close proximity of a license plate).
It can be appreciated that the referenced techniques are preferably actions or tasks that are difficult, if not impossible, for a user to perform while he/she is still the driver of a vehicle.
Turning now to FIG. 18, a flow diagram is described showing a routine 1800 that illustrates a broad aspect of a method for selectively restricting an operation of and/or selectively modifying a restriction employed at mobile device 105, such as within a geographic area and/or a date/time window, in accordance with at least one embodiment disclosed herein. As will be described in detail herein, it can be appreciated that under certain circumstances (e.g., within defined spaces and/or times) it can be advantageous to control and/or influence the operation of one or more mobile devices 105, 160 in various ways, such as by configuring such devices to operate in a highly conspicuous/overt fashion. For example, considering the distracting nature of mobile device usage during class (particularly when used in an inconspicuous fashion), it can be advantageous for a school to require that its students only operate mobile devices 105, 160 during school days/time and/or on school locations/grounds and/or in certain location within school grounds (e.g., classrooms) in a manner that is highly conspicuous, thereby effectively precluding the inconspicuous usage of such devices 105, 160 in settings where their use is undesirable.
At step 1811, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171 generates one or more output(s), such as an audio output (such as a beep or chirp) that is projected through speaker 146 of mobile device 105. It should be understood that such outputs can be configured/adjusted in any number of ways (e.g., in frequency, duration, and/or volume), both with respect to their substance (e.g., chirps, beeps, tones, etc.) and the periodic interval within which they are projected (static and/or dynamic). In any event, it should be understood that such outputs are preferably projected at volumes and for durations such that inconspicuous operation of mobile device 105, 160 is effectively precluded (e.g., in a classroom setting) on their account. Moreover, in
certain arrangements it can be preferable that such outputs are not so loud and/or so frequent so as to significantly annoy the user and/or those around them while using mobile device 105, 160 in a permitted setting. At this juncture, it should also be noted that in certain arrangements, one or more of the referenced outputs can be generated in response to one or more inputs, as will be described in greater detail below.
At step 1812, processor 1 10 executing one or more of software modules 130, including, preferably, restriction module 171, receives one or more inputs. For example, in certain implementations one or more of the outputs projected by mobile device 105 (such as through speaker 146, as described with reference to step 181 1) can, in turn be received, as inputs, at the mobile device, such as through microphone 145D.
By way of further example, in other implementations the one or more inputs can correspond to various user interactions with the device, such as tactile interactions (e.g., with one or more tactile sensors such as one or more buttons, a touchscreen, etc., as describe in detail herein) or device movements. Upon receiving such inputs, one or more outputs can be projected, as described above with respect to step 1811. (It should be understood that in the referenced implementations, the sequence with which steps 1812 and 1811 occur are preferably reversed, such that inputs are received, and then outputs are projected based on such inputs. However, as noted herein, the various steps, operations, etc., that pertain to and/or make up any and all of the various systems and methods described herein should not be understood to be required to be performed in a particular order or sequence. Rather, such steps can be arranged and/or performed in any number of sequences, as can be appreciated by those of ordinary skill in the art, and each such sequence/arrangement should be understood to be encompassed by the methods and systems disclosed herein).
By way of further example, it should be understood that in certain implementations, the systems and methods disclosed herein can be configured such that one or more of the output(s) that the mobile device generates/projects upon/in response to a user input are not readily audible to humans, though such output(s) are perceptible to other electronic devices (e.g., a device used by a teacher and/or in the classroom, such as the teacher's mobile device and/or other devices such as devices configured to perform and/or provide the same or similar functionality), in a manner known to those of ordinary skill in the art. In such scenarios, various devices, such as a device used by a teacher, can be configured to perceive and recognize the referenced output(s) (that is, those output(s) that are not readily audible to humans but which may be in the audible range and not audible by virtue of their short duration (temporal summation) and/or their low volume). Moreover, such device(s), such as a device used by a teacher or administrator, can be configured to generate and/or project another signal, such as a signal that is readily audible to humans. In doing so, the teacher and/or others can be alerted (by way of a human-audible signal/tone) to the fact that a mobile device is in use within the classroom. It can be appreciated that such an implementation can be advantageous in certain situations because in utilizing signals that are not audible to humans, potential distractions arising as a result of periodic/ongoing projection of audible noises (as emitted from chirp-enabled devices) are reduced. Moreover, it should be understood that in
2012/030017 certain implementations a device, such as a device used by a teacher, can configure other mobile devices (such as mobile devices belonging to students present in the teacher's classroom and/or students in the teacher's class) not to emit readily audible sounds during times when the teacher sanctions use of mobile devices for his/her students, such as for legitimate learning purposes. It should also be noted that various of the implementations described herein can also be configured such that a mobile device, such as a mobile device belonging to a student, generates/projects output(s) that are readily audible to human.
In certain implementations, the referenced chirp-enabled mobile device(s) (e.g., a device belonging to and/or being used by a student) can be configured to receive a special output (such as a signal, as described herein) originating, for example, from another device, such as a device controlled and/or operated by a teacher. As referenced above, in certain implementations, such output/signal can either be readily or not readily audible to humans, whereupon the mobile devices that receive such signal preferably cease to chirp (that is, to project/emit an output as described herein) when the user interacts with the device for some period of time or until they receive another signal that they should re-initiate chirping when the user interacts with the device (it should be noted that in other implementations the device can, by default, not be in chirp mode, or cannot be in chirp mode on account of the teacher disabling it, and chirp mode in such devices can be subsequently activated by the teacher, such as by projecting the appropriate signal to such devices). It should be noted that such special signal is preferably secure so that it cannot be readily emitted by all devices (e.g., non-Teacher Devices so as to unintentionally or nefariously disable chirping on chirp-enabled mobile devices. Methods of ensuring this security are known to those of ordinary skill in the art, In certain implementations it can also be useful to utilize two-way communication, including various forms of "handshaking" between the mobile device(s) and the "teacher's device," in a manner known to those of ordinary skill in the art.
At step 1815, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, adjusts one or more aspects of one or more outputs based on one or more of the inputs. That is, in certain implementations the various device(s) can be configured whereby a device chirps in response to one or more external stimuli (e.g., one or more sounds) in a manner that configures the device to chirp more or less frequently and/or more or less loudly. For example, a teacher that hears a chirp, but is unsure as to which device in the classroom emitted the chirp, can use his/her a mobile device or a different electronic device, mechanical device and/or physiological action (e.g., his/her voice or a hand clap) to emit a signal which, upon receipt and processing by chirp enabled devices, causes such devices to chirp, either in their usual manner or in an alternative manner (e.g., in a more frequent and/or a louder manner). Additionally, in certain implementations, one or more aspects of the outputs/chirps can be adjusted based on various determinations, such as a determination the device is operating in a regular/normal fashion for an extended period of time (indicating that the present use of the device is likely permitted), as described in greater detail below.
At step 1820, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, processes the one or more outputs and the one or more inputs. In doing so, a correlation between the one or more outputs and the one or more inputs can be determined.
By way of illustration, in certain implementations a mobile device can be configured to chirp (that is, to generate/project an output), such as in response to a user's tactile input, such as a button press or a tap/gesture at a touchscreen), and the mobile device can, in turn, receive/perceive such chirps by receiving them as inputs via microphone 145D. As such, a correlation can be computed, reflecting the degree to which such outputs (that is, the chirps or signals projected from speaker 146 of mobile device 105) correlate with the inputs (that is, the sound of such chirps/signals) are, in turn, received by microphone 145D. It can be appreciated that if a strong/close correlation can be identified between such outputs/inputs, it is likely that the mobile device is operating properly with respect to projecting and receiving chirp signals. However, if such a strong correlation cannot be determined, it can be determined that the mobile device may have been/has been tampered with, such as in order to prevent the projection of chirp signals (e.g., if the user breaks and/or attempts to muffle/mute speaker 146).
By way of further illustration, in certain implementations the presence/absence of one or more input(s) and/or the presence/absence of a correlation between a first input and a second input can be determined, while the device is within a defined geographic area and/or within a defined date/time window. That is, in certain arrangements restriction module 171 is configured such that one or more inputs (e.g., depressing a button, interaction with the touchscreen, device movement, etc.) cause the outputting referenced above at step 1811. Thus, given that such inputs trigger the projecting of the referenced audio output through speaker 146, it can be appreciated that microphone 145D can be easily configured to have the capacity to detect such an output because the timing in which to look for the signals is exactly known to the device. Accordingly, if a presence of an audio output and/or a presence of a correlation between a first input (e.g., a user depressing a button) and a second input (e.g., detecting the audio output projected by speaker 146 in response to the user's input at microphone 145D) is determined, the restriction scheme (that is a scheme requiring such ongoing 'chirping' in order to prevent covert operation of the mobile device) can be determined to be working properly, and no change or adjustment need be made (given that the restriction(s) are preferably configured, in certain implementations, to allow the device 105, 160 to operate in a conspicuous manner). However, if the presence of an audio output and/or the presence of a correlation between a first input (e.g., a user depressing a button) and a second input (e.g., detecting the audio output projected by speaker 146 in response to the user's input at microphone 145D) is not determined, the restriction scheme can be determined to be unlikely to be working properly. This malfunction can, in certain circumstances, be due to a user attempting to prevent mobile device 105, 160 from functioning properly, perhaps in hopes of avoiding the referenced effects/restrictions. In such a case, where it has been determined that device 105, 160 is not operating properly, one or more restrictions can be employed, modified, and/or removed. In doing so, the framework established can ensure that unauthorized use of the device 105, 160 (e.g., during a class) is effectively precluded, except, in certain circumstances, such as in emergency situations. By way of further illustration, it may be useful for the device to output sound (e.g., frequency, duration, volume) from its speakers and listen for it on its microphone, unrelated to the user's interaction with the device, and where such sounds are similar to the sounds that the teacher devices transmit so that the device will
not be blocked from receiving the signals from the teacher's device if and when they are transmitted. If the student device does not receive the signals so transmitted by the student device, i.e., the speaker and/or microphone are not working properly, the device will be restricted.
Moreover, in certain implementations, in response to such previously described external stimuli, only those devices that meet one or more conditions (e.g., devices that have chirped within the last few minutes) are to chirp in response to one or more such external stimuli. For example, a teacher that hears a chirp, but is unsure as to which device in the classroom chirped, can use a device or take an action to emit a output/signal which will cause chirp-enabled phones that meet the referenced condition(s) to chirp in their usual or in an alternative manner.
In certain implementations, the output/signal that the mobile device emits/projects upon user input can consist of two or more elements, at least one of which is preferably audible. For example, the detection determination as to whether the device's speaker is working properly (as referenced herein) can be performed by having the device emit one or more outputs/signals, with or without connection to the user's interactions with the device, that are not ready/easily audible to humans (e.g., due to their frequency, intensity and/or duration), but which can also be perceived by microphone 145D (the "Detection Signal"), while another output/signal, which preferably enables teachers to identify mobile devices that are in use (the "Teacher Signal"), can be at a frequency in the human audible range. It can be appreciated that by emitting/projecting the detection signal in a range or for durations that are not readily audible to humans, such a signal can optionally be transmitted louder, thus improving the signal to noise ratio (SNR), without distracting others.
Additionally, in certain implementations the Detection Signal and/or the Teacher Signal outputted/emitted from different mobile devices can vary across different devices (it should be understood that in certain other implementations such signals/outputs can actually be the same signal). For example, such outputs can be randomized and/or altered by the user input (e.g., different chirps correspond to different types of inputs, e.g., texting, game playing, etc.). This is useful as it can make the task of detecting the chirp more accurate, easier, more power efficient and/or faster.
At step 1842, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, adjusts an implementation of one or more restrictions at/in relation to mobile device 105 (that is, employs one or more restrictions, modifies an implementation of one or more previously employed restrictions, removes one or more previously employed restrictions, and/or maintains one or more previously employed restrictions). That is, as referenced above, in a scenario where a close coordination can be identified between one or more inputs and outputs, such a correlation can indicate that the 'chirp' restriction is operating properly at the mobile device, and the employment of such a restriction can be maintained. However, in a scenario where such a close correlation cannot be identified, thus indicating that the device may be malfunctioning and/or has been tampered with. In such a scenario, a further restriction can be employed, such as a restriction deactivating all operation of the device. Finally, in implementations where the teacher's device (or similar) signals to the student's device
to disable/enable chirp mode on the student's device, the appropriate changes to the restrictions will be made.
Turning now to FIG. 25, a flow diagram is described showing a routine 2500 that illustrates a broad aspect of a method for selectively projecting outputs at a mobile device 105 in accordance with at least one embodiment disclosed herein.
At step 2510, processor 1 10 executing one or more of software modules 130, including, preferably, restriction module 171, receives one or more inputs, substantially in the manner describe in detail above with respect to step 1710. For example, such inputs can originate at the accelerometer and/or gyroscope and/or user interface of the mobile device 105, and reflect the movement/motion perceived at the device.
At step 2520, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, processes the input(s) to determine a first relationship (e.g., a correlation). By way of example, inputs, such as those received at step 2510, can be processed, such as with one or more operation signatures. In doing so, a relationship between the inputs received and the operation signatures can be determined.
By way of illustration, it should be understood that in certain implementations, the 'chirps' referenced herein can be triggered based on the movement of a mobile device, and/or a combination of user input and movement. For example, inputs received from the accelerometer and/or gyroscope of a device (such as at step 2510) can be processed, such as by being processed with/against one or more operation signatures (that is, data that identifies, such as based on mechanical and/or statistical analysis, how a device moves when engaged in certain activities, such as when a user is texting, walking, etc.). It can be appreciated that in doing so, the manner in which the device is being used can be determined (e.g., whether the device is being used to play a game, text, etc.), such as based on a correlation between the inputs and the operation signature, For example, it can be appreciated that the signature of various inputs originating at the various sensors when the device is being used to text, surf and/or play games is easily differentiable from the sensor signature of the device when the device is at rest and/or when the user is walking with the device on his/her person or in a bag, as is known to those of ordinary skill in the art.
At step 2522, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, projects one or more outputs based on the first relationship. For example, in a scenario where it has been determined (such as based on the relationship computed at step 2520) that the user is texting or playing a video game on his/her mobile device, the device can be configured to project one or more outputs (e.g., chirps), thereby creating a scenario whereby others (such as a teacher) can be made aware of such activity.
At step 2524, processor 1 10 executing one or more of software modules 130, including, preferably, restriction module 171, processes the one or more outputs (such as those projected at step 2522) and one or more inputs (such as an input received via a microphone, substantially in the manner described above with respect to step 1812). In doing so a second relationship, such as a correlation can be determined that reflects a correlation between the one or more outputs and the one or more inputs,
substantially in the manner described above with respect to step 1820. As described in detail above, it can be appreciated that in doing so, it can be determined whether or not the speaker 146 of mobile device 105 is functioning properly (and thus is projecting outputs/chirps, such as those projected at step 2522), or whether the speaker may have been tampered with, as described in detail above.
At step 2542, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, adjusts an implementation of one or more restrictions at/in relation to mobile device 105 (that is, employs one or more restrictions, modifies an implementation of one or more previously employed restrictions, removes one or more previously employed restrictions, and/or maintains one or more previously employed restrictions), preferably based on the second correlation (as computed at step 2524), substantially in the manner described above with respect to step 1842.
Turning now to FIG. 26, a flow diagram is described showing a routine 2600 that illustrates a broad aspect of a method for selectively configuring overt operation of a mobile device 105 in accordance with at least one embodiment disclosed herein.
At step 2602, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, determines a location of the mobile device and/or the current time/date. For example, using the GPS sensor of the mobile device, the location of the device can be determined. Specifically, in certain implementations, the location of the mobile device can be determined as being within a defined area or areas, such as within the grounds of a school, using techniques known as geofencing, as are known to those of ordinary skill in the art. In certain implementations, the presence of the device in an area of interest (e.g., the school) can be detected/determined by the device by sensing the presence of the wifi signals associated with the school's wifi transmitters and/or cell towers / base stations that are known to be near the area of interest. By way of further illustration, the current time date can be determined from one or more sources (e.g., the device's internal or remote clock/calendar, and/or a remote/third party source such as the GPS time, the cellular time, the wifi network time, etc. - i.e., sources that a user is potentially less likely to be able to tamper with).
At this juncture, it should be noted that in certain implementations, any or all of the following steps (2605-2642) can be employed based on the determination at step 2602. Thus, by way of example, based on a determination (at step 2602) that a mobile device is within a defined area (e.g., a school) at a certain time (e.g., during school hours), a restriction can be employed at the device, as described with reference to step 2605.
At step 2605, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, employs a first restriction at the mobile device. It should be understood that the first restriction preferably configures the mobile device to operate in an overt mode. It should be understood that the term "overt mode" as used herein is intended to encompass one or more modes and/or operational states of a mobile device that configure the device to operate in such a way such that operation of such a device by a user, on average, will be more conspicuous to others in the vicinity/presence of the mobile device than if the device were not configured to operate in such a way. An example of such an overt mode is a restriction that configures the device to project an audible 'chirp'
tone in response to every (or only certain) user input(s) received at the device, such as in the manner described in detail herein.
By way of further illustration, in certain implementations, an overt mode can include a restriction that restricts the mobile device to receive one or more commands/actions/events (such as the command to send a message or email or open a message, and email editor, or a browser) only through voice commands. It can be appreciated that in doing so a user of the device will only be capable of sending a message by saying (or shouting) 'send' in an audible tone, thereby resulting in overt operation of the device. It should be appreciated that such a restriction can be further employed together with/in parallel to other restrictions, such as restrictions requiring the user to perform one or more tactile gestures (e.g., holding a finger on a region of a touchscreen while saying 'send').
By way of further illustration, in certain implementations, an overt mode can include a restriction that restricts the mobile device to receive one or more commands/actions/events (such as the command to send a message or email or open a message, an email editor, or a browser) only based on a 'shake' gesture (that is, a gesture that can be identified as an ongoing significant deviation from the typical inputs provided by the accelerometer/gyroscope of a device). It can be appreciated that in doing so a user of the device will only be capable of sending a message by shaking his/her device, preferably vigorously, thereby resulting in overt operation of the device. In other implementations, similar gestures, such as large/broad movements of the mobile device, can similarly result in overt operation of the device. It should be appreciated that such restrictions can be further employed together with/in parallel to other restrictions, such as restrictions that entail the simultaneous projection of one or more chirps/signals, as described herein.
At step 2610, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, receives one or more first inputs, substantially in the manner describe in detail above with respect to step 1710. For example, such inputs can correspond to one or more user interactions with the device, such as the user typing an email, playing a game, etc.
At step 2620, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, processes the input(s). In doing so, a determination can be computed that reflects an operation state of the mobile device. By way of illustration, based on the location within and/or the time/date during which the device is operating (indicating whether the device is/is not within school grounds, and/or whether the device is/is not operating during school hours) in addition to the inputs received (reflecting a particular operation or action being performed at the mobile device), a determination can be computed reflecting the operation state of the mobile device (e.g., a video game is presently being played in a non-school location during school hours, and/or a text is being sent in a school location during recess hours).
At step 2642, processor 110 executing one or more of software modules 130, including, preferably, restriction module 171, adjusts an implementation of one or more restrictions at/in relation to mobile device 105 (that is, employs one or more restrictions, modifies an implementation of one or more
previously employed restrictions, removes one or more previously employed restrictions, and/or maintains one or more previously employed restrictions), preferably based on the determination.
It should be noted that in certain implementations, the transmission of signals to and/or the routing of signals received from all or certain mobile devices within a geo-area (which can be detected, for example, using the device's GPS and/or the wifi and/or the cellular tower/base station and/or location information provided from the cellular carrier such as DOA, AOA, signal strength) and/or in a certain date/time range, that are not chirp-enabled (i.e., not configured to chirp on user input) (and/or restricted such as in the manner described with reference to FIG. 26, such as where movement and/or and audible voice is required), is restricted. For example, a school's wifi network can be configured so that it only transmits to/from mobile devices that were known to the wifi network to be chirp-enabled (and/or restricted such as in the manner described with reference to FIG. 26, such as where movement and/or and audible voice is required),or which mobile devices were on a pre-defined list (e.g., using MAC addresses for teacher devices). In another example, one or more cellular carriers would only transmit (voice, data etc.) to mobile devices that are on a school's premises (e.g., within a geo-area) and in their cellular networks, that were known to the cellular network to be chirp-enabled (and/or restricted such as in the manner described with reference to FIG. 26, such as where movement and/or and audible voice is required) or which mobile devices were on a pre-defined list (e.g., MAC addresses or UDIDs for teacher devices). In both cases there can be exceptions for certain usage (e.g., emergency calls, emergency text- messages) whereby the aforementioned networks will allow such communications to pass through.
The following represents a logical flow that reflects the basic operations of various of the implementations disclosed herein, in a manner that can be appreciated by those of ordinary skill in the art.
If chirping application is installed on device
If during school hours
If (device sees school wifi || device GPS shows in geo-fenced area |( device sees certain cell towers)
Beep when user inputs
If mic hears beeps
Allow free use
Else
Restrict as per usage policy
Else if GPS shows outside geo-fenced area
Allow free use
Else if no GPS signal
Assume in geo-fenced area
Else
Allow free use
At this juncture, it should be noted in certain implementations, various aspects of the outputs/chirps projected by the mobile device can be determined/dictated based upon various determinations that can be computed in relation to such outputs/chirps and the device's usage. For example, it can be appreciated that a device that is being used actively and/or continuously by a user is relatively less likely to be operating in a manner that is improper. As such,, upon determining that a device is so operating, the device can be configured to chirp in a different manner (e.g., by adjusting the frequency and/or pattern and/or volume of the outputs/chirps).
At this juncture it should also be noted that the referenced restrictions (e.g., geographic area and/or date/time can be, and preferably are, established by a third party, such as a school administrator or parent. It should also be noted that the required geographic determinations can be achieved using GPS receiver 145C using standard geofencing approaches known to those of ordinary skill in the art. Additionally, in certain implementations, one or more third parties can optionally override various of the restrictions referenced herein. For example, in a scenario where one (or more) of the sensors at a mobile device is broken or malfunctioning, it can be appreciated that various authentication approaches may no longer be possible, As a result, one or more third parties (e.g., a parent, telecommunications provider, etc.) can override such restrictions, in order to account for the malfunctioning/broken sensor, and thus enable the user to use his/her device in an unrestricted manner.
It should be understood, with regard to any and all of the implementations described herein, that while various of the implementations have been described herein as being implemented by a mobile device (for example, employing a restriction at a mobile device), it should be understood that any and all such embodiments can be similarly implemented in relation to such a mobile device, such as, for example, in a scenario where such a restriction is initiated/employed by a third party device such as a central machine that is capable of communication with the mobile device. As such, all references provided herein that refer to a particular operation occurring at a mobile device (e.g., preventing a mobile device from a particular operation) should be understood to also encompass operations performed by an external/remote device which, in turn, can affect the operation of the mobile device (whether directly or indirectly), and all such implementations are equally within the scope of the methods and systems described herein.
Additionally, in certain implementations a communications provider (e.g., a cellular carrier) can optionally restrict the usage a device, such as the device operated by a driver of a moving vehicle. This can be achieved by determining if the device is in a moving vehicle and, if so, assuming that the device is a driver's (and restricting it accordingly), unless the device user has authenticated himself/herself as a passenger, as described herein.
In one implementation, a cellular carrier can determine whether the device is in a moving vehicle by analyzing successive location positions of the device (as can be determined by cellular networks), pursuant, among other things, to government regulations/guidelines that require such networks to be able to determine the location of a cellular device (such as in the case of an emergency), using such location positioning techniques known to those of ordinary skill in the art, including but not limited to methods for
locating the device such as angle of arrival (AOA), time difference of arrival (TDOA), signal strength (device or cell-tower) and others.
In another implementation, the cellular carrier/operator can receive location and/or speed information from the device itself, consisting of GPS information and/or information from the one or more of the device's sensors. For example, the cellular carrier can send requests to the device's SIM card to query the device's GPS and pass such information back to the carrier. In another example, the carrier can request information from a process running on the device which can obtain such information from the GPS and/or the device's sensors. If no such process is running on the device (and/or if such a process cannot be initialized), the carrier can identify such device to be a driver device and can further apply the associated restrictions, as described herein. The effectiveness of this method can be increased if the process and/or the information coming from the process is authenticated and/or verified, so as to prevent the transmission of erroneous information that might otherwise trick a cellular carrier into thinking that the device is not in a moving vehicle. Such authentication and/or verification can be done in several ways, for example: (a) The GPS values sent from the device can be compared with those obtained directly by the carrier network. If the carrier network is clearly showing that the device is moving, yet the data the device is passing to the carrier shows otherwise, this can indicate a security problem; (b) the device can pass an authentication code to the carrier in a manner known to those of ordinary skill in the art.
Additionally, in order to more accurately and/or more quickly and/or more efficiently determine if the device is in a moving vehicle, the carrier can combine location/speed information sourced from the carrier network with the information sourced from the from the device.
Upon receipt of such device location/speed information, the carrier can determine whether the device is in a moving vehicle. In one implementation, if the speed of the device is greater than a certain threshold speed, it is determined to be in a moving vehicle,
Upon determining that a device is in a moving vehicle and until such time that it is determined that such device is no longer in a moving vehicle, the carrier can restrict (partially or completely) the information that is sent to/from such device unless the device's user has authenticated the device as a passenger device using, among others, any one of the passenger authentication methods described herein. The effectiveness of this method can be increased by ensuring that any passenger authentication is trustworthy, so as to prevent the transmission of erroneous information in order to trick a cellular carrier into thinking that the device is being used by a passenger, This can be done, for example, by authenticating the passenger authentication information, using methods known to those of ordinary skill in the art.
Additionally, the cellular carrier can strengthen any such restrictions by instructing the device's SIM and/or code running on the device itself to further restrict the device (e.g., preventing wi-fi communication).
Moreover, various security measures can be employed to ensure that the device user does not trick the cellular carrier into providing data to the device while the user is the driver. As example, a device that has been 'rooted' or 'jail-broken' may not be allowed to authenticate as a passenger. As an
additional example, various security options for centrally (e.g., from a cellular data center) authenticating application data sent from a mobile device can be employed, such as, (a) creating non-repeating data by incorporating in-data timestamps to make it harder to 'replay' data; (b) using a digital signature to sign data on the device before it is sent to the carrier, where a one-time key generation time process can be employed to make this method even harder to hack/override; (c) performing such authentication at the operating system level (e.g., within the kernel) to make it harder to replace the trusted data with altered data; and/or (d) performing the authentication at the hardware level. These techniques and similar ones are known to those of ordinary skill in the art of computer security and cryptography.
It should be noted that in some methods of passenger authentication (for example, passenger authentication methods that incorporate a repeated pass-phrase, pass-code and/or pass-action), the effectiveness of such methods can be increased by incorporating a protocol that further enhances security, by (a) running at least one component process of the passenger authenticating process on the device in a manner that allows such component process to be authenticated against a central server using a pre- assigned private key that signs OS information about such components and/or other components by using a signed kernel module; (b) if the component process authentication succeeds, by having a central server send a phrase, code and/or action to the passenger authenticating process on the device which, in turn, displays such phrase, code and/or action to the user; and (c) sending the phrase, code and/or action input/performed by the user back to a central server, whereupon the central server only authenticates the device user as a passenger if the phrase, code and/or actions match those that were sent and are performed in a timely manner.
At this juncture, it should be noted that although much of the foregoing description has been directed to systems and methods for determining user roles and/or devices usages within the context of vehicular travel, the systems and methods disclosed herein can be similarly deployed and/or implemented in scenarios, situations, and settings far beyond the referenced scenarios. It can be readily appreciated that the user-role determination system 100 can be effectively employed in practically any scenario where the determination and/or identification of a user or usage of a mobile device is of value, such as in the context of exercising or game playing. It should be further understood that any such implementation and/or deployment is within the scope of the systems and methods described herein.
It is to be understood that like numerals in the drawings represent like elements through the several figures, and that not all components and/or steps described and illustrated with reference to the figures are required for all embodiments or arrangements. It should also be understood that the embodiments and/or arrangements of the systems and methods disclosed herein can be incorporated as a software algorithm, application, program, module, or code residing in hardware, firmware and/or on a computer useable medium (including software modules and browser plug-ins) that can be executed in a processor of a computer system or a computing device to configure the processor and/or other elements to perform the functions and/or operations described below. It should be appreciated that according to at least one embodiment, one or more computer programs or applications that when executed perform methods of the present invention need not reside on a single computer or processor, but can be distributed
in a modular fashion amongst a number of different computers or processors to implement various aspects of the systems and methods disclosed herein.
Thus, illustrative embodiments and arrangements of the present systems and methods provide a computer implemented method, computer system, and computer program product for selectively restricting a mobile device. The flowchart and block diagrams in the figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods and computer program products according to various embodiments and arrangements. In this regard, each block in the flowchart or block diagrams can represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the invention. As used herein, the singular forms "a", "an" and "the" are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms "comprises" and/or "comprising", when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
It should be noted that use of ordinal terms such as "first," "second," "third," etc., in the claims to modify a claim element does not by itself connote any priority, precedence, or order of one claim element over another or the temporal order in which acts of a method are performed, but are used merely as labels to distinguish one claim element having a certain name from another element having a same name (but for use of the ordinal term) to distinguish the claim elements.
Also, the phraseology and terminology used herein is for the purpose of description and should not be regarded as limiting. The use of "including," "comprising," or "having," "containing," "involving," and variations thereof herein, is meant to encompass the items listed thereafter and equivalents thereof as well as additional items.
The subject matter described above is provided by way of illustration only and should not be construed as limiting. Various modifications and changes can be made to the subject matter described herein without following the example embodiments and applications illustrated and described, and without departing from the true spirit and scope of the present invention, which is set forth in the following claims.