数学建模社区-数学中国

标题: 哪些 Python 库让你相见恨晚? [打印本页]

作者: 杨利霞    时间: 2020-4-25 15:28
标题: 哪些 Python 库让你相见恨晚?
, {) |: ~, U& A: x8 o
哪些 Python 库让你相见恨晚?# N$ }! r* j) N1 e# V" ^
! ]6 i7 g. p5 `! M' t) ~
Python的灵活性和易用性不仅体现在大家都知道的语法优雅简洁上,还因为它拥有非常庞大且强大的库。这些库可以用于数据清理、数据操作、可视化、构建模型甚至模型部署,所以这也是为什么Python在开发者中这么受欢迎的原因。$ |& _7 r& F0 n

. J  V& N7 q1 M4 D那么今天,我们就来盘一盘其中8个好用的库:9 \* H% q( ]4 s6 ^) y* S7 U! {9 |% h
: E1 ~0 g* K8 q& `  S& Z2 h
1、TensorFlow6 e4 K2 u) A& @8 M
5 S) h  r5 A$ Q4 ^
1.jpg
6 g9 h: v5 M5 Y4 N5 z9 Z) g5 x. J) a7 ~. A& K
什么是TensorFlow?
% t, H. l: ~* {该库是由Google与Brain Team合作开发的。TensorFlow几乎在每个Google应用程序中用于机器学习。' }* C9 M8 D6 S! t- g3 ~

! _; e* n- c$ O) \TensorFlow的工作方式类似于编写涉及大量张量操作的新算法的计算库。由于神经网络可以很容易地表示为计算图形,因此它们可以使用TensorFlow作为Tensors上的一系列操作来实现。此外,张量是表示数据的N维矩阵。7 b/ b! m( _$ w" n3 W/ h+ V+ E9 t
- U! }" C; m# L2 f" j' S$ O
TensorFlow的特点
: q( t& g1 B5 w+ g0 W! jTensorFlow针对速度进行了优化,它利用XLA等技术实现快速线性代数运算。0 r* ?- ~' D8 ~' T# {4 H
5 T( S/ b4 l/ P& `* P# Q
使用TensorFlow,我们可以轻松地可视化图形的每个部分,这在使用Numpy或SciKit时不是一个选项。
1 ~- F2 f) T/ {) f  a
1 m6 M5 }- W: f4 p其中一个非常重要的Tensorflow功能是它的可操作性非常灵活,这意味着它具有模块化,并且对于您想要独立的部分,它为您提供了这一选择。9 t+ V7 G  |" ]

5 ~# N) g, t/ U. u  w3 j  i它可以在CPU和GPU上轻松训练,用于分布式计算。$ b8 ~+ `3 ^9 s" U2 o

0 V' O# ?  e1 F( P' C$ D0 @TensorFlow提供流水线操作,从某种意义上说,您可以训练多个神经网络和多个GPU,这使得模型在大规模系统上非常高效。已经有一大批软件工程师不断致力于稳定性改进。而且它是开源的,所以只要有互联网连接,任何人都可以使用它。
+ \. g% A3 _9 F" O5 F4 }4 Y
' r& X$ b+ O/ n( _# w) f2、NumPy0 V& K; w# U# P; `2 C! [2 r8 S

, M5 `( S$ x% M9 h5 R 2.jpg
5 W5 V7 L6 P, T7 G# j; a1 d9 S. w1 W# i, [1 X
什么是Numpy?
* t% D1 w& v  _0 ]! Q4 \" GNumpy被认为是Python中最受欢迎的机器学习库之一。TensorFlow和其他库在内部使用Numpy在Tensors上执行多个操作。数组接口是Numpy的最佳和最重要的功能。. X3 G( q; h0 e$ [, B7 Z# K* @

1 E/ ~7 [  p- [( e1 _6 ENumpy的特点
6 e/ z7 Q  G$ m; CNumpy非常具有交互性且易于使用;使复杂的数学实现变得非常简单;使编码变得简单易懂并且理解概念很容易;广泛使用,因此有很多开源贡献。: ~( p) H7 E1 f* D1 w/ C
0 v+ q) G# J6 d3 B$ Y. I
3、Scikit-Learn
+ G6 A4 @4 h0 W4 w; J9 X) P 3.jpg $ ^: @9 D1 @. |5 Q

! r: W1 ~$ f6 r+ V4 F: ~  ~
) b  q0 f, S" L- S7 K什么是Scikit-Learn?: g, N% G' b- R/ u! I1 P
它是一个与NumPy和SciPy相关联的Python库。它被认为是处理复杂数据的最佳库之一。- ~4 ?! m6 m1 g" X! z

- s( J! K* z; p7 f8 R, M这个库中有很多变化。一种修改是交叉验证功能,可以使用多个指标。物流回归和最近邻居等许多培训方法都得到了一些改进。5 [: Q9 o; q7 ]+ r
/ K9 R" E% L: q9 x
Scikit-Learn的特点$ }  I# I- a: ?$ h. `3 `
有多种方法可以检查监督模型对看不见的数据的准确性;无监督学习算法:同样,在提供中有大量的算法 - 从聚类,因子分析和主成分分析到无监督神经网络;用于从图像和文本中提取特征。/ t! i+ |+ n- S% O, ?* h0 ~
: P4 e  b. j' x6 S6 e9 i- W9 W
4、Pandas, t4 V1 A5 B! p- b; Q
4.jpg
0 D6 J; Y# w* G$ s4 p3 u0 ~* R4 l5 q7 }9 f" x
什么是Pandas?3 F/ b* H  _0 b
在数据操作和数据分析方面,Pandas绝无敌手。这个名称来源于术语“面板数据”,“面板数据”是一个计量经济学术语,指的是包含同一个人在多个时间段内的观察结果的数据集。1 b4 m) M" O4 i

1 ^" i9 B; y7 o6 a! \4 D9 ^3 T9 NPandas的特点:# B& q6 {/ E0 h/ G0 L
数据集连接和合并
9 }/ C' f+ P3 U  R删除和插入数据结构列# S4 K2 ~/ m' N+ Y
数据过滤3 B. O+ U) ^4 y2 t5 r
重塑数据集
0 Q8 w) j9 S, J" L6 u9 i使用DataFrame对象来操作数据等  q+ ~, S+ }9 h" V
5、Seaborn
4 I( q5 A& R0 |; { 5.jpg
6 @" [4 m- _7 \- e9 |7 Z什么是Seaborn?5 g# H4 h3 j. Q+ Q6 d/ h: g, x
Seaborn是基于matplotlib产生的一个模块,专攻于统计可视化,可以和pandas进行无缝连接,使初学者更容易上手。相对于matplotlib,Seaborn语法更简洁,两者关系类似于numpy和pandas之间的关系。+ j! q, ]  L9 k1 e

4 g3 A2 r; X4 ^9 ~) b3 m
- Y3 U; _: E' }5 y; G5 J4 Y/ z' ~0 H( ?9 L* n; s& s4 {) a& ^
Seaborn 的特点:  @- P( I2 @7 c! z4 h
作为一个面向数据集的API,可用于查验多个变量之间的关系& w' D! H8 c2 K( ~. b
便于查看复杂数据集的整体结构
/ x! b4 L9 j( g2 d/ }用于选择显示数据中模式的调色板的工具
2 d' @3 M7 z1 h# W6 u+ C6、HoloViews
2 w' Q! t7 V; c2 Q+ W7 j 6.jpg
* w# M) ?5 `$ F; C( r) n什么是HoloViews
, @& o% d7 Z. C, O( f4 zHoloViews可以用非常少的代码完成数据分析和可视化,除了默认的matplotlib后端外,还添加了一个Bokeh后端。  E, b! G  B! @$ e

% P+ |( `0 N- M0 ~6 k' U! lBokeh提供了一个强大的平台,通过结合Bokeh提供的交互式小部件,可以使用HTML5 canvas和WebGL快速生成交互性和高维可视化,非常适合于数据的交互式探索。
7 _+ c4 F9 g6 ]+ X& g" _" X5 f; W/ ^3 }9 v8 L" u
1 c3 a) s- I3 c# m0 f) u1 a, H; V

1 Q% E; T- a$ v  N1 E3 h% i7、PyTorch$ E6 p$ b' `6 O; L5 ~5 w/ \% v
7.jpg 6 i% d% d5 v7 p* ^
5 K' }% l; n5 {9 B2 A( v" U

  k; s9 t/ L3 `  y% v什么是PyTorch?7 r' E+ |5 M; Q% p- E: n) p! j6 i
PyTorch是最大的机器学习库,允许开发人员通过GPU加速执行张量计算,创建动态计算图,并自动计算梯度。除此之外,PyTorch还提供丰富的API,用于解决与神经网络相关的应用问题。, O! @2 \" d5 x/ {+ q; J5 i" \
# d# [3 h3 \2 X) B8 e- c
这个机器学习库基于Torch,它是一个用C语言实现的开源机器库,带有Lua中的包装器。
; Q/ E5 o# O$ v' q! ~+ ?3 Y4 d% a* D6 j5 d; L
它于2017年推出,自成立以来,该库越来越受欢迎,并吸引了越来越多的机器学习开发人员。1 o8 y, c$ i  I1 }" q, V; X  y
' N3 ^9 D- X9 X! x2 _. `) U
PyTorch的特点
5 i! X* g/ u$ w! r2 M; _3 O0 U新的混合前端在急切模式下提供易用性和灵活性,同时无缝转换到图形模式,以便在C ++运行时环境中实现速度,优化和功能。
- ]( U$ ^* @! F. P% ?4 F
' j, }$ \) i0 `' N% o4 @通过利用对Python和C ++可访问的集合操作和对等通信的异步执行的本机支持,优化研究和生产中的性能。: ]- M; I% G% J* m2 ]$ `
5 N( `$ r7 `& h. U2 j
PyTorch不是Python绑定到单片C ++框架。它是为了深入集成到Python中而构建的,因此它可以与流行的库和Cython和Numba等软件包一起使用。
2 X. r- V. _  C8 A2 F
- v: Y3 L; |% E4 V一个活跃的研究人员和开发人员社区建立了丰富的工具和库生态系统,用于扩展PyTorch并支持从计算机视觉到强化学习等领域的开发。
% y) |$ ?& O) p+ I: H; ~
  `$ o/ a1 w5 K1 _( c8、Keras
1 r* \; Z" \+ R3 I
! n* _/ _9 ]2 O/ L0 S1 W3 T 8.jpg
* {6 ?  i$ F: d+ V$ C  e7 l# C' c, J, o, Q3 [4 ~3 F
什么是Keras?- Q7 @, U: t0 R* Q3 a
Keras被认为是Python中最酷的机器学习库之一。它提供了一种更容易表达神经网络的机制。Keras还提供了一些用于编译模型,处理数据集,图形可视化等的最佳工具。
- B# C7 b. N+ u. e& E% f
: ~' X$ `4 i4 T( K  k在后端,Keras在内部使用Theano或TensorFlow。也可以使用一些最流行的神经网络,如CNTK。当我们将其与其他机器学习库进行比较时,Keras相对较慢,因为它通过使用后端基础设施创建计算图,然后利用它来执行操作。4 F4 {( e1 A5 K2 r
$ w$ c6 a6 o4 L, r5 z! z+ V& _4 n
Keras的特点7 p7 j" I( T/ g7 y: y
它在CPU和GPU上都能顺利运行。Keras几乎支持神经网络的所有模型 - 完全连接,卷积,汇集,循环,嵌入等。此外,这些模型可以组合起来构建更复杂的模型。Keras具有模块化特性,具有令人难以置信的表现力,灵活性,适合创新研究。9 V8 ]1 h  B6 y% B- ^
————————————————" M1 C1 N1 O9 ]4 p$ ~4 h) R
版权声明:本文为CSDN博主「九章算法」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
  n. v. M( y% m原文链接:https://blog.csdn.net/JiuZhang_ninechapter/article/details/104481814
: U$ m) f9 R; {) `2 C( u! L( r% S% ~! \8 D/ ^, f  Z" n! V/ t" {

, Z; Y; h( D  o2 }$ o




欢迎光临 数学建模社区-数学中国 (http://www.madio.net/) Powered by Discuz! X2.5