3562: Different Subsets For All Tuples

Memory Limit:256 MB Time Limit:2.000 S
Judge Style:Text Compare Creator:
Submit:0 Solved:0

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