En güzel bayt kompozisyonunu yaz


24

Bytebeat müzik birinin bir stil 's çıktı a taşınıyor olduğu basit bir C programını yazarak oluşturabilirsiniz olduğu aplayya /dev/dsp.

main(t){for(;;t++)putchar(((t<<1)^((t<<1)+(t>>7)&t>>12))|t>>(4-(1^7&(t>>19)))|t>>7);}

Hakkında bilgi iyi bir anlaşma vardır bytebeat sitesinde , bir JavaScript uygulaması içinde ve daha demoları ve örnek kompozisyonlar bu konuya .

Çok basit kurallar: Oldukça sağlam bir kompozisyon yazmaya çalışın. Olağan sonuçlar dikkate alındığında sübjektif olmamakla birlikte çoğu oy çok kazanır.



Bunu katı baytura mı tutuyorsunuz?
Peter Taylor

4
Neden C ile sınırlı?
kullanıcı bilinmeyen

Arabellekleri veya diğer dilleri kullanmayı kısıtlamak için herhangi bir içsel sebep yoktur, ancak genellikle bytebeat, bir formül tarafından tanımlanan çıktıyla belirli bir C döngüsü anlamına gelir. Joey Adams'ın rand()standart dışı olduğunu düşündüğü cevabını oyladım .
Jeff Burdges,

Bu fikri sevmeme rağmen, SSS nesnel kazanma kriterleri gerektiriyor (hesaplamalarda veya ASCII sanatında sıkışmak çok kolay). "Güzel" den daha iyi tanımlanmış bir şey arayabilir miyiz?
dmckee

Yanıtlar:


16

(İmzalı 16 bit küçük endian, 8000Hz mono ( --format=S16_LE))

Müzik

Öncekinden çok daha iyi! (oldukça uzun olmasına rağmen)

main(t){for(;;t++)putchar(((7&(((t>>17)+1)>>2)+((t>>10)&1+2*(t>>18&1))*(("23468643"[7&t>>12]-48)+(3&t>>11))+((3&t>>17)>0)*(3&t>>9)*!(1&t>>10)*(((2+t>>10&3)^(2+t>>11&3))))*t*"@06+"[3&t>>15]/32));}

(Bu dinleyebilirsiniz burada en )

Bunu yazdım, ancak bazı bölümlerin >0ilk başta olduğu gibi (özellikle de) nasıl çalıştığını bile bilmiyorum 7&.

for(;!(t>>22);t++)'Bir kez' dinlemek için döngü için ... olarak değiştirin . Ancak, tam olarak aynı şekilde "döngü" olup olmadığını bilmiyorum.

Melodi (yukarıdaki müziğin temeli)

Yaptığım bu melodiyi seviyorum (CGAF ftw), ama bu çok 'düz' ...

main(t){for(;;t++)putchar(((t>>10)&1)*(t*("23468643"[7&t>>12]-48)+t*(3&t>>11))*"@06+"[3&t>>15]/32);}

Basit müzik (daha önce yaptığım)

main(t){for(;;t++)putchar(t*(3&t>>11)+(t&t>>11)*4*!((t>>11)%3));}


Yukarıdaki baytebeat bağlantısını tıklarsanız, onu .wav dosyasına dönüştürmek için bir sox komut satırı ve tek bir kompresör komut satırı göreceksiniz.
Jeff Burdges,

3
+1 Şaşırtıcı! Birkaç bit (örn. 1:30 - 1:40) ses türünde "kekemelik" tiryakisi, ama sonra tekrar, baytezin çekiciliğinin çoğu bu garip ve sıradışı ritimler ve melodilerde ve genel etki mükemmel. (Ps. Bunu örnek başına 8 bitte kazara çaldım ve bu şekilde şaşırtıcı derecede iyi sesler duydum. 33,3 devir /
dakikada

3

Cetvel fonksiyonu C minor:

#include <math.h>
#include <stdio.h>

#define PI 3.14159265358979323846

#define step(freq, n) ((freq) * pow(2, (n) / 12.0))
#define note(n)       step(440, n)
#define MIDDLE_C      note(-9)

int count_zeros(unsigned int n)
{
    int count = 0;
    for (; (n & 1) == 0; n >>= 1)
        count++;
    return count;
}

int minor_note(int note)
{
    int octave = note / 7;
    int scale[] = {0, 2, 3, 5, 7, 8, 10};

    note %= 7;
    if (note < 0) {
        note += 7;
        octave--;
    }

    return scale[note] + octave*12;
}

int main(void) {
    double t = 0.0;
    double freq = MIDDLE_C * 2;
    double step = PI * 2 / 8192;
    int n = 0;
    int i = 0;

    for (i = 1;; t += step, i++) {
        if (i == 1024) {
            i = 0;
            n++;
            freq = step(MIDDLE_C, minor_note(count_zeros(n)));
        }

        putchar(sin(t * freq) * 50.0 + 128.0);
    }

    return 0;
}

Güzel melodi, ama bu "IMO" kompozisyonu olmak için daha fazlasına ihtiyacı var ...
Ilmari Karonen

3
main(t){for(;;t+=(t%6)?1:2)putchar((((t<<t^(t>>8))|(t<<7))*((t<<t&(t>>12))|(t<<10))));}

Çok klasik bytebeat, eğer oxymoron değilse. Benden +1.
Ilmari Karonen

3

"Bayt" üzerinden "atışı" vurgulayarak:

#include<math.h>

double s(double,double);double r(double,double);double d(double);double f(double);

char bytebeat(int t){return (d(f(t/4000.)/3) + 1) * 63;}
double f(double t){
  double sn=s(1./2,t-1); sn*=(sn*sn);
  return 3*s(1./4,1/s(1,t))+3*s(4,1/sn)/2+s(4,1/(sn*sn*sn*sn*sn))/4
       +2*s(55+18.3*r(1./2,t),t)+s(110+s(5,t)/4000,t)*s(1,t)+s(220+110*r(1,t)+55*r(3,t),t)/5
       +s(880+440*r(1./2,t)-220*r(1,t)+110*r(2,t)+s(5,t)/4000,t)
       *(2+s(1760+438*r(3./2,t)-1234*r(2,t)+423*r(5,t),t))/9
       +s(s(1,t)+s(1./2,t)+s(1./4,t)+s(1./8,t),t)*s(s(1,t)+s(1./2,t)+s(1./4,t)+s(1./8,t)+1,t)
       +r(264+11*r(1./20,t),t)*s(1./20,t);
}
double s(double f,double t){return d(sin(f*3.14159265*(t+999)));}
double r(double f,double t){return s(f,t)<0;}
double d(double a){return tanh(a+a*a/4);}

main(t){for(;;++t)putchar(bytebeat(t));}

8 kHz, uint8 mono'da kullanılmak üzere. İyi bas özelliğine sahip hoparlörlerden daha iyi sesler.


2
main(){for(;;)putchar(rand());}

Okyanus gibi geliyor ;-)


1
Daha çok bana gelen çok yoğun bir demiryolu geçişi gibi. :)
Ilmari Karonen

5
Protip: Sürekli bir tonda gibi geliyorsa, RNG'niz kırıldı.
Bay Llama,

3
kolay yol:$ cat /dev/urandom | aplay
Braden Best

2
@ B1KMusic çok daha basit:aplay /dev/urandom
minmaxavg

0

Kombine melodi ve uyum:

r=3,
r=3,
m=(t*(t>>12|t>>13|t>>14|t>>15|t>>16|t>>17|t>>18))&63,

h= ((t&t>>7&t>>6)|t*5&t>>8-c^t*6&t>>9-c|t*7&t>>12-c^t*9&t>>11-c^t*11&t>>22^t*19&t>>20^t*14&t>>20|t*23&t>>15-c|t*12&t>>9|t*30&t>>30|t>>5|t>>4)-31, m|h
Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.