flask/INFERENCE CALCULATOR.py

56 lines
1.6 KiB
Python
Raw Normal View History

2023-06-28 12:03:38 -04:00
import numpy as np
from flask import Flask
from flask import jsonify
from flask import render_template
from flask import request
2023-06-28 12:03:38 -04:00
app = Flask(__name__)
@app.route("/", methods=["GET", "POST"])
2023-06-28 12:03:38 -04:00
def home():
result = None
if request.method == "POST":
2023-06-28 12:03:38 -04:00
# Get the comma-separated string, split by commas, and convert to integer
s_data = np.array(
[int(i) for i in request.form.get("s_data", "").split(",") if i]
)
ns_data = np.array(
[int(i) for i in request.form.get("ns_data", "").split(",") if i]
)
2023-06-28 12:03:38 -04:00
total = sum(s_data) + sum(ns_data)
# Calculate marginal probabilities
marginal_prob_s = s_data / total
marginal_prob_ns = ns_data / total
# Calculate joint probabilities
joint_prob = np.outer(marginal_prob_s, marginal_prob_ns)
# Calculate likelihoods
posterior_s = s_data / sum(s_data)
posterior_ns = ns_data / sum(ns_data)
# likelihood
2023-06-28 12:03:38 -04:00
likelihood_s = marginal_prob_s
likelihood_ns = marginal_prob_ns
# Return results as dictionary
result = {
"JOINT PROBABILITY": joint_prob.tolist(),
"MARGINAL PROBABILITY_S": marginal_prob_s.tolist(),
"MARGINAL PROBABILITY_NS": marginal_prob_ns.tolist(),
"LIKELIHOOD_S": likelihood_s.tolist(),
"LIKELIHOOD_NS": likelihood_ns.tolist(),
"POSTERIOR_S": posterior_s.tolist(),
"POSTERIOR_NS": posterior_ns.tolist(),
2023-06-28 12:03:38 -04:00
}
return render_template("index.html", result=result)
2023-06-28 12:03:38 -04:00
if __name__ == "__main__":
2023-06-28 12:03:38 -04:00
app.run(debug=True)