import numpy as np
import matplotlib.pyplot as plt
import sympy as sym
import math
import os
import subprocess
import fileinput
import re
import matlab.engine
# from subprocess import Popen, PIPE
#import sys




print('Running Python Code')
InputFile  = "/inputs/cellsolver.parset"
OutputFile = "/outputs/output.txt"
# path = os.getcwd()
# InputFilePath = os.getcwd()+InputFile
# OutputFilePath = os.getcwd()+OutputFile
# --------- Run  from src folder:
path_parent = os.path.dirname(os.getcwd())
os.chdir(path_parent)
path = os.getcwd()
print(path)
InputFilePath = os.getcwd()+InputFile
OutputFilePath = os.getcwd()+OutputFile
print("InputFilepath: ", InputFilePath)
print("OutputFilepath: ", OutputFilePath)
print("Path: ", path)


#1.  Define Gamma-Array..
#2. for(i=0; i<length(array)) ..compute mu_gamma..

# matrix = np.loadtxt(path + 'Qmatrix.txt', usecols=range(3))
# print(matrix)

# Use Shell Commands:
# subprocess.run('ls', shell=True)


#---------------------------------------------------------------

Gamma_Values = np.linspace(0.01, 2.5, num=12)
print(Gamma_Values)

mu_gamma = []
# mu_gamma.append(1)
# np.append(mu_gamma,[[1]])
print("Values for Gamma:", mu_gamma)



RUN = True
# RUN = False

if RUN:
    for gamma in Gamma_Values:
        print("Run Cell-Problem for Gamma = ", gamma)
        # print('gamma='+str(gamma))
        with open(InputFilePath, 'r') as file:
            filedata = file.read()
        filedata = re.sub('(?m)^gamma=.*','gamma='+str(gamma),filedata)
        f = open(InputFilePath,'w')
        f.write(filedata)
        f.close()
        # Run Cell-Problem
        subprocess.run(['./build-cmake/src/dune-microstructure', './inputs/cellsolver.parset'],
                                             capture_output=True, text=True)
        #Extract mu_gamma from Output-File
        with open(OutputFilePath, 'r') as file:
            output = file.read()
        tmp = re.search(r'(?m)^mu_gamma=.*',output).group()
        s = re.findall(r"[-+]?\d*\.\d+|\d+", tmp)
        mu_gammaValue = float(s[0])
        print("mu_gamma:", mu_gammaValue)
        mu_gamma.append(mu_gammaValue)
    # ------------end of for-loop -----------------
    print("(Output) Values of mu_gamma: ", mu_gamma)
# ----------------end of if-statement -------------

# mu_gamma=[2.06099, 1.90567, 1.905]
# mu_gamma=[2.08306, 1.905, 1.90482, 1.90479, 1.90478, 1.90477]

##Gamma_Values = np.linspace(0.01, 20, num=12) :
#mu_gamma= [2.08306, 1.91108, 1.90648, 1.90554, 1.90521, 1.90505, 1.90496, 1.90491, 1.90487, 1.90485, 1.90483, 1.90482]

##Gamma_Values = np.linspace(0.01, 2.5, num=12)
# mu_gamma=[2.08306, 2.01137, 1.96113, 1.93772, 1.92592, 1.91937, 1.91541, 1.91286, 1.91112, 1.90988, 1.90897, 1.90828]


# Make Plot
plt.figure()
plt.title(r'$\mu_\gamma(\gamma)$-Plot')  # USE MATHEMATICAL EXPRESSIONS IN TITLE
# plt.plot(Gamma_Values, mu_gamma, 'r--')
plt.plot(Gamma_Values, mu_gamma)
plt.scatter(Gamma_Values, mu_gamma)
# plt.axis([0, 6, 0, 20])

# # Plot q1, q2 "points"
# plt.plot(0,2.08333,'o-')
# plt.plot(Gamma_Values[-1],1.90476,'o-')
# plt.annotate('$q_1$', (0,2.08333))
# plt.annotate('$q_2$', (Gamma_Values[-1],1.90476))
# # plt.plot(0,2.08333,'bs')
# # plt.plot(Gamma_Values[-1],1.90476,'g^')

# plt.annotate('local max', xy=(2, 1), xytext=(3, 1.5),  #location beeing annotated and the location of the text
#              arrowprops=dict(facecolor='black', shrink=0.05),
#              )

plt.axhline(y = 1.90476, color = 'b', linestyle = ':', label='$q_1$')
plt.axhline(y = 2.08333, color = 'r', linestyle = 'dashed', label='$q_2$')
plt.xlabel("$\gamma$")
plt.ylabel("$\mu_\gamma$")
plt.legend()
plt.show()


# SubPlot Diagram ----
# Gamma_Values1 = np.linspace(0.01, 20, num=12)
# Gamma_Values2 = np.linspace(0.01, 2.5, num=12)
# mu_gamma1 = [2.08306, 1.91108, 1.90648, 1.90554, 1.90521, 1.90505, 1.90496, 1.90491, 1.90487, 1.90485, 1.90483, 1.90482]
# mu_gamma2 = [2.08306, 2.01137, 1.96113, 1.93772, 1.92592, 1.91937, 1.91541, 1.91286, 1.91112, 1.90988, 1.90897, 1.90828]
#
# plt.figure()
#
# plt.subplot(211)
# plt.title(r'$\mu_\gamma$')
# plt.plot(Gamma_Values1 , mu_gamma1)
# plt.plot(0,2.08333,'o-')
# plt.plot(Gamma_Values1[-1],1.90476,'o-')
# plt.annotate('$q_1$', (0,2.08333))
# plt.annotate('$q_2$', (Gamma_Values1[-1],1.90476))
#
# plt.subplot(212)
# plt.title(r'$\mu_\gamma$')
# plt.plot(Gamma_Values2 , mu_gamma2)
# plt.plot(0,2.08333,'o-')
# plt.plot(Gamma_Values2[-1],1.90476,'o-')
# plt.annotate('$q_1$', (0,2.08333))
# plt.annotate('$q_2$', (Gamma_Values2[-1],1.90476))
# plt.show()


# ------------- RUN Matlab symbolic minimization program
eng = matlab.engine.start_matlab()
s = eng.genpath('Matlab-Programs')
eng.addpath(s, nargout=0)
eng.Minimization_Script(nargout=0)  #Name of program:Minimization_Script




#
# #---------------------------------------------------------------
# CellProblem_Output  = subprocess.run(['./build-cmake/src/dune-microstructure', './inputs/cellsolver.parset'],
#                                      capture_output=True, text=True)
#
# print("--------- first run ------- \n", CellProblem_Output.stdout) # Print Cell-Problem Output
# # -----------CHANGE VALUES IN THE PARSET : -----------------
# with open(InputFilePath, 'r') as file:
#    filedata = file.read()
#    print(filedata)
# filedata=re.sub('(?m)^gamma=.*','gamma=51.0',filedata)
# f = open(InputFilePath,'w')
# f.write(filedata)
# print(filedata)
# f.close()
# # # ---------------------------------------------------------
# CellProblem_Output  = subprocess.run(['./build-cmake/src/dune-microstructure', './inputs/cellsolver.parset'], capture_output=True, text=True)
#
# print("--------- second run ------- \n", CellProblem_Output.stdout) # Print Cell-Problem Output
#
# # --- Output
# with open(OutputFilePath, 'r') as file:
#     output = file.read()
#     print(output)
# print("TESTING SEARCH MU_GAMMA: \n")
# tmp = re.search(r'(?m)^mu_gamma=.*',output).group()
# print(tmp)
# s = re.findall(r"[-+]?\d*\.\d+|\d+", tmp)
# # print(s)
# # print(s[0])
# mu_gamma = float(s[0])
# # print(type(mu_gamma))
# #---------------------------------------------------------------