#include<bits/stdc++.h>
using namespace std;
int a[1100][1100],dp[1100][1100],dp1[1100][1100];
int main(){
int n,m;
cin>>n>>m;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
cin>>a[i][j];
}
}
dp[1][1]=a[1][1];
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
if(i==1)
{
dp[i][j]=dp[i][j-1]+a[i][j];
dp[i][j-1]=0;
}
else if(j==1)
{
dp[i][j]=dp[i-1][j]+a[i][j];
dp[i-1][j]=0;
}
else
{
if(dp[i-1][j]>dp[i][j-1]){
dp[i][j]=dp[i-1][j]+a[i][j];
dp[i-1][j]=0;
}
else
{
dp[i][j]=dp[i][j-1]+a[i][j];
dp[i][j-1]=0;
}
}
}
}
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
dp1[i][j]=dp[i][j];
}
}
for(int i=n;i>=1;i--)
{
for(int j=m;j>=1;j--)
{
if(i==n)
{
dp1[i][j]=dp1[i][j+1]+a[i][j];
}
else if(j==m)
{
dp1[i][j]=dp1[i+1][j]+a[i][j];
}
else
{
dp1[i][j]=max(dp1[i+1][j],dp1[i][j+1])+a[i][j];
}
}
}
cout<<dp[n][m]+dp1[1][1];
return 0;
}