Sejak buku Chris Okasaki tahun 1998 "Struktur data murni fungsional", saya belum melihat terlalu banyak struktur data fungsional murni yang menarik muncul; Saya dapat menyebutkan beberapa saja:
- IntMap (juga ditemukan oleh Okasaki pada tahun 1998, tetapi tidak ada dalam buku itu)
- Pohon jari (dan generalisasi mereka atas monoids)
Ada juga beberapa cara menarik untuk mengimplementasikan struktur data yang sudah diketahui, seperti menggunakan "tipe bersarang" atau "tipe data aljabar umum" untuk memastikan invarian pohon.
Gagasan baru apa lagi yang muncul sejak 1998 di bidang ini?
Jawaban:
Struktur data baru yang berfungsi murni yang diterbitkan sejak 1998:
2001: Pohon Hash Ideal , dan pendahulunya tahun 2000, Pencarian Trie Efisien Dan Cepat , oleh Phil Bagwell : Tampaknya digunakan sebagai blok bangunan mendasar di perpustakaan standar Clojure.
2001: Teknik Implementasi Sederhana untuk Antrian Pencarian Prioritas , oleh Ralf Hinze : teknik yang sangat sederhana dan indah untuk mengimplementasikan struktur data penting ini (misalnya, berguna dalam algoritma Dijkstra). Implementasinya sangat indah dan mudah dibaca karena banyak menggunakan "pola tampilan".
2002: Bootstrapping array fleksibel satu sisi , oleh Ralf Hinze : Mirip dengan daftar akses acak Okasaki, tetapi mereka dapat disesuaikan untuk mengubah tradeoff waktu antara
cons
dan pengindeksan.2003: Deques yang dapat disatukan dan tidak dapat disatukan , oleh Radu Mihaescu dan Robert Tarjan : Sebuah pandangan baru tentang beberapa karya yang lebih tua (oleh Kaplan dan Tarjan) yang dikutip oleh Okasaki (Versi terbaru dari karya Kaplan & Tarjan diterbitkan pada tahun 2000 ). Versi ini lebih sederhana dalam beberapa hal.
2005: tumpukan Maxiphobic ( kertas dan kode ), oleh Chris Okasaki : Disajikan bukan sebagai struktur baru yang lebih efisien, tetapi sebagai cara untuk mengajarkan antrian prioritas.
2006: Daftar Fatenisasi Kasus Terburuk Secara Fungsional, Waktu Terbarukan , oleh Gerth Stølting Brodal, Christos Makris, dan Kostas Tsichlas : Menjawab pertanyaan luar biasa dari Kaplan dan Tarjan dengan mendemonstrasikan sebuah struktur dengan memasukkan, mencari, mencari, dan menghapus O (lg n), (1) concat.
2008: Percobaan yang Persisten untuk Kontrol Versi yang Efisien , oleh Erik D. Demaine, Stefan Langerman, dan Eric Harga : Menampilkan beberapa struktur data untuk percobaan yang memiliki navigasi dan modifikasi yang efisien di dekat daun. Beberapa murni berfungsi. Yang lain benar-benar memperbaiki struktur data yang sudah berjalan lama oleh Dietz et al. untuk array sepenuhnya persisten (tetapi tidak persisten atau fungsional murni). Makalah ini juga menyajikan pohon-pohon penghubung yang murni fungsional , kadang-kadang disebut "pohon dinamis".
2010: Algoritme penghapusan murni baru untuk pohon merah-hitam , oleh Matt Might : Seperti algoritma penyisipan pohon merah-hitam Okasaki, ini bukan struktur data baru atau operasi baru pada struktur data, tetapi cara baru yang lebih sederhana untuk tulis operasi yang dikenal.
2012: RRB-Trees: Vektor Tidak Berubah Efisien , oleh Phil Bagwell dan Tiark Rompf : Perpanjangan ke Hash Array Mapped Tries, mendukung gabungan vektor abadi, menyisipkan, pada dan membagi dalam waktu O (lg n), sambil mempertahankan indeks, memperbarui , dan kecepatan penyisipan vektor abadi asli.
Dikenal pada tahun 1997, tetapi tidak dibahas dalam buku Okasaki:
Banyak gaya lain dari pohon pencarian seimbang . AVL, abang, peringkat-seimbang, keseimbangan-terikat, dan banyak pohon pencarian seimbang lainnya dapat (dan telah) diimplementasikan secara murni fungsional dengan menyalin jalur. Mungkin pantas disebutkan secara khusus adalah:
Perangkat tak terbatas yang mengakui pencarian lengkap yang cepat , oleh Martín Escardó : Mungkin bukan struktur data semata .
Tiga algoritma pada Braun Trees , oleh Chris Okasaki : Braun tree menawarkan banyak operasi stack dalam kasus terburuk O (lg n). Batas ini dilampaui oleh banyak struktur data lainnya, tetapi pohon Braun memiliki
cons
operasi yang malas dalam argumen keduanya, dan dengan demikian dapat digunakan sebagai tumpukan tak terbatas dalam beberapa hal yang tidak dapat dilakukan oleh struktur lain.Tumpukan min-max yang santai: Antrian prioritas dua sisi yang dapat digabungkan dan Tumpukan KD: Antrian prioritas multi-dimensi yang efisien , oleh Yuzheng Ding dan Mark Allen Weiss : Ini kebetulan berfungsi murni, meskipun ini tidak dibahas dalam makalah. . Saya tidak berpikir batas waktu yang dicapai lebih baik daripada yang dapat dicapai dengan menggunakan pohon jari (dari Hinze & Paterson atau Kaplan & Tarjan) sebagai antrian prioritas k-dimensi, tetapi saya pikir struktur Ding & Weiss menggunakan lebih sedikit ruang .
The Zipper , oleh Gérard Huet : Digunakan di banyak struktur data lainnya (seperti pohon jari Hinze & Paterson), ini adalah cara untuk mengubah struktur data keluar-masuk.
Daftar perbedaan adalah O (1) daftar yang dapat ditutup dengan transformasi O (n) menjadi
cons
daftar yang biasa . Mereka tampaknya telah dikenal sejak jaman dahulu di komunitas Prolog, di mana mereka memiliki transformasi O (1) kecons
daftar biasa . Transformasi O (1) tampaknya tidak mungkin dalam pemrograman fungsional tradisional, tetapi abstraksi lubang Minamide , dari POPL '98, membahas cara untuk memungkinkan O (1) menambahkan dan O (1) transformasi dalam pemrograman fungsional murni. Berbeda dengan implementasi pemrograman fungsional dari daftar perbedaan, yang didasarkan pada penutupan fungsi, abstraksi lubang pada dasarnya sama (baik dalam penggunaan dan implementasinya) sebagai daftar perbedaan Prolog. Namun, tampaknya selama bertahun-tahun satu-satunya orang yang memperhatikan inisalah satu pengulas Minamide .Struktur data yang paling fungsional, sebelum, selama, dan setelah buku Okasaki:
1989: Pohon Pencarian Secara Acak oleh Cecilia R. Aragon dan Raimund Seidel : Ini dibahas dalam pengaturan fungsional murni oleh Guy E. Blelloch dan Margaret Reid-Miller dalam Operasi Pengaturan Cepat Menggunakan Treaps dan oleh Dan Blandford dan Guy Blelloch dalam Operasi Set Fungsional dengan Treaps ( kode). Mereka menyediakan semua operasi ujung jari murni fungsional dan pohon pencarian bias, tetapi membutuhkan sumber keacakan, membuat mereka tidak sepenuhnya berfungsi. Ini juga dapat membatalkan kompleksitas waktu operasi pada treaps, dengan asumsi musuh yang dapat menentukan waktu operasi dan mengulangi yang lama. (Ini adalah alasan yang sama mengapa argumen amortisasi imperatif tidak valid dalam pengaturan persisten, tetapi itu membutuhkan musuh dengan stopwatch)
1997: Skip-tree, struktur data alternatif untuk Skip-list dalam pendekatan bersamaan , oleh Xavier Messeguer dan Menjelajahi Dualitas Antara Daftar Lewati dan Pohon Pencarian Biner , oleh Brian C. Dean dan Zachary H. Jones : Daftar lompatan tidak murni fungsional, tetapi mereka dapat diimplementasikan secara fungsional sebagai pohon. Seperti treaps, mereka membutuhkan sumber bit acak. (Dimungkinkan untuk membuat daftar skip menjadi deterministik, tetapi, setelah menerjemahkannya ke sebuah pohon, saya pikir itu hanyalah cara lain untuk melihat 2-3 pohon.)
1998: Semua struktur diamortisasi dalam buku Okasaki! Okasaki menemukan metode baru ini untuk menggabungkan amortisasi dan struktur data fungsional, yang sebelumnya dianggap tidak kompatibel. Itu tergantung pada memoisasi, yang, seperti yang kadang-kadang Kaplan dan Tarjan sebutkan, sebenarnya adalah efek samping. Dalam beberapa kasus ( seperti PFDS pada SSD karena alasan kinerja ), ini mungkin tidak sesuai.
1998: Daftar Catenable Confluently Persistent Catenable , oleh Haim Kaplan, Chris Okasaki, dan Robert E. Tarjan : Menggunakan modifikasi di bawah kap untuk memberikan O (1) deatenated catenable deques, menghadirkan antarmuka yang sama seperti sebelumnya (murni fungsional, tetapi dengan memoisasi ) versi muncul di buku Okasaki. Kaplan dan Tarjan sebelumnya telah menciptakan struktur kasus terburuk O yang berfungsi murni, tetapi secara substansial lebih rumit.
2007: Seperti disebutkan dalam jawaban lain di halaman ini, struktur data semi-persisten dan persatuan-persisten oleh Sylvain Conchon dan Jean-Christophe Filliâtre
Teknik untuk memverifikasi struktur data fungsional, sebelum, selama, dan setelah buku Okasaki:
Jenis - jenis hantu adalah metode lama untuk membuat API yang tidak memungkinkan operasi yang salah bentuk tertentu. Penggunaan yang canggih dari mereka dapat ditemukan di Oleg Kiselyov dan Kemampuan Static Lightweight Chung-chieh Shan .
Tipe bersarang sebenarnya tidak lebih baru dari tahun 1998 - Okasaki bahkan menggunakannya dalam bukunya. Ada banyak contoh lain yang tidak ada dalam buku Okasaki; ada yang baru, dan ada yang tua. Mereka termasuk:
GADT juga tidak begitu baru. Mereka adalah tambahan baru-baru ini untuk Haskell dan beberapa ML, tetapi mereka telah hadir, saya pikir, dalam berbagai kalkulus lambda yang diketik sejak tahun 1970-an .
2004-2010: Coq dan Isabelle untuk kebenaran . Beberapa orang telah menggunakan pembuktian teorema untuk memverifikasi kebenaran struktur data yang murni fungsional. Coq dapat mengekstrak verifikasi ini ke kode kerja di Haskell, OCaml, dan Skema; Isabelle dapat mengekstraksi ke Haskell, ML, dan OCaml.
2007: Refech Typechecking with Stardust , oleh Joshua Dunfield : Makalah ini menggunakan tipe penyempurnaan untuk ML untuk menemukan kesalahan dalam fungsi hapus pohon merah-hitam SMLNJ.
2008: Analisis Kompleksitas Waktu Semiformal Ringan untuk Struktur Data Murni Fungsional oleh Nils Anders Danielsson : Menggunakan Agda dengan anotasi manual untuk membuktikan batas waktu untuk beberapa PFDS.
Struktur atau analisis data imperatif tidak dibahas dalam buku Okasaki, tetapi terkait dengan struktur data yang murni fungsional:
Soft Heap: Antrian Prioritas Perkiraan dengan Tingkat Kesalahan Optimal , oleh Bernard Chazelle : Struktur data ini tidak menggunakan array, dan karenanya telah tergoda dulu saluran IRC #haskell dan kemudian pengguna Stack Overflow , tetapi termasuk
delete
dalam o (lg n) , yang biasanya tidak mungkin dalam pengaturan fungsional, dan analisis diamortisasi imperatif, yang tidak valid dalam pengaturan fungsional murni.Pohon pencarian biner seimbang dengan O (1) pembaruan jari . Dalam Membuat Struktur Data yang Persisten , James R Driscoll, Neil Sarnak, Daniel D. Sleator, dan Robert E. Tarjan menyajikan metode untuk mengelompokkan node dalam pohon merah-hitam sehingga pembaruan yang terus-menerus hanya membutuhkan ruang O (1). Deques dan pohon jari yang sepenuhnya fungsional yang dirancang oleh Tarjan, Kaplan, dan Mihaescu semuanya menggunakan teknik pengelompokan yang sangat mirip untuk memungkinkan O (1) memperbarui di kedua ujungnya. AVL-tree untuk pencarian lokal oleh Athanasios K. Tsakalidis bekerja dengan cara yang sama.
Tumpukan pasangan lebih cepat atau batas yang lebih baik untuk tumpukan pasangan : Sejak buku Okasaki diterbitkan, beberapa analisis baru tentang tumpukan pasangan imperatif telah muncul, termasuk Pairing heaps dengan O (log log n) mengurangi Biaya oleh Amr Elmasry dan Menuju Analisis Akhir dari Pairing Heaps oleh Seth Pettie. Dimungkinkan untuk menerapkan sebagian dari pekerjaan ini pada tumpukan pasangan malas Okasaki.
Pohon jari bias deterministik : Dalam Daftar Lompatan yang bias , oleh Amitabha Bagchi, Adam L. Buchsbaum, dan Michael T. Goodrich, sebuah desain disajikan untuk daftar lompatan yang bias deterministik. Melalui lompatan daftar / transformasi pohon yang disebutkan di atas, dimungkinkan untuk membuat pohon pencarian bias deterministik. Daftar lompatan yang bias jari yang dijelaskan oleh John Iacono dan Özgür Özkan dalam Kamus yang Dapat Digabungkan kemudian dimungkinkan pada pohon lompatan yang bias. Pohon jari yang bias disarankan oleh Demaine et al. dalam makalah mereka tentang percobaan yang berfungsi murni (lihat di atas) sebagai cara untuk mengurangi batas waktu dan ruang pada pembaruan jari dalam percobaan.
String B-Tree: Struktur Data Baru untuk Pencarian String dalam Memori Eksternal dan Aplikasi-aplikasinya oleh Paolo Ferragina dan Roberto Grossi adalah struktur data yang dipelajari dengan baik yang menggabungkan manfaat percobaan dan B-tree.
sumber
Untuk catatan bagus yang sudah dibuat, saya akan menambahkan Ritsleting .
Huet, Gerard. “Mutiara Fungsional: Ritsleting” Jurnal Pemrograman Fungsional 7 (5): 549-554, September 1997.
Wikipedia: Zipper (struktur data)
sumber
Conchon, Filliatre, Struktur Data UNION-FIND yang Persisten dan Struktur Data Semi-persisten .
sumber
Saya akan menambahkan ritsleting versi McBride sebagai turunan dari tipe data.
sumber
Rangemaps
Ini adalah struktur data khusus, tetapi dapat digunakan sebagai pengganti DIET Martin Erwig, dengan properti yang sedikit berbeda, jadi setidaknya ada satu struktur data yang ada untuk membandingkannya. DIET itu sendiri dijelaskan dalam sebuah artikel di JFP pada tahun 1998, jadi mungkin itu tidak termasuk dalam Struktur Data Murni Fungsional.
sumber
Menindaklanjuti makalah 2012 terkait di atas, pekerjaan pada vektor RRB sejak itu telah diperpanjang dan diterbitkan dalam ICFP'15.
Vektor RRB: urutan umum tujuan praktis praktis http://dl.acm.org/citation.cfm?id=2784739
sumber