Example embodiments of the present disclosure relate generally to the field of computer technology and, more specifically, to providing and using a mean from a heavy tail distribution
Websites provide a number of publishing, listing, and price-setting mechanisms whereby a publisher (e.g., a seller) may list or publish information concerning items for sale on its site, and where a visitor may view items on the site. The experience of the visitor may vary based on the user interface provided. In one instance, one sample of visitors to the site may be a different experience than another sample of visitors, perhaps by using a different search algorithm to rank products listed.
Various ones of the appended drawings merely illustrate example embodiments of the present disclosure and are not to be considered to be limiting its scope.
The description that follows includes systems, methods, techniques, instruction sequences, and computing machine program products that embody illustrative embodiments of the present disclosure. In the following description, for purposes of explanation, numerous specific details are set forth in order to provide an understanding of various embodiments of the inventive subject matter. It will be evident, however, to those skilled in the art that embodiments of the disclosed subject matter may be practiced without these specific details. In general, well-known instruction instances, protocols, structures, and techniques have not been shown in detail.
As used herein, the term “or” may be construed in either an inclusive or exclusive sense. Additionally, although various example embodiments discussed below focus on a network-based publication environment, the embodiments are given merely for clarity in disclosure. Thus, any type of electronic publication, electronic commerce, or electronic business system and method, including various system architectures, may employ various embodiments of the listing creation system and method described herein and be considered as being within a scope of the example embodiments. Each of a variety of example embodiments is discussed in detail below.
Example embodiments described herein provide systems and methods to provide improved user experience when visiting a publication system site. This may be done by determining from data sets of the publication system's data logs of visitors, using the appropriate analytics, the “gross merchandise bought” on the site, referred to herein “GMB.” GMB may be viewed as an indicator of total gross revenue for the site. In order to maximize the probability of increased gross revenue, one sample of visitors to the site may be given a different user experience than another sample of visitors. For example, different search algorithms may be used to rank products listed, for different samples of visitors. The sample with the highest mean gross revenue would be considered to have the best site experience, and that site experience could then be applied to all visitors to the site going forward as a method of achieving improved revenue.
GMB may be estimated using the GMB dataset mean, a statistic that is subject to great variability and thus usually requires a huge volume of test data to achieve required precision. Sampling distributions that are more tightly distributed are said to be more “efficient” than sampling distributions that are more spread out, and the more efficient a sampling distribution is, the fewer observations that are needed in a sample to get a reliable estimate of the mean. In short, if there is an efficient estimator for the mean, discussed in more detail below, there is less concern about the estimated means varying significantly from one sample to the next solely from random sampling error.
Data sets may be partitioned into two subgroups (or “components”), a “torso” component and a “tail” component. For the “tail” component of the data a more efficient estimator can be obtained (versus the traditionally calculated mean) by using the tail data to estimate parameters from a specific distribution and then deriving the mean from the estimated parameters. The estimated mean from the torso and the estimated mean from the tail may then be combined to obtain the estimated mean for the full data. Because there is now a more efficient estimator for the tail, a more efficient estimator for the full distribution is obtained. This can be applied to gross merchandise bought by various samples of visitors and apply the experience that was provided to the sample with the highest GMB to all visitors to increase gross revenue.
With reference to
The client devices 110 and 112 may comprise a mobile phone, desktop computer, laptop, or any other communication device that a user may utilize to access the networked system 102. In some embodiments, the client devices 110 may comprise or be connectable to an image capture device (e.g., camera). The client device 110 may also comprise a voice recognition module (not shown) to receive audio input and a display module (not shown) to display information (e.g., in the form of user interfaces). In further embodiments, the client device 110 may comprise one or more of a touch screen, an accelerometer, and a Global Positioning System (GPS) device.
An Application Program Interface (API) server 114 and a web server 116 are coupled to, and provide programmatic and web interfaces respectively to, one or more application servers 118. The application servers 118 host a publication system 120 and a payment system 122, each of which may comprise one or more modules, applications, or engines, and each of which may be embodied as hardware, software, firmware, or any combination thereof. The application servers 118 are, in turn, coupled to one or more database servers 124 facilitating access to one or more information storage repositories or database(s) 126. In one embodiment, the databases 126 may comprise a knowledge database that may be updated with content, user preferences, and user interactions (e.g., feedback, surveys, etc.).
The publication system 120 publishes content on a network (e.g., the Internet). As such, the publication system 120 provides a number of publication and marketplace functions and services to users that access the networked system 102. The publication system 120 is discussed in more detail in connection with
The payment system 122 provides a number of payment services and functions to users. The payment system 122 allows users to accumulate value (e.g., in a commercial currency, such as the U.S. dollar, or a proprietary currency, such as “points”) in accounts, and then later to redeem the accumulated value for products (e.g., goods or services) that are made available via the publication system 120. The payment system 122 also facilitates payments from a payment mechanism (e.g., a bank account, PayPal account, or credit card) for purchases of items via the network-based marketplace. While the publication system 120 and the payment system 122 are shown in
While the example network architecture 100 of
Referring now to
In one embodiment, the publication system 120 provides a number of publishing, listing, and price-setting mechanisms whereby a seller may list (or publish information concerning) goods or services for sale, a buyer can express interest in or indicate a desire to purchase such goods or services, and a price can be set for a transaction pertaining to the goods or services. To this end, the publication system 120 may comprise at least one publication engine 202 and one or more auction engines 204 that support auction-format listing and price setting mechanisms (e.g., English, Dutch, Chinese, Double, reverse auctions, etc.). The various auction engines 204 also provide a number of features in support of these auction-format listings, such as a reserve price feature whereby a seller may specify a reserve price in connection with a listing and a proxy-bidding feature whereby a bidder may invoke automated proxy bidding.
A pricing engine 206 supports various price listing formats. One such format is a fixed-price listing format (e.g., the traditional classified advertisement-type listing or a catalog listing). Another format comprises a buyout-type listing. Buyout-type listings (e.g., the Buy-It-Now (BIN) technology developed by eBay Inc., of San Jose, Calif.) may be offered in conjunction with auction-format listings and may allow a buyer to purchase goods or services, which are also being offered for sale via an auction, for a fixed price that is typically higher than a starting price of an auction for an item.
A store engine 208 allows a seller to component listings within a “virtual” store, which may be branded and otherwise personalized by and for the seller. Such a virtual store may also offer promotions, incentives, and features that are specific and personalized to the seller. In one example, the seller may offer a plurality of items as Buy-It-Now items in the virtual store, offer a plurality of items for auction, or a combination of both.
A reputation engine 210 allows users that transact, utilizing the networked system 102, to establish, build, and maintain reputations. These reputations may be made available and published to potential trading partners. Because the publication system 120 supports person-to-person trading between unknown entities, users may otherwise have no history or other reference information whereby the trustworthiness and credibility of potential trading partners may be assessed. The reputation engine 210 allows a user, for example through feedback provided by one or more other transaction partners, to establish a reputation within the network-based publication system over time. Other potential trading partners may then reference the reputation for purposes of assessing credibility and trustworthiness.
Mean estimation in the network-based publication system may be facilitated by a means estimation engine 212. For example, broad operation of the mean estimation engine 212 would include loading into a server experimental GMB data that includes a heavy tail, dividing the data into components, and defining the tail component. The random sampling may be with replacement. Distribution moments may be calculated and these moments may be used to calculate the moments for the combined distribution. A standard error may be calculated and, if desired, an output simulation summary may be generated.
Continuing with a discussion of
A listing creation engine 216 allows sellers to conveniently author listings of items. In one embodiment, the listings pertain to goods or services that a user (e.g., a seller) wishes to transact via the publication system 120. In other embodiments, a user may create a listing that is an advertisement or other form of publication.
A listing management engine 218 allows sellers to manage such listings. Specifically, where a particular seller has authored or published a large number of listings, the management of such listings may present a challenge. The listing management engine 218 provides a number of features (e.g., auto-relisting, inventory level monitors, etc.) to assist the seller in managing such listings.
A post-listing management engine 220 also assists sellers with a number of activities that typically occur post-listing. For example, upon completion of an auction facilitated by the one or more auction engines 204, a seller may wish to leave feedback regarding a particular buyer. To this end, the post-listing management engine 220 provides an interface to the reputation engine 210 allowing the seller to conveniently provide feedback regarding multiple buyers to the reputation engine 210.
A messaging engine 222 is responsible for the generation and delivery of messages to users of the networked system 102. Such messages include, for example, advising users regarding the status of listings and best offers (e.g., providing an acceptance notice to a buyer who made a best offer to a seller). The messaging engine 222 may utilize any one of a number of message delivery networks and platforms to deliver messages to users. For example, the messaging engine 222 may deliver electronic mail (e-mail), an instant message (IM), a Short Message Service (SMS), text, facsimile, or voice (e.g., Voice over IP (VoIP)) messages via wired networks (e.g., the Internet), a Plain Old Telephone Service (POTS) network, or wireless networks (e.g., mobile, cellular, WiFi, WiMAX).
Although the various components of the publication system 120 have been defined in terms of a variety of individual modules and engines, a skilled artisan will recognize that many of the items can be combined or organized in other ways. Furthermore, not all components of the publication system 120 have been included in
There is nothing significant or special about the torso, per se, in the context of this patent. What is significant and noteworthy is that the data can be split into a “torso” component and a “tail” component, a parametric fitting can be applied to the tail data that provides a more efficient estimate of the tail mean than is traditionally estimated, and then the estimates of the torso mean and tail mean can be combined to get an estimate of the mean for the full data that is more efficient than the traditionally estimated mean of the full data. The parametric fitting of the tail may be done by standard maximum likelihood estimation methods that require maximization of a nonlinear function by a derivative based algorithm. One algorithm that may be used is the Newton-Raphson method. The Newton-Raphson algorithm is a method for solving a nonlinear optimization problem based upon optimizing a quadratic approximation of the function (the “maximand”) using first and second derivatives. The quadratic approximation to the function is a second order Taylor Series expansion of the function around some initial estimate. This procedure is iterated to convergence with the estimates produced at the final iteration serving as the maximum likelihood estimates of the Weibull (in the current instance) fit to the tail data. These estimates, which are based upon a numerical or analytical evaluation of the derivatives of the loglikelihood function at the point of convergence, form the basis for computing the mean and variance of the tail data. The “fitting” of the torso is just a simple calculation of the standard arithmetic mean and variance/standard error of that segment of the data. The method discussed results in significantly smaller sample sizes achieving essentially the same statistical power as from larger samples that use traditional techniques.
The partitioning of a data set, here GMB, into components may be done by selecting a fixed cut-off value for the “torso” and “tail” segments (e.g. $300) and putting all values greater than $300 into the “tail”. In an alternate embodiment, the cut point may be determined empirically by selecting a value that jointly minimizes bias (squared) and variance. This latter quantity is called Mean Squared Error by statisticians and serves as a criterion by which cut-points can be empirically selected for the torso and tail components since a fixed cut-point will not be optimal for all datasets.
In other words, when multiplied by one-hundred (100), lift gives a percent change due to treatment. It has been shown by analyses that the torso-tail estimator improves accuracy and precision when compared with other estimators.
As mentioned above, for the “tail” component of the data a more efficient estimator can be obtained (versus the traditionally calculated mean) by using the tail data to estimate parameters for a specific distribution and then deriving the mean from the estimated parameters. This can be seen from tail 503 of
In
The bootstrap statistical simulation module 610 is so-named in accordance with B. Efron & R. J. Tibshirani, An Introduction to the Bootstrap, Chapman & Hall, 1993, p. 5, “the use of the term bootstrap derives from the phrase to pull oneself up by one's bootstrap”. In the current instance, the bootstrap statistical module 610 is letting the data pull itself up by its bootstraps using resampling methods. More practically, the bootstrap is a resampling method used to provide information about the sampling distribution of the mean whereby standard errors and confidence intervals can be calculated by using appropriate resampling methods. Other methods in addition to bootstrapping may be used.
Bootstap statistical simulation module 610 includes random sampling of the data set with replacement 612. In the “bootstrap with replacement” case, after a number is sampled, it is placed back into the mix and can be sampled more than once. Maximum likelihood estimation, 614 which is a statistical estimation procedure that selects those values for the parameters that maximizes the probability of having actually generated the sample data given the distributional assumptions, is performed on the tail data. In other words, maximum likelihood estimation may be viewed as finding those values for the parameters that were most likely to have generated the sample data, given assumptions about the underlying data generating process, which in this case is the Weibull assumption.
Bootstrap statistical simulation module 610 then generates moments for the distribution at moment generating function 612. Moments are statistical quantities of interest associated with any probability distribution. A moment generating function, such as at 612, is a technical mathematical method of calculating moments, which characterize or describe a distribution. For example, the first moment of a distribution is the mean or average value of the distribution, and can be viewed intuitively as a “point of balance”. The second central moment of a distribution is the variance and can be viewed intuitively as a measure of the “spread” of the data. The third central moment is skewness, and the fourth central moment is kurtosis, and so on. These latter moments measure the asymmetry and “fatness” of tails of a distribution, respectively. Stated another way, moment generating functions are a technical mathematical method allowing calculation of these “moments” of interest, but moments like means and variances are substantively important quantities for understanding test results. At 618 are seen moments for the combined distribution which are means and variances from the torso tail method which are of interest since they provide the averages and standard errors needed for evaluating test outcomes.
Post-Processing Simulation Module 620 of mean estimation engine 212 of
Additionally, certain embodiments described herein may be implemented as logic or a number of modules, engines, components, or mechanisms. A module, engine, logic, component, or mechanism (collectively referred to as a “module”) may be a tangible unit capable of performing certain operations and configured or arranged in a certain manner. In certain example embodiments, one or more computer systems (e.g., a standalone, client, or server computer system) or one or more components of a computer system (e.g., a processor or a group of processors) may be configured by software (e.g., an application or application portion) or firmware (note that software and firmware can generally be used interchangeably herein as is known by a skilled artisan) as a module that operates to perform certain operations described herein.
In various embodiments, a module may be implemented mechanically or electronically. For example, a module may comprise dedicated circuitry or logic that is permanently configured (e.g., within a special-purpose processor, application specific integrated circuit (ASIC), or array) to perform certain operations. A module may also comprise programmable logic or circuitry (e.g., as encompassed within a general-purpose processor or other programmable processor) that is temporarily configured by software or firmware to perform certain operations. It will be appreciated that a decision to implement a module mechanically, in dedicated and permanently configured circuitry, or in temporarily configured circuitry (e.g., configured by software) may be driven by, for example, cost, time, energy-usage, and package size considerations.
Accordingly, the term “module” should be understood to encompass a tangible entity, be that an entity that is physically constructed, permanently configured (e.g., hardwired), or temporarily configured (e.g., programmed) to operate in a certain manner or to perform certain operations described herein. Considering embodiments in which modules or components are temporarily configured (e.g., programmed), each of the modules or components need not be configured or instantiated at any one instance in time. For example, where the modules or components comprise a general-purpose processor configured using software, the general-purpose processor may be configured as respective different modules at different times. Software may accordingly configure the processor to constitute a particular module at one instance of time and to constitute a different module at a different instance of time.
Modules can provide information to, and receive information from, other modules. Accordingly, the described modules may be regarded as being communicatively coupled. Where multiples of such modules exist contemporaneously, communications may be achieved through signal transmission (e.g., over appropriate circuits and buses) that connect the modules. In embodiments in which multiple modules are configured or instantiated at different times, communications between such modules may be achieved, for example, through the storage and retrieval of information in memory structures to which the multiple modules have access. For example, one module may perform an operation and store the output of that operation in a memory device to which it is communicatively coupled. A further module may then, at a later time, access the memory device to retrieve and process the stored output. Modules may also initiate communications with input or output devices and can operate on a resource (e.g., a collection of information).
With reference to
The example computer system 700 may include a processor 702 (e.g., a central processing unit (CPU), a graphics processing unit (GPU) or both), a main memory 704 and a static memory 706, which communicate with each other via a bus 707. The computer system 700 may further include a video display unit 710 (e.g., a liquid crystal display (LCD) or a cathode ray tube (CRT)). In example embodiments, the computer system 700 also includes one or more of an alpha-numeric input device 712 (e.g., a keyboard), a user interface (UI) navigation device or cursor control device 714 (e.g., a mouse), a disk drive unit 716, a signal generation device 718 (e.g., a speaker), and a network interface device 720.
The disk drive unit 716 includes a machine-readable storage medium 722 on which is stored one or more sets of instructions 724 and data structures (e.g., software instructions) embodying or used by any one or more of the methodologies or functions described herein. The instructions 724 may also reside, completely or at least partially, within the main memory 704 or within the processor 702 during execution thereof by the computer system 700, with the main memory 704 and the processor 702 also constituting machine-readable media.
While the machine-readable storage medium 722 is shown in an example embodiment to be a single medium, the term “machine-readable storage medium” may include a single storage medium or multiple storage media (e.g., a centralized or distributed database, or associated caches and servers) that store the one or more instructions. The term “machine-readable storage medium” shall also be taken to include any tangible medium that is capable of storing, encoding, or carrying instructions for execution by the machine and that cause the machine to perform any one or more of the methodologies of embodiments of the present application, or that is capable of storing, encoding, or carrying data structures used by or associated with such instructions. The term “machine-readable storage medium” shall accordingly be taken to include, but not be limited to, solid-state memories and optical and magnetic media. Specific examples of machine-readable storage media include non-volatile memory, including by way of example semiconductor memory devices (e.g., Erasable Programmable Read-Only Memory (EPROM), Electrically Erasable Programmable Read-Only Memory (EEPROM), and flash memory devices); magnetic disks such as internal hard disks and removable disks; magneto-optical disks; and CD-ROM and DVD-ROM disks.
The instructions 724 may further be transmitted or received over a communications network 726 using a transmission medium via the network interface device 720 and utilizing any one of a number of well-known transfer protocols (e.g., Hypertext Transfer Protocol (HTTP)). Examples of communication networks include a local area network (LAN), a wide area network (WAN), the Internet, mobile telephone networks, Plain Old Telephone Service (POTS) networks, and wireless data networks (e.g., WiFi and WiMax networks). The term “transmission medium” shall be taken to include any intangible medium that is capable of storing, encoding, or carrying instructions for execution by the machine, and includes digital or analog communications signals or other intangible medium to facilitate communication of such software.
Although an overview of the inventive subject matter has been described with reference to specific example embodiments, various modifications and changes may be made to these embodiments without departing from the broader spirit and scope of embodiments of the present application. Such embodiments of the inventive subject matter may be referred to herein, individually or collectively, by the term “invention” merely for convenience and without intending to voluntarily limit the scope of this application to any single invention or inventive concept if more than one is, in fact, disclosed.
The embodiments illustrated herein are described in sufficient detail to enable those skilled in the art to practice the teachings disclosed. Other embodiments may be used and derived there from, such that structural and logical substitutions and changes may be made without departing from the scope of this disclosure. The Detailed Description, therefore, is not to be taken in a limiting sense, and the scope of various embodiments is defined only by the appended claims, along with the full range of equivalents to which such claims are entitled.
Moreover, plural instances may be provided for resources, operations, or structures described herein as a single instance. Additionally, boundaries between various resources, operations, modules, engines, and data stores are somewhat arbitrary, and particular operations are illustrated in a context of specific illustrative configurations. Other allocations of functionality are envisioned and may fall within a scope of various embodiments of the present application. In general, structures and functionality presented as separate resources in the example configurations may be implemented as a combined structure or resource. Similarly, structures and functionality presented as a single resource may be implemented as separate resources. These and other variations, modifications, additions, and improvements fall within a scope of embodiments of the present application as represented by the appended claims. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense.