לוגיקת זמן

מתוך testwiki
קפיצה לניווט קפיצה לחיפוש

לוגיקת זמן, לוגיקה עתית או לוגיקה טמפורלית (באנגלית: Temporal Logic) היא הרחבה של הלוגיקה הקלאסית המאפשרת ביטויים הקשורים בזמן. לוגיקת זמן היא חלק מהלוגיקה המודלית.

לוגיקת זמן מאפשרת לעסוק בקו זמן, ועל כן מאפשרת לנסח מתמטית משפטים כמו "אני תמיד רעב", "לבסוף אהיה רעב", או "אהיה רעב עד שאוכל משהו". קו הזמן מתחלק לשני סוגים אפשריים: קו זמן ליניארי, שמוגבל לקו זמן אפשרי אחד (כמו בדוגמאות לעיל), וקו זמן מסתעף (Branching logic) שמאפשר לעבוד במספר קווי זמן חלופיים במקביל. בצורה כזו מניחים מראש סביבה לא צפויה שמספר דברים שונים יכולים להתרחש בה. בסביבה כזו ניתן לנסח משפטים כמו: "יש אפשרות שאשאר רעב לנצח" או "יש אפשרות שלבסוף לא אהיה רעב". במידה ואין יודעים אם אי פעם אוכל - שני המשפטים נחשבים נכונים.

אמיר פנואלי זכה בשנת 1996 בפרס טיורינג על הכנסת לוגיקת זמן למדעי המחשב. כיום נעשה שימוש נרחב בלוגיקת זמן באימות תוכנה כדי להוכיח מתמטית נכונות של מערכת מחשב, זאת להבדיל מתהליך בדיקת תוכנה על ידי בודקי תוכנה אנושיים.

אופרטורים של לוגיקת זמן

לוגיקת זמן מכילה שני סוגי אופרטורים: אופרטורים לוגיים ואופרטורים מודליים. האופרטורים הלוגיים הם פעולות בוליאניות רגילות (¬,,,). האופרטורים המודליים שמשתמשים בהם בלוגיקת זמן מוגדרים כך:

טקסטואלי סימול הגדרה הסבר תרשים
אופרטורים בינאריים
ϕ U ψ ϕ𝒰ψ (B𝒰C)(ϕ)=(i:C(ϕi)(j<i:B(ϕj)))

ϕ מתקיים עד ש- ψ מתקיים: ψ מתקיים בנקודת הזמן הנוכחית או בנקודת זמן עתידית, ועד נקודת זמן זו ϕ חייב להתקיים. מנקודת הזמן בה ψ מתקיים, ϕ כבר לא חייב להתקיים.

<timeline>

ImageSize = width:240 height:94 PlotArea = left:30 bottom:30 top:0 right:20 DateFormat = x.y Period = from:0 till:6 TimeAxis = orientation:horizontal AlignBars = justify ScaleMajor = gridcolor:black increment:1 start:0 ScaleMinor = gridcolor:black increment:1 start:0

PlotData=

 bar:p color:red width:10 align:left fontsize:S
 from:1 till:3
 bar:q color:red width:10 align:left fontsize:S
 from:3 till:5
 bar:pUq color:red width:10 align:left fontsize:S
 from:1 till:5

</timeline>

ϕ R ψ ϕψ (BC)(ϕ)=(i:C(ϕi)(j<i:B(ϕj)))

ϕ משחרר את ψ : ψ מתקיים עד נקודת הזמן הראשונה בה ϕ מתקיים (ואחרי זה ψ יכול להתקיים או לא להתקיים), או ש- ψ מתקיים לנצח אם ϕ לא מתקיים לעולם.

<timeline>

ImageSize = width:240 height:100 PlotArea = left:30 bottom:30 top:0 right:20 DateFormat = x.y Period = from:0 till:6 TimeAxis = orientation:horizontal AlignBars = justify ScaleMajor = gridcolor:black increment:1 start:0 ScaleMinor = gridcolor:black increment:1 start:0

PlotData=

 bar:p color:red width:10 align:left fontsize:S
 from:2 till:4
 bar:q color:red width:10 align:left fontsize:S
 from:1 till:3
 from:5 till:6
 bar:pRq color:red width:10 align:left fontsize:S
 from:1 till:3
 from:5 till:6

</timeline>

אופרטורים אונריים
N ϕ ϕ 𝒩B(ϕi)=B(ϕi+1)

ϕ מתקיים בנקודת הזמן הבאה.

<timeline>

ImageSize = width:240 height:60 PlotArea = left:30 bottom:30 top:0 right:20 DateFormat = x.y Period = from:0 till:6 TimeAxis = orientation:horizontal AlignBars = justify ScaleMajor = gridcolor:black increment:1 start:0 ScaleMinor = gridcolor:black increment:1 start:0

PlotData=

 bar:p color:red width:10 align:left fontsize:S
 from:2 till:3
 from:5 till:6
 bar:Np color:red width:10 align:left fontsize:S
 from:1 till:2
 from:4 till:5

</timeline>

F ϕ ϕ B(ϕ)=(true𝒰B)(ϕ)

לבסוף: לבסוף ϕ מתקיים. כלומר בהכרח קיימת נקודה עתידית שבה ϕ מתקיים.

<timeline>

ImageSize = width:240 height:60 PlotArea = left:30 bottom:30 top:0 right:20 DateFormat = x.y Period = from:0 till:6 TimeAxis = orientation:horizontal AlignBars = justify ScaleMajor = gridcolor:black increment:1 start:0 ScaleMinor = gridcolor:black increment:1 start:0

PlotData=

 bar:p color:red width:10 align:left fontsize:S
 from:2 till:3
 from:4 till:5
 bar:Fp color:red width:10 align:left fontsize:S
 from:0 till:5

</timeline>

G ϕ ϕ 𝒢B(ϕ)=¬¬B(ϕ)

תמיד: ϕ תמיד מתקיים.

<timeline>

ImageSize = width:240 height:60 PlotArea = left:30 bottom:30 top:0 right:20 DateFormat = x.y Period = from:0 till:6 TimeAxis = orientation:horizontal AlignBars = justify ScaleMajor = gridcolor:black increment:1 start:0 ScaleMinor = gridcolor:black increment:1 start:0

PlotData=

 bar:p color:red width:10 align:left fontsize:S
 from:1 till:3
 from:4 till:6
 bar:Gp color:red width:10 align:left fontsize:S
 from:4 till:6

</timeline>

A ϕ (𝒜B)(ψ)=(ϕ:ϕ0=ψB(ϕ))

ϕ מתקיים תמיד בכל נקודות הזמן בכל המסלולים שמתחילים בנקודת זמן זו.

E ϕ (B)(ψ)=(ϕ:ϕ0=ψB(ϕ))

קיים לפחות מסלול אחד מנקודת זמן זו שבו ϕ מתקיים.

סימולים אלטרנטיביים:

  • אופרטור R מוחלף לעיתים על ידי הסימון V.
  • אופרטור W משמעו U חלש ושקול ל- fUgGf. כלומר ϕ𝒲ψ משמעו ϕ מתקיים עד ש- ψ מתקיים, או ש- ϕ ממשיך להתקיים לעולם.

אופרטורים אונריים מוגדרים היטב כאשר (B(ϕ מוגדר היטב. אופרטורים בינאריים מוגדרים היטב כאשר (B(ϕ ו- (C(ϕ מוגדרים היטב.

שקילויות

להלן מספר שקילויות בלוגיקת זמן שניתן להסיק מההגדרות שניתנו לעיל:

  • ϕ=ϕ
  • ϕ=ϕ
  • ϕϕ
  • ϕ=ϕ
  • ϕ=ϕ
  • ¬ϕ¬ϕ
  • ¬ϕ¬ϕ
  • ϕϕ
  • ψ(ϕ𝒰ψ)
  • ϕψ(ϕψ)
  • ϕψ=(ϕψ)

ראו גם

קישורים חיצוניים

תבנית:ויקישיתוף בשורה