The present disclosure relates to the field of computers and tracking sensors, and specifically to the use of computers and tracking sensors in the field of pedestrian navigation. Still more particularly, the present disclosure relates to the use of computers and tracking sensors in providing suggested pedestrian routes to mobility-impaired users.
Accessibility to public facilities and buildings can often be challenging to pedestrians that are mobility-impaired. A mobility-impaired pedestrian is a person who has physical or other conditions that impede mobility. Such mobility-impaired persons experience unique challenges when traversing across unfamiliar landscapes to reach a desired destination.
A processor-implemented method, system, and/or computer program product guides mobility-impaired pedestrians. Mobile tracking readings are received from multiple mobility assistance devices, each of which has an affixed tracking device. Based on these mobile tracking readings, multiple pedestrian routes for mobility-impaired pedestrians, including an optimal pedestrian route that has the highest tracking history to a desired destination, are generated.
As will be appreciated by one skilled in the art, aspects of the present invention may be embodied as a system, method or computer program product. Accordingly, 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.” Furthermore, aspects of the present invention may take the form of a computer program product embodied in one or more computer readable medium(s) having computer readable program code embodied thereon.
Any combination of one or more computer readable medium(s) may be utilized. The computer readable medium may be a computer readable signal medium or a computer readable storage medium. A computer readable storage medium may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device, or any suitable combination of the foregoing. More specific examples (a non-exhaustive list) of the computer readable storage medium would include the following: an electrical connection having one or more wires, 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), an optical fiber, a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a computer readable storage medium may be any tangible medium that can contain, or store a program for use by or in connection with an instruction execution system, apparatus, or device.
A computer readable signal medium may include a propagated data signal with computer readable program code embodied therein, for example, in baseband or as part of a carrier wave. Such a propagated signal may take any of a variety of forms, including, but not limited to, electro-magnetic, optical, or any suitable combination thereof. A computer readable signal medium may be any computer readable medium that is not a computer readable storage medium and that can communicate, propagate, or transport a program for use by or in connection with an instruction execution system, apparatus, or device.
Program code embodied on a computer readable medium may be transmitted using any appropriate medium, including, but not limited to, wireless, wireline, optical fiber cable, RF, etc., or any suitable combination of the foregoing.
Computer program code for carrying out operations for aspects of the present invention may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++ or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The program code 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).
Aspects of the present invention are described below 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 program instructions. These computer 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 program instructions may also be stored in a computer readable medium that can direct a computer, other programmable data processing apparatus, or other devices to function in a particular manner, such that the instructions stored in the computer readable medium produce an article of manufacture including instructions which implement the function/act specified in the flowchart and/or block diagram block or blocks.
The computer program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other devices to cause a series of operational steps to be performed on the computer, other programmable apparatus or other devices to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks.
With reference now to the figures, and in particular to
Computer 102 includes a processing unit 104 that is coupled to a system bus 106. Processing unit 104 may utilize one or more processors, each of which has one or more processor cores. A video adapter 108, which drives/supports a display 110, is also coupled to system bus 106. System bus 106 is coupled via a bus bridge 112 to an input/output (I/O) bus 114. An I/O interface 116 is coupled to I/O bus 114. I/O interface 116 affords communication with various I/O devices, including a keyboard 118, a mouse 120, a media tray 122 (which may include storage devices such as CD-ROM drives, multi-media interfaces, etc.), a wireless signal receiver 124, and external USB port(s) 126. While the format of the ports connected to I/O interface 116 may be any known to those skilled in the art of computer architecture, in one embodiment some or all of these ports are universal serial bus (USB) ports.
As depicted, computer 102 is able to communicate with a software deploying server 150 using a network interface 130. Network 128 may be an external network such as the Internet, or an internal network such as an Ethernet or a virtual private network (VPN).
A hard drive interface 132 is also coupled to system bus 106. Hard drive interface 132 interfaces with a hard drive 134. In one embodiment, hard drive 134 populates a system memory 136, which is also coupled to system bus 106. System memory is defined as a lowest level of volatile memory in computer 102. This volatile memory includes additional higher levels of volatile memory (not shown), including, but not limited to, cache memory, registers and buffers. Data that populates system memory 136 includes computer 102's operating system (OS) 138 and application programs 144.
OS 138 includes a shell 140, for providing transparent user access to resources such as application programs 144. Generally, shell 140 is a program that provides an interpreter and an interface between the user and the operating system. More specifically, shell 140 executes commands that are entered into a command line user interface or from a file. Thus, shell 140, also called a command processor, is generally the highest level of the operating system software hierarchy and serves as a command interpreter. The shell provides a system prompt, interprets commands entered by keyboard, mouse, or other user input media, and sends the interpreted command(s) to the appropriate lower levels of the operating system (e.g., a kernel 142) for processing. Note that while shell 140 is a text-based, line-oriented user interface, the present invention will equally well support other user interface modes, such as graphical, voice, gestural, etc.
As depicted, OS 138 also includes kernel 142, which includes lower levels of functionality for OS 138, including providing essential services required by other parts of OS 138 and application programs 144, including memory management, process and task management, disk management, and mouse and keyboard management.
Application programs 144 include a renderer, shown in exemplary manner as a browser 146. Browser 146 includes program modules and instructions enabling a world wide web (WWW) client (i.e., computer 102) to send and receive network messages to the Internet using hypertext transfer protocol (HTTP) messaging, thus enabling communication with software deploying server 150 and other computer systems.
Application programs 144 in computer 102's system memory (and, in one embodiment, software deploying server 150's system memory) also include a mobility-impaired pedestrian route optimization program (MPROP) 148. MPROP 148 includes code for implementing the processes described below, including those described in
The hardware elements depicted in computer 102 are not intended to be exhaustive, but rather are representative to highlight essential components required by the present invention. For instance, computer 102 may include alternate memory storage devices such as magnetic cassettes, digital versatile disks (DVDs), Bernoulli cartridges, and the like. These and other variations are intended to be within the spirit and scope of the present invention.
With reference now to
As depicted in
Note that pedestrian route 308 and pedestrian route 310 have a substantially similar number of tracking points. This similarity may be due to simple randomness, in which both routes are equally optimal (i.e., have the easiest sidewalks, pathways, fields, etc. to cross in a wheelchair or when on crutches), and past users have randomly chosen which route to take. In one embodiment, however, data analysis reveals that when it is snowing, raining, dark, etc., most mobility-impaired pedestrians will choose pedestrian route 308 (e.g., due to paved pathways, good lighting, etc.), but when the weather is clear during daytime hours, most mobility-impaired pedestrians will choose pedestrian route 310 (e.g., due to nicer scenery, proximity to popular coffee shops, etc.).
With reference now to
In one embodiment, the determination of the optimal pedestrian route may include locating and identifying an elevator, which if not on a route, will eliminate that route as a possible candidate for the optimal pedestrian route for a particular mobility-impaired pedestrian. For example, assume that a mobility-impaired pedestrian is in a wheelchair, and desires to get to the third floor of a parking facility. If there is no elevator in the parking facility, then that mobility-impaired pedestrian will be required to roll uphill on the parking facility ramps, which is may be physically exhausting, if not physically impossible, for that mobility-impaired pedestrian. In the present embodiment, an elevator is located by a processor (e.g., computer 102 in
As described in block 408, an optimal pedestrian route is then identified for a current mobility-impaired pedestrian. The current mobility-impaired pedestrian is defined as a mobility-impaired pedestrian who is currently at an origination point A of the past pedestrian routes that have been identified, and who desires to travel to a destination point B on these past pedestrian routes. A preliminary determination is made that whichever route has been taken the most often in the past, as indicated by having more mobile tracking readings than other routes from the origination point A to the destination point B, is the optimal pedestrian route. Note that in one embodiment, a correlation is made between the mobility-impaired pedestrians whose tracking devices generated the route histories and the current mobility-impaired pedestrian. That is, the route taken most often in the past by persons with a same mobility-impairment as the current mobility-impaired pedestrian will be deemed the optimal route for that mobility-impaired pedestrian. Thus, a recommendation will be made to person in a wheelchair to follow the route most often taken by other wheelchair-using pedestrians, while a visually impaired pedestrian will be advised to follow the most popular route taken by other visually impaired pedestrians in the past (all as indicated by the tracking history generated by the tracking devices associated with the past pedestrians). Stated another way, a specific mobility-impairment affecting a specific type of user of one of the multiple mobility assistance devices that provided past mobile tracking readings is identified. A type-specific pedestrian route is then generated for mobility-impaired pedestrians having that same specific mobility-impairment. After a processor identifies which mobility-impairment affects the current mobility-impaired pedestrian, and then matches the mobility-impairment of the current mobility-impaired pedestrian to the specific mobility-impairment affecting the specific type of user of one of the multiple mobility assistance devices that provided past mobile tracking readings.
As indicated above, certain pedestrian routes are deemed optimal according to current conditions surrounding the current mobility-impaired pedestrian who is in need of route advice. For example, a route that was most popular, particularly with mobility-impaired pedestrians having a same mobility impairment as the current mobility-impaired pedestrian, during certain weather conditions, time of day or night, time of year, etc., will be recommended to the current mobility-impaired pedestrian. Similarly, if the current mobility-impaired pedestrian wants to get to a venue where a recurring public event is occurring (e.g., a college athletic game), whichever route was preferred in the past by those having his same mobility impairment will be recommended to that current mobility-impaired pedestrian.
As indicated in block 410 of
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 disclosure. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the invention. As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
The corresponding structures, materials, acts, and equivalents of all means or step plus function elements in the claims below are intended to include any structure, material, or act for performing the function in combination with other claimed elements as specifically claimed. The description of various embodiments of the present invention has been presented for purposes of illustration and description, but is not intended to be exhaustive or limited to the invention in the form 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 invention. The embodiment was chosen and described in order to best explain the principles of the invention and the practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.
Note further that any methods described in the present disclosure may be implemented through the use of a VHDL (VHSIC Hardware Description Language) program and a VHDL chip. VHDL is an exemplary design-entry language for Field Programmable Gate Arrays (FPGAs), Application Specific Integrated Circuits (ASICs), and other similar electronic devices. Thus, any software-implemented method described herein may be emulated by a hardware-based VHDL program, which is then applied to a VHDL chip, such as a FPGA.
Having thus described embodiments of the invention of the present application in detail and by reference to illustrative embodiments thereof, it will be apparent that modifications and variations are possible without departing from the scope of the invention defined in the appended claims.
Number | Name | Date | Kind |
---|---|---|---|
3820381 | Thurston | Jun 1974 | A |
3838421 | Dasse-Hartaut et al. | Sep 1974 | A |
4073183 | Byalko et al. | Feb 1978 | A |
4186590 | Egorov et al. | Feb 1980 | A |
4511247 | McGovern et al. | Apr 1985 | A |
4530233 | Kadi | Jul 1985 | A |
4715743 | Schmanski | Dec 1987 | A |
5195046 | Gerardi et al. | Mar 1993 | A |
5549803 | Schoess et al. | Aug 1996 | A |
5681986 | Merk et al. | Oct 1997 | A |
5736940 | Burgener | Apr 1998 | A |
6260004 | Hays et al. | Jul 2001 | B1 |
6265979 | Chen et al. | Jul 2001 | B1 |
6718270 | Horiuchi et al. | Apr 2004 | B2 |
6731804 | Carrieri et al. | May 2004 | B1 |
6950767 | Yamashita et al. | Sep 2005 | B2 |
7228740 | Sinha | Jun 2007 | B2 |
7325759 | Meyer | Feb 2008 | B2 |
7343136 | Liu et al. | Mar 2008 | B2 |
7535355 | Barone | May 2009 | B2 |
7627441 | Longsdorf et al. | Dec 2009 | B2 |
7630948 | Friedlander et al. | Dec 2009 | B2 |
7693663 | Friedlander et al. | Apr 2010 | B2 |
7720574 | Roys | May 2010 | B1 |
7762142 | Rakow et al. | Jul 2010 | B2 |
8154723 | Fu et al. | Apr 2012 | B2 |
8538667 | Friedlander et al. | Sep 2013 | B2 |
20020077749 | Doi | Jun 2002 | A1 |
20040122787 | Avinash et al. | Jun 2004 | A1 |
20050011278 | Brown et al. | Jan 2005 | A1 |
20050256885 | Yairi et al. | Nov 2005 | A1 |
20060071786 | Fano | Apr 2006 | A1 |
20060097983 | Haggman et al. | May 2006 | A1 |
20060285350 | Wang | Dec 2006 | A1 |
20070050121 | Ammon et al. | Mar 2007 | A1 |
20070199382 | Sakai | Aug 2007 | A1 |
20080009099 | Kishkovich et al. | Jan 2008 | A1 |
20080077463 | Friedlander et al. | Mar 2008 | A1 |
20080180281 | Bilimoria et al. | Jul 2008 | A1 |
20080270034 | Friedlander et al. | Oct 2008 | A1 |
20080274553 | Bratton et al. | Nov 2008 | A1 |
20090157302 | Tashev et al. | Jun 2009 | A1 |
20090271100 | Kim et al. | Oct 2009 | A1 |
20100125409 | Prehofer | May 2010 | A1 |
20100150359 | Knickrehm et al. | Jun 2010 | A1 |
20100189291 | Aharoni et al. | Jul 2010 | A1 |
20100268469 | Harrison et al. | Oct 2010 | A1 |
20110085156 | Jones et al. | Apr 2011 | A1 |
20110130956 | Tracton et al. | Jun 2011 | A1 |
20110153193 | Fox et al. | Jun 2011 | A1 |
20110153208 | Kruglick | Jun 2011 | A1 |
20110172907 | Rui Da Silva Freitas | Jul 2011 | A1 |
20110173067 | Herbst et al. | Jul 2011 | A1 |
20110238291 | Bach | Sep 2011 | A1 |
20110308638 | Hyland et al. | Dec 2011 | A1 |
20130030613 | Friedlander et al. | Jan 2013 | A1 |
20130030680 | Friedlander et al. | Jan 2013 | A1 |
20130030724 | Friedlander et al. | Jan 2013 | A1 |
20130030725 | Friedlander et al. | Jan 2013 | A1 |
20130040399 | Belbruno et al. | Feb 2013 | A1 |
Number | Date | Country |
---|---|---|
52104960 | Sep 1977 | JP |
4235380 | Aug 1992 | JP |
05052972 | Jul 1993 | JP |
07044117 | Feb 1995 | JP |
08085496 | Apr 1996 | JP |
2006194795 | Jul 2006 | JP |
2007531868 | Nov 2007 | JP |
2008052786 | May 2008 | WO |
2010071607 | Jun 2010 | WO |
Entry |
---|
N. Harrington, “Knock-Based Commands for Your Linux Laptop”, pp. 1-11, Jul. 25, 2006, http:// www.ibm.com/developerworks/library/I-knockage/index.html, pp. 1-14. |
W. Xie et al., “A New Diagnostic Method of Bolt Loosening Detection for Thermal Protection Systems”, Proceedings of the SPIE—The International Society for Optical Engineering, vol. 7493, 2009, pp. 1-2. |
S. Lihua et al., “Applications of Piezoelectric Material Sensors in Smart Structures”, Transactions of Nanjing University of Aeronautics & Astronautics, vol. 1, No. 2, 210-213, Dec. 1996. |
J. Schoess et al., “Smart Aircraft Fastener Evaluation (SAFE) System—A Condition-Based Corrosion Detection System for Aging Aircraft”, Proceedings of the SPIE—The International Society for Optical Engineering, vol. 2718, 175-184, 1996. |
J. Schoess et al., “Smart Fastener for KC-135 Structural Integrity Monitoring”, Proceedings of the SPIE—The International Society for Optical Engineering, vol. 3042, pp. 278-282, 1997. |
T. Bojko, “Smart Sensor Solutions for Mechanical Measurements and Diagnostics”, Metrology and Measurement Systems, vol. 12, No. 1, 2005, pp. 95-103. |
S. Kessler, “Piezoelectric-Based In-Situ Damage Detection of Composite Materials for Structural Health Monitoring Systems”, Doctorate of Philosophy in Aeronautics and Astronautics at the Massachusetts Institute of Technology, 2002, pp. 1-200. |
D. Sinha, “Acoustic Sensor for Pipeline Monitoring: Technology Report”, Los Alamos National Laboratory, Jul. 20, 2005, pp. 1-23. |
B. Umeadi et al., “The Development of an Intelligent Sensor for the Monitoring of Pipeline System Integrity”, Oil and Gas 2008, pp. 1-4. |
C. Zang et al., “Structural Health Monitoring and Damage Assessment Using Frequency Response Correlation Criteria”, Journal of Engineering Mechanics, Sep. 2007, 981-993. |
S.L. Hung et al., “Aiming for the Top University Plan: Preliminary Results” 2009, http://www.cv.nctu.edu.tw/˜wwwadm/chinese/monitoring2/result.html, 1 page. |
U.S. Appl. No. 11/741,186, Friedlander et al.—Non-Final Office Action Mailed Nov. 21, 2008, pp. 1-17. |
U.S. Appl. No. 11/741,186, Friedlander et al.—Final Office Action Mailed Apr. 15, 2009, pp. 1-6. |
U.S. Appl. No. 11/741,186, Friedlander et al.—Non-Final Office Action Mailed Jul. 9, 2009, pp. 1-26. |
U.S. Appl. No. 11/741,186, Friedlander et al.—Notice of Allowance Mailed Nov. 20, 2009, pp. 1-15. |
R. Marinelli, “FAA Runway Friction Program”, Runway Condition Determination, Reporting, and Report Dissemination Workshop, Jun. 20, 2006, pp. 1-13. |
T. Yager, “Runway Friction Measurement”, FAA/Aviation Industry Workshop on Runway Condition Determination, Reporting, and Report Dissemination, Aug. 7-8, 2006, pp. 1-15. |
Douglas Equipment International Inc., Special Products Division “MU-Meter MK 6—Specification” PDF Retrieved From http://www.douglas-equipment.com/product—display.php?id=0000000035, pp. 1-2. |
U.S. Appl. No. 13/962,665—Notice of Allowance Mailed Jan. 3, 2014, pp. 1-14. |
U.S. Appl. No. 13/192,149—Final Office Action Mailed Feb. 26, 2014, pp. 1-34. |
United Kingdom Patent Application No. GB1216790.4, Combined Search and Examination Report, January 18, 2013, pp. 1-5. |
International Searching Authority, International Search Report and Written Opinion for PCT/IB2012/053753, Dec. 18, 2012, pp. 1-6. |
U.S. Appl. No. 14/155,781—Non-Final Office Action mailed Apr. 17, 2015 , pp. 1-47. |
UK IPO, GB Patent Application No. 1401834.5—Examination Report Mailed Mar. 18, 2014, pp. 1-4. |
U.S. Appl. No. 13/962,665—Non-Final Office Action Mailed Sep. 27, 2013, pp. 1-6. |
U.S. Appl. No. 13/192,149—Non-Final Office Action Mailed Sep. 27, 2013, pp. 1-19. |
U.S. Appl. No. 13/190,172—Non-Final Office Action Mailed Sep. 25, 2013, pp. 1-26. |
U.S. Appl. No. 13/192,887—Non-Final Office Action Mailed Feb. 7, 2013, pp. 1-18. |
Number | Date | Country | |
---|---|---|---|
20130085671 A1 | Apr 2013 | US |