Apakah aturan promosi cewek dalam dobutsu shogi benar-benar penting?

9

Dalam dobutsu shogi , anak ayam (pion Jepang) berpromosi menjadi ayam (Jenderal emas). Dalam pengalaman saya promosi ini jarang terjadi dan saya curiga setelah banyak kesalahan.

Apakah aturan promosi cewek dalam dobutsu shogi benar-benar penting? Artinya, apakah game benar-benar berubah jika promosi cewek dibatalkan (dan cewek malah terjebak di baris terakhir)?

Dengan benar-benar berubah, maksud saya klasifikasi suatu posisi (menang, kalah atau seri) berubah, atau urutan gerakan yang tepat untuk memaksa kemenangan dari posisi menang berubah secara material.

hkBst
sumber

Jawaban:

6

Aturan promosi sebenarnya sangat penting. Dengan permainan sempurna, permainan berakhir imbang bukannya menang untuk putih / gote jika Anda membatalkan aturan promosi. Bahkan, evaluasi keempat gerakan di posisi awal berubah dengan cara ini.

Saya telah menggunakan dua metode independen untuk mendapatkan hasil ini untuk memeriksa ulang bahwa tidak ada bug dalam implementasi saya:

  1. Menggunakan mesin dengan pencarian alpha-beta, yaitu garpu Stockfish saya untuk varian catur peri (termasuk varian shogi), saya menjalankan pencarian mendalam (~ 1h) sebelum dan setelah menonaktifkan aturan promosi , lihat hasilnya di bawah.
  2. Karena dobutsu shogi adalah permainan yang diselesaikan , ada generator tablebase untuk itu. Saya telah menggunakan generator tablebase open-source dan memodifikasinya untuk menonaktifkan promosi (Saya tidak terlalu akrab dengan basis kode ini, tetapi karena hasil dari kedua metode ini konsisten, perubahan saya tampaknya berfungsi dengan baik). Saya menjalankan pembuatan tablebase dengan kedua set aturan dan memeriksa hasilnya, yang dapat Anda temukan di bawah.

1. Hasil pencarian

memasukkan:

setoption name multipv value 4
setoption name hash value 4096
setoption name UCI_Variant value dobutsu
position startpos
go depth 90

output dengan aturan promosi:

info depth 90 seldepth 87 multipv 1 score mate -43 nodes 2423491649 nps 889420 hashfull 338 tbhits 0 time 2724798 pv c1c2 a4a3 c2c1 b3b2 a1b2 c4b3 C@a1 C@a2 c1c2 a2a1+ b2a1 b3c2 b1c2 a3b3 c2b1 b4a3 E@b2 a3b4 b2c1 b3a3 a1b2 a3a4 b1c2 b4c4 b2c3 a4a3 c3b2 a3a2 C@a1 a2b2 c2b2 G@b3 b2b1 E@a3 G@c2 C@c3 c2b2 c4b4 b2a2 b4a4 a2a3 a4a3 a1a2 a3b4 b1a1 G@c2 a1b1 b4c4 E@a1 b3b4 a1b2 c4b3 a2a3 b4c4 b1a1 c2c1 b2c1 b3a3 G@a2 a3b3 a2b2 b3a4 b2a2 C@a3 c1b2 a3a2 a1a2 c3c2 C@b3 E@c3 b2c3 c4c3 b3b4+ a4b4 E@b2 c3b3 a2b1 b3b2 b1b2 E@a3 b2a1 E@b2 a1b1 G@a1 b1c2 C@c3
info depth 90 seldepth 87 multipv 2 score mate -43 nodes 2423491649 nps 889420 hashfull 338 tbhits 0 time 2724798 pv b1c2 b3b2 a1b2 c4b3 c2b1 a4a3 C@a1 C@a2 c1c2 a2a1+ b2a1 b3c2 b1c2 a3b3 c2b1 b4a3 E@b2 a3b4 b2c1 b3a3 a1b2 a3a4 b1c2 b4c4 b2c3 a4a3 c3b2 a3a2 C@a1 a2b2 c2b2 G@b3 b2b1 E@a3 G@c2 C@c3 c2b2 c4b4 b2a2 b4a4 a2a3 a4a3 a1a2 a3b4 b1a1 G@c2 a1b1 b4c4 E@a1 b3b4 a1b2 c4b3 a2a3 b4c4 b1a1 c2c1 b2c1 b3a3 G@a2 a3b3 a2b2 b3a4 b2a2 C@a3 c1b2 a3a2 a1a2 c3c2 C@b3 E@c3 b2c3 c4c3 b3b4+ a4b4 E@b2 c3b3 a2b1 b3b2 b1b2 E@a3 b2a1 E@b2 a1b1 G@a1 b1c2 C@c3
info depth 90 seldepth 87 multipv 3 score mate -43 nodes 2423491649 nps 889420 hashfull 338 tbhits 0 time 2724798 pv b1a2 a4a3 a2b1 b3b2 a1b2 c4b3 C@a1 C@a2 c1c2 a2a1+ b2a1 b3c2 b1c2 a3b3 c2b1 b4a3 E@b2 a3b4 b2c1 b3a3 a1b2 a3a4 b1c2 b4c4 b2c3 a4a3 c3b2 a3a2 C@a1 a2b2 c2b2 G@b3 b2b1 E@a3 G@c2 C@c3 c2b2 c4b4 b2a2 b4a4 a2a3 a4a3 a1a2 a3b4 b1a1 G@c2 a1b1 b4c4 E@a1 b3b4 a1b2 c4b3 a2a3 b4c4 b1a1 c2c1 b2c1 b3a3 G@a2 a3b3 a2b2 b3a4 b2a2 C@a3 c1b2 a3a2 a1a2 c3c2 C@b3 E@c3 b2c3 c4c3 b3b4+ a4b4 E@b2 c3b3 a2b1 b3b2 b1b2 E@a3 b2a1 E@b2 a1b1 G@a1 b1c2 C@c3
info depth 90 seldepth 85 multipv 4 score mate -42 nodes 2423491649 nps 889420 hashfull 338 tbhits 0 time 2724798 pv b2b3 c4b3 a1b2 a4a3 C@a1 C@a2 c1c2 a2a1+ b2a1 b3c2 b1c2 a3b3 c2b1 b4a3 E@b2 a3b4 b2c1 b3a3 a1b2 a3a4 b1c2 b4c4 b2c3 a4a3 c3b2 a3a2 C@a1 a2b2 c2b2 G@b3 b2b1 E@a3 G@c2 C@c3 c2b2 c4b4 b2a2 b4a4 a2a3 a4a3 a1a2 a3b4 b1a1 G@c2 a1b1 b4c4 E@a1 b3b4 a1b2 c4b3 a2a3 b4c4 b1a1 c2c1 b2c1 b3a3 G@a2 a3b3 a2b2 b3a4 b2a2 C@a3 c1b2 a3a2 a1a2 c3c2 C@b3 E@c3 b2c3 c4c3 b3b4+ a4b4 E@b2 c3b3 a2b1 b3b2 b1b2 E@a3 b2a1 E@b2 a1b1 G@a1 b1c2 C@c3

output tanpa aturan promosi:

info depth 90 seldepth 52 multipv 1 score cp 0 nodes 2745548262 nps 965315 hashfull 244 tbhits 0 time 2844199 pv b1a2 a4a3 a2b1 b3b2 a1b2 c4b3 C@a1 b4a4 c1c2 b3c2 b1c2 G@b3 b2c3 C@c4 c3b2 a4b4 E@a2 c4c3 c2c1 b3b2 c1b2 E@b3 b2b1 b3a4 G@b2 b4c4 b1c1 a4b3 a2b3 a3b3 b2b3 c4b3 G@b2 b3c4 E@b3 c4b4 c1b1 G@a3 b3a2 b4c4 b1c1 E@a4 c1b1 a4b3 b2b3 a3b3 a2b3 c4b3 G@b2 b3b4 E@b3
info depth 90 seldepth 52 multipv 2 score cp 0 nodes 2745548262 nps 965315 hashfull 244 tbhits 0 time 2844199 pv b1c2 b3b2 a1b2 c4b3 c2b1 a4a3 C@a1 b4a4 c1c2 b3c2 b1c2 G@b3 b2c3 C@c4 c3b2 a4b4 E@a2 c4c3 c2c1 b3b2 c1b2 E@b3 b2b1 b3a4 G@b2 b4c4 b1c1 a4b3 a2b3 a3b3 b2b3 c4b3 G@b2 b3c4 E@b3 c4b4 c1b1 G@a3 b3a2 b4c4 b1c1 E@a4 c1b1 a4b3 b2b3 a3b3 a2b3 c4b3 G@b2 b3b4 E@b3
info depth 90 seldepth 50 multipv 3 score cp 0 nodes 2745548262 nps 965315 hashfull 244 tbhits 0 time 2844199 pv b2b3 c4b3 a1b2 a4a3 C@a1 b4a4 c1c2 b3c2 b1c2 G@b3 b2c3 C@c4 c3b2 a4b4 E@a2 c4c3 c2c1 b3b2 c1b2 E@b3 b2b1 b3a4 G@b2 b4c4 b1c1 a4b3 a2b3 a3b3 b2b3 c4b3 G@b2 b3c4 E@b3 c4b4 c1b1 G@a3 b3a2 b4c4 b1c1 E@a4 c1b1 a4b3 b2b3 a3b3 a2b3 c4b3 G@b2 b3b4 E@b3
info depth 90 seldepth 59 multipv 4 score cp 0 nodes 2745548262 nps 965315 hashfull 244 tbhits 0 time 2844199 pv c1c2 a4a3 c2c1 b3b2 a1b2 c4b3 C@a1 b4a4 c1c2 b3c2 b1c2 G@b3 b2c3 C@c4 c3b2 a4b4 E@a2 c4c3 c2c1 b3b2 c1b2 E@b3 b2b1 b3a4 G@b2 b4c4 b1c1 a4b3 a2b3 a3b3 b2b3 c4b3 G@b2 b3c4 E@b3 c4b4 c1b1 G@a3 b3a2 b4c4 b1c1 E@a4 c1b1 a4b3 b2b3 a3b3 a2b3 c4b3 G@b2 b3a4 E@b3 a4b4 b1c1 G@a3 b3a2 b4c4 c1b1 E@b3

Lihat deskripsi protokol UCI untuk perincian tentang arti input dan output.

2. Hasil tablebase

memasukkan:

show lines

output dengan aturan promosi:

Gc4-c3 : #-78  (25.00%)
Lb4-c3 : #-78  (25.00%)
Lb4-a3 : #-78  (25.00%)
Cb3xb2 : #-76  (24.99%)

output tanpa aturan promosi:

Cb3xb2 : 0     (25.00%)
Gc4-c3 : 0     (25.00%)
Lb4-c3 : 0     (25.00%)
Lb4-a3 : 0     (25.00%)

Tolong dicatat:

  • Jarak pasangan berbeda karena dua alasan:
    • Stockfish menghitung jarak pasangan dalam gerakan penuh (kecuali jika Anda mengaktifkan protokol USI), sedangkan generator tablebase menghitung dalam lapis (setengah bergerak).
    • Pencarian tidak selalu menemukan cara terpendek untuk kawin, sedangkan hasil tablebase harus akurat.
  • Kedua perangkat lunak juga menggunakan sistem koordinat yang berbeda untuk menggambarkan kotak (urutan peringkat terbalik), jadi berhati-hatilah untuk tidak mencampurnya saat membandingkan string pindahan.
Fabian Fichter
sumber
1
Sungguh hasil yang menarik dan tak terduga! Saya mempelajari generator tablebase itu sedikit tetapi tidak menyadari bahwa perubahan sekecil itu akan mencapai tujuan saya. Ngomong-ngomong, bisakah Anda menjelaskan output ikan peri sedikit lebih banyak? (Kenapa) artinya "cp 0" berarti menggambar?
hkBst
1
Ya, itu mengejutkan saya juga. Terima kasih atas umpan baliknya, saya telah menambahkan tautan ke deskripsi protokol UCI. Untuk pertanyaan spesifik Anda: Ya, cp 0 berarti menggambar, karena itu berdiri untuk keuntungan pihak yang bergerak dalam satuan centipawns (1/100 pion catur).
Fabian Fichter
1

Saya sekarang yakin bahwa jawaban Fabian Fichter benar. Komentar berikut tentang jawaban Fabian dapat membantu meyakinkan orang lain tentang hal yang sama.

1. Posisi yang tampaknya terkena dampak dengan menghapus promosi anak ayam

Menganalisis hasil yang diposting dari Stockfish yang dimodifikasi, semua game bertemu cukup cepat pada posisi berikut: S / -l- / ge - / - E - / - LG / cC.

$ ./dobutsu -vs900
Loading tablebase... done
1. setup S/-l-/ge-/-E-/-LG/cC
1. show board
  ABC 
 +---+
1| l | c
2|ge |
3| E |
4| LG| *C
 +---+
1. show lines
Eb3xa2 : #-72  (67.13%)
C  *a4 : #-70  (32.87%)   <---  apparently quite strong
Gc4-c3 : #-46  ( 0.00%)
C  *c2 : #-36  ( 0.00%)
C  *c1 : #-28  ( 0.00%)
Eb3-a4 : #-26  ( 0.00%)
Lb4-a4 : #-26  ( 0.00%)
C  *a1 : #-24  ( 0.00%)
C  *c3 : #-22  ( 0.00%)
C  *a3 : #-20  ( 0.00%)
Eb3-c2 : #-12  ( 0.00%)
Lb4-c3 : #-2   ( 0.00%)
Lb4-a3 : #-2   ( 0.00%)

Sente kemudian bermain C*a4, menjatuhkan anak ayam mereka di sudut kiri bawah. Awalnya saya pikir ini penurunan yang sangat sia-sia tetapi menurut basis tabel sebenarnya tidak buruk sama sekali.

1. C  *a4
  ABC 
 +---+
1| l | *c
2|ge |
3| E |
4|CLG| 
 +---+

Sekarang sesuatu yang menarik terjadi. Basis tabel setuju dengan Stockfish bahwa mengayunkan Singa ke samping adalah hasil imbang, tetapi bagaimana dengan menjatuhkan anak ayam untuk melawan anak ayam?

2. show lines
C  *a3 : #69   (99.57%)   <---  winning chick drop
C  *c2 : #91   ( 0.21%)
C  *c1 : #91   ( 0.21%)
C  *a1 : 0     ( 0.00%)
Ga2-a1 : 0     ( 0.00%)
Eb2-c1 : 0     ( 0.00%)
Eb2-a1 : 0     ( 0.00%)
Lb1-a1 : 0     ( 0.00%)   <---  draws the game
C  *c3 : #-28  ( 0.00%)
Lb1-c1 : #-22  ( 0.00%)
Eb2-c3 : #-20  ( 0.00%)
Eb2-a3 : #-20  ( 0.00%)
Ga2-a3 : #-18  ( 0.00%)
Lb1-c2 : #-2   ( 0.00%)
2. C  *a3
  ABC 
 +---+
1| l | 
2|ge |
3|cE |
4|CLG| *
 +---+

Sekarang cewek a3ini berada satu langkah lagi dari promosi dan terlebih lagi akan memberi cek pada promosi, yang akan memaksa singa Sente untuk mengambilnya. Satu-satunya masalah adalah bahwa langkah terbaik melibatkan kehilangan anak ayam a3dan juga bahwa kita masih cukup jauh dari skakmat. Karena itu kita akan mengambil jalan pintas, sehingga kita kehilangan lebih cepat, tetapi tanpa kehilangan karena alasan lain seperti memberikan materi secara sia-sia.

3. show lines
Ca4xa3 : #-68  (92.84%)   <---  catches chick about to promote
Gc4-c3 : #-62  ( 7.16%)
Eb3xa2 : #-32  ( 0.00%)   <---  shortcut
Eb3-c2 : #-8   ( 0.00%)   <---  give away elephant
Lb4-c3 : #-2   ( 0.00%)   <---  stupid
Lb4xa3 : #-2   ( 0.00%)   <---  stupid
3. Eb3xa2
  ABC 
 +---+
1| l | *
2|Ee |
3|c  |
4|CLG| G
 +---+
4. show lines
Lb1xa2 : #31   (100.00%)
Lb1-c2 : #-10  ( 0.00%)
Lb1-c1 : #-6   ( 0.00%)
Lb1-a1 : #-6   ( 0.00%)
Ca3xa4+: #-2   ( 0.00%)
Eb2-c3 : #-2   ( 0.00%)
Eb2-c1 : #-2   ( 0.00%)
Eb2-a1 : #-2   ( 0.00%)
4. Lb1xa2
  ABC 
 +---+
1|   | e
2|le |
3|c  |
4|CLG| *G
 +---+

Kami tampaknya telah berhasil dalam melestarikan ancaman cewek yang mempromosikan pengorbanan, jadi mari kita lanjutkan!

5. show lines
G  *b3 : #-30  (100.00%)
G  *a1 : #-24  ( 0.00%)
G  *c3 : #-20  ( 0.00%)
Gc4-c3 : #-18  ( 0.00%)
G  *c2 : #-14  ( 0.00%)
G  *c1 : #-10  ( 0.00%)
G  *b1 : #-10  ( 0.00%)
Ca4xa3 : #-8   ( 0.00%)
Lb4-c3 : #-2   ( 0.00%)
Lb4-b3 : #-2   ( 0.00%)
Lb4xa3 : #-2   ( 0.00%)
5. G  *b3
  ABC 
 +---+
1|   | *e
2|le |
3|cG |
4|CLG| 
 +---+
6. show lines
Ca3xa4+: #29   (100.00%)   <---  sacrificial promoting chick check
E  *c3 : #-30  ( 0.00%)
E  *c1 : #-28  ( 0.00%)
Eb2-c1 : #-28  ( 0.00%)
Eb2-a1 : #-28  ( 0.00%)
La2-b1 : #-28  ( 0.00%)
La2-a1 : #-28  ( 0.00%)
E  *c2 : #-26  ( 0.00%)
E  *a1 : #-24  ( 0.00%)
E  *b1 : #-12  ( 0.00%)
Eb2-c3 : #-12  ( 0.00%)
La2xb3 : #-2   ( 0.00%)

Dan itu dia, cewek yang mempromosikan pengorbanan sebagai langkah terbaik! Mari lihat apa yang terjadi.

6. Ca3xa4+:
  ABC 
 +---+
1|   | ce
2|le |
3| G |
4|rLG| *
 +---+
7. show lines
Lb4xa4 : #-28  (100.00%)   <---  take chick (forced if promoted)
Gc4-c3 : #-2   ( 0.00%)
Gb3-c3 : #-2   ( 0.00%)
Gb3-a3 : #-2   ( 0.00%)
Gb3xb2 : #-2   ( 0.00%)
Lb4-c3 : #-2   ( 0.00%)
Lb4-a3 : #-2   ( 0.00%)

Sekarang mari kita lihat apa yang terjadi jika kita mengubah ayam itu menjadi anak ayam:

7. setup S/---/le-/-G-/cLG/ec
1. show board
  ABC 
 +---+
1|   | ce
2|le |
3| G |
4|cLG| *
 +---+
1. show lines
Gc4-c3 : #-90  (100.00%)
Gb3xb2 : #-30  ( 0.00%)
Lb4xa4 : #-28  ( 0.00%)
Gb3-c3 : #-10  ( 0.00%)
Gb3-a3 : #-8   ( 0.00%)
Lb4-c3 : #-2   ( 0.00%)
Lb4-a3 : #-2   ( 0.00%)

Dalam posisi ini langkah terbaik menempatkan skakmat 88 (90-2) bergerak menjauh, yang jauh dari skakmat daripada posisi awal, membuatnya masuk akal bahwa ketika dianalisis akan mengarah ke posisi lain bahwa tanpa mempromosikan kekuatan cewek tiba-tiba jauh lebih jauh dari pasangan dari sebelumnya (ad infinitum). Jika benar itu akan membuat posisi G / --- / le- / cG- / CLG / e (lihat di bawah) hasil imbang bukannya menang tanpa promosi anak ayam .

  ABC 
 +---+
1|   | *e
2|le |
3|cG |
4|CLG| 
 +---+

2. Ketepatan pencarian lengkap

Dengan asumsi bahwa generator basis tabel yang digunakan adalah pencarian lengkap yang benar, tampaknya tambalan Fabian harus berhasil menonaktifkan promosi cewek karena file moves.cadalah satu-satunya tempat yang POS_FLAGSdigunakan (kecuali untuk digunakan dalam validation.cmemeriksa posisi struct) dan memang tampaknya dibuat khusus. untuk menonaktifkan promosi.

/* clear promotion bits for pieces that can't be promoted */
status &= POS_FLAGS;
hkBst
sumber