redes petri temporizada - modcs.org · tempo em redes de petri breve histórico: ranchandani, 1973...

135
Extensões Temporizadas de Redes de Petri Prof. Eduardo Tavares Prof. Paulo Maciel Centro de Informática (UFPE) Disciplina: Modelos de Sistemas Comunicantes

Upload: lamdang

Post on 23-Jan-2019

222 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Extensões Temporizadas de Redes de Petri

Prof. Eduardo TavaresProf. Paulo Maciel

Centro de Informática (UFPE)

Disciplina: Modelos de Sistemas Comunicantes

Page 2: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Tempo

Várias definiçõesTempo em sistemas computacionais (Interpretações)

• Tempo Lógico: definido a partir de relações de precedência entre eventos. Estabelece ordens causais entre conjunto de eventos.

• Tempo Físico: tempo métrico que expressa quantitativamente a distância entre eventos. Estabelece também as ordens totais entre eventos

• Tempo Contínuo: segue a natureza uniforme e contínua do tempo físico e é isomorfo a ℜ

• Tempo Discreto: simplificação do tempo contínuo e isomorfo a ℵ

Farine e et al. Sistemas de Tempo Real. 2000

Page 3: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Tempo

• Tempo Global: Referência temporal única para os componentes do sistema

• Tempo Local: Cada componente do sistema possui sua própria referência temporal

Farine e et al. Sistemas de Tempo Real. 2000

Qual a motivação da adoção de tempo nos modelos de sistemas comunicantes?

Page 4: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Avaliação de Desempenho

Measuring�Medição�Benchmark�Prototipação

Modelagem�Modelos de Simulação�Modelos Analíticos

Page 5: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Avaliação de Desempenho

Modelagem�Modelos Analíticos

�Determinísticos• Avaliação de pior (melhor) caso

�Probablísticos• Valores médios prováveis• Valores médios prováveis

�Simulação�Análise Exaustiva

Implementação real�Medidas obtidas do sistema real�Benchmark�Protótipos

Page 6: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Modelos Temporizados

Diversos modelos propostos. Alguns representativos(Probabilísticos e Deterministícos):

– Lógicas Temporais (Ex: Linear Time Temporal Logic)– Autômatos temporizados– Álgebra de processos temporizadas (ex: Timed CSP)– Redes de Fila– Cadeias de Markov– Redes de Petri Temporizada (Ex: TPN)

Importância dos tempos físicos em sistemas críticos

Foco será nos modelos determinísticos

Page 7: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Modelos Temporizados

Os modelos, que possibilitam a especificação do tempo físico, podem representar os tempos de formas distintas:

� Intervalo� Intervalo� De forma determinística� Forma probabilística (não é considerado nesta

disciplina). Distribuição exponencial geralmente adotada.

Page 8: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Tempo em Redes de Petri

Redes de Petri(Extensões

Temporizadas

Timed Places

Timed Transitions

Timed ArcsTimed Tokens

Stochastic PN

Time PN Timed PN

Page 9: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Tempo em Redes de Petri

Breve Histórico:� Ranchandani, 1973 – Transition Timed Net� Merling, 1976 – Transition Time Net� Sifakis, 1977 – Place Timed Net

Extensões estocástica (Delay é uma variável aleatória de distribuição exponencial)Natkin, 1980Moloy, 1981Marsan et al., 1984

Page 10: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Lugares Temporizados

Tempo associados com lugares

Tokens ficam disponíveis nos lugares de saída após a passagem de um tempo especificado

Classificação dos tokens: disponíveis e indisponíveis

Tokens disponíveis habilitam transições

Conceito de Holding Durations

Page 11: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Lugares Temporizados

P1

P3 P4T1 T2

time=0

P2

τ =1 τ =4

Page 12: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Lugares Temporizados

P1

P3 P4T1 T2

0<=time<1

τ =1 τ =4

P2

Page 13: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Lugares Temporizados

P1

P3 P4T1 T2

time=1

τ =1 τ =4

P2

Page 14: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Lugares Temporizados

P1

P3 P4T1 T2

1<=time<5

τ =1 τ =4

P2

Page 15: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Lugares Temporizados

P1

P3 P4T1 T2

time = 5

τ =1 τ =4

P2

Page 16: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Lugares Temporizados

Page 17: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Tokens temporizados

Tempo associado com os tokens

Token guarda timestamp (indica quando uma transição pode ser disparada)

Timestamp pode ser incrementado ao disparo de uma transição

Page 18: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Arcos temporizados

Tempo associado com os arcos

Travelling delay é associado aos arcos

Tokens ficam indisponíveis até alcançar a transiçãoTokens ficam indisponíveis até alcançar a transição

Page 19: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Transições Temporizadas

Extensão mais comum

Tempo associado com transições. Representação natural.� Início da atividade com a habilitação da transição� Término da atividade com o disparo da transição� Término da atividade com o disparo da transição

O delay pode ser um valor constante ou intervalo

Page 20: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Transições Temporizadas (Conceitos Básicos)

Políticas de disparo� Duração (Disparo em três fases)

� Tokens (marcas) são consumidas dos lugares de entrada

� Há uma duração� Há uma duração� Tokens são gerados nos lugares de saída

� Disparo atômico� As marcas permanecem nos lugares de entrada

pelo período igual ao delay associado à transíção� Após o delay, as marcas consumidas são

imediatamente geradas nos lugares de saída

Page 21: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Transições Temporizadas (Conceitos Básicos)

Políticas de disparo� Duração (Disparo em três fases)

� O estado é uma informação mais complexa do que o modelo não temporizado

� Disparo atômico� O conjunto de marcações alcançáveis é um

subconjunto das marcações do modelo sem temporização

� Pode representar um modelo com duração

Page 22: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Transições Temporizadas (Conceitos Básicos)

Regras de Seleção� Pré-seleção: (duração e delay)

� Prioridade� Probabilidade

P1P2T1,τ1

T2,τ2

� Race(Corrida): (delay)� Transições com menor delay são disparadas

P3T2,τ2

Page 23: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Transições Temporizadas (Conceitos Básicos)

Quando uma das transiçõesconflitantes é desabilitada pelo disparoconflitantes é desabilitada pelo disparoda outra, o que acontece com o timer

daquela que ficou desabilitada?

Page 24: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Transições Temporizadas (Conceitos Básicos)

Como fica a memorizaçãodo tempo de habilitaçãoanterior ?

Mecanismos Básicos de Memória

P1P2T1,τ1

T2,τ2Mecanismos Básicos de Memória� Continue: O timer da transição mantém o valor atual

e quando a transição se tornar novamente habilitada o valor do timer iniciará naquele valor

� Restart: Quando a transição for novamente habilitada o timer será reiniciado

P3T2,τ2

Page 25: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Transições Temporizadas (Conceitos Básicos)

O que acontece com o timer das transições habilitadas após o disparode uma transição? (Para todas astransições, não somente as conflitantes)

Políticas de memória� Resampling

� Em todos os disparos de transições, os timers de todas as transições são descartadas (restart)

� Nenhum histórico do passado é mantido� Na nova marcação, um novo valor para o timer é

associado para cada transição habilitada

Page 26: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Transições Temporizadas (Conceitos Básicos)

Políticas de memória� Enabling Memory

� A cada disparo de uma transição, os timers das transições desabilitadas na nova marcação são descartados (restart)descartados (restart)

� O valor dos timers de todas transições que continuam habilitadas na nova marcação são mantidas (continue)

Page 27: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Transições Temporizadas (Conceitos Básicos)

Políticas de memória� Age Memory

� Após cada disparo de uma transição, os timersmantém seus respectivos valores (continue), tanto para as transições habilitadas e desabilitadas na para as transições habilitadas e desabilitadas na nova marcação

Page 28: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Transições Temporizadas (Conceitos Básicos)

Semântica de Temporização

Qual procedimento deve-se realizar quando o grau de habilitação de uma transição é maior que 1?

� Single-server firing semantics� Infinite-server firing semantics� Multiple-server firing semantics

P1

P2

T1,τ1

Page 29: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Transições Temporizadas (Conceitos Básicos)

� Single-server firing semantics

P1

P2

T1,τ1

Page 30: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Transições Temporizadas (Conceitos Básicos)

� Infinite-server firing semantics

P1

P2

T1,τ1

Page 31: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Transições Temporizadas (Conceitos Básicos)

� Multiple-server firing semanticsK = Grau máximo de paralelismo. Assuma K=2.

P1

Se K=∞, então igual a infinite-server firing semantics

P2

T1,τ1

Page 32: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Transições Temporizadas (Conceitos Básicos)

� Multiple-server firing semanticsK = Grau máximo de paralelismo. Assuma K=2.

P1

Se K=∞, então igual a infinite-server firing semantics

P2

T1,τ1

Page 33: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Leitura

L. Motus. Time Concepts in Real-Time Software. ControlEngineering Practice, 1993.

F. D. J. Bowden. A Brief Survey and Synthesis of theRoles of Time in Petri Nets. Mathematical andRoles of Time in Petri Nets. Mathematical andComputter Modelling, 2000.

G. Balbo. Introduction to Stochastic Petri Nets. Formal Methods on Performance Evaluation, 2001.

Seção: Time in Petri Nets.

Page 34: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Time Petri Nets

Definição de Tavares09 e Barreto05 baseada em Merling76

Restrições temporais associado às transições (intervalo). Assume-se tempo discreto

Transições habilitadas – enabled (marcação) e disparáveis – firable (marcação e tempo)

Política Enabling Memory

Singler-server semantics e Strong Firing Mode

Page 35: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Time Petri Nets

Page 36: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Time Petri Nets

Vetor de clocks c ∈∈∈∈ (ℵ ∪ {#})|T|

Dynamic Firing Interval: ID(t) = (DLB(t),DUB(t))• DLB(t) = max(0,EFT(t)-c(t))• DUB(t) = LFT(t) – c(t)

Atenção Strong Firing Mode!

Inicialmente, I(t)= ID(t)

Page 37: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Time Petri Nets

Page 38: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Time Petri Nets

Page 39: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Time Petri Nets

p0

t0[0,0]

p1p2

t1[1,4]

t2[2,3]

2 t3[0,0]

p3

p4

Page 40: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Time Petri Nets

p0

t0[0,0]

p1p2

FT(s0)={t0}cs0 (t0)=0

IDs0 (t0)=[0,0]FDs0(t0)=[0,0]

s0m0={(p0,1),(p1,0),(p

2,0),(p3,0),(p4,0)}c0=[0 # # #]T

t1[1,4]

t2[2,3]

2 t3[0,0]

p3

p4

Page 41: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Time Petri Nets

p0

t0[0,0]

p1p2

ET (m1)={t1,t2}cs1 (t1)=0cs1 (t2)=0

I s (t1)=[1,4]

s0m0={(p0,1),(p1,0),(p

2,0),(p3,0),(p4,0)}c0=[0 # # #]T

s1

t0,0

t1[1,4]

t2[2,3]

2 t3[0,0]

p3

p4

IDs1 (t1)=[1,4]IDs1 (t2)=[2,3]

FDs1(t1)=[1,3]FDs1(t2)=[2,3]

s1m1={(p0,0),(p1,1),(p

2,1),(p3,0),(p4,0)}c1=[# 0 0 #]T

Page 42: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Time Petri Nets

p0

t0[0,0]

p1p2

ET(m1)={t1,t2}FT (s1)={t1}cs1 (t1)=1cs1 (t2)=1

s0m0={(p0,1),(p1,0),(p

2,0),(p3,0),(p4,0)}c0=[0 # # #]T

s1

t0,0

t1[1,4]

t2[2,3]

2 t3[0,0]

p3

p4

IDs1 (t1)=[0,3]IDs1 (t2)=[1,2]

FDs1(t1)=[1,3]FDs1(t2)=[2,3]

s1m1={(p0,0),(p1,1),(p

2,1),(p3,0),(p4,0)}c1=[# 0 0 #]T

Page 43: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Time Petri Nets

p0

t0[0,0]

p1p2

FT (s1)={t1,t2}cs1 (t1)=2cs1 (t2)=2

I s (t1)=[0,2]

s0m0={(p0,1),(p1,0),(p

2,0),(p3,0),(p4,0)}c0=[0 # # #]T

s1

t0,0

t1[1,4]

t2[2,3]

2 t3[0,0]

p3

p4

IDs1 (t1)=[0,2]IDs1 (t2)=[0,1]

FDs1(t1)=[1,3]FDs1(t2)=[2,3]

s1m1={(p0,0),(p1,1),(p

2,1),(p3,0),(p4,0)}c1=[# 0 0 #]T

Page 44: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Time Petri Nets

p0

t0[0,0]

p1p2

FTs7={t1}Cs7(t1)=2

IDs7 (t1)=[0,2]FDs7 (t1)=[0,2]

s0m0={(p0,1),(p1,0),(p

2,0),(p3,0),(p4,0)}c0=[0 # # #]T

s1

t0,0

t1[1,4]

t2[2,3]

2 t3[0,0]

p3

p4

s1m1={(p0,0),(p1,1),(p

2,1),(p3,0),(p4,0)}c1=[# 0 0 #]T

s7m1={(p0,0),(p1,1),(p

2,0),(p3,1),(p4,0)}c7=[# 2 # #]T

t2,2

Page 45: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Time Petri Nets

p0

t0[0,0]

p1p2

FTs3={t3}cs3(t3)=0

IDs3(t3)=[0,0]F s (t3)=[0,0]

s0m0={(p0,1),(p1,0),(p

2,0),(p3,0),(p4,0)}c0=[0 # # #]T

s1

t0,0

t1[1,4]

t2[2,3]

2 t3[0,0]

p3

p4

D 3FDs3(t3)=[0,0]

s1m1={(p0,0),(p1,1),(p

2,1),(p3,0),(p4,0)}c1=[# 0 0 #]T

s7m1={(p0,0),(p1,1),(p

2,0),(p3,1),(p4,0)}c7=[# 2 # #]T

t2,2

s3m1={(p0,0),(p1,0),(p

2,0),(p3,2),(p4,0)}c3=[# # # 0]T

t1,0

Page 46: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Time Petri Nets

p0

t0[0,0]

p1p2

s0m0={(p0,1),(p1,0),(p

2,0),(p3,0),(p4,0)}c0=[0 # # #]T

s1

t0,0

t1[1,4]

t2[2,3]

2 t3[0,0]

p3

p4

s1m1={(p0,0),(p1,1),(p

2,1),(p3,0),(p4,0)}c1=[# 0 0 #]T

s7m1={(p0,0),(p1,1),(p

2,0),(p3,1),(p4,0)}c7=[# 2 # #]T

t2,2

s4m1={(p0,0),(p1,0),(p

2,0),(p3,0),(p4,1)}c4=[# # # #]T

s3m1={(p0,0),(p1,0),(p

2,0),(p3,2),(p4,0)}c3=[# # # 0]T

t1,0

t3,0

Page 47: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Time Petri Nets

Page 48: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Time Petri Nets

p0

t0[2,3]

p1

t1[2,4]

t2[2,3]

p3

p2

Page 49: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Time Petri Nets

p0

t0[2,3]

p1

ET(s0)={t0}cs0 (t0)=0

IDs0 (t0)=[2,3]

FDs (t0)=[2,3]

s0m0={(p0,2),(p1,0),(p

2,0),(p3,0),(p4,0)}c0=[0 # # ]T

t1[2,4]

t2[2,3]

p3

FDs0(t0)=[2,3]

p2

Page 50: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Time Petri Nets

p0

t0[2,3]

p1

ET(s0)={t0}cs0 (t0)=1

IDs0 (t0)=[1,2]

FDs (t0)=[2,3]

s0m0={(p0,2),(p1,0),(p

2,0),(p3,0),(p4,0)}c0=[0 # # ]T

t1[2,4]

t2[2,3]

p3

FDs0(t0)=[2,3]

p2

Page 51: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Time Petri Nets

p0

t0[2,3]

p1

FT(s0)={t0}cs0 (t0)=2

IDs0 (t0)=[0,1]

FDs (t0)=[2,3]

s0m0={(p0,2),(p1,0),(p

2,0),(p3,0),(p4,0)}c0=[0 # # ]T

t1[2,4]

t2[2,3]

p3

FDs0(t0)=[2,3]

p2

Page 52: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Time Petri Nets

p0

t0[2,3]

p1

ET(s1)={t0,t2,t1}cs1 (t0)=0cs1 (t1)=0cs1 (t2)=0

I s (t0)=[2,3]

s0m0={(p0,2),(p1,0),(p

2,0),(p3,0),(p4,0)}c0=[0 # # ]T

s1m1={(p0,1),(p1,1),(p

t0,2

t1[2,4]

t2[2,3]

p3

IDs1 (t0)=[2,3]IDs1 (t1)=[2,4]IDs1 (t2)=[2,3]

FDs1(t0)=[2,3]FDs1(t1)=[2,3]FDs1(t2)=[2,3]

p2

m1={(p0,1),(p1,1),(p2,0),(p3,0)}c1=[0 0 0]T

Page 53: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Time Petri Nets

p0

t0[2,3]

p1

ET(s1)={t0,t2,t1}cs1 (t0)=1cs1 (t1)=1cs1 (t2)=1

I s (t0)=[1,2]

s0m0={(p0,2),(p1,0),(p

2,0),(p3,0),(p4,0)}c0=[0 # # ]T

s1m1={(p0,1),(p1,1),(p

t0,2

t1[2,4]

t2[2,3]

p3

IDs1 (t0)=[1,2]IDs1 (t1)=[1,3]IDs1 (t2)=[1,2]

FDs1(t0)=[2,3]FDs1(t1)=[2,3]FDs1(t2)=[2,3]

p2

m1={(p0,1),(p1,1),(p2,0),(p3,0)}c1=[0 0 0]T

Page 54: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Time Petri Nets

p0

t0[2,3]

p1

FT(s1)={t0,t2,t1}cs1 (t0)=2cs1 (t1)=2cs1 (t2)=2

I s (t0)=[0,1]

s0m0={(p0,2),(p1,0),(p

2,0),(p3,0),(p4,0)}c0=[0 # # ]T

s1m1={(p0,1),(p1,1),(p

t0,2

t1[2,4]

t2[2,3]

p3

IDs1 (t0)=[0,1]IDs1 (t1)=[0,2]IDs1 (t2)=[0,1]

FDs1(t0)=[2,3]FDs1(t1)=[2,3]FDs1(t2)=[2,3]

p2

m1={(p0,1),(p1,1),(p2,0),(p3,0)}c1=[0 0 0]T

Page 55: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Time Petri Nets

p0

t0[2,3]

p1

FT(s2)={t0}cs2(t0)=2

IDs2(t0)=[0,1]

FDs (t0)=[0,1]

s0

s1

s2

t1,2

t1[2,4]

t2[2,3]

p3

FDs2(t0)=[0,1]

p2

s2m2={(p0,1),(p1,0),(p

2,0),(p3,1)}c2=[2 # #]T

Page 56: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Time Petri Nets

p0

t0[2,3]

p1

FT(s3)={t0}cs3(t0)=2

IDs3(t0)=[0,1]

FDs (t0)=[0,1]

s0

s1

t1,2t2,2

t1[2,4]

t2[2,3]

p3

FDs3(t0)=[0,1]

p2

s2s3

m3={(p0,1),(p1,0),(p2,1),(p3,0)}c3=[2 # #]T

Page 57: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Time Petri Nets

p0

t0[2,3]

p1

FT(s1)={t2,t1}cs4(t1)=2cs4(t2)=2

IDs4(t1)=[0,2]IDs4(t2)=[0,1]

s0

s1

t1,2t2,2

t0,2

t1[2,4]

t2[2,3]

p3

FDs4(t1)=[0,1]FDs4(t2)=[0,1]

p2

s2s3

s4m4={(p0,0),(p1,2),(p

2,0),(p3,0)}c4=[# 2 2]T

Page 58: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets

Ramchandani74 e Zuberek87

Disparo em três fases. Duração. “Transição em disparo”

Infinite-server semantics

Veremos Zuberek87 (adota semântica de Passos)

Page 59: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets

Inp(p) = •p, Out(p)= p•, Inp(t)= •t, Out(t)=t•Inh(t) = O conjunto de lugares inibidores de t

Um lugar p é free-choice, se, e somente se, ∀ti,tj ∈ Out(p): Inp(ti) = Inp(tj) ∧inh(ti)=inh(tj) ∧w(ti)=w(tj).∀ti,tj ∈ Out(p): Inp(ti) = Inp(tj) ∧inh(ti)=inh(tj) ∧w(ti)=w(tj).

Um lugar p é guardado (guarded) se, e somente se,∀ti,tj ∈ Out(p), ∃pk ∈ P: pk ∈ Inp(ti) ∧ pk ∈ Inh(tj)∨ pk ∈ Inp(tj) ∧ pk ∈ Inh(ti)

Page 60: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets

T = (P,T,A,w,m0,c,f) , Timed Petri net

� P – Conjunto de lugares� T – Conjunto de transições� A ⊆ (P x T) ∪ (T x P), Conjunto de arcos� w:A→ℵ,Peso dos arcos� m0:P →ℵ, marcação inicial� m0:P →ℵ, marcação inicial

Free-choice Petri net: cada lugar é free-choice ou guardedPartição de T em diferentes classes: Free(T) ={T1,T2,...,Tk}

� c:T→0≤ℜ≤1, função de probabilidade de escolha, tal que

Page 61: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets

T = (P,T,A,w,m0,c,f) , Timed Petri net

� f: T → ℜ+ ∪ {0} – Duração

Page 62: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets

Page 63: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets

s=(m,n,r) é um estado de uma TPN T :

� m:P →ℵ, é uma função de marcação� n:T →ℵ, firing-ranking function – função que indica o

número de vezes que uma transição dispara naquele estado

� r(ti): (ℜ+ ∪ {0})|k| , vetor que associa a cada disparo de t� r(ti): (ℜ+ ∪ {0})|k| , vetor que associa a cada disparo de tium numero real que representa remaining firing timedisparo de ti naquele estado. K é o número de vezes que ti está sendo disparada em s (i.e., n(ti)=k). Os valores do vetor são crescentes: r(ti)[1]<r(t)[2]<...<r(t)[k].

Page 64: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets

si=(mi,ni,ri) é o estado inicial (pode haver vários para uma free-choice net)

Escolhendo ni ∈ Sel(m0)

Page 65: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets

sj=(mj,nj,rj) é diretamente alcançado por si=(mi,ni,ri) , satisfazendo as seguintes condições:

1.

2.

3.4.5.

6.7.

Page 66: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets

sj=(mj,nj,rj) é diretamente alcançado por si=(mi,ni,ri) , satisfazendo as seguintes condições:

1.

2.

Pega o menor remainingfiring time. Holding time do estado si

3.4.5.

6.7.

Page 67: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets

sj=(mj,nj,rj) é diretamente alcançado por si=(mi,ni,ri) , satisfazendo as seguintes condições:

1.

2.

3.4.5.

6.7.

Para cada transição, obtém-se quantidade de disparos que terminam em hi unidades de tempo

Page 68: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets

sj=(mj,nj,rj) é diretamente alcançado por si=(mi,ni,ri) , satisfazendo as seguintes condições:

1.

2.

3.4.5.

6.7.

Gera-se uma marcação intermediária m’i (p), considerando os términos dos disparos

Page 69: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets

sj=(mj,nj,rj) é diretamente alcançado por si=(mi,ni,ri) , satisfazendo as seguintes condições:

1.

2.

3.4.5.

6.7.

Escolhe-se uma função de seleção considerando as transições habilitadas na marcação intermediária (Passo máximo).

Page 70: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets

sj=(mj,nj,rj) é diretamente alcançado por si=(mi,ni,ri) , satisfazendo as seguintes condições:

1.

2.

3.4.5.

6.7.

Define a marcação mj,removendo os tokensdevido aos disparos representando por gk

Page 71: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets

sj=(mj,nj,rj) é diretamente alcançado por si=(mi,ni,ri) , satisfazendo as seguintes condições:

1.

2. Define os novos disparos de transição em s

3.4.5.

6.7.

de transição em sj,adicionando novos - gk(t) -e removendo alguns concluídos - di(t)

Page 72: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets

sj=(mj,nj,rj) é diretamente alcançado por si=(mi,ni,ri) , satisfazendo as seguintes condições:

1.

2.

3.4.5.

6.7.

Define os remaining firingtimes em sj, Atualiza o tempo dos disparos que não concluíram e define-se os novos disparos - f(t).

Page 73: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets

Grafo de alcançabilidade G=(V,D,h,q) de uma TPN T

� V é conjunto de vértices, V=S(T) (conjunto de estados de T)

� D é o conjunto dos arcos dirigidos, D ⊂ V x V. (si,sj) ∈ D, se, e somente se, é diretamente alcançável por si.

� Associa o holding time a cada estado� Associa o holding time a cada estado

� q:D→[0,1] é uma função que associa uma probabilidade aos arcos do grafo

Page 74: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

t1

t2

t3t5

t6t7

p1

p2

p3p4

p5

0

10

0

0

200.1

t4

p1p6

0

5

0

0.9

Page 75: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

t1

t2

t3t5

t6t7

p1

p2

p3p4

p5

0

10

0

0

200.1

t4

p1p6

0

5

0

0.9

Page 76: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

t1

t2

t3t5

t6t7

p1

p2

p3p4

p5

0

10

0

0

200.1

t4

p1p6

0

5

0

0.9

Marcações intermediárias:m1’(p2)=1m1’(p4)=1

Page 77: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

t1

t2

t3t5

t6t7

p1

p2

p3p4

p5

0

10

0

0

200.1

t4

p1p6

0

5

0

0.9

Marcações intermediárias:m1’(p2)=1m1’(p4)=1

Page 78: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

t1

t2

t3t5

t6t7

p1

p2

p3p4

p5

0

10

0

0

200.1

t4

p1p6

0

5

0

0.9

rs2(t2)[1]=10rs2(t5)[1]=20

Page 79: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

t1

t2

t3t5

t6t7

p1

p2

p3p4

p5

0

10

0

0

200.1

t4

p1p6

0

5

0

0.9

rs2(t2)[1]=10rs2(t5)[1]=20 (subtrair 10)

Marcações intermediárias:m2’(p3)=1

Page 80: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

t1

t2

t3t5

t6t7

p1

p2

p3p4

p5

0

10

0

0

200.1

t4

p1p6

0

5

0

0.9

rs3(t4)[1]=5rs3(t5)[1]=10

Page 81: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

t1

t2

t3t5

t6t7

p1

p2

p3p4

p5

0

10

0

0

200.1

t4

p1p6

0

5

0

0.9

rs3(t4)[1]=5rs3(t5)[1]=10 (subtrair 5)

Marcações intermediárias:m2’(p1)=1m2’(p6)=1

Page 82: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

t1

t2

t3t5

t6t7

p1

p2

p3p4

p5

0

10

0

0

200.1

t4

p1p6

0

5

0

0.9

rs5(t1)[1]=0rs5(t5)[1]=5

Page 83: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

t1

t2

t3t5

t6t7

p1

p2

p3p4

p5

0

10

0

0

200.1

t4

p1p6

0

5

0

0.9

rs5(t1)[1]=0rs5(t5)[1]=5 (subtrair 0)

Marcações intermediárias:m2’(p2)=1m2’(p4)=1

Page 84: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

t1

t2

t3t5

t6t7

p1

p2

p3p4

p5

0

10

0

0

200.1

t4

p1p6

0

5

0

0.9

rs7(t2)[1]=10rs7(t5)[1]=5

rs7(t5)[2]=20

Page 85: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

t1

t2

t3t5

t6t7

p1

p2

p3p4

p5

0

10

0

0

200.1

t4

p1p6

0

5

0

0.9

rs7(t2)[1]=10 (subtrair 5)rs7(t5)[1]=5

rs7(t5)[2]=20 (subtrair 5)Marcações Intermediárias:

m2’(p5)=1m2’(p6)=1

Page 86: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

t1

t2

t3t5

t6t7

p1

p2

p3p4

p5

0

10

0

0

200.1

t4

p1p6

0

5

0

0.9

rs9(t2)[1]=5rs9(t5)[1]=15rs9(t6)[1]=0

Page 87: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

t1

t2

t3t5

t6t7

p1

p2

p3p4

p5

0

10

0

0

200.1

t4

p1p6

0

5

0

0.9

rs10(t2)[1]=5rs10(t5)[1]=15

Page 88: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

t1

t2

t3t5

t6t7

p1

p2

p3p4

p5

0

10

0

0

200.1

t4

p1p6

0

5

0

0.9

rs10(t2)[1]=5rs10(t5)[1]=15 (subtrair 5)

Marcações Intermediárias:m10’(p3)=1

Page 89: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets - INA

T = (P,T,F,W,m0,D) , Timed Petri net� P – Conjunto de lugares� T – Conjunto de transições� F ⊆ (P x T) ∪ (T x P), Conjunto de arcos� W:A→ℵ,Peso dos arcos� D:T →ℵ, Duração da transição� D:T →ℵ, Duração da transição

Adota semântica de passos com single-server firingsemantics

Page 90: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets - INA

S ⊆ (M,A) conjunto de todos os estados, onde • M ⊆ (P Xℵ) : conjunto de marcações• A ⊆ (T Xℵ): conjunto das durações (tempo) restantes

de disparo das transições

Um estado s ϵ S é uma tupla s = (m,a), no qual m ϵ M é a Um estado s ϵ S é uma tupla s = (m,a), no qual m ϵ M é a marcação e a ϵ A a duração restante das transições em disparo.

Se a(t) = 0, a transição t não está disparando no estado s

s0 = (m0,0) é a marcação inicial. 0(t) =0, t ϵ T

A

Page 91: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets - INA

U ⊆ T é um passo máximo no estado s=(m,a), se e somente se:

• t ϵ U, a(t) = 0;• p ϵ P, m(p) >= ∑t ϵ UW(p,t);• U = {}: (i) t ϵ ET(m), a(t) > 0; ou (ii) ET(m) = {} ∧ ∃ t ϵ T,

A

A

A• U = {}: (i) t ϵ ET(m), a(t) > 0; ou (ii) ET(m) = {} ∧ ∃ t ϵ T,

a(t) > 0; • U’ satisfazendo as condições acima, tal que U ⊂ U’

Conjunto de transições habilitadas:ET(m) = {t | m(p)>= W(p,t)}, p ϵ P

A

A

Page 92: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets - INA

Assuma o estado s=(m,a) e U um passo máximo em s. O estado s’=(m’,a’) é alcançado devido ao disparo de U em s, da seguinte forma:

• Ɵ = min(1,D(t)), t ϵ U• m'(p) = m(p) - ∑t ϵU W(p,t) + ∑t ϵU ˄ D(t)=ƟW(t,p) + ∑a(t)>0 ˄

a(t)=Ɵ W(t,p), p ϵ P

A

Aa(t)=Ɵ W(t,p), p ϵ P

D(t) – Ɵ, if t ϵ U • a‘(t) = a(t) – Ɵ, if t ϵ U ˄ a(t) > 0

0, caso contrário

A

Page 93: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets - INA

p0

t0D(t0)=0

t1D(t1)=3

p1

s0m0={(p0,1),(p1,0),(p

2,0),(p3,0),(p4,0)}

p2t4

t2D(t2)=1

p3

t3D(t3)=1

t4D(t4)=4

Page 94: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets - INA

p0

t0D(t0)=0

t1D(t1)=3

p1

ET(m0) = {t0,t1}U0={t0}, U01={t1}

p2t4

s0m0={(p0,1),(p1,0),(p

2,0),(p3,0),(p4,0)}

t2D(t2)=1

p3

t3D(t3)=1

t4D(t4)=4

Page 95: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets - INA

p0

t0D(t0)=0

t1D(t1)=3

p1p2

t4

s0m0={(p0,1),(p1,0),(p

2,0),(p3,0),(p4,0)}

s0'm1'={(p0,1),(p1,0),(p

U01={t1}, Ɵ01=1

ET(m0’) = {}U0’={}

t2D(t2)=1

p3

t3D(t3)=1

t4D(t4)=4

m1'={(p0,1),(p1,0),(p2,0),(p3,0),(p4,0)}

a0'(t1)=2

Page 96: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets - INA

p0

t0D(t0)=0

t1D(t1)=3

p1p2

t4

s0m0={(p0,1),(p1,0),(p

2,0),(p3,0),(p4,0)}

s0'm1'={(p0,1),(p1,0),(p

U01={t1}, Ɵ01=1

ET(m0’’) = {}U0’’={}

t2D(t2)=1

p3

t3D(t3)=1

t4D(t4)=4

m1'={(p0,1),(p1,0),(p2,0),(p3,0),(p4,0)}

a0'(t1)=2

s0‘’m1‘’={(p0,1),(p1,0),(p2,0),(p3,0),(p4,0)}

a0‘’(t1)=1

U0’={}, Ɵ0’=1

Page 97: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets - INA

p0

t0D(t0)=0

t1D(t1)=3

p1

ET(m1) = {t3}U1={t3}

p2t4

s0m0={(p0,1),(p1,0),(p

2,0),(p3,0),(p4,0)}

s0'm1'={(p0,1),(p1,0),(p

U01={t1}, Ɵ01=1

t2D(t2)=1

p3

t3D(t3)=1

t4D(t4)=4

m1'={(p0,1),(p1,0),(p2,0),(p3,0),(p4,0)}

a0‘(t1)=2

s0‘’m1‘’={(p0,1),(p1,0),(p2,0),(p3,0),(p4,0)}

a0‘’(t1)=1

U0’={}, Ɵ0’=1

s1m1={(p0,0),(p1,1),(p

2,0),(p3,0),(p4,0)} U0’’={}, Ɵ0’’=1

Page 98: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets - INA

p0

t0D(t0)=0

t1D(t1)=3

p1p2

t4

s0m0={(p0,1),(p1,0),(p

2,0),(p3,0),(p4,0)}

U01={t1}, Ɵ01=3

s1m1={(p0,0),(p1,1),(p

ET(m1) = {t3}U1={t3}

t2D(t2)=1

p3

t3D(t3)=1

t4D(t4)=4

m1={(p0,0),(p1,1),(p2,0),(p3,0),(p4,0)}

Page 99: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets - INA

p0

t0D(t0)=0

t1D(t1)=3

p1p2

t4

s0m0={(p0,1),(p1,0),(p

2,0),(p3,0),(p4,0)}

U01={t1}, Ɵ01=3

s1m1={(p0,0),(p1,1),(p

ET(m2) = {t4}U2={t4}

t2D(t2)=1

p3

t3D(t3)=1

t4D(t4)=4

m1={(p0,0),(p1,1),(p2,0),(p3,0),(p4,0)}

U1={t3}, Ɵ1=1

s2m2={(p0,0),(p1,0),(p

2,0),(p3,1),(p4,0)}

Page 100: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets - INA

p0

t0D(t0)=0

t1D(t1)=3

p1p2

t4

s0m0={(p0,1),(p1,0),(p

2,0),(p3,0),(p4,0)}

U01={t1}, Ɵ01=3

s1m1={(p0,0),(p1,1),(p

ET(m2’) = {}U2’={}

t2D(t2)=1

p3

t3D(t3)=1

t4D(t4)=4

m1={(p0,0),(p1,1),(p2,0),(p3,0),(p4,0)}

U1={t3}, Ɵ1=1

s2m2={(p0,0),(p1,0),(p

2,0),(p3,1),(p4,0)}s2‘’m2={(p0,0),(p1,0),(p

2,0),(p3,0),(p4,0)}a3‘(t4)=3

U2={t4}, Ɵ2=1

Page 101: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets - INA

p0

t0D(t0)=0

t1D(t1)=3

p1p2

t4

s0m0={(p0,1),(p1,0),(p

2,0),(p3,0),(p4,0)}

U01={t1}, Ɵ01=3

s1m1={(p0,0),(p1,1),(p

s2‘’’...

a2‘(t4)=1

U2’’’={}, Ɵ2’’’=1

U ={}, Ɵ =1

t2D(t2)=1

p3

t3D(t3)=1

t4D(t4)=4

m1={(p0,0),(p1,1),(p2,0),(p3,0),(p4,0)}

U1={t3}, Ɵ1=1

s2m2={(p0,0),(p1,0),(p

2,0),(p3,1),(p4,0)}s2‘m2={(p0,0),(p1,0),(p

2,0),(p3,0),(p4,0)}a2‘(t4)=3

U2={t4}, Ɵ2=1

s2‘’...

a2‘(t4)=2

U2’={}, Ɵ2’=1

U2’’={}, Ɵ2’’=1

Page 102: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets - INA

p0

t0D(t0)=0

t1D(t1)=3

p1p2

t4

s0m0={(p0,1),(p1,0),(p

2,0),(p3,0),(p4,0)}

U01={t1}, Ɵ01=3

s1m1={(p0,0),(p1,1),(pU2={t4}, Ɵ2=4

t2D(t2)=1

p3

t3D(t3)=1

t4D(t4)=4

m1={(p0,0),(p1,1),(p2,0),(p3,0),(p4,0)}

U1={t3}, Ɵ1=1

s2m2={(p0,0),(p1,0),(p

2,0),(p3,1),(p4,0)}

U2={t4}, Ɵ2=4

Page 103: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets - INA

s0m0={(p0,1),(p1,0),(p

2,0),(p3,0),(p4,0)}

U01={t1}, Ɵ=3

s1U2={t4}, Ɵ=4

U0={t0}, Ɵ=0

s1m1={(p0,0),(p1,1),(p

2,0),(p3,0),(p4,0)}

U1={t3}, Ɵ=1

s2m2={(p0,0),(p1,0),(p

2,0),(p3,1),(p4,0)}

s3m3={(p0,0),(p1,0),(p

2,1),(p3,0),(p4,0)}

U3={t2}, Ɵ=1

Page 104: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets - INA

p0

t0D(t0)=0

t1D(t1)=3

p1

s0m0={(p0,2),(p1,0),(p

2,0),(p3,0),(p4,0)}

p2t4

t2D(t2)=1

p3

t3D(t3)=1

t4D(t4)=4

Page 105: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets - INA

p0

t0D(t0)=0

t1D(t1)=3

p1

s0m0={(p0,2),(p1,0),(p

2,0),(p3,0),(p4,0)}

p2t4

ET(m0) = {t0,t1}U0={t0,t1}

t2D(t2)=1

p3

t3D(t3)=1

t4D(t4)=4

Page 106: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets - INA

p0

t0D(t0)=0

t1D(t1)=3

p1

s0m0={(p0,1),(p1,0),(p

2,0),(p3,0),(p4,0)}

p2t4

ET(m1) = {t2}U1={t2}

U0={t0,t1}, Ɵ0=0

s1m1={(p0,0),(p1,0),(p

t2D(t2)=1

p3

t3D(t3)=1

t4D(t4)=4

m1={(p0,0),(p1,0),(p2,1),(p3,0),(p4,0)}

a1(t1)=3

Page 107: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets - INA

p0

t0D(t0)=0

t1D(t1)=3

p1

s0m0={(p0,1),(p1,0),(p

2,0),(p3,0),(p4,0)}

p2t4

ET(m2) = {t4}U2={t4}

U0={t0,t1}, Ɵ0=0

s1m1={(p0,0),(p1,0),(p

t2D(t2)=1

p3

t3D(t3)=1

t4D(t4)=4

m1={(p0,0),(p1,0),(p2,1),(p3,0),(p4,0)}

a1(t1)=3

U1={t2}, Ɵ1=1

s2m1={(p0,0),(p1,0),(p

2,0),(p3,1),(p4,0)}a2(t1)=2

Page 108: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets - INA

p0

t0D(t0)=0

t1D(t1)=3

p1

s0m0={(p0,1),(p1,0),(p

2,0),(p3,0),(p4,0)}

p2t4

ET(m2’) = {}U2’={}

U0={t0,t1}, Ɵ0=0

s1m1={(p0,0),(p1,0),(p

t2D(t2)=1

p3

t3D(t3)=1

t4D(t4)=4

m1={(p0,0),(p1,0),(p2,1),(p3,0),(p4,0)}

a1(t1)=3

U1={t2}, Ɵ1=1

s2m1={(p0,0),(p1,0),(p

2,1),(p3,0),(p4,0)}a2(t1)=2

U2={t4}, Ɵ2=1s2’...

a2’(t1)=1a2’(t4)=3

Page 109: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets - INA

p0

t0D(t0)=0

t1D(t1)=3

p1

s0m0={(p0,1),(p1,0),(p

2,0),(p3,0),(p4,0)}

p2t4

ET(m3) = {t3}U3={t3}

U0={t0,t1}, Ɵ0=0

s1m1={(p0,0),(p1,0),(p

t2D(t2)=1

p3

t3D(t3)=1

t4D(t4)=4

m1={(p0,0),(p1,0),(p2,1),(p3,0),(p4,0)}

a1(t1)=3

U1={t2}, Ɵ1=1

s2m1={(p0,0),(p1,0),(p

2,1),(p3,0),(p4,0)}a2(t1)=2

U2={t4}, Ɵ2=1s2’...

a2’(t1)=1a2’(t4)=3

s3m1={(p0,0),(p1,1),(p

2,0),(p3,0),(p4,0)}a3(t4)=2

U2’={}, Ɵ2’=1

Page 110: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets - INA

p0

t0D(t0)=0

t1D(t1)=3

p1

s0m0={(p0,1),(p1,0),(p

2,0),(p3,0),(p4,0)}

p2t4

ET(m3) = {t3}U3={t3}

U0={t0,t1}, Ɵ0=0

s1m1={(p0,0),(p1,0),(p...

t2D(t2)=1

p3

t3D(t3)=1

t4D(t4)=4

m1={(p0,0),(p1,0),(p2,1),(p3,0),(p4,0)}

a1(t1)=3

U1={t2}, Ɵ1’=1

s2m1={(p0,0),(p1,0),(p

2,1),(p3,0),(p4,0)}a2(t1)=2

U2={t4}, Ɵ2=2

s3m1={(p0,0),(p1,1),(p

2,0),(p3,0),(p4,0)}a3(t4)=2

...

Page 111: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Timed Petri Nets – INA (Sem estados transientes)Assuma o estado s=(m,a) e U um passo máximo em s. O

estado s’=(m’,a’) é alcançado devido ao disparo de U em s, da seguinte forma:

• Duration={D(t)| t ϵU} ∪ {a(ta)| a(ta) > 0, ta ϵ T-U}• Ɵ = min(Duration):(ET(m’)≠∅ ∧ ∃t’ ϵ ET(m’), a(t’)=0)∨

(ET(m’)=∅↔ a(t)=0,∀t ϵ T)(ET(m’)=∅↔ a(t)=0,∀t ϵ T)• m'(p) = m(p) - ∑t ϵU W(p,t) + ∑t ϵU ˄ D(t)<=ƟW(t,p) + ∑a(t)>0 ˄

a(t)<=Ɵ W(t,p), ∀p ϵ P

D(t) – Ɵ, if t ϵ U ˄ D(t) > Ɵ• a‘(t) = a(t) – Ɵ, if t ϵ U ˄ a(t) > 0 ˄ a(t) > Ɵ

0, caso contrário

Page 112: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Tempo de Execução

� Análise do grafo de estados + Algoritmo de procura de caminhos (Redes Genéricas)

� Métodos estruturais

Page 113: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

t1

t2

t3t5

t6t7

p1

p2

p3p4

p5

0

10

0

0

200.1

t4

p1p6

0

5

0

0.9

Qual é o menor caminho s1 até s5?

Page 114: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

t1

t2

t3t5

t6t7

p1

p2

p3p4

p5

0

10

0

0

200.1

t4

p1p6

0

5

0

0.9

D(s1,s5)=0 + 10 + 5 + 0= 15

Page 115: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Regras de Redução

Técnicas de reduções para uma rede sequencial

Page 116: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Regras de Redução

Técnicas de reduções para uma rede sequencial

Page 117: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Regras de Redução

Técnicas de reduções para uma rede sequencial

Page 118: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Regras de Redução

Técnicas de reduções para uma rede sequencial

Page 119: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Tempo de Ciclo (Cycle Time)

Grafos marcados

Cm = maxk {Dk/Nk } k=1,...,q• q é o número de circuito• D é a soma dos tempos associados às transições • Dk é a soma dos tempos associados às transições

do circuito• Nk é o somatório de marcas no circuito k

Page 120: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Tempo de Ciclo (Cycle Time)

p0

t1D(t1)=5

p2 p3

p1P-minimum semiflows:

SP1 = {p0,p2,p4,p6}SP2 = {p0,p3,p5,p6}SP3 = {p1,p2,p4}SP4 = {p1,p3,p5]

t2D(t2)=20

t4D(t4)=3

t5D(t5)=2 p4 p5

p6

t3D(t3)=4

Circuito:

c1 = {t1,t2,t4,t5}c2 = {t1,t3,t4,t5}c3 = {t1,t2,t4}c4 = {t1,t3,t4}

Page 121: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Tempo de Ciclo (Cycle Time)

p0

t1D(t1)=5

p2 p3

p1 Cm = maxk {Dk/Nk } k=1,...,qC1 =(5+20+3+2)/2=15C2 =(5+4+3+2)/1 = 14C3=(5+20+3)/2=14C =(5+4+3)/1 = 12

t2D(t2)=20

t4D(t4)=3

t5D(t5)=2 p4 p5

p6

t3D(t3)=4

C4=(5+4+3)/1 = 12

Cm = maxk{15,14,14,12}=15

Page 122: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Leitura

F. D. J. Bowden. A Brief Survey and Synthesis of theRoles of Time in Petri Nets. Mathematical andComputter Modelling, 2000.

E. Tavares. Software Synthesis for Energy-ConstrainedE. Tavares. Software Synthesis for Energy-ConstrainedHard Real-Time Systems, 2009.

W. Zuberek. Timed Petri Nets: Definitions, Propertiesand Applications. Microelectronics and Reliability, 1991

Zeugmann and et al. Worst-case Analysis of ConcurrentSystems with Duration Interval Petri Nets. Informatik-Bericht,1997.

Page 123: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Leitura

B. Berthomieu and M. Diaz. Modeling and Verification ofTime Dependent Systems Using Time Petri Nets. IEEE Trans. Software Engineering, 1991.

N. Leveson e J. Stolzy. Safety Analysis Using Petri Nets. N. Leveson e J. Stolzy. Safety Analysis Using Petri Nets. IEEE Trans. Software Engineering, 1987.

Page 124: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

� Tavares09 e Barreto05

� Síntese de software para sistemas de tempo real crítico com restrições de energia

� Geração de código sob medida� Escalonador Híbrido� Adoção de DVS� Adoção de DVS

124

Page 125: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

• Sistemas de Tempo Real Crítico– Execuções satisfazendo as restrições temporais

– Restrições temporais críticas

– Restrições de Energia e Temporais: usualmente

conflitantes

125

Page 126: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

Page 127: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

Page 128: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

Composta por tarefas concorrentes periódicasRestrições Temporais

Tarefas Periódicas (php,rp,cp,dp ,pp ,code p)�ph = fase�r = release�c = pior caso de ciclos de execução (WCEC)�c = pior caso de ciclos de execução (WCEC)�d = deadline�p = período�code= código

Tarefas Esporádicas (cs,ds,min s,code s)min = menor período entre duas ativações

Tradução de tarefas esporádicas para periódicas

Page 129: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

Relação entre Tarefas�Precedência�Exclusão

Método de Escalonamento (preempção ou não)Adoção de uma unidade de tempo (Task Time UnitAdoção de uma unidade de tempo (Task Time Unit- TTU)Informações sobre o despachanteArquitetura do hardware

�DVS: Níveis de tensão (e as respectivas máximasfrequências)

�Consumo de energia por ciclo em cada nível

Restrição de Energia do Sistema

Page 130: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

Modelagem

�Time Petri Net estendida com valores de energia�Blocos Básicos

�Atributos de um sistema de tempo real crítico

�Regras de Composição�Regras de Composição�União de redes e renomeação de lugares

Período da Escala (PS)

�Menor múltiplo comum de todos os períodos das tarefas

�Diversas instâncias: S(ti) = PS/pi

Page 131: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

Inst. Size Schedule Found W/DVS(J) O/DVS(J) % lpedf Time(s)

4 7 x 107 48 141 0.24740 0.31320 21% 45% 0.001

6 7 x 1035 4377 518406 0.00069 0.00105 34% 54% 35.200

12 2 x 1032 551 9906 267.00000 360.00000 26% 29% 0.282

4 5 x 1014 246 246 279.00000 371.00000 25% 25% 0.003

• Geração de escalas

4 5 x 10 246 246 279.00000 371.00000 25% 25% 0.003

289 9 x 1070 235852 1884381 0.11900 0.34500 66% 73% 291.221

10 2 x 108 83 4268 0.00021 0.00023 9% 39% 0.234

3604 3 x 1068 381313 381313 3.86200 4.76600 19% 19% 9.606

10 9 x 1018 320 85085 0.01607 0.01682 4% 27% 0.395

Page 132: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

5060708090

100

Tam

anho

do

espa

ço d

e es

tado

s (P

otên

cia

de 1

0)

L. InferiorAlcançado

01020304050

1 2 3 4 5 6 7 8

Tam

anho

do

espa

ço d

e es

tado

s (P

otên

cia

de 1

0)

Estudos de Caso

AlcançadoL. Superior

Page 133: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

Page 134: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Escalonador Runtime (Abordagem Híbrida)

Segmentos

Fatias de Tempo

Page 135: redes petri temporizada - modcs.org · Tempo em Redes de Petri Breve Histórico: Ranchandani, 1973 – Transition Timed Net Merling, 1976 – Transition Time Net Sifakis, 1977 –

Exemplo

0.8

0.9

1

Con

sum

o de

Ene

rgia

(N

orm

aliz

ado)

só despachante

ocioso 10MHz

ocioso DPM

ocioso DPM/10MHz

0.5

0.6

0.7

10% 25% 50% 75% 100%

Con

sum

o de

Ene

rgia

(N

orm

aliz

ado)

% WCEC

ocioso DPM/10MHz

escalonador