#include<bits/stdc++.h>
using namespace std;
int n,m,hx,hy;
int h[9][2]={{0,0},{2,1},{1,2},{-1,2},{-2,1},{-2,-1},{-1,-2},{1,-2},{2,-1}};
long long zu[21][21];
bool horse(int x,int y)
{
for (int i=0;i<9;i++)
{
if (x==hx+h[i][0] and y==hy+h[i][1])
return false;
}
return true;
}
int main()
{
cin>>n>>m>>hx>>hy;
for (int i=0;i<=n;i++)
{
if (horse(i,0)==false)
{
break;
}
zu[i][0]=1;
}
for (int j=0;j<=m;j++)
{
if (horse(0,j)==false)
{
break;
}
zu[0][j]=1;
}
for (int i=1;i<=n;i++)
{
for (int j=1;j<=n;j++)
{
if (horse(i,j))
{
zu[i][j]=zu[i-1][j]+zu[i][j-1];
}
}
}
cout<<zu[n][m]<<endl;
return 0;
}