#!/usr/bin/python
# -*- coding: UTF-8 -*-

import numpy as np

def Analytic_ER_rule(r,w,p):
    m = len(p)
    n = len(p[0])
    P_fin = []
    k1 = 0
    for i in range(0, n):
        temp = 1
        for j in range(0, m):
            temp = ((w[j] * p[j, i] + 1 - r[j]) / (1 + w[j] - r[j])) * temp
            pass
        k1 = temp + k1
    k2 = 1
    for i in range(0, m):
        k2 = ((1 - r[i]) / (1 + w[i] - r[i])) * k2
        pass
    k2 = (n - 1) * k2
    k = k1 - k2
    k = 1 / k
    for i in range(0, n):
        sec1 = 1
        sec2 = 1
        for j in range(0, m):
            sec1 = ((w[j] * p[j, i] + 1 - r[j]) / (1 + w[j] - r[j])) * sec1
            sec2 = ((1 - r[j]) / (1 + w[j] - r[j])) * sec2
        numerator = k * (sec1 - sec2)
        denominator = 1 - (k * sec2)
        a = numerator / denominator
        if denominator==0:
            P_fin.append(0)
        else:
            P_fin.append(a)
    return P_fin



