#include <bits/stdc++.h>
using namespace std;
int b[3005][3005];
int c[3005][3005];
int main()
{
long long n,m,ans=0;
cin >> n >> m;
string a[n+1];
for(int i=0;i<n;i++) {
cin >> a[i];
}
for(int i=0;i<n;i++) {
b[i][m+1]=0;
for(int j=m-1;j>=0;j--) {
b[i][j]=b[i][j+1];
if(a[i][j]=='O') {
b[i][j]++;
}
}
}
for(int i=n-1;i>=0;i--) {
for(int j=0;j<m;j++) {
c[i][j]=c[i+1][j];
if(a[i][j]=='I') {
c[i][j]++;
}
}
}
for(int i=0;i<n;i++) {
for(int j=0;j<m;j++) {
if(a[i][j]=='J') {
ans+=b[i][j]*c[i][j];
}
}
}
cout << ans << endl;
}