<?xml version="1.0" encoding="utf-8"?>
<rss xmlns:atom="http://www.w3.org/2005/Atom" version="2.0"><channel><title>glitch / Drkcore</title><link>http://blog.kzfmix.com/entry/glitch</link><description>Programming, Music, Snowboarding</description><atom:link href="http://blog.kzfmix.com/rss/" rel="self"></atom:link><language>ja</language><lastBuildDate>Wed, 21 Oct 2009 17:04:32 +0900</lastBuildDate><item><title>夕焼けグリッチ</title><link>http://blog.kzfmix.com/entry/1256112234</link><description>&lt;p&gt;5x5のタイル状にしてみた。&lt;/p&gt;

&lt;p&gt;&lt;img src="http://www.kzfmix.com/images/blog/1256111943.jpg" alt="1256111943" /&gt; &lt;/p&gt;

&lt;p&gt;好みの夕暮れの色があるように、好みのノイズ量があるに違いないので、もう少しノイズの入れ方を考えないと。&lt;/p&gt;

&lt;pre&gt;&lt;code&gt;import base64,re,Image
from random import randint

def glitch(infile,outfile):
    jpg_text = base64.encodestring(open(infile,"rb").read())
    glitched_text = ""
    count = 0
    width,height = Image.open(infile).size
    num = width * height / 10000
    for c in jpg_text:
        if c == '0':
            if randint(0,num) == 0:
                count += 1
                glitched_text += str(randint(0,9))
            else:
                glitched_text += c
        else:
            glitched_text += c
    glitched_jpg = base64.decodestring(glitched_text)
    open(outfile,"wb").write(glitched_jpg)
    return count
if __name__ == '__main__':
    for i in range(25):
        outfile = "test_%d.jpg" % i
        count = glitch("/Users/kzfm/yuki3.jpg",outfile)
        #print "%d: %d" % (i,count)

    tiled_im = Image.new('RGB',(1600,1200))
    tiled_px = tiled_im.load()
    for i in range(5):
        for j in range(5):
            n = 5*i+j;
            imgfile = "/Users/kzfm/python/test_%d.jpg" % n
            im = Image.open(imgfile)
            px = im.load()
            for x in range(320):
                for y in range(240):
                    nx = 320 * j + x
                    ny = 240 * i + y
                    tiled_px[nx,ny] = px[x,y]
    tiled_im.show()
&lt;/code&gt;&lt;/pre&gt;
</description><pubDate>Wed, 21 Oct 2009 17:04:32 +0900</pubDate><category>Python</category><category>PIL</category><category>glitch</category></item><item><title>昼下がりグリッチ</title><link>http://blog.kzfmix.com/entry/1256101855</link><description>&lt;p&gt;今日もグリッチ&lt;/p&gt;

&lt;pre&gt;&lt;code&gt;import Image,sys
from random import randint

file = sys.argv[1]
im = Image.open(file)

width,height = im.size
interval = 0

for h in range(height):
    if(interval == 0):
        interval = randint(0,height-1)
        rand_slide_x = randint(0,14)
        rand_slide_y = randint(0,4)
        slide_x = 0
        slide_y = 0
    else:
        interval -= 1

    slide_x += rand_slide_x
    slide_y += rand_slide_y

    for w in range(width):
        current = (w,h)
        new_h = h + slide_y
        new_w = w + slide_x
        if new_h &amp;gt;= height: new_h = h
        if new_w &amp;gt;= width: new_w = w
        src = (new_w,new_h)
        im.putpixel(current,im.getpixel(src))

im.show()
im.save("glitch091021.jpg")
&lt;/code&gt;&lt;/pre&gt;

&lt;p&gt;&lt;img src="http://www.kzfmix.com/images/blog/1256101630.jpg" alt="1256101630" /&gt; &lt;/p&gt;
</description><pubDate>Wed, 21 Oct 2009 14:11:21 +0900</pubDate><category>Python</category><category>PIL</category><category>glitch</category></item><item><title>夕暮れグリッチ</title><link>http://blog.kzfmix.com/entry/1256027110</link><description>&lt;p&gt;そしたらベンジーあたしをグリッチで殴って&lt;/p&gt;

&lt;pre&gt;&lt;code&gt;import base64,re
from random import randint

jpgfile = "/Users/kzfm/orig.jpg"
jpg_text = base64.encodestring(open(jpgfile,"rb").read())
glitched_text = ""
for c in jpg_text:
    if c == '0':
        glitched_text += str(randint(0,9))
    else:
        glitched_text += c
glitched_jpg = base64.decodestring(glitched_text)
open("glitched.jpg","wb").write(glitched_jpg)
&lt;/code&gt;&lt;/pre&gt;

&lt;p&gt;&lt;img src="http://www.kzfmix.com/images/blog/1256026704.jpg" alt="1256026704" /&gt; &lt;/p&gt;

&lt;p&gt;&lt;a href="http://www001.upp.so-net.ne.jp/landscape/paper/imgproc005.htm"&gt;Jpeg においては DCT を施すために如何なる入力画像も 8x8 画素のブロックに分割される&lt;/a&gt;らしいのでbase64エンコーディングしたのをいじってデコードすると8x8のブロックの単位でノイズが混じるっていう理解でいいのか。&lt;/p&gt;

&lt;p&gt;参考&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;a href="http://userscripts.org/scripts/show/9653"&gt;GlitchMonkey&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;div class="awsxom"&gt;
&lt;a href="http://www.amazon.co.jp/exec/obidos/ASIN/B00000JD1I/ref=nosim/kaerutyuuihou-22"&gt;
&lt;img src="http://ecx.images-amazon.com/images/I/41R7FQ4EBQL._SL160_.jpg" align="left" hspace="5" border="0" alt="ProductName" class="image" /&gt;
&lt;strong&gt;無罪モラトリアム&lt;/strong&gt;&lt;/a&gt;&lt;br /&gt;
椎名林檎 &lt;br /&gt;
EMIミュージック・ジャパン / ￥ 3,059 (1999-02-24)&lt;br /&gt;
在庫あり。&lt;br /&gt;
&lt;br clear="all" /&gt;
&lt;/div&gt;&lt;/p&gt;
</description><pubDate>Tue, 20 Oct 2009 17:25:46 +0900</pubDate><category>Python</category><category>glitch</category></item><item><title>PILでglitch</title><link>http://blog.kzfmix.com/entry/1255994030</link><description>&lt;p&gt;早朝グリッチ。PILのputpixelは遅いので、1.1.6からはim.loadを使えとのこと。&lt;/p&gt;

&lt;pre&gt;&lt;code&gt;import Image,sys
from random import randint

file = sys.argv[1]
im = Image.open(file)

width,height = im.size
slide_x = 0
slide_y = 0
rand_slide_x = randint(0,14)
rand_slide_y = randint(0,4)

pix = im.load()
for h in range(height):
    slide_x += rand_slide_x
    slide_y += rand_slide_y

    for w in range(width):
        new_h = h + slide_y
        new_w = w + slide_x
        if new_h &amp;gt;= height: new_h = h
        if new_w &amp;gt;= width: new_w = w
        pix[w,h] = pix[new_w,new_h]

im.show()
im.save("glitch091020.jpg")
&lt;/code&gt;&lt;/pre&gt;

&lt;p&gt;&lt;img src="http://www.kzfmix.com/images/blog/1255993806.jpg" alt="1255993806" /&gt; &lt;/p&gt;

&lt;p&gt;そしてGlitch: Perfet Imperfectionsもポチッた&lt;/p&gt;

&lt;p&gt;&lt;div class="awsxom"&gt;
&lt;a href="http://www.amazon.co.jp/exec/obidos/ASIN/0979966663/ref=nosim/kaerutyuuihou-22"&gt;
&lt;img src="http://ecx.images-amazon.com/images/I/61BPZtEepdL._SL160_.jpg" align="left" hspace="5" border="0" alt="ProductName" class="image" /&gt;
&lt;strong&gt;Glitch: Perfet Imperfections&lt;/strong&gt;&lt;/a&gt;&lt;br /&gt;
Iman Moradi,Ant Scott,Joe Gilmore,Christopher Murphy &lt;br /&gt;
Mark Batty Pub / ￥ 3,105 ()&lt;br /&gt;
通常1～3週間以内に発送&lt;br /&gt;
&lt;br clear="all" /&gt;
&lt;/div&gt;&lt;/p&gt;

&lt;p&gt;参考&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;a href="http://hysysk.blogspot.com/2007/11/todays-glitch-2.html"&gt;today's glitch 2&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="http://d.hatena.ne.jp/koyachi/20071107/1194413657"&gt;きょうのglitch&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;
</description><pubDate>Tue, 20 Oct 2009 14:24:51 +0900</pubDate><category>Python</category><category>PIL</category><category>glitch</category></item></channel></rss>
