Problem1975--Different Subsets For All Tuples

1975: Different Subsets For All Tuples

Time Limit: 2 Sec  Memory Limit: 256 MB
Submit: 0  Solved: 0
[Submit] [Status] [Web Board] [Creator:]

Description

time limit per test
2 seconds
memory limit per test
256 megabytes
input
standard input
output
standard output

For a sequence a of n integers between 1 and m, inclusive, denote f(a) as the number of distinct subsequences of a (including the empty subsequence).

You are given two positive integers n and m. Let S be the set of all sequences of length n consisting of numbers from 1 to m. Compute the sum f(a) over all a in S modulo 109+7.

Input

The only line contains two integers n and m (1≤n,m≤106) − the number of elements in arrays and the upper bound for elements.

Output

Print the only integer c − the desired sum modulo 109+7.

Examples
Input
1 3
Output
6
Input
2 2
Output
14
Input
3 3
Output
174

Source/Category