View on GitHub

ecocoding

Energy Consumption of various Machine Learning and Deep Learning Models using codecarbon

Energy Consumption in Machine Learning & Deep Learning Models

The exploratory project estimates and measures carbon emissions from various Machine Learning and deep learning datasets to quantify and analyze their impact.


Definitions

Why do we need Sustainable Software?

Email:

Web search:

Per capita consumption: equivalent to ≈ 1,400 km by car

ICT global demand

Forecast:

Product development/software development teams

Organizational: Product development teams and methods Examples: Agile Development, DevOps

Technological: Technological Advancements Examples: cloud infrastructure, mobile devices

Market: Examples: hyperscale cloud providers, consumer demands

GREENSOFT Model

Lifecycle phases in the “Greensoft- Green and Sustainable Software Model”?

The following projects in the repo uses code carbon taking into account the computing infrastructure, location, usage and running time.

Emissions

Algorithm Dataset/ Link to code Instance Accuracy Emissions Recorded in Joules* (average) Emissions Recorded in kg* (average)
Logistic Regression IRIS Dataset 50 95.56% 11322593948.720951 joules 1.2598084791716727e-07 kg
Logistic Regression ASD Screening 761 99.53% 23098647146.30177 joules 2.570071104209542e-07 kg
Support Vector Machines IRIS Dataset 50 97.78% 11020140817.496267 joules 1.226156029830599e-07 kg
K Nearest Neighbors IRIS Dataset 50 93.33% 11183853335.19536 joules 1.2443715040300566e-07 kg
Adam Optimization Fashion MNIST 70,000   52381696453822.83 joules (5 epochs)  

Installation

Download the project along with a code editor. Use the terminal to navigate to the source folder.

Create a virtual environment using conda for easier management of dependencies and packages. You can also follow the instructions on the official conda website

conda create --name codecarbon python=3.6
conda activate codecarbon

Install from PyPI repository

pip install codecarbon

Install from Conda repository

conda install -c codecarbon -c conda-forge codecarbon

This project requires Python and some of the following Python libraries installed:

You can install them using

pip install <packagename>

To run the code

python train.py

About the Dataset

1. Iris Dataset

The IRIS data set contains 3 classes of 50 instances each, where each class refers to a type of iris plant. One class is linearly separable from the other 2; the latter are NOT linearly separable from each other.

The details on the dataset can be found here

Data Visualization: Sepal Length vs Width & Petal Length vs Width

|Screenshot|Screenshot|Screenshot| | ————- | ————- |————- |

2. ASD Screening

The Autism-Spectrum Quotient publisehed by Baron-Cohen, Wheelwright, Skinner, Martin, & Clubley was developed to assess how adults with ‘normal’ intelligence has the traits associated with autism spectrum conditions. Each question allows the subject to indicate “Definitely agree”, “Slightly agree”, “Slightly disagree” or “Definitely disagree”. Approximately half the questions are worded to elicit an “agree” response from normal individuals, and half to elicit a “disagree” response. The subject scores one point for each question which is answered “autistically” either slightly or definitely.” The questions cover five different domains associated with the autism spectrum: social skills; communication skills; imagination; attention to detail; and attention switching/tolerance of change.

According to the dataset, ‘Yes’ indicates that the individual is on the Autism Spectum and ‘No’ is indicated when the final score is less than or equal to 7. You can refer the questions from here.

The Dataset can be downloaded from the UCI Repository which is publicly available here.

Data Visualization

|Screenshot|Screenshot|Screenshot|Screenshot| | ————- | ————- |————- | ————- | |Screenshot|Screenshot|Screenshot|Screenshot|

|Screenshot|Screenshot| | ————- |————- |

3. Fashion MNIST

Fashion MNIST is a dataset comprised of 60,000 small square 28×28 pixel grayscale images of items of 10 types of clothing, such as shoes, t-shirts, dresses, and more. The mapping of all 0-9 integers to class labels is listed below.

0: T-shirt/top
1: Trouser
2: Pullover
3: Dress
4: Coat
5: Sandal
6: Shirt
7: Sneaker
8: Bag
9: Ankle boot

Data Visualization

|Screenshot|Screenshot|Screenshot| |–|–|–|

↑ Back to top