Estimating corporate emissions

Imagine a company that has done a perfect job of measuring its carbon emissions. This company would have analyzed every expense in its financials, gone a level deeper to get activity data, performed lifecycle analysis on each of its products, and then asked each company in its supply chain to do the same.

This idealized company does not exist, though Google, Microsoft, Axel Springer, and Salesforce - among others - are making substantive efforts to get there. We can think of this as a spectrum where on the far left is a company that has done nothing to measure its emissions, on the middle-right are these best-of-breed companies, at at the far right is this idealized company who has measured everything.

We need a way to estimate corporate emissions based on the information we have available. We can translate the spectrum above into a table that translates what we know into a methodology to fill in the gaps of what we don’t know:

What we knowEstimation methodology
NothingUse industry-average emissions per impression
Number of employeesUse industry-average emissions per employee
Sustainability report with missing or aggregated scope 3 categoriesUse industry-average emissions per employee for missing categories
Complete sustainability report with suboptimal methodology (market-based vs location-based, or omitting embodied emissions, for instance)Use industry average correction factors

Mapping emissions into business units

For a company like Google, the corporate sustainability report will be produced for the entire company. Some business units, like YouTube, will be broken out with specific emissions data; other business units will not be.

For a business unit like ad tech inside Google, we need to allocate a percentage of the overall corporate emissions based on percentage of revenue or another method.

Calculating industry-average emissions factors

In this repository we aggregate public data from companies who produce sustainability reports - for instance, Axel Springer. We pull facts from these reports and use them to produce industry average values including:

  • Office Emissions Per Employee Per Month
  • Commuting Emissions Per Employee Per Month
  • Travel Emissions Per Employee Per Month
  • Datacenter Emissions Per Employee Per Month (may include cloud)
  • Overhead Emissions Per Employee Per Month (this bucket includes third party software and marketing expenses; we need to get it broken out in a consistent way)

We only include data that includes all scope 3 categories and uses location-based emissions for electricity use. Unfortunately, this means that very few sustainability reports are usable for us, though we expect this to change quickly.

How we parse and understand corporate sustainability reports

Scope 3 Aggregation

One of the issues with combining sustainability reports across a supply chain is that, at least in theory, the upstream supply partner should already be accounted for by the downstream partner and vice versa.

In other words, a publisher should be including programmatic supply chain emissions already, as should a DSP, SSP, all the way through to the agency and advertiser. When we parse these reports, we should be excluding these in order to get a non-overlapping boundary.

In practice, at least in 2022, when we have asked companies - both publishers and ad tech companies - they have told us that these emissions are not included in their reporting boundaries today. Therefore we are not making any additional exclusions. In the future, we suggest that companies be explicit about what parts of their value chain are included recursively so that a de-duplication is possible (h/t Benjamin Davy for pointing this out!)

For the purposes of the current project, we are assuming the following categories of scope 3 emissions are fairly comprehensive for companies in the media and advertising space:

offsets, RECs, and PPAs

to discuss

Usage

Note: this will change soon to support hierarchical organizations

Create a YAML file that describes the company you would like to model. The YAML file should look like this:

---
type: corporate
name: Criteo
facts:
  - travel_emissions_mt_co2e_per_employee_per_month: 0.011
    reference: page 7
    source_id: 1
  - office_emissions_mt_co2e_per_employee_per_month: 0.0176
  - number_of_employees: 2810
raw_facts:
  - office_electricity_kwh: 2262000
    reference: page 91
    source_id: 1
  - office_electricity_kwh_per_employee: 860
    reference: page 91
    source_id: 1
sources:
  - id: 1
    year: 2021
    url: >-
      https://filecache.investorroom.com/mr5ir_criteo/1674/Criteo_CSR_Report_2021.pdf
    file: Criteo_CSR_Report_2021.pdf

The file must have:

  • Some number of facts, with number_of_employees required at a minimum unless you provide full corporate emissions data.

To model emissions, make sure defaults have been computed. Then run:

./scope3_methodology/cli/model_corporate_emissions.py --verbose {generic,atp,publisher} [company_file.yaml]