diff options
Diffstat (limited to 'src/main.rs')
| -rw-r--r-- | src/main.rs | 43 | 
1 files changed, 39 insertions, 4 deletions
| diff --git a/src/main.rs b/src/main.rs index 3e8e461..13af134 100644 --- a/src/main.rs +++ b/src/main.rs @@ -3,17 +3,52 @@ use std::{f32::INFINITY, time::{Duration, Instant}};  use chessnost::board::Board;  fn main() { +    let increment = Duration::from_secs(0); +    let mut time_left = Duration::from_secs(60 * 10); +    let manual_decrement = Duration::from_secs(7); // Time to sync moves with the game +      let mut board = Board::new(); +    board.print(); +      loop { -        let start = Instant::now(); -        let (score, pv) = board.iterative_deepening(Duration::from_secs(4)); -        println!("Finished in {:?}: score={:?}", start.elapsed(), score); +        time_left += increment; +        time_left -= manual_decrement; + +        let mov = match board.read_move() { +            Ok(m) => m, +            Err(e) => { +                println!("Error: {}", e); +                continue; +            } +        }; +        print!("{:?}", mov); +        board.make_move(mov); +        board.print(); + +        let allowed_move_duration = time_left / 20; +        let max_depth = 6 + (board.ply as i32 / 15) as u8; +        println!("~{:?} left, allocating {:?} for a move", time_left, allowed_move_duration); + +        let move_start = Instant::now(); +        let (score, pv) = board.iterative_deepening(max_depth, allowed_move_duration); +        let elapsed = move_start.elapsed(); + +        if time_left >= elapsed { +            time_left -= elapsed; +        } else { +            println!("You are probably out of time. I will keep going anyway..."); +        } + +        println!("Finished in {:?}: score={:?}", elapsed, score);          let mov = pv[0];          println!("{:?}", mov);          board.make_move(mov);          board.print(); -        println!("Score for {:?} is now: {} (material advantage={})", board.color(), board.quiscence(-INFINITY, INFINITY), board.material_advantage()); +        println!("Score for {:?} is now: {}", board.color(), board.quiscence(-INFINITY, INFINITY)); + +        println!("\nPondering for 3 seconds..."); +        board.iterative_deepening(max_depth - 1, Duration::from_secs(3));      }  } | 
