gfk_plate.py 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210
  1. # https://akaszynski.github.io/pyansys/ansys_control.html#initial-setup-and-example
  2. # pip install pyansys --upgrade
  3. import pyansys
  4. import numpy as np
  5. import os
  6. import time
  7. from scipy import sparse
  8. from scipy.sparse import linalg
  9. def sim_rotor(materials, angles, outer_diameter=0.250, inner_diameter=0.050, thickness=0.005, omega=1):
  10. layers = len(angles)
  11. layer_thickness = thickness / layers
  12. path = os.getcwd() + "\\ws"
  13. mapdl = pyansys.launch_mapdl(run_location=path, interactive_plotting=True, loglevel='ERROR', override=True)
  14. # """
  15. # clear existing geometry
  16. mapdl.finish()
  17. mapdl.clear()
  18. th = 50 # [°C]
  19. tn = 50 # [°C]
  20. mapdl.prep7()
  21. # define Material
  22. for i in range(0, len(materials)):
  23. mapdl.mptemp(i + 1, th)
  24. mapdl.mpdata("EX", i + 1, "", materials[i]["e11"])
  25. mapdl.mpdata("EY", i + 1, "", materials[i]["e22"])
  26. mapdl.mpdata("EZ", i + 1, "", materials[i]["e33"])
  27. mapdl.mpdata("PRXY", i + 1, "", materials[i]["pr12"])
  28. mapdl.mpdata("PRXZ", i + 1, "", materials[i]["pr13"])
  29. mapdl.mpdata("PRYZ", i + 1, "", materials[i]["pr23"])
  30. mapdl.mpdata("DENS", i + 1, "", materials[i]["dens"])
  31. mapdl.mpdata("GXY", i + 1, "", materials[i]["g12"])
  32. mapdl.mpdata("GXZ", i + 1, "", materials[i]["g13"])
  33. mapdl.mpdata("GYZ", i + 1, "", materials[i]["g23"])
  34. # Waermeausdenungsk
  35. mapdl.mpdata("ALPX", i + 1, "", materials[i]["alp11"])
  36. mapdl.mpdata("ALPY", i + 1, "", materials[i]["alp22"])
  37. mapdl.mpdata("ALPZ", i + 1, "", materials[i]["alp33"])
  38. # Waermeleitfaehigk
  39. mapdl.mpdata("KXX", i + 1, "", materials[i]["k11"])
  40. mapdl.mpdata("KYY", i + 1, "", materials[i]["k22"])
  41. mapdl.mpdata("KZZ", i + 1, "", materials[i]["k33"])
  42. # Quellkoeffizient
  43. mapdl.mpdata("BETX", i + 1, "", materials[i]["bet11"])
  44. mapdl.mpdata("BETY", i + 1, "", materials[i]["bet22"])
  45. mapdl.mpdata("BETZ", i + 1, "", materials[i]["bet33"])
  46. # Diffusionskoeffizient
  47. mapdl.mpdata("DXX", i + 1, "", materials[i]["d11"])
  48. mapdl.mpdata("DYY", i + 1, "", materials[i]["d22"])
  49. mapdl.mpdata("DZZ", i + 1, "", materials[i]["d33"])
  50. mapdl.et(1, "SOLID186")
  51. mapdl.csys(1)
  52. mapdl.k(1, str(inner_diameter/2), 0, str(-thickness/2))
  53. mapdl.k(2, str(inner_diameter/2), 0, str(thickness/2))
  54. mapdl.k(3, str(outer_diameter/2), 0, str(thickness/2))
  55. mapdl.k(4, str(outer_diameter/2), 0, str(-thickness/2))
  56. mapdl.l(1, 2)
  57. mapdl.l(2, 3)
  58. mapdl.l(3, 4)
  59. mapdl.l(4, 1)
  60. mapdl.al(1, 2, 3, 4)
  61. mapdl.k(5, 0, 0, str(thickness/2))
  62. mapdl.k(6, 0, 0, str(-thickness/2))
  63. mapdl.run("VROT,1,,,,,,5,6")
  64. arcdiv = 20*4
  65. darc = 360/arcdiv
  66. mapdl.lsel("S", "LOC", "X", str(inner_diameter/2))
  67. mapdl.lsel("R", "LOC", "Z", str(-thickness/2))
  68. mapdl.lesize("ALL", "", "", str(arcdiv/4))
  69. mapdl.lsel("S", "LOC", "X", str(inner_diameter/2))
  70. mapdl.lsel("R", "LOC", "Z", str(thickness/2))
  71. mapdl.lesize("ALL", "", "", str(arcdiv/4))
  72. mapdl.lsel("S", "LOC", "X", str(outer_diameter/2))
  73. mapdl.lsel("R", "LOC", "Z", str(-thickness/2))
  74. mapdl.lesize("ALL", "", "", str(arcdiv/4))
  75. mapdl.lsel("S", "LOC", "X", str(outer_diameter/2))
  76. mapdl.lsel("R", "LOC", "Z", str(thickness/2))
  77. mapdl.lesize("ALL", "", "", str(arcdiv/4))
  78. for i in range(0, 4):
  79. mapdl.lsel("S", "LOC", "Y", str(90*i))
  80. mapdl.lsel("R", "LOC", "Z", str(-thickness/2))
  81. mapdl.lesize("ALL", "", "", str(arcdiv/4))
  82. mapdl.lsel("S", "LOC", "Y", str(90*i))
  83. mapdl.lsel("R", "LOC", "Z", str(thickness/2))
  84. mapdl.lesize("ALL", "", "", str(arcdiv/4))
  85. mapdl.lsel("S", "LOC", "Y", str(90*i))
  86. mapdl.lesize("ALL", "", "", str(len(angles)))
  87. mapdl.lsel("ALL")
  88. mapdl.mshape(0, "3D")
  89. mapdl.mshkey(1)
  90. mapdl.vmesh("ALL")
  91. # mapdl.eplot("ALL")
  92. for j in range(1, len(angles)+1):
  93. for i in range(0, 20*4):
  94. mapdl.csys(1)
  95. mapdl.esel("S", "CENT", "Y", str(darc*(i + 0.5)))
  96. mapdl.esel("R", "CENT", "Z", str(thickness*(-1/2+1/len(angles)*(j-1))), str(thickness*(-1/2+1/len(angles)*j)), str(thickness/len(angles)/2))
  97. mapdl.local(str(j*100+i), 0, 0, 0, 0, str(angles[j-1]+darc*(i + 0.5)))
  98. mapdl.emodif("all", "ESYS", str(j*100+i))
  99. if len(angles) == len(materials):
  100. mapdl.emodif("all", "MAT", str(j))
  101. mapdl.esel("ALL")
  102. # Read Stress
  103. mapdl.run("/SOLU")
  104. mapdl.csys(1)
  105. mapdl.omega("", "", omega)
  106. mapdl.nsel("S", "LOC", "X", inner_diameter / 2)
  107. mapdl.d("ALL", "UX", 0)
  108. mapdl.d("ALL", "UY", 0)
  109. # D,ALL,ROTX,0
  110. # D,ALL,ROTY,0
  111. # D,ALL,ROTZ,0
  112. mapdl.nsel("R", "LOC", "Z", 0)
  113. mapdl.d("ALL", "UZ", 0)
  114. mapdl.run("ALLS")
  115. mapdl.outres("ALL", "ALL")
  116. mapdl.solve()
  117. mapdl.finish()
  118. mapdl.run("/Post1")
  119. result = mapdl.result
  120. # result.plot_nodal_solution(0, 'z', show_displacement=True)
  121. # result.plot_principal_nodal_stress(0, 'S1', show_edges=True, show_axes=True)
  122. # """
  123. nodenump, stress = result.principal_nodal_stress(0)
  124. s1max = np.nanmax(stress[:, -5])
  125. s2max = np.nanmax(stress[:, -4])
  126. nodenum, stress = result.nodal_stress(0)
  127. srmax = np.nanmax(stress[:, -6])
  128. stmax = np.nanmax(stress[:, -5])
  129. # Modual-Analysis
  130. # """
  131. mapdl.run("/SOLU")
  132. mapdl.csys(1)
  133. mapdl.omega("", "", omega)
  134. mapdl.nsel("S", "LOC", "X", inner_diameter / 2)
  135. mapdl.d("ALL", "UX", 0)
  136. mapdl.d("ALL", "UY", 0)
  137. mapdl.nsel("R", "LOC", "Z", 0)
  138. mapdl.d("ALL", "UZ", 0)
  139. mapdl.run("ALLS")
  140. mapdl.outres("ALL", "ALL")
  141. mapdl.antype("MODAL")
  142. mapdl.modopt("lanb", 3)
  143. mapdl.mxpand("", "", "", "yes")
  144. mapdl.solve()
  145. mapdl.finish()
  146. mapdl.run("/Post1")
  147. result = mapdl.result
  148. f = result.time_values
  149. mapdl.exit()
  150. time.sleep(0.5)
  151. return s1max, s2max, srmax, stmax, f[0], f[1], f[2]
  152. print(sim_rotor(
  153. [{
  154. "e11": 42.5E9 ,
  155. "e22": 11E9 ,
  156. "e33": 11E9 ,
  157. "pr12": 0.28 ,
  158. "pr13": 0.28 ,
  159. "pr23": 0.28 ,
  160. "dens": 1950 ,
  161. "g12": 4.2E9 ,
  162. "g13": 4.2E9 ,
  163. "g23": 2.56E9 ,
  164. "alp11": 5.7E-6 ,
  165. "alp22": 45E-6 ,
  166. "alp33": 45E-6 ,
  167. "k11": 0.72E3 ,
  168. "k22": 0.5E3 ,
  169. "k33": 0.5E3 ,
  170. "bet11": 0E-3,
  171. "bet22": 4E-3,
  172. "bet33": 4E-3,
  173. "d11": 4.4E-3,
  174. "d22": 3.1E-3,
  175. "d33": 3.1E-3
  176. }], [90, 0, 0, 0, 0, 0]))