oscillator_sketch.py 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. """Draw mechanical vibration system."""
  2. from pysketcher import *
  3. L = 12.
  4. H = L/6
  5. W = L/6
  6. xmax = L
  7. drawing_tool.set_coordinate_system(xmin=-L, xmax=xmax,
  8. ymin=-1, ymax=L+H,
  9. axis=False,
  10. instruction_file='tmp_mpl.py')
  11. x = 0
  12. drawing_tool.set_linecolor('black')
  13. def make_dashpot(x):
  14. d_start = (-L,2*H)
  15. d = Dashpot(start=d_start, total_length=L+x, width=W,
  16. bar_length=3*H/2, dashpot_length=L/2, piston_pos=H+x)
  17. d.rotate(-90, d_start)
  18. return d
  19. def make_spring(x):
  20. s_start = (-L,4*H)
  21. s = Spring(start=s_start, length=L+x, bar_length=3*H/2, teeth=True)
  22. s.rotate(-90, s_start)
  23. return s
  24. d = make_dashpot(0)
  25. s = make_spring(0)
  26. M = Rectangle((0,H), 4*H, 4*H).set_linewidth(4)
  27. left_wall = Rectangle((-L,0),H/10,L).set_filled_curves(pattern='/')
  28. ground = Wall(x=[-L/2,L], y=[0,0], thickness=-H/10)
  29. wheel1 = Circle((H,H/2), H/2)
  30. wheel2 = wheel1.copy()
  31. wheel2.translate(point(2*H, 0))
  32. fontsize = 18
  33. text_m = Text('$m$', (2*H, H+2*H), fontsize=fontsize)
  34. text_ku = Text('$ku$', (-L/2, H+4*H), fontsize=fontsize)
  35. text_bv = Text("$bu'$", (-L/2, H), fontsize=fontsize)
  36. x_axis = Axis((2*H, L), H, '$u(t)$', fontsize=fontsize,
  37. label_spacing=(0.04, -0.01))
  38. x_axis_start = Line((2*H, L-H/4), (2*H, L+H/4)).set_linewidth(4)
  39. fig = Composition({
  40. 'spring': s, 'mass': M, 'left wall': left_wall,
  41. 'ground': ground, 'wheel1': wheel1, 'wheel2': wheel2,
  42. 'text_m': text_m, 'text_ku': text_ku,
  43. 'x_axis': x_axis, 'x_axis_start': x_axis_start})
  44. fig.draw()
  45. drawing_tool.display()
  46. drawing_tool.savefig('tmp_oscillator_spring')
  47. drawing_tool.erase()
  48. fig['dashpot'] = d
  49. fig['text_bv'] = text_bv
  50. # or fig = Composition(dict(fig=fig, dashpot=d, text_bv=text_bv))
  51. fig.draw()
  52. drawing_tool.display()
  53. drawing_tool.savefig('tmp_oscillator')
  54. drawing_tool.erase()
  55. text_ku = Text('$ku$', (-L/2, H+4*H), fontsize=fontsize)
  56. text_bv = Text("$bu'$", (-L/2, H), fontsize=fontsize)
  57. x_axis = Axis((2*H, L), H, '$u(t)$', fontsize=fontsize,
  58. label_spacing=(0.04, -0.01))
  59. F_force = Force((4*H, H+2*H), (4*H+H, H+2*H), '$F(t)$',
  60. text_spacing=(0.057, -0.007), text_alignment='left', fontsize=fontsize)
  61. fig['text_ku'] = text_ku
  62. fig['text_bv'] = text_bv
  63. fig['x_axis'] = x_axis
  64. fig['F_force'] = F_force
  65. fig.draw()
  66. drawing_tool.savefig('tmp_oscillator_general')
  67. raw_input()