diff --git a/src/ClassifyMin.py b/src/ClassifyMin.py index 1f78c5ef9c9151c4cfee49b3a455d8e73882f7ae..e2d08c74f37047b61c26f367482b9339ddda038d 100644 --- a/src/ClassifyMin.py +++ b/src/ClassifyMin.py @@ -75,6 +75,17 @@ def classifyMin_ana(alpha,beta,theta,q3,mu_1,rho_1,print_Cases=False, print_Outp +# Matrix Version that just gets matrices Q & B +def classifyMin_mat(Q,B,print_Cases=False, print_Output=False): + q1 = Q[0][0] + q2 = Q[1][1] + q3 = Q[2][2] + q12 = Q[0][1] + b1 = B[0] + b2 = B[1] + b3 = B[2] + return classifyMin(q1, q2, q3, q12, b1, b2, print_Cases, print_Output) + # -------------------------------------------------------------------- # Classify Type of minimizer 1 = R1 , 2 = R2 , 3 = R3 # before : destinction between which axis.. (4Types ) diff --git a/src/HelperFunctions.py b/src/HelperFunctions.py index b819eaf89ac5da9620d8db27921cec6b1e3f7960..7007d5de2ee64059746a5a4470d0f0ed55391ef1 100644 --- a/src/HelperFunctions.py +++ b/src/HelperFunctions.py @@ -94,13 +94,18 @@ def RunCellProblem(alpha,beta,theta,gamma,mu1,rho1, InputFilePath = os.path.dirn + + + + + def GetCellOutput(alpha,beta,theta,gamma,mu1,rho1, InputFilePath = os.path.dirname(os.getcwd()) +"/inputs/computeMuGamma.parset", OutputFilePath = os.path.dirname(os.getcwd()) + "/outputs/outputMuGamma.txt" ): RunCellProblem(alpha,beta,theta,gamma,mu1,rho1, InputFilePath) print('Read effective quantities...') Q, B = ReadEffectiveQuantities() - print('Q:', Q) - print('B:', B) + # print('Q:', Q) + # print('B:', B) return Q, B diff --git a/src/PhaseDiagram.py b/src/PhaseDiagram.py index 35081eb7b376b71c0878a81987ce96f05d6546d5..3d68b230ee06de24c4d64733163e86a4db08e0ad 100644 --- a/src/PhaseDiagram.py +++ b/src/PhaseDiagram.py @@ -118,9 +118,9 @@ beta = 2.0 theta = 1.0/4.0 #set gamma either to 1. '0' 2. 'infinity' or 3. a numerical positive value gamma = '0' -gamma = 'infinity' +# gamma = 'infinity' # gamma = 0.5 -# gamma = 0.25 +gamma = 0.25 # gamma = 1.0 print('---- Input parameters: -----') @@ -133,150 +133,169 @@ print('gamma:', gamma) print('----------------------------') # ---------------------------------------------------------------- -# muGamma = GetMuGamma(beta,theta,gamma,mu1,rho1,InputFilePath) -# # muGamma = GetMuGamma(beta,theta,gamma,mu1,rho1) -# print('Test MuGamma:', muGamma) -# ------- Options -------- -# print_Cases = True -# print_Output = True +# gamma_min = 0.05 +# gamma_max = 2.0 - #TODO -# generalCase = False #Read Output from Cell-Problem instead of using Lemma1.4 (special case) +gamma_min = 1 +gamma_max = 1 +Gamma_Values = np.linspace(gamma_min, gamma_max, num=1) -# make_3D_plot = True -make_3D_PhaseDiagram = True -make_2D_plot = False -make_2D_PhaseDiagram = False -make_3D_plot = False -# make_3D_PhaseDiagram = False -# make_2D_plot = True -# make_2D_PhaseDiagram = True +# Gamma_Values = np.linspace(gamma_min, gamma_max, num=13) # TODO variable Input Parameters...alpha,beta... +print('(Input) Gamma_Values:', Gamma_Values) +for gamma in Gamma_Values: -# --- Define effective quantities: q1, q2 , q3 = mu_gamma, q12 --- -# q1 = harmonicMean(mu1, beta, theta) -# q2 = arithmeticMean(mu1, beta, theta) -# --- Set q12 -# q12 = 0.0 # (analytical example) # TEST / TODO read from Cell-Output + # muGamma = GetMuGamma(beta,theta,gamma,mu1,rho1,InputFilePath) + # # muGamma = GetMuGamma(beta,theta,gamma,mu1,rho1) + # print('Test MuGamma:', muGamma) + # ------- Options -------- + # print_Cases = True + # print_Output = True + #TODO + generalCase = True #Read Output from Cell-Problem instead of using Lemma1.4 (special case) + # make_3D_plot = True + # make_3D_PhaseDiagram = True + make_2D_plot = False + # make_2D_PhaseDiagram = False + make_3D_plot = False + make_3D_PhaseDiagram = False + # make_2D_plot = True + make_2D_PhaseDiagram = True -# b1 = prestrain_b1(rho1, beta, alpha, theta) -# b2 = prestrain_b2(rho1, beta, alpha, theta) -# -# print('---- Input parameters: -----') -# print('mu1: ', mu1) -# print('rho1: ', rho1) -# print('alpha: ', alpha) -# print('beta: ', beta) -# print('theta: ', theta) -# print("q1: ", q1) -# print("q2: ", q2) -# print("mu_gamma: ", mu_gamma) -# print("q12: ", q12) -# print("b1: ", b1) -# print("b2: ", b2) -# print('----------------------------') -# print("machine epsilon", sys.float_info.epsilon) - -# G, angle, type, kappa = classifyMin(q1, q2, mu_gamma, q12, b1, b2, print_Cases, print_Output) -# Test = f(1,2 ,q1,q2,mu_gamma,q12,b1,b2) -# print("Test", Test) - -# ---------------------- MAKE PLOT / Write to VTK------------------------------------------------------------------------------ - -# SamplePoints_3D = 10 # Number of sample points in each direction -# SamplePoints_2D = 10 # Number of sample points in each direction -SamplePoints_3D = 300 # Number of sample points in each direction -SamplePoints_2D = 10 # Number of sample points in each direction - - - -if make_3D_PhaseDiagram: - alphas_ = np.linspace(-20, 20, SamplePoints_3D) - betas_ = np.linspace(0.01,40.01,SamplePoints_3D) - thetas_ = np.linspace(0.01,0.99,SamplePoints_3D) - # print('type of alphas', type(alphas_)) - # print('Test:', type(np.array([mu_gamma])) ) - alphas, betas, thetas = np.meshgrid(alphas_, betas_, thetas_, indexing='ij') - classifyMin_anaVec = np.vectorize(classifyMin_ana) - - # Get MuGamma values ... - GetMuGammaVec = np.vectorize(GetMuGamma) - muGammas = GetMuGammaVec(betas, thetas, gamma, mu1, rho1) - # Classify Minimizers.... - G, angles, Types, curvature = classifyMin_anaVec(alphas, betas, thetas, muGammas, mu1, rho1) # Sets q12 to zero!!! - # print('size of G:', G.shape) - # print('G:', G) - # Out = classifyMin_anaVec(alphas,betas,thetas) - # T = Out[2] - # --- Write to VTK - GammaString = str(gamma) - - VTKOutputName = "outputs/PhaseDiagram3D" + "Gamma" + GammaString - gridToVTK(VTKOutputName , alphas, betas, thetas, pointData = {'Type': Types, 'angles': angles, 'curvature': curvature} ) - print('Written to VTK-File:', VTKOutputName ) - -if make_2D_PhaseDiagram: - # alphas_ = np.linspace(-20, 20, SamplePoints_2D) - # thetas_ = np.linspace(0.01,0.99,SamplePoints_2D) - alphas_ = np.linspace(8, 12, SamplePoints_2D) - thetas_ = np.linspace(0.05,0.2,SamplePoints_2D) - # betas_ = np.linspace(0.01,40.01,1) - #fix to one value: - betas_ = 2.0; - alphas, betas, thetas = np.meshgrid(alphas_, betas_, thetas_, indexing='ij') - - - # if generalCase: #TODO - # classifyMinVec = np.vectorize(classifyMin) - # GetCellOutputVec = np.vectorize(GetCellOutput) - # Q, B = GetCellOutputVec(alpha,betas,thetas,gamma,mu1,rho1,InputFilePath ,OutputFilePath ) - # - # print('type of Q:', type(Q)) - # print('Q:', Q) + + # --- Define effective quantities: q1, q2 , q3 = mu_gamma, q12 --- + # q1 = harmonicMean(mu1, beta, theta) + # q2 = arithmeticMean(mu1, beta, theta) + # --- Set q12 + # q12 = 0.0 # (analytical example) # TEST / TODO read from Cell-Output + + + + + + # b1 = prestrain_b1(rho1, beta, alpha, theta) + # b2 = prestrain_b2(rho1, beta, alpha, theta) # - # else: - classifyMin_anaVec = np.vectorize(classifyMin_ana) - GetMuGammaVec = np.vectorize(GetMuGamma) - muGammas = GetMuGammaVec(betas,thetas,gamma,mu1,rho1,InputFilePath ,OutputFilePath ) - G, angles, Types, curvature = classifyMin_anaVec(alphas,betas,thetas, muGammas, mu1, rho1) # Sets q12 to zero!!! - # print('size of G:', G.shape) - # print('G:', G) - # print('Types:', Types) - # Out = classifyMin_anaVec(alphas,betas,thetas) - # T = Out[2] - # --- Write to VTK - # VTKOutputName = + path + "./PhaseDiagram2DNEW" - GammaString = str(gamma) - - VTKOutputName = "outputs/PhaseDiagram2D" + "Gamma_" + GammaString - gridToVTK(VTKOutputName , alphas, betas, thetas, pointData = {'Type': Types, 'angles': angles, 'curvature': curvature} ) - print('Written to VTK-File:', VTKOutputName ) - - -# --- Make 3D Scatter plot -if(make_3D_plot or make_2D_plot): - fig = plt.figure() - ax = fig.add_subplot(111, projection='3d') - colors = cm.plasma(Types) - # if make_2D_plot: pnt3d=ax.scatter(alphas,thetas,c=Types.flat) - # if make_3D_plot: pnt3d=ax.scatter(alphas,betas,thetas,c=Types.flat) - if make_2D_plot: pnt3d=ax.scatter(alphas,thetas,c=angles.flat) - if make_3D_plot: pnt3d=ax.scatter(alphas,betas,thetas,c=angles.flat) - # cbar=plt.colorbar(pnt3d) - # cbar.set_label("Values (units)") - ax.set_xlabel('alpha') - ax.set_ylabel('beta') - if make_3D_plot: ax.set_zlabel('theta') - plt.show() - # plt.savefig('common_labels.png', dpi=300) - # print('T:', T) - # print('Type 1 occured here:', np.where(T == 1)) - # print('Type 2 occured here:', np.where(T == 2)) + # print('---- Input parameters: -----') + # print('mu1: ', mu1) + # print('rho1: ', rho1) + # print('alpha: ', alpha) + # print('beta: ', beta) + # print('theta: ', theta) + # print("q1: ", q1) + # print("q2: ", q2) + # print("mu_gamma: ", mu_gamma) + # print("q12: ", q12) + # print("b1: ", b1) + # print("b2: ", b2) + # print('----------------------------') + # print("machine epsilon", sys.float_info.epsilon) + + # G, angle, type, kappa = classifyMin(q1, q2, mu_gamma, q12, b1, b2, print_Cases, print_Output) + # Test = f(1,2 ,q1,q2,mu_gamma,q12,b1,b2) + # print("Test", Test) + + # ---------------------- MAKE PLOT / Write to VTK------------------------------------------------------------------------------ + + # SamplePoints_3D = 10 # Number of sample points in each direction + # SamplePoints_2D = 10 # Number of sample points in each direction + SamplePoints_3D = 300 # Number of sample points in each direction + SamplePoints_2D = 5 # Number of sample points in each direction + + + + if make_3D_PhaseDiagram: + alphas_ = np.linspace(-20, 20, SamplePoints_3D) + betas_ = np.linspace(0.01,40.01,SamplePoints_3D) + thetas_ = np.linspace(0.01,0.99,SamplePoints_3D) + # print('type of alphas', type(alphas_)) + # print('Test:', type(np.array([mu_gamma])) ) + alphas, betas, thetas = np.meshgrid(alphas_, betas_, thetas_, indexing='ij') + classifyMin_anaVec = np.vectorize(classifyMin_ana) + + # Get MuGamma values ... + GetMuGammaVec = np.vectorize(GetMuGamma) + muGammas = GetMuGammaVec(betas, thetas, gamma, mu1, rho1) + # Classify Minimizers.... + G, angles, Types, curvature = classifyMin_anaVec(alphas, betas, thetas, muGammas, mu1, rho1) # Sets q12 to zero!!! + # print('size of G:', G.shape) + # print('G:', G) + # Out = classifyMin_anaVec(alphas,betas,thetas) + # T = Out[2] + # --- Write to VTK + GammaString = str(gamma) + + VTKOutputName = "outputs/PhaseDiagram3D" + "Gamma" + GammaString + gridToVTK(VTKOutputName , alphas, betas, thetas, pointData = {'Type': Types, 'angles': angles, 'curvature': curvature} ) + print('Written to VTK-File:', VTKOutputName ) + + if make_2D_PhaseDiagram: + # alphas_ = np.linspace(-20, 20, SamplePoints_2D) + # thetas_ = np.linspace(0.01,0.99,SamplePoints_2D) + alphas_ = np.linspace(9, 10, SamplePoints_2D) + thetas_ = np.linspace(0.075,0.14,SamplePoints_2D) + + # alphas_ = np.linspace(8, 12, SamplePoints_2D) + # thetas_ = np.linspace(0.05,0.2,SamplePoints_2D) + # betas_ = np.linspace(0.01,40.01,1) + #fix to one value: + betas_ = 2.0; + alphas, betas, thetas = np.meshgrid(alphas_, betas_, thetas_, indexing='ij') + + + if generalCase: #TODO + classifyMin_matVec = np.vectorize(classifyMin_mat) + GetCellOutputVec = np.vectorize(GetCellOutput) + Q, B = GetCellOutputVec(alphas,betas,thetas,gamma,mu1,rho1,InputFilePath ,OutputFilePath ) + + + print('type of Q:', type(Q)) + print('Q:', Q) + G, angles, Types, curvature = classifyMin_matVec(Q,B) + + else: + classifyMin_anaVec = np.vectorize(classifyMin_ana) + GetMuGammaVec = np.vectorize(GetMuGamma) + muGammas = GetMuGammaVec(betas,thetas,gamma,mu1,rho1,InputFilePath ,OutputFilePath ) + G, angles, Types, curvature = classifyMin_anaVec(alphas,betas,thetas, muGammas, mu1, rho1) # Sets q12 to zero!!! + # print('size of G:', G.shape) + # print('G:', G) + # print('Types:', Types) + # Out = classifyMin_anaVec(alphas,betas,thetas) + # T = Out[2] + # --- Write to VTK + # VTKOutputName = + path + "./PhaseDiagram2DNEW" + GammaString = str(gamma) + + VTKOutputName = "outputs/PhaseDiagram2D" + "Gamma_" + GammaString + gridToVTK(VTKOutputName , alphas, betas, thetas, pointData = {'Type': Types, 'angles': angles, 'curvature': curvature} ) + print('Written to VTK-File:', VTKOutputName ) + + + # --- Make 3D Scatter plot + if(make_3D_plot or make_2D_plot): + fig = plt.figure() + ax = fig.add_subplot(111, projection='3d') + colors = cm.plasma(Types) + # if make_2D_plot: pnt3d=ax.scatter(alphas,thetas,c=Types.flat) + # if make_3D_plot: pnt3d=ax.scatter(alphas,betas,thetas,c=Types.flat) + if make_2D_plot: pnt3d=ax.scatter(alphas,thetas,c=angles.flat) + if make_3D_plot: pnt3d=ax.scatter(alphas,betas,thetas,c=angles.flat) + # cbar=plt.colorbar(pnt3d) + # cbar.set_label("Values (units)") + ax.set_xlabel('alpha') + ax.set_ylabel('beta') + if make_3D_plot: ax.set_zlabel('theta') + plt.show() + # plt.savefig('common_labels.png', dpi=300) + # print('T:', T) + # print('Type 1 occured here:', np.where(T == 1)) + # print('Type 2 occured here:', np.where(T == 2)) # print(alphas_)