| 提要 | 第1-7页 |
| 第1章 绪论 | 第7-10页 |
| ·研究背景 | 第7页 |
| ·研究内容及现状 | 第7-9页 |
| ·旋律搜索引擎 | 第7-8页 |
| ·音乐的相似比较 | 第8-9页 |
| ·开发工具 | 第9页 |
| ·本文的结构安排 | 第9-10页 |
| 第2章 MIDI数据的下载及预处理 | 第10-23页 |
| ·网络爬虫 | 第10页 |
| ·Heritrix的配置与使用 | 第10-14页 |
| ·Heritrix的配置 | 第10-11页 |
| ·Heritrix的使用 | 第11-14页 |
| ·可以模拟登录下载的爬虫程序 | 第14-18页 |
| ·HttpClient简介 | 第15页 |
| ·HtmlParser简介 | 第15-16页 |
| ·模拟登陆 | 第16页 |
| ·路径下载 | 第16-18页 |
| ·数据预处理 | 第18-23页 |
| ·MIDI信息简介 | 第18-19页 |
| ·Java Sound简介 | 第19-21页 |
| ·MIDI文件音乐对象化 | 第21-23页 |
| 第3章 主旋律提取 | 第23-29页 |
| ·旋律的特征 | 第23页 |
| ·主旋律音轨识别 | 第23-27页 |
| ·直接排除 | 第24页 |
| ·小节的旋律特征分析 | 第24-26页 |
| ·基于特征布尔数组提取候选音轨 | 第26-27页 |
| ·主旋律音轨的选出 | 第27页 |
| ·实验 | 第27-28页 |
| ·实验结果 | 第27页 |
| ·实验结果分析 | 第27-28页 |
| ·比较 | 第28页 |
| ·数据保存 | 第28-29页 |
| 第4章 模糊搜索算法的实现 | 第29-37页 |
| ·编辑距离(Levenshtein Distance) | 第29-31页 |
| ·动态规划法求编辑距离 | 第29-31页 |
| ·字符串的模糊搜索(string matching with errors) | 第31-37页 |
| ·Aho-Corasick自动机算法介绍 | 第31-34页 |
| ·BM算法与QS算法介绍 | 第34-35页 |
| ·模糊搜索算法的实现 | 第35-37页 |
| 第5章 音乐的相似比较 | 第37-44页 |
| ·基于和弦序列的方法 | 第37-39页 |
| ·和弦提取 | 第37-39页 |
| ·数据保存 | 第39页 |
| ·基于统计音符的方法 | 第39-40页 |
| ·音符统计 | 第40页 |
| ·数据保存 | 第40页 |
| ·实验 | 第40-44页 |
| ·方法一匹配结果 | 第41页 |
| ·方法二匹配结果 | 第41-43页 |
| ·比较与结论 | 第43-44页 |
| 第6章 总结与展望 | 第44-45页 |
| ·本文总结 | 第44页 |
| ·展望 | 第44-45页 |
| 参考文献 | 第45-47页 |
| 附录 | 第47-52页 |
| Crawler类的parsePage函数 | 第47-48页 |
| 音轨的构造 | 第48页 |
| 时间戳序列的构造 | 第48-49页 |
| 模糊搜索算法的实现 | 第49-50页 |
| Goto函数和Output函数的实现 | 第50-52页 |
| 致谢 | 第52-53页 |
| 摘要 | 第53-55页 |
| Abstract | 第55-57页 |