|
版本12.0中的一个示例是ImagePyramid框架,用于执行多尺度图像处理: 6 C7 W/ b3 F8 `' ~; s; z
, ]- E3 R. ~; A' ?4 N# B) u+ f
4 I# h8 e% c, c' t+ C8 O) L( F2 ]2 b" o
版本12.0中有几个与颜色计算有关的新函数。一个关键的想法是ColorsNear,它代表感知色彩空间中的一个邻域,这里的颜色为Pink:
, f( X) E( ]3 K6 T* O
! F2 w$ g( \* n0 M, j例如,可以在新的ImageRecolor函数中使用颜色邻域的概念:
2 ]7 N' y0 o" i8 i8 m
语音识别及更多音频功能
. b3 {4 U0 ?' s$ h当我坐在电脑前写这篇文章的时候,让我对电脑随便说句话,然后记录它: 7 B/ B" [; }' ?/ J$ c( G0 L3 ]/ z
- L H' B, X9 n这是我获得的音频频谱图:
5 R4 t3 W2 V. N: f: ]
# G% Q( d: H M此操作在版本11.3中即可执行(但在12.0中Spectrogram的速度提高了10倍)。而新功能是:
! }% F$ Y5 S( y5 k3 ?
9 V- ]! Q: u6 {! |9 `. n* g. U
我们正在使用最先进的神经网络技术,实现从语音到文字的转变!它流线型的工作效果好得令我吃惊,并且完全能够处理很长的音频片段。在典型的计算机上,转录速度大约等于实际的语音速度,因此一小时的语音将需要大约一个小时来转录。
. ~7 N' |: A# x5 a: }# o# G现在我们认为SpeechRecognize仍是实验性的,我们将继续增强它。但有趣的是看到另一个重要的计算任务现在变成了Wolfram语言的一个单个函数。
5 n0 }; j: `& p; K/ a5 t+ v在12.0版中,还有其他增强功能。SpeechSynthesize支持新语言和新语音(由VoiceStyleData[]列出)。 1 T- m5 A3 G/ r3 }, b
有WebAudioSearch——WebImageSearch的对照版,可以让你在网上搜索音频:
8 n4 y3 q. D& i* v: U# z) [% `) B
* r6 S' R6 P3 M; b4 x
可以提取实际的音频对象:
/ q- ^- U4 j! X8 u; v/ A! V1 v8 H' f9 L0 F0 W
然后制作光谱图或其他测量结果的图形:
n! Q$ @* J5 E& N
/ T6 J0 X$ i8 R# t) J' Y
版本12.0中的新功能在此:可以使用AudioIdentify来尝试识别声音的类别(这是一只会说话的公鸡吗?):
! k9 R, X+ x" ?$ K+ d/ J$ m' ?" V) ^0 a" b
我们认为AudioIdentify仍在试验阶段。这只是一个有趣的开始,还不像ImageIdentify那样好用。 9 a6 A" i$ f' @/ w$ U! t% ^0 g9 s* F
更成功的音频函数是PitchRecognize,它试图识别音频信号中的主导频率(它使用“经典”和神经网络方法)。虽然它还不能处理“和弦”,但它对“单音符”非常有效。 i: p0 w5 N2 b8 D' h p
在处理音频时,人们通常不仅要识别音频中的内容,还要添加注释。版本12.0开始引入了大规模音频架构。现在AudioAnnotate可以标记静音的位置,或者有大声的地方。将来,我们将添加说话人识别和单词边界,以及其他许多内容。除此之外,我们还有像AudioAnnotationLookup这样的函数,用于挑选以特定方式注释的音频对象的部分。
3 p6 I6 R% K5 R' N) [$ g/ a所有上述高级音频功能都建立在一个完整的低级音频处理基础之上。版本12.0大大增强了AudioBlockMap(用于将滤波器应用于音频信号),并引入了ShortTimeFourier等函数。 , M/ Z5 v# C% D- J5 T0 M! B
频谱图看起来有点像乐谱的连续模拟,其中音高被绘制为时间的函数。在版本12.0中,现在有InverseSpectrogram,将一系列频谱图数据转成音频。从1991年的第2版开始就有了Play,根据一个函数生成声音(比如Sin[100 t])。现在使用InverseSpectrogram,我们可以将“频率-时间位图”转变为声音。(并且必须承认,当只有振幅信息时,关于相位的最佳猜测仍是棘手的问题。)
# Y; ~) ?0 g% S- _# {4 R9 l Y" k1 [自然语言处理
* e( H, o, ]4 l1 Q9 P7 V# g3 i, H从Wolfram|Alpha开始,我们长期以来拥有非常强大的自然语言理解(NLU)功能。这意味着,给定一种自然语言,我们擅长将其理解为Wolfram语言,然后由此进行计算: 5 O% g( b7 H% E6 j+ i6 ~) M
1 Y5 H, L: H" O+ z# C但是在自然语言处理(NLP)方面,如果我们输入一大段自然语言,但不试图完全理解它们,而只是找到或处理它们的一些特定功能,又怎样呢?一段时间以来,像TextSentences,TextStructure,TextCases和 WordCounts这样的函数已经在这个方面为我们提供了基本功能。在版本12.0中,通过利用最新的机器学习技术,以及我们长期的NLU和知识库功能,强大的NLP功能已经开始崭露头角。 / \6 }2 W$ W0 |0 l0 a* }( v
核心是TextCases的显著增强版本。TextCases的基本目标是在一段文本中查找不同类型内容的实例。一个例子是“实体识别”的经典NLP任务,在这里TextCases找到哪些国家名称出现在关于ocelots的维基百科文章中: ! [0 X$ |6 z/ a7 {
" C! Y$ K3 Z6 }; f* k+ X: ?我们也可以问一下提到哪些岛屿,但现在我们不会要求Wolfram语言解释:
. I6 {/ Y# S- L+ Z
) a5 e' _: s, P+ S0 u2 I( h% q/ B NTextCases并不完美,但它确实表现出色:- s( W/ I! U! l
. X/ Y. Z6 F) g. b9 F; R
它也支持许多不同的内容类型(https://reference.wolfram.com/la ... xtContentTypes.html)
+ }, E- f8 s1 Z0 K; N) g0 {
$ z0 |# d/ b7 @) e5 z您可以要它查找代词或简化关系从句,量词,电子邮件地址,或150种实体(如公司、植物或电影)中出现的任何一种。您还可以要求它挑选出特定人类语言或计算机语言的文本,或者关于特定主题(如旅行或健康)或具有正面或负面情绪的文本。您可以使用像Containing这样的结构要求这些东西的组合(如包含河流名称的名词短语):
$ J! ^' e, Y, |
, X, }2 h$ _0 ?3 z# B4 ~4 b. U2 D
例如,TextContents可以让您查看在特定文本中检测到的所有实体的详细信息:
0 O, }4 f5 t- w9 j$ |
+ B2 V. X6 h$ H* T
并且,是的,原则上可以通过FindTextualAnswer使用这些功能来尝试回答文本中的问题。但在这种情况下,结果可能非常古怪:
; j) d8 G5 C7 T7 z! d e4 K
" X! I7 j& r! c4 I( z当然,您可以从我们内置的策展知识库中获得真正的答案:
0 ~1 t- a2 W, z( b" _9 k6 t# x* A; c& J N2 N. x0 V/ u9 b$ ^
顺便说一句,在版本12.0中,我们添加了各种小的“自然语言便利功能”,如Synonyms和 Antonyms:
0 b5 o) m0 A) }" K" L. [# V8 o
5 C; A) d5 |$ M计算化学
, M+ l7 a" J* V" z- `0 V12.0版在计算化学方面带来了“惊喜”。我们的知识库中在很久以前就有了显式已知化学品数据。但是在版本12.0中,我们可以对指定为纯符号对象的分子进行计算。以下是我们如何指定最终成为水分子的方法:
6 |( m6 X' a7 q. ~4 H) X2 C o以下是我们如何进行3D渲染:
- w, R: @4 A$ Q% l( r+ x+ h0 `
% d0 T! c1 R, x: S5 @; L+ r& R
可以处理“已知化学品”:
+ P' K; h( d5 J! R: S- y( e
4 ?% d2 R* C4 [2 G Y3 @. Z
可以使用任意IUPAC名称: # S, f) K$ ?& `
' n3 t! a7 v' _或者可以“编造”一个化学品。例如通过其SMILES字符串指定它们:
' ~, V5 Q# I* L6 h$ g6 d. F+ |
2 V% e p$ T9 k% g h
但我们不仅能生成图片,还可以根据结构进行计算,如对称性:9 ]) Y7 q' u( |9 d; |1 G# a
( N8 H1 ?* z! F# ?: D给定一个分子,我们可以突出显示其碳氧键:
- `4 T' ?% j7 V: F) {/ h, o* ^. G
. Y# R' x% i! S# G或者突出显示结构,例如由SMARTS字符串指定(这里是任何5个成员的环):& U/ |/ f3 `9 a- k
4 q# S( v: e. U6 a也可以搜索“分子模式”;结果以原子数表示:
7 B% f- y# H. [1 @( K+ t! h8 D
9 N- D- `* j Z. v我们在版本12.0中添加的计算化学功能颇具通用性并且功能强大(需要注意的是,到目前为止它们只涉及有机分子)。在最底层,它们将分子视为标号图,其中图的边对应于键。但他们也了解物理学,并正确地解释原子价和键配置。不用说,有很多细节(关于立体化学,对称性,芳香性,同位素等)。但最终结果是分子结构和分子计算现已成功地添加到整合到Wolfram语言的区域列表中。 4 p; P! g4 R- i* u
地理计算扩展
! b/ H( v5 R5 [! K3 }. dWolfram语言已具备强大的地理计算功能,但12.0版增加了更多功能,并对已有功能进行了增强。
- u3 j( V" x! E. K) X8 L0 P例如,现在有RandomGeoPosition,它生成一个随机的维度-经度位置。这看上去似乎微不足道,但当人们不得不进行坐标变换时,就看到它的威力了,人们可以告诉它只在某个地区内选取点,这里是法国: ) h/ R" o( `6 h I- E
, R, S8 }" L6 ~3 Z K在版本12.0中,新地理功能的一个主题是不仅处理地理点和区域,还处理地理矢量。例如,这是当前在艾菲尔铁塔处的风矢量,表示为GeoVector,具有速度和方向(还有GeoVectorENU,它提供东,北和上分量,以及GeoGridVector和GeoVectorXYZ):
, k7 i4 T% L+ V) W$ J
% a/ l- |) z# `/ y像GeoGraphics这样的函数可以可视化离散的地理矢量。GeoStreamPlot是StreamPlot(或ListStreamPlot)在地理方面的对照,并显示由地理向量(此处来自WindDirectionData)形成的流线:
+ O/ f' k* b. C1 i' @' w( F/ _/ S1 m r4 G( I$ P
大地测量学是一个在数学上相当复杂的领域,我们为Wolfram语言在此方面的卓越性能而感到自豪。在12.0版中,我们添加了一些新功能来填充一些细节。例如,我们现在有像GeoGridUnitDistance和GeoGridUnitArea这样的函数,它们提供与地球上每个位置(或月亮,火星等)的不同地理投影相关的失真(基本上是雅可比行星的特征值)。 y. {) y# ?# Q! x9 G% I& ~
增强的可视化功能
" T, ^# ]$ r. u% x3 {# ~ t* Z T+ N我们一直在稳步发展的一个可视化方向被人们称之为“元图形”:图形化事物的标注和注释。我们在版本11.0中引入了Callout;在版本12.0中,它已经扩展到3D图形: ! R2 o+ p) B2 D* x! h
1 Q, i( {) l0 i$ ]即使对于比较复杂的物体,它也能很好地确定标记其位置:1 ~" d, a# w9 K; f8 n' [
5 L" r* \& ], U- R$ `$ h
为了让图形更加美观,对很多细节的改进非常重要。在版本12.0中增强的功能是确保图形各列沿边框排列,而不管其刻度标签的长度如何。我们还添加了LabelVisibility,它允许您指定不同标签应该可见的相对优先级。 9 ]; z/ p! |5 Q0 h) Y1 A
版本12.0的另一个新功能是多面板绘图布局,其中不同的数据集显示在不同的面板中,但面板尽可能地共用坐标轴:
) P c7 C- w* u! G. c4 w# z7 H+ \
8 E% ]- B9 _. i4 X. U
加强知识库集成 9 w' O- T3 q. L( u) P
我们的策展知识库非常庞大且不断增长,它驱动着Wolfram|Alpha。随着Wolfram语言的每次版本发布,我们逐渐将其融入语言的核心。 5 e/ B" _! }1 h3 q" E0 K
在版本12.0中,我们直接在语言中公开了数百种类型的实体: 4 M9 D! P4 g. x3 ?
|( |- s, q9 y9 }) W: V0 p/ g H# `% _ {0 Z
在12.0版之前,许多类型实体记录在Wolfram|Alpha的示例页面。但现在所有这些都收录在Wolfram语言参考文档中心:
) }+ W! n5 u- O: V3 s9 t
: Z2 u( h' ?. J, j仍有像SatelliteData,WeatherData和FinancialData这样的函数来处理通常需要复杂选择或计算的实体类型。但在版本12.0中,可以使用自然语言(“control+ =”)输入和“黄色框”实体和属性以相同方式访问每个实体类型:
' e4 p( T( S6 S1 ~" V
H0 X/ v) V2 J* ?! m) f顺便说一句,人们也可以隐性使用实体,比如这里求具有最高已知熔点的5个元素:
" k* ~' T6 ^! i3 C H8 S
" O9 {$ B5 O9 f* A: M并且可以使用Dated获取时间序列值:5 ]( i+ s5 I8 N
1 G) e! \+ s: u* f7 L+ M5 E6 q
与外部数据库的大数据集成
: ?1 L6 g1 S3 r6 s2 l3 q使用Wolfram知识库中的内置数据非常方便。查询实体的相关属性非常方便: % r! [1 X" y4 T. x& A
3 [3 L3 Z9 M, W' Q* f' c4 [
7 [ D1 g( M2 g. q, A3 M' M
但是如果你有自己的数据怎么办?能否对它进行设置,使其可以像这样轻松地使用吗?版本11的一个主要新功能是添加了EntityStore,可以定义一个自己的实体类型,然后指定实体、属性和值。
6 D, ^+ X( [2 G7 S9 i1 ?WolframData Repository 包含了一堆实体范例。这是其中一个: ) H$ M! L" f+ Z7 ?* z( d1 y/ h
# L1 v7 a2 S5 U# a' S
4 b% F3 S% Z; }它描述了单个实体类型:“SWLibraryBook”。为了能够像内置实体一样使用这种类型的实体,我们“注册”实体存储:
* i$ j0 s6 Q2 W1 J' s
现在我们可以做一些事情,比如要求10个类型为“SWLibraryBook”的随机实体:+ Z3 t3 I `$ `
@ i2 b, h; J0 o$ F
实体存储中的每个实体都具有各种属性。这是一个特定实体的属性值数据集:
$ |. C1 x' V. H% z6 }
* p K7 E+ M7 ^. N' C" [# t通过这种设置,我们基本上是将实体存储的全部内容读入内存,这使得执行Wolfram语言运算非常有效。但是,对于大量数据而言,它并不是一个很好的可扩展解决方案- 例如数据太大而无法容纳在内存中。 0 C. H& l5 _ H
但什么是大数据的典型来源?通常它是一个数据库,通常是一个可以使用SQL访问的关系数据库。我们使用DatabaseLink软件包对SQL数据库进行低级读写访问已有十多年。但是在版本12.0中,我们添加了一些主要的内置功能,允许在Wolfram语言中处理外部关系数据库,就像实体存储或Wolfram知识库的内置部分一样。
5 y3 @0 j0 `" o4 v O8 b让我们从玩具示例开始吧。这是一个恰好存储在文件中的小型关系数据库的符号表示:
$ k: I4 \2 W: _4 f L" q! d
我们立即得到一个汇总数据库内容的框,并告诉我们这个数据库有8个表。如果我们打开框体,可以开始检查这些表的结构:3 A9 W1 f( d, x# }! W- s5 a
0 t5 s9 E' M! s" G$ c: N% ^8 E! ]2 f
+ j- ]# u5 y8 f- l$ M' o$ }2 @1 C
然后,我们可以将此关系数据库设置为Wolfram语言中的实体存储。它看起来与上面的库实体商店非常相似,但现在实际的数据没有被放内存;相反,它仍然在外部关系数据库中,我们只是在Wolfram语言中定义一个(“类ORM”)映射到实体:5 A7 m% D) n1 G
/ u. \" _; E0 U( J" H4 Y
* R& n. U5 b2 Z$ a1 X j% L现在我们可以注册这个实体存储,它设置了一堆实体类型(至少在默认情况下),以数据库中表的名称命名:
4 h' l5 o& M. o/ c
4 D* B3 V: O" B9 d" @; E现在我们可以对这些实体进行“实体计算”,就像我们在Wolfram知识库中的内置实体一样。这里的每个实体都对应于数据库中“employees”表中的一行:
; Y3 L3 O x5 Y5 i6 O1 g
, C* x; k. r. L0 @6 n( x, j2 S
对于给定的实体类型,我们可以询问它具有哪些属性。这些“属性”对应于底层数据库中表的列:
" p& P4 g' j7 A7 \. w' j
) b# w% Y0 @, F; B/ Z; q, Q; j( C- f
现在我们可以询问特定实体的特定属性值:" |5 m/ m6 T$ T" x% Z
) ^9 v4 }/ `1 ~: q. p8 @
我们也可以通过给定标准来挑选实体; 在这里,我们要求“payments”实体具有“amount”(金额)属性的4个最大值:; w( ^, F: B: q0 J
$ y! |9 `& ^1 M4 U' ^- C# W, V; N5 D' b我们同样可以询问最大金额值:
- C a ^3 A; i4 q! H
# y4 H0 w3 M0 A8 w9 _. K但是在这里它变得更加有趣了:到目前为止,我们看见的是一个文件支持的小数据库。但我们也可以对外部服务器上的巨型数据库做同样的事情。
9 u: Q( v2 V& G例如,让我们连接到TB级的OpenStreetMap PostgreSQL数据库,该数据库包含几乎全部世界街道地图的数据:
; f, l2 }7 A1 S+ C4 ^* y" ~
x- s9 u9 [" ~6 L4 ?* _3 N和以前一样,让我们将这个数据库中的表注册为实体类型。像大多数野外数据库一样,结构中存在一些小故障,这些故障已被绕过,但会产生警告:
/ {) D7 P- {+ Q0 t
7 W8 G9 F- I5 A
但现在我们可以询问有关数据库的问题,比如世界上所有街道上有多少个地理点或“节点”(是的,这是一个很大的数字,这正是数据库很大的原因):
# I x% R7 W0 m: P
# h( |% q+ o: Z) j在这里,我们要求(101 GB)的planet_osm_polygon表中具有10个最大(投影)区域的对象的名称(是的,只需不到一秒):
1 Y+ `0 e" d: v) T2 X- G! K; V
4 R. N' ^3 o$ ^ K& J
这一切是如何运作的?过程基本是这样,我们的Wolfram语言表示被编译成低级SQL查询,然后将其发送以直接在数据库服务器上执行。 8 F7 ]) R5 H) p) r* y. W; z% h
有时您需要的只是最终值(例如,上面的“amounts”)。但其他情况下,一些中间值也是需要的,比如以特定方式选择的实体集合。当然,这个系列可能有十亿个条目。因此,我们在版本12.0中引入的一个非常重要的功能是,我们可以纯符号式地表示和运算这些事物,仅在最后将它们解析为特定的事物。
' L5 O0 j! F1 A2 F' C5 f! N7 u回到我们的玩具数据库。下面这个例子可以说明我们如何通过聚合具有给定国家值的所有客户的总creditLimit来获得实体类别: ) j' ^$ n) t( F! A
' v/ i5 x3 ^' ?- \7 @0 L起初,这只是符号表示。但如果我们要求具体值,则执行实际的数据库查询,这样我们得到了具体的结果:
% v" P n/ v3 O& l- n5 C/ V- Z有一系列新功能可用于设置不同类型的查询。这些函数不仅适用于关系数据库,还适用于实体存储以及内置的Wolfram知识库。因此,我们可以在元素周期表中询问给定周期的平均原子质量:
) V" i$ K N7 `: U
# W( y, R6 Q6 H0 H: W; q3 Y一个重要的新结构是EntityFunction。EntityFunction与Function类似,不同之处在于其变量表示实体(或实体类),并描述可以直接在外部数据库上执行的操作。这是一个内置数据的例子,我们在其中定义一个“筛选”实体类,其中筛选标准是一个检验总体值的函数。该FilteredEntityClass本身只是符号表示,但EntityList实际执行查询,并解析(这里为未排序)实体的显式列表:
; z; R8 j3 l4 ?1 r
& b9 ~; I# \, c; l1 J
2 ^7 W; }, [0 Q9 H+ H除了EntityFunction、AggregatedEntityClass和SortedEntityClass之外,版本12.0还包括SampledEntityClass(用于从类中获取一些实体),ExtendedEntityClass(用于添加计算属性)和CombinedEntityClass(用于组合来自不同类的属性)。通过这些原语,可以构建“关系代数”的所有标准运算。
! h0 o: `" x: P在标准数据库编程中,人们通常最终会得到一整片由“joins”和“foreign keys”等组成的丛林。我们的Wolfram语言表示允许您进行更高级别的操作,其中“joins”(连接)变为函数组合,而“foreignkeys”(外键)只是不同的实体类型。(但如果要进行显式连接,则可以使用CombinedEntityClass。)
5 P3 H- V% y3 E* r' W6 @3 E所有这些Wolfram语言结构都被编译成SQL,或者更准确地说,是与您正在使用的特定数据库相匹配的SQL的特定方言(我们目前支持SQLite、MySQL、PostgreSQL和MS-SQL,对OracleSQL的支持即将推出)。当我们进行编译时,会自动检查类型,以确保您获得有意义的查询。即使是相当简单的Wolfram语言规范也可能最终变成许多SQL行。例如,
0 P/ q; [. |9 t: N a
) @3 j( _( j0 c, e+ ]9 G& h3 B
将生成以下中间SQL(此处用于查询SQLite数据库):
- z* E: g( Q# s: _8 T a. C5 q
/ A A5 |( k' z5 h1 e, Q2 N8 y12.0版的数据库集成系统非常复杂,为此我们已经奋斗多年。这是朝Wolfram语言直接处理大数据中的“大”迈出的重要一步,并让Wolfram语言直接在TB级别的数据集上进行数据科学研究。比如查找世界上哪些街头实体的名字中有“Wolfram”:# E8 C+ U! U+ S
+ `) a* D" L3 Q
% q: H7 S8 N2 p
; D. m# s0 Z& n! ?$ N% Z
7 V1 A0 M! f/ C |