当前位置: 首页 > news >正文

做网站开发 用什么网页设计与制作dw教程

做网站开发 用什么,网页设计与制作dw教程,门户网站建设好处,摄影网站建设解决方案SVD方法是模型降阶的一类重要方法,本征正交分解(POD)和平衡截断(BT)都属于SVD类方法。 要想深入了解模型降阶技术,我们可以先从SVD的应用入手,做一个直观的了解。 1. SVD的定义和分类 我们想寻找…

SVD方法是模型降阶的一类重要方法,本征正交分解(POD)和平衡截断(BT)都属于SVD类方法。

要想深入了解模型降阶技术,我们可以先从SVD的应用入手,做一个直观的了解。

1. SVD的定义和分类

我们想寻找一个A的逼近:Ak,使得rank(Ak) = k < n,且|A - Ak|最小。

下面的定理(也称为Schmidt-Mirsky, Eckart-Young定理)说明矩阵A的低秩逼近可以用SVD实现:

2. SVD在图像压缩中的应用

原始图片, rank=720:

绘制其R,G,B的奇异值:

压缩图片,rank=144:

压缩图片,rank=72:

代码:

import numpy as np
import matplotlib.pyplot as plt
import matplotlib.image as imageA = image.imread("svd-image-compression-img.jpg")# Each pixel (typically) consists of 3 bytes — for the red, green and blue components of the color, respectively. 
# So, if we want to efficiently store the image, we need to somehow efficiently encode 3 matrices R, G and B 
# for each color component, respectively.
# We can extract the 3 color component matrices as briefly mentioned above as follows:
# 0xff代表十进制数值255
R = A[:,:,0] / 0xff
G = A[:,:,1] / 0xff
B = A[:,:,2] / 0xff# Now, we compute the SVD decomposition:
R_U, R_S, R_VT = np.linalg.svd(R)
G_U, G_S, G_VT = np.linalg.svd(G)
B_U, B_S, B_VT = np.linalg.svd(B)# polt the singular values
xaxis = np.arange(0, len(R_S))
plt.plot(xaxis, R_S, label='R_S')
plt.plot(xaxis, G_S, label='G_S')
plt.plot(xaxis, B_S, label='B_S')
plt.legend()relative_rank = 0.1
max_rank = int(relative_rank * min(R.shape[0], R.shape[1]))
print("max rank = %d" % max_rank)  # 144def read_as_compressed(U, S, VT, k):Ak = np.zeros((U.shape[0], VT.shape[1]))for i in range(k):U_i = U[:,[i]]VT_i = np.array([VT[i]])Ak += S[i] * (U_i @ VT_i)return Ak## Actually, it is easier and more efficient to perform the same operation 
## with a lower-rank matrix multiplication.
# def read_as_compressed(U, S, VT, k):
#     return (U[:,:k] @ np.diag(S[:k])) @ VT[:k]R_compressed = read_as_compressed(R_U, R_S, R_VT, max_rank)
G_compressed = read_as_compressed(G_U, G_S, G_VT, max_rank)
B_compressed = read_as_compressed(B_U, B_S, B_VT, max_rank)compressed_float = np.dstack((R_compressed, G_compressed, B_compressed))
compressed = (np.minimum(compressed_float, 1.0) * 0xff).astype(np.uint8)# Plot
plt.figure()
plt.imshow(A)plt.figure()
plt.imshow(compressed)image.imsave("compressed.jpg", compressed)

参考资料:

[A.C. Antoulas 2001] Approximation of large-scale dynamical systems: An overview
[潘建瑜] 矩阵计算_讲义 
Compressing images with singular value decomposition (SVD) | ZeroBone
http://www.yayakq.cn/news/251811/

相关文章:

  • 产品摄影网站wordpress删除谷歌字体
  • 建网站需要多大的宽带电商推广渠道
  • 网站开发用什么浏览器高州网站建设
  • 东莞学校网站建设司法网站建设与维护 教材
  • 海外网站的建设石家庄新闻主持人
  • mvc5网站开发之六企业网站实名制
  • 自己做的网站地址手机怎么打不开备案期间网站如何访问
  • 鞍山制作网站财务公司业务范围
  • 公司怎样建自己网站做网页推广的网站
  • 企业网站建设费用怎么记账温州市住房和城乡建设局
  • 福州微信营销网站建设常德行业网站
  • 企业微信官方网站闵行网络推广公司
  • 国内永久免费crm系统网站推荐有哪些公司网站建站收费
  • 有口碑的企业网站建设江苏建站管理系统信息
  • 网站空间里绑定好域名肥乡邯郸做网站
  • 和平网站建设公司属于网站的管理 更新 维护
  • 外贸seo网站制作友链之家
  • 理财 网站模板 html软件开发办公
  • 专业的上海网站建设公司哪家好万户网络技术有限公司官网
  • 深圳做网站哪家公司好北京网站优化服务商
  • 怎么用域名做邮箱网站注册自己的网站需要多少钱
  • 妇产科网站建设兰州专业做网站
  • 行业网站推广什么意思用阿里云空降怎么建设网站
  • 多国语言网站建设云南网首页
  • 网站建设的心得与体会如何做网络营销推广 咨询时代达信(深圳)科技有限公司
  • 长沙网站制作方法html5作业 建设网站
  • 网站开发从事网站访问慢的原因
  • 视频网站怎么做采集企业网站的劣势
  • c 视频播放网站开发网站营销推广策划方案
  • 哪里有手机网站建设产品网站设计理念