莫扎特高尔夫-迷你“ Rondo”


13

将“ Mozart-Alla Turca”输出到标准输出(请参阅示例的“参考实现”)

尝试找到如何将合成器和音乐打包到最小尺寸。

要求:

  • 适用于馈入的格式aplay -f cd(带符号的16位Little Endian,2通道);
  • 应该播放整个音乐(没有跳过的音符或声部,至少不小于示例程序中的音乐),但是不需要复音。
  • 不能随便打电话/usr/bin/timidity/usr/bin/sox或类似的东西(例如,需要安装一个特殊的音乐模块);
  • 无法访问网络或无法确定音乐在本地可用;

具有可分析分数的“参考实现”:https : //gist.github.com/vi/5478693
(旧示例Perl程序:https : //gist.github.com/vi/5447962


您是否有指向乐谱的链接?
beary605

目前不行,我是通过侦听和反复试验来键入示例程序的。现在正在寻找...
Vi。

例如,this
六。

另外,我假设您已经意识到这一点,但是每个人都将使用方波。
彼得·泰勒

2
注意:链接乐谱中的安排对于任何尝试仅用一种声音来实现的人来说都是毫无用处的。我已经下载了各种MIDI文件,但它们并不同意所有的音符-它们可以在同一琴键中,但是对某些音符的不同之处为4个半音!为了使其成为一个明确指定的问题,它确实需要一个规范的分数(最好采用某种易于解析的格式,以便实现者可以将其转换为便于实现的格式,而不会引入转录错误)。
彼得·泰勒

Answers:


11

和弦,Haskell, 2826 3177 4719

音频输出:https : //www.dropbox.com/s/nba6489tfet740r/hs-golf-turca.ogg

特征:

  • 所有笔记 右手。我当然也可以加左手 (做到)。
  • 断音注释等的正确表达
  • 合理,动听的声音。不仅是简单的音量调制,而且是攻击字符和泛音内容的正确变形,就像上一架真正的钢琴一样实际上,更多……嘿,这首歌应该是在模仿土耳其禁卫军乐队,对吧?
  • 混响 听起来也不错,但也不算太差。
  • 动态压缩。不要问...
  • 输出抖动。这有点荒谬:具有适当的16位分辨率,几乎没有人会听到量化伪像,但是为了避免包括二进制库,我实际上只使用了7位分辨率,可以使用ASCII输出。抖动本身很大,没有噪音。
  • 和弦的多线程计算。

import Control.Parallel
main=mapM_ (\(d,s)->(\p->p>>p>>p>>p).putChar.toEnum.round.(+d).(*62).min 2.abs$s+1).zip(dθ 1).lim.rev.hgp 9. pl 9e6 (\_->0) . ä
 $[mT%8.1,t2%16.1,t3(∡7)%8,t4%8,t5%16,t3(∡7)%8,mT%8.1,t2%16.1,t3(tev arp8)%8,cdT%99] >>= \e->[e,e]
mM=ä[2-^8,1-^8,0-^8,1-^8,3-^4]
cM=ä[7-^20,8-^20,9.^4,F[(7,0),(6,1)](map((∡2).(.^4))[6,5,6])%0.75]
cMv=ä[10-^2,8.^4,9.^4,hom(.^4)[[24,5],[23,8,12],[22,4],[21,6,9],[22,3],[19,5,8],[20,4],[18,6,9],[17]]#7&(-14)%2.5,tr 2%0.4,1-^9,2-^12,1-^1]%4.5
 ⋎(ä[6-^4,lp(8.^4∡3)%(3/4),sil%2,lp(5.^4∡3)%h,lp(5.^4∡2)%h,1-^1∡7]&(-14)#7#4%5)
mMa f=ä[(1-3*f).^4,lp(5.^4∡(-2-f))%0.75,mMa f%1.5,mMa(f*2)%h,mMa f%1]#7
mTm=ä[mM%1,mM&2%1,mM#4&4%h,mM&7%h,mM&7%1,8.^4,ä[10.^4]%0.2,cM%1,cM%1,cM%0.85,ä[4.^4∡2,5.^2]#6#4%2]#7
mT=p$ä[mTm%8.1⋎(ä[sil%h,mMa 0%4,mMa 1%2.75,2.^4,(-2)-^2]&(-7)%8)]
m2=ä[ä(map((∡2).(.^4))[1,2,3,3]++[es[6,5,4,3]%h]++[0-^2∡2])%2
 ⋎(ä[sil%h,1.^4,8.^4,3.^4,10.^4,5-^2]⊿1.3&(-14)%2)]
t2=p$ä[m2&2%1.8,0-^5,m2&2%2,m2#7%1.8,(-2)-^5,m2#7%2,mT%3.5,cMv]
m3=ä$[3-^4,4-^4,5-^2]++map(-^4)[3,4,5,4,3,2,1,2,3,4,2,0]
m3a=ä[(ä[sil%(1/8),lp(8.^4)%1]:zw(\d n->ä[sil%(d/24),n-^1]⊿cos d)[0..][1,3,5],s),m3a%1]
m3ra=(map((%1). \[a,b,c]->es[a,c,b,c,a,c,b,c])[[1,3,5],[1,4,6],[-2,0,5]]!!)
t3 o=ä[ä[o$ḋ[m3%4,m3%2.5,1-^4,4-^4,2-^4,0-^4]&(-2)%7.5,1-^2∡7]%8
 ⋎(ḋ[sil%(3/8),m3a&4%2,m3a%h,m3a#4%h,m3a&1%1,m3a&4%2,m3a%h,m3a&1%(5/8),5-^2]&(-18)%8)]
mQ=es[2,1,0,2]
m4=mM⇆4
i4 e=ḋ[m4⇅11%h,m4⇅9%h,mQ⇆4⇅8%h,F[(5,e),(4,1)][mQ⇅7%h,mQ⇅5%h,m4&5%h,m4&7%h]%2,es[10,9,10,9]#2%h ]
mla[b,c,d]=ä[b-^4,lp(c-^4⋎(d-^4))%1]%1
i4a=ḋ[sil%h,ä(map mla[[1,3,5],[2,4,5],[1,3,5],[0,2,5]])#5%4,ä(map mla[[1,3,5],[2,5,7],[2,6,8]])#4%3,5-^2⋎(7-^2)]
t4=p$ä[ḋ[i4 1%4,i4 0%2.5,ä[mQ⇅6%h,mQ⇅4%h]#4#2%1,3-^2]%8⋎(i4a&(-9)%8)]
mlaa=mla[1,3,5]
m5=ä$map(-^8)[1..4]
i5=ḋ[m5⇅6%h,m5%h,m5&4%h,m5⇅9%h]
i5d=hom(-^4)[[2],[4,5],[0],[4,5]]%1
i5a=ḋ[sil%h,mlaa,i5d,mlaa,mla[-2,0,4],mlaa,i5d,sq 4[1,-1,-3,-2,-6,1]%2]&(-7)
t5=ḋ[ḋ[i5%2,i5%1.5,ä[8-^4,9-^4]#1%h,i5%2,ḋ[es[5,4,3,2,3,5,1,3,2,4,0,2]%2]%1.5,1-^2]%8⋎(i5a%8)
 ,p(ä[ä[i4 1%4,es[3,2,3,1,4,3,4,3,4,3,4,3]#2#1&7%1.5,m5⇅13%h,mQ⇅8%h,m5&7%(3/8),6-^8,mQ⇅7#5%h,6-^2]%8
 ⋎(ä[i4a%3.5,F[(1,-1),(7,0),(6,1)][hom(-^4)[[-2],[3,5],[2,5],[1,5]]%1]%1,mla[-3,1,4],mla[-3,2,4],hom(-^4)[[-2],[1,3],[-2],[2,4],[1,3]]%1.5]&(-9)%8)])%8]⊿0.8
am d=3-^d∡2∡5
amf=1-^υ∡2⋎(5-^1∡3)
vh v(c,d)=lp(ä[v-^12]:map(\t->ä[t⊿0%0.04,t%d])c,d)
aam=vh 11.am
aar=ä[1-^10,4-^10,6-^1]&4
eam=vh 10.em
dm=6-^1∡2⋎(11-^1)
em d=5-^d∡2⋎(9-^1)
cdM=ḋ[4-^8,3-^8,2.^8,3.^8,cdM%1]
cdT=ḋ[ä[3-^(8/3)∡7,10-^6,am 1,am 1,cdM&7%1,dm,aam 4.05%1,em(4/3),12-^4,am 1,am 1,cdM&7%1,dm,aam 1%1,eam 4%1]%12.5⋎(ä(sil%(11/24) : map((%1).(m3a&))[4,4,4,0,4,1,4,4,4,0,4,1])&(-18)%13.1)
 ,p(ä[ä[ä[8-^2]⊿2%h,aar%(3/8),10-^8,aar%1,aar%1,cdM&7%1,11-^1,vh 11(10-^4)%1,9-^(4/3)]%7⋎(ä(map m3ra[0,0,0,0,1,0,2])&(-7)%7)])%6.75
 ,ä[p(ä[12-^4])%(1/4),am 1,am 1,cdM&7%1,dm,aam 1%1,eam 4%1,amf,ä[3-^4,1-^υ,5-^4,1-^υ,3-^4,1-^4,3-^4,1-^4,5-^4,1-^2]%3.75∡7,ä[amf∡(-14)]%0.56,ä[amf∡(-14)]⊿0.8%1]%12⋎(ä(sil%(1/8):map((%1).(m3a&))[4,4,4,0,4,1,4,4,4]++[m3a&4%h,m3a&4%h,5-^(8/5)])&(-18)%12)]
type D=Double
data F=N Int D|F[(Int,D)][([F],D)]
φ⇸F a fs=F a$map(\(f,d)->(map φ f,d))fs
_⇸N i d=N i d
i##c
 |i<1=(i+7)##c/2
 |i>7=(i-7)##c*2
 |1>0=1.06**(c i+case i of{1->0;3->3;4->5;5->7;6->8;7->10;_->fri i})
pl dur acc(N n v)=(\ω η->map(sin.(\x->x+τ x^2/η). \i->v*exp(-i*η/s)*τ(i*v)*(0.8-τ((i-dur)/90))*sin(i*ω))[1..dur])(n##acc/15.5).exp$fri n/9
pl dur acc(F accm fs)=pl' dur (foldr(\(q,m)f i->if q==i then m else f i)acc accm) fs
pl' dur _ _|dur<=0 = []
pl' dur _ []=map(\_->0)[1..dur]
pl' dur acc((f,dr):fs)|n<-min dr dur=trans(round n)(foldr1(\a b->sum a`par`sum b`pseq`zw(+)a b)(map(pl(n+99)acc)f))$pl'(dur-dr)acc fs
trans n a b|(f,ol)<-splitAt n a,(or,l)<-splitAt 99 b=f++zw(+)ol or++l
fri=fromIntegral
F a fs#q=F((q,1):a)fs
N i d&n=N(n+i)d
f&n=(&n)⇸f
N i d⇅n=N(n-i)d
f⇅n=(⇅n)⇸f
N i d⇆_=N i d
F a fs⇆n=F a.reverse$take n fs
N i d⊿v=N i$d*v
f⊿v=(⊿v)⇸f
p=(⊿0.3)
n.^q=([F[][([N n 1],s/2/q)]],s/q)
n-^q=([N n 1],s/q)
(l,d)⋎(r,_)=(l++r,d)
(l,d)∡j=(l++map(\h->ä[h⊿0%0.01,h&j%100])l,d)
f%t=([f],s*t)
tr n=F[]$cycle[n-^15,(n+1)-^20]
ä=F[];ḋ=F$zip[6,3,7][1,1,1]
lp=ä.repeat
sil=N 0 0
tev f(l,d)=(map f l,d)
h=1/2
υ=4/3
s=4e+4
sq d=ä.map(-^d)
es=sq 8 
arp8 n@(N i v)=F[][([n,ä[n⊿0%(1/8),n&7⊿(v/υ)%100]],s)]
arp8 f=arp8⇸f
hom q=ä.map(foldr((⋎).q)$sil%1)
dθ l=2*asin l/pi:dθ(abs.sin$l*1e+9)
rev ls=(\z->z id(foldr(\m sg->(\v->z(*v)(map(*0)[0..m*14349]++sg)sg)$abs(cos$(m*3)^2)-0.6)ls.take 9$dθ 1)ls)$(.lwp 3 0).zw.((+).)
lwp ω c(x:l)=c:lwp ω((x+c*ω)/(ω+1))l
lwp _ _ _=[]
hgp ω l=zw(-)l$lwp ω 0 l
lime e(x:l)
 |abs(e*x)>1,e'<-((e*8+abs(1/x))/9)=e':lime e' l
 |1>0=e:lime((e*49999+1)/5e4)l
lime _[]=[]
lim ls=zw(\a u->τ$a/9+max(-2)(min 2$a*u)/6)(map(*0)[0..500]++ls).lwp 9 0.lime 1$hgp 9 ls
zw=zipWith
τ=tanh

$ make
ghc -o bin / def0-hs def0.hs -O2 -fllvm -threaded
[1 of 1]编译Main(def0.hs,def0.o)
链接bin / def0-hs ...
time sh -c'bin / def0-hs + RTS -N4> hsoutp.pcm'189.39
用户138.41系统2:06.62经过258%CPU(0avgtext + 0avgdata 6440240maxresident)k
0inputs + 0outputs(0major + 403037minor)pagefaults 0swaps
ffmpeg -loglevel panicle -y -f -ar 44.1k -ac 2 -i hsoutp.pcm hsoutp.ogg


这是部分取消注释的版本:https ://gist.github.com/leftaroundabout/5517198 。


不错的尝试。2970 UTF-8字节,2826代码点 由于它不是<600 python版本的竞争对手,因此最好将其调整为更好的声音/和弦(例如,将其保持在5000字节以下)。
六。

1
@Vi。如果您认为UTF-8编码时的字节数是“程序的长度”,那么我认为您应该在问题中说明。只是
要说

@Bakuriu是的,对,哈哈。
Soham Chowdhury

太疯狂了!我很想知道这个程序是如何工作的。
shiona

@shiona:实际上并没有那么混淆,对于类型熟悉的Haskell和基本DSP的人来说,类型签名应该足够容易理解。

7

Python,331 + 286 = 617(每个注释0.548字节)

我的解决方案使用数据文件和python脚本。数据文件应用作脚本的输入。我没有玩法,但是当我将其作为原始数据导入带有签名的16位PCM,little-endian和2通道的Audacity中时,它可以工作。

数据文件为331字节。这是输出它的python脚本:

import sys
sys.stdout.write('\x08\x1c\x9d\xb9"\xc7\xea\xf0\xb7)\xc0D!u\x0bB~\'\x91S\xb2\x0c\xe9\xf8T;\xfd\xc13\xcf\xb9\xa6r>\xbc\xc5\xb4\xbb\xf8\xa4\x9a\x05H\xa0\x1d\x0eIq\t\\+\t\xdbn\x03\xc3&\x98\xa0\x11\xc5\xaa\xef\xbcSR^\x13\xe7\xc7\x0e\xc0\xa9^\x91Z\xfc\x02\x11\xb9\x1bE\xfc/=\xb8\xaf5<\x12\xa2\xc4\x02\xec\xdcO\xc2a\x04<Q\xfd\xe9L\xbc\xab%\xf5wX1F\xa6\x88\xddP\xfec(_#\xb4\x0bN\xba&m\xe3\xa4\x08Q\xdb\xd9\xf3<Q\xc6\xf6\x0e\xd7\xacd\x1f"g\xce\xae.\xb0\x90{|\x04\xc5X\xe6x>\xefE\xc8\xb0\xd2?N\x83?\x04\x86"a\xcc\x9b\x8fq\x9c\xce\xa2\xb6f\x9ab\x92\x9e:\xc0S\xcd\th\xb1\x87\xecT\x9d\xf4\n\xaf\xc9$`E5\xcc\xc5\xa0m\xcc\n8\xf8:\x03\xf5\x02H\xf3k\xe5\x86\xa64\x90\xa2\xc2w\xfa\xb7\xc0\x1e*2\x93\xca\x12\xe3^!\xd5yQ,LXW\xb4\x96D\x8dB\x9c`\xbf\x96`s;\xb7}\xeb\x8c\xebI\xa0o\x00\x08\xfe\xf1\xd2M3}\x8e\xd0\xda\x97\'\xca\x83-\x14\xda\xa1ET\n\xe8\xc7@\x1c\xa2a\xbb\xa7\x1b\x014\xdcz\xc7\xa6\xc4\x1d\x18\x04\r\xb1\x9e\xe3\xd0\x18<\x98`N?a\xe4\x8e\x9d\xd5\r\xe7Z[\xf4\xed\xf1PQ')

这是python脚本:

import sys
k=0
m=185
p=[]
q=[]
for c in sys.stdin.read():k=k*256+ord(c)
while k:
    v=k%m;k/=m
    if v<184:q+=[v]
    elif v-m+1:q+=p[v-184]
    else:m+=1;p+=[q];q=[]
for n in q:r=[1,2,3,4,6,8,12,15,16][n%9]*2000;sys.stdout.write(''.join(chr(int(i*1.06**(n/9)/4.3)%99)for i in range(r*3))+'\0'*r)

注意:如果您正在运行Windows,则-u因为两个stdin和stdout正在处理二进制数据,所以请对两个脚本都使用该开关。


做得好。考虑331 + 286 + 10(用于捆扎在一起的文件和脚本)== 627
六。

您可以使用os.read/write代替来缩短一点sys.stdin/stdout
Bakuriu

+50用于漂亮的压缩方案。使用不带熵编码的基于语法的方法,如果不考虑长度的话,我不能仅靠音符值来做到这一点。
彼得·泰勒

您能描述一下如何压缩数据吗?我有兴趣知道您怎么这么小。
Sir_Lagsalot

1
@Sir_Lagsalot:它基本上是一本嵌套/递归的字典,即您具有由音符(音高和长度编码为一个数字)组成的主题,然后您的主题包含这些主题和/或单个音符,然后由主题等组成。我的程序使用了基本相同的原理(通过换位,倒置等扩展),只是没有进一步压缩成紧密的二进制文件;我只是将所有内容都设为顶级变量定义。

4

GolfScript(129 + 369 = 498字节)

程序和数据文件都包含不可打印的字符,因此我将给出Base64和xxd表示形式。

程序(129字节):

MjU2YmFzZSA2OWJhc2VbMDpOXS8oNDMse1xbMSQpXS9cMiQ9Kn0vXCwpey19KyUuLDIvL3ppcHt+
TisyNSU6Tid7goqSm6SuuMPP2+j2/0FFSU1SV1xcYWdtdCc9OmY7MTc2MCosey41MD4qZioxNy8u
Li59JScnOm4rcHV0c30v

0000000: 3235 3662 6173 6520 3639 6261 7365 5b30  256base 69base[0
0000010: 3a4e 5d2f 2834 332c 7b5c 5b31 2429 5d2f  :N]/(43,{\[1$)]/
0000020: 5c32 243d 2a7d 2f5c 2c29 7b2d 7d2b 252e  \2$=*}/\,){-}+%.
0000030: 2c32 2f2f 7a69 707b 7e4e 2b32 3525 3a4e  ,2//zip{~N+25%:N
0000040: 277b 828a 929b a4ae b8c3 cfdb e8f6 ff41  '{.............A
0000050: 4549 4d52 575c 5c61 676d 7427 3d3a 663b  EIMRW\\agmt'=:f;
0000060: 3137 3630 2a2c 7b2e 3530 3e2a 662a 3137  1760*,{.50>*f*17
0000070: 2f2e 2e2e 7d25 2727 3a6e 2b70 7574 737d  /...}%'':n+puts}
0000080: 2f                                       /

数据(369字节):

LoDJFvCRQqNdL7+JDvjtSkX4HBS2FwgvjfdxAHrF1/DcMIBtG/g7QZBLLYHpzgaWaM1TaHwbtxG+
l1lqsL3A8nuprtpPI20YbHm3lf7NxmYNdEIMTlhwTG+TlSn802DzN3YgIwbcKbtty9gWmF2nVS55
iJHQZd4HCcokoLRwH1g2XqP8Yo5xj5/YQm9DH85obUv47mii5n+PwsoJZ6yaz4eSpGps6dQMl+Pa
YP/WC6cVDBBGs3vq5cGe51H2u7oVArFuHrsI2sHkGNYHlhWudKn5RRvJhe3sxfrtQE/MekKRuZBt
f4B9qdyss66vFipSi1zf2MXF9A/CzwvMQ/t9PEtxw8kzxxikp2Ek3kc9TiamLl+iG2vjdWp84JzY
Mg6cE+3bFI4kVdn+d1NEnBR/S9HMnksgEc9sdAcyWsbSaGjwetwGTr7UXkpKO9aHF01D2i5pCO40
/keR0+a+NsBEOXZfatpXav44AJjalywtLeWu

0000000: 2e80 c916 f091 42a3 5d2f bf89 0ef8 ed4a  ......B.]/.....J
0000010: 45f8 1c14 b617 082f 8df7 7100 7ac5 d7f0  E....../..q.z...
0000020: dc30 806d 1bf8 3b41 904b 2d81 e9ce 0696  .0.m..;A.K-.....
0000030: 68cd 5368 7c1b b711 be97 596a b0bd c0f2  h.Sh|.....Yj....
0000040: 7ba9 aeda 4f23 6d18 6c79 b795 fecd c666  {...O#m.ly.....f
0000050: 0d74 420c 4e58 704c 6f93 9529 fcd3 60f3  .tB.NXpLo..)..`.
0000060: 3776 2023 06dc 29bb 6dcb d816 985d a755  7v #..).m....].U
0000070: 2e79 8891 d065 de07 09ca 24a0 b470 1f58  .y...e....$..p.X
0000080: 365e a3fc 628e 718f 9fd8 426f 431f ce68  6^..b.q...BoC..h
0000090: 6d4b f8ee 68a2 e67f 8fc2 ca09 67ac 9acf  mK..h.......g...
00000a0: 8792 a46a 6ce9 d40c 97e3 da60 ffd6 0ba7  ...jl......`....
00000b0: 150c 1046 b37b eae5 c19e e751 f6bb ba15  ...F.{.....Q....
00000c0: 02b1 6e1e bb08 dac1 e418 d607 9615 ae74  ..n............t
00000d0: a9f9 451b c985 edec c5fa ed40 4fcc 7a42  ..E........@O.zB
00000e0: 91b9 906d 7f80 7da9 dcac b3ae af16 2a52  ...m..}.......*R
00000f0: 8b5c dfd8 c5c5 f40f c2cf 0bcc 43fb 7d3c  .\..........C.}<
0000100: 4b71 c3c9 33c7 18a4 a761 24de 473d 4e26  Kq..3....a$.G=N&
0000110: a62e 5fa2 1b6b e375 6a7c e09c d832 0e9c  .._..k.uj|...2..
0000120: 13ed db14 8e24 55d9 fe77 5344 9c14 7f4b  .....$U..wSD...K
0000130: d1cc 9e4b 2011 cf6c 7407 325a c6d2 6868  ...K ..lt.2Z..hh
0000140: f07a dc06 4ebe d45e 4a4a 3bd6 8717 4d43  .z..N..^JJ;...MC
0000150: da2e 6908 ee34 fe47 91d3 e6be 36c0 4439  ..i..4.G....6.D9
0000160: 765f 6ada 576a fe38 0098 da97 2c2d 2de5  v_j.Wj.8....,--.
0000170: ae                                       .

说明

我已经将(更新的)提供的乐谱(后面会详细介绍)整理成一个包含值从0到24的字节的单个字符串。然后音符值,表示为mod 25并进行差分编码。进行差异编码的原因是,在转置中重复的段落将减少为相同的序列,并且可以被压缩。

然后,我通过一个字符串转GolfScript压缩程序来运行此程序,该程序我之前已经提到过(为了在高尔夫运动中具有竞争力,我对其进行了改进)以获取数据文件,该文件由程序的第一部分解压缩:

256base 69base[0:N]/(43,{\[1$)]/\2$=*}/\,){-}+%

这是这种类型的简单语法扩展,对于那些看过许多标记为问题的人来说都很熟悉。

然后,我将该字符串分成两对,[length note]并在各对之间进行迭代。不可打印的字符来自魔术字符串,该魔术字符串包含音符的频率参数:我使用的是GolfScript的整数数组的隐式截断mod 256,将其转换为字符串以产生三角波*,因此基频为22050/256赫兹。我编写了一个程序来查找可以很好调整的整数比率。魔术弦包含分子,并且所有音符的分母17相同。平均调谐误差约为3.4美分。

音符长度按原样表示,并且比乐谱的先前版本更合理。正如我所怀疑的那样,舍入增加了字符串中的冗余,并将压缩的数据文件缩短了30个字节,更不用说保存了查找数组。但是,我仍然觉得有些可疑之处:

72 13

要么

71 9
69 2
71 2

提供比钩子上其他棒长六分之一的钩针长的棒,并且

85 9
85 4
85 24
85 23

要么

83 18
88 7
85 24
85 23

条数是整数,但有一些可疑的偏移量。

该程序可能会略短一些。我故意选择在执行时间上做空。由于我已经提交给Darren Smith,并且我相信他计划在某个时候发布,因此对GolfScript解释器进行了一些速度上的改进,当前版本在我的计算机上运行时间不到15分钟。如果puts在生成笔记后我没有每个音符,它的运行速度就会慢很多。

*我特此承认,我对使用方波的每个人的评论都是错误的。


如何正确运行GolfScript?我尝试base64 -d <<< 'MjU2Y.....9Lw==' | golfscript,它说golfscript:405:in 'scan': invalid byte sequence in UTF-8 (ArgumentError)(当然,如果我将程序保存到文件中也是如此)
Vi。

音符长度是使用粗略算法从MIDI文件中提取的(请参见play.pl的注释)。我将把音符的长度固定为理智。
六。

更新了要点。说明目前最小长度为1
六。

如果尝试使用在线解释器运行(插入的代码看起来像㔲戶獡⁥㌷慢敳せ为⽝㐨ⰴ屻ㅛ⤤⽝㉜㴤紪尯⤬⵻⭽⸥㈬⼯楺筰乾㈫┵为笧誂鮒꺤쎸��䇿䥅前屗慜浧❴㨽㭦∩ĦĂ༃ጔ؏༆ณؕḧ⸘研��⒖✏㰢⭻⩽㐴Ⱚ⹻〵⨾⩦㜱ⸯ⸮╽✧渺瀫瑵絳/),我将得到undefined method nil:NilClass`
Vi的

1
而且它不可能在在线解释器中运行-会超时。
彼得·泰勒

2

x86机器码-513字节

这不能完全解决挑战,因为它不是播放适合于播放的格式的输出,而是播放Midi。

可执行.COM文件和asm源代码 -音乐可能最多需要14秒才能开始播放。由于计时器分辨率为1/18秒,因此播放速度也会有些慢。

使用斐波那契编码和由先前解码的音乐组成的字典,将音乐编码为375字节。

伪码解码算法:

store_pos=0;
if ( !readBit() ){
    note = FibonacciDecode() + 63;
    time = FibonacciDecode();
    store(note, time);
    store_pos++;
} else {
    pos = FibonacciDecode();
    run = FibonacciDecode();
    copy(store_pos-pos,store_pos,run);
    store_pos+=run;
}

音乐解码后,只需将其输出到Midi端口即可。


1
它依赖于现有的合成器(在这种情况下,音频卡在MIDI内)而不是自己提供。
六。

您可以修改合成器,并将其输出样本输出到相应的端口或stdout / file(使用DOS或Linux syscalls)。作为单独的挑战,您可以使用完全成熟的和弦MIDI(仍然压缩成单个COM文件)来制作一个版本。
六。

我只是对挑战的“紧凑型莫扎特音乐”方面感兴趣,而不对合成器感兴趣。我发布此信息是因为它很有趣,应该让其他人感兴趣,而不是赢得挑战。
–'Sir_Lagsalot

好。等待Arduino版本...
Vi。
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.