2

👁 8 👍 0 💬 0 字数 1150 阅读 5 分钟

Homework 2

姓名: 刘欣楠

班级: 数学强基 2301

学号: 2233310237

Question 1:

有一推销员, 从城市 $v_0$ 出发, 要依次访问城市 $v_1, v_2, \dots, v_n$ 各一次, 最后返回到 $v_0$. 已知从 $v_i$$v_j$ 的旅费为 $c_{ij}$, 对于任意的 $v_i$$v_j$, 问他应按怎样的次序访问这些城市, 使得总旅费最小?

答案
定义变量 $x_{ij}=\begin{cases} 1, & \text{路径中包含从\ } v_i\text{\ 到\ } v_j \text{\ 的边}\\ 0, & \text{不包含} \end{cases}$

那么我们的目标函数就是 $\min \sum\limits_{i,j=0}^n c_{ij}x_{ij}$.

接着考虑约束条件, 由于要用一条路径覆盖, 所以每个点只会有一个入边即 $\sum\limits_{i=0}^n x_{ij}=1$. 也只会有一条出边 $\sum\limits_{j=0}^nx_{ij}=1$.

但仍要保证路径是一条, 考虑加入辅助变量 $u_i, i=1,2,\ldots, n$, 只需满足 $u_i-u_j+x_{ij}(n)\leqslant n-1, i,j=1,2,\ldots,n$.

因为当 $1\sim n$ 中存在子连通图, 那么一定存在一个子环, 设大小, 而将这个环上的边 $(i,j)$ 对应的式子取出, 那么相加后所有的 $u_i,u_j$ 抵消, 左侧为 $kn$, 右侧为 $k(n-1)$ 显然不成立.

所以该限制确保了不存在子环. 而当只有一条路径时, 只需取 $u_i$ 表示第 i 个点的顺序即可保证所有等式成立, 因为此时 $1\leqslant u_i\leqslant n$, $u_i-u_j\leqslant n-1$ 成立.

故满足上述限制的解一定构成一条符合要求的路径. 汇总后可将模型写成.

$$\begin{cases} \min & z=\sum\limits_{i,j=0}^n c_{ij}x_{ij} &\\ \text{s.t.} & \sum\limits_{i=0}^{n}x_{ij}=1, & j=0,\ldots,n\\ & \sum\limits_{j=0}^n x_{ij}=1, & i=0,\ldots,n\\ & u_i-u_j+nx_{ij}\leqslant n-1, & 1\leqslant i,j \leqslant n. \\ & x_{ij}\in \{0,1\}, & i,j=0,\ldots,n\\ & u_i\in \mathbb{R} & i=1,\ldots,n \end{cases}$$

Question 2:

需要将 11 件加工任务 (A-K) 分配到两个工作站, 任务需要依次经过工作站 1, 2 以完成加 工. 任务间的依赖关系如下图 (后续节点任务的启动需要前序任务完成), 每件任务在工作 站所花费的时间如下表:

图

每件任务在两个工作站上所需时间如下表 (单位: 小时):

\small

`latex \begin{tabular}{c|*{11}{c}} 任务 & A & B & C & D & E & F & G & H & I & J & K \

在工作站 1 上花费时间 (小时) & 25 & 5 & 5 & 35 & 10 & 7 & 8 & 7 & 2 & 4 & 7 \ 在工作站 2 上花费时间 (小时) & 20 & 6 & 4 & 15 & 5 & 5 & 4 & 5 & 10 & 4 & 2 \ \end{tabular} `

设计装配任务分配方案, 目标是为工作站分配加工任务, 尽可能使总装配时间最短.

答案
$A-K$ 对应到 $1-11$.

题目中的符号表示 $t_{ij}$ 表示第 $i$ 个任务在 $j$ 工作站上的耗时, 具体值见上表.

$P_i$ 表示任务 $i$ 的直接前序依赖任务集合, 例如 $P_{3}=\{2\}$.

$M$ 为充分大的常数.

决策变量:

$x_i\in\{0,1\}$: 表示任务 $i$ 是否分配给工作站 $1$, $1$ 表示是, $0$ 表示否 ($i=1,\ldots,11$).

$S_i$ 表示任务 $i$ 的开工时间 ($i=1,\ldots,11$).

$y_{ij}\in\{0,1\}$ 表示任务 $i$ 是否在任务 $j$ 之前完成 ($i\neq j$).

为了方便, 先推导每个任务的结束时间记作 $C_i=S_i+x_it_{i1}+(1-x_i)t_{i2}$$x_i$ 控制在哪个工作站上.

目标函数:

$f=\min C_{11}$.

约束条件:

第一类是依赖关系, 即对于每个任务 $i$, 要求 $C_j\leqslant S_i,\forall j\in P_i$.

第二类是单个工作站上任务不重叠, 那么考虑先限定 $y_{ij}+y_{ji}=1$.

然后当 $x_i=x_j$ 时要求根据 $y_{ij}$ 的取值判断 $i,j$ 的先后顺序.

可以构建下面的条件

$$\begin{cases} C_i\leqslant S_j+M(y_{ji}+2-x_i-x_j)\\ C_i\leqslant S_j+M(y_{ji}+x_i+x_j) \end{cases}$$

不难验证, 当 $x_i\neq x_j$ 时, 上述两个限制肯定成立. 而当 $x_i=x_j$ 时, 上述限制具有约束力, 仅当 $y_{ji}=0$, 即 $y_{ij}=1$. 此时要求 $i$$j$ 之前完成, 即 $C_i\leqslant S_j$. 满足定义.

所以只需对 $i\neq j$ 上述两条约束成立即可满足在单个工作站上不重叠.

综上, 汇总可得总的运筹模型可建立为 $$\begin{cases} \min & C_{11} & \\ \text{s.t.} & C_j\leqslant S_i & \forall j\in P_i, i=1,2,\ldots,11\\ & y_{ij}+y_{ji}=1 & 1\leqslant i\neq j\leqslant 11\\ & C_i\leqslant S_j+M(y_{ji}+2-x_i-x_j) & 1\leqslant i\neq j \leqslant 11 \\ & C_i\leqslant S_j+M(y_{ji}+x_i+x_j) & 1\leqslant i\neq j \leqslant 11\\ & x_{ij}\in \{0,1\} & 1\leqslant i\neq j\leqslant 11\\ & y_{ij}\in \{0,1\} & 1\leqslant i\neq j\leqslant 11\\ & C_i=S_i+x_i t_{i1}+(1-x_i)t_{i2} & i=1,\ldots,11\\ & S_i\geqslant 0 & i=1,\ldots,11 \end{cases}$$

下面是一组我得到的最优解, 并且分类讨论 A 一开始在 1,还是 2 可以证明该方案已经达到下界.

先简要证明.

如果 A 在工作站 1, 那么只考虑 A,B,C,F,G,J,K 这些任务, A 25h, B 最早 30h, C 最早 34h, F,G 最早 41h (F1G2), 再 J,K 依次完成最早要 47h.

如果 A 在工作站 2, 那么 D 最早在 35h 完成, E 最早 40h, H,I 最早 45h, 再 J,K 依次完成最早要 51h.

注意上述两种假设都忽略了部分任务以考虑最优, 所以实际必定不低于上述考虑, 所以总时间至少为 47h.

下面给出恰好为 47h 的方案.

在工作站 1 上依次完成 A,B,I,F.

在工作站 2 上依次完成 D,E,H,C,G,J,K.

几个重要的时间点,

$0\sim25h$ 工作站 1 完成 A, 工作站 2 完成 D,E,H.

$25\sim30h$ 工作站 1 完成 B, 工作站 2 等待.

$30\sim34h$ 工作站 1 完成 I, 工作站 2 完成 C.

$34\sim41h$ 工作站 1 完成 F, 工作站 2 完成 G.

接下来 6h 依次完成 J,K. 在 47h 时完成所有任务. 达到理论下界. 所以已经是最优解.

评论 0
评论加载中...