ID:50312
Title:Cowardly Lion
Author:Nick Howe
Date:2008-11-07 15:21:54
Score:8586.4236
Result:8560.19 (cyc: 30, node: 803)
CPU Time:59.9155
Status:Passed
Comments:
Based on:none
Code:
function [dRow,dCol,action,mark] = cowardlylion(mainMap,foodMap,myAntMap,opAntMap, ...
    myScentMap,opScentMap,myDeathMap,opDeathMap)

%dRt = repmat([-1;-1;0;1;1],1,5);
%dCt = dRt';

% mask
mask = isnan(mainMap);
if mask(7)
    mask([1 2 6]) = true;
end;
if mask(9)
    mask([4 5 10]) = true;
end;
if mask(17)
    mask([16 21 22]) = true;
end;
if mask(19)
    mask([20 24 25]) = true;
end;
if mask(8)
    mask(3) = true;
end;
if mask(12)
    mask(11) = true;
end;
if mask(14)
    mask(15) = true;
end;
if mask(18)
    mask(23) = true;
end;
mainMap(mask) = nan;

% decide scent
if (mainMap(13) == 1)
    mark = 100;
else
    mark = floor((max(max(myScentMap(2:4,2:4)))-myScentMap(13)-1)/myAntMap(13));
end;
myScent = myScentMap(13); %+mark*myAntMap(13);
myScentMap(mainMap==1) = inf;

% fight if challenged
if (opAntMap(7)||opAntMap(8)||opAntMap(9)||opAntMap(12)||opAntMap(13)||opAntMap(14)||opAntMap(17)||opAntMap(18)||opAntMap(19))
    action = -1;
    if (sum(myAntMap(:))<9)||(rand < 0.5)
        dRow = 0;
        dCol = 0;
        return
    else
        [r,c] = find(opAntMap(2:4,2:4)&~opAntMap(4:-1:2,4:-1:2));
        if isempty(r)
            action = -1;
            dRow = 0;
            dCol = 0;
            return
        else
            pick = ceil(rand*numel(r));
            dRow = sign(r(pick)-2);
            dCol = sign(c(pick)-2);
        end;
    end;
end;

% look for food
action = 0;
foodMap(mainMap==1) = 0;
netFood = foodMap-myAntMap;
netFood(mask) = 0;
netFood(mainMap==1) = 0;
if (foodMap(13) > 0)&&(rand > (myAntMap(13)-foodMap(13))/myAntMap(13))
    lowFood = (netFood>0)&(myScentMap<myScent);
    hiFood = (netFood>0)&(myScentMap>myScent);
    myFood = foodMap(13);
    if ~any(lowFood(:))||((foodMap(13) > 1)&&(rand > sqrt(1/foodMap(13))))
        % carry home
        action = 1;
        myScentMap(mask) = -inf;
        myScentMap(13) = -inf;
        maxScent = max(myScentMap(:));
        if (maxScent == 0)
            mainMap(13) = nan;
            [r,c] = find(~isnan(mainMap(2:4,2:4)));
            pick = ceil(rand*numel(r));
            dRow = sign(r(pick)-2);
            dCol = sign(c(pick)-2);
        else
            [r,c] = find(myScentMap==maxScent);
            dRow = sign(r(1)-3);
            dCol = sign(c(1)-3);
        end;
    else
        % gather lower
        bottomFood = min(myScentMap(lowFood>0));
        [r,c] = find((lowFood>0)&(myScentMap==bottomFood));
        dRow = sign(r(1)-3);
        dCol = sign(c(1)-3);
    end;
elseif (any(netFood(:) > 0))
    % gather
    bottomFood = min(myScentMap(netFood>0));
    [r,c] = find((netFood>0)&(myScentMap==bottomFood));
    %[r,c] = find(netFood==max(netFood(:)));
    dRow = sign(r(1)-3);
    dCol = sign(c(1)-3);
else
    % explore
    if (rand>.9)
        mainMap(13) = nan;
        [r,c] = find(~isnan(mainMap(2:4,2:4)));
        pick = ceil(rand*numel(r));
        dRow = sign(r(pick)-2);
        dCol = sign(c(pick)-2);
    else
        myScentMap(mask) = inf;
        myScentMap(13) = inf;
        [r,c] = find(myScentMap==min(myScentMap(:)));
        pick = ceil(rand*numel(r));
        dRow = sign(r(pick)-3);
        dCol = sign(c(pick)-3);
    end;
end;
end