Built with Alectryon, running Coq+SerAPI v8.19.0+0.19.0. Bubbles () indicate interactive fragments: hover for details, tap to reveal contents. Use Ctrl+↑ Ctrl+↓ to navigate, Ctrl+🖱️ to focus. On Mac, use instead of Ctrl.
[Loading ML file ssrmatching_plugin.cmxs (using legacy method) ... done]
[Loading ML file ssreflect_plugin.cmxs (using legacy method) ... done]
[Loading ML file ring_plugin.cmxs (using legacy method) ... done]
[Loading ML file coq-elpi.elpi ... done]
[Loading ML file zify_plugin.cmxs (using legacy method) ... done]
[Loading ML file micromega_plugin.cmxs (using legacy method) ... done]
[Loading ML file btauto_plugin.cmxs (using legacy method) ... done]
[Loading ML file paramcoq.cmxs (using legacy method) ... done]
Notation "_ + _" was already used in scope nat_scope. [notation-overridden,parsing,default]
Notation "_ - _" was already used in scope nat_scope. [notation-overridden,parsing,default]
Notation "_ <= _" was already used in scope nat_scope. [notation-overridden,parsing,default]
Notation "_ < _" was already used in scope nat_scope. [notation-overridden,parsing,default]
Notation "_ >= _" was already used in scope nat_scope. [notation-overridden,parsing,default]
Notation "_ > _" was already used in scope nat_scope. [notation-overridden,parsing,default]
Notation "_ <= _ <= _" was already used in scope nat_scope. [notation-overridden,parsing,default]
Notation "_ < _ <= _" was already used in scope nat_scope. [notation-overridden,parsing,default]
Notation "_ <= _ < _" was already used in scope nat_scope. [notation-overridden,parsing,default]
Notation "_ < _ < _" was already used in scope nat_scope. [notation-overridden,parsing,default]
Notation "_ * _" was already used in scope nat_scope. [notation-overridden,parsing,default]
(** In this section, we prove some properties that every valid arrival curve prefix entails. *) Section ValidArrivalCurvePrefixFacts. (** Consider a task set with valid arrivals [ts], ... *) Variable ts : seq Task. Hypothesis H_valid_task_set : task_set_with_valid_arrivals ts. (** ... and a task [tsk] belonging to [ts] with positive cost and non-zero arrival bound. *) Variable tsk : Task. Hypothesis H_positive_cost : 0 < task_cost tsk. Hypothesis H_tsk_in_ts : tsk \in ts. Hypothesis H_positive_step : fst (head (0,0) (steps_of (get_arrival_curve_prefix tsk))) > 0. (** First, we show that the arrival curve prefix of [tsk] is valid. *)
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1

has_valid_arrival_curve_prefix tsk
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1

has_valid_arrival_curve_prefix tsk
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
VALID: match task_arrival tsk with | Periodic p => 0 < p | Sporadic m => 0 < m | ArrivalPrefix emax_vec => valid_arrival_curve_prefix_dec emax_vec end

has_valid_arrival_curve_prefix tsk
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
VALID: match task_arrival tsk with | Periodic p => 0 < p | Sporadic m => 0 < m | ArrivalPrefix emax_vec => valid_arrival_curve_prefix_dec emax_vec end
p: nat
EQ: task_arrival tsk = Periodic p

has_valid_arrival_curve_prefix tsk
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
VALID: match task_arrival tsk with | Periodic p => 0 < p | Sporadic m => 0 < m | ArrivalPrefix emax_vec => valid_arrival_curve_prefix_dec emax_vec end
m: nat
EQ: task_arrival tsk = Sporadic m
has_valid_arrival_curve_prefix tsk
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
VALID: match task_arrival tsk with | Periodic p => 0 < p | Sporadic m => 0 < m | ArrivalPrefix emax_vec => valid_arrival_curve_prefix_dec emax_vec end
evec: ArrivalCurvePrefix
EQ: task_arrival tsk = ArrivalPrefix evec
has_valid_arrival_curve_prefix tsk
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
VALID: match task_arrival tsk with | Periodic p => 0 < p | Sporadic m => 0 < m | ArrivalPrefix emax_vec => valid_arrival_curve_prefix_dec emax_vec end
p: nat
EQ: task_arrival tsk = Periodic p

exists ac_prefix_vec : ArrivalCurvePrefix, inter_arrival_to_prefix p = ac_prefix_vec /\ valid_arrival_curve_prefix ac_prefix_vec
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
VALID: match task_arrival tsk with | Periodic p => 0 < p | Sporadic m => 0 < m | ArrivalPrefix emax_vec => valid_arrival_curve_prefix_dec emax_vec end
m: nat
EQ: task_arrival tsk = Sporadic m
exists ac_prefix_vec : ArrivalCurvePrefix, inter_arrival_to_prefix m = ac_prefix_vec /\ valid_arrival_curve_prefix ac_prefix_vec
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
VALID: match task_arrival tsk with | Periodic p => 0 < p | Sporadic m => 0 < m | ArrivalPrefix emax_vec => valid_arrival_curve_prefix_dec emax_vec end
evec: ArrivalCurvePrefix
EQ: task_arrival tsk = ArrivalPrefix evec
exists ac_prefix_vec : ArrivalCurvePrefix, evec = ac_prefix_vec /\ valid_arrival_curve_prefix ac_prefix_vec
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
p: nat
EQ: task_arrival tsk = Periodic p
VALID: 0 < p

exists ac_prefix_vec : ArrivalCurvePrefix, inter_arrival_to_prefix p = ac_prefix_vec /\ valid_arrival_curve_prefix ac_prefix_vec
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
m: nat
EQ: task_arrival tsk = Sporadic m
VALID: 0 < m
exists ac_prefix_vec : ArrivalCurvePrefix, inter_arrival_to_prefix m = ac_prefix_vec /\ valid_arrival_curve_prefix ac_prefix_vec
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
evec: ArrivalCurvePrefix
EQ: task_arrival tsk = ArrivalPrefix evec
VALID: valid_arrival_curve_prefix_dec evec
exists ac_prefix_vec : ArrivalCurvePrefix, evec = ac_prefix_vec /\ valid_arrival_curve_prefix ac_prefix_vec
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
p: nat
EQ: task_arrival tsk = Periodic p
VALID: 0 < p

exists ac_prefix_vec : ArrivalCurvePrefix, inter_arrival_to_prefix p = ac_prefix_vec /\ valid_arrival_curve_prefix ac_prefix_vec
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
p: nat
EQ: task_arrival tsk = Periodic p
VALID: 0 < p

inter_arrival_to_prefix p = inter_arrival_to_prefix p /\ valid_arrival_curve_prefix (inter_arrival_to_prefix p)
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
p: nat
EQ: task_arrival tsk = Periodic p
VALID: 0 < p

large_horizon (inter_arrival_to_prefix p)
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
p: nat
EQ: task_arrival tsk = Periodic p
VALID: 0 < p
s: Datatypes_nat__canonical__eqtype_Equality

s \in time_steps_of (inter_arrival_to_prefix p) -> s <= horizon_of (inter_arrival_to_prefix p)
by rewrite /large_horizon in_cons => /orP [|] /eqP.
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
m: nat
EQ: task_arrival tsk = Sporadic m
VALID: 0 < m

exists ac_prefix_vec : ArrivalCurvePrefix, inter_arrival_to_prefix m = ac_prefix_vec /\ valid_arrival_curve_prefix ac_prefix_vec
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
evec: ArrivalCurvePrefix
EQ: task_arrival tsk = ArrivalPrefix evec
VALID: valid_arrival_curve_prefix_dec evec
exists ac_prefix_vec : ArrivalCurvePrefix, evec = ac_prefix_vec /\ valid_arrival_curve_prefix ac_prefix_vec
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
m: nat
EQ: task_arrival tsk = Sporadic m
VALID: 0 < m

exists ac_prefix_vec : ArrivalCurvePrefix, inter_arrival_to_prefix m = ac_prefix_vec /\ valid_arrival_curve_prefix ac_prefix_vec
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
m: nat
EQ: task_arrival tsk = Sporadic m
VALID: 0 < m

inter_arrival_to_prefix m = inter_arrival_to_prefix m /\ valid_arrival_curve_prefix (inter_arrival_to_prefix m)
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
m: nat
EQ: task_arrival tsk = Sporadic m
VALID: 0 < m

large_horizon (inter_arrival_to_prefix m)
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
m: nat
EQ: task_arrival tsk = Sporadic m
VALID: 0 < m
s: Datatypes_nat__canonical__eqtype_Equality

s \in time_steps_of (inter_arrival_to_prefix m) -> s <= horizon_of (inter_arrival_to_prefix m)
by rewrite /large_horizon in_cons => /orP [|] /eqP.
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
evec: ArrivalCurvePrefix
EQ: task_arrival tsk = ArrivalPrefix evec
VALID: valid_arrival_curve_prefix_dec evec

exists ac_prefix_vec : ArrivalCurvePrefix, evec = ac_prefix_vec /\ valid_arrival_curve_prefix ac_prefix_vec
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
evec: ArrivalCurvePrefix
EQ: task_arrival tsk = ArrivalPrefix evec
VALID: valid_arrival_curve_prefix_dec evec

exists ac_prefix_vec : ArrivalCurvePrefix, evec = ac_prefix_vec /\ valid_arrival_curve_prefix ac_prefix_vec
by exists evec; split => //; apply /valid_arrival_curve_prefix_P. } Qed. (** Next, we show that each time step of the arrival curve prefix must be positive. *)
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1

forall st : Datatypes_nat__canonical__eqtype_Equality, st \in get_time_steps_of_task tsk -> 0 < st
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1

forall st : Datatypes_nat__canonical__eqtype_Equality, st \in get_time_steps_of_task tsk -> 0 < st
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
st: Datatypes_nat__canonical__eqtype_Equality
IN: st \in time_steps_of (get_arrival_curve_prefix tsk)

0 < st
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
st: Datatypes_nat__canonical__eqtype_Equality
IN: st \in time_steps_of (get_arrival_curve_prefix tsk)
VAL: valid_arrivals tsk

0 < st
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of match task_arrival tsk with | Periodic p => inter_arrival_to_prefix p | Sporadic m => inter_arrival_to_prefix m | ArrivalPrefix steps => steps end)).1
st: Datatypes_nat__canonical__eqtype_Equality
IN: st \in time_steps_of match task_arrival tsk with | Periodic p => inter_arrival_to_prefix p | Sporadic m => inter_arrival_to_prefix m | ArrivalPrefix steps => steps end
VAL: match task_arrival tsk with | Periodic p => 0 < p | Sporadic m => 0 < m | ArrivalPrefix emax_vec => valid_arrival_curve_prefix_dec emax_vec end

0 < st
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
a: nat
H_positive_step: 0 < (head (0, 0) (steps_of (inter_arrival_to_prefix a))).1
st: Datatypes_nat__canonical__eqtype_Equality
IN: st \in time_steps_of (inter_arrival_to_prefix a)
VAL: 0 < a

0 < st
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
a: nat
H_positive_step: 0 < (head (0, 0) (steps_of (inter_arrival_to_prefix a))).1
st: Datatypes_nat__canonical__eqtype_Equality
IN: st \in time_steps_of (inter_arrival_to_prefix a)
VAL: 0 < a
0 < st
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
a: ArrivalCurvePrefix
H_positive_step: 0 < (head (0, 0) (steps_of a)).1
st: Datatypes_nat__canonical__eqtype_Equality
IN: st \in time_steps_of a
VAL: valid_arrival_curve_prefix_dec a
0 < st
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
a: nat
H_positive_step: 0 < (head (0, 0) (steps_of (inter_arrival_to_prefix a))).1
st: Datatypes_nat__canonical__eqtype_Equality
IN: st \in time_steps_of (inter_arrival_to_prefix a)
VAL: 0 < a

0 < st
by unfold inter_arrival_to_prefix, time_steps_of in *; simpl in IN; move: IN; rewrite mem_seq1 => /eqP EQ; subst.
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
a: nat
H_positive_step: 0 < (head (0, 0) (steps_of (inter_arrival_to_prefix a))).1
st: Datatypes_nat__canonical__eqtype_Equality
IN: st \in time_steps_of (inter_arrival_to_prefix a)
VAL: 0 < a

0 < st
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
a: ArrivalCurvePrefix
H_positive_step: 0 < (head (0, 0) (steps_of a)).1
st: Datatypes_nat__canonical__eqtype_Equality
IN: st \in time_steps_of a
VAL: valid_arrival_curve_prefix_dec a
0 < st
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
a: nat
H_positive_step: 0 < (head (0, 0) (steps_of (inter_arrival_to_prefix a))).1
st: Datatypes_nat__canonical__eqtype_Equality
IN: st \in time_steps_of (inter_arrival_to_prefix a)
VAL: 0 < a

0 < st
by unfold inter_arrival_to_prefix, time_steps_of in *; simpl in IN; move: IN; rewrite mem_seq1 => /eqP EQ; subst.
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
a: ArrivalCurvePrefix
H_positive_step: 0 < (head (0, 0) (steps_of a)).1
st: Datatypes_nat__canonical__eqtype_Equality
IN: st \in time_steps_of a
VAL: valid_arrival_curve_prefix_dec a

0 < st
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
a: ArrivalCurvePrefix
H_positive_step: 0 < (head (0, 0) (steps_of a)).1
st: Datatypes_nat__canonical__eqtype_Equality
IN: st \in time_steps_of a
VAL: valid_arrival_curve_prefix_dec a

0 < st
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
h: duration
st0: (duration * nat)%type
sts: seq (duration * nat)
H_positive_step: 0 < (head (0, 0) (steps_of (h, st0 :: sts))).1
st: Datatypes_nat__canonical__eqtype_Equality
IN: st \in time_steps_of (h, st0 :: sts)
VAL: valid_arrival_curve_prefix_dec (h, st0 :: sts)

0 < st
ts: seq concrete_task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: concrete_task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
h: duration
st0: (duration * nat)%type
sts: seq (duration * nat)
H_positive_step: 0 < st0.1
VAL: valid_arrival_curve_prefix_dec (h, st0 :: sts)
t, v: nat
IN: (t, v) \in st0 :: sts

0 < t
ts: seq concrete_task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: concrete_task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
h: duration
st0: (duration * nat)%type
sts: seq (duration * nat)
H_positive_step: 0 < st0.1
VAL: valid_arrival_curve_prefix_dec (h, st0 :: sts)
t, v: nat
IN: (t, v) \in sts

0 < t
ts: seq concrete_task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: concrete_task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
h: duration
st0: (duration * nat)%type
sts: seq (duration * nat)
H_positive_step: 0 < st0.1
t, v: nat
IN: (t, v) \in sts
VAL: valid_arrival_curve_prefix (h, st0 :: sts)

0 < t
ts: seq concrete_task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: concrete_task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
h: duration
st0: (duration * nat)%type
sts: seq (duration * nat)
H_positive_step: 0 < st0.1
t, v: nat
IN: (t, v) \in sts
SORT: sorted_ltn_steps (h, st0 :: sts)

0 < t
ts: seq concrete_task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: concrete_task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
h: duration
st0: (duration * nat)%type
sts: seq (duration * nat)
H_positive_step: 0 < st0.1
t, v: nat
IN: (t, v) \in sts
SORT: path ltn_steps st0 sts

0 < t
ts: seq concrete_task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: concrete_task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
h: duration
st0: (duration * nat)%type
sts: seq (duration * nat)
H_positive_step: 0 < st0.1
t, v: nat
IN: (t, v) \in sts
SORT: all (ltn_steps st0) sts && sorted ltn_steps sts

0 < t
ts: seq concrete_task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: concrete_task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
h: duration
st0: (duration * nat)%type
sts: seq (duration * nat)
H_positive_step: 0 < st0.1
t, v: nat
IN: (t, v) \in sts
{in predT & &, transitive (T:=nat * nat) ltn_steps}
ts: seq concrete_task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: concrete_task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
h: duration
st0: (duration * nat)%type
sts: seq (duration * nat)
H_positive_step: 0 < st0.1
t, v: nat
IN: (t, v) \in sts
SORT: all (ltn_steps st0) sts && sorted ltn_steps sts

0 < t
ts: seq concrete_task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: concrete_task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
h: duration
st0: (duration * nat)%type
sts: seq (duration * nat)
H_positive_step: 0 < st0.1
t, v: nat
IN: (t, v) \in sts
ALL: {in sts, forall x : Datatypes_prod__canonical__eqtype_Equality Datatypes_nat__canonical__eqtype_Equality Datatypes_nat__canonical__eqtype_Equality, ltn_steps st0 x}

0 < t
ts: seq concrete_task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: concrete_task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
h: duration
st0: (duration * nat)%type
sts: seq (duration * nat)
H_positive_step: 0 < st0.1
t, v: nat
IN: (t, v) \in sts

ltn_steps st0 (t, v) -> 0 < t
ts: seq concrete_task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: concrete_task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
h, d: duration
n: nat
sts: seq (duration * nat)
H_positive_step: 0 < d
t, v: nat
IN: (t, v) \in sts

ltn_steps (d, n) (t, v) -> 0 < t
by move => /andP //= => [[LT1 LT2]]; lia.
ts: seq concrete_task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: concrete_task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
h: duration
st0: (duration * nat)%type
sts: seq (duration * nat)
H_positive_step: 0 < st0.1
t, v: nat
IN: (t, v) \in sts

{in predT & &, transitive (T:=nat * nat) ltn_steps}
by intros ? ? ? _ _ _; apply ltn_steps_is_transitive. } Qed. (** Next, we show that even shifting the time steps by a positive offset, they remain positive. *)
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1

forall (A : Datatypes_nat__canonical__eqtype_Equality) (offs : seq nat), A \in repeat_steps_with_offset tsk offs -> 0 < A
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1

forall (A : Datatypes_nat__canonical__eqtype_Equality) (offs : seq nat), A \in repeat_steps_with_offset tsk offs -> 0 < A
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
A: Datatypes_nat__canonical__eqtype_Equality
offs: seq nat
IN: A \in repeat_steps_with_offset tsk offs

0 < A
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
A: Datatypes_nat__canonical__eqtype_Equality
offs: seq nat
o: Datatypes_nat__canonical__eqtype_Equality
INo: o \in offs
IN: A \in time_steps_with_offset tsk o

0 < A
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
offs: seq nat
o: Datatypes_nat__canonical__eqtype_Equality
INo: o \in offs
st: Datatypes_nat__canonical__eqtype_Equality
IN: st \in get_time_steps_of_task tsk

0 < st + o
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
offs: seq nat
o: Datatypes_nat__canonical__eqtype_Equality
INo: o \in offs
st: Datatypes_nat__canonical__eqtype_Equality
IN: st \in get_time_steps_of_task tsk

0 < st
by apply steps_are_positive_if_first_step_is_positive. Qed. (** Finally, we show that the time steps are strictly increasing. *)
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1

sorted ltn (get_time_steps_of_task tsk)
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1

sorted ltn (get_time_steps_of_task tsk)
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
VALID: task_set_with_valid_arrivals ts

sorted ltn (time_steps_of (get_arrival_curve_prefix tsk))
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
VALID: task_set_with_valid_arrivals ts
arrival_curve_prefix: ArrivalCurvePrefix
EQ: get_arrival_curve_prefix tsk = arrival_curve_prefix
POSh: positive_horizon arrival_curve_prefix
LARGEh: large_horizon arrival_curve_prefix
NOINF: no_inf_arrivals arrival_curve_prefix
BUR: specified_bursts arrival_curve_prefix
SORT: sorted_ltn_steps arrival_curve_prefix

sorted ltn (time_steps_of (get_arrival_curve_prefix tsk))
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
VALID: task_set_with_valid_arrivals ts
arrival_curve_prefix: ArrivalCurvePrefix
EQ: get_arrival_curve_prefix tsk = arrival_curve_prefix
POSh: positive_horizon arrival_curve_prefix
LARGEh: large_horizon arrival_curve_prefix
NOINF: no_inf_arrivals arrival_curve_prefix
BUR: specified_bursts arrival_curve_prefix
SORT: sorted_ltn_steps arrival_curve_prefix

sorted ltn (time_steps_of arrival_curve_prefix)
eapply (homo_sorted _ _ SORT).
ts: seq Task
H_valid_task_set: task_set_with_valid_arrivals ts
tsk: Task
H_positive_cost: 0 < task_cost tsk
H_tsk_in_ts: tsk \in ts
H_positive_step: 0 < (head (0, 0) (steps_of (get_arrival_curve_prefix tsk))).1
VALID: task_set_with_valid_arrivals ts
arrival_curve_prefix: ArrivalCurvePrefix
EQ: get_arrival_curve_prefix tsk = arrival_curve_prefix
POSh: positive_horizon arrival_curve_prefix
LARGEh: large_horizon arrival_curve_prefix
NOINF: no_inf_arrivals arrival_curve_prefix
BUR: specified_bursts arrival_curve_prefix
SORT: sorted_ltn_steps arrival_curve_prefix

{homo fst : x y / ltn_steps x y >-> ltn x y}
by move => x y; rewrite /ltn_steps => /andP[LT _]. Qed. End ValidArrivalCurvePrefixFacts.