Author: Edward Rothberg, PhD
Date: 2/24/2021
You may have heard the news that two American economists – Paul Milgrom and Robert Wilson – recently won the 2020 Nobel Prize in Economic Sciences “for improvements to auction theory and inventions of new auction formats.” The prize committee highlighted the fact that their work has resulted in “practical applications, which have spread globally” and “benefitted sellers, buyers and taxpayers around the world.”
Indeed, Milgrom and Wilson’s work has spurred numerous real-world auction applications across various industries including telecommunications and media. Their “best-known contribution,” in the eyes of the prize committee, is the auction they designed in the early 1990s that enables the U.S. government’s Federal Communications Commission (FCC) to sell radio frequencies to telecom operators. This incredibly complex spectrum allocation auction can be classified as a “combinatorial auction” problem — and this type of problem is typically solved using mathematical optimization techniques and technologies.
This mathematical optimization-based approach to auctioning radio frequencies is now utilized around the world by the regulatory agencies of various countries and has had a tremendous economic impact. In 2016, for instance, the FCC (using Milgrom and Wilson’s framework) conducted a combinatorial auction, which deployed a mathematical optimization solver (my company’s Gurobi Optimizer) to determine the best way to repurpose radio spectrum from broadcast television to wireless internet and generated nearly $20 billion in revenue — $7.3 billion of which went to the U.S. Treasury to reduce the federal deficit.
As a mathematical optimization software developer, I am proud of the part that this AI technology played in Milgrom and Wilson’s Nobel Prize-winning work. And this is not the first time mathematical optimization has had a hand in winning this prestigious award. Leonid Kantorovich and Tjalling Koopmans, for example, shared the Nobel Prize in Economics in 1975 for their contributions to optimal resource allocation, and Harry Markowitz received the award in 1990 for his work on optimal financial portfolio design.
With a history stretching back over 70 years, mathematical optimization has proven to be very effective in addressing some of the most challenging, high-stakes problems in the business world.
In this article, I will take a closer look at the combinatorial auction problem and explain what makes it so complex before exploring how it appears in various industries.
Everyone is familiar with the format of a simple, standard auction: A group of buyers bids on a particular item that is listed by a seller at a certain starting price, and the buyer with the highest bid takes home the item.
But in a combinatorial auction, participants can bid on combinations or “packages” of interrelated items — and this is where the complexity comes in. As the number of items for sale increases, the number of possible combinations grows exponentially.
Let’s say, for example, you are tasked with auctioning off radio frequencies in different parts of a country. Even if you simplify the problem by putting a fixed price on each frequency (so that bidders just have to pick a set of frequencies to bid on), you are still faced with massive complexity. If you only have three radio frequencies, there are eight possible bidding combinations. If you have four radio frequencies, there are 16 possible combinations. By the time you reach 265 radio frequencies, the number of possible combinations is actually more than the number of atoms in the universe!
It’s impossible for the human brain to comb through the astronomical number of possible packages of items in a combinatorial auction and identify the best one. This problem (known as the “winner determination problem”) requires the power of a mathematical optimization solver to sift through all the possible allocations of items and figure out which combination of bids maximizes total revenue (while also meeting other business objectives).
Besides telecommunications, combinatorial auctions can be found in numerous other industries.
Perhaps the most common example is in industrial procurement. Many leading global corporations today – across various industries including manufacturing, construction and retail — employ a combinatorial auction approach (and deploy mathematical optimization technologies) to handle their procurement operations and drive their sourcing decisions.
Whenever a company puts out an RFP for a package of items (products or services), suppliers place bids on providing a combination of these items — and they can tailor their bid to take into account their capacity, supply, inventory and other constraints as well as economies of scale.
To evaluate all the possible combinations of bids and make the best sourcing decisions (while considering multiple factors besides price including quantity, technical specifications, lead times and location), the company putting out the RFP must be able to run a combinatorial auction (or, to be more precise, a reverse combinatorial auction). Using a mathematical optimization tool, they can determine which combination of bids and allocation of contracts will enable them to get the goods and services they need (when and where they need them) at the lowest possible cost.
Another established use case of combinatorial auctions is in the truck transport industry, where shippers forecast loads and invite carriers to bid for their business. The carriers submit bids on sets of routes, and the shippers figure out the best combination of bids (in terms of price, service levels, geographic areas and other factors) and award contracts accordingly.
It’s interesting to note that all the combinatorial auction examples highlighted above are ultimately “winner determination problems.” Mathematical optimization’s ability to tackle this and other problem types that crop up over and over again is one of the main reasons this AI technology is part and parcel of the business world.
Mathematical optimization’s role as a key technological tool that helped Milgrom and Wilson win this year’s Nobel Prize in Economics is proof of this profound and positive real-world impact.
This article was originally published on Forbes.com here.
GUROBI NEWSLETTER
Latest news and releases
Choose the evaluation license that fits you best, and start working with our Expert Team for technical guidance and support.
Request free trial hours, so you can see how quickly and easily a model can be solved on the cloud.
Cookie | Duration | Description |
---|---|---|
_biz_flagsA | 1 year | A Cloudflare cookie set to record users’ settings as well as for authentication and analytics. |
_biz_pendingA | 1 year | A Cloudflare cookie set to record users’ settings as well as for authentication and analytics. |
_biz_sid | 30 minutes | This cookie is set by Bizible, to store the user's session id. |
ARRAffinity | session | ARRAffinity cookie is set by Azure app service, and allows the service to choose the right instance established by a user to deliver subsequent requests made by that user. |
ARRAffinitySameSite | session | This cookie is set by Windows Azure cloud, and is used for load balancing to make sure the visitor page requests are routed to the same server in any browsing session. |
BIGipServersj02web-nginx-app_https | session | NGINX cookie |
cookielawinfo-checkbox-advertisement | 1 year | Set by the GDPR Cookie Consent plugin, this cookie is used to record the user consent for the cookies in the "Advertisement" category . |
cookielawinfo-checkbox-analytics | 11 months | This cookie is set by GDPR Cookie Consent plugin. The cookie is used to store the user consent for the cookies in the category "Analytics". |
cookielawinfo-checkbox-functional | 11 months | The cookie is set by GDPR cookie consent to record the user consent for the cookies in the category "Functional". |
cookielawinfo-checkbox-necessary | 11 months | This cookie is set by GDPR Cookie Consent plugin. The cookies is used to store the user consent for the cookies in the category "Necessary". |
cookielawinfo-checkbox-others | 11 months | This cookie is set by GDPR Cookie Consent plugin. The cookie is used to store the user consent for the cookies in the category "Other. |
cookielawinfo-checkbox-performance | 11 months | This cookie is set by GDPR Cookie Consent plugin. The cookie is used to store the user consent for the cookies in the category "Performance". |
CookieLawInfoConsent | 1 year | Records the default button state of the corresponding category & the status of CCPA. It works only in coordination with the primary cookie. |
elementor | never | This cookie is used by the website's WordPress theme. It allows the website owner to implement or change the website's content in real-time. |
JSESSIONID | session | New Relic uses this cookie to store a session identifier so that New Relic can monitor session counts for an application. |
viewed_cookie_policy | 11 months | The cookie is set by the GDPR Cookie Consent plugin and is used to store whether or not user has consented to the use of cookies. It does not store any personal data. |
Cookie | Duration | Description |
---|---|---|
__cf_bm | 30 minutes | This cookie, set by Cloudflare, is used to support Cloudflare Bot Management. |
_biz_nA | 1 year | Bizible sets this cookie to remember users’ settings as well as for authentication and analytics. |
_biz_uid | 1 year | This cookie is set by Bizible, to store user id on the current domain. |
_hjAbsoluteSessionInProgress | 30 minutes | Hotjar sets this cookie to detect a user's first pageview session, which is a True/False flag set by the cookie. |
_mkto_trk | 2 years | This cookie is set by Marketo. This allows a website to track visitor behavior on the sites on which the cookie is installed and to link a visitor to the recipient of an email marketing campaign, to measure campaign effectiveness. Tracking is performed anonymously until a user self-identifies by submitting a form. |
bcookie | 1 year | LinkedIn sets this cookie from LinkedIn share buttons and ad tags to recognize browser ID. |
bscookie | 1 year | LinkedIn sets this cookie to store performed actions on the website. |
doc_langsBB | 1 year | Documentation system cookie |
doc_version | 1 year | Documentation system cookie |
lang | session | LinkedIn sets this cookie to remember a user's language setting. |
lidc | 1 day | LinkedIn sets the lidc cookie to facilitate data center selection. |
UserMatchHistory | 1 month | LinkedIn sets this cookie for LinkedIn Ads ID syncing. |
whova_client_id | 10 years | Event agenda system cookie |
Cookie | Duration | Description |
---|---|---|
_gat_UA-5909815-1 | 1 minute | A variation of the _gat cookie set by Google Analytics and Google Tag Manager to allow website owners to track visitor behaviour and measure site performance. The pattern element in the name contains the unique identity number of the account or website it relates to. |
Cookie | Duration | Description |
---|---|---|
_an_uid | 7 days | 6Sense Cookie |
_BUID | 1 year | This cookie, set by Bizible, is a universal user id to identify the same user across multiple clients’ domains. |
_ga | 2 years | The _ga cookie, installed by Google Analytics, calculates visitor, session and campaign data and also keeps track of site usage for the site's analytics report. The cookie stores information anonymously and assigns a randomly generated number to recognize unique visitors. |
_ga_* | 1 year 1 month 4 days | Google Analytics sets this cookie to store and count page views. |
_gat_UA-* | 1 minute | Google Analytics sets this cookie for user behaviour tracking. |
_gcl_au | 3 months | Provided by Google Tag Manager to experiment advertisement efficiency of websites using their services. |
_gd_session | 4 hours | This cookie is used for collecting information on users visit to the website. It collects data such as total number of visits, average time spent on the website and the pages loaded. |
_gd_visitor | 2 years | This cookie is used for collecting information on the users visit such as number of visits, average time spent on the website and the pages loaded for displaying targeted ads. |
_gid | 1 day | Installed by Google Analytics, _gid cookie stores information on how visitors use a website, while also creating an analytics report of the website's performance. Some of the data that are collected include the number of visitors, their source, and the pages they visit anonymously. |
_hjFirstSeen | 30 minutes | Hotjar sets this cookie to identify a new user’s first session. It stores the true/false value, indicating whether it was the first time Hotjar saw this user. |
_hjIncludedInSessionSample_* | 2 minutes | Hotjar cookie that is set to determine if a user is included in the data sampling defined by a site's daily session limit. |
_hjRecordingEnabled | never | Hotjar sets this cookie when a Recording starts and is read when the recording module is initialized, to see if the user is already in a recording in a particular session. |
_hjRecordingLastActivity | never | Hotjar sets this cookie when a user recording starts and when data is sent through the WebSocket. |
_hjSession_* | 30 minutes | Hotjar cookie that is set when a user first lands on a page with the Hotjar script. It is used to persist the Hotjar User ID, unique to that site on the browser. This ensures that behavior in subsequent visits to the same site will be attributed to the same user ID. |
_hjSessionUser_* | 1 year | Hotjar cookie that is set when a user first lands on a page with the Hotjar script. It is used to persist the Hotjar User ID, unique to that site on the browser. This ensures that behavior in subsequent visits to the same site will be attributed to the same user ID. |
_hjTLDTest | session | To determine the most generic cookie path that has to be used instead of the page hostname, Hotjar sets the _hjTLDTest cookie to store different URL substring alternatives until it fails. |
6suuid | 2 years | 6Sense Cookie |
AnalyticsSyncHistory | 1 month | LinkedIn cookie |
BE_CLA3 | 1 year 1 month 4 days | BrightEdge sets this cookie to enable data aggregation, analysis and report creation to assess marketing effectiveness and provide solutions for SEO, SEM and website performance. |
CONSENT | 2 years | YouTube sets this cookie via embedded youtube-videos and registers anonymous statistical data. |
dj | 10 years | DemandJump cookie |
djaimid.a28e | 2 years | DemandJump cookiean |
djaimses.a28e | 30 minutes | DemandJump cookie |
li_gc | 5 months 27 days | LinkedIn Cookie |
ln_or | 1 day | LinkedIn Cookie |
vuid | 2 years | Vimeo installs this cookie to collect tracking information by setting a unique ID to embed videos to the website. |
Cookie | Duration | Description |
---|---|---|
__adroll | 1 year 1 month | This cookie is set by AdRoll to identify users across visits and devices. It is used by real-time bidding for advertisers to display relevant advertisements. |
__adroll_fpc | 1 year | AdRoll sets this cookie to target users with advertisements based on their browsing behaviour. |
__adroll_shared | 1 year 1 month | Adroll sets this cookie to collect information on users across different websites for relevant advertising. |
__ar_v4 | 1 year | This cookie is set under the domain DoubleClick, to place ads that point to the website in Google search results and to track conversion rates for these ads. |
_fbp | 3 months | This cookie is set by Facebook to display advertisements when either on Facebook or on a digital platform powered by Facebook advertising, after visiting the website. |
_te_ | session | Adroll cookie |
fr | 3 months | Facebook sets this cookie to show relevant advertisements to users by tracking user behaviour across the web, on sites that have Facebook pixel or Facebook social plugin. |
IDE | 1 year 24 days | Google DoubleClick IDE cookies are used to store information about how the user uses the website to present them with relevant ads and according to the user profile. |
li_sugr | 3 months | LinkedIn sets this cookie to collect user behaviour data to optimise the website and make advertisements on the website more relevant. |
test_cookie | 15 minutes | The test_cookie is set by doubleclick.net and is used to determine if the user's browser supports cookies. |
VISITOR_INFO1_LIVE | 5 months 27 days | A cookie set by YouTube to measure bandwidth that determines whether the user gets the new or old player interface. |
YSC | session | YSC cookie is set by Youtube and is used to track the views of embedded videos on Youtube pages. |
yt-remote-connected-devices | never | YouTube sets this cookie to store the video preferences of the user using embedded YouTube video. |
yt-remote-device-id | never | YouTube sets this cookie to store the video preferences of the user using embedded YouTube video. |
yt.innertube::nextId | never | This cookie, set by YouTube, registers a unique ID to store data on what videos from YouTube the user has seen. |
yt.innertube::requests | never | This cookie, set by YouTube, registers a unique ID to store data on what videos from YouTube the user has seen. |