So I decided to write my own chess engine. (Because if it ever appears on CCRL it means I left at least some trail in the world).
After watching Bluefever's Vice series I started rewriting it in D.
The first changes were changing board representation to 0x88. Now I also added tapering of Vice's king PST based on chessprogramming.org code.
Although even with all the things that Vice had at the time, it still doesn't dominate Nero 6.1.
The old bugs resurface, and due to my approach to defensive programming (no point in doing too many asserts till somebody pays attention to the engine), it is very easy to get discouraged.
It means that if I don't show my creation to somebody soon, I will simply delete the project.
The engine is named Mussaurus, the smallest dinosaur. I saw this name in Michael Chrichton's "The Lost World", and since the previous book was only about large dinosaurs, mussaurus is something new.
Full disclosure: After playing a whole hour of Lichess hourly arena, I got burnt out and stayed away from chess for two weeks. Now I lose to Chessmaster's Cassie.
Here's the link, if you want to laugh: https://github.com/shinkarom/mussaurus.
Mussaurus 0.1-prealpha - a poor man's Vice
Moderators: hgm, Rebel, chrisw, Ras, hgm, chrisw, Rebel, Ras
-
- Posts: 92
- Joined: Tue Nov 19, 2019 1:26 pm
- Full name: Roman Shynkarenko
-
- Posts: 92
- Joined: Tue Nov 19, 2019 1:26 pm
- Full name: Roman Shynkarenko
Re: Mussaurus 0.1-prealpha - a poor man's Vice
Nobody has anything to say to me at all?
-
- Posts: 43101
- Joined: Sun Feb 26, 2006 10:52 am
- Location: Auckland, NZ
Re: Mussaurus 0.1-prealpha - a poor man's Vice
Well gone on writing a chess engine.
I hope that you keep developing it.
gbanksnz at gmail.com
-
- Posts: 4557
- Joined: Tue Jul 03, 2007 4:30 am
Re: Mussaurus 0.1-prealpha - a poor man's Vice
Yes, something like this is not for pointing and laughing, the effort is appreciated and new programmers are always welcome.
-
- Posts: 238
- Joined: Tue Jul 12, 2011 1:31 pm
Re: Mussaurus 0.1-prealpha - a poor man's Vice
What about a README file in your github, with some instructions to compile Mussaurus?
Two first meanings of the dutch word "leren":
1. leren [vc] (learn, larn, acquire) acquire or gain knowledge or skills.
2. leren [v] (teach, learn, instruct) impart skills or knowledge to.
1. leren [vc] (learn, larn, acquire) acquire or gain knowledge or skills.
2. leren [v] (teach, learn, instruct) impart skills or knowledge to.
-
- Posts: 92
- Joined: Tue Nov 19, 2019 1:26 pm
- Full name: Roman Shynkarenko
Re: Mussaurus 0.1-prealpha - a poor man's Vice
@Graham Banks Nobody needs another also ran. The perpetually buggy sorta clone would be quickly forgotten if there are more noteworthy engines around.
@Ovyron Well, didn't you smile when you saw the poor and sloppy shape my code is in? Then after you ran it and the engine crashed at seemingly random point, what did it make you think about the programmer?
@pocopito I haven't decided on the license yet. The README would also be the repository's readme, which means it should be copied from the root to bin folder after every change, and that also need to be figured out. The building instructions are simple: "dub build".
@Ovyron Well, didn't you smile when you saw the poor and sloppy shape my code is in? Then after you ran it and the engine crashed at seemingly random point, what did it make you think about the programmer?
@pocopito I haven't decided on the license yet. The README would also be the repository's readme, which means it should be copied from the root to bin folder after every change, and that also need to be figured out. The building instructions are simple: "dub build".
-
- Posts: 1408
- Joined: Sat Jul 21, 2018 7:43 am
- Location: Budapest, Hungary
- Full name: Gabor Szots
Re: Mussaurus 0.1-prealpha - a poor man's Vice
Unfortunately, it always hangs under Banksia. Here is a sample log:
19:16:38 Numpty Recharged 64-bit> move e1g1
19:16:38 Mussaurus 0.1< position startpos moves e2e4 c7c5 g1f3 d7d6 d2d4 c5d4 f3d4 g8f6 b1c3 a7a6 c1e3 e7e5 d4b3 c8e6 f2f3 f8e7 f1d3 e6b3 a2b3 e8d7 e1g1
go wtime 103208 btime 112582 winc 0 binc 0 movestogo 30
19:16:38 Mussaurus 0.1> r n . q . . . r
19:16:38 Mussaurus 0.1> . p . k b p p p
19:16:38 Mussaurus 0.1> p . . p . n . .
19:16:38 Mussaurus 0.1> . . . . p . . .
19:16:38 Mussaurus 0.1> . . . . P . . .
19:16:38 Mussaurus 0.1> . P N B B P . .
19:16:38 Mussaurus 0.1> . P P . . . P P
19:16:38 Mussaurus 0.1> R . . Q . R K .
19:16:38 Mussaurus 0.1> Side: b
19:16:38 Mussaurus 0.1> En passant: -
19:16:38 Mussaurus 0.1> Castling: ----
19:16:38 Mussaurus 0.1> Key: ba6eaa996e9f3f91
19:16:38 Mussaurus 0.1> Pieces:
19:16:38 Mussaurus 0.1> wP: [F3 B2 C2 E4 H2 G2 B3 ] wN: [C3 ] wB: [E3 D3 ] wR: [A1 F1 ] wQ: [D1 ] wK: [G1 ] bP: [G7 B7 H7 D6 A6 F7 E5 ] bN: [B8 F6 ] bB: [E7 ] bR: [A8 H8 ] bQ: [D8 ] bK: [D7 ]
19:16:38 Mussaurus 0.1> Score: -59
19:16:38 Mussaurus 0.1> info score cp -33 depth 1 nodes 175 time 0 pv d7c8
19:16:38 Mussaurus 0.1> Ordering: 77%
19:16:38 Mussaurus 0.1> info score cp -43 depth 2 nodes 1954 time 8 pv d7c8 f3f4
19:16:38 Mussaurus 0.1> Ordering: 78%
19:16:38 Mussaurus 0.1> info score cp -24 depth 3 nodes 9517 time 36 pv b8c6 c3d5 f6d5
19:16:38 Mussaurus 0.1> Ordering: 75%
19:16:38 Mussaurus 0.1> info score cp -32 depth 4 nodes 56586 time 224 pv b8c6 d3c4 d7e8 f3f4
19:16:38 Mussaurus 0.1> Ordering: 76%
19:16:39 Mussaurus 0.1> info score cp 0 depth 5 nodes 171276 time 662 pv b8c6 g1f2 h8e8 d3c4 e8f8
19:16:39 Mussaurus 0.1> Ordering: 78%
19:16:41 Mussaurus 0.1> info score cp 84 depth 6 nodes 729319 time 2768 pv h8f8 g1f2 d7e6 f2g3 b8c6 f3f4
19:16:41 Mussaurus 0.1> Ordering: 80%
19:16:42 Mussaurus 0.1> bestmove h8f8
19:16:42 Numpty Recharged 64-bit< force
19:16:42 Numpty Recharged 64-bit< h8f8
19:16:42 Numpty Recharged 64-bit< time 10320
otim 10886
19:16:42 Numpty Recharged 64-bit< go
19:16:42 Numpty Recharged 64-bit> 4 50 1 20067 f3f4
19:16:42 Numpty Recharged 64-bit> 5 80 8 268986 f3f4
19:16:42 Numpty Recharged 64-bit> 5 107 12 385044 c3d5
19:16:43 Numpty Recharged 64-bit> 6 60 149 4653640 c3d5
19:16:47 Numpty Recharged 64-bit> move c3d5
19:16:47 Mussaurus 0.1< position startpos moves e2e4 c7c5 g1f3 d7d6 d2d4 c5d4 f3d4 g8f6 b1c3 a7a6 c1e3 e7e5 d4b3 c8e6 f2f3 f8e7 f1d3 e6b3 a2b3 e8d7 e1g1 h8f8 c3d5
go wtime 97578 btime 108868 winc 0 binc 0 movestogo 29
19:16:47 Mussaurus 0.1> r n . q . r . .
19:16:47 Mussaurus 0.1> . p . k b p p p
19:16:47 Mussaurus 0.1> p . . p . n . .
19:16:47 Mussaurus 0.1> . . . N p . . .
19:16:47 Mussaurus 0.1> . . . . P . . .
19:16:47 Mussaurus 0.1> . P . B B P . .
19:16:47 Mussaurus 0.1> . P P . . . P P
19:16:47 Mussaurus 0.1> R . . Q . R K .
19:16:47 Mussaurus 0.1> Side: b
19:16:47 Mussaurus 0.1> En passant: -
19:16:47 Mussaurus 0.1> Castling: ----
19:16:47 Mussaurus 0.1> Key: 96be8b3656532ab5
19:16:47 Mussaurus 0.1> Pieces:
19:16:47 Mussaurus 0.1> wP: [F3 B2 C2 E4 H2 G2 B3 ] wN: [D5 ] wB: [E3 D3 ] wR: [A1 F1 ] wQ: [D1 ] wK: [G1 ] bP: [G7 B7 H7 D6 A6 F7 E5 ] bN: [B8 F6 ] bB: [E7 ] bR: [A8 F8 ] bQ: [D8 ] bK: [D7 ]
19:16:47 Mussaurus 0.1> Score: -64
19:16:47 Mussaurus 0.1> info score cp -39 depth 1 nodes 32 time 0 pv f6d5
19:16:47 Mussaurus 0.1> Ordering: 100%
19:16:47 Mussaurus 0.1> info score cp -43 depth 2 nodes 674 time 2 pv d7c8 d3c4
19:16:47 Mussaurus 0.1> Ordering: 81%
19:16:47 Mussaurus 0.1> info score cp -41 depth 3 nodes 1873 time 7 pv f6d5 e4d5 f7f5
19:16:47 Mussaurus 0.1> Ordering: 82%
19:16:47 Mussaurus 0.1> info score cp -59 depth 4 nodes 13722 time 55 pv f6d5 e4d5 f7f5 c2c4
19:16:47 Mussaurus 0.1> Ordering: 82%
19:16:48 Mussaurus 0.1> info score cp -194 depth 5 nodes 52101 time 200 pv f6d5 e4d5 d7c8 g1h1 f7f5
19:16:48 Mussaurus 0.1> Ordering: 85%
19:16:49 Mussaurus 0.1> info score cp -2824 depth 6 nodes 387843 time 1554 pv f6d5 e4d5 d7c8 g1h1 f7f5 c2c4
19:16:49 Mussaurus 0.1>
19:16:49 Mussaurus 0.1> Ordering: 74%
19:16:49 Mussaurus 0.1> core.exception.AssertError@source\search.d(230): Assertion failure
----------------
19:16:49 Mussaurus 0.1>
0x004275E7 in _d_assertp
0x0042381D in int search.AlphaBeta(int, int, int, ref defs.Board, ref defs.SearchInfo, bool) at D:\MyDocuments\mussaurus\source\search.d(179)
0x0042381D in int search.AlphaBeta(int, int, int, ref defs.Board, ref defs.SearchInfo, bool) at D:\MyDocuments\mussaurus\source\search.d(179)
0x0042381D in int search.AlphaBeta(int, int, int, ref defs.Board, ref defs.SearchInfo, bool) at D:\MyDocuments\mussaurus\source\search.d(179)
0x0042381D in int search.AlphaBeta(int, int, int, ref defs.Board, ref defs.SearchInfo, bool) at D:\MyDocuments\mussaurus\source\search.d(179)
0x0042381D in int search.AlphaBeta(int, int, int, ref defs.Board, ref defs.SearchInfo, bool) at D:\MyDocuments\mussaurus\source\search.d(179)
0x0042381D in int search.AlphaBeta(int, int, int, ref defs.Board, ref defs.SearchInfo, bool) at D:\MyDocuments\mussaurus\source\search.d(179)
0x00423BC2 in void search.SearchPosition(ref defs.Board, ref defs.SearchInfo) at D:\MyDocuments\mussaurus\source\search.d(244)
0x004240D8 in void uci.ParseGo(immutable(char)[][], ref defs.Board, ref defs.SearchInfo) at D:\MyDocuments\mussaurus\source\uci.d(67)
0x0042440A in void uci.UCI_Loop(defs.Board, defs.SearchInfo) at D:\MyDocuments\mussaurus\source\uci.d(139)
0x00402406 in _Dmain at D:\MyDocuments\mussaurus\source\app.d(29)
0x0042486B in void rt.dmain2._d_run_main(int, char**, extern (C) int function(char[][])*).runAll().__lambda1()
0x004247E5 in void rt.dmain2._d_run_main(int, char**, extern (C) int function(char[][])*).runAll()
0x00424680 in _d_run_main
0x0041C05C in main at D:\MyDocuments\mussaurus\source\defs.d(7)
0x0044D345 in mainCRTStartup
0x77366359 in BaseThreadInitThunk
0x77717B74 in RtlGetAppContainerNamedObjectPath
0x77717B44 in RtlGetAppContainerNamedObjectPath
Gabor Szots
CCRL testing group
CCRL testing group
-
- Posts: 4718
- Joined: Wed Oct 01, 2008 6:33 am
- Location: Regensburg, Germany
- Full name: Guenther Simon
Re: Mussaurus 0.1-prealpha - a poor man's Vice
What happens if you try w/o a given start position?Gabor Szots wrote: ↑Thu Nov 21, 2019 7:27 pm Unfortunately, it always hangs under Banksia. Here is a sample log:
19:16:38 Numpty Recharged 64-bit> move e1g1
19:16:38 Mussaurus 0.1< position startpos moves e2e4 c7c5 g1f3 d7d6 d2d4 c5d4 f3d4 g8f6 b1c3 a7a6 c1e3 e7e5 d4b3 c8e6 f2f3 f8e7 f1d3 e6b3 a2b3 e8d7 e1g1
-
- Posts: 1408
- Joined: Sat Jul 21, 2018 7:43 am
- Location: Budapest, Hungary
- Full name: Gabor Szots
Re: Mussaurus 0.1-prealpha - a poor man's Vice
The same.Guenther wrote: ↑Thu Nov 21, 2019 8:15 pmWhat happens if you try w/o a given start position?Gabor Szots wrote: ↑Thu Nov 21, 2019 7:27 pm Unfortunately, it always hangs under Banksia. Here is a sample log:
19:16:38 Numpty Recharged 64-bit> move e1g1
19:16:38 Mussaurus 0.1< position startpos moves e2e4 c7c5 g1f3 d7d6 d2d4 c5d4 f3d4 g8f6 b1c3 a7a6 c1e3 e7e5 d4b3 c8e6 f2f3 f8e7 f1d3 e6b3 a2b3 e8d7 e1g1
Gabor Szots
CCRL testing group
CCRL testing group
-
- Posts: 92
- Joined: Tue Nov 19, 2019 1:26 pm
- Full name: Roman Shynkarenko
Re: Mussaurus 0.1-prealpha - a poor man's Vice
https://github.com/shinkarom/mussaurus/ ... -prealpha2
I've reuploaded the fixed version. The problem is when it puts a move into TT after alpha cutoff when all moves in a list were cut off. In that case it didn't select a move and produced empty pv. After disabling TTing of alpha cutoffs the problem disappeared at the cost of some speedups.
I've reuploaded the fixed version. The problem is when it puts a move into TT after alpha cutoff when all moves in a list were cut off. In that case it didn't select a move and produced empty pv. After disabling TTing of alpha cutoffs the problem disappeared at the cost of some speedups.