面向对象的液压系统分析研究--2
二、液压系统面向对象的分析
1. 问题描述
液压系统分为液压传动系统和液压控制系统两种类型,本文的研究对象是液压传动系统。液压系统是能实现系统功能的液压回路的总和。液压回路又是能实现某种规定功能的液压元件的组合。液压元件是组成液压系统的基本单元。主要的液压元件有液压泵、执行元件(液压缸、液压马达)、液压控制阀(压力控制阀、流量控制阀、方向控制阀等)、液压辅件(密封圈、滤油器、蓄能器、油箱及其附件、管件、热交换器等)。液压控制阀按照其安装形式的不同又可分为普通阀、叠加阀、插装阀。液压回路是液压元件组成的功能单元。液压回路主要有压力控制回路、流量(速度)控制回路、方向控制回路、安全回路、定位回路、同步回路、顺序动作回路等。以上分类只是粗略分类,限于篇幅,详细分类此处不一一列出。液压系统设计就是根据机械师提出的主机的动作循环要求、静、动态性能及液压系统工作环境等方面的要求,进行系统的工况分析,确定主要参数(包括系统压力、系统流量、液压执行元件类型及主要参数等),选择合理的液压回路和液压元件,设计工作的最终形式是液压系统原理图和各种技术文件。
2. 标识类和对象
类和对象是对应用论域中的概念的标识,是系统分析的基础。这一过程要考虑许多情况,以形成软件复用的基础。类和对象的标识是从对问题描述的分析开始的。在液压系统中抽取出如下对象(本文的类即对象都是以大写字母表示):
液压系统(HYDRAULIC SYSTEM)、执行元件(ACTUATOR)、液压缸(CYLINDER)、液压马达(MOTOR)、液压回路(CIRCUIT)、压力控制回路(PRESSURE CONTROL)、流量(速度)控制回路(SPEED CONTROL)、方向控制回路(DIRECTIONAL VALVE CONTROL)、安全回路(SECURITY CONTROL)、定位回路(POSITION CONTROL)、同步回路(SYNCHRONISE CIRCUIT)、顺序动作回路(SEQUEUNT CIRCUIT)、液压泵(PUMP)、阀(VALVE)、压力控制阀(PRESSURE VALVE)、流量控制阀(FLOW VALVE)、
方向控制阀(DIRECTIONAL VALVE)、液压辅件(ACCESSORY)……普通阀(COMMON VALVE)、插装阀(CARTRIDGE VALVE)、叠加阀(SUPERIMPOSED VALVE)……。
因为液压系统是一个很复杂的系统,在此不可能将所有的对象都列出,本文只列出了部分对象,为下文继续分析提供依据。
3. 标识结构
结构层反映了对象之间的组装及继承关系。整体-部分结构标识了组装结构,泛化-特化关系反映了继承关系。如果父对象,或泛化对象的属性或特征可为其所有的子对象,或特化对象共享,就建立起了泛化-特化关系。父对象和子对象的这种属性共享就称之为继承性。父对象是由若干子对象以某种方式组装而成的,就构成了整体-部分关系。这种关系一般建立在物理组装的基础上。虽然整体-部分关系不象泛化-特化关系那样具有继承性,但它们也同样有重复度和参与度特征。重复度是指组成一个父对象的子对象的数量。(例如,一个液压系统中有若干个调速回路。)参与度是指父对象或子对象是否都必须在整体-部分关系中出现。(例如,一个液压系统有若干个调速回路,而一个调速回路并不一定是一个液压系统的一部分。)
在液压系统中,由于液压回路组成了液压系统,液压元件组成了液压回路,所以整体-部分结构较容易标识。以液压回路组成液压系统为例,可得到图3所示的组装结构。

图3 液压系统的组装结构示例
图中数字表示了整体与部分之间的数量关系。1,m表示一个液压系统可由一个或多个泵源回路组成;0,m表示一个液压系统可以包含零个或多个相应回路;0,1表示该回路可以不作为该液压系统的组成回路,也可以作为该液压系统的组成回路。
泛化-特化关系在液压系统中也是广泛存在的。以阀的泛化-特化关系为例,可得到如图4所示继承关系。

图4 泛化---特化结构示例
4.标识主题
过去的结构化模型的特征之一就是层次分解。而大多数OOA模型的结构都相对平坦,除非应用论域使用泛化-特化结构或整体-部分结构。事实上,可以通过建立多个主题来处理规模比较大的复杂模型。每个主题可以看作一个子系统。主题的概念是从观察者的角度来看的。分析员可以依据子论域、子系统,甚至组织或地域等来区分主题,只要运用得当,所有这些规则都有助于主题划分。
本文讨论的液压系统根据子系统原则划分为三个主题层。组成液压系统的液压回路对象及其对象之间的联系构成了回路层;组成液压回路的液压元件对象及其之间的联系构成了元件层。各主题层内对象之间与主题层间的对象之间都存在着实例连接和消息通信。两个主题层共同构成了一个复杂的液压系统。液压系统主题层如图5所示。

图5 主题层示例
5.标识属性及实例连接
OOA模型的属性层包括对象属性和对象之间的关系(实例连接)。对象属性即对象内部封装的数据。实例连接可以看作是一种事务规则或应用论域约束,这些连接表明一个类中的对象如何与另一个类中的对象相关联的。
标识属性的目的就是为前面已经确立的各个对象建立一系列属性。本文的属性均以小写字母来表示。标识属性的基本做法是:标识属性、修改OOA模型的其它层以适应这些属性,如果有必要的话修改对象,然后重复这个过程。之所以有时会有修改对象的可能,是因为在表示对象时发现有的属性对于某些对象不适合。例如,在为液压缸(CYLINDER)标识属性输出力(output_force)时,发现该属性不适合于摆动式液压缸,因此发现CYLINDER这个对象需要细化为直线型液压缸(LINEAR CYLINDER)和摆动式液压缸(ROTARY CYLINDER)。其相应属性分别为output_force和output_torque。
本文讨论的液压系统的属性标识的一部分如表1所示。



表1 液压系统属性标识示例
系统的实例连接示例如图6所示(为简单起见,图中略去了属性标识)。

图6 实例连接示例
6.标识服务及消息通信
前面讨论的均是应用论域的某个静态方面。对象之间的动态关系可以表示为对象所执行的服务以及对象之间传递的消息。建立动态关系是为了说明所标识的各种对象是如何共同协作,使系统运作起来的。通常的步骤是,首先标识在每个对象中必须封装的一组服务;然后将服务与对象的属性相比较,验证其一致性。如果已经标识了某个对象的属性,那么每个属性就必须关联到某个服务,否则这个属性对于这个对象来说就形同虚设,永远不可能被访问。然后画出对象之间的消息通信路径,协调系统的行为。
以“液压系统”这个最上层的类-对象为例,它有五个属性(system_name,pressure_level,designer,pressure,max_flow_quantity)。“液压系统”具有的行为:Set_Name , Get_Name , Set_System_Level , Get_System_Level , Set_Pressure_Level , Get_Pressure_Level , Set_Designer , Get_Designer , Set_Pressure , Get_Pressure , Set_Max_Flow_Quantity , Get_Max_Flow_Quantity。“液压系统”与其它许多类--对象之间都有消息通信。以“液压系统”与“执行元件”之间的消息通信为例。“液压系统”在计算系统压力(pressure)和系统最大流量(max_flow_quantity)时,需要各个执行元件的压力和流量参数,因此“液压系统”在计算系统压力和流量时,向“执行元件”发送消息,请求提供相关参数。两个对象及其消息通信如图7所示。

图7 服务及消息通信示例
图中“执行元件”只有类边界而没有实例边界,因为在现实世界中它需要以“液压缸”和“液压马达”的形式出现。
第 [1] 2 [3] 页
|