Production Level Knowledge & Tips

  1. アカデミック
  2. 49 view

[Ruby][ImageProcessing]rubyで画像処理ができる環境を作ってみる

1.RVM インストール

wget --no-check-certificate https://raw.github.com/wayneeseguin/rvm/master/binscripts/rvm-installer

bash ./rvm-installer

source ~/.bashrc

ls -la ~/.rvm

rvm install ruby-1.9.3-p385

/bin/bash --login
rvm use ruby-1.9.3-p385 --default

# .bashrcに以下を追加
if [[ -s $HOME/.rvm/scripts/rvm ]] then
    source $HOME/.rvm/scripts/rvm
fi

rvm reload

ruby -v
gem -v

echo "gem: --no-rdoc --no-ri" >> ~/.gemrc

gem install bundler

2.libimlib2-rubyをインストール

sudo apt-get install libimlib2-ruby

3.グレースケールにするプログラムを書いてみる

参考:http://d.hatena.ne.jp/tohka383/20120201/1328037573
require 'imlib2'

img = Imlib2::Image.load("src/lena.jpg")

img.h.times do |y|
  img.w.times do |x|
    color = img.pixel(x, y)

    gray = (0.299 * color.r + 0.587 * color.g + 0.114 * color.b).to_i
    color.r = color.g = color.b = gray

    img.draw_pixel(x, y, color)
  end
end

img.save("dst/lena.jpg")
src
dst
うまくいった♪

4. ラプラシアンフィルタをかけてみる

require 'imlib2'

img = Imlib2::Image.load("srcimg/lena.jpg")

img.h.times do |y|
    img.w.times do |x|
        color = img.pixel(x, y)

        gray = (0.299 * color.r + 0.587 * color.g + 0.114 * color.b).to_i
        color.r = color.g = color.b = gray

        img.draw_pixel(x, y, color)
    end
end

dstimg = Imlib2::Image.create(img.width, img.height)
laplacian_filter=[[1,1,1],[1,-8,1],[1,1,1]]
dstimg.h.times do |y|
    dstimg.w.times do |x|
        if x == 0 or x == dstimg.width
            next
        end
        if y == 0 or y == dstimg.height
            next
        end

        sum = 0
        for i in -1..1 do
            for j in -1..1 do
                color = img.pixel(x+j, y+i)
                sum += color.r * laplacian_filter[i+1][j+1]
            end
        end
        if sum < 0
            sum = 0
        end

        color = img.pixel(x,y)
        color.r = color.b = color.g = sum

        dstimg.draw_pixel(x, y, color)
    end
end

dstimg.save("dstimg/edge.jpg")
src
edge
良さげ♪

アカデミックの最近記事

  1. How to bring columns not GROUP BY key from ne…

  2. HiveでGROUP BYを伴うサブクエリのネストからGROUP BYのキー以外のカラムを…

  3. How to drop Hive’s External Table

  4. HiveでExternal Tableを削除する方法メモ

  5. [触ってみた]Microsoft Quantum Development Kit

関連記事

PAGE TOP