#include <iostream>
#include <vector>
using namespace std;
bool mp[101][101] = {false};
int dx[] = {1, 0, -1, 0};
int dy[] = {0, -1, 0, 1};
bool isValid(int x, int y) {
return x >= 0 && x <= 100 && y >= 0 && y <= 100;
}
pair<int, int> turn(pair<int, int>& o, pair<int, int>& p) {
auto c = make_pair(p.first-o.first, p.second-o.second);
return make_pair(o.first+c.second, o.second-c.first);
}
void func(int x, int y, int d, int g) {
vector<pair<int, int>> v;
v.push_back({x, y});
v.push_back({x+dx[d], y+dy[d]});
while(g--) {
auto o = v.back();
for(int i = v.size()-2; i >= 0; i--)
v.push_back(turn(o, v[i]));
}
for(auto& p : v) {
if(isValid(p.first, p.second))
mp[p.second][p.first] = true;
}
}
int check() {
int result = 0;
for(int y = 0; y < 100; y++) {
for(int x = 0; x < 100; x++)
if(mp[y][x] && mp[y+1][x] && mp[y][x+1] && mp[y+1][x+1])
result++;
}
return result;
}
int main() {
int t;
cin >> t;
while(t--) {
int x, y, d, g;
cin >> x >> y >> d >> g;
func(x, y, d, g);
}
cout << check();
return 0;
}
I2luY2x1ZGUgPGlvc3RyZWFtPgojaW5jbHVkZSA8dmVjdG9yPgp1c2luZyBuYW1lc3BhY2Ugc3RkOwoKYm9vbCBtcFsxMDFdWzEwMV0gPSB7ZmFsc2V9OwppbnQgZHhbXSA9IHsxLCAwLCAtMSwgMH07CmludCBkeVtdID0gezAsIC0xLCAwLCAxfTsKCmJvb2wgaXNWYWxpZChpbnQgeCwgaW50IHkpIHsKICAgIHJldHVybiB4ID49IDAgJiYgeCA8PSAxMDAgJiYgeSA+PSAwICYmIHkgPD0gMTAwOwp9CgpwYWlyPGludCwgaW50PiB0dXJuKHBhaXI8aW50LCBpbnQ+JiBvLCBwYWlyPGludCwgaW50PiYgcCkgewogICAgYXV0byBjID0gbWFrZV9wYWlyKHAuZmlyc3Qtby5maXJzdCwgcC5zZWNvbmQtby5zZWNvbmQpOwogICAgcmV0dXJuIG1ha2VfcGFpcihvLmZpcnN0K2Muc2Vjb25kLCBvLnNlY29uZC1jLmZpcnN0KTsKfQoKdm9pZCBmdW5jKGludCB4LCBpbnQgeSwgaW50IGQsIGludCBnKSB7CiAgICB2ZWN0b3I8cGFpcjxpbnQsIGludD4+IHY7CiAgICB2LnB1c2hfYmFjayh7eCwgeX0pOwogICAgdi5wdXNoX2JhY2soe3grZHhbZF0sIHkrZHlbZF19KTsKICAgIAogICAgd2hpbGUoZy0tKSB7CiAgICAgICAgYXV0byBvID0gdi5iYWNrKCk7CiAgICAgICAgZm9yKGludCBpID0gdi5zaXplKCktMjsgaSA+PSAwOyBpLS0pCiAgICAgICAgICAgIHYucHVzaF9iYWNrKHR1cm4obywgdltpXSkpOwogICAgfQogICAgCiAgICBmb3IoYXV0byYgcCA6IHYpIHsKICAgICAgICBpZihpc1ZhbGlkKHAuZmlyc3QsIHAuc2Vjb25kKSkKICAgICAgICAgICAgbXBbcC5zZWNvbmRdW3AuZmlyc3RdID0gdHJ1ZTsKICAgIH0KfQoKaW50IGNoZWNrKCkgewogICAgaW50IHJlc3VsdCA9IDA7CiAgICBmb3IoaW50IHkgPSAwOyB5IDwgMTAwOyB5KyspIHsKICAgICAgICBmb3IoaW50IHggPSAwOyB4IDwgMTAwOyB4KyspCiAgICAgICAgICAgIGlmKG1wW3ldW3hdICYmIG1wW3krMV1beF0gJiYgbXBbeV1beCsxXSAmJiBtcFt5KzFdW3grMV0pCiAgICAgICAgICAgICAgICByZXN1bHQrKzsKICAgIH0KICAgIHJldHVybiByZXN1bHQ7Cn0KCmludCBtYWluKCkgewogICAgaW50IHQ7CiAgICBjaW4gPj4gdDsKICAgIHdoaWxlKHQtLSkgewogICAgICAgIGludCB4LCB5LCBkLCBnOwogICAgICAgIGNpbiA+PiB4ID4+IHkgPj4gZCA+PiBnOwogICAgICAgIGZ1bmMoeCwgeSwgZCwgZyk7CiAgICB9CiAgICBjb3V0IDw8IGNoZWNrKCk7CiAgICByZXR1cm4gMDsKfQ==