File: killers.c

package info (click to toggle)
phalanx 22-12
  • links: PTS
  • area: main
  • in suites: sarge
  • size: 868 kB
  • ctags: 534
  • sloc: ansic: 6,876; sh: 79; makefile: 72
file content (121 lines) | stat: -rw-r--r-- 2,363 bytes parent folder | download | duplicates (9)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
#include "phalanx.h"

typedef struct { unsigned f, t; } killentry;
killentry RK[H9][H9]; /* reaction killer */

unsigned HK[H9][H9]; /* history killer table */
unsigned Maxhist = 1;


void init_killers(void)
{
memset( RK, 0, H9*H9*sizeof(killentry) );
memset( HK, 0, H9*H9*sizeof(unsigned) );
Maxhist = 1;
}



void write_killer( int from, int to )
{

if( B[to] == 0 )
{
	RK[G[Counter-1].m.from][G[Counter-1].m.to].f = from;
	RK[G[Counter-1].m.from][G[Counter-1].m.to].t = to;

	HK[from][to] += Depth/10 + 1;
	if( HK[from][to] > Maxhist )
	{
		Maxhist = HK[from][to];
		if( Maxhist > 16000 )
		{
			int f,t;
			Maxhist /= 2;
			for( f=A1; f!=H9; f++ )
			for( t=A1; t!=H9; t++ )
				HK[f][t] /= 2;
		}
	}
}

}



void add_killer( tmove *m, int n, thashentry *ht )
{

int i, f=0, t=0;
tmove *mpv = &PV[0][Ply];
tmove *mlv = &PV[Ply][Ply];

if( Depth > 0 )
{
	f = RK[G[Counter-1].m.from][G[Counter-1].m.to].f;
	t = RK[G[Counter-1].m.from][G[Counter-1].m.to].t;
}

for( i=0; i!=n; i++ )
{
	register tmove *m1 = m+i;

	if( FollowPV )
	{
	  if( m1->from == mpv->from
	    && m1->to == mpv->to
	    && m1->in2a == mpv->in2a ) m1->value = CHECKMATE;
	}
	else
	{
	  if( m1->from == mlv->from
	    && m1->to == mlv->to
	    && m1->in2a == mlv->in2a ) m1->value += 350;

	  if( ht != NULL ) if( ht->move != 0 )
	  if( ht->move == smove(m1) ) m1->value = CHECKMATE;
	}

	if( m1->value != CHECKMATE )
	{
		if( m1->in2 ) /* capture */
		{
			m1->value += Values[ m1->in2>>4 ];
			if( Color==WHITE )
			{ if( P[m1->to]&0xFF00 )
			  m1->value -= ( Values[ m1->in1>>4 ] >> 2 );
			  else m1->value += 100; }
			else
			{ if( P[m1->to]&0x00FF )
			  m1->value -= ( Values[ m1->in1>>4 ] >> 2 );
			  else m1->value += 100; }
			if( m1->value < 30 ) m1->value = 30;
		}

		/* leaving attacked square */
		if( Color==WHITE )
		{ if(P[m1->from]&0xFF00) m1->value += 50; }
		else
		{ if(P[m1->from]&0x00FF) m1->value += 50; }

		if( m->in1 != m->in2 ) /* pawn promotion */
			m->value += Values[ m->in2>>4 ] - Values[ m->in1>>4 ];

		if( Depth > 200 ) m1->value += see( B, m1->from, m1->to );
		else /* last moved piece */
		if( m1->to == G[Counter-1].m.to ) m1->value += 150;

		if( Depth > 0 )
		{
			if( m1->from == f && m1->to == t )
				m1->value += max(Depth,50);
			if( HK[ m1->from ][ m1->to ] )
			m1->value +=
			 1 + HK[ m1->from ][ m1->to ] * 500 / Maxhist;
		}

	}
}

}