1. Technical Field
The present invention relates generally to managing vehicle parking, and in particular, to a computer implemented method for administering shared parking facilities for multiple tenants.
2. Description of Related Art
A variety of techniques have been utilized in the past by entities for managing parking across parking facilities. A common technique is the use of a parking sticker assigned to individuals that is affixed to a windshield or bumper. The sticker is obtained by the individual vehicle owner through a registration process with the entity, such as a school or business. The registration is specific to the vehicle given the affixed nature of the sticker. Alternatively, a tag may be obtained by an individual that is hung from the rear view mirror or displayed in the interior dash of the vehicle. The registration of the tag is typically specific to the individual, although visitor tags may be provided on occasion. Each tag may be utilized in multiple vehicles owned by the registering individual, although each vehicle may be registered as a potential user of the tag.
Parking is then typically enforced through the use of attendants walking or driving through parking lots looking for vehicles without approved stickers or tags. Unauthorized vehicles may be ticketed, towed, or booted to prevent vehicle movement until the vehicle owner contacts the entity.
The illustrative embodiments provide a method, system, and computer usable program product for administering a set of vehicle parking facilities shared by a plurality of tenants, including managing an administrative domain accessible by a parking administrator, the administrative domain capable of communicating with a plurality of tenant domains; and managing an access enforcement system in communication with tag sensors and gates at access points of the vehicle parking facilities for reading tags to obtain a current tag identifier of a current vehicle at a current gate, and providing a signal to the current gate allowing the current vehicle to proceed through the access point; wherein user attributes in the tenant domains are secured from access by the parking administrator.
The novel features believed characteristic of the invention are set forth in the appended claims. The invention itself, further objectives and advantages thereof, as well as a preferred mode of use, will best be understood by reference to the following detailed description of illustrative embodiments when read in conjunction with the accompanying drawings, wherein:
Processes and devices may be implemented and utilized for managing vehicle parking. These processes and apparatuses may be implemented and utilized as will be explained with reference to the various embodiments below.
In data processing system 100 there is a computer system/server 112, which is operational with numerous other general purpose or special purpose computing system environments, peripherals, or configurations. Examples of well-known computing systems, environments, and/or configurations that may be suitable for use with computer system/server 112 include, but are not limited to, personal computer systems, server computer systems, thin clients, thick clients, hand-held or laptop devices, multiprocessor systems, microprocessor-based systems, set top boxes, programmable consumer electronics, network PCs, minicomputer systems, mainframe computer systems, and distributed cloud computing environments that include any of the above systems or devices, and the like.
Computer system/server 112 may be described in the general context of computer system-executable instructions, such as program modules, being executed by a computer system. Generally, program modules may include routines, programs, objects, components, logic, data structures, and so on that perform particular tasks or implement particular abstract data types. Computer system/server 112 may be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in both local and remote computer system storage media including memory storage devices.
As shown in
Bus 118 represents one or more of any of several types of bus structures, including a memory bus or memory controller, a peripheral bus, an accelerated graphics port, and a processor or local bus using any of a variety of bus architectures. By way of example, and not limitation, such architectures include Industry Standard Architecture (ISA) bus, Micro Channel Architecture (MCA) bus, Enhanced ISA (EISA) bus, Video Electronics Standards Association (VESA) local bus, and Peripheral Component Interconnects (PCI) bus.
Computer system/server 112 typically includes a variety of non-transitory computer system readable media. Such media may be any available media that is accessible by computer system/server 112, and it includes both volatile and non-volatile media, removable and non-removable media.
System memory 128 can include non-transitory computer system readable media in the form of volatile memory, such as random access memory (RAM) 130 and/or cache memory 132. Computer system/server 112 may further include other non-transitory removable/non-removable, volatile/non-volatile computer system storage media. By way of example, storage system 134 can be provided for reading from and writing to a non-removable, non-volatile magnetic media (not shown and typically called a “hard drive”). Although not shown, a USB interface for reading from and writing to a removable, non-volatile magnetic chip (e.g., a “flash drive”), and an optical disk drive for reading from or writing to a removable, non-volatile optical disk such as a CD-ROM, DVD-ROM or other optical media can be provided. In such instances, each can be connected to bus 118 by one or more data media interfaces. Memory 128 may include at least one program product having a set (e.g., at least one) of program modules that are configured to carry out the functions of the embodiments. Memory 128 may also include data that will be processed by a program product.
Program/utility 140, having a set (at least one) of program modules 142, may be stored in memory 128 by way of example, and not limitation, as well as an operating system, one or more application programs, other program modules, and program data. Each of the operating system, one or more application programs, other program modules, and program data or some combination thereof, may include an implementation of a networking environment. Program modules 142 generally carry out the functions and/or methodologies of the embodiments. For example, a program module may be software for managing vehicle parking.
Computer system/server 112 may also communicate with one or more external devices 114 such as a keyboard, a pointing device, a display 124, etc.; one or more devices that enable a user to interact with computer system/server 112; and/or any devices (e.g., network card, modem, etc.) that enable computer system/server 112 to communicate with one or more other computing devices. Such communication can occur via I/O interfaces 122 through wired connections or wireless connections. Still yet, computer system/server 112 can communicate with one or more networks such as a local area network (LAN), a general wide area network (WAN), and/or a public network (e.g., the Internet) via network adapter 120. As depicted, network adapter 120 communicates with the other components of computer system/server 112 via bus 118. It should be understood that although not shown, other hardware and/or software components could be used in conjunction with computer system/server 112. Examples, include, but are not limited to: microcode, device drivers, tape drives, RAID systems, redundant processing units, data archival storage systems, external disk drive arrays, etc.
Server 220 and client 240 are coupled to network 210 along with storage unit 230. In addition, laptop 250, RFID detector 270 and facility 280 (such as a home or business) are coupled to network 210 including wirelessly such as through a network router 253. A mobile phone 260 and RFID detector 270 may be coupled to network 210 through a mobile phone tower 262. Data processing systems, such as server 220, client 240, laptop 250, mobile phone 260, RFID detector 270, and facility 280 contain data and have software applications including software tools executing thereon. Other types of data processing systems such as personal digital assistants (PDAs), smartphones, tablets and netbooks may be coupled to network 210. An RFID tag 290 may contain an RFID chip 292 which can be detected by RFID detector 270.
Server 220 may include software application 224 and data 226 for managing vehicle parking or other software applications and data in accordance with embodiments described herein. Storage 230 may contain software application 234 and a content source such as data 236 for managing vehicle parking. Other software and content may be stored on storage 230 for sharing among various computer or other data processing devices. Client 240 may include software application 244 and data 246. Laptop 250 and mobile phone 260 may also include software applications 254 and 264 and data 256 and 266. RFID detector 270 may include software applications 274 and data 276. Facility 280 may include software applications 284 and data 286. Other types of data processing systems coupled to network 210 may also include software applications. Software applications could include a web browser, email, or other software application for managing vehicle parking.
Server 220, storage unit 230, client 240, laptop 250, mobile phone 260, RFID detector 270 and facility 280 and other data processing devices may couple to network 210 using wired connections, wireless communication protocols, or other suitable data connectivity. Client 240 may be, for example, a personal computer or a network computer.
In the depicted example, server 220 may provide data, such as boot files, operating system images, and applications to client 240 and laptop 250. Server 220 may be a single computer system or a set of multiple computer systems working together to provide services in a client server environment. Client 240 and laptop 250 may be clients to server 220 in this example. Client 240, laptop 250, mobile phone 260, RFID detector 270 and facility 280 or some combination thereof, may include their own data, boot files, operating system images, and applications. Data processing environment 200 may include additional servers, clients, and other devices that are not shown.
In the depicted example, data processing environment 200 may be the Internet. Network 210 may represent a collection of networks and gateways that use the Transmission Control Protocol/Internet Protocol (TCP/IP) and other protocols to communicate with one another. At the heart of the Internet is a backbone of data communication links between major nodes or host computers, including thousands of commercial, governmental, educational, and other computer systems that route data and messages. Of course, data processing environment 200 also may be implemented as a number of different types of networks, such as for example, an intranet, a local area network (LAN), or a wide area network (WAN).
Among other uses, data processing environment 200 may be used for implementing a client server environment in which the embodiments may be implemented. A client server environment enables software applications and data to be distributed across a network such that an application functions by using the interactivity between a client data processing system and a server data processing system. Data processing environment 200 may also employ a service oriented architecture where interoperable software components distributed across a network may be packaged together as coherent business applications.
A parking facility management system 320 (also referred to herein as parking management system) interfaces with tag sensors 312 and security devices 314 to manage access to parking facilities 310. Parking facility management system includes parking management software 322 and a parking administrative domain 324 (also referred to herein as an administrative database or domain). Parking management software 322 interfaces with tag sensors 312 and security devices 314 and utilizes data stored in parking administrative domain 324 to manage access to parking facilities 310 as an access enforcement system. Parking management software may also interface with tenant domain 328 such as to identify the tenant associated with a given tag and to confirm whether a certain tag includes special needs parking privileges. Parking management software can also manage accounting for tenant parking including providing for automated payment system for parking by the tenant for the users, providing flexible parking plans which can be managed by the tenants, etc. A description of the operation of parking management software is provided below.
Parking facility management system 320 also includes tenant software 326 and tenant domain 328. Although a single tenant is shown, multiple tenant domains and software may be utilized for multiple tenants, each tenant having multiple users. Tenant software 326 and domain 328 may be located on the same server or on different servers as different locations as parking management software 322 and parking administrative domain 324. For example, parking administrative domain 324 and tenant domain 328 may be included in the same database as separate domains where a parking administrator has exclusive access to the parking administrative domain and the tenant has exclusive access to the tenant domain, or they may be separate databases on separate servers and even separate locations. This allows for each entity to maintain and secure privacy and administrative control for their information including accounting information and parking user information. Parking administrative domain 324 and tenant domain 328 may be referred to herein as databases even if they are the same database with different domains within that database or if they are separate databases. Tenant domain 328 includes attribute information about each user of each tag such as name, employee status, shift, whether authorized to park in special needs parking, etc. The user attribute information is secured from access by anyone other than the tenant managing that tenant domain, thereby preventing access to that information by the parking administrator or other tenants. Selected information such as whether a specific tag has been assigned to a user and whether the user is authorized to park in special needs parking may be uploaded to the parking administrative database for ease of managing special needs parking.
A tag such as an RFID tag 340 can be assigned to a particular user 330 by the tenant. The assignment may be by the tenant or directly by the user such as through a kiosk. Although a single user is shown, each tenant may have one or multiple users, each user being assigned a specific tag with a unique tag id. In some cases, a single user may have multiple tags. That assignment is registered in the tenant database and selected information from the tenant database may be automatically updated to the parking administrative database. The upload may occur upon registration, periodically, or when the tag is first used by the user in the parking facilities. The upload may not include personal information about the user to protect the user's privacy. However, selected information such as whether the user is authorized to park in reserved locations may be uploaded. Each tag may contain an RFID chip which transmits the tag ID such as within a tag that hangs from the rear view mirror or within a sticky patch that is affixed to the interior of the windshield. Alternatively, other types of devices may be included in the tag for providing the tag ID such as a battery operated Wi-Fi or LED devices which emit a code (referred to herein is a code emitting device in a code emitting tag) or a visual code that can be scanned with the use of a video camera or other photo capture device. Optionally, each tag may also have a unique tag number that is human readable for ease of distinguishing between tags.
The user then places or affixes the tag to the desired vehicle 350 which is then driven to parking facility 310. Upon approaching or entry to the parking facility, the tag ID is obtained from the tag. The parking management software then determines the tenant number and any parking attributes (e.g., eligible for certain parking spaces) for that tag from the parking administrative database. The parking facility can then be instructed to allow or disallow the vehicle from parking in the parking facility. The vehicle tag ID can also be obtained when the vehicle leaves the facility, thereby providing an accounting of the time spent in the parking facilities. Examples of these processes are described below.
Due to the flexibility of this system, a variety of types of agreements may be made between the parking administrator and each tenant including providing parking on a fixed fee for a certain number of parking spaces, a use fee for parking depending on the number and time of parking spaces used, etc. The tenant can be invoiced for the vehicle parking at the parking facility according to the agreement between the parking administrator and the tenant.
A tenant ID 462 is an identifier of the tenant for identifying the tenant for which this record applies and for managing which tenant may access this record. Plan ID 464 is an identifier of an accounting plan selected by the tenant. For example, some plans may be static and only allow a certain number of parking spaces for certain parking lots at a given time. Other plans may be dynamic and allow extra parking spaces at a premium cost. Rather than having a detailed description of each plan in each record, an identifier is utilized instead which may be linked to an additional database with the plan details. Fixed 466 and variable 468 are standard limitations on the number of parking spaces allocated to a tenant at any given time. For example, a tenant may pay for 100 parking spaces at a low cost, but then will pay for an additional 20 spaces at any time at a premium cost should the need arise. Many other alternative configurations and types of data may be stored in this and other records.
In step 520, a message is sent to the tenant database corresponding to the tenant #. This message includes the tag # and the tag ID. This allows the tenant database to generate a tag record as described below. Processing then ceases with regards to this tag until a message is received in step 525 indicating that the tag has been activated (assigned to an employee or other authorized person). This message should include any parking attributes such as whether the user can park in certain restricted spaces. Then in step 528, the tag record in the parking administrative database is updated and the parking attributes updated to allow use of the parking tag by a user. Processing then ceases unless a subsequent message is received from the tenant software with updated parking attributes. Such updated attributes could include cancelling the parking tag and thereby revoking the parking privileges associated with that tag.
In step 560, it is determined whether the tag ID is within the parking administrative database. If not, then entry to the parking facilities is denied to the vehicle in step 562 and processing ceases. If yes, then in step 564 it is determined from the parking attributes and accounting information stored in the parking administrative database whether the tag associated with that tag ID is authorized to park in the facility where the vehicle is entering. If not, then entry to the parking facilities is denied to the vehicle in step 562 and processing ceases. If yes, then in step 566 a record is created in the parking log database. This record will include the tag ID, the time of entry, and any applicable accounting information. Then in step 568 the vehicle is allowed entry to the parking facilities. Processing then ceases until the tag is again detected.
In step 570, it is determined from the parking attributes stored in the parking administrative database whether the vehicle is authorized to park at the location it has parked. That is, RFID or other sensors may be located at special needs or other restricted parking spaces. In addition, each tag may be for a specific reserved spot within the parking facility (which may match the human readable tag # on the tag). If authorized, then no action is taken and processing ceases. If not authorized, then in step 572 the log record parking attributes for that tag that does not have an exit time is updated with information about the unauthorized parking. This information may be later utilized to enact a parking fine or other punitive actions which may be stored in accounting information for the parking event. Then in step 574, a notification is sent of the parking violation. This notification may be sent to a security person of the parking administrator for action such as ticketing, putting a boot on the vehicle, or even towing depending on the severity of the unauthorized parking. This notification may also be sent to the tenant software for storage in the tenant database, for action to be taken by the tenant with the user of the tag such as a notification text sent to the user's mobile phone or an email to a manager of the user. Processing then ceases.
In step 580, the vehicle is exiting the parking facilities, so the log record for that tag that does not have an exit time is updated with the exit time. This allows for invoicing the tenant for the parking. It also allows one to determine how many vehicles are located within the parking facilities at any given time. Processing then ceases until the next tag is detected.
In step 620, a message is sent to the tenant database corresponding to the tenant #. This message includes the tag # and the tag ID. This allows the tenant database to generate a tag record as described below. Processing then ceases with regards to this tag until the tag is utilized for parking at a parking facility.
In step 660, it is determined whether the tag ID is within the parking administrative database. If not, then entry to the parking facilities is denied to the vehicle in step 662 and processing ceases. If yes, then the tenant database is queried for parking attributes associated with that tag ID in step 663. Then in step 664 it is determined from the parking attributes obtained from the tenant database whether the tag associated with that tag ID is authorized to park in the facility where the vehicle is entering. If not, then entry to the parking facilities is denied to the vehicle in step 662 and processing ceases. If yes, then in step 666 a record is created in the parking log database. This record will include the tag ID and the time of entry. Then in step 668 the vehicle is allowed entry to the parking facilities. Processing then ceases until the tag is again detected.
In step 670, the tenant database is queried such as through the tenant software to obtain the parking attributes for that vehicle. If the vehicle just entered the parking facility, that information may still be retained in memory and this step may be avoided. Then in step 672, it is determined from the parking attributes obtained from the tenant database whether the vehicle is authorized to park at the location it has parked. That is, RFID or other sensors may be located at special needs or other restricted parking spaces. In addition, each tag may be for a specific reserved spot within the parking facility (which may match the human readable tag # on the tag). If authorized, then no action is taken and processing ceases. If not authorized, then in step 672 the log record parking attributes for that tag, which does not have an exit time, is updated with information about the unauthorized parking. This information may be later utilized to enact a parking fine or other punitive actions. Then in step 674, a notification is sent of the parking violation. This notification may be sent to a security person of the parking administrator for action such as ticketing, putting a boot on the vehicle, or even towing depending on the severity of the unauthorized parking. This notification may also be sent to the tenant software for storage in the tenant database, for action to be taken with the user of the tag such as a notification text sent to the user's mobile phone or an email to a manager of the user. Processing then ceases.
In step 680, the vehicle is exiting the parking facilities, so the log record for that tag that does not have an exit time is updated with the exit time. This allows for invoicing the tenant for the parking. It also allows one to determine how many vehicles are located within the parking facilities at any given time. Processing then ceases until the next tag is detected.
A tenant ID 762 is an identifier of the tenant for identifying the tenant for which this record applies and for managing which tenant may access this record. Plan ID 764 is an identifier of an accounting plan selected by the tenant. For example, some plans may be static and only allow a certain number of parking spaces for certain parking lots at a given time. Other plans may be dynamic and allow extra parking spaces at a premium cost. Rather than having a detailed description of each plan in each record, an identifier is utilized instead which may be linked to an additional database with the plan details. Fixed 766 and variable 768 are standard limitations on the number of parking spaces allocated to a tenant at any given time. For example, a tenant may pay for 100 parking spaces at a low cost, but then will pay for an additional 20 spaces at any time at a premium cost should the need arise. Many other alternative configurations and types of data may be stored in this and other records.
In step 820, a message is sent to the tenant database corresponding to the tenant #. This message includes the tag # and the tag ID. This allows the tenant database to generate a tag record as described below. Processing then ceases with regards to this tag until a message is received in step 825 indicating that the tag has been activated (assigned to an employee or other authorized person). This message should include any parking attributes such as whether the user can park in certain restricted spaces. Then in step 828, the tag record in the parking administrative database is updated and the parking attributes updated to allow use of the parking tag by a user. Processing then ceases unless a subsequent message is received from the tenant software with updated parking attributes. Such updated attributes could include cancelling the parking tag and thereby revoking the parking privileges associated with that tag.
In step 860, it is determined whether the tag ID is within the parking administrative database. If not, then entry to the parking facilities is denied to the vehicle in step 862 and processing ceases. If yes, then in step 864 it is determined from the parking attributes and accounting information stored in the parking administrative database whether the tag associated with that tag ID and the vehicle ID is authorized to park in the facility where the vehicle is entering. If not, then entry to the parking facilities is denied to the vehicle in step 862 and processing ceases. If yes, then in step 866 a record is created in the parking log database. This record will include the tag ID, vehicle ID, the time of entry and any applicable accounting information. Then in step 868 the vehicle is allowed entry to the parking facilities. Processing then ceases until the tag is again detected.
In step 870, it is determined from the parking attributes stored in the parking administrative database whether the vehicle is authorized to park at the location it has parked. That is, RFID or other sensors may be located at special needs or other restricted parking spaces. In addition, each tag may be for a specific reserved spot within the parking facility (which may match the human readable tag # on the tag). In another example, the vehicle may be a large vehicle such as a truck and it may not be authorized to park in a parking space dedicated to small vehicles. If authorized, then no action is taken and processing ceases. If not authorized, then in step 872 the log record parking attributes for that tag that does not have an exit time is updated with information about the unauthorized parking. This information may be later utilized to enact a parking fine or other punitive actions and stored in accounting information for that parking event. Then in step 874, a notification is sent of the parking violation. This notification may be sent to a security person of the parking administrator for action such as ticketing, putting a boot on the vehicle, or even towing depending on the severity of the unauthorized parking. This notification may also be sent to the tenant software for storage in the tenant database, for action to be taken by the tenant with the user of the tag such as a notification text sent to the user's mobile phone or an email to a manager of the user. Processing then ceases.
In step 880, the vehicle is exiting the parking facilities, so the log record for that tag that does not have an exit time is updated with the exit time. This allows for invoicing the tenant for the parking. It also allows one to determine how many vehicles are located within the parking facilities at any given time. Processing then ceases until the next tag is detected.
A combination of the first, second and third embodiments may be utilized in combination. Some tenants or some parking areas may require vehicle IDs, some tenants may utilize different flows of information, etc. Other embodiments may also be utilized as appreciated by one of ordinary skill in the art.
Processing then continues to step 920 where the authorized person is queried whether he or she wants to see any accumulations of parking for the past accounting period (e.g., since the first of the current month). If yes, then in step 925, the parking accumulations are provided to the authorized person. Details of those accumulations may be provided depending on the specific implementation of the system. Processing then continues to step 930 where the authorized person is queried whether he or she wants to make any adjustments to the current parking plan and allocation. For example, the tenant may desire to increase the number of fixed parking spaces due to a recent increase in tenant headcount. The tenant may also want to add or remove specific parking lots that its users may utilize for parking. These types of changes can be accomplished by choosing a different parking plan or by increasing or decreasing fixed and variable parking space allocations. If yes in step 930, then in step 935 the user is allowed to make the desired changes. Processing then ceases unless other capabilities are added to the specific implementation.
Given the flexibility of maintaining detailed records on parking by tag and by vehicle ID, many alternative billing arrangements may be utilized. For example, a tenant may be allowed a certain number of parking spaces at any given time for a fixed price per month. However, if that number is exceeded, then the tenant may be billed an additional charge for the excessive parking. Information can be provided to each tenant on an as needed or a periodic basis regarding the parking by vehicle with tags authorized by that tenant. This type of audit trail can be utilized to support billing to the tenant, but may also be useful by the tenant to identify parking trends by employees. Guests may be allowed to utilize temporary tags which may be assigned by a tenant or by the use of kiosks. However, such temporary tags may have greater parking restrictions due to security issues. For example, users with temporary tags may be required to park in designated visitor areas.
The invention can take the form of an entirely software embodiment, or an embodiment containing both hardware and software elements. In a preferred embodiment, the embodiments are implemented in software or program code, which includes but is not limited to firmware, resident software, and microcode.
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, microcode, 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, electromagnetic, 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. Further, a computer storage medium may contain or store a computer-readable program code such that when the computer-readable program code is executed on a computer, the execution of this computer-readable program code causes the computer to transmit another computer-readable program code over a communications link. This communications link may use a medium that is, for example without limitation, physical or wireless.
A data processing system suitable for storing and/or executing program code will include at least one processor coupled directly or indirectly to memory elements through a system bus. The memory elements can include local memory employed during actual execution of the program code, bulk storage media, and cache memories, which provide temporary storage of at least some program code in order to reduce the number of times code must be retrieved from bulk storage media during execution.
A data processing system may act as a server data processing system or a client data processing system. Server and client data processing systems may include data storage media that are computer usable, such as being computer readable. A data storage medium associated with a server data processing system may contain computer usable code such as for managing vehicle parking. A client data processing system may download that computer usable code, such as for storing on a data storage medium associated with the client data processing system, or for using in the client data processing system. The server data processing system may similarly upload computer usable code from the client data processing system such as a content source. The computer usable code resulting from a computer usable program product embodiment of the illustrative embodiments may be uploaded or downloaded using server and client data processing systems in this manner.
Input/output or I/O devices (including but not limited to keyboards, displays, pointing devices, etc.) can be coupled to the system either directly or through intervening I/O controllers.
Network adapters may also be coupled to the system to enable the data processing system to become coupled to other data processing systems or remote printers or storage devices through intervening private or public networks. Modems, cable modem and Ethernet cards are just a few of the currently available types of network adapters.
The description of the present invention has been presented for purposes of illustration and description, and 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. The embodiment was chosen and described in order to explain the principles of the invention, 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.
The terminology used herein is for the purpose of describing particular embodiments 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 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.