aboutsummaryrefslogtreecommitdiff
path: root/src/grossmeister/search.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/grossmeister/search.rs')
-rw-r--r--src/grossmeister/search.rs42
1 files changed, 21 insertions, 21 deletions
diff --git a/src/grossmeister/search.rs b/src/grossmeister/search.rs
index 20e1dd9..2c2a296 100644
--- a/src/grossmeister/search.rs
+++ b/src/grossmeister/search.rs
@@ -1,7 +1,5 @@
use std::cmp::Ordering;
-use std::sync::Arc;
-use std::sync::atomic::AtomicBool;
-use std::{time::Instant, f32::INFINITY};
+use std::f32::INFINITY;
use crate::{moves::{Move, MoveKind}, board::io::IO};
@@ -192,7 +190,7 @@ impl Grossmeister {
alpha
}
- pub fn iterative_deepening(&mut self, max_depth: u8, print: bool) -> (f32, Vec<Move>) {
+ pub fn iterative_deepening(&mut self, max_depth: u8) -> (f32, Vec<Move>) {
let mut result = None;
let mut depth = 1;
let mut alpha = -INFINITY;
@@ -201,11 +199,12 @@ impl Grossmeister {
let mut gradual_widening_counter = 0;
let mut root_killers: Vec<Move> = Vec::new();
-
+ println!("info depth 1");
while depth <= max_depth {
- if print {
- println!("\nSearching depth({}) in the window {:?}", depth, (alpha, beta));
+ if self.debug {
+ println!("info string window {:?}", (alpha, beta));
}
+
let search_result = self.negamax_search(alpha, beta, depth, &mut root_killers);
if search_result.0.abs() >= VALUE_WIN {
@@ -213,32 +212,24 @@ impl Grossmeister {
}
if self.should_halt.load(std::sync::atomic::Ordering::Relaxed) {
- if print {
- println!("Aborting...");
+ if self.debug {
+ println!("info string aborting");
}
break;
}
- if print {
- println!("Finished depth({}) {:?}", depth, search_result);
- }
-
if search_result.0 <= alpha { // Alpha-cutoff
- if print {
- println!("Alpha cutoff {} <= {:?}", search_result.0, (alpha, beta));
- }
gradual_widening_counter += 1;
beta = alpha + window_size * 0.1;
alpha = search_result.0 - window_size * 2.0f32.powi(gradual_widening_counter);
+ println!("info score upperbound {:.0}", beta * 100.0);
continue;
}
if search_result.0 >= beta { // Beta-cutoff
- if print {
- println!("Beta cutoff {:?} <= {}", (alpha, beta), search_result.0);
- }
gradual_widening_counter += 1;
alpha = beta - window_size * 0.1;
beta = search_result.0 + window_size * 2.0f32.powi(gradual_widening_counter);
+ println!("info score lowerbound {:.0}", alpha * 100.0);
continue;
}
@@ -247,11 +238,20 @@ impl Grossmeister {
gradual_widening_counter = 0;
alpha = search_result.0 - window_size;
beta = search_result.0 + window_size;
+
+ {
+ print!("info score cp {:.0} pv ", search_result.0 * 100.0);
+ for mov in &search_result.1 {
+ print!("{} ", mov);
+ }
+ println!();
+ println!("info depth {}", depth);
+ }
+
+ result = Some(search_result);
} else {
panic!("Why the fuck no moves?");
}
-
- result = Some(search_result);
}
match result {