Skip to main content

Assigns light and sound frequencies to prime numbers and mixes them using pygame.

Project description

#pygame virtual keyboard which assigns a prime number, light frequency, and sound frequency #to keys. it mixes the light frequencies to corresponding RGB colors, mixes #the pure tones to sounds, and multiplies the primes to get unique numbers.

This code assigns a color and sound to a range of positive integers in a natural way.

Input: n

  1. Factor n into a product of primes n = p_1^s_1 * ... * p_r ^s_r

  2. Map every prime to a wavelength into the visible range which is roughly 380nm (800Thz, violet) - 700nm (400Thz, red). Use f_red*(f_violet/f_red)^((i-1)/(num_keys-1)) in analogy to the keyboard mapping of sound frequencies 440Hz*2^((i-49)/12).

  3. For example, the number 197 is p_45. Its light frequency is 492 THz -> 608nm wavelength, so red. 563 is p_103, so 649 THz -> 462nm, so blue. Combining them we get the number 110911 which has a bright purple color.

  4. To convert this spectrum to the appropriate color of light we use the CIE color matching functions (https://www.cs.rit.edu/~ncs/color/t_spectr.html). This can be implemented in almost any language. (https://mathematica.stackexchange.com/questions/57389/convert-spectral-distribution-to-rgb-color/57457#57457).

Output: An RBG color specification.

A similar method can be used for sound, in which case we just scale into the audible range of 20Hz - 20kHz. We then need to mix the tones to get a sound using a synthesizer package, in this case tones.

Importantly, spectra of colors and sounds combine additively. Combining natural numbers via multiplication is straightforward.

This could be used to make a *keyboard whose keys are appropriately colored and labeled by prime numbers.

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

synesthesiaer-0.0.8.tar.gz (5.2 kB view details)

Uploaded Source

Built Distribution

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

synesthesiaer-0.0.8-py3-none-any.whl (5.9 kB view details)

Uploaded Python 3

File details

Details for the file synesthesiaer-0.0.8.tar.gz.

File metadata

  • Download URL: synesthesiaer-0.0.8.tar.gz
  • Upload date:
  • Size: 5.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.7.9

File hashes

Hashes for synesthesiaer-0.0.8.tar.gz
Algorithm Hash digest
SHA256 dad2d4f220f8868b3a16f5bef69321f6ada5cd89d83c343ca9e8d12a4fdfaaba
MD5 ae4eb637dd2d8579ce3c4bd204efd70c
BLAKE2b-256 a10f88c71805b64dcf852a9698ea9e6ace131343f63394900ffcdab4ab050899

See more details on using hashes here.

File details

Details for the file synesthesiaer-0.0.8-py3-none-any.whl.

File metadata

  • Download URL: synesthesiaer-0.0.8-py3-none-any.whl
  • Upload date:
  • Size: 5.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.7.9

File hashes

Hashes for synesthesiaer-0.0.8-py3-none-any.whl
Algorithm Hash digest
SHA256 434afdd4d08ebf68efcbc46db710cdd874d89733adb9968461ff79953fe5fe27
MD5 693d11b0ff148e869948cd0ba498dfe6
BLAKE2b-256 ade660c4743499bbba4c6f3482879d1e40097dad8eb5f562f7c55a6717a21d39

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