Stavo pensando a un modo per rappresentare i numeri algebrici in Haskell come un flusso di approssimazioni. Probabilmente potresti farlo con qualche algoritmo di ricerca delle radici. Ma non è divertente. Quindi è possibile aggiungere x
al polinomio, riducendo il problema alla ricerca di punti fissi.È possibile utilizzare le funzioni a punto fisso sui polinomi?
Quindi, se si dispone di una funzione in Haskell come
f :: Double -> Double
f x = x^2 + x
io non capisco perché concettualmente correzione non funziona, vale a dire, posso facilmente verificare per me stesso che non funziona , ma non è lo zero vero punto fisso di f? Esiste un'altra funzione di punto fisso semplice (come nella dimensione della definizione) che funzionerebbe?
'fix' trova il minimo _defined_ punto fisso che in molti casi è ⊥ (non-terminazione, errore, ...). Vedi anche: http://stackoverflow.com/a/8099449/700253 – Vitus
Questa è una domanda molto buona, ma trovo molto difficile rispondere senza andare troppo astratto. Sto cercando di formulare una buona risposta. – hivert
Come dice vitus, l'ordinamento in cui la correzione trova il punto meno fisso è l'ordinamento del dominio, piuttosto che l'ordinamento regolare su Double. – augustss