From f02c2b7d87e6160198c765bb41656d2fef308eeb Mon Sep 17 00:00:00 2001 From: Sean Mcilroy Date: Thu, 11 Apr 2024 16:32:50 +0100 Subject: [PATCH] SCI aligning with ISO v1.0 approved changes (#377) * Update Software_Carbon_Intensity_Specification.md Signed-off-by: Sean Mcilroy * Update Software_Carbon_Intensity_Specification.md Signed-off-by: Sean Mcilroy --------- Signed-off-by: Sean Mcilroy --- .../Software_Carbon_Intensity_Specification.md | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/Software_Carbon_Intensity/Software_Carbon_Intensity_Specification.md b/Software_Carbon_Intensity/Software_Carbon_Intensity_Specification.md index 7346fb1..bda02a0 100644 --- a/Software_Carbon_Intensity/Software_Carbon_Intensity_Specification.md +++ b/Software_Carbon_Intensity/Software_Carbon_Intensity_Specification.md @@ -1,3 +1,7 @@ +--- +version: 1.0.0 +--- + # Software Carbon Intensity (SCI) Specification ## Introduction @@ -26,6 +30,9 @@ In situations where there is a lack of access, capability, or rights to the nece This specification describes a methodology for calculating the rate of carbon emissions for a software system; that is, its SCI score. The purpose of this score is to increase awareness and transparency of an application's sustainability credentials. The score will help software practitioners make better, evidence-based decisions during system design, development, and deployment, that will ultimately minimize carbon emissions. A reliable, consistent, fair and comparable measure allows targets to be defined during development and progress to be tracked. +## Normative reference +There are no normative references in this document. + ## Terms and definitions For the purposes of this document, the following terms and definitions apply. @@ -127,7 +134,7 @@ When software runs on a device, a fraction of the total embodied emissions of th This fraction consists of both a time- and resource-share. The length of time that the software runs on the device determines its time-share. The percentage of the device reserved just for that application during the time-share determines that application's resource-share. -To calculate the time-share, amortize the total embodied carbon over the expected life span of the device and then extrapolate based on the time reserved for the usage. For example, if the device’s embodied carbon was 1000kg with an expected lifespan of four years and it was reserved for use for one hour, the time-share embodied emissions would be 1000 * 1/(4\*365\*24) or around 28g of the total. +To calculate the time-share, amortize the total embodied carbon over the expected life span of the device and then extrapolate based on the time reserved for the usage. For example, if the device’s embodied carbon was 1000 kg with an expected lifespan of four years and it was reserved for use for one hour, the time-share embodied emissions would be 1000 * 1/(4\*365\*24) or around 28 g of the total. To calculate resource-share, look at the share of total available resources reserved for use by the software. For instance, the percentage of total virtual CPUs reserved for the software is a good choice for the resource-share metric in the virtualized cloud space. @@ -239,7 +246,7 @@ Carbon emissions may be quantified by measuring the total real-world carbon emis ### Calculation -What one unit of `R` looks like may be modelled and the total carbon (`C`) calculated for executing one functional unit of work (`R`) in a controlled lab environment. For instance, a benchmark application may be created that models a user interacting with your application and then measure the `C` emitted per run of that benchmark. The result is still a `C` per user. +What one unit of `R` looks like may be modelled and the total carbon (`C`) calculated for executing one functional unit of work (`R`) in a controlled lab environment. For instance, a benchmark application may be created that models a user interacting with developer's and then measure the `C` emitted per run of that benchmark. The result is still a `C` per user. ## Comparing an SCI score to a baseline @@ -251,10 +258,10 @@ As this specification develops, the following core characteristics shall remain - **The SCI is sensitive to carbon awareness, energy efficiency, and hardware efficiency** - The purpose of the SCI is to encourage actions that reduce the carbon emissions of software. Therefore, the SCI shall be sensitive to those actions described in this document under **Software Sustainability Actions**; specifically, carbon awareness, energy efficiency, and hardware efficiency. - - If an application's SCI is X, and then actions are taken to make the application more carbon aware, more energy efficient, or more hardware efficient, the value of X shall go down. + - If an application's SCI is X, and then actions are taken to make the application more Carbon Awareness, more Energy Efficient, or more Hardware Efficient, the value of X shall go down. - **The SCI takes a systems-impact view** - - The purpose of the SCI is to encourage actions that reduce carbon emissions of software in a way that creates reductions at a system-wide level rather than just at a local level. Local-level optimizations may lead to micro improvements but may have negative downstream impacts at a macro level that negate the impact of those actions. + - The purpose of the SCI is to encourage actions that reduce carbon emissions of software in a way that creates reductions at a system-wide level rather than just at a local level. While local-level optimizations might lead to micro improvements, they might lead to negative downstream impacts at a macro level that negate the impact of those actions. - Such a systems view shall be adopted by articulating the [boundaries](#software-boundary) of the software and its associated infrastructure, keeping in mind the [exclusions](#exclusions) mentioned in this specification. - **The SCI is easy to implement**