//No.146 試験監督(1) #pragma GCC optimize("O3") #pragma GCC target("avx") #include #define rep(i ,n) for(int i=0;i<(int)(n);++i) typedef long long int i64; typedef unsigned long long u64; const i64 MOD = 1e9 + 7; using namespace std; i64 modpow(i64 a, i64 n = MOD-2) { i64 r=1; while(n) r=r*((n%2)?a:1)%MOD,a=a*a%MOD,n>>=1; return r; } signed main(){ int n; cin >> n; u64 ans = 0; u64 a , b; rep( i , n ){ cin >> a >> b; a = ( a + 1 ) / 2; ans += modpow( a * b , MOD ); } cout << ans << endl; }