Data Visualization and D3.js 笔记(1)
课程地址: https://classroom.udacity.com/courses/ud507
什么是数据可视化?
- 高效传达一个故事/概念,探索数据的pattern
- 通过颜色、尺寸、形式在视觉上表示基础数据和storytelling,然后得到一些发现
数据可视化是一种从值到图像的映射,将结构化的数据信息转化为更易理解的视觉图像。
什么是好的数据可视化?[by Cole Nussbaumer]
- 对内容有透彻的理解,知道谁是观众、他们想得到什么?
- 数据展示,选择恰当的图像类型
- 排除无效信息,删除不会为图像增加价值的内容。降低认知负担,突出数据
- 通过颜色、尺寸、布局等元素吸引观众注意力,让他们知道哪里是重点
- 故事叙述。好的数据可视化会让本身成为故事或叙述的关键点
数据科学与数据可视化

(by Ben Fry)
这是一个非线性迭代,在过程中会不断回溯前一步骤,或从新数据得到新结果进行合并。
EDA vs. Data Visualization
EDA, Exploratory Data Analysis, is whatever happened between you and your data when you are not trying to proof anything to anyone. But Data Visualization cares about it.
Amscombe 四重奏
Anscombe’s quartet是指四组基本统计特征(均值、方差、相关系数、最优拟合线)一致的数据,由他们绘制出来的图形截然不同。
说明分析数据前先绘制图表的重要性,以及离群值对统计的影响。
Data && Data Types
- 值数据 Quantitative Data
- 离散
- 连续
- 分类数据 Categorical Data (表示特性,可以用数值表示,但是没有数学意义)
- 定类数据 Nominal
- 对数据进行标注和分类的一种方法
- 有序数据 Ordinal
- 定类数据 Nominal
- 时序数据 Time Series Data
- 经过长时间重复观测得到的数据集合
Visual Encoding
Visual Encoding is mapping data to display elements.
- Position
平面内可对x和y两个变量进行编码
人眼对三维很难迅速感知 - Retinal Variables 视网膜变量
- For Ordered Data
- size
- orientation
- color saturation
- For Nominal Data
- color hue
- shape
- texture
- For Ordered Data
- Animation
not a Visual Encoding, but encodes some information- time 用帧来代表时间
大专栏 Data Visualization and D3.js 笔记(1)l Encoding">Rankings of Visual Encoding

D3.js

D3: Data Driven Document
- Data: csv / json
- Driven: 将csv / json 数据与SVG元素结合 (DOM)
- Document: HTML, CSS, JS, SVG
DOM 与 HTML
浏览器存储两种Web页面/视图
从服务器返回的初始源
1
2
3
4
5
6
7<html>
<head>
</head>
<body>
<svg>
</body>
</html>解析的DOM对象
- DOM 是一个规范,为HTML和XML文档规定了常见的编程接口
- 在页面被加载的时候逐步解析
- 通过JavaScript API访问
将HTML转为DOM
- 用户发出访问某一URL的请求
- 浏览器向服务器发送请求
- 浏览器收到服务器响应,即HTML
- 浏览器开始处理HTML文件
- 遇到一个标记,如
<html>,浏览器会发出一个token,startTag: htmlstartTag:headmetalink - 同时会消耗这些token, 生成节点对象,并建立联系
- DOM树被生成

有趣的图表们
斜率图 Slope Graph
用斜率代表方向和变化量,可以进行group之间的比较
小多组图 Small Multiples
利用相同的布局,可以进行
- 数据
- 数据组
之间的比较
一些链接
- https://charts.animateddata.co.uk/uktemperaturelines/
- http://www.storytellingwithdata.com/blog/2014/03/more-on-slopegraphs
- https://www.youtube.com/watch?v=jbkSRLYSojo
- https://www.targetprocess.com/articles/visual-encoding/
Data Visualization and D3.js 笔记(1)的更多相关文章
- D3 & Data Visualization in Ext JS
通过适配器可以在ExtJs中轻松的集成D3的展示能力 http://video.sencha.com/watch/zvUjnFJ91xVvuwdTh2zjqP?mkt_tok=eyJpIjoiWm1a ...
- 精通D3.js笔记
DOM常用属性 innerHTML: 元素标签内部的文本. innerText outerHTML outerText nodeName: 节点名称 parentNode: 父节点 nextSibli ...
- Python equivalent of D3.js
http://brandonrose.org/ Python equivalent of D3.js Ask Question Asked 7 years, 1 month ago Act ...
- d3.js:数据可视化利器之快速入门
hello,data! 在进入d3.js之前,我们先用一个小例子回顾一下将数据可视化的基本流程. 任务 用横向柱状图来直观显示以下数据: var data = [10,15,23,78,57,29,3 ...
- D3.js & Data Visualization & SVG
D3.js & Data Visualization & SVG https://davidwalsh.name/learning-d3 // import {scaleLinear} ...
- d3.js读书笔记-1
d3.js入门 d3入门 D3是一个强大的数据可视化工具,它是基于Javascript库的,用于创建数据可视化图形.在生成可视化图形的过程中,需要以下几步: 把数据加载到浏览器的内存空间: 把数据绑定 ...
- 【 D3.js 选择集与数据详解 — 2 】 使用data()绑定数据
D3 中绑定数据大多是由 data() 函数来完成的,它是怎样工作的,它与 datum() 有什么区别呢? data()函数能够将数组各项分别绑定到各元素上,而且能够设置绑定的规则.data()还能够 ...
- Data Visualization 课程 笔记1
对数据可视化比较有兴趣,因此最近在看coursera上伊利诺伊大学香槟分校的数据可视化课程,做了一些笔记. 1. 定义 Data visualization is a high bandwidth c ...
- 学习笔记之Data Visualization
Data visualization - Wikipedia https://en.wikipedia.org/wiki/Data_visualization Data visualization o ...
随机推荐
- Maven--导出pom中依赖的jar包
参考:https://my.oschina.net/cloudcoder/blog/212648 mvn dependency:copy-dependencies -DoutputDirectory= ...
- request请求生命周期
request请求生命周期 一.request请求分析 1.1. request数据请求 # views.py from rest_framework.views import APIView fro ...
- Java常见异常说明汇总
1. java.lang.nullpointerexception 这个异常大家肯定都经常遇到,异常的解释是"程序遇上了空指针",简单地说就是调用了未经初始化的对象或者是不存在的对 ...
- 使用tensorflow的retrain.py训练图片分类器
参考 https://hackernoon.com/creating-insanely-fast-image-classifiers-with-mobilenet-in-tensorflow-f030 ...
- 利用docker安装gitlab
安装docker 安装 virtualbox 下载 dockertoolbox并安装 官网的服务器一直连不上, 幸亏还有这个 https://get.daocloud.io/toolbox/ 比 ht ...
- redis设置cpu核数与内存
每个redis实例,给系统要预留至少1/4核,可使用1核心cpu.内存要预留1/2. 比如:8核120G的服务器,可部署8-8/4=6个redis实例,每个实例120/2/6=10G内存.
- 00 - 准备 Anaconda 环境
Anaconda 环境 官方下载安装包:https://www.anaconda.com/download/ Anaconda Navigtor :用于管理工具包和环境的图形用户界面,后续涉及的众多管 ...
- RPM包和YUM仓库管理
1.RPM包管理 RPMRPM Package Manger,前身Redhat Package Manger,由红帽开发用于软件包的安装升级卸载与查询有一个完整的数据库体系,每个RPM包的所有信息都固 ...
- 用Kinect为听障人士架一座沟通的桥梁
编者按:这是微软亚洲研究院和中国科学院共同进行的一个合作项目,希望通过使用Kinect来帮助提升手语的识别率,从而为听力受损的残障人士(以下简称听障人士)架起一座与外界沟通的桥梁. 文章译自:Digi ...
- nginx相关地址
http://www.nginx.cn/doc/ 中文文档 http://nginx.org/en/docs/ 英文文档 https://pan.baidu.com/s/1qWAZ ...