question about symmertic evaluation
Moderator: Ras
- 
				Uri Blass
- Posts: 10905
- Joined: Thu Mar 09, 2006 12:37 am
- Location: Tel-Aviv Israel
question about symmertic evaluation
I found that my evaluation is not symmetric for white and black.
one of the reason is that in some part of my evaluation I simply calculate score from white point of view and later divide by 8
now (14>>3)=1 and (-14>>3)=-2 so I can get a different number
for white and black.
My question is how do you solve that type of problem and if there is a way to solve it without doing the code slower(of course it is easy to solve it by doing the code slower and writing something like
if (score<0)
{
score=-score;
score=score>>3;
score=-score;
}
else
score=score>>3;
I thought also about using (score+4)>>3 but in that case (12+4)>>3=2
when (-12+4)>>3=-1
Uri
			
			
									
						
										
						one of the reason is that in some part of my evaluation I simply calculate score from white point of view and later divide by 8
now (14>>3)=1 and (-14>>3)=-2 so I can get a different number
for white and black.
My question is how do you solve that type of problem and if there is a way to solve it without doing the code slower(of course it is easy to solve it by doing the code slower and writing something like
if (score<0)
{
score=-score;
score=score>>3;
score=-score;
}
else
score=score>>3;
I thought also about using (score+4)>>3 but in that case (12+4)>>3=2
when (-12+4)>>3=-1
Uri
- 
				Uri Blass
- Posts: 10905
- Joined: Thu Mar 09, 2006 12:37 am
- Location: Tel-Aviv Israel
Re: question about symmertic evaluation
The best thing that I can think about is something like this
I wonder if you have better idea how to make it symmetric for score=X and score=-X
Maybe there is a simple library function of division that is faster
			
			
									
						
										
						Code: Select all
if (score>0)
			score+=4;
		else
			score+=3;
		return (score>>3);Maybe there is a simple library function of division that is faster
- 
				Gerd Isenberg
- Posts: 2251
- Joined: Wed Mar 08, 2006 8:47 pm
- Location: Hattingen, Germany
Re: question about symmertic evaluation
One idea is to avoid the asymmetrical arithmetical shift right 3 at all and to mul all other eval aspects by 8. You may add 7 if the value to shift arithmetical right 3 is negative, but this is of course more expensive.
or with respect to the value range:
The common approach seems to score and aggregate from white resp. black point of view and keep both values in evalScore[2] to divide both before the final difference for color's point of view:
Gerd
			
			
									
						
										
						Code: Select all
symmetrical arithmetical shift right 3 ::= (x + ((x>>31)&7)) >> 3
Code: Select all
symmetrical arithmetical shift right 3 ::= (x + ((unsigned)x>>29)) >> 3
Code: Select all
posEval = (evalScore[color]>>3) - (evalScore[color^1]>>3);
- 
				Uri Blass
- Posts: 10905
- Joined: Thu Mar 09, 2006 12:37 am
- Location: Tel-Aviv Israel
Re: question about symmertic evaluation
ThanksGerd Isenberg wrote:One idea is to avoid the asymmetrical arithmetical shift right 3 at all and to mul all other eval aspects by 8. You may add 7 if the value to shift arithmetical right 3 is negative, but this is of course more expensive.or with respect to the value range:Code: Select all
symmetrical arithmetical shift right 3 ::= (x + ((x>>31)&7)) >> 3The common approach seems to score and aggregate from white resp. black point of view and keep both values in evalScore[2] to divide both before the final difference for color's point of view:Code: Select all
symmetrical arithmetical shift right 3 ::= (x + ((unsigned)x>>29)) >> 3GerdCode: Select all
posEval = (evalScore[color]>>3) - (evalScore[color^1]>>3);
Here is the full code that caused the problem and is about prefering pawns in the endgame
Code: Select all
static int evalpawnrelative(void)
{
	int score=0;
	if (numpawns[LIGHT]!=numpawns[DARK])
	{
		score=(24-valuepieces)*(numpawns[LIGHT]-numpawns[DARK]);
 		return (score>>3)*prefer_pawns_in_end_games;
	}
	return 0;
}The default value of prefer_pawns_in_the end_games is 1
practically the score that it returns is between -0.0475 per pawn advantage in the opening and 0.03 per pawn advantage in pawn endgames.
I can make 2 tables for pawns in the endgame and in the opening but I am not sure if it is a good idea because in many positions the number of pawns of both sides is equal so calculating 2 piece square tables when the difference between them is constant seems to be a waste of time.
Maybe I care too much about small speed change that is not very important and it is not that I really care about speed but simply that I do not like my program to be slower because of fixing a bug.
Uri
- 
				bob
- Posts: 20943
- Joined: Mon Feb 27, 2006 7:30 pm
- Location: Birmingham, AL
Re: question about symmertic evaluation
just don't use shift as it is not correct for positive and negative numbers.
			
			
									
						
										
						- 
				bob
- Posts: 20943
- Joined: Mon Feb 27, 2006 7:30 pm
- Location: Birmingham, AL
Re: question about symmertic evaluation
I'd be willing to bet that a plain divide will not noticably affect his overall search speed. And it will solve this correctly.Gerd Isenberg wrote:One idea is to avoid the asymmetrical arithmetical shift right 3 at all and to mul all other eval aspects by 8. You may add 7 if the value to shift arithmetical right 3 is negative, but this is of course more expensive.or with respect to the value range:Code: Select all
symmetrical arithmetical shift right 3 ::= (x + ((x>>31)&7)) >> 3The common approach seems to score and aggregate from white resp. black point of view and keep both values in evalScore[2] to divide both before the final difference for color's point of view:Code: Select all
symmetrical arithmetical shift right 3 ::= (x + ((unsigned)x>>29)) >> 3GerdCode: Select all
posEval = (evalScore[color]>>3) - (evalScore[color^1]>>3);
- 
				Uri Blass
- Posts: 10905
- Joined: Thu Mar 09, 2006 12:37 am
- Location: Tel-Aviv Israel
Re: question about symmertic evaluation
thanksbob wrote:I'd be willing to bet that a plain divide will not noticably affect his overall search speed. And it will solve this correctly.Gerd Isenberg wrote:One idea is to avoid the asymmetrical arithmetical shift right 3 at all and to mul all other eval aspects by 8. You may add 7 if the value to shift arithmetical right 3 is negative, but this is of course more expensive.or with respect to the value range:Code: Select all
symmetrical arithmetical shift right 3 ::= (x + ((x>>31)&7)) >> 3The common approach seems to score and aggregate from white resp. black point of view and keep both values in evalScore[2] to divide both before the final difference for color's point of view:Code: Select all
symmetrical arithmetical shift right 3 ::= (x + ((unsigned)x>>29)) >> 3GerdCode: Select all
posEval = (evalScore[color]>>3) - (evalScore[color^1]>>3);
It seems that replacing some >> by / solves the problem
of anti-symmetric evaluation and now at least for the wac positions my evaluation is symmetric between white and black(did not check symmetry between left and right)
Uri
- 
				Gerd Isenberg
- Posts: 2251
- Joined: Wed Mar 08, 2006 8:47 pm
- Location: Hattingen, Germany
Re: question about symmertic evaluation
Idiv is still quite expensive (idiv r32/imm ~18-42 cycles on core2 duo) - but if seldomly used it does not hurt. Anyway, vc2005 seems aware of that trick:bob wrote: I'd be willing to bet that a plain divide will not noticably affect his overall search speed. And it will solve this correctly.
Code: Select all
int idiv8(int x)
{
   return x / 8;
}
  mov  eax, ecx
  cdq
  and  edx, 7
  add  eax, edx
  sar  eax, 3
- 
				bob
- Posts: 20943
- Joined: Mon Feb 27, 2006 7:30 pm
- Location: Birmingham, AL
Re: question about symmertic evaluation
The thing is it interlaces nicely with other instructions around it... I have been using several divides in my code to scale parts of the evaluation, and it made absolutely no difference in my NPS...Gerd Isenberg wrote:Idiv is still quite expensive (idiv r32/imm ~18-42 cycles on core2 duo) - but if seldomly used it does not hurt. Anyway, vc2005 seems aware of that trick:bob wrote: I'd be willing to bet that a plain divide will not noticably affect his overall search speed. And it will solve this correctly.
Code: Select all
int idiv8(int x) { return x / 8; } mov eax, ecx cdq and edx, 7 add eax, edx sar eax, 3
- 
				sje  
- Posts: 4675
- Joined: Mon Mar 13, 2006 7:43 pm
Re: question about symmertic evaluation
Agreed. Furthermore, a decent optimizing compiler will code a power of two division as a right shift where it is possible (and correct) to do so.bob wrote:I'd be willing to bet that a plain divide will not noticably affect his overall search speed. And it will solve this correctly.