#include <bits/stdc++.h>
using namespace std;

int main() {
  int a,b;
  cin>>a>>b;
  long long kouhuku[a][b];
for(int i=0;i<a;i++){
  for(int j=0;j<b;j++){
    cin>>kouhuku[i][j];
  }
}
 vector<long long> n(a);
  for(int i=0;i<a;i++){
  for(int j=0;j<b;j++){
    n.at(i)=n.at(i)+kouhuku[i][j];
  }
  }
  
  long long dp[a+1][2];
  dp[0][0]=0;
  dp[0][1]=0;
  for(int i=1;i<=a;i++){
    dp[i][0]=max(dp[i-1][0],dp[i-1][1]-n.at(i-1));
      dp[i][1]=max(dp[i-1][1],dp[i-1][0]+n.at(i-1));
  }
  cout<<max(dp[a][0],dp[a][1])%1000000007<<endl;
}