Programowanie funkcyjne/Procedury jeszcze wyższych rzędów/Ćwiczenia

Z Studia Informatyczne
Przejdź do nawigacjiPrzejdź do wyszukiwania

Ćwiczenia

  • Dla dowolnych dwóch funkcji f:XA i g:XB istnieje dokładnie jedna taka funkcja h:XA×B, że π1h=f i π2h=g. Zdefiniuj wprost procedurę prod, która na podstawie funkcji f i g wyznacza funkcję h dla proceduralnej definicji produktów. (let prod f g x p = p (f x) (g x);;)
  • Zaimplementuj sumy rozłączne (koprodukty) za pomocą procedur. (Koprodukt zbiorów A i B to taki zbiór A+B wraz z włożeniami iA:AA+B, iB:BA+B, że dla dowolnej pary funkcji f:AX i g:BX istnieje dokładnie jedna taka funkcja h:A+bX, że hiA=f i hiB=g. Potraktuj tę definicję dosłownie.)
  • Należy zaimplementować włożenie A i B w A+B oraz procedurę, która na podstawie funkcji f i g wyznaczy funkcję h.
  • Potęgowanie funkcji w czasie logarytmicznym.
  • Co tak na prawdę jest obliczane szybciej: funkcja wynikowa, czy jej wartość? Jak można rozszerzyć liczby naturalne Churcha do liczb całkowitych? Jak za pomocą operatora punktu stałego można wyznaczać procedury wzajemnie rekurencyjne?

Laboratorium