Advertisement
Coolbboy83

VillamCalc

Apr 19th, 2024 (edited)
619
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Python 8.10 KB | Source Code | 0 0
  1. import math
  2. import numpy as np
  3.  
  4. # variables
  5.  
  6. M = 100
  7. Lv = 1.25
  8. h = 0.15
  9. Iv = 200000
  10. Delta_l = [0, -(Lv / M), 0]
  11.  
  12. nur = 1
  13. nu0 = 4 * math.pi * 10 ** (-7)
  14.  
  15. K = 2
  16. N1 = 100
  17. N2 = 100
  18.  
  19. Ig1 = Iv / 3
  20. Ig2 = 2 * (Iv / 3)
  21.  
  22.  
  23. # vectors
  24.  
  25. rK1 = [0, 0, (-h)]
  26. rK2 = [0, 0, (-h)]
  27.  
  28. rV1 = [0.26, -0.16, 0]
  29. rV2 = [-0.26, -0.16, 0]
  30.  
  31.  
  32.  
  33. # vectorial division
  34.  
  35. Delta_r1 = [(rV1[i] - rK1[i]) / N1 for i in range(len(rV1))]
  36. Delta_r2 = [(rV2[j] - rK2[j]) / N2 for j in range(len(rV2))]
  37.  
  38.  
  39.  
  40.  
  41. # calculations
  42.  
  43. vectors_rpX_j = [[0, Lv / M * (j - 0.5), (-h)] for j in range(1, M + 1)]
  44.  
  45. vectors_r1X_i = [ [rK1[j] + (i - 0.5) / N1 * (rV1[j] - rK1[j]) for j in range(len(rK1))] for i in range(1, N1 + 1) ]
  46.  
  47. vectors_r2X_i = [ [rK2[j] + (i - 0.5) / N2 * (rV2[j] - rK2[j]) for j in range(len(rK2))] for i in range(1, N2 + 1) ]
  48.  
  49. #
  50.  
  51. scalar = (nur * nu0 / (4 * math.pi) * Ig1)
  52.  
  53. Bp_res_part = [scalar * x for x in Delta_r1]
  54.  
  55. scalar_2 = (nur * nu0 / (4 * math.pi) * Ig2)
  56.  
  57. Bp_2 = [scalar_2 * x for x in Delta_r2]
  58.  
  59.  
  60. #print(result_vectors)
  61. vektor = np.array([1, 2, 3])
  62. vektor_abs_result = np.linalg.norm(vektor)
  63.  
  64.  
  65. # Az eredmény vektorok tárolására szolgáló lista inicializálása
  66. result_vectors = []
  67.  
  68. # Végigiterálunk minden lehetséges j és i pároson
  69. for j in vectors_rpX_j:
  70.     for i in vectors_r1X_i:
  71.         # Kivonjuk az i-edik vektort a j-edik vektortól
  72.         result_vector = [j_elem - i_elem for j_elem, i_elem in zip(j, i)]
  73.         # Hozzáadjuk az eredményt a result_vectors listához
  74.         result_vectors.append(result_vector)
  75.  
  76. # Az eredmény kiíratása
  77.  
  78. vec_abs = []
  79.  
  80. # Iterálunk a result_vectors listán, és kiszámítjuk minden vektor abszolút értékét
  81. for vec in result_vectors:
  82.     abs_value = math.sqrt(sum(x**2 for x in vec))  # A vektor abszolút értékének kiszámítása
  83.     vec_abs.append(abs_value)  # Hozzáadjuk az abszolút értéket a vec_abs listához
  84.  
  85. # Kiírjuk a vec_abs listát, hogy lássuk az abszolút értékeket
  86.  
  87. abs_list = []
  88.  
  89. for j in vectors_rpX_j:
  90.     for i in vectors_r1X_i:
  91.         # Kivonjuk az i-edik vektort a j-edik vektortól
  92.         result_vector = [j_elem - i_elem for j_elem, i_elem in zip(j, i)]
  93.         # Hozzáadjuk az eredményt a result_vectors listához
  94.         result_vectors.append(result_vector)
  95.         # Kiszámítjuk a vektor abszolút értékét, majd harmadik hatványra emeljük
  96.         abs_value_cubed = (math.sqrt(sum(x**2 for x in result_vector)))**3
  97.         # Hozzáadjuk az abszolút érték harmadik hatványát az abs_list listához
  98.         abs_list.append(abs_value_cubed)
  99.  
  100.  
  101. total = []
  102.  
  103. # Ellenőrizzük, hogy az abs_list nem tartalmaz-e nullát, hogy elkerüljük a nullával való osztást
  104. if all(value != 0 for value in abs_list):
  105.     for vec, abs_value_cubed in zip(result_vectors, abs_list):
  106.         # Minden vektor elemét elosztjuk a megfelelő abszolút érték harmadik hatványával
  107.         divided_vector = [element / abs_value_cubed if abs_value_cubed != 0 else 0 for element in vec]
  108.         total.append(divided_vector)
  109. else:
  110.     print("Hiba: Az abs_list tartalmaz nullát, ami nem megengedett az osztás során.")
  111.  
  112.  
  113. reduced = []
  114.  
  115. vector_length = len(total[0])  # Feltételezve, hogy minden vektor azonos hosszúságú
  116.  
  117. # Végigiterálunk a total listán 100-as lépésközzel
  118. for i in range(0, len(total), N1):
  119.     # Inicializálunk egy kezdő vektort nullákkal
  120.     sum_vector = [0] * vector_length
  121.     # Összeadjuk az aktuális 100 vektor elemeit
  122.     for vector in total[i:i + N1]:
  123.         sum_vector = [sum(x) for x in zip(sum_vector, vector)]
  124.     # Hozzáadjuk az összeget a reduced listához
  125.     reduced.append(sum_vector)
  126.  
  127. # A scalar és a 100-as vector pakk cross product szorzata.
  128. product_result = []
  129.  
  130. # Iterálunk a reduced listán
  131. for vec in reduced:
  132.     # Keresztszorzat a Bp_res_part és az aktuális vektor között
  133.     cross_prod = np.cross(Bp_res_part, vec)
  134.     # Hozzáadjuk a keresztszorzat eredményét a product_result listához
  135.     product_result.append(cross_prod)
  136.  
  137. #print(Delta_r1)
  138.  
  139. #vec1 = [2,5,8]
  140. #vec2 = [10,-3,7]
  141.  
  142. #print("vektorok szorzat: ", np.cross(vec1, vec2))
  143.  
  144. result_vectors_2 = []
  145.  
  146. # Végigiterálunk minden lehetséges j és i pároson
  147. for j in vectors_rpX_j:
  148.     for i in vectors_r2X_i:
  149.         # Kivonjuk az i-edik vektort a j-edik vektortól
  150.         result_vector_2 = [j_elem - i_elem for j_elem, i_elem in zip(j, i)]
  151.         # Hozzáadjuk az eredményt a result_vectors listához
  152.         result_vectors_2.append(result_vector_2)
  153.  
  154.  
  155. norm_cubed_results = []
  156.  
  157. # Iterálunk a result_vectors_2 listán lévő vektorokon
  158. for vec in result_vectors_2:
  159.     # Kiszámítjuk a vektor normáját (abszolút értékét)
  160.     norm = np.linalg.norm(vec)
  161.     # A norma harmadik hatványát vesszük és hozzáadjuk az eredmények listájához
  162.     norm_cubed_results.append(norm ** 3)
  163.  
  164.  
  165. result2 = []
  166.  
  167. # Ellenőrizzük, hogy a norm_cubed_results lista nem tartalmaz-e nullát
  168. if all(value != 0 for value in norm_cubed_results):
  169.     # Iterálunk a result_vectors_2 listán és az azonos indexű norm_cubed_results értékeken
  170.     for vec, norm_cubed in zip(result_vectors_2, norm_cubed_results):
  171.         # Minden vektor elemét elosztjuk a megfelelő norma harmadik hatványával
  172.         divided_vector = [element / norm_cubed for element in vec]
  173.         # Hozzáadjuk az eredményt a result2 listához
  174.         result2.append(divided_vector)
  175. else:
  176.     print("Hiba: A norm_cubed_results tartalmaz nullát, ami nem megengedett az osztás során.")
  177.  
  178.  
  179.  
  180. reduced_2 = []
  181. vector_length_2 = len(result2[0])
  182.  
  183. # Végigiterálunk a total listán 100-as lépésközzel
  184. for i in range(0, len(result2), N2):
  185.     # Inicializálunk egy kezdő vektort nullákkal
  186.     sum_vector = [0] * vector_length_2
  187.     # Összeadjuk az aktuális N vektor elemeit
  188.     for vector in result2[i:i + N2]:
  189.         sum_vector = [sum(x) for x in zip(sum_vector, vector)]
  190.     # Hozzáadjuk az összeget a reduced listához
  191.     reduced_2.append(sum_vector)
  192.  
  193.  
  194.  
  195. product_result_2 = []
  196.  
  197. # Iterálunk a reduced listán
  198. for vec in reduced_2:
  199.     # Keresztszorzat a Bp_res_part és az aktuális vektor között
  200.     cross_prod = np.cross(Bp_2, vec)
  201.     # Hozzáadjuk a keresztszorzat eredményét a product_result listához
  202.     product_result_2.append(cross_prod)
  203.  
  204.  
  205.  
  206. total_result = []
  207.  
  208. # Ellenőrizzük, hogy a két lista hossza megegyezik-e
  209. if len(product_result) == len(product_result_2):
  210.     # Iterálunk a listák hosszán
  211.     for i in range(len(product_result)):
  212.         # Összeadjuk a megfelelő vektorokat a két listából
  213.         summed_vector = [sum(x) for x in zip(product_result[i], product_result_2[i])]
  214.         # Hozzáadjuk az összeadott vektort a total_result listához
  215.         total_result.append(summed_vector)
  216. else:
  217.     print("Hiba: A listák hossza nem egyezik meg.")
  218.  
  219.  
  220. final_sum_vector = [0] * len(total_result[0])
  221.  
  222. # Iterálunk a total_result listán lévő vektorokon
  223. for vec in total_result:
  224.     # Összeadjuk az aktuális vektort a final_sum_vector vektorral
  225.     final_sum_vector = [sum(x) for x in zip(final_sum_vector, vec)]
  226.  
  227.  
  228. result_vec = [Iv * x for x in Delta_l]
  229.  
  230.  
  231. #most jon az ero kiszamitasa :) maybe the force with U :)
  232.  
  233. force_total = []
  234.  
  235. for v in reduced:
  236.     # Keresztszorzat a Bp_res_part és az aktuális vektor között
  237.     cross_prod_2 = np.cross(result_vec, final_sum_vector)
  238.     # Hozzáadjuk a keresztszorzat eredményét a product_result listához
  239.     force_total.append(cross_prod_2)
  240.  
  241.  
  242. force = np.cross(result_vec, final_sum_vector)
  243. #print(force)
  244.  
  245. # nyomatek
  246.  
  247. # elemi elmozdulas a villamharoiton X az ottani magneses ter
  248. alma = np.cross(Delta_l, total_result)
  249. #print(s)
  250.  
  251. #print(len(alma))
  252.  
  253. korte = np.cross(vectors_rpX_j, alma)
  254.  
  255. szilva = [sum(i) for i in zip( * korte)]
  256. #print(szilva)
  257.  
  258. #EREDO NYOMATEK VEKTOR Momentum_Null
  259.  
  260. mumentum_null = np.multiply(Iv, szilva)
  261. #print("nyomatek: ", mumentum_null, "Ero: ", force)
  262.  
  263. H = mumentum_null[0] / force[2]
  264.  
  265. print("Eredo ero vektor (N): ", force)
  266.  
  267. print("Az origora vett eredo forgato nyomatek vektor (Nm): ", mumentum_null)
  268.  
  269. print("Eredo ero hatasvonalanak magassaga a villamharito talpatol (meter): ", H)
  270.  
  271.  
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement