function xdot_val=replicator_rps(v,w,A0)

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

x = v(1:2);
x = [x ;1-sum(x)];
y = v(3:4);
y = [y ;1-sum(y)];

% u1 = A_w*y;
u1=[A_w(1,1)*y(1)+A_w(1,2)*y(2)+A_w(1,3)*y(3);
 A_w(2,1)*y(1)+A_w(2,2)*y(2)+A_w(2,3)*y(3);
 A_w(3,1)*y(1)+A_w(3,2)*y(2)+A_w(3,3)*y(3)];

% u2 = -A_w'*x';
u2=[B_w(1,1)*x(1)+B_w(1,2)*x(2)+B_w(1,3)*x(3);
 B_w(2,1)*x(1)+B_w(2,2)*x(2)+B_w(2,3)*x(3);
 B_w(3,1)*x(1)+B_w(3,2)*x(2)+B_w(3,3)*x(3)];

u_bar = x(1)*u1(1)+x(2)*u1(2)+x(3)*u1(3);
 
xdot_val = [
        x(1) * (u1(1) - u_bar);
        x(2) * (u1(2) - u_bar);
        y(1) * (u2(1) + u_bar);
        y(2) * (u2(2) + u_bar)];

end