python Arnold变换

import numpy as np
import random,cv2
from PIL import Image
def img():
    image = cv2.imread('bmg.png')
    mat= np.array(image)
    r,g,b = [image[:,:,i] for i in range(3)]
    img_gray = r*0.299+g*0.587+b*0.114#灰度处理
    image2 = Image.fromarray(img_gray)
    image2.show()
    a=1
    b=1
    N=200
    an=np.zeros([200,200])
    for i in range(0,150):#200*200矩阵150轮变换复原
        for y in range(0,200):
            for x in range(0,200):#变换每个像素点
                xx=(a*x+b*y)%N
                yy=(a*x+(a*b+1)*y)%N
                an[xx][yy]=img_gray[x][y]
        img_gray[:][:]=an[:][:]
        if (i+1)%50==0:#每50轮输出一次变换图像
            image2 = Image.fromarray(img_gray)
            image2.show()

if __name__=="__main__":
    img()
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值