#D7591. Spiderweb Trees

    ID: 6307 Type: Default 1000ms 256MiB

Spiderweb Trees

Spiderweb Trees

Let's call a graph with n vertices, each of which has it's own point A_i = (x_i, y_i) with integer coordinates, a planar tree if:

  • All points A_1, A_2, …, A_n are different and no three points lie on the same line.
  • The graph is a tree, i.e. there are exactly n-1 edges there exists a path between any pair of vertices.
  • For all pairs of edges (s_1, f_1) and (s_2, f_2), such that s_1 ≠ s_2, s_1 ≠ f_2, f_1 ≠ s_2, and f_1 ≠ f_2, the segments A_{s_1} A_{f_1} and A_{s_2} A_{f_2} don't intersect.

Imagine a planar tree with n vertices. Consider the convex hull of points A_1, A_2, …, A_n. Let's call this tree a spiderweb tree if for all 1 ≤ i ≤ n the following statements are true:

  • All leaves (vertices with degree ≤ 1) of the tree lie on the border of the convex hull.
  • All vertices on the border of the convex hull are leaves.

An example of a spiderweb tree:

The points A_3, A_6, A_7, A_4 lie on the convex hull and the leaf vertices of the tree are 3, 6, 7, 4.

Refer to the notes for more examples.

Let's call the subset S ⊂ {1, 2, …, n} of vertices a subtree of the tree if for all pairs of vertices in S, there exists a path that contains only vertices from S. Note that any subtree of the planar tree is a planar tree.

You are given a planar tree with n vertexes. Let's call a partition of the set {1, 2, …, n} into non-empty subsets A_1, A_2, …, A_k (i.e. A_i ∩ A_j = ∅ for all 1 ≤ i < j ≤ k and A_1 ∪ A_2 ∪ … ∪ A_k = {1, 2, …, n}) good if for all 1 ≤ i ≤ k, the subtree A_i is a spiderweb tree. Two partitions are different if there exists some set that lies in one parition, but not the other.

Find the number of good partitions. Since this number can be very large, find it modulo 998 244 353.

Input

The first line contains an integer n (1 ≤ n ≤ 100) — the number of vertices in the tree.

The next n lines each contain two integers x_i, y_i (-10^9 ≤ x_i, y_i ≤ 10^9) — the coordinates of i-th vertex, A_i.

The next n-1 lines contain two integers s, f (1 ≤ s, f ≤ n) — the edges (s, f) of the tree.

It is guaranteed that all given points are different and that no three of them lie at the same line. Additionally, it is guaranteed that the given edges and coordinates of the points describe a planar tree.

Output

Print one integer — the number of good partitions of vertices of the given planar tree, modulo 998 244 353.

Examples

Input

4 0 0 0 1 -1 -1 1 -1 1 2 1 3 1 4

Output

5

Input

5 3 2 0 -3 -5 -3 5 -5 4 5 4 2 4 1 5 2 2 3

Output

8

Input

6 4 -5 0 1 -2 8 3 -10 0 -1 -4 -5 2 5 3 2 1 2 4 6 4 2

Output

13

Input

8 0 0 -1 2 -2 5 -5 1 1 3 0 3 2 4 -1 -4 1 2 3 2 5 6 4 2 1 5 5 7 5 8

Output

36

Note

The picture for the first sample.

In the first test case, all good partitions are:

  1. {1}, {2}, {3}, {4};
  2. {1, 2}, {3}, {4};
  3. {1, 3}, {2}, {4};
  4. {1, 4}, {2}, {3};
  5. {1, 2, 3, 4}.

The partition {1, 2, 3}, {4} isn't good, because the subtree {1, 2, 3} isn't spiderweb tree, since the non-leaf vertex 1 lies on the convex hull.

The partition {2, 3, 4}, {1} isn't good, because the subset {2, 3, 4} isn't a subtree.

The picture for the second sample.

In the second test case, the given tree isn't a spiderweb tree, because the leaf vertex 1 doesn't lie on the convex hull. However, the subtree {2, 3, 4, 5} is a spiderweb tree.

The picture for the third sample. The picture for the fourth sample.

In the fourth test case, the partition {1, 2, 3, 4}, {5, 6, 7, 8} is good because all subsets are spiderweb subtrees.

inputFormat

Input

The first line contains an integer n (1 ≤ n ≤ 100) — the number of vertices in the tree.

The next n lines each contain two integers x_i, y_i (-10^9 ≤ x_i, y_i ≤ 10^9) — the coordinates of i-th vertex, A_i.

The next n-1 lines contain two integers s, f (1 ≤ s, f ≤ n) — the edges (s, f) of the tree.

It is guaranteed that all given points are different and that no three of them lie at the same line. Additionally, it is guaranteed that the given edges and coordinates of the points describe a planar tree.

outputFormat

Output

Print one integer — the number of good partitions of vertices of the given planar tree, modulo 998 244 353.

Examples

Input

4 0 0 0 1 -1 -1 1 -1 1 2 1 3 1 4

Output

5

Input

5 3 2 0 -3 -5 -3 5 -5 4 5 4 2 4 1 5 2 2 3

Output

8

Input

6 4 -5 0 1 -2 8 3 -10 0 -1 -4 -5 2 5 3 2 1 2 4 6 4 2

Output

13

Input

8 0 0 -1 2 -2 5 -5 1 1 3 0 3 2 4 -1 -4 1 2 3 2 5 6 4 2 1 5 5 7 5 8

Output

36

Note

The picture for the first sample.

In the first test case, all good partitions are:

  1. {1}, {2}, {3}, {4};
  2. {1, 2}, {3}, {4};
  3. {1, 3}, {2}, {4};
  4. {1, 4}, {2}, {3};
  5. {1, 2, 3, 4}.

The partition {1, 2, 3}, {4} isn't good, because the subtree {1, 2, 3} isn't spiderweb tree, since the non-leaf vertex 1 lies on the convex hull.

The partition {2, 3, 4}, {1} isn't good, because the subset {2, 3, 4} isn't a subtree.

The picture for the second sample.

In the second test case, the given tree isn't a spiderweb tree, because the leaf vertex 1 doesn't lie on the convex hull. However, the subtree {2, 3, 4, 5} is a spiderweb tree.

The picture for the third sample. The picture for the fourth sample.

In the fourth test case, the partition {1, 2, 3, 4}, {5, 6, 7, 8} is good because all subsets are spiderweb subtrees.

样例

8
0 0
-1 2
-2 5
-5 1
1 3
0 3
2 4
-1 -4
1 2
3 2
5 6
4 2
1 5
5 7
5 8
36

</p>