云计算与大数据实验六 MapReduce综合应用

本文涉及的产品
云原生大数据计算服务 MaxCompute,5000CU*H 100GB 3个月
云原生大数据计算服务MaxCompute,500CU*H 100GB 3个月
简介: 云计算与大数据实验六 MapReduce综合应用

一、实验目的

  1. 了解KUMO技术应用于词频分析,词云生成的开源技术
  2. 使用KUMO框架绘制一个简单的词云
  3. 了解词云的渲染
  4. 理解数据分析渲染生成词云

二、实验内容

  1. 使用KUMO框架绘制一个简单的词云
  2. 数据分析渲染生成词云

三、实验步骤

(一)使用KUMO框架绘制一个简单的词云

词云就是由词汇组成类似云的彩色图形,如下图:

如何绘制词云

绘制一个简单的词云总的下来只需5个主要操作:

1.创建词频分析器,设置词频,此处的参数配置视情况而定即可。

1. FrequencyAnalyzer frequencyAnalyzer = new FrequencyAnalyzer();
2. frequencyAnalyzer.setWordFrequenciesToReturn(200);

2.加载文本文件路径,生成词频集合。

List<WordFrequency> wordFrequencyList = frequencyAnalyzer.load("wordcloud.txt");

3.设置图片分辨率。

Dimension dimension = new Dimension(500,312);

4.生成词云对象,此处的设置采用内置常量即可。

WordCloud wordCloud = new WordCloud(dimension,CollisionMode.PIXEL_PERFECT);

5.生成词云并写入图片。

1. wordCloud.build(wordFrequencies);
2. wordCloud.writeToFile("wordcloud.png");

编程要求

读取wordcloud.txt文件生成词云,要求图片分辨率为500 × 312,生成图片存放路径和名称为 imgs/wordcloud_img.png

效果如下:

测试输入:

1. imgs/wordcloud_img.png
2. step1/my_wordcloud_img.png

相关代码:

1. 1. package com.showdata;
2. 2. 
3. 3. import java.awt.Dimension;
4. 4. import java.io.IOException;
5. 5. import java.util.List;
6. 6. import com.kennycason.kumo.CollisionMode;
7. 7. import com.kennycason.kumo.WordCloud;
8. 8. import com.kennycason.kumo.WordFrequency;
9. 9. import com.kennycason.kumo.nlp.FrequencyAnalyzer;
10. 10. 
11. 11. public class WordCloud_img {
12. 12. 
13. 13.     public WordCloud get() throws IOException  {
14. 14.         /**********     Begin   **********/
15. 15.         //1.为实例化词云做准备
16. 16.         FrequencyAnalyzer frequencyAnalyzer = new FrequencyAnalyzer();
17. 17.         frequencyAnalyzer.setWordFrequenciesToReturn(200);
18. 18.         List<WordFrequency> wordFrequencies = frequencyAnalyzer.load("wordcloud.txt");
19. 19.         Dimension dimension = new Dimension(500, 312);
20. 20.         //2.修改词云的实例化
21. 21.         WordCloud wordCloud = new WordCloud(dimension, CollisionMode.PIXEL_PERFECT);        
22. 22.         //3.生成词云并写入图片
23. 23.         wordCloud.build(wordFrequencies);
24. 24.         wordCloud.writeToFile("imgs/wordcloud_img.png");
25. 25.         /**********     End   **********/
26. 26.         return wordCloud;
27. 27.     }
28. 28. 
29. 29. }

(二)数据分析渲染生成词云

词云渲染

1.设置图片中字体样式为宋体粗斜体24磅(具体可以参照Font源码)

1. java.awt.Font font = new java.awt.Font("宋体",3, 24);//3表示粗斜体
2. wordCloud.setKumoFont(new KumoFont(font));

2.设置词组边界(词组拥挤不易于观察美观)

wordCloud.setPadding(2);

3.设置背景颜色和背景图片

1. wordCloud.setBackgroundColor(Color.black);
2. 
3. wordCloud.setBackground(new PixelBoundryBackground("背景图片地址"));

示例: 背景图片:(注意设置的背景图片需要透明底才可进行转换成图中形状)

对上一章节的词云进行设置后,输出如下:

4.设置词云显示的颜色,越靠前设置表示词频越高的词语的颜色

wordCloud.setColorPalette(new ColorPalette(Color.RED, Color.BLUE, Color.GREEN));

5.设置频词高低从图片中间出现往外扩张(词频高者聚集图片中心位置)

wordCloud.setWordStartStrategy(new CenterWordStart());

6.设置词云中的词语横向摆置

wordCloud.setAngleGenerator(new AngleGenerator(0));//0表示横向  若填180则表示横向基础旋转180°

编程要求

将第一步的图片进行渲染,具体要求如下:

  1. 字体为宋体粗斜体24磅;
  2. 单词边界为 2
  3. 背景颜色为白色,背景图片为myImgs/whale_small.png
  4. 词云词频单词颜色一次为红、蓝、绿;
  5. 根据词频高低由中心往外散发,且单词横向摆置;
  6. 图片存储路径个名称为 imgs/wordcloud_render.png

测试输入: imgs/wordcloud_render.pngstep2/my_wordcloud_render.png

相关代码:

1. 1. package com.showdata;
2. 2. 
3. 3. import java.awt.Color;
4. 4. import java.awt.Dimension;
5. 5. import java.io.IOException;
6. 6. import java.util.List;
7. 7. import com.kennycason.kumo.CollisionMode;
8. 8. import com.kennycason.kumo.WordCloud;
9. 9. import com.kennycason.kumo.WordFrequency;
10. 10. import com.kennycason.kumo.bg.PixelBoundryBackground;
11. 11. import com.kennycason.kumo.font.KumoFont;
12. 12. import com.kennycason.kumo.image.AngleGenerator;
13. 13. import com.kennycason.kumo.nlp.FrequencyAnalyzer;
14. 14. import com.kennycason.kumo.palette.ColorPalette;
15. 15. import com.kennycason.kumo.wordstart.CenterWordStart;
16. 16. import java.awt.Font;
17. 17. 
18. 18. public class WordCloud_render {
19. 19. 
20. 20.     public WordCloud get() throws IOException {
21. 21.         FrequencyAnalyzer frequencyAnalyzer = new FrequencyAnalyzer();
22. 22.         frequencyAnalyzer.setWordFrequenciesToReturn(200);
23. 23.         List<WordFrequency> wordFrequencies = frequencyAnalyzer.load("wordcloud.txt");
24. 24.         Dimension dimension = new Dimension(500, 312);
25. 25.         WordCloud wordCloud = new WordCloud(dimension, CollisionMode.PIXEL_PERFECT);
26. 26.         /**********     Begin   **********/
27. 27.         Font font = new Font("宋体", 3, 24);
28. 28.         wordCloud.setKumoFont(new KumoFont(font));
29. 29.         wordCloud.setPadding(2);
30. 30.         wordCloud.setBackgroundColor(Color.white);
31. 31.         wordCloud.setBackground(new PixelBoundryBackground("myImgs/whale_small.png"));
32. 32.         wordCloud.setColorPalette(new ColorPalette(Color.RED, Color.BLUE, Color.GREEN));
33. 33.         wordCloud.setWordStartStrategy(new CenterWordStart());
34. 34.         wordCloud.setAngleGenerator(new AngleGenerator(0));
35. 35.         /**********     End   **********/
36. 36.         wordCloud.build(wordFrequencies);
37. 37.         wordCloud.writeToFile("imgs/wordcloud_render.png");
38. 38.         return wordCloud;
39. 39.     }
40. 40. 
41. 41. }

四、实验心得

会使用KUMO框架绘制一个简单的词云

理解了数据分析渲染生成词云

相关实践学习
基于MaxCompute的热门话题分析
本实验围绕社交用户发布的文章做了详尽的分析,通过分析能得到用户群体年龄分布,性别分布,地理位置分布,以及热门话题的热度。
SaaS 模式云数据仓库必修课
本课程由阿里云开发者社区和阿里云大数据团队共同出品,是SaaS模式云原生数据仓库领导者MaxCompute核心课程。本课程由阿里云资深产品和技术专家们从概念到方法,从场景到实践,体系化的将阿里巴巴飞天大数据平台10多年的经过验证的方法与实践深入浅出的讲给开发者们。帮助大数据开发者快速了解并掌握SaaS模式的云原生的数据仓库,助力开发者学习了解先进的技术栈,并能在实际业务中敏捷的进行大数据分析,赋能企业业务。 通过本课程可以了解SaaS模式云原生数据仓库领导者MaxCompute核心功能及典型适用场景,可应用MaxCompute实现数仓搭建,快速进行大数据分析。适合大数据工程师、大数据分析师 大量数据需要处理、存储和管理,需要搭建数据仓库?学它! 没有足够人员和经验来运维大数据平台,不想自建IDC买机器,需要免运维的大数据平台?会SQL就等于会大数据?学它! 想知道大数据用得对不对,想用更少的钱得到持续演进的数仓能力?获得极致弹性的计算资源和更好的性能,以及持续保护数据安全的生产环境?学它! 想要获得灵活的分析能力,快速洞察数据规律特征?想要兼得数据湖的灵活性与数据仓库的成长性?学它! 出品人:阿里云大数据产品及研发团队专家 产品 MaxCompute 官网 https://www.aliyun.com/product/odps&nbsp;
目录
相关文章
|
1月前
|
SQL 存储 分布式计算
ODPS技术架构深度剖析与实战指南——从零开始掌握阿里巴巴大数据处理平台的核心要义与应用技巧
【10月更文挑战第9天】ODPS是阿里巴巴推出的大数据处理平台,支持海量数据的存储与计算,适用于数据仓库、数据挖掘等场景。其核心组件涵盖数据存储、计算引擎、任务调度、资源管理和用户界面,确保数据处理的稳定、安全与高效。通过创建项目、上传数据、编写SQL或MapReduce程序,用户可轻松完成复杂的数据处理任务。示例展示了如何使用ODPS SQL查询每个用户的最早登录时间。
98 1
|
22天前
|
存储 人工智能 大数据
物联网、大数据、云计算、人工智能之间的关系
物联网、大数据、云计算、人工智能之间的关系是紧密相连、相互促进的。这四者既有各自独立的技术特征,又能在不同层面上相互融合,共同推动信息技术的发展和应用。
183 0
|
1月前
|
存储 分布式计算 druid
大数据-149 Apache Druid 基本介绍 技术特点 应用场景
大数据-149 Apache Druid 基本介绍 技术特点 应用场景
59 1
大数据-149 Apache Druid 基本介绍 技术特点 应用场景
|
1月前
|
算法 大数据 数据库
云计算与大数据平台的数据库迁移与同步
本文详细介绍了云计算与大数据平台的数据库迁移与同步的核心概念、算法原理、具体操作步骤、数学模型公式、代码实例及未来发展趋势与挑战。涵盖全量与增量迁移、一致性与异步复制等内容,旨在帮助读者全面了解并应对相关技术挑战。
37 3
ly~
|
1月前
|
供应链 搜索推荐 安全
大数据模型的应用
大数据模型在多个领域均有广泛应用。在金融领域,它可用于风险评估与预测、智能营销及反欺诈检测,助力金融机构做出更加精准的决策;在医疗领域,大数据模型能够协助疾病诊断与预测、优化医疗资源管理和加速药物研发;在交通领域,该技术有助于交通流量预测、智能交通管理和物流管理,从而提升整体交通效率;电商领域则借助大数据模型实现商品推荐、库存管理和价格优化,增强用户体验与企业效益;此外,在能源和制造业中,大数据模型的应用范围涵盖从需求预测到设备故障预测等多个方面,全面推动了行业的智能化转型与升级。
ly~
113 2
ly~
|
1月前
|
供应链 搜索推荐 大数据
大数据在零售业中的应用
在零售业中,大数据通过分析顾客的购买记录、在线浏览习惯等数据,帮助零售商理解顾客行为并提供个性化服务。例如,分析网站点击路径以了解顾客兴趣,并利用历史购买数据开发智能推荐系统,提升销售和顾客满意度。此外,大数据还能优化库存管理,通过分析销售数据和市场需求,更准确地预测需求,减少库存积压和缺货现象,提高资金流动性。
ly~
324 2
ly~
|
1月前
|
机器学习/深度学习 人工智能 自然语言处理
大数据在智慧金融中的应用
在智能算法交易中,深度学习揭示价格波动的复杂动力学,强化学习依据市场反馈优化策略,助力投资者获取阿尔法收益。智能监管合规利用自然语言处理精准解读法规,实时追踪监管变化,确保机构紧跟政策。大数据分析监控交易,预警潜在违规行为,变被动防御为主动预防。数智化营销通过多维度数据分析,构建细致客户画像,提供个性化产品推荐。智慧客服借助 AI 技术提升服务质量,增强客户满意度。
ly~
121 2
ly~
|
1月前
|
供应链 监控 搜索推荐
大数据的应用场景
大数据在众多行业中的应用场景广泛,涵盖金融、零售、医疗保健、交通物流、制造、能源、政府公共服务及教育等领域。在金融行业,大数据用于风险评估、精准营销、反欺诈以及决策支持;零售业则应用于商品推荐、供应链管理和门店运营优化等;医疗保健领域利用大数据进行疾病预测、辅助诊断和医疗质量评估;交通物流业通过大数据优化物流配送、交通管理和运输安全;制造业则在生产过程优化、设备维护和供应链协同方面受益;能源行业运用大数据提升智能电网管理和能源勘探效率;政府和公共服务部门借助大数据改善城市管理、政务服务及公共安全;教育行业通过大数据实现个性化学习和资源优化配置;体育娱乐业则利用大数据提升赛事分析和娱乐制作水平。
ly~
427 2
|
2月前
|
存储 数据可视化 大数据
大数据管理与应用
大数据管理与应用是一门融合数学、统计学和计算机科学的新兴专业,涵盖数据采集、存储、处理、分析及应用,旨在帮助企业高效决策和提升竞争力。核心课程包括数据库原理、数据挖掘、大数据分析技术等,覆盖数据处理全流程。毕业生可从事数据分析、大数据开发、数据管理等岗位,广泛应用于企业、金融及互联网领域。随着数字化转型加速,该专业需求旺盛,前景广阔。
138 5
|
11天前
|
存储 分布式计算 数据挖掘
数据架构 ODPS 是什么?
数据架构 ODPS 是什么?
97 7
下一篇
无影云桌面