Skip to main content

No project description provided

Project description

Noise-Based-Random-Number-Generator

This random number generator leverages the inherent noise found in images captured by low-tech cameras to produce truly random numbers.

INSTALLATION

pip install noiserandom

How it works

The program captures multiple images in JPG format and randomly selects one to generate a random number. It utilizes images because older, low-tech cameras often contain significant white noise, which is a result of different random effects. Since those phenomena are inherently random, and if the camera is pointed at a dynamic scene such as a fish tank, a street, a forest , etc, the combination of a randomly chosen image and naturally occurring noise makes the process extremely difficult to reverse engineer.

Noises.

Each of these factors contributes to the overall noise level in the final image. In high-end cameras, many of these sources are mitigated through advanced sensor designs, cooling systems, and image processing algorithms. Low-tech cameras, however, often expose these weaknesses more clearly, resulting in images with a higher noise floor especially under conditions of low light or high gain.

This list should provide a clear overview of the effects that contribute to image noise in lower-performing camera systems.

  • Shot Noise

    • What it is: This is the inherent randomness in the arrival of photons at the sensor. Because light itself is made up of particles, the number that hit each sensor element will fluctuate, causing noise.

    • Why it’s significant: In low-light or lower sensitivity cameras, these variations become more apparent due to a lower photon count.

  • Dark Current Noise

    • What it is: Even in complete darkness, sensor pixels generate electrons due to thermal energy. This random generation, called dark current, results in noise.

    • Why it’s significant: Lower-tech sensors, which often lack sophisticated cooling or low-noise design, show higher dark current noise especially noticeable in long exposures or higher temperatures.

  • Read Noise

    • What it is: This noise arises during the process of converting the sensor’s charge to a digital signal. It includes disturbances from the sensor’s electronics, such as amplifiers and analog-to-digital converters (ADCs).

    • Why it’s significant: Cameras with less advanced electronics and lower-quality ADCs tend to exhibit higher levels of read noise.

  • Thermal (Johnson-Nyquist) Noise

    • What it is: Thermal agitation of electrons within the sensor’s circuits creates random fluctuations, commonly known as thermal noise.

    • Why it’s significant: This becomes a more dominant effect in systems without effective thermal management or when the sensor is operating at higher temperatures.

  • Fixed-Pattern Noise (FPN)

    • What it is: FPN is a pattern of noise that remains constant across images it originates from slight variations in sensor pixel responses or electronic circuits.

    • Why it’s significant: In low tech cameras where calibration and compensation routines are less robust, fixed-pattern noise can be noticeable as persistent spots or patterns in images.

  • Quantization Noise

    • What it is: During the analog-to-digital conversion process, continuous signals are approximated by discrete digital values. The rounding (quantization) errors introduce additional noise.

    • Why it’s significant: Lower-resolution ADCs or sensors with limited bit depth (which are common in older or simpler cameras) result in higher quantization noise.

  • Amplifier Noise

    • What it is: In many imaging systems, signals from the sensor are amplified before being digitized. The amplification process, especially when not using low-noise amplifiers, can introduce additional noise.

    • Why it’s significant: Low-tech cameras may employ more basic amplification hardware, leading to more pronounced noise artifacts.

  • Interference and External Noise

    • What it is: Electromagnetic interference from nearby electronic components or poor shielding can add stray signals into the sensor’s output.

    • Why it’s significant: In less advanced camera designs, insufficient electromagnetic shielding can result in visible noise patterns or erratic pixel behavior.

How to use

Example 1 (Random Integer)

#Firts import it

from noiserandom import NoiseRandom

#Then write the path that the images are going to be saved

path = "images" #This must be an existing folder

#After that create your object
noise_random = NoiseRandom(path=path,strength=10) #The strength is the number of images (min=1)

#Get your random number

random_number = noise_random.randomInt()

#print your random number

print(random_number)

Example 2 (Random Integer with 2048 bits)

#Firts import it

from noiserandom import NoiseRandom

#Then write the path that the images are going to be saved

path = "images" #This must be an existing folder

#After that create your object
noise_random = NoiseRandom(path=path,strength=10) #The strength is the number of images (min=1)

#Get your random number

random_number = noise_random.random2048()

#print your random number

print(random_number)

Example 3 (Random Prime Integer with 2048 bits)

#Firts import it

from noiserandom import NoiseRandom

#Then write the path that the images are going to be saved

path = "images" #This must be an existing folder

#After that create your object
noise_random = NoiseRandom(path=path,strength=10) #The strength is the number of images (min=1)

#Get your random number

random_number = noise_random.randomPrime2048()

#print your random number

print(random_number)

Example 4 (Get the bytes of the image scrambled)

#Firts import it

from noiserandom import NoiseRandom

#Then write the path that the images are going to be saved

path = "images" #This must be an existing folder

#After that create your object
noise_random = NoiseRandom(path=path,strength=10) #The strength is the number of images (min=1)

#Get your bytes

random_bytes = noise_random.randomInt(True)

#print your bytes

print(random_bytes)

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

noiserandom-1.6.tar.gz (5.4 kB view details)

Uploaded Source

Built Distribution

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

noiserandom-1.6-py3-none-any.whl (5.6 kB view details)

Uploaded Python 3

File details

Details for the file noiserandom-1.6.tar.gz.

File metadata

  • Download URL: noiserandom-1.6.tar.gz
  • Upload date:
  • Size: 5.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for noiserandom-1.6.tar.gz
Algorithm Hash digest
SHA256 8f7f8ceafdab7a7b6d98b0c34e578ec908f2ae61bd64f33fc1866b7fb48a4554
MD5 79125560cb08db5a523d277820404578
BLAKE2b-256 f6d9838a197a5b3679221e2e387cf14993726f890d9f6e00b2e192c2869f01a9

See more details on using hashes here.

File details

Details for the file noiserandom-1.6-py3-none-any.whl.

File metadata

  • Download URL: noiserandom-1.6-py3-none-any.whl
  • Upload date:
  • Size: 5.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for noiserandom-1.6-py3-none-any.whl
Algorithm Hash digest
SHA256 5abec11ce164227fa42fe10412d2df5655239ea631850edab8d89295a5c55640
MD5 a5ade5dd0ce5c99df80baa701a433de4
BLAKE2b-256 ac7727d23ed88f62019bc5e21ed383231041f4abe2390a15c1375e699d4fa68c

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