Little girl Masha likes winter sports, today she's planning to take part in slalom skiing.
The track is represented as a grid composed of
n×m squares. There are rectangular obstacles at the track, composed of grid squares. Masha must get from the square
(1,1) to the square
(n,m). She can move from a square to adjacent square: either to the right, or upwards. If the square is occupied by an obstacle, it is not allowed to move to that square.
One can see that each obstacle can actually be passed in two ways: either it is to the right of Masha's path, or to the left. Masha likes to try all ways to do things, so she would like to know how many ways are there to pass the track. Two ways are considered different if there is an obstacle such that it is to the right of the path in one way, and to the left of the path in the other way.
Help Masha to find the number of ways to pass the track. The number of ways can be quite big, so Masha would like to know it modulo
109+7.
The pictures below show different ways to pass the track in sample tests.