3、化工过程非单调规划与操作策略综合

化工过程非单调规划与操作策略综合

1. 层次化建模:过程与操作的精准刻画

在化工过程规划中,对过程和操作步骤进行有效表示至关重要。这些表示模型需满足两个关键要求:一是能够捕捉过程中的布尔型、整数型(即分类或定性)或实值变量;二是能在多个细节层次上对过程或操作进行描述,且保持内部一致性。

1.1 操作建模

操作步骤的特征化,即算子 (Op_{jq}) 的特征化,取决于操作类型(如布尔型、整数型、解析实值型)和所需的细节层次(如工厂某部分的抽象操作、阀门和泵等的原始操作)。以下是几种可能的模型:
- STRIPS 算子 :由 Fikes 和 Nilsson 在 1971 年引入,是最简单的操作步骤模型。它包含前置条件和后置条件,前置条件是在操作执行前系统及其周围环境必须满足的陈述,后置条件是操作执行后保证为真的陈述。然而,STRIPS 算子存在严重局限性,例如不同过程的时间前置和后置条件不同,难以创建通用的算子集合;且过程操作的函数关系会导致整体成为功能算子,这在严格的 STRIPS 模型中是不允许的。
- 条件算子 :为克服 STRIPS 算子的局限性,Chapman 在 1985 年提出了条件算子。它根据所有前置条件是否为真产生两组后置条件。但在合成操作程序时,条件算子也有类似的缺点,其使用受到严重限制,无法涵盖设备/产品切换、优化控制和某些安全回退策略等操作程序的规划。
- 功能算子 :与 STRIPS 和条件算子使用前置条件的合取不同,功能算子有一组前置条件的合取。对于每组前置条件,都有一组对应的后置条件。功能算子是比 STRIP

资源下载链接为: https://pan.quark.cn/s/67c535f75d4c C语言作为一门基础且强大的编程语言,在底层系统编程和算法实现方面表现卓越,其效率灵活性备受推崇。其中,“用指针实现的C语言排序算法”这一主题,融合了C语言的核心概念——指针,以及数据结构和算法的基础知识。指针是C语言的一大特色,它能够直接操作内存地址,从而为高效的数据操作提供了有力支持。在排序算法中,指针通常被用作迭代工具,用于遍历数组或链表,进而改变元素的顺序。 常见的排序算法,如冒泡排序、选择排序、插入排序、快速排序和归并排序等,都可以借助指针来实现。具体而言: 冒泡排序:通过交换相邻元素来实现排序。在C语言中,可以定义一个指向数组的指针,通过指针的递增或递减操作来遍历数组,比较相邻元素并在必要时进行交换。 选择排序:每次从剩余部分中找到最小(或最大)元素,然后将其第一个未排序的元素进行交换。指针可用于标记已排序和未排序部分的边界。 插入排序:将元素插入到已排序的部分,以保持有序性。可以使用指针跟踪已排序部分的末尾,并在找到合适位置后进行插入操作。 快速排序:采用分治策略,选择一个“基准”元素,将数组分为两部分,一部分的所有元素都小于基准,另一部分的所有元素都大于基准。这一过程通常通过递归来实现,而基准元素的选择和划分过程往往涉及指针操作。 归并排序:将数组分为两半,分别对它们进行排序,然后再进行合并。在C语言中,这通常需要借助动态内存分配和指针操作来处理临时数组。 在实现这些排序算法时,理解指针的用法极为关键。指针不仅可以作为函数参数传递,从而使排序算法能够作用于任何可寻址的数据结构(如数组或链表),而且熟练掌握指针的解引用、算术运算和比较操作,对于编写高效的排序代码至关重要。然而,需要注意的是,尽管指针提供了直接操作内存的便利,但不当使用可能会引发错误,例如内存泄漏、空指针
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值