Methodology
In order to address carbon emissions from software, we focus on two main sources: Operational and Embodied Emissions. These are discussed in depth in the Software Carbon Intensity (SCI) specification, developed by the Green Software Foundation. At Trycarbonara, we use this methodology to calculate the total carbon footprint of software.
Total Emissions = Operational Emissions + Embodied Emissions
Operational Emissions
Operational Emissions are produced due to electricity consumption, which powers various components of a service, including servers, databases, and other systems. To calculate these emissions, we need to accurately measure the electricity usage of these components and the carbon emissions factor of the local grid where the service is run.
Operational emissions = (Electricity usage [kWh]) x (Instance provider Power Usage Effectiveness (PUE)) x (grid emissions factors [metric tonnes CO2e/kWh])
Electricity Usage
The amount of electricity used by software is one of the biggest sources of Carbon Emissions. The total electricity usage is the sum of usage from compute, memory, storage, and networking:
Total Electricity Usage = Electricity Usage From [Compute + Memory + Storage + Networking]
Compute/Memory Energy Estimation
For the estimation of Compute & Memory in servers, we leverage hardware sensors capable of providing detailed power consumption data. Examples of such tools include IPMI and Redfish for server management, and NVML for monitoring NVIDIA GPUs. However, our method is not exclusive to these specific tools. We employ any available hardware sensor, regardless of the manufacturer, that can deliver accurate power information. This approach ensures a comprehensive understanding of both compute and memory usage across different server types.
Storage Energy Estimation
For estimating the energy usage associated with storage, we adopt the methodology suggested by the Cloud Carbon Footprintproject. This methodology involves deriving a coefficient for energy usage (in Watt-hours) per Terabyte of storage, both for Hard Disk Drives (HDDs) and Solid State Drives (SSDs).
HDD Energy Usage Estimation:
Average HDD capacity in 2020: 10 Terabytes per disk
Average power draw per disk for 2020: 6.5 Watts per disk
Energy Usage (Watt-Hours per Terabyte) = Power Draw (Watt-Hours per Disk) / Storage Capacity (Terabytes per Disk)
This translates to: 0.65 Watt-Hours per Terabyte for HDD = 6.5 Watt-Hours per Disk / 10 Terabytes per Disk
SSD Energy Usage Estimation:
Average SSD capacity in 2020: 5 Terabytes per disk
Average power draw per disk for 2020: 6 Watts per disk
Similarly, for SSDs, the energy usage per Terabyte is calculated as:
Energy Usage (Watt-Hours per Terabyte) = Power Draw (Watt-Hours per Disk) / Storage Capacity (Terabytes per Disk)
This gives: 1.2 Watt-Hours per Terabyte for SSD = 6 Watt-Hours per Disk / 5 Terabytes per Disk
To obtain the measure of Terabytes from different services, we query for the total bytes available rather than the total bytes used. This is because the total bytes available represent a more accurate reflection of the energy required to support storage.
Consideration of Replication Factors
Our carbon emissions calculation methodology accounts for storage replication. We set the replication factor as 1 by default, but this can be adjusted based on the specific configurations of the service or workload.
Network Energy Estimation
The application estimates network energy usage by looking at the total network usage, both incoming and outgoing data, in bytes. This total bandwidth usage is then used to calculate energy consumption. A coefficient of 1 Wh/Gb, as suggested by Cloud Carbon Footprint’s methodology, is used in this calculation.
Networking Coefficient = 1 Wh/Gb
Power Usage Effectiveness
In estimating the carbon emissions of workloads, we take into account the energy consumption for compute, storage, memory, and networking. This is then multiplied by the Power Usage Effectiveness (PUE) of the data center. PUE is a measure of a data center’s energy efficiency, with a PUE of 1 indicating that all consumed energy is dedicated to powering the servers, without any energy being wasted on cooling. We default to an industry average PUE of 1.57, as suggested by the Uptime Institute, for on-premise workloads. For cloud-based workloads, we have specific PUE values for each of the three major cloud providers. However, this value can be adjusted based on user input if more specific data is available, allowing our methodology to provide a more accurate carbon footprint based on the specific circumstances of each workload.
Grid Emissions Factors
Trycarbonara calculates two types of emissions: Attributional (Location-based) and Consequential. Attributional emissions assign a portion of the grid’s emissions to your specific workloads based on their location. Consequential emissions reflect the system-wide impact of your operations on the grid’s emissions, whether causing an increase or decrease. Our methodology is designed to be compatible with popular frameworks such as the GHG Protocol and the GSF SCI, and we collaborate with two organizations, Watttime and Electricity Maps, to obtain the necessary data for Grid Emissions.
The equations to calculate these emissions are as follows:
Attributional Emissions = (Electricity usage [kWh]) x (Instance provider Power Usage Effectiveness (PUE)) x (Average Emissions Rate [metric tonnes CO2e/kWh])
Consequential Emissions = (Electricity usage [kWh]) x (Instance provider Power Usage Effectiveness (PUE)) x (Marginal Emissions Rate [metric tonnes CO2e/kWh])
We use average and marginal emissions rates from Watttime and Electricity Maps respectively. In cases where these specific emissions data aren’t available, we use default data sources. For the Average Emissions Rate, we default to “Our World In Data”, and for the Marginal Emissions Rate, we default to the UNFCCC data source.
Embodied Emissions
Embodied Carbon Emissions or Embedded Emissions is the amount of carbon emitted during the creation and disposal of a hardware device. In order to estimate embodied emissions for the servers used to host and run software services and workloads, we need to calculate the fraction of the total embodied emissions that should be allocated to the usage of these servers.
Embodied Emissions = Estimated emissions from Manufacturing, Transportation and End of life management of Server [metric tonnes CO2e ]
The Green Software Foundation (GSF) released the Software Carbon Intensity (SCI) Specification, which defines a methodology for calculating the rate of carbon emissions for a software system. For the purpose of estimating embodied emissions, we have leveraged the relevant part of the specification.
In our implementation, we leverage this formula provided by the SCI standard:
M = TE*(TR/EL)*(RR/TR)
Where:
TE = Total Embodied Emissions, the sum of Life Cycle Assessment(LCA) emissions for all hardware components
TR = Time Reserved, the length of time the hardware is reserved for use by the software
EL = Expected Lifespan, the anticipated time that the equipment will be installed
RR = Resources Reserved, the number of resources reserved for use by the software.
TR = Total Resources, the total number of resources available.
The embodied emissions are typically modeled based on the specific server model used. For example, if the Dell PowerEdge R940 server is used, the embodied emissions can be modeled as follows:
According to Dell, the total embodied emissions for 'Manufacturing, Transportation and End of Life' of PowerEdge 940 = 10.6% of Total LCA.
Total Embodied Emissions = 1.466 tonnes CO2eq
Expected Lifespan = 2 years = 17520 hours
Resources Reserved = 1 (Since the entire server is used)
Total Resources = 1
Hourly Embodied Emissions Constant = (1.466/17520) tons/hours
Please note that this is an example calculation and the specifics will vary depending on the server model used and the results from its Life Cycle Assessment.
Appendix
Power Consumption Data Source
Trycarbonara uses system tooling to fetch detailed system/process level power consumption metrics specifically for compute and memory resources on bare-metal hosts. Here is the list of the open source software (OSS) tooling that Trycarbonara leverages:
IPMI
IPMI Project provides in-band and out-of-band IPMI software based on the IPMI v1.5/2.0 specification.
The IPMI specification defines a set of interfaces for platform management and is used by a variety of vendors for system management on motherboards. The features of IPMI that are most pertinent for Trycarbonara’s needs are sensor monitoring and remote power control. These features allow for the measurement and control of power consumption metrics.
Node Exporter
Node Exporter is a Prometheus exporter for hardware and OS metrics exposed by UNIX kernels, written in Go with pluggable metric collectors.
Trycarbonara uses Node Exporter to collect data on storage and network utilization. These metrics are then combined with appropriate factors to compute energy consumption by the resources, providing a detailed breakdown of power usage.