Vincoli - PowerPoint PPT Presentation

About This Presentation
Title:

Vincoli

Description:

Title: General Author: Computer Science Last modified by: Default Created Date: 6/2/1995 9:27:28 PM Document presentation format: On-screen Show Other titles – PowerPoint PPT presentation

Number of Views:66
Avg rating:3.0/5.0
Slides: 44
Provided by: Compute360
Category:

less

Transcript and Presenter's Notes

Title: Vincoli


1
VincoliProgramming with constraintsCapitolo 1
2
Vincoli
  • Cosa sono i vincoli?
  • Modellare i problemi reali
  • Risolvere un problema con vincoli
  • Vincoli sugli alberi
  • Altre classi di vincoli
  • Proprieta della soluzione di problemi con vincoli

3
Vincoli
Variabile un place holder per valori
Simboli di funzione mapping di valori a valori
Simboli di relazione relazioni tra valori
4
Vincoli
Vincolo primitivo relazione con argomenti
Vincolo congiunzione di vincoli primitivi
5
Soddisfacibilita
Valutazione un assegnamento di valori a variabili
Soluzione valutazione che soddisfa i vincoli
6
Soddisfacibilita
Soddisfacibile vincolo che ha una soluzione Non
soddisfacibile vincolo che non ha una soluzione
soddisfacibile
Non soddisfacibile
7
Vincoli e modello a stati
Stato variabili con valori da un dominio Test
per il goal vincoli che specificano le
combinazioni permesse di valori per delle
variabili
8
Esempio
  • N-regine
  • Variabili Q1, , Qn
  • Domini Di 1,,n
  • Vincoli di non attacco

9
Esempio
  • Cripto-aritmetica
  • Es. SENDMOREMONEY
  • Variabili S,E,N,D,M,O,R,Y
  • Domini Di 0,1,,9
  • Vincoli
  • M ? 0, S ? 0, somma, all-different

10
Esempio
  • Colorazione di mappe
  • In modo che stati adiacenti non abbiamo lo stesso
    colore
  • Variabili stati S1, , Sn
  • Domini insieme dei colori
  • Vincoli all-different

11
Esempi reali
  • Problemi di assegnamento
  • Es. chi insegna quale classe
  • Problemi di orario quale classe e in quale
    orario?
  • Configurazioni hardware
  • Spreadsheets
  • Scheduling di trasporti
  • Scheduling di attivita

12
Albero di ricerca
  • Nodo rappresenta uno stato (variabili con domini
    di lavori)
  • Goal assegnamento di valori a tutte le variabili
    tale che i vincoli siano soddisfatti
  • Stato iniziale nessuna variabile istanziata
  • Funzione successore istanziazione di una
    variabile
  • Lo stesso per tutti i problemi con vincoli

13
Ricerca o no?
  • Strategie di ricerca viste prima tutte
    applicabili ai problemi con vincoli
  • Euristiche specifiche per i problemi con vincoli
    (per scelta della variabile da istanziare e
    scelta del valore per la variabile, cioe la
    scelta del nodo da espandere)
  • Classi di problemi con vincoli che non hanno
    bisogno di ricerca ? risolvibili polinomialmente

14
Vincoli come sintassi
  • I vincoli sono stringhe di simboli
  • Lordine non importa
  • Ma alcuni algoritmi dipendono dallordine

15
Vincoli equivalenti
Due vincoli diversi possono rappresentare la
stessa informazione
Due vincoli sono equivalenti se hanno lo stesso
insieme di soluzioni
16
Modellare con i vincoli
  • I vincoli descrivono il comportamento idealizzato
    di oggetti nel mondo reale

17
Modellare con i vincoli
start foundations interior walls exterior
walls chimney roof doors tiles windows
18
Soddisfazione di vincoli
  • Dato un vincolo C, due domande
  • soddisfazione ha una soluzione?
  • soluzione trovare una soluzione, se ce ne una
  • La prima domanda e piu di base
  • Un risolutore di vincoli risponde al problema
    della soddisfazione

19
Soddisfazione di vincoli
  • Come rispondiamo a questa domanda?
  • Approccio piu semplice tentare tutte le
    valutazioni

20
Soddisfazione di vincoli
  • Il metodo enumerativo non funziona con i numeri
    reali
  • Una versione piu intelligente sara usata per
    vincoli a dominio finito
  • Come risoviamo i vincoli sui reali?
  • Ricordiamo leliminazione di Gauss-Jordan dalle
    scuole medie

21
Eliminazione di Gauss-Jordan
  • Scegliamo un equazione c da C
  • Riscriviamo c nella forma x e
  • Rimpiazziamo x, ovunque appaia in C, con e
  • Continuiamo finche
  • Tutte le equazioni sono nella forma x e
  • O una equatione e equivalente a d 0 (d ! 0)
  • Ritorniamo true nel primo caso, altrimenti false

22
Gauss-Jordan Esempio 1
Rimpiazza X con 2YZ-1
Rimpiazza Y con -1
Ritorna false
23
Gauss-Jordan Esempio 2
Rimpiazza X con 2YZ-1
Rimpiazza Y con -1
Forma risolta vincoli in questa forma sono
soddisfacibili
24
Forma risolta
  • Variabile non parametrica appare sulla sinistra
    di unequazione
  • Variabile parametrica appare sulla destra di
    alcune equazioni
  • Soluzione scegli i valori dei parametri e
    determina i non-parametri

25
Vincoli sugli alberi
  • Rappresentano dati strutturati
  • Costruttori sugli alberi stringa di caratteri
  • cons, node, null, widget, f
  • Costante construttore o numero
  • Albero
  • Una costante e un albero
  • Un construttore con una lista di gt 0 alberi e
    un albero
  • Disegnato con il costruttore sopra i figli

26
Esempi
order(part(77665, widget(red, moose)),
quantity(17), date(3, feb, 1994))
cons(red,cons(blue,cons(red,cons())))
27
Vincoli sugli alberi
  • Altezza di un albero
  • Una costante ha altezza 1
  • Un albero con figli t1, , tn ha altezza uno piu
    della massima altezza degli alberi t1,,tn
  • Albero finito ha altezza finita
  • Esempi altezza 4 e altezza

28
Termini
  • Un termine e un albero con variabili che
    sostituiscono i sottoalberi
  • Termine
  • Una costante e un termine
  • Una variabile e un termine
  • Un costruttore con una lista di gt 0 termini e un
    termine
  • Disegnato con il costruttore sopra i figli
  • Equazione di termini s t (s,t termini)

29
Esempi di termini
order(part(77665, widget(C, moose)), Q, date(3,
feb, Y))
cons(red,cons(B,cons(red,L)))
30
Risolutore per vincoli sugli alberi
  • Assegnare alberi a variabili in modo che I due
    termini siano uguali
  • Es. cons(R, cons(B, nil)) cons(red, L)
  • Simile al metodo di Gauss-Jordan
  • Inizia con un insieme di equazioni di termini C e
    un insieme vuoto di equazioni di termini S
  • Continua finche C e vuoto o ritorna false

31
Soluzione di vincoli sugli alberi
  • unify(C)
  • Rimuove lequazione c da C
  • case xx non fa niente
  • case f(s1,..,sn)g(t1,..,tn) return false
  • case f(s1,..,sn)f(t1,..,tn)
  • aggiunge s1t1, .., sntn a C
  • case tx (x variabile) aggiunge xt a C
  • case xt (x variabile) aggiunge xt a S
  • sustituisce t per x ovunque in C e S

32
Esempio
C
S
Come Gauss-Jordan, le variabili sono parametri o
non-parametri. Una soluzione e ottenuta settando
I parametri (T) ad un qualsiasi valore.
33
Un caso particolare
  • Ce una soluzione per X f(X) ?
  • NO!
  • Se laltezza di X nella soluzione e n
  • allora f(X) ha altezza n1
  • Occurs check
  • Prima di sostituire t per x
  • Controlla che x non appare in t

34
Altri domini di vincoli
  • Ce ne sono molti
  • Vincoli booleani
  • Vincoli di sequenze
  • Mondo dei blocchi
  • Molti altri, di solito collegati a una qualche
    struttura matematica

35
Vincoli booleani
Usati per modellare circuiti,
Vincolo booleano che descrive il circuito
Circuito per lor esclusivo
36
Vincoli booleani
Vincolo che modella il circuito con variabili per
i guasti
Vincolo che modella che solo un gate e guasto
Comportamento osservato
Soluzione
37
Risolutore per vincoli booleani
Sia m il numero di vincoli primitivi in
C epsilon e tra 0 e 1 e determina il grado
di incompletezza for i 1 to n do genera una
valutazione random sulle variabili in C if la
valutazione soddisfa C then return true
endif endfor return unknown
38
Vincoli booleani
  • Il risoluote booleano puo ritornare unknown
  • E incompleto (non risponde a tutte le domande)
  • E polinomiale in tempo, mentre un risolutore
    completo e esponenziale (a meno che P NP)

39
Vincoli sul mondo dei blocchi
pavimento
I vincoli non sono solo matematici
Gli oggetti possono essere sul pavimento o su un
altro oggetto. La fisica dice quali posizioni
sono stabili. I vincoli primitivi sono, per es.,
red(X), on(X,Y), not_sphere(Y).
40
Vincoli sul mondo dei blocchi
Una soluzione e una figura con una annotazione
che dice quale variabile e quale blocco
X
Y
Z
41
Definizione di risolutore
  • Un risolutore di vincoli e una funzione solv che
    prende un vincolo C e ritorna true, false o
    unknown in dipendenza dal fatto se il vincolo e
    soddifacibile
  • se solv(C) true allora C e soddisfacibile
  • se solv(C) false allora C e non soddisfacibile

42
Proprieta dei risolutori
  • Vogliamo risolutori che hanno certe proprieta
  • well-behaved
  • basati su insiemi la risposta dipende solo
    dallinsieme dei vincoli primitivi
  • monotonici se il risolutore fallisce per C1
    allora fallisce anche per C1 /\ C2
  • indipendenti dal nome delle variabili il
    risolutore da la stessa risposta
    indipendentemente dal nome delle variabili

43
Proprieta dei risolutori
  • La proprieta piu stringente che possiamo
    chiedere
  • completezzaA un risolutore e completo se
    ritorna sempre la risposta true o false (mai
    unknown)

44
Sommario sui vincoli
  • I vincoli sono usati per modellare il
    comportamento del mondo reale
  • Un risolutore di vincoli determina se un vincolo
    ha una soluzione
  • Aritmetica reale e vincoli sugli alberi
  • Proprieta dei risolutori
Write a Comment
User Comments (0)
About PowerShow.com