It's been a couple years. I'm looking for any engine that does games per second to choose it's move.
Engines can do over 100 million nodes per second with today's hardware (e.g., AMD 5950X).
How many games per second do you think you can get your engine to do? Average game of chess ~37 moves.
I haven't seen anything talked about. Was wondering if anything has been in the works.
Thanks
			
			
									
						
										
						Games/second Engines
Moderator: Ras
- 
				Kotlov  
- Posts: 269
- Joined: Fri Jul 10, 2015 9:23 pm
- Location: Russia
- 
				lithander  
- Posts: 915
- Joined: Sun Dec 27, 2020 2:40 am
- Location: Bremen, Germany
- Full name: Thomas Jahn
Re: Games/second Engines
Many engine programmers use ultra fast time controls for testing. With 1 second + 100ms strong engines still play at grandmaster level.
If you want to play dozens of hundreds of games per second I would assume the whole overhead of using a GUI and an engine thread that you talk to with text commands becomes a bottleneck and needs to be removed.
I could write a program in C# in a day that utilizes my chess engine's search routine directly to play hundreds of games per second utilizing all available cores... theses games would be pretty shallow in terms of search depth but otherwise they will just be normal chess games like you'd expect them from an engine with 200 Elo less when given a more normal amount of time. But.. why would I want to do that?
			
			
									
						
										
						If you want to play dozens of hundreds of games per second I would assume the whole overhead of using a GUI and an engine thread that you talk to with text commands becomes a bottleneck and needs to be removed.
I could write a program in C# in a day that utilizes my chess engine's search routine directly to play hundreds of games per second utilizing all available cores... theses games would be pretty shallow in terms of search depth but otherwise they will just be normal chess games like you'd expect them from an engine with 200 Elo less when given a more normal amount of time. But.. why would I want to do that?
- 
				hgm  
- Posts: 28396
- Joined: Fri Mar 10, 2006 10:06 am
- Location: Amsterdam
- Full name: H G Muller
Re: Games/second Engines
It is not advisable to play sub-second games with conventional engines communicating through a GUI. Communication delays will be too long and too unpredictable.
You can do such a thing for self-play when you write a routine for that inside the engine itself. But even then maniging the time by wall-clock would be a bad idea. There will be unpredictable lapses where the process doesn't get any CPU time or will be partly swapped out of memory because of hidden tasks the OS occasionally performs. So it would be better to play by number of nodes rather than time.
This is what I did in my Janggi engine. I equipped it with some extra commands, so that I can run it from the command line, and play a requested number of games with a given number of nodes per move. Positions are sampled from these games (in particular the positions at the end of the PV, as these are quiet) for collecting a set to tune the eval on.
			
			
									
						
										
						You can do such a thing for self-play when you write a routine for that inside the engine itself. But even then maniging the time by wall-clock would be a bad idea. There will be unpredictable lapses where the process doesn't get any CPU time or will be partly swapped out of memory because of hidden tasks the OS occasionally performs. So it would be better to play by number of nodes rather than time.
This is what I did in my Janggi engine. I equipped it with some extra commands, so that I can run it from the command line, and play a requested number of games with a given number of nodes per move. Positions are sampled from these games (in particular the positions at the end of the PV, as these are quiet) for collecting a set to tune the eval on.
- 
				jhaglund2
- Posts: 66
- Joined: Mon Jan 16, 2017 6:28 pm
Re: Games/second Engines
There's no where I mention you need to do additional talking to a GUI while doing the crunching of games.Many engine programmers use ultra fast time controls for testing. With 1 second + 100ms strong engines still play at grandmaster level.
If you want to play dozens of hundreds of games per second I would assume the whole overhead of using a GUI and an engine thread that you talk to with text commands becomes a bottleneck and needs to be removed.
 
 Code: Select all
I could write a program in C# in a day that utilizes my chess engine's search routine directly to play hundreds of games per second utilizing all available cores... theses games would be pretty shallow in terms of search depth but otherwise they will just be normal chess games like you'd expect them from an engine with 200 Elo less when given a more normal amount of time. But.. why would I want to do that? 
  Yes, that's the part where tuning, and other methods to get a complete game would come in before you decide to increment to the next move in your PV.
If you can do 100 million nps. I think 5k-20k and upwards of 50k games/sec would be a good goal.
- 
				jhaglund2
- Posts: 66
- Joined: Mon Jan 16, 2017 6:28 pm
Re: Games/second Engines
Correct.It is not advisable to play sub-second games with conventional engines communicating through a GUI. Communication delays will be too long and too unpredictable.
Games / Second is just a benchmark how fast the engine completes games. Similar to Nodes per Second. It doesn't imply it's based on a clock.You can do such a thing for self-play when you write a routine for that inside the engine itself. But even then maniging the time by wall-clock would be a bad idea. There will be unpredictable lapses where the process doesn't get any CPU time or will be partly swapped out of memory because of hidden tasks the OS occasionally performs. So it would be better to play by number of nodes rather than time.
Tuning is certainly a part of the process. How you want to complete a game, statistics for the root moves have to be done, etc. Think of it like a chess database being created for each move.This is what I did in my Janggi engine. I equipped it with some extra commands, so that I can run it from the command line, and play a requested number of games with a given number of nodes per move. Positions are sampled from these games (in particular the positions at the end of the PV, as these are quiet) for collecting a set to tune the eval on.
- 
				jhaglund2
- Posts: 66
- Joined: Mon Jan 16, 2017 6:28 pm
Re: Games/second Engines
I'm not aware Stockfish does games/second for move selection.Stockfish with movetime 1000?
- 
				hgm  
- Posts: 28396
- Joined: Fri Mar 10, 2006 10:06 am
- Location: Amsterdam
- Full name: H G Muller
Re: Games/second Engines
Well, if your search can do 1Mnps, and you want to do 10 games per second, you have 100k nodes per game. If a game lasts 100 half-moves you have 1k nodes per move. It should be possible to search some 3 ply + QS with that.
Multi-threaded engines could probably do more nps, but you would spend the CPU time better by playing a number of single-threaded games in parallel.
Of course you can also play games with a 1-ply search + QS. That might take only 100 nodes per move. Quality would suffer, but they would still be games.
			
			
									
						
										
						Multi-threaded engines could probably do more nps, but you would spend the CPU time better by playing a number of single-threaded games in parallel.
Of course you can also play games with a 1-ply search + QS. That might take only 100 nodes per move. Quality would suffer, but they would still be games.
- 
				lithander  
- Posts: 915
- Joined: Sun Dec 27, 2020 2:40 am
- Location: Bremen, Germany
- Full name: Thomas Jahn
Re: Games/second Engines
You could also make a "game tree" where games with a common ancestry all had the same moves made up to the point where they branch off. Can generate a lot of games that way that start the same but then end differently!  
			
			
									
						
										
						
- 
				jhaglund2
- Posts: 66
- Joined: Mon Jan 16, 2017 6:28 pm
Re: Games/second Engines
That is part of the tuning, how to arrive at a concluded game. I'd rather see more data points / games.Well, if your search can do 1Mnps, and you want to do 10 games per second, you have 100k nodes per game. If a game lasts 100 half-moves you have 1k nodes per move. It should be possible to search some 3 ply + QS with that.
1 thread per root move possible and iterate is what comes to mind.Multi-threaded engines could probably do more nps, but you would spend the CPU time better by playing a number of single-threaded games in parallel.
Plenty of options here.Of course you can also play games with a 1-ply search + QS. That might take only 100 nodes per move. Quality would suffer, but they would still be games.
					Last edited by jhaglund2 on Fri Jul 01, 2022 9:11 pm, edited 2 times in total.