- Vosk Android使用方法
熊爱吃鱼
android语音识别java
Vosk是一个基于kaldi的开源语音识别框架,支持多种编程语言和多个平台,易于使用和集成,是做语音识别时很好的选择。使用步骤如下:下载vosk源码:源码地址。利用源码编译so库,不会编译的小伙伴可以从这里下载aar包:libvosk.so,然后把文件后缀名从.aar改为.zip,再解压这个文件即可在其中jni目录下找到so库。删除源码vosk-api-0.3.45\android\lib\src
- Token Passing解码
搬砖人NO17
语音神经网络共同学习语音识别人工智能
1、TokenPassing讲解视频参考地址:Tokenpassing2、TokenPassing(以Kaldi代码为例)(1)取src/fstext/deterministic-fst-test.cc,描述了怎么创建fst。StdVectorFst*CreateBackoffFst(){StdVectorFst*fst=newStdVectorFst();fst->AddState();//st
- 智能语音技术栈
chenkaifang
不归类
识别原理——硬件数据采集——软件数据处理目前主流的开源平台包括CMUSphinx、HTK、Kaldi、Julius、iATROS、CNTK、TensorFlow等,CMUSphinx是离线的语音识别工具,支持DSP等低功耗的离线应用场景。由于深度学习对于语音识别WER的下降具有明显的作用,所以Kaldi、CNTK、TensorFlow等支持深度学习的工具目前比较流行,Kaldi的优势就是集成了很多
- ai智能语音机器人如何基于本地语音识别,搭建一款智能聊天机器人?
VO_794632978
WX-794632978语音机器人人工智能机器人语音识别腾讯云阿里云
基于本地语音识别技术,搭建智能聊天机器人是一种广泛使用的人工智能应用。它可以为用户提供语音聊天、语音指令和语音控制等服务,提高用户的体验和方便性。以下是基于本地语音识别的智能聊天机器人搭建过程。确定使用的技术在搭建智能聊天机器人之前,需要确定将使用的技术和平台。通常情况下,语音识别技术可以使用开源框架,如CMUSphinx、Kaldi、DeepSpeech等。它们都提供了丰富的文档和示例代码,用于
- julius开源语音识别引擎
xyc310898673
语音识别
开源语音识别软件HTK,对Julius和Kaldi等系统了解者更佳一.InstallationBySourcetarballInstallationprocessissimpleandcontainsthefollowingpoints:1.DownloadthenewestsourcetarbalfromJuliusofficialsite–link2.Unpackthearchiveforex
- Kaldi单步完美运行AIShell v1 S5之四:DNN (nnet3、xent、MPE)
aiXpert
Kaldidnnnnet3kaldiasr语音识别
Kaldi单步完美运行AIShellv1S5之四:DNN(nnet3、xent、MPE)致谢机器配置问题:显卡设备老旧,一个GPU,想跑tdnn模型,如何破?第11部分:nnet3DNN第12部分:nnet3训练、解码、校准第13部分:迭代深度计算第14部分:Chain致谢感谢AIShell在商业化道路上的探索。期待着v3的到来。机器配置sv@HP:~$sudolsb_release-aDistr
- Kaldi完美运行TIMIT完整结果(含DNN)
aiXpert
Kaldikalditimit语音识别asrdnn
Kaldi完美运行TIMIT完整结果(含DNN)完全完整含DNN的TIMIT结果RESULTS机器配置Kaldi下TIMIT详细输出第一部分:数据准备第二部分:MFCC&CMVN第三部分:单音素第四部分:tri1:Deltas第五部分:LDA+MLLT第六部分:LDA+MLLT+SAT第七部分:SGMM2第八部分:MMI+SGMM2第九部分:DNN第十部分:DNN+SGMM第十一部分:成功的结果后
- wenet环境部署
weixin_43870390
语音识别
下载镜像、生成container原始nvidia提供镜像的网站(包含kaldi):https://docs.nvidia.com/deeplearning/frameworks/kaldi-release-notes/rel_20-03.html#rel_20-03本次采用的是21.02版本,包含如下内容:Ubuntu20.04includingPython3.8NVIDIACUDA11.2.0i
- tensorflow环境安装配置
weixin_43870390
网络
下载匹配cuda的kaldi镜像Ubuntu20.04includingPython3.8NVIDIACUDA11.6.0cuBLAS11.8.1.74NVIDIAcuDNN8.3.2.44NVIDIANCCL2.11.4(optimizedforNVLink™)rdma-core36.0NVIDIAHPC-X2.10OpenMPI4.1.2rc4+OpenUCX1.12.0GDRCopy2.3N
- 离线语音识别 sherpa-ncnn 尝鲜体验
杭州_燕十三
语音识别sherpa-ncnn
文章目录1、ubuntu编译运行依赖安装下载与编译模型下载运行2、树莓派4B编译运行确认树莓派4B环境交叉编译交叉编译模型下载与运行模型对比测试树莓派4B运行大模型Sherpa-NCNN是一个基于C++的轻量级神经网络推理框架,是kaldi下的一个子项目,它专门针对移动设备和嵌入式系统进行了优化。Sherpa-NCNN的目标是提供高性能、低延迟的推理能力,适用于移动设备和嵌入式系统,可以以满足实时
- RivaGAN 水印项目
张昊亮
typescript
git地址https://github.com/DAI-Lab/RivaGANDockerfile(/tools下文件为git下的文件)################################################使用NVIDIACUDA10.0开发环境作为基础镜像FROMkaldiasr/kaldi:gpu-ubuntu18.04-cuda10.0#设置非交互式安装模式以避免某
- Kaldi中语言模型
legendayue
语音识别语言模型语音识别
数据准备流程是为了整理数据,生成指定的文件或者是变成指定的格式,方便kaldi后面的语言模型训练,数据准备流程1、处理集外词,将分词后的预料库data/local/train/text中的文件索引全部替换成,在生成语言模型时,如果计数文件中或者训练文件总出现了词典之外的词(OOV)将被替换成,然后将作为正常词进行统计,这么做的好处是给大量OOV分配概率,使得相比于以前频数稀少的精确词,使用增大计算
- 如何解决kaldi的依赖库mkl安装失败的问题
醉心编码
shell基础知识及技巧c/c++kaldipythonasr
最近在学习如何使用kaldi进行语音识别。按照进程进行安装部署时发现IntelMKL库总是失败。通过搜索大量的资料,但都发现不太适用。现在将失败的症状和解决方法分享一下,希望能给读者提供一些帮助。通过执行./check_dependencies.sh发现缺少IntelMKL。[root@localhostextras]#./check_dependencies.sh./check_dependen
- 报名开启丨2023 SpeechHome 语音技术研讨会
语音之家
语音之家活动专区智能语音人工智能语音识别AIGC开源
2023SpeechHome语音技术研讨会将于11月18日—11月19日,在北京举办,同时举行开源语音技术交流会和第八届Kaldi技术交流会。欢迎大家报名参加(报名链接在文末)!本届研讨会覆盖5大主题,包括语音前沿技术、音频生成、音频与大模型、数据与大模型及开源技术,其中开源技术内容包括Kaldi、ESPnet、WeNet、ModelScope、AISHELL等。邀请来自产学研智能语音技术领域的专
- Lhotse 音频库管理音频数据集
mingqian_chu
#音频部分音视频
原文参考这里,原文作者GenerativeAI,作者FeitengLhotse是一个旨在使语音和音频数据准备更具灵活性和可访问性的Python库,它与k2一起,构成了下一代Kaldi语音处理库的一部分。主要目标:1.以Python为中心的设计吸引更广泛的社区参与语音处理任务。2.为有经验的Kaldi用户提供富有表现力的命令行接口。3.为常用的语料库提供标准的数据准备方案。4.为与语音和音频相关的任
- 语音识别学习笔记
AI视觉网奇
语音识别语音识别学习笔记
目录端到端的多说话人语音识别序列化训练方法简介新一代Kaldi:Two-pass实时语音识别端到端的多说话人语音识别序列化训练方法简介端到端的多说话人语音识别序列化训练方法简介-知乎2.2基于排列不变性训练PermutationInvariantTraining(PIT)的多说话人语音识别所谓排列不变性训练是在AED的基础之上,添加多个output分支(通常支持几个人就有几个分支),文本序列和输出
- kaldi mfcc
落红灬有丶情
kaldi
Kaldi特征提取之-预处理背景本质上语音信号是一维的时间信号,随时间上下波动。现实中,人们再说话时会受到各种音素的干扰,为了进一步进行处理,我们必须进行必要的预处理以便之后的特征提取。诸如FBank,MFCC,PLP等都需要经过预处理步骤。本章将假设语音的格式为wav。预处理整个预处理过程如下图所示:分帧从图中可以看出我们需要将不定长的音频切分成固定长度的小段,这一步称为分帧。分帧的原因在于语音
- 语音识别开源框架
Swaggie
机器学习语音识别开源人工智能
语音识别开源框架文章目录语音识别开源框架Whisper特征Github地址开源文档介绍论文参考ASRT特征环境Github地址开源文档介绍DeepSpeech特征环境Github地址文档介绍论文参考DeepSpeech2环境Github地址文档介绍论文参考ESPNET特征Github地址开源文档介绍kaldi特征Kaldi'sversusothertoolkitsTheflavorofKaldiG
- 双系统Ubuntu-22.04.3安装编译kaldi
伪_装
ubuntulinux运维
Ubuntu物理内存要求85-100G以上,运行内存5-6G以上(如果第一次安装的Ubuntu物理内存不够,请勿进行扩容,扩容易出现黑屏、蓝屏、死机的情况,应该卸载Ubuntu重新安装,在安装过程中进行内存分配;运行内存可直接在虚拟机进行操作)1.1下载kaldiKaldi地址:GitHub-kaldi-asr/kaldi:kaldi-asr/kaldiistheofficiallocationo
- 使用 Lhotse 高效管理音频数据集
希尔贝壳AISHELL
智能语音音视频
Lhotse是一个旨在使语音和音频数据准备更具灵活性和可访问性的Python库,它与k2一起,构成了下一代Kaldi语音处理库的一部分。主要目标:1.以Python为中心的设计吸引更广泛的社区参与语音处理任务。2.为有经验的Kaldi用户提供富有表现力的命令行接口。3.为常用的语料库提供标准的数据准备方案。4.为与语音和音频相关的任务提供PyTorch数据集类。5.通过音频剪辑的概念实现模型训练中
- python 3.8+vscode 无法启动jupyter kernal问题
一点飞鸿影
python
在python3.8环境下,所有包更新到最新之后,使用vscode打开ipynb,提示`kerkaldiedwithexitcode1.`通过命令行启动jupyternotebook,提示启动内核失败,现象如下:详细报错信息是:```Traceback(mostrecentcalllast):File"c:\work\projects\test_robot\venv\lib\site-packag
- ubuntu16.04安装和卸载Kaldi
ZQSZXY
个人笔记kaldi安装深度学习
Ubuntu16.04环境:g++=4.9版本,gcc=4.9版本,刚开始我的gcc=5.4,结果报错:Ubuntu16.04默认的gcc版本是5以上,亲测会报错,***configurefailed:CUDA7_5doesnotsupportg++(g++-5.4.0).Youneedg++<5.0.***,如果报同样的错误,那就需要把系统的gcc和g++降级。下载Kaldi安装包Kaldi官网
- 基于深度学习的语音识别系统构建
周南音频科技教育学院(AI湖湘学派)
音频算法设计研究开发语音识别人工智能信号处理
加我微信hezkz17进数字音频系统研究开发交流答疑(课题组)项目内容:1.语音识别系统构建:负责基于kaldi的混合语音识别模型系统的构建,包括训练数据的搜集与处理,模型训练测试、rescore解码流程和上线部署等;2.声纹识别系统构建:使用cnn+aam-softmax的模型结构提取说话人声纹特征(embedding),然后在声纹库内进行声纹相似度的检索匹配;3.语种识别算法:使用类似声纹识别
- python语音识别库kaldi_Kaldi语音识别库在Linux下的安装和编译
岑依惜
1.介绍Kaldi语音识别工具将HTK比较零碎的各种各样的指令和功能进行整理集合,使用perl脚本调用。同时也加入了深度神经网络的分类器(DNN),本身由原来做HTK开发的人员制作而成,可以说是HTK的升级加强版。kaldi官方网站请见:http://kaldi.sourceforge.net/index.html2.安装和编译第一步:下载kaldi工具包kaldi有两个版本,kaldi-1和ka
- kaldi在linux上编译,Kaldi语音识别库linux环境下的安装和编译
三上酱
kaldi在linux上编译
介绍:Kaldi语音识别库可以说是,HTK数据库的整理加强版,将HTK比较零碎的各种各样的指令和功能进行整理,使用更加的方便,同时也加入了深度神经网络的分类器(DNN),本身由原来做HTK开发的人员制作而成。kaldi官方网站请见:http://kaldi.sourceforge.net/index.html安装以及编译:第一步:下载kaldi工具包kaldi有两个版本,kaldi-1和kaldi
- linux编译aidl接口,ubuntu下安装kaidl实用教程
weixin_39779530
linux编译aidl接口
1.介绍Kaldi语音识别工具将HTK比较零碎的各种各样的指令和功能进行整理集合,使用perl脚本调用。同时也加入了深度神经网络的分类器(DNN),本身由原来做HTK开发的人员制作而成,可以说是HTK的升级加强版。kaldi官方网站请见:http://kaldi.sourceforge.NET/index.html2.安装和编译第一步:下载kaldi工具包kaldi有两个版本,kaldi-1和ka
- kaldi在Linux下的安装
ch977
1.介绍Kaldi语音识别工具将HTK比较零碎的各种各样的指令和功能进行整理集合,使用perl脚本调用。同时也加入了深度神经网络的分类器(DNN),本身由原来做HTK开发的人员制作而成,可以说是HTK的升级加强版。kaldi官方网站请见:http://kaldi.sourceforge.net/index.html2.安装和编译第一步:下载kaldi工具包kaldi有两个版本,kaldi-1和ka
- Fedora 32安装Kaldi
胖多鱼
Kaldi
网上很多LInux安装Kaldi的链接,讲的都比较明确,例如:kaldi的编译安装与报错解决方法_extras/check_dependencies.shextras/check_dependen-CSDN博客保姆级kaldi语音识别(2)Linux系统Ubuntu20.04下开源语音识别工具kaldi配置_mozun2020的博客-CSDN博客这里面写的比较清楚。我用的是VMWARE+Fedor
- kaldi安装编译
泉泉酱
Kaldi是一款基于C++编写的开源语音识别工具箱。这款工具既可以在Windows下编译也可以在Linux下编译。一般建议在linux下开发。一、下载打开终端terminal,输入命令:gitclonehttps://github.com/kaldi-asr/kaldi.gitkaldi-trunk--origingolden二、各目录功能下载完毕以后,cdkaldi-trunk进去看看下载了一些
- Kaldi语音识别技术(八) ----- 整合HCLG
Python-AI Xenon
学习笔记语音识别基本法语音识别人工智能kaldiNLP
Kaldi语音识别技术(八)-----整合HCLG文章目录Kaldi语音识别技术(八)-----整合HCLGHCLG概述组合LG.fst可视化LG.fst组合CLG.fst可视化CLG.fst生成H.fst组合HCLG.fst生成HaCLG.fst生成HCLG.fstHCLG概述HCLG=min(det(Homin(det(Comin(det(LoG)))))将四者逐层合并,即可得到最后的图。其中
- java杨辉三角
3213213333332132
java基础
package com.algorithm;
/**
* @Description 杨辉三角
* @author FuJianyong
* 2015-1-22上午10:10:59
*/
public class YangHui {
public static void main(String[] args) {
//初始化二维数组长度
int[][] y
- 《大话重构》之大布局的辛酸历史
白糖_
重构
《大话重构》中提到“大布局你伤不起”,如果企图重构一个陈旧的大型系统是有非常大的风险,重构不是想象中那么简单。我目前所在公司正好对产品做了一次“大布局重构”,下面我就分享这个“大布局”项目经验给大家。
背景
公司专注于企业级管理产品软件,企业有大中小之分,在2000年初公司用JSP/Servlet开发了一套针对中
- 电驴链接在线视频播放源码
dubinwei
源码电驴播放器视频ed2k
本项目是个搜索电驴(ed2k)链接的应用,借助于磁力视频播放器(官网:
http://loveandroid.duapp.com/ 开放平台),可以实现在线播放视频,也可以用迅雷或者其他下载工具下载。
项目源码:
http://git.oschina.net/svo/Emule,动态更新。也可从附件中下载。
项目源码依赖于两个库项目,库项目一链接:
http://git.oschina.
- Javascript中函数的toString()方法
周凡杨
JavaScriptjstoStringfunctionobject
简述
The toString() method returns a string representing the source code of the function.
简译之,Javascript的toString()方法返回一个代表函数源代码的字符串。
句法
function.
- struts处理自定义异常
g21121
struts
很多时候我们会用到自定义异常来表示特定的错误情况,自定义异常比较简单,只要分清是运行时异常还是非运行时异常即可,运行时异常不需要捕获,继承自RuntimeException,是由容器自己抛出,例如空指针异常。
非运行时异常继承自Exception,在抛出后需要捕获,例如文件未找到异常。
此处我们用的是非运行时异常,首先定义一个异常LoginException:
/**
* 类描述:登录相
- Linux中find常见用法示例
510888780
linux
Linux中find常见用法示例
·find path -option [ -print ] [ -exec -ok command ] {} \;
find命令的参数;
- SpringMVC的各种参数绑定方式
Harry642
springMVC绑定表单
1. 基本数据类型(以int为例,其他类似):
Controller代码:
@RequestMapping("saysth.do")
public void test(int count) {
}
表单代码:
<form action="saysth.do" method="post&q
- Java 获取Oracle ROWID
aijuans
javaoracle
A ROWID is an identification tag unique for each row of an Oracle Database table. The ROWID can be thought of as a virtual column, containing the ID for each row.
The oracle.sql.ROWID class i
- java获取方法的参数名
antlove
javajdkparametermethodreflect
reflect.ClassInformationUtil.java
package reflect;
import javassist.ClassPool;
import javassist.CtClass;
import javassist.CtMethod;
import javassist.Modifier;
import javassist.bytecode.CodeAtt
- JAVA正则表达式匹配 查找 替换 提取操作
百合不是茶
java正则表达式替换提取查找
正则表达式的查找;主要是用到String类中的split();
String str;
str.split();方法中传入按照什么规则截取,返回一个String数组
常见的截取规则:
str.split("\\.")按照.来截取
str.
- Java中equals()与hashCode()方法详解
bijian1013
javasetequals()hashCode()
一.equals()方法详解
equals()方法在object类中定义如下:
public boolean equals(Object obj) {
return (this == obj);
}
很明显是对两个对象的地址值进行的比较(即比较引用是否相同)。但是我们知道,String 、Math、I
- 精通Oracle10编程SQL(4)使用SQL语句
bijian1013
oracle数据库plsql
--工资级别表
create table SALGRADE
(
GRADE NUMBER(10),
LOSAL NUMBER(10,2),
HISAL NUMBER(10,2)
)
insert into SALGRADE values(1,0,100);
insert into SALGRADE values(2,100,200);
inser
- 【Nginx二】Nginx作为静态文件HTTP服务器
bit1129
HTTP服务器
Nginx作为静态文件HTTP服务器
在本地系统中创建/data/www目录,存放html文件(包括index.html)
创建/data/images目录,存放imags图片
在主配置文件中添加http指令
http {
server {
listen 80;
server_name
- kafka获得最新partition offset
blackproof
kafkapartitionoffset最新
kafka获得partition下标,需要用到kafka的simpleconsumer
import java.util.ArrayList;
import java.util.Collections;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.
- centos 7安装docker两种方式
ronin47
第一种是采用yum 方式
yum install -y docker
 
- java-60-在O(1)时间删除链表结点
bylijinnan
java
public class DeleteNode_O1_Time {
/**
* Q 60 在O(1)时间删除链表结点
* 给定链表的头指针和一个结点指针(!!),在O(1)时间删除该结点
*
* Assume the list is:
* head->...->nodeToDelete->mNode->nNode->..
- nginx利用proxy_cache来缓存文件
cfyme
cache
user zhangy users;
worker_processes 10;
error_log /var/vlogs/nginx_error.log crit;
pid /var/vlogs/nginx.pid;
#Specifies the value for ma
- [JWFD开源工作流]JWFD嵌入式语法分析器负号的使用问题
comsci
嵌入式
假如我们需要用JWFD的语法分析模块定义一个带负号的方程式,直接在方程式之前添加负号是不正确的,而必须这样做:
string str01 = "a=3.14;b=2.71;c=0;c-((a*a)+(b*b))"
定义一个0整数c,然后用这个整数c去
- 如何集成支付宝官方文档
dai_lm
android
官方文档下载地址
https://b.alipay.com/order/productDetail.htm?productId=2012120700377310&tabId=4#ps-tabinfo-hash
集成的必要条件
1. 需要有自己的Server接收支付宝的消息
2. 需要先制作app,然后提交支付宝审核,通过后才能集成
调试的时候估计会真的扣款,请注意
- 应该在什么时候使用Hadoop
datamachine
hadoop
原帖地址:http://blog.chinaunix.net/uid-301743-id-3925358.html
存档,某些观点与我不谋而合,过度技术化不可取,且hadoop并非万能。
--------------------------------------------万能的分割线--------------------------------
有人问我,“你在大数据和Hado
- 在GridView中对于有外键的字段使用关联模型进行搜索和排序
dcj3sjt126com
yii
在GridView中使用关联模型进行搜索和排序
首先我们有两个模型它们直接有关联:
class Author extends CActiveRecord {
...
}
class Post extends CActiveRecord {
...
function relations() {
return array(
'
- 使用NSString 的格式化大全
dcj3sjt126com
Objective-C
格式定义The format specifiers supported by the NSString formatting methods and CFString formatting functions follow the IEEE printf specification; the specifiers are summarized in Table 1. Note that you c
- 使用activeX插件对象object滚动有重影
蕃薯耀
activeX插件滚动有重影
使用activeX插件对象object滚动有重影 <object style="width:0;" id="abc" classid="CLSID:D3E3970F-2927-9680-BBB4-5D0889909DF6" codebase="activex/OAX339.CAB#
- SpringMVC4零配置
hanqunfeng
springmvc4
基于Servlet3.0规范和SpringMVC4注解式配置方式,实现零xml配置,弄了个小demo,供交流讨论。
项目说明如下:
1.db.sql是项目中用到的表,数据库使用的是oracle11g
2.该项目使用mvn进行管理,私服为自搭建nexus,项目只用到一个第三方 jar,就是oracle的驱动;
3.默认项目为零配置启动,如果需要更改启动方式,请
- 《开源框架那点事儿16》:缓存相关代码的演变
j2eetop
开源框架
问题引入
上次我参与某个大型项目的优化工作,由于系统要求有比较高的TPS,因此就免不了要使用缓冲。
该项目中用的缓冲比较多,有MemCache,有Redis,有的还需要提供二级缓冲,也就是说应用服务器这层也可以设置一些缓冲。
当然去看相关实现代代码的时候,大致是下面的样子。
[java]
view plain
copy
print
?
public vo
- AngularJS浅析
kvhur
JavaScript
概念
AngularJS is a structural framework for dynamic web apps.
了解更多详情请见原文链接:http://www.gbtags.com/gb/share/5726.htm
Directive
扩展html,给html添加声明语句,以便实现自己的需求。对于页面中html元素以ng为前缀的属性名称,ng是angular的命名空间
- 架构师之jdk的bug排查(一)---------------split的点号陷阱
nannan408
split
1.前言.
jdk1.6的lang包的split方法是有bug的,它不能有效识别A.b.c这种类型,导致截取长度始终是0.而对于其他字符,则无此问题.不知道官方有没有修复这个bug.
2.代码
String[] paths = "object.object2.prop11".split("'");
System.ou
- 如何对10亿数据量级的mongoDB作高效的全表扫描
quentinXXZ
mongodb
本文链接:
http://quentinXXZ.iteye.com/blog/2149440
一、正常情况下,不应该有这种需求
首先,大家应该有个概念,标题中的这个问题,在大多情况下是一个伪命题,不应该被提出来。要知道,对于一般较大数据量的数据库,全表查询,这种操作一般情况下是不应该出现的,在做正常查询的时候,如果是范围查询,你至少应该要加上limit。
说一下,
- C语言算法之水仙花数
qiufeihu
c算法
/**
* 水仙花数
*/
#include <stdio.h>
#define N 10
int main()
{
int x,y,z;
for(x=1;x<=N;x++)
for(y=0;y<=N;y++)
for(z=0;z<=N;z++)
if(x*100+y*10+z == x*x*x
- JSP指令
wyzuomumu
jsp
jsp指令的一般语法格式: <%@ 指令名 属性 =”值 ” %>
常用的三种指令: page,include,taglib
page指令语法形式: <%@ page 属性 1=”值 1” 属性 2=”值 2”%>
include指令语法形式: <%@include file=”relative url”%> (jsp可以通过 include