In some regions, a shipping address is not a reliable indicator of the actual location of a residence or office of a customer. For example, zip codes or other portions of shipping addresses may be incorrect, or postal delivery systems may be underdeveloped. As a consequence, shipments to addresses can be delayed due to the time needed for the courier to find the correct location of the residence or office. Also, shipments may become lost which results in concessions to customers and a poor customer experience.
Many aspects of the present disclosure can be better understood with reference to the following drawings. The components in the drawings are not necessarily to scale, emphasis instead being placed upon clearly illustrating the principles of the disclosure. Moreover, in the drawings, like reference numerals designate corresponding parts throughout the several views.
The present application describes various embodiments of systems and methods for courier management. For example, in some embodiments, a computing device generates geocode locations (e.g., a latitude and a longitude) based at least in part on customer locations. The computing device determines the portion of a carrier infrastructure in terms of carrier resources that are invoked to effect the delivery of a package that includes an item given the address or geocode of a customer who is to receive a shipment. Ultimately, the resources that make up the portion of the carrier infrastructure are printed on a shipping label with the customer address/geocode to help guide the carrier in shipping a package including one or more items. Such information is particularly useful in regions where shipping addresses or zip codes are sometimes unreliable, and/or where carrier operations may be less than optimal. In the following discussion, a general description of the system and its components is provided, followed by a discussion of the operation of the same.
With reference to
The computing device 103 may comprise, for example, a server computer or any other system providing computing capability. Alternatively, a plurality of computing devices 103 may be employed that are arranged, for example, in one or more server banks or computer banks or other arrangements. For example, a plurality of computing devices 103 together may comprise a networked computing resource, a grid computing resource, and/or any other distributed computing arrangement. Such computing devices 103 may be located in a single installation or may be distributed among many different geographical locations. For purposes of convenience, the computing device 103 is referred to herein in the singular. Even though the computing device 103 is referred to in the singular, it is understood that a plurality of computing devices 103 may be employed in the various arrangements as described above.
Various applications and/or other functionality may be executed in the computing device 103 according to various embodiments. Also, various data is stored in a data store 116 that is accessible to the computing device 103. The data store 116 may be representative of a plurality of data stores as can be appreciated. The data stored in the data store 116, for example, is associated with the operation of the various applications and/or functional entities described below.
The components executed on the computing device 103, for example, include applications 119 such as a carrier management application 123 and, in some embodiments, an electronic commerce application 126. The components executed on the computing device 103 may further include a network interface application(s) 129 as well as other applications, services, processes, systems, engines, or functionality not discussed in detail herein. The network interface application 129 may comprise, for example, a front end web server or other networking application.
The electronic commerce application 126 is executed in order to facilitate the online purchase of items 143 over the network 109. The electronic commerce application 126 also performs various backend functions associated with the online presence of a merchant in order to facilitate the online purchase of items 143. For example, the electronic commerce application 126 generates network pages such as web pages or other types of network content that are provided to clients 106 for the purposes of selecting items for purchase, rental, download, lease, or other form of consumption. It should be noted that the electronic commerce application 126 and the carrier management application 123 are operated by or on the behalf of a merchant that sells items 143 through the network.
The data stored in the data store 116 includes, for example, items 143. As used herein, the term “item” 143 may refer to a product, good, or other item 143 that may be offered for sale, purchase, rental, lease, and/or another form of consumption as may be appreciated. Ultimately, one or more items 143 may be included in a package that is delivered to a customer. The items 143 may be stored in a catalog for purchase through the electronic commerce application 126 as can be appreciated. Also, the data store 116 stores information associated with customers 146 such as customer location(s) 149, geocode location(s) 151, and other information related to customers 146. Such other information may include, purchase histories, payment instrument information, browse histories, billing addresses, product preferences, personal profile information, and other information. The customer locations 149 may comprise, for example, a customer address or other location information. A geocode location 151 is a location that may be expressed in various forms. In one embodiment, a geocode location 151 may be expressed as a latitudinal value and a longitudinal value. Also, a geocode location 151 may be expressed in terms of an elevation in situations where customers live in units, for example in a high rise building. Also, various information may be associated with a geocode location 151 such as the name and age of an occupant, or other information. In some cases, a geocode location 151 may be based at least in part on a customer location 149.
The customer location 149 is associated with a customer explicitly or implicitly from a client 106. As an example of an explicit association, in some embodiments, the customer location 149 is a shipping address provided by a customer 146. Specifically, the customer location 149 may be obtained from a customer input on a network page such as entry of an address, clicking on a specific point on a graphical map, or some other action that explicitly provides the geographic location. The entered customer location 149 is associated with the customer 146 in the data store 116.
The customer location 149 may be provided implicitly as well using information such as an internet protocol (IP) address, a telephone number, and/or other information. Further, the client 106 may include a global positioning system (GPS) device or may determine a current location of the customer by way of trilateration using various other mobile base stations having known locations. Alternatively, in some embodiments, a customer location 149 may be stored on the computing device 103 because the customer 146 may have previously registered with the electronic commerce application 126. As such, an identification of the customer, for example, through cookies, security credentials, etc., may point to a customer location 149 corresponding to a customer 146.
The data store 116 further stores information related to carriers that ship packages containing items 143 sold by a merchant to customers 146. The carrier will have a carrier infrastructure 153 to accomplish the delivery of packages containing items 143 to customers 146. In one approach, the carrier may be a separate entity from the merchant or the merchant may act as their own carrier.
The carrier infrastructure 153 may include one or more materials handling facilities 156. A materials handling facility 156 may comprise, for example, a warehouse, distribution center, cross-docking facility, order fulfillment center (also referred to as a fulfillment facility), packaging facility, shipping facility, brick-and-mortar stores, retail outlets, or other facility or combination of facilities for performing one or more functions of material or inventory handling.
The materials handling facilities 156 are located at various materials handling facility locations 159. According to one embodiment, each materials handling facility 156 services a geographical area 163. Each geographical area 163 may include one or more service areas 166 that may be serviced by one or more couriers 173. In addition, couriers 173 may be assigned specific delivery routes 176 to follow. In one embodiment, such routes 176 are determined just before deliveries are to be made. Alternatively, it may be the case that some couriers 173 are assigned the same route 176 each day. According to various embodiments, one or more portions of the carrier infrastructure 153 are identified and placed on a shipping label 179 to assist the carrier in delivering packages containing items 143 as will be described.
The couriers 173 ultimately perform various courier task(s) in a service area 166 or along a route 176. A courier task may include a delivery of a package to a customer 146, a pick-up of at least one item 143, or other types of tasks.
In addition, the activity of a courier 173 causes the generation of courier events that may comprise, for example, the successful delivery of a package containing one or more items 143 to a customer 146, the successful pickup of at least one item 143 from a customer 146, an arrival or departure of a package containing one or more items 143 to or from a service area 166, materials handling facility 156, or geographical area 163, a failure to deliver or pick-up an item 143 at a customer location 149, and other events related to the activity of a courier 173. In some embodiments, a courier event 164 is associated with a customer location 149.
The client 106 is coupled to the network 109. The client 106 may comprise, for example, a processor-based system such as computer system. Such a computer system may be embodied in the form of a desktop computer, a laptop computer, a personal digital assistant, a cellular telephone, a set-top box, a music player, a web pad, a tablet computer system, or other devices with like capability. To this end, the client 106 may comprise a mobile computing device as can be appreciated. Additionally, the client 106 may include, for example, a keyboard, a keypad, a touch pad, a touch screen, a microphone, a scanner, a mouse, a joystick, or one or more push buttons, etc. The client 106 may also include display devices, indicator lights, speakers, etc. Examples of display devices are cathode ray tubes (CRTs), liquid crystal display (LCD) screens, gas plasma-based flat panel displays, LCD projectors, or other types of display devices, etc. A client 106 may be configured to execute various applications such as a browser, email applications, instant message applications, and/or other applications.
Moving now to
Further shown are geocode locations 151 (
It should be noted that the geographical areas 163 and the service areas 166 may take any shape and are likely to depend upon geography, government boundaries, or other features of a given area.
In an additional alternative, a merchant may choose to employ mobile materials handling facilities 156 that operate out of an appropriate delivery vehicle. Such mobile materials handling facilities 156 may be stocked with high velocity items 143 that are expected to be sold in various geographical areas 163 or service areas 166. Such mobile materials handling facilities 156 may be deployed for immediate delivery of orders for items 143 in a predefined geographical area 163 or service area 166. Orders for items 143 that are received through the electronic commerce application 126 may be forwarded to fulfillment agents operating the mobile materials handling facilities 156.
Turning to
Referring next to
The functionality of the courier management application described below assumes that a plurality of geocode locations 151 (
In some embodiments, a geocode location 151 may be generated by a client 106 such as a mobile computing device associated with a courier 173 (
With specific reference to
Turning then to
In cases where the carrier is an independent entity that services customers other than the merchant operating the electronic commerce application 126, the functionality of
According to one embodiment, another example of functionality of the carrier management application 123 is described below with reference to
Beginning at box 403, the carrier management application 123 receives an input of an identifier associated with a shipment such as an order number or other identifier. Such an identifier may be input by an operator using a scanner, keyboard, or other input device as can be appreciated. In one embodiment, the operator may be packing the shipment in a fulfillment center, where the shipment is provided to a carrier for delivery to a customer 146.
Thereafter, in box 406, the carrier management application 123 retrieves the geocode location 151 associated with the customer to which the shipment is to be shipped. This is done because in some countries, it may be the case that the geocode location 151 is a much more reliable indication of where a shipment is to be delivered given inaccuracies in the address infrastructure of such countries.
Next, in box 409, the carrier management application 123 determines the points of the carrier infrastructure 153 that are invoked based on the geocode location 151. Specifically, portions of the carrier infrastructure 153 are invoked when they would be used or are otherwise involved in the delivery of a shipment of one or more items 143. Such portions of the carrier infrastructure 153 may comprise, for example, materials handling facilities 156, service areas 166, routes 176, couriers 173, and other aspects of a carrier infrastructure 153 as described above. In the case that delivery routes 176 have been precalculated, then the portions of the carrier infrastructure 153 that may be identified may include the delivery route 176 and the courier 173 that is to make the delivery of a package containing one or more items 143 as described above. Where the carrier is an independent entity, this level of information about the carrier infrastructure 153 may not be known unless it is provided by the carrier. In such case, the carrier would have to calculate delivery routes 176 based on deliveries to be made that were given to the carrier for such calculation provided that the carrier could make such calculations given that other entities may request the services of the carrier to deliver in the same areas.
Thereafter, in box 413, a shipping label is generated with the customer location 149, geocode location 151 and other portions or components of the carrier infrastructure identified in box 409 that were invoked by, or to be employed for, the delivery of the shipment of one or more items 143. Then, in box 416, the shipping label 179 is printed to be placed on the shipment, or the same is stored for future printing when items 143 are packaged for shipment. In one embodiment, the shipping label 179 may be forwarded in digital form to a carrier indicating that a certain mobile materials handling facility 156 is to be employed for a given delivery so that high velocity items 143 may be delivered immediately after being ordered through the electronic commerce application 126. Thereafter, this portion of the carrier management application 123 ends as shown.
With reference to
Stored in the memory 506 are both data and several components that are executable by the processor 503. In particular, stored in the memory 506 and executable by the processor 503 are applications 119 such as the electronic commerce application 126, the carrier management application 123, and potentially other applications 119. Also stored in the memory 506 may be a data store 116 and other data. In addition, an operating system 513 may be stored in the memory 506 and executable by the processor 503.
It is understood that there may be other applications that are stored in the memory 506 and are executable by the processors 503 as can be appreciated. Where any component discussed herein is implemented in the form of software, any one of a number of programming languages may be employed such as, for example, C, C++, C#, Objective C, Java, Javascript, Perl, PHP, Visual Basic, Python, Ruby, Delphi, Flash, or other programming languages.
A number of software components are stored in the memory 506 and are executable by the processor 503. In this respect, the term “executable” means a program file that is in a form that can ultimately be run by the processor 503. Examples of executable programs may be, for example, a compiled program that can be translated into machine code in a format that can be loaded into a random access portion of the memory 506 and run by the processor 503, source code that may be expressed in proper format such as object code that is capable of being loaded into a random access portion of the memory 506 and executed by the processor 503, or source code that may be interpreted by another executable program to generate instructions in a random access portion of the memory 506 to be executed by the processor 503, etc. An executable program may be stored in any portion or component of the memory 506 including, for example, random access memory (RAM), read-only memory (ROM), hard drive, solid-state drive, USB flash drive, memory card, optical disc such as compact disc (CD) or digital versatile disc (DVD), floppy disk, magnetic tape, or other memory components.
The memory 506 is defined herein as including both volatile and nonvolatile memory and data storage components. Volatile components are those that do not retain data values upon loss of power. Nonvolatile components are those that retain data upon a loss of power. Thus, the memory 506 may comprise, for example, random access memory (RAM), read-only memory (ROM), hard disk drives, solid-state drives, USB flash drives, memory cards accessed via a memory card reader, floppy disks accessed via an associated floppy disk drive, optical discs accessed via an optical disc drive, magnetic tapes accessed via an appropriate tape drive, and/or other memory components, or a combination of any two or more of these memory components. In addition, the RAM may comprise, for example, static random access memory (SRAM), dynamic random access memory (DRAM), or magnetic random access memory (MRAM) and other such devices. The ROM may comprise, for example, a programmable read-only memory (PROM), an erasable programmable read-only memory (EPROM), an electrically erasable programmable read-only memory (EEPROM), or other like memory device.
Also, the processor 503 may represent multiple processors and the memory 506 may represent multiple memories that operate in parallel processing circuits, respectively. In such a case, the local interface 509 may be an appropriate network 109 (
Although the applications 119 including the carrier management application 123, the electronic commerce application 126, and other various systems described herein may be embodied in software or code executed by general purpose hardware as discussed above, as an alternative the same may also be embodied in dedicated hardware or a combination of software/general purpose hardware and dedicated hardware. If embodied in dedicated hardware, each can be implemented as a circuit or state machine that employs any one of or a combination of a number of technologies. These technologies may include, but are not limited to, discrete logic circuits having logic gates for implementing various logic functions upon an application of one or more data signals, application specific integrated circuits having appropriate logic gates, or other components, etc. Such technologies are generally well known by those skilled in the art and, consequently, are not described in detail herein.
The flowcharts of
Although the flowcharts of
Also, any logic or application described herein, including the carrier management application 123, that comprises software or code can be embodied in any non-transitory computer-readable medium for use by or in connection with an instruction execution system such as, for example, a processor in a computer system or other system. In this sense, the logic may comprise, for example, statements including instructions and declarations that can be fetched from the computer-readable medium and executed by the instruction execution system. In the context of the present disclosure, a “computer-readable medium” can be any medium that can contain, store, or maintain the logic or application described herein for use by or in connection with the instruction execution system. The computer-readable medium can comprise any one of many physical media such as, for example, magnetic, optical, or semiconductor media. More specific examples of a suitable computer-readable medium would include, but are not limited to, magnetic tapes, magnetic floppy diskettes, magnetic hard drives, memory cards, solid-state drives, USB flash drives, or optical discs. Also, the computer-readable medium may be a random access memory (RAM) including, for example, static random access memory (SRAM) and dynamic random access memory (DRAM), or magnetic random access memory (MRAM). In addition, the computer-readable medium may be a read-only memory (ROM), a programmable read-only memory (PROM), an erasable programmable read-only memory (EPROM), an electrically erasable programmable read-only memory (EEPROM), or other type of memory device.
It should be emphasized that the above-described embodiments of the present disclosure are merely possible examples of implementations set forth for a clear understanding of the principles of the disclosure. Many variations and modifications may be made to the above-described embodiment(s) without departing substantially from the spirit and principles of the disclosure. All such modifications and variations are intended to be included herein within the scope of this disclosure and protected by the following claims.