US20190122143A1 - Cognitive-based passenger selection - Google Patents
Cognitive-based passenger selection Download PDFInfo
- Publication number
- US20190122143A1 US20190122143A1 US15/791,961 US201715791961A US2019122143A1 US 20190122143 A1 US20190122143 A1 US 20190122143A1 US 201715791961 A US201715791961 A US 201715791961A US 2019122143 A1 US2019122143 A1 US 2019122143A1
- Authority
- US
- United States
- Prior art keywords
- passenger
- physical
- seat
- physical attributes
- score
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Abandoned
Links
Images
Classifications
-
- G06N99/005—
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06N—COMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
- G06N20/00—Machine learning
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q10/00—Administration; Management
- G06Q10/02—Reservations, e.g. for tickets, services or events
Definitions
- the present invention relates to computer software, and more specifically, to computer software which provides cognitive-based passenger selection for vehicles.
- Mass transit operators are constantly trying to improve safety measures and precautions used to ensure the safety of all people on board.
- limited attention has been given to programmatically allocating passengers to seats, especially seats that are associated with various restrictions, such as exit-row seats in an aircraft, train, or bus.
- users select these seats because of the extra leg room provided.
- many users select these seats even if they are unwilling and/or unable to perform the duties associated with the seats.
- mass transit employees may allocate passengers to seats before the vehicle departs. In such circumstances, the employees may not be able to determine whether a passenger is willing and/or able to perform the duties associated with the seats. As such, the safety of all persons on board may be at risk during an emergency situation.
- a method comprises receiving a plurality of rules associated with a first seat in a mass-transit vehicle, determining a plurality of physical attributes for a first passenger, of a plurality of passengers, based on data describing the first passenger received from a plurality of data sources, determining a plurality of non-physical attributes for the first passenger based on the received data describing the first passenger, determining that at least one of the plurality of physical attributes and the plurality of non-physical attributes of the first passenger satisfy each rule in the set of rules associated with the first seat, computing, based on a machine learning (ML) model a score for the first passenger, determining that the score exceeds a threshold score associated with the first seat, and allocating the first passenger to the first seat in the mass-transit vehicle.
- ML machine learning
- a system comprises a processor and a memory storing instructions, which when executed by the processor, performs an operation comprising receiving a plurality of rules associated with a first seat in a mass-transit vehicle, determining a plurality of physical attributes for a first passenger, of a plurality of passengers, based on data describing the first passenger received from a plurality of data sources, determining a plurality of non-physical attributes for the first passenger based on the received data describing the first passenger, determining that at least one of the plurality of physical attributes and the plurality of non-physical attributes of the first passenger satisfy each rule in the set of rules associated with the first seat, computing, based on a machine learning (ML) model a score for the first passenger, determining that the score exceeds a threshold score associated with the first seat, and allocating the first passenger to the first seat in the mass-transit vehicle.
- ML machine learning
- a non-transitory computer-readable storage medium has computer-readable program code embodied therewith, the computer-readable program code executable by a processor to perform an operation comprising receiving a plurality of rules associated with a first seat in a mass-transit vehicle, determining a plurality of physical attributes for a first passenger, of a plurality of passengers, based on data describing the first passenger received from a plurality of data sources, determining a plurality of non-physical attributes for the first passenger based on the received data describing the first passenger, determining that at least one of the plurality of physical attributes and the plurality of non-physical attributes of the first passenger satisfy each rule in the set of rules associated with the first seat, computing, based on a machine learning (ML) model a score for the first passenger, determining that the score exceeds a threshold score associated with the first seat, and allocating the first passenger to the first seat in the mass-transit vehicle.
- ML machine learning
- FIG. 1 illustrates an example system architecture which provides cognitive-based passenger selection for vehicles, according to one embodiment.
- FIG. 2 is a schematic illustrating an example cognitive-based selection of passengers, according to one embodiment.
- FIG. 3 is a flow chart illustrating an example method to provide cognitive-based passenger selection for vehicles, according to one embodiment.
- FIG. 4 is a flow chart illustrating an example method to determine physical attributes of passengers, according to one embodiment.
- FIG. 5 is a flow chart illustrating an example method to determine non-physical attributes of passengers, according to one embodiment.
- FIG. 6 is a flow chart illustrating an example method to allocate passengers to seats in a vehicle based on ordered list of candidate passengers, according to one embodiment.
- FIG. 7 illustrates an example system which provides cognitive-based passenger selection for vehicles, according to one embodiment.
- Embodiments disclosed herein leverage cognitive computing to intelligently allocate passengers to seats in a vehicle in accordance with predefined rules associated with the seats.
- the attributes may include, without limitation, behavioral, cognitive, mental, emotional, personal, and physical attributes.
- Embodiments disclosed herein leverage the identified attributes to generate an allocation of passengers to seats that ensures the rules associated with each seat are satisfied by each user allocated to the seat. For example, a person may be physically fit, but unable to act in stressful situations due to fear of heights. Therefore, embodiments disclosed herein would refrain from assigning the person to an exit row seat in an aircraft. Instead, embodiments disclosed herein would attempt to identify persons who are physically, mentally, and emotionally able to sit in the exit row seat in the aircraft.
- FIG. 1 illustrates an example system architecture 100 which provides cognitive-based passenger selection for vehicles, according to one embodiment.
- the system 100 includes a server 101 , one or more inventory sources 102 , a plurality of services 103 , and a plurality of data sources 104 communicably coupled via a network 130 .
- the server 101 includes an allocation engine 105 , and data stores of machine learning (ML) models 106 , rules 107 , allocation data 108 , and training data 109 .
- the allocation engine 105 is configured to intelligently allocate passengers to seats in vehicles based on programmatically determined attributes of the passengers and one or more rules in the rules 107 applicable to each seat in a given vehicle.
- ML machine learning
- the passenger attributes include, without limitation, physical attributes and non-physical attributes, such as mental attributes, emotional attributes, personality traits, preferences, and the like.
- the vehicles include any type of passenger vehicle, such as airplanes, trains, and buses. Although airplanes, trains, and/or buses are used as reference examples herein, the techniques of the disclosure are applicable to any type of mass transit vehicle.
- the rules 107 are representative of any type of rule, such as rules specifying required physical attributes of a passenger to sit in a given seat in a vehicle, such as minimum and/or maximum passenger height and/or weight, passenger ability to lift a minimum amount of weight, minimum muscle mass of a passenger, no current injuries, etc.
- the rules 107 further include rules specifying required mental attributes, emotional attributes, personality traits, and other non-physical attributes (e.g., age) required to sit in a given seat in a vehicle.
- a rule in the rules 107 may specify that passengers with fear of heights cannot sit in an exit-row seat in an aircraft.
- a rule in the rules 107 may specify that passengers must be able to perform tasks in emergency situations.
- the rules 107 include rules defined by law, as well as rules defined by a system administrator (e.g., the operator of an airline, train, etc.) to enhance passenger safety.
- the allocation engine 105 generates the ML models 106 during a training session based on the training data 109 .
- the training data 109 includes labeled input that allows the allocation engine 105 to compute a desired outcome.
- the training data 109 may include a set of input parameters related to different types of passenger attributes and rules 107 associated with a plurality of different types of seats in different types of vehicles.
- the training data 109 may further specify whether one or more passenger attributes would satisfy one or more rules 107 for a given seat in a given type of vehicle. Therefore, as part of the training session, the allocation engine 105 generates the ML models 106 that specify features and associated weights.
- the allocation engine 105 then uses the ML models 106 to allocate passengers to seats in vehicles.
- the allocation engine 105 may determine that a range of body mass index (BMI) values is correlated with passengers who satisfy the rules 107 for a seat in a vehicle. In such an example, the allocation engine 105 generates an ML model 106 which specifies a greater weight to passengers having a BMI in the determined range of BMI values. As another example, the allocation engine 105 may determine that passengers who engage in action sports (e.g., skydiving) are correlated with passengers who satisfy the rules 107 for a seat in a vehicle. In such an example, the allocation engine 105 generates an ML model 106 which specifies a greater weight to those passengers who engage in action sports. In both examples, doing so allows the allocation engine 105 to allocate passengers to seats in a manner which satisfies the rules 107 more to a degree that is greater than allocating passengers to seats without using the ML models 106 .
- BMI body mass index
- the allocation engine 105 may receive requests to allocate passengers to seats, and generate allocations which are stored in the allocation data 108 .
- the allocation engine 105 may receive a request from an airline, and receive inventory data 110 from the inventory source 102 for the airline.
- the inventory sources 102 are representative of mass transit data systems, such as airline data systems, train data systems, railroad data systems, etc.
- the inventory data 110 specifies passengers who have tickets for a given trip in a vehicle, the available seats in the vehicle, and one or more attributes for each seat in the vehicle.
- the attributes for the seat may include any associated rules for the seat as well as a priority for the seat.
- the seat priority may reflect a relative level of importance allocating passengers to the seats who meet predefined requirements in order to improve safety for the passengers in the vehicle.
- the inventory data 110 may further include user-specified data (e.g., information provided during the ticketing process), which may include any number and type of physical and non-physical attributes.
- the allocation engine 105 processes information regarding each passenger specified in the inventory data 110 . More specifically, the allocation engine 105 receives data describing each passenger from one or more data sources 104 .
- the data sources 104 are representative of any type of data source. As shown, the data sources 104 include, without limitation, social media data 113 , publication data 114 , and profiles 115 .
- the social media data 113 is representative of data from user accounts on social media platforms, where users may specify attributes as biographical information, friendships, relationships, and the like. Similarly, the social media data 113 is representative of photos, videos, text, and other types of content posted by the user on the social media platforms.
- the publication data 114 is representative of blogs, articles, and any other type of information published by the users on the Internet.
- the profiles 115 are representative of any type of user profile which stores data describing user attributes.
- a user may maintain a travel blog.
- the allocation engine 105 may receive the publication data 114 from the user's travel blog, and perform natural language processing on the text of the blog to extract different attributes of the user therefrom. For example, the allocation engine 105 may determine that the user enjoys to travel, and frequently engages in surfing and skiing. Similarly, the allocation engine 105 may determine that the user is in several groups related to travel and action sports on one or more social media platforms.
- the allocation engine 105 further leverages the services 103 , which are representative of any type of online service.
- the services 103 include, without limitation, the non-physical attribute service 111 and the physical attribute service 112 .
- the non-physical attribute service 111 is generally configured to discover information describing non-physical attributes of a person.
- the non-physical attributes include, without limitation, how the person acts, how the person thinks, emotions expressed by the person, mental health, preferences, likes, dislikes, personality traits, and the like.
- One example of a non-physical attribute service 111 is “Watson Personality Insights” by IBM Corporation of Armonk, N.Y.
- the physical attribute service 112 extracts physical attributes of a given person based on an analysis of one or more images of the person.
- the physical attribute service 112 may apply image analysis algorithms to detect attributes of the person(s) depicted in an image.
- the image analysis algorithms may include computer vision algorithms (e.g., to detect objects, features, or other physical attributes), facial recognition algorithms, and other image analysis routines. Doing so allows the physical attribute service 112 to determine an approximate, height, weight, BMI, amount of muscle mass, etc. of a person.
- the physical attribute service 112 may identify whether the person is depicted in images engaging in sports or other activities.
- the physical attribute service 112 may identify whether the person has limitations (e.g., is wearing a cast to heal a broken bone).
- One example of a physical attribute service 112 is “Watson Visual Recognition” by IBM.
- the allocation engine 105 may make an application programming interface (API) call to the non-physical attribute service 111 , which specifies to extract non-physical attributes of the passenger (e.g., based on the data from the data sources 104 ).
- the allocation engine 105 makes an API call to the physical attribute service 112 specifying to extract physical attributes of each passenger based on the data from the data sources 104 .
- the allocation engine 105 uses the results provided by the non-physical attribute service 111 and the physical attribute service 112 to allocate passengers to seats.
- the allocation engine 105 may compute a score for the passenger (based on the ML models 106 ) which indicates the user should not be seated in an exit row seat of an aircraft.
- the allocation engine 105 may compute a score which indicates the user is able to sit in an exit row seat of an aircraft.
- the allocation engine 105 determines that an attribute of the person violates a rule in the rules 107 for a given seat, the allocation engine 105 refrains from allocating that person to the seat. For example, if a profile 115 specifies that the person's age is outside of a range of ages specified in the rules 107 for sitting in a given seat, the allocation engine 105 refrains from allocating the person to the seat. Similarly, if a person has a broken bone, a rule in the rules 107 may be violated for an exit row seat, and the allocation engine 105 would refrain from allocating the person to an exit row seat.
- the allocation engine 105 may be invoked at any time to refine the seat allocations in the allocation data 108 .
- the allocation engine 105 may initially allocate a person Y to an exit row seat. However, before the flight departs, the allocation engine 105 may reprocess the data of person Y, and determine that person Y published a blog post (after the allocation of person Y to the exit row seat) expressing a fear of flying. As such, the allocation engine 105 may remove person Y from the exit row seat, and select a more suitable person for the exit row seat.
- FIG. 2 is a schematic 200 illustrating an example cognitive-based selection of passengers, according to one embodiment.
- FIG. 2 depicts an example vehicle 201 that includes example seats 202 - 213 .
- the vehicle 201 may generally include any number of seats.
- seats 206 - 209 may be “exit row” seats that include one or more rules defined in the rules 107 .
- the rules 107 may specify rules related to physical attributes such as height, weight, lifting ability, BMI, etc.
- the rules 107 may further specify rules related to non-physical attributes, such as not being scared of heights, willingness (or ability) to assist others, good mental health, emotions that cannot be expressed (e.g., fear, hostility, etc.), and emotions that must be expressed (e.g., confidence, assertiveness, etc.).
- the rules 107 may further specify minimum score thresholds for sitting in a given seat.
- FIG. 2 further depicts example service results 220 - 223 returned by the services 111 , 112 for four example persons.
- the allocation engine 105 may make similar determinations based on the data received from the data sources 104 for a given person. Based on the service results 220 - 223 , the allocation engine 105 computes one or more scores for the respective person using the weights defined in the ML models 106 . For example, the allocation engine 105 has computed a score of 99 (on a scale of 0-100) for person A, based on the service results 220 specifying that person A is physically fit, authors an adventure sports blog, and is generally excited about travel.
- the allocation engine 105 has computed a score of 25 for person B based on the results 221 , which specify that person B is currently wearing a cast on their leg (which may violate a rule in the rules 107 ), is not physically fit, but enjoys flying and is willing to help others.
- the allocation engine 105 computes a score for each person, the allocation engine 105 generates a list that ranks each person based on the computed score, and allocates the people to the seats 202 - 213 based on the rankings.
- FIG. 2 depicts an example table of allocation data 108 , where the allocation engine 105 has allocated person A to seat 206 , person B to seat 211 , person C to seat 204 , and person D to seat 209 . Therefore, the allocation engine 105 allocates the people with the highest scores to the exit row seats 206 , 209 , while refraining from allocating people with lower scores to seats 207 - 208 .
- the allocation engine 105 may refrain from allocating the people with lower scores to seats 207 - 208 based on a determination that one of the rules 107 has been violated and/or based on a determination that the scores computed for persons B, C in results 221 , 222 fall below a threshold score for sitting in seats 206 - 209 .
- the seats 202 - 205 and 210 - 213 may have associated rules 107 and/or score thresholds.
- seat 204 may have additional leg room, and a rule 107 specifies that seat 202 should be allocated to users needing the additional leg room. Therefore, the allocation engine 105 determines, based on person B wearing a cast on their leg, that person B satisfies this rule, and allocates person B to seat 204 .
- FIG. 3 is a flow chart illustrating an example method 300 to provide cognitive-based passenger selection for vehicles, according to one embodiment.
- the method 300 begins at block 310 , where the allocation engine 105 is trained to produce the ML models 106 as described above.
- the allocation engine 105 receives inventory data 110 for a given vehicle as part of a request to generate an allocation of passengers to seats in the vehicle for a given trip (or plurality of trips) of the vehicle.
- the allocation engine 105 receives the passenger data for the vehicle, which may be specified in the inventory data 110 received at block 320 .
- the passenger data includes an indication of each passenger who currently holds a ticket to travel on the vehicle.
- the allocation engine 105 filters the passengers using a first set of rules in the rules 107 . For example, if a first passenger does not meet height requirements mandated by law for an exit row seat, the allocation engine 105 removes the first passenger from consideration for allocation to exit row seats.
- the allocation engine 105 determines the physical attributes of each remaining passenger that was not filtered at block 340 .
- the allocation engine 105 leverages the data sources 104 and the physical attribute service 112 to determine the physical attributes of a given passenger. For example, the allocation engine 105 may determine that a person has significant muscle mass, is generally physically fit, and meets all height and weight requirements for an exit row seat specified in the rules 107 . The allocation engine 105 may then compute a score for the user reflecting a high degree of suitability for allocating the person to an exit row seat on an aircraft.
- the allocation engine 105 may determine that a person has significant muscle mass, is generally physically fit, and meets all height and weight requirements for an exit row seat specified in the rules 107 .
- the allocation engine 105 may then compute a score for the user reflecting a high degree of suitability for allocating the person to an exit row seat on an aircraft.
- block 360 described in greater detail below with reference to FIG.
- the allocation engine 105 determines non-physical attributes of each remaining passenger that was not filtered at block 340 .
- the non-physical attributes include emotions, metal state, personality traits, preferences, and the like. For example, if the allocation engine 105 determines that a person engages in sky diving, parachuting, etc., the allocation engine 105 may determine that the user does not have a fear of heights, and computes a score reflecting a high degree of suitability for allocating the user to an exit row seat.
- the allocation engine 105 generates an ordered list of candidate passengers based on the determined attributes and/or the scores computed for each passenger. Generally, the allocation engine 105 orders the list based on one or more scores computed for each passenger. However, if the allocation engine 105 determines a passenger attribute violates a rule, the allocation engine 105 may place the passenger at the bottom of the list.
- the allocation engine 105 allocates passengers to seats based at least in part on the ordered list of passengers. The allocation engine 105 may store the results of the allocation in the allocation data 108 , which may then be transmitted to the requesting entity, or may otherwise be made available to the requesting entity.
- FIG. 4 is a flow chart illustrating an example method 400 corresponding to block 350 to determine physical attributes of passengers, according to one embodiment.
- the method 400 begins at block 410 , where the allocation engine 105 executes a loop including blocks 420 - 480 for each passenger that was not filtered at block 340 .
- the allocation engine 105 receives data from the data sources 104 for the current passenger, such as profile data from the profiles 115 , social media data 113 , and publication data 114 .
- the allocation engine 105 optionally extracts attributes from the data received at block 420 .
- the allocation engine 105 may apply natural language processing to blog posts generated by the current passenger to extract sentiment, emotions, preferences, and other attributes therefrom.
- the allocation 105 may determine that the blog posts indicate the passenger exercises multiple times per day, and is therefore likely physically fit.
- the allocation engine 105 may analyze images of the current passenger to determine the passenger is physically fit, images shared by the current passenger, and content “liked” by the passenger on social media platforms to extract attributes of the passenger therefrom.
- the allocation engine 105 makes an API call to the physical attribute service 112 .
- the API call may include an indication of the current passenger, such as the passenger's full name, a user account name for social media services, email addresses extracted from the profile 115 , and the like.
- the allocation engine 105 receives a result set from the physical attribute service 112 .
- the result set specifies one or more attributes determined based on analysis of images and/or other data describing the passenger. For example, the result set may specify physical height, weight, whether the passenger is physically fit, whether the passenger has significant muscle mass, and the like.
- the allocation engine 105 computes a physical attribute score for the user based on the weights specified in the ML models 106 .
- the allocation engine 105 removes the current passenger as a candidate for seating in a seat upon determining that at least one of the determined physical attributes of the passenger do not satisfy at least one rule for the seat in the rules 107 . For example, if the physical attribute score of the passenger does not exceed a minimum physical attribute score for a seat, the allocation engine 105 removes the current passenger from consideration for allocation for the seat.
- the allocation engine 105 determines whether more passengers remain. If more passengers remain, the method returns to block 410 . Otherwise, the method 400 ends.
- FIG. 5 is a flow chart illustrating an example method 500 corresponding to block 360 to determine non-physical attributes of passengers, according to one embodiment.
- the method 500 begins at block 510 , where the allocation engine 105 executes a loop including blocks 520 - 580 for each passenger that was not filtered at block 340 .
- the allocation engine 105 receives data from the data sources 104 for the current passenger, such as profile data from the profiles 115 , social media data 113 , and publication data 114 .
- the allocation engine 105 optionally extracts attributes from the data received at block 520 .
- the allocation engine 105 may apply natural language processing to social media posts generated by the current passenger to extract sentiment, emotions, preferences, and other attributes therefrom. For example, if the allocation engine 105 detects a fearful or negative sentiment relative to heights in the social media posts, the allocation engine 105 may determine that the user has a fear of flying.
- the allocation engine 105 makes an API call to the non-physical attribute service 111 .
- the API call may include an indication of the current passenger, such as the passenger's full name, a user account name for social media services, email addresses extracted from the profile 115 , and the like.
- the allocation engine 105 receives a result set from the non-physical attribute service 111 .
- the result set specifies one or more non-physical attributes of the passenger, such as mental state, willingness to help others, personality traits, fears, likes, dislikes, emotions, and the like.
- the allocation engine 105 computes a non-physical attribute score for the user based on the weights specified in the ML models 106 .
- the allocation engine 105 optionally computes a composite score based on the ML models 106 and the physical and non-physical attribute scores computed for the passenger at blocks 460 and 560 , respectively. Doing so allows the allocation engine 105 to consider both the physical and non-physical attributes of the passenger when allocating the passenger to a seat.
- the allocation engine 105 removes the current passenger as a candidate for seating in a seat upon determining that at least one of the determined physical attributes of the passenger do not satisfy at least one rule for the seat in the rules 107 .
- the allocation engine 105 may remove the passenger from consideration for allocation to a seat associated with the violated rule(s). For example, if the passenger expresses the emotions of fear, and a negative sentiment towards helping others, the allocation engine 105 may remove the passenger from consideration for allocation to a seat associated with the violated rule(s). As another example, if the non-physical attribute score does not exceed a minimum non-physical attribute score threshold, the allocation engine 105 may remove the passenger from consideration for allocation to a seat associated with the violated rule. Similarly, if the composite score does not exceed a minimum composite score threshold, the allocation engine 105 may remove the passenger from consideration for allocation to a seat associated with the violated rule. At block 590 , the allocation engine 105 determines whether more passengers remain. If more passengers remain, the method returns to block 510 . Otherwise, the method 500 ends.
- FIG. 6 is a flow chart illustrating an example method 600 corresponding to block 380 to allocate passengers to seats in a vehicle based on ordered list of candidate passengers, according to one embodiment.
- the method 600 begins at block 610 , where the allocation engine 105 generates an ordered list of seats based on the seat priority for each vehicle specified in the inventory data 110 .
- the ordered list of seats is received with the inventory data 110 .
- the allocation engine 105 executes a loop including blocks 630 - 670 for each seat in the ordered list.
- the allocation engine 105 determines the rules from the rules 107 that are applicable to the current seat.
- the current seat may be associated with rules that require the passenger to not be afraid of heights, express a positive sentiment towards helping others, required physical attributes, and the like.
- the allocation engine 105 receives the highest ranked passenger from the ordered list of passengers generated at block 370 .
- the allocation engine 105 allocates the highest ranked passenger to the current seat, e.g., by storing an indication of the allocation in the allocation data 108 .
- the allocation engine 105 removes the passenger allocated to the seat from the ordered list of passengers.
- the allocation engine 105 determines whether more seats remain. If more seats remain, the allocation engine 105 returns to block 670 . Otherwise, the method 600 ends.
- FIG. 7 illustrates an example system 700 which provides cognitive-based passenger selection for vehicles, according to one embodiment.
- the networked system 700 includes a server 101 .
- the server 101 may also be connected to other computers (e.g., the inventory sources 102 , the services 103 , and the data sources 104 ) via the network 130 .
- the network 130 may be a telecommunications network and/or a wide area network (WAN).
- the network 130 is the Internet.
- the server 101 generally includes a processor 704 which obtains instructions and data via a bus 720 from a memory 706 and/or a storage 708 .
- the server 101 may also include one or more network interface devices 718 , input devices 722 , and output devices 724 connected to the bus 720 .
- the server 101 is generally under the control of an operating system (not shown). Examples of operating systems include the UNIX operating system, versions of the Microsoft Windows operating system, and distributions of the Linux operating system. (UNIX is a registered trademark of The Open Group in the United States and other countries. Microsoft and Windows are trademarks of Microsoft Corporation in the United States, other countries, or both.
- the processor 704 is a programmable logic device that performs instruction, logic, and mathematical processing, and may be representative of one or more CPUs.
- the network interface device 718 may be any type of network communications device allowing the server 101 to communicate with other computers via the network 130 .
- the storage 708 is representative of hard-disk drives, solid state drives, flash memory devices, optical media and the like. Generally, the storage 708 stores application programs and data for use by the server 101 . In addition, the memory 706 and the storage 708 may be considered to include memory physically located elsewhere; for example, on another computer coupled to the server 101 via the bus 720 .
- the input device 722 may be any device for providing input to the server 101 .
- a keyboard and/or a mouse may be used.
- the input device 722 represents a wide variety of input devices, including keyboards, mice, controllers, and so on.
- the input device 722 may include a set of buttons, switches or other physical device mechanisms for controlling the server 101 .
- the output device 724 may include output devices such as monitors, touch screen displays, and so on.
- the memory 706 contains the allocation engine 105
- the storage 708 contains the ML models 106 , rules 107 , allocation data 108 , and training data 109 , each described in greater detail above.
- the system 700 implements all systems, methods, and functionality described above with reference to FIGS. 1-6 .
- embodiments disclosed herein provide techniques to intelligently allocate passengers to seats in mass-transit vehicles. By identifying those persons most willing and able to sit in a particular seat, the safety of all passengers is improved. Furthermore, performance of the server 101 is improved, as the allocation engine 105 is able to generate more accurate allocations that need not be revised. Doing so saves computing resources of the server 101 .
- aspects of the present invention may 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 aspects that may all generally be referred to herein as a “circuit,” “module” or “system.”
- the present invention may be a system, a method, and/or a computer program product.
- the computer program product may include a computer readable storage medium (or media) having computer readable program instructions thereon for causing a processor to carry out aspects of the present invention.
- the computer readable storage medium can be a tangible device that can retain and store instructions for use by an instruction execution device.
- the computer readable storage medium may be, for example, but is not limited to, an electronic storage device, a magnetic storage device, an optical storage device, an electromagnetic storage device, a semiconductor storage device, or any suitable combination of the foregoing.
- a non-exhaustive list of more specific examples of the computer readable storage medium includes the following: a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), a static random access memory (SRAM), a portable compact disc read-only memory (CD-ROM), a digital versatile disk (DVD), a memory stick, a floppy disk, a mechanically encoded device such as punch-cards or raised structures in a groove having instructions recorded thereon, and any suitable combination of the foregoing.
- RAM random access memory
- ROM read-only memory
- EPROM or Flash memory erasable programmable read-only memory
- SRAM static random access memory
- CD-ROM compact disc read-only memory
- DVD digital versatile disk
- memory stick a floppy disk
- a mechanically encoded device such as punch-cards or raised structures in a groove having instructions recorded thereon
- a computer readable storage medium is not to be construed as being transitory signals per se, such as radio waves or other freely propagating electromagnetic waves, electromagnetic waves propagating through a waveguide or other transmission media (e.g., light pulses passing through a fiber-optic cable), or electrical signals transmitted through a wire.
- Computer readable program instructions described herein can be downloaded to respective computing/processing devices from a computer readable storage medium or to an external computer or external storage device via a network, for example, the Internet, a local area network, a wide area network and/or a wireless network.
- the network may comprise copper transmission cables, optical transmission fibers, wireless transmission, routers, firewalls, switches, gateway computers and/or edge servers.
- a network adapter card or network interface in each computing/processing device receives computer readable program instructions from the network and forwards the computer readable program instructions for storage in a computer readable storage medium within the respective computing/processing device.
- Computer readable program instructions for carrying out operations of the present invention may be assembler instructions, instruction-set-architecture (ISA) instructions, machine instructions, machine dependent instructions, microcode, firmware instructions, state-setting data, or either source code or object code written in any combination of one or more programming languages, including an object oriented programming language such as Smalltalk, C++ or the like, and conventional procedural programming languages, such as the “C” programming language or similar programming languages.
- the computer readable program instructions may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server.
- the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
- electronic circuitry including, for example, programmable logic circuitry, field-programmable gate arrays (FPGA), or programmable logic arrays (PLA) may execute the computer readable program instructions by utilizing state information of the computer readable program instructions to personalize the electronic circuitry, in order to perform aspects of the present invention.
- These computer readable program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
- These computer readable program instructions may also be stored in a computer readable storage medium that can direct a computer, a programmable data processing apparatus, and/or other devices to function in a particular manner, such that the computer readable storage medium having instructions stored therein comprises an article of manufacture including instructions which implement aspects of the function/act specified in the flowchart and/or block diagram block or blocks.
- the computer readable program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other device to cause a series of operational steps to be performed on the computer, other programmable apparatus or other device to produce a computer implemented process, such that the instructions which execute on the computer, other programmable apparatus, or other device implement the functions/acts specified in the flowchart and/or block diagram block or blocks.
- each block in the flowchart or block diagrams may represent a module, segment, or portion of instructions, which comprises one or more executable instructions for implementing the specified logical function(s).
- the functions noted in the block may occur out of the order noted in the figures.
- 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.
- Embodiments of the invention may be provided to end users through a cloud computing infrastructure.
- Cloud computing generally refers to the provision of scalable computing resources as a service over a network.
- Cloud computing may be defined as a computing capability that provides an abstraction between the computing resource and its underlying technical architecture (e.g., servers, storage, networks), enabling convenient, on-demand network access to a shared pool of configurable computing resources that can be rapidly provisioned and released with minimal management effort or service provider interaction.
- cloud computing allows a user to access virtual computing resources (e.g., storage, data, applications, and even complete virtualized computing systems) in “the cloud,” without regard for the underlying physical systems (or locations of those systems) used to provide the computing resources.
- cloud computing resources are provided to a user on a pay-per-use basis, where users are charged only for the computing resources actually used (e.g. an amount of storage space consumed by a user or a number of virtualized systems instantiated by the user).
- a user can access any of the resources that reside in the cloud at any time, and from anywhere across the Internet.
- a user may access applications or related data available in the cloud.
- the allocation engine 105 could execute on a computing system in the cloud. In such a case, the allocation engine 105 may store the seat allocations in the allocation data 108 for a plurality of clients at a storage location in the cloud. Doing so allows a user to access this information from any computing system attached to a network connected to the cloud (e.g., the Internet).
Landscapes
- Engineering & Computer Science (AREA)
- Business, Economics & Management (AREA)
- Theoretical Computer Science (AREA)
- Tourism & Hospitality (AREA)
- General Physics & Mathematics (AREA)
- Physics & Mathematics (AREA)
- Software Systems (AREA)
- Economics (AREA)
- General Business, Economics & Management (AREA)
- Strategic Management (AREA)
- Quality & Reliability (AREA)
- Operations Research (AREA)
- Marketing (AREA)
- Human Resources & Organizations (AREA)
- Development Economics (AREA)
- Entrepreneurship & Innovation (AREA)
- Mathematical Physics (AREA)
- Artificial Intelligence (AREA)
- Computer Vision & Pattern Recognition (AREA)
- Data Mining & Analysis (AREA)
- Medical Informatics (AREA)
- Evolutionary Computation (AREA)
- General Engineering & Computer Science (AREA)
- Computing Systems (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
Abstract
Description
- The present invention relates to computer software, and more specifically, to computer software which provides cognitive-based passenger selection for vehicles.
- Mass transit operators are constantly trying to improve safety measures and precautions used to ensure the safety of all people on board. However, limited attention has been given to programmatically allocating passengers to seats, especially seats that are associated with various restrictions, such as exit-row seats in an aircraft, train, or bus. Often, users select these seats because of the extra leg room provided. However, many users select these seats even if they are unwilling and/or unable to perform the duties associated with the seats. In some circumstances, mass transit employees may allocate passengers to seats before the vehicle departs. In such circumstances, the employees may not be able to determine whether a passenger is willing and/or able to perform the duties associated with the seats. As such, the safety of all persons on board may be at risk during an emergency situation.
- In one embodiment, a method comprises receiving a plurality of rules associated with a first seat in a mass-transit vehicle, determining a plurality of physical attributes for a first passenger, of a plurality of passengers, based on data describing the first passenger received from a plurality of data sources, determining a plurality of non-physical attributes for the first passenger based on the received data describing the first passenger, determining that at least one of the plurality of physical attributes and the plurality of non-physical attributes of the first passenger satisfy each rule in the set of rules associated with the first seat, computing, based on a machine learning (ML) model a score for the first passenger, determining that the score exceeds a threshold score associated with the first seat, and allocating the first passenger to the first seat in the mass-transit vehicle.
- In another embodiment, a system comprises a processor and a memory storing instructions, which when executed by the processor, performs an operation comprising receiving a plurality of rules associated with a first seat in a mass-transit vehicle, determining a plurality of physical attributes for a first passenger, of a plurality of passengers, based on data describing the first passenger received from a plurality of data sources, determining a plurality of non-physical attributes for the first passenger based on the received data describing the first passenger, determining that at least one of the plurality of physical attributes and the plurality of non-physical attributes of the first passenger satisfy each rule in the set of rules associated with the first seat, computing, based on a machine learning (ML) model a score for the first passenger, determining that the score exceeds a threshold score associated with the first seat, and allocating the first passenger to the first seat in the mass-transit vehicle.
- In another embodiment, a non-transitory computer-readable storage medium has computer-readable program code embodied therewith, the computer-readable program code executable by a processor to perform an operation comprising receiving a plurality of rules associated with a first seat in a mass-transit vehicle, determining a plurality of physical attributes for a first passenger, of a plurality of passengers, based on data describing the first passenger received from a plurality of data sources, determining a plurality of non-physical attributes for the first passenger based on the received data describing the first passenger, determining that at least one of the plurality of physical attributes and the plurality of non-physical attributes of the first passenger satisfy each rule in the set of rules associated with the first seat, computing, based on a machine learning (ML) model a score for the first passenger, determining that the score exceeds a threshold score associated with the first seat, and allocating the first passenger to the first seat in the mass-transit vehicle.
-
FIG. 1 illustrates an example system architecture which provides cognitive-based passenger selection for vehicles, according to one embodiment. -
FIG. 2 is a schematic illustrating an example cognitive-based selection of passengers, according to one embodiment. -
FIG. 3 is a flow chart illustrating an example method to provide cognitive-based passenger selection for vehicles, according to one embodiment. -
FIG. 4 is a flow chart illustrating an example method to determine physical attributes of passengers, according to one embodiment. -
FIG. 5 is a flow chart illustrating an example method to determine non-physical attributes of passengers, according to one embodiment. -
FIG. 6 is a flow chart illustrating an example method to allocate passengers to seats in a vehicle based on ordered list of candidate passengers, according to one embodiment. -
FIG. 7 illustrates an example system which provides cognitive-based passenger selection for vehicles, according to one embodiment. - Embodiments disclosed herein leverage cognitive computing to intelligently allocate passengers to seats in a vehicle in accordance with predefined rules associated with the seats. Generally, embodiments disclosed herein identify different physical and non-physical attributes of each passenger. The attributes may include, without limitation, behavioral, cognitive, mental, emotional, personal, and physical attributes. Embodiments disclosed herein leverage the identified attributes to generate an allocation of passengers to seats that ensures the rules associated with each seat are satisfied by each user allocated to the seat. For example, a person may be physically fit, but unable to act in stressful situations due to fear of heights. Therefore, embodiments disclosed herein would refrain from assigning the person to an exit row seat in an aircraft. Instead, embodiments disclosed herein would attempt to identify persons who are physically, mentally, and emotionally able to sit in the exit row seat in the aircraft.
-
FIG. 1 illustrates anexample system architecture 100 which provides cognitive-based passenger selection for vehicles, according to one embodiment. As shown, thesystem 100 includes aserver 101, one ormore inventory sources 102, a plurality ofservices 103, and a plurality ofdata sources 104 communicably coupled via anetwork 130. Theserver 101 includes anallocation engine 105, and data stores of machine learning (ML)models 106,rules 107,allocation data 108, andtraining data 109. Theallocation engine 105 is configured to intelligently allocate passengers to seats in vehicles based on programmatically determined attributes of the passengers and one or more rules in therules 107 applicable to each seat in a given vehicle. The passenger attributes include, without limitation, physical attributes and non-physical attributes, such as mental attributes, emotional attributes, personality traits, preferences, and the like. The vehicles include any type of passenger vehicle, such as airplanes, trains, and buses. Although airplanes, trains, and/or buses are used as reference examples herein, the techniques of the disclosure are applicable to any type of mass transit vehicle. - The
rules 107 are representative of any type of rule, such as rules specifying required physical attributes of a passenger to sit in a given seat in a vehicle, such as minimum and/or maximum passenger height and/or weight, passenger ability to lift a minimum amount of weight, minimum muscle mass of a passenger, no current injuries, etc. Therules 107 further include rules specifying required mental attributes, emotional attributes, personality traits, and other non-physical attributes (e.g., age) required to sit in a given seat in a vehicle. For example, a rule in therules 107 may specify that passengers with fear of heights cannot sit in an exit-row seat in an aircraft. As another example, a rule in therules 107 may specify that passengers must be able to perform tasks in emergency situations. Generally, therules 107 include rules defined by law, as well as rules defined by a system administrator (e.g., the operator of an airline, train, etc.) to enhance passenger safety. - The
allocation engine 105 generates the MLmodels 106 during a training session based on thetraining data 109. Thetraining data 109 includes labeled input that allows theallocation engine 105 to compute a desired outcome. For example, thetraining data 109 may include a set of input parameters related to different types of passenger attributes andrules 107 associated with a plurality of different types of seats in different types of vehicles. Thetraining data 109 may further specify whether one or more passenger attributes would satisfy one ormore rules 107 for a given seat in a given type of vehicle. Therefore, as part of the training session, theallocation engine 105 generates theML models 106 that specify features and associated weights. Theallocation engine 105 then uses the MLmodels 106 to allocate passengers to seats in vehicles. For example, during training, theallocation engine 105 may determine that a range of body mass index (BMI) values is correlated with passengers who satisfy therules 107 for a seat in a vehicle. In such an example, theallocation engine 105 generates anML model 106 which specifies a greater weight to passengers having a BMI in the determined range of BMI values. As another example, theallocation engine 105 may determine that passengers who engage in action sports (e.g., skydiving) are correlated with passengers who satisfy therules 107 for a seat in a vehicle. In such an example, theallocation engine 105 generates an MLmodel 106 which specifies a greater weight to those passengers who engage in action sports. In both examples, doing so allows theallocation engine 105 to allocate passengers to seats in a manner which satisfies therules 107 more to a degree that is greater than allocating passengers to seats without using theML models 106. - Once trained, the
allocation engine 105 may receive requests to allocate passengers to seats, and generate allocations which are stored in theallocation data 108. For example, theallocation engine 105 may receive a request from an airline, and receiveinventory data 110 from theinventory source 102 for the airline. Theinventory sources 102 are representative of mass transit data systems, such as airline data systems, train data systems, railroad data systems, etc. Theinventory data 110 specifies passengers who have tickets for a given trip in a vehicle, the available seats in the vehicle, and one or more attributes for each seat in the vehicle. The attributes for the seat may include any associated rules for the seat as well as a priority for the seat. The seat priority may reflect a relative level of importance allocating passengers to the seats who meet predefined requirements in order to improve safety for the passengers in the vehicle. Theinventory data 110 may further include user-specified data (e.g., information provided during the ticketing process), which may include any number and type of physical and non-physical attributes. - To generate the allocations of passengers to seats, the
allocation engine 105 processes information regarding each passenger specified in theinventory data 110. More specifically, theallocation engine 105 receives data describing each passenger from one ormore data sources 104. Thedata sources 104 are representative of any type of data source. As shown, thedata sources 104 include, without limitation,social media data 113,publication data 114, andprofiles 115. Thesocial media data 113 is representative of data from user accounts on social media platforms, where users may specify attributes as biographical information, friendships, relationships, and the like. Similarly, thesocial media data 113 is representative of photos, videos, text, and other types of content posted by the user on the social media platforms. Thepublication data 114 is representative of blogs, articles, and any other type of information published by the users on the Internet. Theprofiles 115 are representative of any type of user profile which stores data describing user attributes. - For example, a user may maintain a travel blog. The
allocation engine 105 may receive thepublication data 114 from the user's travel blog, and perform natural language processing on the text of the blog to extract different attributes of the user therefrom. For example, theallocation engine 105 may determine that the user enjoys to travel, and frequently engages in surfing and skiing. Similarly, theallocation engine 105 may determine that the user is in several groups related to travel and action sports on one or more social media platforms. - The
allocation engine 105 further leverages theservices 103, which are representative of any type of online service. As shown, theservices 103 include, without limitation, thenon-physical attribute service 111 and thephysical attribute service 112. Thenon-physical attribute service 111 is generally configured to discover information describing non-physical attributes of a person. The non-physical attributes include, without limitation, how the person acts, how the person thinks, emotions expressed by the person, mental health, preferences, likes, dislikes, personality traits, and the like. One example of anon-physical attribute service 111 is “Watson Personality Insights” by IBM Corporation of Armonk, N.Y. Thephysical attribute service 112 extracts physical attributes of a given person based on an analysis of one or more images of the person. For example, thephysical attribute service 112 may apply image analysis algorithms to detect attributes of the person(s) depicted in an image. The image analysis algorithms may include computer vision algorithms (e.g., to detect objects, features, or other physical attributes), facial recognition algorithms, and other image analysis routines. Doing so allows thephysical attribute service 112 to determine an approximate, height, weight, BMI, amount of muscle mass, etc. of a person. Similarly, thephysical attribute service 112 may identify whether the person is depicted in images engaging in sports or other activities. Furthermore, thephysical attribute service 112 may identify whether the person has limitations (e.g., is wearing a cast to heal a broken bone). One example of aphysical attribute service 112 is “Watson Visual Recognition” by IBM. - Therefore, for each passenger, the
allocation engine 105 may make an application programming interface (API) call to thenon-physical attribute service 111, which specifies to extract non-physical attributes of the passenger (e.g., based on the data from the data sources 104). Similarly, theallocation engine 105 makes an API call to thephysical attribute service 112 specifying to extract physical attributes of each passenger based on the data from the data sources 104. Theallocation engine 105 uses the results provided by thenon-physical attribute service 111 and thephysical attribute service 112 to allocate passengers to seats. For example, if thephysical attribute service 112 identifies an image of an example passenger in which the passenger is wearing a cast on their arm, theallocation engine 105 may compute a score for the passenger (based on the ML models 106) which indicates the user should not be seated in an exit row seat of an aircraft. As another example, if thenon-physical attribute service 111 returns an indication that a passenger enjoys to travel and is engaged in action sports, theallocation engine 105 may compute a score which indicates the user is able to sit in an exit row seat of an aircraft. - More generally, if at any point the
allocation engine 105 determines that an attribute of the person violates a rule in therules 107 for a given seat, theallocation engine 105 refrains from allocating that person to the seat. For example, if aprofile 115 specifies that the person's age is outside of a range of ages specified in therules 107 for sitting in a given seat, theallocation engine 105 refrains from allocating the person to the seat. Similarly, if a person has a broken bone, a rule in therules 107 may be violated for an exit row seat, and theallocation engine 105 would refrain from allocating the person to an exit row seat. - The
allocation engine 105 may be invoked at any time to refine the seat allocations in theallocation data 108. For example, theallocation engine 105 may initially allocate a person Y to an exit row seat. However, before the flight departs, theallocation engine 105 may reprocess the data of person Y, and determine that person Y published a blog post (after the allocation of person Y to the exit row seat) expressing a fear of flying. As such, theallocation engine 105 may remove person Y from the exit row seat, and select a more suitable person for the exit row seat. -
FIG. 2 is a schematic 200 illustrating an example cognitive-based selection of passengers, according to one embodiment. As shown,FIG. 2 depicts anexample vehicle 201 that includes example seats 202-213. Although thevehicle 201 is shown as including the seats 202-213, thevehicle 201 may generally include any number of seats. In the example depicted inFIG. 2 , seats 206-209 may be “exit row” seats that include one or more rules defined in therules 107. For example, therules 107 may specify rules related to physical attributes such as height, weight, lifting ability, BMI, etc. Therules 107 may further specify rules related to non-physical attributes, such as not being scared of heights, willingness (or ability) to assist others, good mental health, emotions that cannot be expressed (e.g., fear, hostility, etc.), and emotions that must be expressed (e.g., confidence, assertiveness, etc.). Therules 107 may further specify minimum score thresholds for sitting in a given seat. - As shown,
FIG. 2 further depicts example service results 220-223 returned by theservices allocation engine 105 may make similar determinations based on the data received from thedata sources 104 for a given person. Based on the service results 220-223, theallocation engine 105 computes one or more scores for the respective person using the weights defined in theML models 106. For example, theallocation engine 105 has computed a score of 99 (on a scale of 0-100) for person A, based on the service results 220 specifying that person A is physically fit, authors an adventure sports blog, and is generally excited about travel. As another example, theallocation engine 105 has computed a score of 25 for person B based on theresults 221, which specify that person B is currently wearing a cast on their leg (which may violate a rule in the rules 107), is not physically fit, but enjoys flying and is willing to help others. - Once the
allocation engine 105 computes a score for each person, theallocation engine 105 generates a list that ranks each person based on the computed score, and allocates the people to the seats 202-213 based on the rankings. For example, as shown,FIG. 2 depicts an example table ofallocation data 108, where theallocation engine 105 has allocated person A toseat 206, person B toseat 211, person C toseat 204, and person D toseat 209. Therefore, theallocation engine 105 allocates the people with the highest scores to theexit row seats allocation engine 105 may refrain from allocating the people with lower scores to seats 207-208 based on a determination that one of therules 107 has been violated and/or based on a determination that the scores computed for persons B, C inresults rules 107 and/or score thresholds. For example,seat 204 may have additional leg room, and arule 107 specifies thatseat 202 should be allocated to users needing the additional leg room. Therefore, theallocation engine 105 determines, based on person B wearing a cast on their leg, that person B satisfies this rule, and allocates person B toseat 204. -
FIG. 3 is a flow chart illustrating anexample method 300 to provide cognitive-based passenger selection for vehicles, according to one embodiment. As shown, themethod 300 begins atblock 310, where theallocation engine 105 is trained to produce theML models 106 as described above. Atblock 320, theallocation engine 105 receivesinventory data 110 for a given vehicle as part of a request to generate an allocation of passengers to seats in the vehicle for a given trip (or plurality of trips) of the vehicle. Atblock 330, theallocation engine 105 receives the passenger data for the vehicle, which may be specified in theinventory data 110 received atblock 320. Generally, the passenger data includes an indication of each passenger who currently holds a ticket to travel on the vehicle. Atblock 340, theallocation engine 105 filters the passengers using a first set of rules in therules 107. For example, if a first passenger does not meet height requirements mandated by law for an exit row seat, theallocation engine 105 removes the first passenger from consideration for allocation to exit row seats. - At
block 350, described in greater detail below with reference toFIG. 4 , theallocation engine 105 determines the physical attributes of each remaining passenger that was not filtered atblock 340. Generally, theallocation engine 105 leverages thedata sources 104 and thephysical attribute service 112 to determine the physical attributes of a given passenger. For example, theallocation engine 105 may determine that a person has significant muscle mass, is generally physically fit, and meets all height and weight requirements for an exit row seat specified in therules 107. Theallocation engine 105 may then compute a score for the user reflecting a high degree of suitability for allocating the person to an exit row seat on an aircraft. Atblock 360, described in greater detail below with reference toFIG. 5 , theallocation engine 105 determines non-physical attributes of each remaining passenger that was not filtered atblock 340. As previously stated, the non-physical attributes include emotions, metal state, personality traits, preferences, and the like. For example, if theallocation engine 105 determines that a person engages in sky diving, parachuting, etc., theallocation engine 105 may determine that the user does not have a fear of heights, and computes a score reflecting a high degree of suitability for allocating the user to an exit row seat. - At
block 370, theallocation engine 105 generates an ordered list of candidate passengers based on the determined attributes and/or the scores computed for each passenger. Generally, theallocation engine 105 orders the list based on one or more scores computed for each passenger. However, if theallocation engine 105 determines a passenger attribute violates a rule, theallocation engine 105 may place the passenger at the bottom of the list. At block 280, described in greater detail with reference toFIG. 7 , theallocation engine 105 allocates passengers to seats based at least in part on the ordered list of passengers. Theallocation engine 105 may store the results of the allocation in theallocation data 108, which may then be transmitted to the requesting entity, or may otherwise be made available to the requesting entity. -
FIG. 4 is a flow chart illustrating anexample method 400 corresponding to block 350 to determine physical attributes of passengers, according to one embodiment. As shown, themethod 400 begins atblock 410, where theallocation engine 105 executes a loop including blocks 420-480 for each passenger that was not filtered atblock 340. Atblock 420, theallocation engine 105 receives data from thedata sources 104 for the current passenger, such as profile data from theprofiles 115,social media data 113, andpublication data 114. Atblock 430, theallocation engine 105 optionally extracts attributes from the data received atblock 420. For example, theallocation engine 105 may apply natural language processing to blog posts generated by the current passenger to extract sentiment, emotions, preferences, and other attributes therefrom. In such an example, theallocation 105 may determine that the blog posts indicate the passenger exercises multiple times per day, and is therefore likely physically fit. As another example, theallocation engine 105 may analyze images of the current passenger to determine the passenger is physically fit, images shared by the current passenger, and content “liked” by the passenger on social media platforms to extract attributes of the passenger therefrom. - At
block 440, theallocation engine 105 makes an API call to thephysical attribute service 112. The API call may include an indication of the current passenger, such as the passenger's full name, a user account name for social media services, email addresses extracted from theprofile 115, and the like. Atblock 450, theallocation engine 105 receives a result set from thephysical attribute service 112. The result set specifies one or more attributes determined based on analysis of images and/or other data describing the passenger. For example, the result set may specify physical height, weight, whether the passenger is physically fit, whether the passenger has significant muscle mass, and the like. Atblock 460, theallocation engine 105 computes a physical attribute score for the user based on the weights specified in theML models 106. Atblock 470, theallocation engine 105 removes the current passenger as a candidate for seating in a seat upon determining that at least one of the determined physical attributes of the passenger do not satisfy at least one rule for the seat in therules 107. For example, if the physical attribute score of the passenger does not exceed a minimum physical attribute score for a seat, theallocation engine 105 removes the current passenger from consideration for allocation for the seat. Atblock 480, theallocation engine 105 determines whether more passengers remain. If more passengers remain, the method returns to block 410. Otherwise, themethod 400 ends. -
FIG. 5 is a flow chart illustrating anexample method 500 corresponding to block 360 to determine non-physical attributes of passengers, according to one embodiment. As shown, themethod 500 begins atblock 510, where theallocation engine 105 executes a loop including blocks 520-580 for each passenger that was not filtered atblock 340. Atblock 520, theallocation engine 105 receives data from thedata sources 104 for the current passenger, such as profile data from theprofiles 115,social media data 113, andpublication data 114. Atblock 530, theallocation engine 105 optionally extracts attributes from the data received atblock 520. For example, theallocation engine 105 may apply natural language processing to social media posts generated by the current passenger to extract sentiment, emotions, preferences, and other attributes therefrom. For example, if theallocation engine 105 detects a fearful or negative sentiment relative to heights in the social media posts, theallocation engine 105 may determine that the user has a fear of flying. - At
block 540, theallocation engine 105 makes an API call to thenon-physical attribute service 111. The API call may include an indication of the current passenger, such as the passenger's full name, a user account name for social media services, email addresses extracted from theprofile 115, and the like. Atblock 550, theallocation engine 105 receives a result set from thenon-physical attribute service 111. The result set specifies one or more non-physical attributes of the passenger, such as mental state, willingness to help others, personality traits, fears, likes, dislikes, emotions, and the like. Atblock 560, theallocation engine 105 computes a non-physical attribute score for the user based on the weights specified in theML models 106. Atblock 570, theallocation engine 105 optionally computes a composite score based on theML models 106 and the physical and non-physical attribute scores computed for the passenger atblocks allocation engine 105 to consider both the physical and non-physical attributes of the passenger when allocating the passenger to a seat. Atblock 580, theallocation engine 105 removes the current passenger as a candidate for seating in a seat upon determining that at least one of the determined physical attributes of the passenger do not satisfy at least one rule for the seat in therules 107. For example, if the passenger expresses the emotions of fear, and a negative sentiment towards helping others, theallocation engine 105 may remove the passenger from consideration for allocation to a seat associated with the violated rule(s). As another example, if the non-physical attribute score does not exceed a minimum non-physical attribute score threshold, theallocation engine 105 may remove the passenger from consideration for allocation to a seat associated with the violated rule. Similarly, if the composite score does not exceed a minimum composite score threshold, theallocation engine 105 may remove the passenger from consideration for allocation to a seat associated with the violated rule. Atblock 590, theallocation engine 105 determines whether more passengers remain. If more passengers remain, the method returns to block 510. Otherwise, themethod 500 ends. -
FIG. 6 is a flow chart illustrating anexample method 600 corresponding to block 380 to allocate passengers to seats in a vehicle based on ordered list of candidate passengers, according to one embodiment. As shown, themethod 600 begins atblock 610, where theallocation engine 105 generates an ordered list of seats based on the seat priority for each vehicle specified in theinventory data 110. In one embodiment, the ordered list of seats is received with theinventory data 110. Atblock 620, theallocation engine 105 executes a loop including blocks 630-670 for each seat in the ordered list. Atblock 630, theallocation engine 105 determines the rules from therules 107 that are applicable to the current seat. For example, the current seat may be associated with rules that require the passenger to not be afraid of heights, express a positive sentiment towards helping others, required physical attributes, and the like. - At
block 640, theallocation engine 105 receives the highest ranked passenger from the ordered list of passengers generated atblock 370. Atblock 650, theallocation engine 105 allocates the highest ranked passenger to the current seat, e.g., by storing an indication of the allocation in theallocation data 108. Atblock 660, theallocation engine 105 removes the passenger allocated to the seat from the ordered list of passengers. Atblock 670, theallocation engine 105 determines whether more seats remain. If more seats remain, theallocation engine 105 returns to block 670. Otherwise, themethod 600 ends. -
FIG. 7 illustrates anexample system 700 which provides cognitive-based passenger selection for vehicles, according to one embodiment. Thenetworked system 700 includes aserver 101. Theserver 101 may also be connected to other computers (e.g., theinventory sources 102, theservices 103, and the data sources 104) via thenetwork 130. In general, thenetwork 130 may be a telecommunications network and/or a wide area network (WAN). In a particular embodiment, thenetwork 130 is the Internet. - The
server 101 generally includes a processor 704 which obtains instructions and data via abus 720 from amemory 706 and/or astorage 708. Theserver 101 may also include one or morenetwork interface devices 718,input devices 722, andoutput devices 724 connected to thebus 720. Theserver 101 is generally under the control of an operating system (not shown). Examples of operating systems include the UNIX operating system, versions of the Microsoft Windows operating system, and distributions of the Linux operating system. (UNIX is a registered trademark of The Open Group in the United States and other countries. Microsoft and Windows are trademarks of Microsoft Corporation in the United States, other countries, or both. Linux is a registered trademark of Linus Torvalds in the United States, other countries, or both.) More generally, any operating system supporting the functions disclosed herein may be used. The processor 704 is a programmable logic device that performs instruction, logic, and mathematical processing, and may be representative of one or more CPUs. Thenetwork interface device 718 may be any type of network communications device allowing theserver 101 to communicate with other computers via thenetwork 130. - The
storage 708 is representative of hard-disk drives, solid state drives, flash memory devices, optical media and the like. Generally, thestorage 708 stores application programs and data for use by theserver 101. In addition, thememory 706 and thestorage 708 may be considered to include memory physically located elsewhere; for example, on another computer coupled to theserver 101 via thebus 720. - The
input device 722 may be any device for providing input to theserver 101. For example, a keyboard and/or a mouse may be used. Theinput device 722 represents a wide variety of input devices, including keyboards, mice, controllers, and so on. Furthermore, theinput device 722 may include a set of buttons, switches or other physical device mechanisms for controlling theserver 101. Theoutput device 724 may include output devices such as monitors, touch screen displays, and so on. - As shown, the
memory 706 contains theallocation engine 105, while thestorage 708 contains theML models 106,rules 107,allocation data 108, andtraining data 109, each described in greater detail above. Generally, thesystem 700 implements all systems, methods, and functionality described above with reference toFIGS. 1-6 . - Advantageously, embodiments disclosed herein provide techniques to intelligently allocate passengers to seats in mass-transit vehicles. By identifying those persons most willing and able to sit in a particular seat, the safety of all passengers is improved. Furthermore, performance of the
server 101 is improved, as theallocation engine 105 is able to generate more accurate allocations that need not be revised. Doing so saves computing resources of theserver 101. - The descriptions of the various embodiments of the present invention have been presented for purposes of illustration, but are not intended to be exhaustive or limited to the embodiments disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the described embodiments. The terminology used herein was chosen to best explain the principles of the embodiments, the practical application or technical improvement over technologies found in the marketplace, or to enable others of ordinary skill in the art to understand the embodiments disclosed herein.
- In the foregoing, reference is made to embodiments presented in this disclosure. However, the scope of the present disclosure is not limited to specific described embodiments. Instead, any combination of the recited features and elements, whether related to different embodiments or not, is contemplated to implement and practice contemplated embodiments. Furthermore, although embodiments disclosed herein may achieve advantages over other possible solutions or over the prior art, whether or not a particular advantage is achieved by a given embodiment is not limiting of the scope of the present disclosure. Thus, the recited aspects, features, embodiments and advantages are merely illustrative and are not considered elements or limitations of the appended claims except where explicitly recited in a claim(s). Likewise, reference to “the invention” shall not be construed as a generalization of any inventive subject matter disclosed herein and shall not be considered to be an element or limitation of the appended claims except where explicitly recited in a claim(s).
- Aspects of the present invention may 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 aspects that may all generally be referred to herein as a “circuit,” “module” or “system.”
- The present invention may be a system, a method, and/or a computer program product. The computer program product may include a computer readable storage medium (or media) having computer readable program instructions thereon for causing a processor to carry out aspects of the present invention.
- The computer readable storage medium can be a tangible device that can retain and store instructions for use by an instruction execution device. The computer readable storage medium may be, for example, but is not limited to, an electronic storage device, a magnetic storage device, an optical storage device, an electromagnetic storage device, a semiconductor storage device, or any suitable combination of the foregoing. A non-exhaustive list of more specific examples of the computer readable storage medium includes the following: a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), a static random access memory (SRAM), a portable compact disc read-only memory (CD-ROM), a digital versatile disk (DVD), a memory stick, a floppy disk, a mechanically encoded device such as punch-cards or raised structures in a groove having instructions recorded thereon, and any suitable combination of the foregoing. A computer readable storage medium, as used herein, is not to be construed as being transitory signals per se, such as radio waves or other freely propagating electromagnetic waves, electromagnetic waves propagating through a waveguide or other transmission media (e.g., light pulses passing through a fiber-optic cable), or electrical signals transmitted through a wire.
- Computer readable program instructions described herein can be downloaded to respective computing/processing devices from a computer readable storage medium or to an external computer or external storage device via a network, for example, the Internet, a local area network, a wide area network and/or a wireless network. The network may comprise copper transmission cables, optical transmission fibers, wireless transmission, routers, firewalls, switches, gateway computers and/or edge servers. A network adapter card or network interface in each computing/processing device receives computer readable program instructions from the network and forwards the computer readable program instructions for storage in a computer readable storage medium within the respective computing/processing device.
- Computer readable program instructions for carrying out operations of the present invention may be assembler instructions, instruction-set-architecture (ISA) instructions, machine instructions, machine dependent instructions, microcode, firmware instructions, state-setting data, or either source code or object code written in any combination of one or more programming languages, including an object oriented programming language such as Smalltalk, C++ or the like, and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The computer readable program instructions may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider). In some embodiments, electronic circuitry including, for example, programmable logic circuitry, field-programmable gate arrays (FPGA), or programmable logic arrays (PLA) may execute the computer readable program instructions by utilizing state information of the computer readable program instructions to personalize the electronic circuitry, in order to perform aspects of the present invention.
- Aspects of the present invention are described herein with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems), and computer program products according to embodiments of the invention. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer readable program instructions.
- These computer readable program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks. These computer readable program instructions may also be stored in a computer readable storage medium that can direct a computer, a programmable data processing apparatus, and/or other devices to function in a particular manner, such that the computer readable storage medium having instructions stored therein comprises an article of manufacture including instructions which implement aspects of the function/act specified in the flowchart and/or block diagram block or blocks.
- The computer readable program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other device to cause a series of operational steps to be performed on the computer, other programmable apparatus or other device to produce a computer implemented process, such that the instructions which execute on the computer, other programmable apparatus, or other device implement the functions/acts specified in the flowchart and/or block diagram block or blocks.
- 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 of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of instructions, which comprises one or more executable instructions for implementing the specified logical function(s). 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 carry out combinations of special purpose hardware and computer instructions.
- Embodiments of the invention may be provided to end users through a cloud computing infrastructure. Cloud computing generally refers to the provision of scalable computing resources as a service over a network. More formally, cloud computing may be defined as a computing capability that provides an abstraction between the computing resource and its underlying technical architecture (e.g., servers, storage, networks), enabling convenient, on-demand network access to a shared pool of configurable computing resources that can be rapidly provisioned and released with minimal management effort or service provider interaction. Thus, cloud computing allows a user to access virtual computing resources (e.g., storage, data, applications, and even complete virtualized computing systems) in “the cloud,” without regard for the underlying physical systems (or locations of those systems) used to provide the computing resources.
- Typically, cloud computing resources are provided to a user on a pay-per-use basis, where users are charged only for the computing resources actually used (e.g. an amount of storage space consumed by a user or a number of virtualized systems instantiated by the user). A user can access any of the resources that reside in the cloud at any time, and from anywhere across the Internet. In context of the present invention, a user may access applications or related data available in the cloud. For example, the
allocation engine 105 could execute on a computing system in the cloud. In such a case, theallocation engine 105 may store the seat allocations in theallocation data 108 for a plurality of clients at a storage location in the cloud. Doing so allows a user to access this information from any computing system attached to a network connected to the cloud (e.g., the Internet). - While the foregoing is directed to embodiments of the present invention, other and further embodiments of the invention may be devised without departing from the basic scope thereof, and the scope thereof is determined by the claims that follow.
Claims (20)
Priority Applications (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US15/791,961 US20190122143A1 (en) | 2017-10-24 | 2017-10-24 | Cognitive-based passenger selection |
US16/398,360 US11410079B2 (en) | 2017-10-24 | 2019-04-30 | Cognitive-based passenger selection |
US17/808,464 US11803776B2 (en) | 2017-10-24 | 2022-06-23 | Cognitive-based passenger selection |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US15/791,961 US20190122143A1 (en) | 2017-10-24 | 2017-10-24 | Cognitive-based passenger selection |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US16/398,360 Continuation US11410079B2 (en) | 2017-10-24 | 2019-04-30 | Cognitive-based passenger selection |
Publications (1)
Publication Number | Publication Date |
---|---|
US20190122143A1 true US20190122143A1 (en) | 2019-04-25 |
Family
ID=66170009
Family Applications (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US15/791,961 Abandoned US20190122143A1 (en) | 2017-10-24 | 2017-10-24 | Cognitive-based passenger selection |
US16/398,360 Active 2039-06-14 US11410079B2 (en) | 2017-10-24 | 2019-04-30 | Cognitive-based passenger selection |
US17/808,464 Active US11803776B2 (en) | 2017-10-24 | 2022-06-23 | Cognitive-based passenger selection |
Family Applications After (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US16/398,360 Active 2039-06-14 US11410079B2 (en) | 2017-10-24 | 2019-04-30 | Cognitive-based passenger selection |
US17/808,464 Active US11803776B2 (en) | 2017-10-24 | 2022-06-23 | Cognitive-based passenger selection |
Country Status (1)
Country | Link |
---|---|
US (3) | US20190122143A1 (en) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112441072A (en) * | 2019-08-30 | 2021-03-05 | 比亚迪股份有限公司 | Rail vehicle and loving and seating reminding method and device for rail vehicle |
US11190529B2 (en) * | 2017-11-24 | 2021-11-30 | Eric Edward Stuck | Method and system for on-board cyber (information) security appliance and applications to detect, manage and optionally mitigate cyber security events and /or anomalies on aircraft networks |
US11410079B2 (en) * | 2017-10-24 | 2022-08-09 | International Business Machines Corporation | Cognitive-based passenger selection |
Family Cites Families (35)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
AU2003255702B2 (en) * | 2002-07-02 | 2008-06-05 | Amadeus S.A.S | Method of allocating seats to customers in a computer reservation system |
US6923375B2 (en) | 2003-05-15 | 2005-08-02 | Arinc, Inc. | Aircraft weight and balance system |
US7908158B2 (en) * | 2007-09-04 | 2011-03-15 | Accenture Global Services Limited | Seat routine equipment model |
FR2947771B1 (en) * | 2009-07-08 | 2011-10-21 | Airbus Operations Sas | METHOD AND DEVICE FOR PASSENGER CABIN LAYOUT |
EP2323082A1 (en) | 2009-10-09 | 2011-05-18 | Amadeus S.A.S. | Seat allocation to passengers on an aircraft |
WO2011061711A1 (en) * | 2009-11-19 | 2011-05-26 | Air New Zealand Limited | Method and system for reserving and allocating vehicle seating |
US20120010912A1 (en) * | 2010-07-08 | 2012-01-12 | Lele Avinash S | Systems and methods for optimizing the scheduling of resources on an airplane |
US20120022901A1 (en) | 2010-07-20 | 2012-01-26 | Continental Airlines, Inc. | Preference Seating System |
US20120123812A1 (en) * | 2010-11-17 | 2012-05-17 | Accenture Global Services Limited | Evaluating customers |
US20130054375A1 (en) * | 2011-08-24 | 2013-02-28 | Accenture Global Services Limited | Personalized travel experience with social media integration |
US20130060585A1 (en) | 2011-09-02 | 2013-03-07 | Accenture Global Services Limited | Processing Data Using Rules Based Engine |
US8870116B2 (en) * | 2011-09-27 | 2014-10-28 | The Boeing Company | Aircraft seating systems |
GB201117278D0 (en) | 2011-10-06 | 2011-11-16 | Fuel Matrix Ltd | Method and system |
WO2014172369A2 (en) * | 2013-04-15 | 2014-10-23 | Flextronics Ap, Llc | Intelligent vehicle for assisting vehicle occupants and incorporating vehicle crate for blade processors |
US20140309876A1 (en) * | 2013-04-15 | 2014-10-16 | Flextronics Ap, Llc | Universal vehicle voice command system |
US20130262159A1 (en) * | 2012-03-28 | 2013-10-03 | Accenture Global Services Limited | Finding Best Seating Selections via Algorithmic Search |
EP2698749A1 (en) * | 2012-08-14 | 2014-02-19 | Amadeus s.a.s. | Passenger oriented seating system and method |
US20140052482A1 (en) * | 2012-08-14 | 2014-02-20 | Mathieu Le Marier | Passenger oriented seating system and method |
DE102012217795A1 (en) * | 2012-09-28 | 2014-04-03 | Lufthansa Technik Ag | Software, communication system and method in an aircraft |
EP2912624A4 (en) * | 2012-10-23 | 2016-04-27 | Olset Inc | Methods and systems for making travel arrangements |
JP5594705B2 (en) * | 2012-12-25 | 2014-09-24 | 楽天株式会社 | Seat management system, seat management system control method, and program |
US10185917B2 (en) | 2013-01-31 | 2019-01-22 | Lf Technology Development Corporation Limited | Computer-aided decision systems |
DE102014209554A1 (en) * | 2014-05-20 | 2015-11-26 | Siemens Aktiengesellschaft | Management of passengers |
WO2016113967A1 (en) * | 2015-01-14 | 2016-07-21 | ソニー株式会社 | Information processing system, and control method |
US20160358272A1 (en) * | 2015-06-05 | 2016-12-08 | Mastercard International Incorporated | Airline seat optimization for passenger shoulder width and size |
US20170243172A1 (en) * | 2016-02-23 | 2017-08-24 | International Business Machines Corporation | Cognitive optimal and compatible grouping of users for carpooling |
US10012990B2 (en) * | 2016-04-01 | 2018-07-03 | Uber Technologies, Inc. | Optimizing timing for configuring an autonomous vehicle |
US10093252B2 (en) * | 2016-04-01 | 2018-10-09 | Uber Technologies, Inc. | Transport facilitation system for configuring a service vehicle for a user |
US20180018593A1 (en) * | 2016-07-15 | 2018-01-18 | International Business Machines Corporation | Expedited identification verification and biometric monitoring |
US11599833B2 (en) * | 2016-08-03 | 2023-03-07 | Ford Global Technologies, Llc | Vehicle ride sharing system and method using smart modules |
US9633402B1 (en) * | 2016-09-16 | 2017-04-25 | Seatwizer OU | System and method for seat search comparison and selection based on physical characteristics of travelers |
US20180218470A1 (en) * | 2017-01-27 | 2018-08-02 | Ford Global Technologies, Llc | Personalized seat system for rideshare vehicle interior |
US20180276573A1 (en) * | 2017-03-22 | 2018-09-27 | Facebook, Inc. | Providing travel related content customized for users |
US20190122143A1 (en) * | 2017-10-24 | 2019-04-25 | International Business Machines Corporation | Cognitive-based passenger selection |
CN112734259A (en) * | 2021-01-18 | 2021-04-30 | 中国民航信息网络股份有限公司 | Configurable seat adjustment method, device, storage medium and equipment |
-
2017
- 2017-10-24 US US15/791,961 patent/US20190122143A1/en not_active Abandoned
-
2019
- 2019-04-30 US US16/398,360 patent/US11410079B2/en active Active
-
2022
- 2022-06-23 US US17/808,464 patent/US11803776B2/en active Active
Cited By (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US11410079B2 (en) * | 2017-10-24 | 2022-08-09 | International Business Machines Corporation | Cognitive-based passenger selection |
US11803776B2 (en) | 2017-10-24 | 2023-10-31 | International Business Machines Corporation | Cognitive-based passenger selection |
US11190529B2 (en) * | 2017-11-24 | 2021-11-30 | Eric Edward Stuck | Method and system for on-board cyber (information) security appliance and applications to detect, manage and optionally mitigate cyber security events and /or anomalies on aircraft networks |
US20220046034A1 (en) * | 2017-11-24 | 2022-02-10 | Eric Edward Stuck | Method and system for on-board cyber security |
US11838302B2 (en) * | 2017-11-24 | 2023-12-05 | Eric Edward Stuck | Method and system for on-board cyber security |
CN112441072A (en) * | 2019-08-30 | 2021-03-05 | 比亚迪股份有限公司 | Rail vehicle and loving and seating reminding method and device for rail vehicle |
Also Published As
Publication number | Publication date |
---|---|
US11410079B2 (en) | 2022-08-09 |
US20190258956A1 (en) | 2019-08-22 |
US11803776B2 (en) | 2023-10-31 |
US20220318680A1 (en) | 2022-10-06 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11803776B2 (en) | Cognitive-based passenger selection | |
US10061814B2 (en) | Question answer system using physical distance data | |
US11615876B2 (en) | Predictive model for substance monitoring and impact prediction | |
US20210118424A1 (en) | Predicting personality traits based on text-speech hybrid data | |
US10958742B2 (en) | Cognitive content filtering | |
US10692606B2 (en) | Stress level reduction using haptic feedback | |
US20170126892A1 (en) | Using graphical text analysis to facilitate communication between customers and customer service representatives | |
US11182447B2 (en) | Customized display of emotionally filtered social media content | |
US20200204562A1 (en) | Permission management | |
US20200152328A1 (en) | Cognitive analysis for identification of sensory issues | |
US20160328987A1 (en) | Detecting the mood of a group | |
US20160275302A1 (en) | Securing a device using graphical analysis | |
US11188851B2 (en) | Priority seating management in public/private transportation | |
US20190090772A1 (en) | Predicting thought based on neural mapping | |
US11068476B2 (en) | Determining whether to take an action by applying a metric calculated using natural language processing tokens | |
US20190266617A1 (en) | Reader reaction learning-based article cataloging management | |
US20170185942A1 (en) | Generation of optimal team configuration recommendations | |
US20190005841A1 (en) | Representation of group emotional response | |
US11501059B2 (en) | Methods and systems for auto-filling fields of electronic documents | |
US20170169397A1 (en) | Personalized scheduling and networking system, method, and recording medium | |
Zhang et al. | The difficulty to break a relational complexity network can predict air traffic controllers’ mental workload and performance in conflict resolution | |
US11410110B2 (en) | Alert generation based on a cognitive state and a physical state | |
US10764206B2 (en) | Adjusting network bandwidth based on an analysis of a user's cognitive state | |
US20180060706A1 (en) | Dynamic determination of human gestures based on context | |
US20190156294A1 (en) | Scheduling approach that digitally groups individuals with similar conditions |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: INTERNATIONAL BUSINESS MACHINES CORPORATION, NEW Y Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:AYYAGARI, PHANI KUMAR V.U.;BHIDE, MANISH A.;CHUKKA, MADAN K.;AND OTHERS;REEL/FRAME:043937/0506 Effective date: 20171024 |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NON FINAL ACTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: FINAL REJECTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: ADVISORY ACTION MAILED |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |