#include <bits/extc++.h>
#include <bits/stdc++.h>
using namespace std;
#define int int64_t
typedef int64_t ftype;
typedef complex<ftype> point;
#define x real
#define y imag
ftype dot(point a, point b)
{
return (conj(a) * b).x();
}
ftype cross(point a, point b)
{
return (conj(a) * b).y();
}
const int mod = 998244353;
void add_mod(int &a, int b)
{
a += b;
while(a >= mod)
a -= mod;
while(a < 0)
a += mod;
}
signed main()
{
//freopen("input.txt", "r", stdin);
ios::sync_with_stdio(0);
cin.tie(0);
int n;
cin >> n;
point r[n];
for(int i = 0; i < n; i++)
{
int x, y;
cin >> x >> y;
r[i] = {x, y};
}
int ans = 0;
for(int s = 0; s < n; s++)
{
point o = r[s];
vector<point> pts;
for(int i = 0; i < n; i++)
if(r[i].y() > o.y() || r[i].y() == o.y() && r[i].x() > o.x())
pts.push_back(r[i]);
sort(begin(pts), end(pts), [&](point a, point b)
{return cross(a - o, b - o) < 0 || cross(a - o, b - o) == 0 && norm(a) < norm(b);});
int m = pts.size();
int dp[m][m];
for(int i = 0; i < m; i++)
for(int j = 0; j < m; j++)
dp[i][j] = 0;
for(int r = 0; r < m; r++)
for(int l = 0; l < r; l++)
{
if(cross(pts[r] - o, pts[l] - o) == 0)
continue;
dp[l][r] = 1;
for(int p = 0; p < l; p++)
if(cross(pts[p] - o, pts[l] - o) == 0)
add_mod(dp[l][r], dp[l][r]);
for(int p = 0; p < l; p++)
if(cross(pts[l] - pts[p], pts[r] - pts[p]) < 0)
add_mod(dp[l][r], dp[p][l]);
for(int p = l + 1; p < r; p++)
if(cross(pts[r] - pts[l], pts[p] - pts[l]) <= 0)
add_mod(dp[l][r], dp[l][r]);
add_mod(ans, dp[l][r]);
}
}
cout << ans << endl;
return 0;
}
I2luY2x1ZGUgPGJpdHMvZXh0YysrLmg+CiNpbmNsdWRlIDxiaXRzL3N0ZGMrKy5oPgoKdXNpbmcgbmFtZXNwYWNlIHN0ZDsKCiNkZWZpbmUgaW50IGludDY0X3QKCnR5cGVkZWYgaW50NjRfdCBmdHlwZTsKdHlwZWRlZiBjb21wbGV4PGZ0eXBlPiBwb2ludDsKI2RlZmluZSB4IHJlYWwKI2RlZmluZSB5IGltYWcKCmZ0eXBlIGRvdChwb2ludCBhLCBwb2ludCBiKQp7CglyZXR1cm4gKGNvbmooYSkgKiBiKS54KCk7Cn0KCmZ0eXBlIGNyb3NzKHBvaW50IGEsIHBvaW50IGIpCnsKCXJldHVybiAoY29uaihhKSAqIGIpLnkoKTsKfQoKY29uc3QgaW50IG1vZCA9IDk5ODI0NDM1MzsKCnZvaWQgYWRkX21vZChpbnQgJmEsIGludCBiKQp7CglhICs9IGI7Cgl3aGlsZShhID49IG1vZCkKCQlhIC09IG1vZDsKCXdoaWxlKGEgPCAwKQoJCWEgKz0gbW9kOwp9CgpzaWduZWQgbWFpbigpCnsKCS8vZnJlb3BlbigiaW5wdXQudHh0IiwgInIiLCBzdGRpbik7Cglpb3M6OnN5bmNfd2l0aF9zdGRpbygwKTsKCWNpbi50aWUoMCk7CglpbnQgbjsKCWNpbiA+PiBuOwoJcG9pbnQgcltuXTsKCWZvcihpbnQgaSA9IDA7IGkgPCBuOyBpKyspCgl7CgkJaW50IHgsIHk7CgkJY2luID4+IHggPj4geTsKCQlyW2ldID0ge3gsIHl9OwoJfQoJaW50IGFucyA9IDA7Cglmb3IoaW50IHMgPSAwOyBzIDwgbjsgcysrKQoJewoJCXBvaW50IG8gPSByW3NdOwoJCXZlY3Rvcjxwb2ludD4gcHRzOwoJCWZvcihpbnQgaSA9IDA7IGkgPCBuOyBpKyspCgkJCWlmKHJbaV0ueSgpID4gby55KCkgfHwgcltpXS55KCkgPT0gby55KCkgJiYgcltpXS54KCkgPiBvLngoKSkKCQkJCXB0cy5wdXNoX2JhY2socltpXSk7CgkJc29ydChiZWdpbihwdHMpLCBlbmQocHRzKSwgWyZdKHBvaW50IGEsIHBvaW50IGIpCgkJCXtyZXR1cm4gY3Jvc3MoYSAtIG8sIGIgLSBvKSA8IDAgfHwgY3Jvc3MoYSAtIG8sIGIgLSBvKSA9PSAwICYmIG5vcm0oYSkgPCBub3JtKGIpO30pOwoJCWludCBtID0gcHRzLnNpemUoKTsKCQlpbnQgZHBbbV1bbV07CgkJZm9yKGludCBpID0gMDsgaSA8IG07IGkrKykKCQkJZm9yKGludCBqID0gMDsgaiA8IG07IGorKykKCQkJCWRwW2ldW2pdID0gMDsKCQlmb3IoaW50IHIgPSAwOyByIDwgbTsgcisrKQoJCQlmb3IoaW50IGwgPSAwOyBsIDwgcjsgbCsrKQoJCQl7CgkJCQlpZihjcm9zcyhwdHNbcl0gLSBvLCBwdHNbbF0gLSBvKSA9PSAwKQoJCQkJCWNvbnRpbnVlOwoJCQkJZHBbbF1bcl0gPSAxOwoJCQkJZm9yKGludCBwID0gMDsgcCA8IGw7IHArKykKCQkJCQlpZihjcm9zcyhwdHNbcF0gLSBvLCBwdHNbbF0gLSBvKSA9PSAwKQoJCQkJCQlhZGRfbW9kKGRwW2xdW3JdLCBkcFtsXVtyXSk7CgkJCQlmb3IoaW50IHAgPSAwOyBwIDwgbDsgcCsrKQoJCQkJCWlmKGNyb3NzKHB0c1tsXSAtIHB0c1twXSwgcHRzW3JdIC0gcHRzW3BdKSA8IDApCgkJCQkJCWFkZF9tb2QoZHBbbF1bcl0sIGRwW3BdW2xdKTsKCQkJCWZvcihpbnQgcCA9IGwgKyAxOyBwIDwgcjsgcCsrKQoJCQkJCWlmKGNyb3NzKHB0c1tyXSAtIHB0c1tsXSwgcHRzW3BdIC0gcHRzW2xdKSA8PSAwKQoJCQkJCQlhZGRfbW9kKGRwW2xdW3JdLCBkcFtsXVtyXSk7CgkJCQlhZGRfbW9kKGFucywgZHBbbF1bcl0pOwoJCQl9Cgl9Cgljb3V0IDw8IGFucyA8PCBlbmRsOwogICAgcmV0dXJuIDA7Cn0K