通过 MATLAB 处理大数据[通俗易懂]

通过 MATLAB 处理大数据[通俗易懂]原文链接:通过MATLAB处理大数据大数据指的是创建的数据和供分析的数据的数量与速率迅速增加。大数据使分析师和数据专家有机会获得更好的见解,进行更明智的决策,但是它同时也会带来许多的挑战:可用的内存可能无法足以处理大数据集,可能需要花太久的时间进行处理或可能流动太快而无法存储标准算法通常不能以合理的时间或内存来处理大数据集等等。目前没有任何一种单一方法可以处理大数据。为此,MATLAB…

大家好,又见面了,我是你们的朋友全栈君。

原文链接:通过MATLAB处理大数据

大数据指的是创建的数据和供分析的数据的数量与速率迅速增加。大数据使分析师和数据专家有机会获得更好的见解,进行更明智的决策,但是它同时也会带来许多的挑战:可用的内存可能无法足以处理大数据集,可能需要花太久的时间进行处理或可能流动太快而无法存储标准算法通常不能以合理的时间或内存来处理大数据集等等。

目前没有任何一种单一方法可以处理大数据。为此,MATLAB提供了许多工具来解决这些挑战。

在MATLAB中处理大数据

1. 64位计算。

64位版本的MATLAB可快速增加内存中可保留的数据量 – 通常可达到任意32位程序的2000倍.32位程序限制您只能使用2 GB的内存,而64位MATLAB的内存可以达到操作系统的物理内存限制。对于Windows 8,台式机内存为500 GB,Windows Server内存为4 TB。

2.内存映射的变量。

借助MATLAB中的memmapfile函数,您可以将文件或文件的一部分映射到内存中的MATLAB变量。这样,您就可以高效访问磁盘上由于太大而无法保留在内存中或需要花太长时间而无法加载的大数据集。

磁盘变量。

matfile函数使您可以直接从磁盘上的MAT文件访问MATLAB变量(使用MATLAB索引命令),无需将全部变量加载到内存。这使您可以在大数据集上进行块处理,这些大数据集因为太大而无法保存在内存中。

4.内在的多核数学。

MATLAB中的许多内置数学函数,如fft,inv和eig都是多线程的。通过并行运行,这些函数充分利用计算机的多核,提供高性能的大数据集计算。

5. GPU计算。

如果您正在使用GPU,并行计算工具箱中的GPU优化的数学函数可以为大数据集提供更高的性能。

6.并行计算。

并行计算工具箱提供并行用于循环,该循环在多核计算机上并行运行您的MATLAB代码和算法。如果您使用MATLAB Distributed Computing Server,则可以在机器群集上并行执行,这些机器可扩展到数千台计算机。

7.云计算。

对于数百或数千台计算机的按需并行处理,您可以在Amazon Elastic Computing Cloud(亚马逊弹性计算云)(EC2)上使用MATLAB Distributed Computing Server并行运行MATLAB计算。借助云计算,您无需购买或维护您自己的群集或数据中心就可以处理大数据。

8.分布式阵列。

使用并行计算工具箱和MATLAB DistributedComputing Server,您可以处理分布在计算机群集内存中的矩阵和**数组。使用此方法,您可以针对因太大而无法由单台计算机内存处理的大数据集,进行存储和执行计算。

9.流式算法。

使用系统对象,您可以对因太大或太快而无法保留在内存中的数据传入流执行流式处理。此外,您还可以使用MATLAB编码器通过MATLAB算法生成嵌入式C / C ++代码,并针对高性能实时系统运行产生的代码。

10.图像块处理。

使用图像处理工具箱中的blockproc函数,您可以处理特别大的图像,方法是每次以模块的形式高效处理它们。与并行计算工具箱一起使用时,在多核和GPU上并行运行计算。

11. 机器学习。

机器学习有助于通过大数据集提取见解和开发预测性模型。广泛的机器学习算法,包括 Statistics and Machine Learning Toolbox 和 Neural Network Toolbox 中提供的促进式 (boosted) 。袋装 (bagged) 决策树、K 均值和分层聚类、k-最近邻搜索、高斯混合、期望最大化算法、隐马尔可夫模型和神经网络。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/144762.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • “ORA-01017(:用户名/口令无效; 登录被拒绝)”解决办法

    “ORA-01017(:用户名/口令无效; 登录被拒绝)”解决办法报错:ORA-01017(:用户名/口令无效;登录被拒绝)1.打开CMD命令窗,输入sqlplus/assysdba1)修改密码SQL>alteruser用户名identifiedby密码2)用户被锁定,解锁ALTERUSERusernameACCOUNTUNLOCK;再次登录验证,成功…

    2022年6月1日
    54
  • C语言中void代表什么意思?

    C语言中void代表什么意思?一、理解voidvoid代表空,放在返回值位置上,说明此函数执行完不返回任何值;放在参数位置上则显示说明无形式参数。二、1.放在返回值的位置上voidswap(inta,intb){intc;c=a;a=b;b=c;}该函数表示把a和b的数值进行交换即可,不需要返回值,所以用void。2.放在参数位置上#include<stdio.h>intfun(void){ return1; }int

    2022年5月19日
    65
  • git如何查看分支是哪个分支创建的_哪里查看QQ建立时间

    git如何查看分支是哪个分支创建的_哪里查看QQ建立时间实际应用中,可能需要准确知道指定分支的创建时间。代码实例如下:gitreflogshow–date=isomastergitreflogshow–date=iso#######[Shell]纯文本查看复制代码 1 $gitreflogshow–date=isomaster 代码运行效果截图如下:…

    2022年9月26日
    0
  • ubuntu远程桌面控制_ubuntu 远程控制

    ubuntu远程桌面控制_ubuntu 远程控制已经使用的,备份Section”Monitor”Identifier”Monitor0″HorizSync28.0-80.0VertRefresh48.0-75.0#https://arachnoid.com/modelines/#1920×1080@60.00Hz(GTF)hsync:67.08kHz;pclk:172…

    2022年8月21日
    4
  • settimeout()方法_setinterval函数

    settimeout()方法_setinterval函数setTimeOut()は、指定された時間「待ってから」指定された動作を行う関数です。setTimeOut():等待指定时间,执行指定方法。 setTimeInterval()は、指定された時間「間隔ごとに」指定された動作を行う関数です。setTimeInterval():间隔指定时间,执行指定方法。 処理の開始を待ちたいのであれば「setTimeOut」を使いますし、如果是从处理…

    2022年10月5日
    0
  • h3c交换机端口加入vlan命令_h3c交换机vlan配置划分命令

    h3c交换机端口加入vlan命令_h3c交换机vlan配置划分命令h3c交换机vlan配置划分命令一、基本设置1.console线连接成功2.进入系统模式system-view//提示符由变为[H3C]3.更改设备名称[H3C]sysnameTEST4.查看所有配置信息[H3C]displaycurrent-configuration//displaythis为查看当前路径下的设备信息5.创建并进入VLAN10[H3C]vlan10…

    2022年6月20日
    71

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号