为什么说模型化在远程通信是最先进的

本文将关注模型化技术在远程通信领域的应用,以展示相对于其它的领域的先进性。

一致性不是可选的

一个远程通信系统是一套能够相互通信的不均匀的设备。要做到这一点,这些设备必须遵从同样的协议。从技术上讲,这包含2个互补的方面:

一个静态界面——从一个设备到另一个的交换的报文格式。

一个动态界面——定义了交换的报文的正确的序列。

对一个远程通信系统协议,这两方面的一致性都很重要。此外,协议定义需要尽可能清楚不能有岐义。

标准化机构

标准化机构定义的协议这两个方面的介绍。从历史上看,世界的每个地区自己的标准化机构,如欧洲ETSI,日本的ARIB,美国的ATIS。当时,因为标准是不同的,这意味着在一个区域的设备如手机无法在另一个领域正常工作。多亏了全球化,不同的标准化组织现已携手发布全球标准,如3G或即将到来的LTE(Long Term Evolution),是4G技术的方案之一。

为了产生清晰易于理解的标准,欧洲标准化机构ETSI已经公布了一组介绍通过一组技术如SDL(Specification and Description Language规范和描述语言)ASN.1(Abstract Syntax Notation One抽象语法记法一),ECN(Encoding Control Notation编码控制符号),TTCN-3(Testing and Test Control Notation测试和测试控制表示法)制作出更好的标准”这些介绍可见于ETSI网站:

http://www.etsi.org/WebSite/Technologies/ProtocolSpecification.aspx 

本文将论述这些技术如何帮助远程通信行业生成更好的标准。

 

动态界面

一种协议描述了同级的从一层到另一远程层的报文交换。这样的界面称为Protocol Data Unit即PDU。 

这实际上是一个协议的逻辑视图,因为实际中一与上一层或下一层交换信息。这种“垂直”的界面被称为ASP(Abstract Service Primitive)。因此PDU通过ASP发送远程层,但不发送描述交换的PDU协议定义。

动态描述的协议逻辑视图由一堆情景组成。 ETSI建议使用MSC(消息序列图)。我们看下一个简单的例子,一层请求连接并在MSC描述。

在上面的情景中,报文在终端机与网络间进行交换。一条报文可能包含参数如 例子中ConConf报文带有conId 参数。

大多时候,一个远程通信系统是一个分布式系统,终端是脱离网络的实体设备。它很可能有一个不同的处理器架构运行不同的操作系统。因此,必须一种方法来创建一个信息流,使该信息流独立于处理器和操作系统

静态界面

为了定义一个硬件独立的信息流,一起使用抽象的数据表示法与ASN.1表示。ASN.1指的是Abstract Syntax Notation One ,由ITU-T标准化。它描述的是可理解的数据类型,包括基本类型如布尔型或实数,复杂类型如结构或数组。ASN.1描述类型,但没有说明如何在一个给定的语言操纵们。主要关注的是ASN.1定义编码和解码规则,以便为某一类型的信息数据流独立给定的硬件结构的实施。除了标准化的编码规则,如BER(Basic Encoding Rule基本编码规则)或PERPacket Encoding Rule分组编码规则),它们也有一个符号来描述具体的编码规则,它就是ECN:Encoding Control Notation编码控制符号。最后一点,ASN.1数据类型可以直接导入SDL规范,TTCN进行测试。

An ASN.1 example structure:

PersonRecord ::= SEQUENCE {

name IA5String,

age INTEGER,

member BOOLEAN

}

An example value:

examplePerson PersonRecord ::= {

name “Smith”,

age 35,

member true

}

XML encoding of the value:

<PersonRecord>

<name>Smith</name>

<age>35</age>

<member>true</member>

</PersonRecord>

协议详细的行为

MSC描述的协议行为只几种可能的情景。即使它描述替代,循环,或可选的情景MCS也无法描述发生在一个协议所有可能的情况。要做到这点,它关乎要描述该协议的详细和可执行的模型。以这种方式,它可能可以模拟和验证的行为,这样该模型被认为是一个参考模型。为了这个目的,ETSI推荐一个正式的建模语言,称为SDL规范和描述语言。

SDL已在80年代首先用描述远程通信协议,无需说明语言是否符合我们的要求设计。但随着不同技术的革新,语言自此跟着演变,如面向对象的介绍,UML概要文件的定义

从技术上讲SDL有4个互补的观点,我们以下简要介绍。

体系结构

一个系统由块组成,这些块可以分解为子块。 

体系统结构的页就是一个进程,主要是一个带有关联的隐含消息队列的有限状态机。

●通信

不同块间交换的信息流在体系结构中有描述,用来定义块的接口。

●行为

详细的行为被完全生动地描述。根据规格想要的精确度,它可能忽略了实施细节。

上面的例子示了一个基本的有限状态机:初始化ConReq消息发送出去ConReqTimer开始启动。状态机转到Connecting状态并等待连接确认消息ConConf,或者计时器关闭之后,连接请求10。如果仍然不成功,进程停止。

●数据

为了使规格完整无岐义,SDL嵌入抽象数据类型和语法来操纵这些数据。如前所述,最好导入ASN.1数据类型

协议一致性

现在的问题是确保实现相同协议符合ETSI公布的标准。对于近代的标准如SIP协议,IP V63GPP IMS等,ETSI的已公布基于TTCN-3语言一致性测试套件。为了确保它符合需求,ETSI还保持了由ITU-T标准化TTCN-3语言。
TTCN代表测试和测试控制符号是国际标准化组织发起的一致性测试方法和框架文件(9646-3)的一部分。 TTCN-2专用通信系统,TTCN-3适用于测试任何一种系统。

TTCN-3可视为一个经典文本的编程语言,但几个方面使用它成为了一种十分强大的测试语言。

●抽象层

SDL, TTCN-3包含报文和计时器的概念,它们是一个远程通信系统的基本服务。这样就很容易发送或接收一条报文,启动或取消一个计时器。

●模板

当测试一个远程通信系统时,大部分的工作是核实交换的报文是否包含正确的信息。TTCN-3定义了模板的概念,轻松地验证一组复杂参数的正确性。TTCN-3还可选择参数(参数可能不存在),可以忽略一些参数(参数是存在的,但与它的值无关)。

●可选方案

测试描述可选方案并根据不同的可选方案设置结论。TTCN-3 嵌入可选方案的概念,无论它们是基于异步信息如报文的交换还是同步信息如修改的变量值。

cEnv.send(ConReq);

ConReqTimer.start;

alt {

[]cEnv.receive(ConConf){

setverdict(pass);

}

[]ConReqTimer.timeout{

setverdict(fail);

}

}

上面的例子显示了TTCN-3的一个基本可选方案:一个连接请求ConReq 通过cEnv 端口发送,计时器 ConReqTimer 开发启动。在这个可选方案中,或是接收到 ConConf 响应或是计时器ConReqTimer 关闭。

模型测试

由于SDL和TTCN-3有同样的抽象层,两种语言都可在实施前测试一个规范模型。由于两种语言都是正式的,意味着完整且没有岐义的,可以从SDL规范中生成协议实施的代码,从TTCN-3测试例中生成测试代码。一个早期的验证将最终节省大量的时间和精力。

最后一点,ETSI发布了TTCN-3的一致性测试套件,这样远程通信制造商可以确保其实施符合标准。

结论

由于远程通信系统本质要求符合一个共同的标准,该标准包括静态和动态接口,远程标准化机构以及远程通信设备制造商采用多年的先进技术如 MSC, ASN.1, SDL和 TTCN 。事实上,这些技术涵盖整个开发周期,从需求,规划到设计,测试。这就是为什么在开发通信系统时必须考虑清楚的原因。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值