Skip to main content

eshard scared Python library.

Project description

SCAred

pipeline status PyPI version Conda installer Latest Conda release

scared is a side-channel analysis framework maintained by eShard team.

Getting started

Requirements

Scared need python 3.11, 3.12 or 3.13 and Numpy>=2

You can install scared, depending on your setup:

  • from source
  • with pip
  • with conda

Install with conda

You just have to run:

conda install -c eshard scared

Install with pip

Python wheels are available from Pypi, just run:

pip install scared

Install from sources

To install from sources, you will need to run:

pip install .

from the source folder.

If you are planning to contribute, see CONTRIBUTING.md to install the library in development mode and run the test suite.

Make a first cool thing

Start using scared by doing a cool thing:

# First import the lib
import scared
import numpy as np

# Define a selection function
@scared.attack_selection_function
def first_add_key(plaintext, guesses):
    res = np.empty((plaintext.shape[0], len(guesses), plaintext.shape[1]), dtype='uint8')
    for i, guess in enumerate(guesses):
        res[:, i, :] = np.bitwise_xor(plaintext, guess)
    return res

# Create an analysis CPA
a = scared.CPAAttack(
        selection_function=first_add_key,
        model=scared.HammingWeight(),
        discriminant=scared.maxabs)

# Load some traces, for example a dpa v2 subset
ths = scared.traces.read_ths_from_ets_file('dpa_v2.ets')

# Create a container for your ths
container = scared.Container(ths)

# Run!
a.run(container)

Documentation

To go further and learn all about scared, please go to the full documentation. You can also have an interactive introduction to scared by launching these notebooks with Binder.

Contributing

All contributions, starting with feedbacks, are welcomed. Please read CONTRIBUTING.md if you wish to contribute to the project.

License

This library is licensed under LGPL V3 license. See the LICENSE file for details.

It is mainly intended for non-commercial use, by academics, students or professional willing to learn the basics of side-channel analysis.

If you wish to use this library in a commercial or industrial context, eShard provides commercial licenses under fees. Contact us!

Authors

See AUTHORS for the list of contributors to the project.

Binary builds available

Binary builds (wheels on pypi and conda builds) are available for the following platforms and Python version.

Platforms:

  • Linux x86 64
  • Macosx x86 64

Python version:

  • 3.11
  • 3.12
  • 3.13

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

scared-1.2.8.tar.gz (60.4 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

scared-1.2.8-py3-none-any.whl (97.9 kB view details)

Uploaded Python 3

File details

Details for the file scared-1.2.8.tar.gz.

File metadata

  • Download URL: scared-1.2.8.tar.gz
  • Upload date:
  • Size: 60.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.9

File hashes

Hashes for scared-1.2.8.tar.gz
Algorithm Hash digest
SHA256 acea3a703b800c3e746891d8cffc2b737248235150fae1179b33be738799a1e3
MD5 4b785d99110024b23c459f690bc433e1
BLAKE2b-256 a6c38ae3aa64764e5aa1ce25b2af30cc555acf049b47165c1d3e46ac88b4f1ef

See more details on using hashes here.

File details

Details for the file scared-1.2.8-py3-none-any.whl.

File metadata

  • Download URL: scared-1.2.8-py3-none-any.whl
  • Upload date:
  • Size: 97.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.9

File hashes

Hashes for scared-1.2.8-py3-none-any.whl
Algorithm Hash digest
SHA256 df2dae9ec2a1e27a55d7fcae5f9a36a45fed5fc3e100a8779819be915925820e
MD5 a8ce056865e6747ba6a882ba7d2585e0
BLAKE2b-256 250fa2ff2068f5897a7a3a778d29abd72c7e1daa48207215fbac80fa25f8d6ac

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page