脉冲时序图 下图为指令“分配保持型接通延时定时器参数并启动”的脉冲图:如果操作数“TagIn_1”的信号状态从“0”变为“1”,将启动“Timer_1”定时器。即使操作数 “TagIn_1”的信号状态变为“0”,定时器也会在操作数“TagIn_Number”的定时器值结束时计时 结束。定时器计时结束后,操作数“TagOut”将被置位为“1”。如果定时器计时期间操作数 “TagIn_1”的信号状态从“0”变为“1”,定时器将重启。
S_OFFDT:分配关断延时定时器参数并启动 (S7-300, S7-400) 说明 当输入 S 的逻辑运算结果 (RLO) 的信号状态从“1”变为“0”(信号下降沿)时,指令“分配关 断延时定时器参数并启动”将启动预设的定时器。定时器在预设的持续时间 (TV) 结束时计 时结束。只要定时器在计时或输入 S 返回信号状态“1”,输出 Q 的信号状态就为“1”。定时器 计时结束且输入 S 的信号状态为“0”时,输出 Q 的信号状态将复位为“0”。如果定时器运行期 间输入 S 的信号状态从“0”变为“1”,定时器将停止。只有在检测到输入 S 的信号下降沿后,才 会重新启动定时器。 持续时间由定时器值和时基构成,且在参数 TV 处设定。指令启动后,预设时间值开始递减 计数,直至为零。时基表示定时器值更改的时间段。当前定时器值在输出 BI 处以 BI 编码格 式输出,在输出 BCD 处以 BCD 编码格式输出。 输入端 R 的信号状态为“1”时,当前时间值和时基都将复位为“0”。这种情况下,输出 Q 的信 号状态为“0”。 “分配关断延时定时器参数并启动”指令需要对边沿评估进行前导逻辑运算,可以放在程序 段中或程序段的结尾。 每次访问时都会更新指令数据。因此,在循环开始和循环结束时查询数据可能会返回不同的 值。 说明 在时间单元,操作系统通过时基指定的间隔,以一个时间单位缩短时间值,直到该值为“0”。 递减操作与用户程序不同步执行。因此,定时器中的值比预期的时基Zui多短一个时间间隔值。 以下给出了如何构造时间单元的一个示例:另请参见“L:加载定时器值”。下表列出了“分配关断延时定时器参数并启动”指令的参数: 参数 声明 数据类型 存储区 说明 <定时器> InOut/Input TIMER T 指令的时间 定时器的数量取决于 CPU。 S Input BOOL I、Q、M、D、L 启动输入 TV Input S5TIME、WORD I、Q、M、D、L 或常量 预设时间值 R Input BOOL I、Q、M、D、 L、T、C、P 复位输入 BI Output WORD I、Q、M、D、 L、P 当前时间值(BI 编码) BCD Output WORD I、Q、M、D、 L、P 当前时间值(BCD 格式) Q Output BOOL I、Q、M、D、L 定时器的状态 有关有效数据类型的更多信息,请参见“另请参见”。 脉冲时序图 下图显示了指令“分配关断延时定时器参数并启动”的脉冲时序图:如果操作数“TagIn_1”的信号状态从“1”变为“0”,将启动“Timer_1”定时器。定时器在等于操作 数“TagIn_Number”的定时器值时结束计时。定时器计时期间如果操作数“TagIn_1”的信号状 态为“0”,则操作数“TagOut”将被置位为“1”。如果定时器计时期间操作数“TagIn_1”的信号状 态从“0”变为“1”,定时器将被复位。启动脉冲定时器 (S7-300, S7-400) 说明 逻辑运算结果 (RLO) 中检测到信号从“0”到“1”的变化(信号上升沿)时,“启动脉冲定时器” 指令将启动已设定的定时器。只要 RLO 的信号状态为“1”,定时器便会运行指定的一段时间。 只要定时器正在运行,对定时器状态是否为“1”的查询将返回信号状态“1”。在该定时器值计 时结束前,如果 RLO 中的信号状态从“1”变为“0”,则定时器将停止。在这种情况下,查询定 时器状态是否为“1”时会返回信号状态“0”。 持续时间在内部由定时器值和时基构成。指令启动后,预设时间值开始递减计数,直至为零。 时基表示定时器值更改的时间段。“启动脉冲定时器”指令需要前导逻辑运算进行边沿评估,且只能放在程序段的右侧。 说明 在时间单元,操作系统通过时基指定的间隔,以一个时间单位缩短时间值,直到该值为“0”。 递减操作与用户程序不同步执行。因此,定时器中的值比预期的时基Zui多短一个时间间隔值。 以下给出了如何构造时间单元的一个示例:另请参见“L:加载定时器值”。 参数 下表列出了“启动脉冲定时器”指令的参数: 参数 声明 数据类型 存储区 说明 <持续时间> Input S5TIME、WORD I、Q、M、D、L 或常数 定时器计时结束的持续时 间。 <定时器> Output TIMER T 已启动的定时器。 定时器的数量取决于 CPU。 有关有效数据类型的更多信息,请参见“另请参见”。操作数“TagIn_1”的信号状态从“0”变为“1”时,“Timer_1”启动。只要操作数“TagIn_1”的信号状 态为“1”,定时器就运行操作数“TagIn_Number”预设的时间值。如果在定时器计时结束前操 作数“TagIn_1”的信号状态从“1”变为“0”,则定时器将停止。只要定时器正在运行,输出 “TagOut”的信号状态就为“1”。操作数“TagIn_2”的信号状态从“0”变为“1”时会复位定时器,这 会使定时器停止并将当前定时器值置位为“0”。 下图为本示例的时序图:启动扩展脉冲定时器 (S7-300, S7-400) 说明 当逻辑运算结果 (RLO) 中检测到信号从“0”到“1”的变化(信号上升沿)时,“启动扩展脉冲 定时器”指令将启动已设定的定时器。即使 RLO 的信号状态为“0”,定时器也运行预设的时 间段。只要定时器正在运行,对定时器状态是否为“1”的查询将返回信号状态“1”。如果定时 器在运行时 RLO 从“0”变为“1”,定时器将按预设的时间段重新启动。定时器计时结束时,查 询定时器状态是否为“1”时会返回信号状态“0”。 持续时间在内部由定时器值和时基构成。指令启动后,预设时间值开始递减计数,直至为零。 时基表示定时器值更改的时间段。 “启动扩展脉冲定时器”指令需要前导逻辑运算进行边沿评估,且只能放在程序段的右侧。 说明 在时间单元,操作系统通过时基指定的间隔,以一个时间单位缩短时间值,直到该值为“0”。 递减操作与用户程序不同步执行。因此,定时器中的值比预期的时基Zui多短一个时间间隔值。 此处给出了如何构造时间单元的示例:L:加载定时器值操作数“TagIn_1”的信号状态从“0”变为“1”时,“Timer_1”启动。定时器在等于操作数 “TagIn_Number”的定时器值时结束计时,不受 RLO 中信号下降沿的影响。只要定时器正在 运行,输出“TagOut”的信号状态就为“1”。如果在定时器计时结束前操作数“TagIn_1”的信号 状态再次从“0”变为“1”,则定时器将重启。启动接通延时定时器 (S7-300, S7-400) 说明 当在启动输入处检测到信号状态“1”时,“启动接通延时定时器”指令将启动一个编程的定 时器。只要该信号状态保持为“1”,定时器将在超出指定的持续时间后结束计时。如果定时 器计时结束且启动输入的信号状态仍为“1”,则定时器状态的查询将返回“1”。如果启动输入 处的信号状态为“0”,则将复位定时器。此时,查询定时器状态将返回信号状态“0”。只要启 动输入的信号状态再次变为“1”,定时器将再次运行。 定时器输出的信号状态与启动输入的信号状态相同。启动输入与输出直接互连,而非连接连 接定时器。 持续时间由定时器值和时基构成,且在参数 TV 处设定。该指令启动后,预设定时器值开始 递减计数,直至为零。 说明 在时间单元,操作系统通过时基指定的间隔,以一个时间单位缩短时间值,直到该值为“0”。 递减操作与用户程序不同步执行。因此,定时器中的值比预期的时基Zui多短一个时间间隔值。 此处给出了如何构造时间单元的示例:L:加载定时器值参数 下表列出了指令“启动接通延时定时器”的参数: 参数 声明 数据类型 存储区 说明 <持续时间> Input S5TIME、WORD I、Q、M、D、L 或常数 定时器计时结束的持续时 间。 <定时器> Output TIMER T 已启动的定时器。 定时器的数量取决于 CPU。 有关有效数据类型的更多信息,请参见“另请参见”。程序段 1: 操作数“#Timer_1”的信号状态从“0”变为“1”时,“#TagIn_1”启动。并根据操作数 “#TagIn_Number”的值结束计时。如果在定时器计时结束前操作数“#TagIn_1”的信号状态从 “1”变为“0”,则定时器将复位。 程序段 2: 当定时器计时结束后,启动输入的操作数 #TagIn_1 的信号状态为“1”且定时器未复位,操作 数 #TagOut 为“1”。 程序段 3: 如果操作数 #TagIn_2 的信号状态为“1”,将复位定时器 #Timer_1 和输出 #TagOut。 如需重启 #Timer_1,操作数 #TagIn_2 的信号状态必须为“0”,启动输入 #TagIn_1 的信号状 态必须从“0”变为“1”。