#include #define rep0(i,n) for (int i = 0; i < (n); ++i) #define rep1(i,n) for (int i = 1; i < (n); ++i) #define REP(i,a,b) for (int i = a; i < (b); ++i) #define mREP(i,a,b) for (int i = a; i > (b); --i) #define all(x) (x).begin(),(x).end() const int INF = 1000000007; typedef long long ll; using namespace std; template inline bool chmax(T& a, T b) { if (a < b) { a = b; return 1; } return 0; } template inline bool chmin(T& a, T b) { if (a > b) { a = b; return 1; } return 0; } ll gcd(ll a, ll b) { return b ? gcd(b, a%b) : a; } int main(){ ll a,b; cin >> a >> b; ll ans = (a%INF) * (b%INF) % INF; cout << ans << endl; return 0; }