% A9 a$ F/ P* x1 d5 Q6 R
在 GIJN 的“我最喜爱的工具”系列中,我们采访了彭博社数据记者莱昂纳多·尼科莱蒂(Leonardo Nicoletti)。他近期的项目深入探讨了社交媒体上的极端主义、生成式 AI 中的种族和性别刻板印象,以及美国的阿片类药物危机。
; y. P: k* j& f ' a, o4 Q! L& J( r
莱昂纳多·尼科莱蒂在 2024 年佩鲁贾国际新闻节上,与 Sigma 奖得主们一起讨论他们的工作。图:由 Ascanio Pepe 为 IJF 拍摄,遵循 CC 许可协议使用
R3 g' b. ~( B; a' V, I尼科莱蒂进入新闻业的道路颇为曲折——他曾在学术界工作多年。但即使在学生时代,他就对视觉表达有着敏锐的洞察力。 % R3 `1 Z) F. O3 P4 x+ W& ^+ `+ C
“我在学生时期热衷于摄影,主要是街头摄影,这份热情至今未减,”他说。“那时我意识到自己对讲故事、尤其是人文故事非常感兴趣。”
, n4 h" ~. B6 o/ Q5 o
1 F2 H+ q7 ?3 n$ P) B- N( X毕业后,他继续在学术界深耕,利用开源技术衡量城市中的不平等,并量化与环境脆弱性相关的挑战。“那段时间,我对数据可视化以及如何用它向更广泛的受众传达复杂理念产生了浓厚兴趣,并开始在网络上构建应用程序。”
/ O+ b7 I( _9 U y, {; o$ z在与他人合作为《The Pudding》撰写的一篇关于新闻中女性代表性的视觉文章后,尼科莱蒂开始全职进入新闻领域,并于同年晚些时候加入彭博社。此后,他的工作获得了全球认可,特别是他对生成式 AI 和文本到图像模型在放大种族和性别刻板印象方面的影响的研究。他与同事合作撰写的文章《人类有偏见,但生成式 AI 更甚》(Humans Are Biased. Generative AI Is Even Worse)获得了 2024 年 Sigma 奖。
2 O, l! w+ g, ]. K! W1 X' t; f" D“这是新闻领域首个数据驱动的调查,关注图像生成器,并大规模量化其中存在的性别和种族偏见,”他解释道。 . ?8 e7 o; H2 L9 f* X& e1 ?% h
尼科莱蒂的工作还获得了其他许多荣誉,如新闻设计学会的认可。他的研究,特别是关于生成式 AI 风险的研究,被联合国和国际货币基金组织引用。
9 }4 }/ N f( H0 A“由于我的工作介于分析、数据调查,以及数据可视化和交互式图形之间,我使用了许多与数据科学相关的编程语言和工具。” ——莱昂纳多・尼科莱蒂 % f/ i# w' G: R5 n8 |0 x
尼科莱蒂在彭博社的工作让他深入研究了技术问责的问题,将技术对人的影响放在首位。1 `+ @+ A7 j9 F' u2 e2 t3 Z
5 b" `& E4 c, y7 D c( L“彭博社报道不一定都是金融故事,但总有商业视角或某种金融角度,”尼科莱蒂指出:“这看似有局限性,但我发现并非如此,几乎任何故事都能与某家公司、经济趋势或资金流动关联起来。” % a/ C- o* H% u: l
近期,他制作了各种各样的报道,从探讨 OpenAI 的 GPT 如何导致招聘中的种族偏见,到 AI 如何“扰乱”全球电力系统的调查,再到深入研究隐藏的芬太尼如何将美国阿片类药物死亡推向新阶段。以下是他最喜欢的一些工具。
x7 T; Q7 k. h" V% z
9 g. `* N8 E/ u5 ?) d4 v! {Python 1 ]' N3 F0 L) t1 k+ V3 R
“我的工作涉及数据分析、调查、可视化和交互图形,主要使用Python和R这类数据科学工具,其中以Python为主,”尼科莱蒂说。 ; V7 Y( R; f- l1 x I- f
“我使用 Jupyter Notebook 上使用 pandas 和 geopandas 等 Python 库”他补充道。Pandas 通过构建、操作和转换数据来分析大型数据集;geopandas则简化了Python中地理空间数据的处理流程。
; g. } O- f/ R( C, Q- Q他还使用 spaCy 这个开源Python库,用于处理大量文本并构建自然语言处理应用,比如根据情感分析对演讲等文本进行分类,判断表达的语气或观点。
& E6 [" G* ^) t4 t8 P# ]! U% O: {“有时我们需要进行自然语言处理,这时会用到 spaCy 等工具,具体使用什么要看项目需求。但主要还是用Python做数据分析,网页抓取也经常用到,”他说。
, {3 m8 U) p+ C! l7 OD3.js and Svelte
. x9 T. g) Z1 ?7 f; _3 R! r. R7 h4 LD3.js 是一个用于在网络上创建自定义图形的 JavaScript 库,能够对可视化进行全面定制。
+ d {! k5 C) g t“在网络上构建数据可视化和交互式图形都是用网络语言完成的,所以都是 JavaScript、HTML、CSS,还有像 D3 这样非常有用的 JavaScript 库,”尼科莱蒂指出。
6 H% c) o' R# M& t+ _6 m9 e% W, G, R“在网络上构建数据可视化和交互式图形都需要用到网络语言,也就是 JavaScript、HTML、CSS,还有像 D3 这样非常实用的JavaScript库,”尼科莱蒂指出。
+ t; W$ F, E2 D" Q4 H2 o* M2 R1 VSvelte 是一个开源JavaScript框架,用于构建具有交互设计的网络应用程序,当底层数据发生变化时,它会自动更新用户界面。 # |: l4 E1 Z& n) `( B
“它让你能够创建响应迅速的网页,用简洁的方式实现丰富的交互,而无需处理繁琐的网络基础问题。这些都由它来处理,”尼科莱蒂说。 ! c' c4 n8 Y7 w; v; f! U. r
“它让过渡效果变得容易实现。比如,你有一个散点图,每个点代表一个国家,你想将这些点移动到实际的国家位置,再转换成条形图。在关于 Stable Diffusion 的文章中——或者看看我参与的大多数作品,都有大量动画和过渡效果。这些基本上都是通过 D3 来计算位置,然后用 Svelte 实现数据点的平滑过渡,比如当用户滚动到页面特定位置时。”
1 F; Q0 d6 a0 X; {) o9 JQGIS ; H" S* L# o# w& f8 x0 B$ ^% [
QGIS 是一款开源软件,是想要在不购买专有软件的情况下进行制图的人们的首选工具。
$ B8 j/ C: g/ C8 q“我的理念是尽可能使用开源软件,这样你可以重复使用,不必担心服务的API是否会改变。这样可以减少依赖,获得更多自由,”尼科莱蒂解释道。
/ h7 T4 W1 k+ \QGIS 可用于使用矢量和栅格数据来分析和编辑几乎所有形式的地图和空间数据。 ( ] W/ N6 F* C q/ H j8 U
尼科莱蒂的一个个人项目使用 QGIS 绘制了全球范围内的城市,这些城市为居民提供了在 15 分钟步行范围内可达的服务。City Access Map 使用了 Mapbox,但尼科莱蒂的大部分数据探索都是在 QGIS 中完成的。“我写了一个 Python 脚本,利用了 QGIS 的功能,因为它有许多非常强大的地理空间功能,这些功能并不总是在 Python 中实现。我处理了全球约 11000 个城市,数据量巨大,而 QGIS 的效率最高,”尼科莱蒂说。
+ M8 n r6 y) F, U“我经常使用 QGIS 来探索数据,有时我只是想把数据放在地图上,看看它的样子并进行放大,所以这非常有用,”他补充道。“QGIS 中也有很多插件,有时在 QGIS 脚本中做一些事情比在 Python 中更容易。” 3 ~% Y6 r( X' o: i; o. i3 k) ]
![]() 尼科莱蒂的 CityAccessMap 从全球角度展示了为居民提供15分钟步行范围内可达服务的人口中心。图:CityAccessMap 截图
& x3 w+ C. y, hHTML Canvas
1 _9 o0 n: h" w2 z6 b, E) u/ y3 WHTML的功能使在网络上生成动态交互式图形成为可能。由于它基于栅格,通常用于更复杂的可视化和动画。使用JavaScript可以直接将图形绘制到网站上。 N; x8 T+ H6 B- s- O" o& r0 ~
“大多数可视化使用SVG(可缩放矢量图形),但它处理大量数据点的效果不够理想,”尼科莱蒂说。“在我参与的许多项目中,我一直在使用 canvas 这种网络技术,它不是矢量的,而是像素的。它可以直接绘制形状,能处理更多的数据点。虽然在编程上使用和理解都有点难度,但功能非常强大。” 4 u, O, _& M' I2 M8 Z) H0 b' m+ Y
跨学科的思维方式
) {+ @8 J( M, j/ \- K除了尼科莱蒂使用的传统数据分析和可视化工具外,他还提倡在构思和制作故事时采用跨学科的方法。 % D( x$ T2 S3 @' o9 b. w2 M
“我认为拥有社会科学背景很有帮助,掌握一些数据科学和编程知识对于使用这些工具来说很重要,”他说。“但作为一个学习过其他学科的人,比如城市规划和城市中的社会技术挑战,我觉得这很有价值,因为你会接触到很多复杂的问题,这在想出创意和更深入地了解世界方面是一个优势。”
2 @- E6 m& K/ E来源:GIJN(公众号) 编辑:李佳! s# u3 k8 _$ I$ ^0 o
1 N- J1 C7 h! Z! S2 G0 g# u4 L4 E& L* ]2 v% ]3 h s4 u1 l0 ?6 q
|