function xdot_val=replicator_sh(x,w,A0)

A_w = A0 + [w(1) w(2);w(3) 0];
B_w=A_w;

u1=[x(2)*(A_w(1,1)-A_w(1,2))+A_w(1,2);
   x(2)*(A_w(2,1)-A_w(2,2))+A_w(2,2)];

u2=[x(1)*(B_w(1,1)-B_w(1,2))+B_w(1,2);
   x(1)*(B_w(2,1)-B_w(2,2))+B_w(2,2)];

u1bar=x(1) * u1(1) + (1 - x(1)) * u1(2);
u2bar=x(2) * u2(1) + (1 - x(2)) * u2(2);

%%replicator
xdot_val=[x(1)*(u1(1)-u1bar);
          x(2)*(u2(1)-u2bar)];
end