mirror of
https://github.com/correl/mage.git
synced 2025-01-12 03:00:13 +00:00
AI: disable outdated suggested file usage and disk access;
This commit is contained in:
parent
c835fb409d
commit
6cbc970414
1 changed files with 20 additions and 14 deletions
|
@ -54,8 +54,11 @@ public class ComputerPlayer6 extends ComputerPlayer /*implements Player*/ {
|
||||||
protected Combat combat;
|
protected Combat combat;
|
||||||
protected int currentScore;
|
protected int currentScore;
|
||||||
protected SimulationNode2 root;
|
protected SimulationNode2 root;
|
||||||
private static final String FILE_WITH_INSTRUCTIONS = "config/ai.please.cast.this.txt";
|
|
||||||
private final List<String> suggested = new ArrayList<>();
|
private static final boolean AI_SUGGEST_BY_FILE_ENABLE = true; // old method to instruct AI to play cards (use cheat commands instead now)
|
||||||
|
private static final String AI_SUGGEST_BY_FILE_SOURCE = "config/ai.please.cast.this.txt";
|
||||||
|
private final List<String> suggestedActions = new ArrayList<>();
|
||||||
|
|
||||||
protected Set<String> actionCache;
|
protected Set<String> actionCache;
|
||||||
private static final List<TreeOptimizer> optimizers = new ArrayList<>();
|
private static final List<TreeOptimizer> optimizers = new ArrayList<>();
|
||||||
protected int lastLoggedTurn = 0;
|
protected int lastLoggedTurn = 0;
|
||||||
|
@ -165,8 +168,8 @@ public class ComputerPlayer6 extends ComputerPlayer /*implements Player*/ {
|
||||||
if (ability.isUsesStack()) {
|
if (ability.isUsesStack()) {
|
||||||
usedStack = true;
|
usedStack = true;
|
||||||
}
|
}
|
||||||
if (!suggested.isEmpty() && !(ability instanceof PassAbility)) {
|
if (!suggestedActions.isEmpty() && !(ability instanceof PassAbility)) {
|
||||||
Iterator<String> it = suggested.iterator();
|
Iterator<String> it = suggestedActions.iterator();
|
||||||
while (it.hasNext()) {
|
while (it.hasNext()) {
|
||||||
String action = it.next();
|
String action = it.next();
|
||||||
Card card = game.getCard(ability.getSourceId());
|
Card card = game.getCard(ability.getSourceId());
|
||||||
|
@ -286,7 +289,7 @@ public class ComputerPlayer6 extends ComputerPlayer /*implements Player*/ {
|
||||||
root = root.children.get(0);
|
root = root.children.get(0);
|
||||||
}
|
}
|
||||||
logger.trace("Sim getNextAction -- game value:" + game.getState().getValue(true) + " test value:" + test.gameValue);
|
logger.trace("Sim getNextAction -- game value:" + game.getState().getValue(true) + " test value:" + test.gameValue);
|
||||||
if (!suggested.isEmpty()) {
|
if (!suggestedActions.isEmpty()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (root.playerId.equals(playerId)
|
if (root.playerId.equals(playerId)
|
||||||
|
@ -915,10 +918,10 @@ public class ComputerPlayer6 extends ComputerPlayer /*implements Player*/ {
|
||||||
sim.setSimulation(true);
|
sim.setSimulation(true);
|
||||||
for (Player copyPlayer : sim.getState().getPlayers().values()) {
|
for (Player copyPlayer : sim.getState().getPlayers().values()) {
|
||||||
Player origPlayer = game.getState().getPlayers().get(copyPlayer.getId()).copy();
|
Player origPlayer = game.getState().getPlayers().get(copyPlayer.getId()).copy();
|
||||||
if (!suggested.isEmpty()) {
|
if (!suggestedActions.isEmpty()) {
|
||||||
logger.debug(origPlayer.getName() + " suggested: " + suggested);
|
logger.debug(origPlayer.getName() + " suggested: " + suggestedActions);
|
||||||
}
|
}
|
||||||
SimulatedPlayer2 newPlayer = new SimulatedPlayer2(copyPlayer.getId(), copyPlayer.getId().equals(playerId), suggested);
|
SimulatedPlayer2 newPlayer = new SimulatedPlayer2(copyPlayer.getId(), copyPlayer.getId().equals(playerId), suggestedActions);
|
||||||
newPlayer.restore(origPlayer);
|
newPlayer.restore(origPlayer);
|
||||||
sim.getState().getPlayers().put(copyPlayer.getId(), newPlayer);
|
sim.getState().getPlayers().put(copyPlayer.getId(), newPlayer);
|
||||||
}
|
}
|
||||||
|
@ -954,21 +957,24 @@ public class ComputerPlayer6 extends ComputerPlayer /*implements Player*/ {
|
||||||
}
|
}
|
||||||
|
|
||||||
protected final void getSuggestedActions() {
|
protected final void getSuggestedActions() {
|
||||||
|
if (!AI_SUGGEST_BY_FILE_ENABLE) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
Scanner scanner = null;
|
Scanner scanner = null;
|
||||||
try {
|
try {
|
||||||
File file = new File(FILE_WITH_INSTRUCTIONS);
|
File file = new File(AI_SUGGEST_BY_FILE_SOURCE);
|
||||||
if (file.exists()) {
|
if (file.exists()) {
|
||||||
scanner = new Scanner(file);
|
scanner = new Scanner(file);
|
||||||
while (scanner.hasNextLine()) {
|
while (scanner.hasNextLine()) {
|
||||||
String line = scanner.nextLine();
|
String line = scanner.nextLine();
|
||||||
if (line.startsWith("cast:")
|
if (line.startsWith("cast:")
|
||||||
|| line.startsWith("play:")) {
|
|| line.startsWith("play:")) {
|
||||||
suggested.add(line.substring(5));
|
suggestedActions.add(line.substring(5));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
System.out.println("suggested::");
|
System.out.println("suggested::");
|
||||||
for (int i = 0; i < suggested.size(); i++) {
|
for (int i = 0; i < suggestedActions.size(); i++) {
|
||||||
System.out.println(" " + suggested.get(i));
|
System.out.println(" " + suggestedActions.get(i));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
|
@ -986,13 +992,13 @@ public class ComputerPlayer6 extends ComputerPlayer /*implements Player*/ {
|
||||||
if (action != null
|
if (action != null
|
||||||
&& (action.startsWith("cast:")
|
&& (action.startsWith("cast:")
|
||||||
|| action.startsWith("play:"))) {
|
|| action.startsWith("play:"))) {
|
||||||
suggested.add(action.substring(5));
|
suggestedActions.add(action.substring(5));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getActionCount() {
|
public int getActionCount() {
|
||||||
return suggested.size();
|
return suggestedActions.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected String listTargets(Game game, Targets targets) {
|
protected String listTargets(Game game, Targets targets) {
|
||||||
|
|
Loading…
Reference in a new issue