#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int P = 1e9 + 7;
int n, m, K, U;
ll f[1 << 19], ans;
bool vis[20][20], pos[20][20];
#define lowbit(x) ((x) & -(x))
int main() {
  scanf("%d%d%d", &n, &m, &K);
  for (int i = 1, a, b, c; i <= K; i++)
    scanf("%d%d%d", &a, &b, &c), a--, b--, vis[a][b] = true, pos[a][b] = c;
  n--;
  U = 1 << n;
  f[0] = 1;
  for (int p = 0; p < m; p++) {
    for (int i = 0; i < n; i++) {
      if (!vis[p][i] || pos[p][i])
        for (int j = 0, l = 1 << i; j < U; j += l << 1)
          for (int k = 0; k < l; k++)
            if (f[j + k])
              f[j + k + l - lowbit(j)] += f[j + k];
      if (vis[p][i])
        for (int j = 0, l = 1 << i, k = pos[p][i] ? 0 : l; j < U; j += l << 1)
          memset(f + j + k, 0, l << 3);
    }
    for (int i = 0; i < U; i++)
      if (f[i] >= P)
        f[i] %= P;
  }
  for (int i = 0; i < U; i++)
    ans += f[i];
  printf("%lld\n", ans % P);
  return 0;
}