数据集可视化——tile("贴砖")

在大量的数据处理或者计算机视觉的文献和著作中,我们常见如下的数据集可视化(甚至对参数也可进行可视化,毕竟图像的本质是二维数组),通过文章末尾的代码我们发现只需对布局及间距的慎重设置,便可对大量丰富的图像以”地板贴砖(tiles on a floor)”的形式进行组织,也即可视化,展示数据或相关工作,可以起到十分直观的效果,下图即是对深度神经网络的权值矩阵进行的贴砖可视化:


这里写图片描述

def normalize(darr, eps=1e-8):
    # normalize(x) = (x-min)/(max-min)
    darr -= darr.min()
    darr *= 1./(darr.max()+eps)
    return darr

def tile_raster_images(X, image_shape, tile_shape, 
            tile_spacing=(0, 0), normalize_rows=True, output_pixel_vals=True):
            # image_shape:每一个砖的高和宽,
            # tile_shape:在横纵两个方向上分别有多少砖
            # tile_spacing:砖与砖之间的距离
            # normalize_rows:是否对砖进行归一化
            # output_pixel_vals:是否对砖以图像的形式进行显示

    assert len(image_shape) == 2
    assert len(tile_shape) == 2
    assert len(tile_spacing) == 2
                            # 对参数进行断言,确保它们都是二维元组
    output_shape = [
        (ishp + tsp)*tshp-tsp
        for ishp, tshp, tsp in zip(image_shape, tile_shape, tile_spacing)
    ]
                    # image_shape == (28, 28)   mnist data
                    # tile_shape == (10, 10), tile_spacing == (1, 1)
                    # [(28+1)*10-1]*[(28+1)*10-1]                   

    H, W = image_shape
    Hs, Ws = tile_spacing
    dt = 'uint8' if output_pixel_vals else X.dtype
                            # python 风格的三目运算符
    output_array = numpy.zeros(output_shape, dtype=dt)

    # 开始贴砖
    for i in range(tile_shape[0]):
        for j in range(tile_shape[1]):
            if i*tile_shape[1]+j < X.shape[0]:
                    # X的每一行是一个图像(二维)flatten后的(一维的行向量)
                this_x = X[i*tile_shape[1]+j]
                this_image = normalize(this_x.reshape(image_shape)) if normalize_rows else this_x.reshape(image_shape)
                c = 255 if output_pixel_vals else 1
                output_array[
                    i*(H+Hs):i*(H+Hs)+H, j*(W+Ws):j*(W+Ws)+W
                ] = this_image*c
    return output_array

客户端调用:

import numpy
from PIL import Image

X = numpy.random.randn(500, 28*28)
arr = tile_raster_images(X, image_shape=(28, 28), 
            tile_shape=(12, 12), tile_spacing=(1, 1))
img = Image.fromarray(arr)
img.show()
img.save('./tiles.png')
    # 这里也可使用 matplotlib 进行显示
    # plt.imshow(img, cmap='gray')
    # plt.show()


这里写图片描述

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
OpenLayers是一个开源的JavaScript库,用于在Web浏览器中显示交互式地图。OpenLayers可以加载各种类型的地图数据,包括矢量数据、栅格数据、WMS服务等。下面是实现可视化的步骤: 1. 准备气象战点数据,可以是CSV、JSON等格式的文件。 2. 在HTML页面中添加OpenLayers的引用: ``` <script src="https://cdn.jsdelivr.net/npm/ol@6.4.3/dist/ol.js"></script> <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/ol@6.4.3/dist/ol.css" /> ``` 3. 创建一个地图容器: ``` <div id="map" style="width: 100%; height: 600px;"></div> ``` 4. 创建一个OpenLayers地图对象: ``` var map = new ol.Map({ target: 'map', layers: [ new ol.layer.Tile({ source: new ol.source.OSM() }) ], view: new ol.View({ center: ol.proj.fromLonLat([120, 30]), zoom: 8 }) }); ``` 5. 加载气象战点数据: ``` var features = []; // 读取CSV文件中的数据 d3.csv("data.csv", function(data) { data.forEach(function(d) { // 将数据转换为OpenLayers要求的格式 var feature = new ol.Feature({ geometry: new ol.geom.Point(ol.proj.fromLonLat([+d.lng, +d.lat])), name: d.name, value: +d.value }); features.push(feature); }); // 创建矢量图层 var vectorLayer = new ol.layer.Vector({ source: new ol.source.Vector({ features: features }), style: function(feature) { // 根据value的值设置点的颜色和大小 var color = 'rgba(255, 0, 0, 0.5)'; var size = 10; if (feature.get('value') > 10) { color = 'rgba(0, 255, 0, 0.5)'; size = 20; } return new ol.style.Style({ image: new ol.style.Circle({ radius: size, fill: new ol.style.Fill({ color: color }) }) }); } }); // 将矢量图层添加到地图中 map.addLayer(vectorLayer); }); ``` 6. 根据需要设置地图的样式和交互功能。 以上就是使用OpenLayers加载气象战点数据实现可视化的步骤。需要注意的是,代码中使用了d3.csv方法读取CSV文件中的数据,因此需要在HTML页面中添加d3.js的引用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

五道口纳什

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值