|
Расчет составной конструкции системы двух тел
Расчет составной конструкции системы двух тел
КУРСОВАЯ РАБОТА по информатике на тему: Расчет составной конструкции системы двух тел СОДЕРЖАНИЕ Введение 1. Постановка задачи 2. Исходные данные 3. Математическая модель (Расчётная формула) 4. Краткие теоретические сведенья об используемых методах решения задачи 5. Описание форм, переменных свойств объектов Заключение Список используемой литературы Приложение 1. Текст программы Введение Персональный компьютер - неотъемлемая часть рабочего места инженера, специалиста любого профиля, руководителя организации, учреждения, надежным средством оперативного сбора и обработки информации. Изменение технических возможностей вычислительной техники способствовало разработке и новых систем программирования, позволяющих инженеру - не программисту самостоятельно разрабатывать пользовательские программы достаточно высокого качества для решение текущих задач. Одним из таких языков программирования высокого уровня является Visual Basic. Visual Basic предъявляет достаточно высокие требования к техническим характеристикам персонального компьютера. Visual Basic в среде Windows позволяет создавать приложения - программы для работы в этой среде. При этом программы имеют похожий интерфейс и способы управления. В частности, Visual Basic позволяет добавлять к окнам полям ввода, меню, командные кнопочки, переключатели, флажки, списки, линейки прокрутки, а так же диалоговые окна для выбора файла или каталога. Программист может использовать сетку для обработки табличных данных, организовывать взаимодействие с другими приложениями Windows и доступ к базам данных. 1. Постановка задачи Разработка программы для расчёта составной конструкции системы двух тел. Исходные данные к проекту согласно методическим материалам. Вариант N20. Разработать программу для расчёта реакций составной конструкции при шарнирной и скользящей заделке. Оценить варианты построения системы по минималу реакций опор А. Исследовать зависимость реакции опоры А от направления силы Р1. Построить графики зависимости реакций опоры в зависимости от направления действия силы Р1 в электронной таблице. 2. Исходные данные Исходные данные к проекту согласно методическим материалам. Вариант N16. Разработать программу для расчёта реакций составной конструкции при шарнирной и скользящей заделке. Схема (Рис.2.1)
Рис.2.1 Схема 3. Краткие теоретические сведения об используемых методах решения задачи Создаём программу в среде VISUAL BASIC 6.0. Конструируем форму mdiform. На форме размещаем меню для выбора режимов работы: Ввод данных, Расчет, Паспорт, Выход. Блок 1 предназначен для реализации отображения исходных данных. Для реализации данного блока конструируем форму Form2.На форме размещаем кнопку для выхода (Command1), TextBox для ввода заданных значений, кнопку Command2 для просмотра схемы. Блок 2 предназначен для расчета реакций опор и сил в стержнях. Для реализации данного блока конструируем форму Form3. На форме размещаем 2 сетки, с помощью которых происходит отображение рассчитанных величин. Также на данной форме размещены кнопки, которые позволяют нам связать VB с Excel. Блок 3 предназначен для реализации просмотра паспорта программы. Для реализации данного блока конструируем форму Form1. Блок 4 предназначен для выхода из программы. Размещаем в проекте модуль (modulе1) для объявления глобальных переменных и расчёта математической модели. 4. Описание форм, переменных свойств объектов ОПЕРАТОР - это указания для выполнения некоторого действия. Различают: операторы присваивания (организующие вычисления); операторы перехода (безусловного перехода); условные операторы (условного перехода); операторы цикла (повторение); операторы процедур (подпрограмм); операторы ввода - вывода. В курсовой работе содержатся следующие операторы: Оператор CLS - очистка экрана. Оператор QBCOLOR - устанавливает цвет экрана. Оператор DIM -Объявление переменных . Оператор END - заканчивает программу, процедуру, блок или тип данных, определенный пользователем. Операторы FOR и NEXT установки параметров. Все операторы, охваченные этой парой операторов, повторяют свою работу в условиях определяемых аргументами оператора FOR. Оператор SUB - определяет процедуру SUB Оператор IF - организация условного перехода или выполнение указанного действия в зависимости от результата проверки логического условия. Формы и конструкции: Оператор CURENT (X,Y) - перемещает курсор на экране в указанную позицию. Оператор PRINT - для вывода данных на экран и в файлы данных последующего доступа. Оператор WHILE - выполняет серию операторов, пока указанное условие верно. Таблица описания типов переменных Таблица 5,1 |
Имя переменной | Тип переменной | Комментарий | | F1,F2,M | Single | Переменные, хранящие значения сил F1,F2,M. соответственно | | Ya,Xa,Ma,Rb,Xc,Yc | Single | Переменные, в которые записываются значения реакций опор Yb,Xb,Ra | | alfa1,alfa2,betta | Single | Переменные, хранящие значение угла наклона линии действия силы F1,F2,Rb к горизонтали | | pi | Const | Константа, хранящая значение числа р. | | i | Integer | Вспомогательные переменные - счетчик. | | NameFile | String | Переменная, используемая для обозначения имени создаваемого текстового файла. | | ObjXLApp | Application | Переменная для работы с приложением Ехсеl | | c,d | Single | Вспомогательные переменные, используемые для построения рисунка. | | a | Single | Переменные хранящие зачения ширины . | | |
Таблица описания элементов управления Таблица 5,2 |
Элемент управления | Свойства | Значение | | Form | Name Border Style Caption MDIChild WindowState | Form3 1 - Fixed Single Расчет True 0 - Normal | | CommandButton | Name Caption Cancle Style Visible | cmdClose Закрыть False 1 - Graphical True | | MSFlexGrid | Name BorderStyle Cols Rows FixedCols FixedRows ScrollBars | MSFlexGrid 1 - flexBorderSingle 5 2 1 1 0 - flexScrollBarVertical | | PictureBox | Name BorderStyle Enabled Visible | Picture1 1 - Fixed Single True True | | |
Заключение Для запуска программы в редакторе VISUAL BASIC 6.0 следует нажать клавишу f5 или выбрать в меню пункт RUN. Для просмотра исходных данных выбираем в меню пункт “Исходные данные”, для просмотра рисунка фермы выбираем “Схема задания”, для отображения расчета реакций опор и сил в стержнях плоской фермы выбираем “Расчет”, график зависимости реакции опоры A от направления приложения силы F1 отбражается при нажатии кнопки Excel в меню Расчет. Чтобы узнать кто является автором данного курсового выбираем “Паспорт”, для выхода --- “Выход”. Список использованной литературы Катков В.Л., Любимский Э.З. “Программирование”. - Минск “Вышэйшая школа”, 1992г. Кетков Ю.Л. “Диалог на языке БЭЙСИК для мини - и микро - ЭВМ”. - Москва “Наука”, 1992г. Трояновский В.М., Шаньгин В.Ф. “БЭЙСИК для начинающих и будущих профессионалов”. - Москва “Высшая школа”, 1992г. Турчак Л.И. “Основы численных методов” - М.: Наука, 1987. Уолш Б. “Программирование на VISUAL BASIC”. - Москва “Радио и связь”, 1998г. Приложение 1. ТЕКСТ ПРОГРАММЫOption ExplicitGlobal P1 As Single, P2 As Single, M As Single, Qr As Single, Q As Single, alf1 As Single, alfa1 As SingleGlobal Xa As Single, Rb As Single, Rd As Single, Ya As Single, Yd As SingleGlobal Xc As Single, Yc As Single, Mc As SingleGlobal beta As Single, ugol As SingleGlobal i As Integer, j As IntegerGlobal Const pi = 3.14159265358979Public Sub RaschetSharnir()P1 = Val(frmDannye.tbP1.Text)P2 = Val(frmDannye.tbP2.Text)M = Val(frmDannye.tbM.Text)alf1 = Val(frmDannye.tbA1.Text)alfa1 = pi * alf1 / 180Rd = (-4 * P1 * Cos(alfa1) + 0.25 * P2 - 0.104 - 0.928 * P1 * Sin(alfa1)) / 3.464Rb = 28.135 + 0.103 * P2 - Rd - 0.268 * P1 * Sin(alfa1)Xa = P1 * Sin(alfa1) + 0.866 * P2 + 0.866 * Rd - 0.866 * Rb + 52.5Ya = -P1 * Cos(alfa1) + 0.5 * P2 - 0.5 * Rd - 0.5 * Rb + 60End SubPublic Sub RaschetZadelka()P1 = Val(frmDannye.tbP1.Text)P2 = Val(frmDannye.tbP2.Text)M = Val(frmDannye.tbM.Text)alf1 = Val(frmDannye.tbA1.Text)alfa1 = pi * alf1 / 180Rd = (-P1 * (Sin(alfa1) - 7.464 * Cos(alfa1)) - 3.348 * P2 - 342.81) / 7.464Rb = -2 * P1 * Cos(alfa1) + 120 + P2 + RdXa = P1 * Sin(alfa1) + P2 * 0.866 + 0.866 * Rd - 0.866 * Rb + 52.5End SubPrivate Sub ex_Click()otvet = MsgBox("Завершить программу?", vbYesNo + vbQuestion, "Курсовая работа по информатике")If otvet = vbYes Then EndEnd SubPrivate Sub MDIForm_Load()End SubPrivate Sub mnuDannye_Click()frmDannye.ShowEnd SubPrivate Sub mnuExit_Click()otvet = MsgBox("Завершить программу?", vbYesNo + vbQuestion, "Курсовая работа по информатике")If otvet = vbYes Then EndEnd SubPrivate Sub mnuPassport_Click()frmPasport.ShowEnd SubPrivate Sub mnuRaschet_Click()frmRaschet.ShowEnd SubPrivate Sub cmdShow_Click()Set Pic1 = Picture1Picture1.Picture = LoadPicture()a = 10alfa = 4 * Atn(1) / 3Picture1.ScaleMode = 6Picture1.DrawWidth = 3.5' Рисуем исходный рисунокxo = 10: yo = 40 'начальная точкаPicture1.Line (xo, yo + 2 * a)-(xo + 3 * a, yo)Picture1.Line (xo + 3 * a, yo)-(xo + 3 * a, yo - 1 * a)Picture1.Line (xo + 3 * a, yo - 1 * a)-(xo + 8 * a, yo - 1 * a)Picture1.Line (xo + 8 * a, yo - 3 * a)-(xo + 8 * a, yo + 2 * a)Picture1.Circle (xo + 3 * a, yo), 1, vbBluePicture1.DrawWidth = 1.5'Заделки нижние:'APicture1.Circle (xo, yo + 2 * a + 0.5), 1Picture1.Line (xo, yo + 2 * a + 0.5)-(xo - 2, yo + 2 * a + 7)Picture1.Line (xo, yo + 2 * a + 0.5)-(xo + 2, yo + 2 * a + 7)Picture1.Line (xo - 4, yo + 2 * a + 7)-(xo + 4, yo + 2 * a + 7)For s = xo - 5 To xo + 3 Step 1 Picture1.Line (s + 1.5, yo + 2 * a + 7)-(s, yo + 2 * a + 7 + 2)Next s'BPicture1.Line (xo + 8 * a - a / 3 - 2, yo + 2 * a + 5)-(xo + 8 * a + a / 3 - 3, yo + 2 * a + 7)Picture1.Circle (xo + 8 * a, yo + 2 * a), 1Picture1.Line (xo + 8 * a - a / 3 - 2, yo + 2 * a + 5)-(xo + 8 * a - 1, yo + 2 * a + 1)Picture1.Line (xo + 8 * a + a / 3 - 3, yo + 2 * a + 7)-(xo + 8 * a, yo + 2 * a + 1)Picture1.Circle (xo + 8 * a - a / 3 - 2, yo + 2 * a + 6), 1Picture1.Circle (xo + 8 * a + a / 3 - 3, yo + 2 * a + 8), 1Picture1.Line (xo + 8 * a - a / 3 - 4, yo + 2 * a + 7)-(xo + 8 * a + a / 3 - 2, yo + 2 * a + 10)'DPicture1.Circle (xo + 8 * a, yo - 3 * a), 1Picture1.Line (xo + 8 * a, yo - 3 * a)-(xo + 8 * a + 2, yo - 3 * a + 5)Picture1.Circle (xo + 8 * a + 2, yo - 3 * a + 5), 1'Сила P1Picture1.Line (xo + 5 * a, yo - 1 * a)-(xo + 4.5 * a - 1.5 * a * Sin(alfa - 0.7 * Atn(1)), yo - 0.4 * a * Cos(alfa)), &HC0&Picture1.Line (xo + 4.5 * a - 1.5 * a * Sin(alfa - 0.7 * Atn(1)), yo - 0.4 * a * Cos(alfa))-(xo + 4.5 * a, yo - 0.4 * a), &HC0&Picture1.Line (xo + 4.5 * a - 1.5 * a * Sin(alfa - 0.7 * Atn(1)), yo - 0.4 * a * Cos(alfa))-(xo + 4.3 * a, yo - 0.8 * a), &HC0&'Сила P2Picture1.Line (xo + 3 * a, yo - 1 * a)-(xo + 1 * a + 2 * a * Cos(alfa), yo - 2.5 * a - Sin(alfa)), &HC0&Picture1.Line (xo + 1 * a + 2 * a * Cos(alfa), yo - 2.5 * a - Sin(alfa))-(xo + 2.16 * a, yo - 1 * a - 10), &HC0&Picture1.Line (xo + 1 * a + 2 * a * Cos(alfa), yo - 2.5 * a - Sin(alfa))-(xo + 2.5 * a, yo - 1 * a - 12), &HC0&'Рисуем нагрузку qPicture1.DrawWidth = 1.2For s = xo + 3 * a To xo + 5 * a Step 5Picture1.Line (s, yo - 2 * a)-(s, yo - 1 * a)Picture1.Line (s, yo - 10)-(s - 0.8, yo - a * 1.5)Picture1.Line (s, yo - 10)-(s + 0.8, yo - a * 1.5)Next sPicture1.Line (xo + 3 * a, yo - 2 * a)-(xo + 5 * a, yo - 2 * a)'q2-q1Picture1.Line (xo + 8 * a, yo - 1 * a)-(xo + 8 * a + 5, yo - 1 * a)Picture1.Line (xo + 8 * a + 5, yo - 1 * a)-(xo + 8 * a + 10, yo + 2 * a)Picture1.Line (xo + 8 * a + 10, yo + 2 * a)-(xo + 8 * a, yo + 2 * a)Picture1.Line (xo + 8 * a, yo + 2 * a)-(xo + 8 * a + 10, yo + 2 * a)Picture1.Line (xo + 8 * a, yo + 2 * a)-(xo + 8 * a + 3, yo + 2 * a - 1)Picture1.Line (xo + 8 * a, yo + 2 * a)-(xo + 8 * a + 3, yo + 2 * a + 1)Picture1.Line (xo + 8 * a, yo - 1 * a)-(xo + 8 * a + 3, yo - 1 * a - 1)Picture1.Line (xo + 8 * a, yo - 1 * a)-(xo + 8 * a + 3, yo - 1 * a + 1)Picture1.Line (xo + 8 * a, yo - 1 * a)-(xo + 8 * a + 3, yo - 1 * a - 1)Picture1.Line (xo + 8 * a, yo - 1 * a + 5)-(xo + 8 * a + 6, yo - 1 * a + 5)Picture1.Line (xo + 8 * a, yo - 1 * a + 5)-(xo + 8 * a + 3, yo - 1 * a + 4)Picture1.Line (xo + 8 * a, yo - 1 * a + 5)-(xo + 8 * a + 3, yo - 1 * a + 6)Picture1.Line (xo + 8 * a, yo - 1 * a + 10)-(xo + 8 * a + 7, yo - 1 * a + 10)Picture1.Line (xo + 8 * a, yo - 1 * a + 10)-(xo + 8 * a + 3, yo - 1 * a + 9)Picture1.Line (xo + 8 * a, yo - 1 * a + 10)-(xo + 8 * a + 3, yo - 1 * a + 11)Picture1.Line (xo + 8 * a, yo - 1 * a + 15)-(xo + 8 * a + 8, yo - 1 * a + 15)Picture1.Line (xo + 8 * a, yo - 1 * a + 15)-(xo + 8 * a + 3, yo - 1 * a + 14)Picture1.Line (xo + 8 * a, yo - 1 * a + 15)-(xo + 8 * a + 3, yo - 1 * a + 16)Picture1.Line (xo + 8 * a, yo - 1 * a + 20)-(xo + 8 * a + 9, yo - 1 * a + 20)Picture1.Line (xo + 8 * a, yo - 1 * a + 20)-(xo + 8 * a + 3, yo - 1 * a + 19)Picture1.Line (xo + 8 * a, yo - 1 * a + 20)-(xo + 8 * a + 3, yo - 1 * a + 21)Picture1.Line (xo + 8 * a, yo - 1 * a + 25)-(xo + 8 * a + 10, yo - 1 * a + 25)Picture1.Line (xo + 8 * a, yo - 1 * a + 25)-(xo + 8 * a + 3, yo - 1 * a + 24)Picture1.Line (xo + 8 * a, yo - 1 * a + 25)-(xo + 8 * a + 3, yo - 1 * a + 26)'Подпись точек заделкиPicture1.DrawWidth = 1.1Picture1.FontSize = 12Picture1.CurrentX = xo - 6Picture1.CurrentY = yo + 12Picture1.Print "A"Picture1.CurrentX = xo + 8 * a - 10Picture1.CurrentY = yo - 1 * a + 25Picture1.Print "B"Picture1.CurrentX = xo + 25Picture1.CurrentY = yo - 5Picture1.Print "C"Picture1.CurrentX = xo + 7 * a + 15Picture1.CurrentY = yo - 2 * a - 15Picture1.Print "D"Picture1.CurrentX = xo + 3 * a + 10Picture1.CurrentY = yo - 0.3 * aPicture1.Print "P1"Picture1.CurrentX = xo + 1.5 * aPicture1.CurrentY = yo - 2 * aPicture1.Print "P2"Picture1.CurrentY = yo + 1 * aPicture1.Print "M"Picture1.CurrentX = xo + 5 * aPicture1.CurrentY = yo - 2.5 * aPicture1.Print "q"Picture1.CurrentX = xo + 8 * a + 8Picture1.CurrentY = yo - 1 * aPicture1.Print "q1"Picture1.CurrentX = xo + 8 * a + 10Picture1.CurrentY = yo - 1 * a + 25Picture1.Print "q2"'Сектор под момент'Picture1.ForeColor = 0Picture1.Circle (xo + 1.9 * a, yo + 1 * a), 6, 0, 7 * Atn(1), 3.5 * Atn(1)Picture1.Line (xo + 2.31 * a, yo + 1.5 * a)-(xo + 1.9 * a + 4.7, yo + 1 * a)Picture1.Line (xo + 2.31 * a, yo + 1.5 * a)-(xo + 2 * a + 7, yo + 1 * a)Picture1.DrawWidth = 1Picture1.DrawStyle = 2End SubPrivate Sub Command1_Click()Unload MeEnd SubPrivate Sub Form_load()frmDannye.Height = 6195frmDannye.Width = 9195End SubOption ExplicitPrivate Sub cmdClose_Click()Unload MeEnd SubPrivate Sub cmdExcel_Click()Dim XL As New Excel.ApplicationXL.Workbooks.Open App.Path & "\MyBook.xls"XL.Visible = TrueSet XL = XL.ActiveWorkbook.Sheets.ApplicationWith XL.ActiveSheet .Cells(1, 2) = "Исходные данные" .Cells(2, 1) = "F1=" .Cells(3, 1) = "F2=" .Cells(4, 1) = "M=" .Cells(5, 1) = "alfa1=" .Cells(2, 2) = Val(frmDannye.tbP1.Text) .Cells(3, 2) = Val(frmDannye.tbP2.Text) .Cells(4, 2) = Val(frmDannye.tbM.Text) .Cells(5, 2) = pi * alf1 / 180 .Cells(2, 3) = "kH" .Cells(3, 3) = "kH" .Cells(4, 3) = "kH*m" .Cells(5, 3) = "рад" .Cells(1, 6) = "Расчет реакций" .Cells(2, 6) = "Шарнирное закрепление:" .Cells(3, 6) = "Rd=" .Cells(4, 6) = "Rb=" .Cells(5, 6) = "Xa=" .Cells(6, 6) = "Ya=" .Cells(10, 6) = "Скользящая заделка:" .Cells(11, 6) = "Rd=" .Cells(12, 6) = "Rb=" .Cells(13, 6) = "Xa=" End WithEnd SubPrivate Sub Command1_Click()Unload MefrmRaschet.ShowEnd SubPrivate Sub Form_load()frmRaschet.Height = 5325frmRaschet.Width = 8340For i = 0 To 1 msfgSharnir.ColAlignment(i) = 4 msfgZadelka.ColAlignment(i) = 4 Next imsfgSharnir.TextMatrix(0, 0) = "Сила"msfgSharnir.TextMatrix(0, 1) = "Значение"msfgSharnir.TextMatrix(1, 0) = "Rd"msfgSharnir.TextMatrix(2, 0) = "Rb"msfgSharnir.TextMatrix(3, 0) = "Xa"msfgSharnir.TextMatrix(4, 0) = "Ya"msfgZadelka.TextMatrix(0, 0) = "Сила"msfgZadelka.TextMatrix(0, 1) = "Значение"msfgZadelka.TextMatrix(1, 0) = "Rd"msfgZadelka.TextMatrix(2, 0) = "Rb"msfgZadelka.TextMatrix(3, 0) = "Xa"VyvodEnd SubPrivate Sub vscrlUgol_Change()txtUgol.Text = vscrlUgol.ValueVyvodEnd SubPublic Sub Vyvod()'beta = Val(txtUgol.Text)RaschetSharnirmsfgSharnir.TextMatrix(1, 1) = Str(Round(Rd, 2))msfgSharnir.TextMatrix(2, 1) = Str(Round(Rb, 2))msfgSharnir.TextMatrix(3, 1) = Str(Round(Xa, 2))msfgSharnir.TextMatrix(4, 1) = Str(Round(Ya, 2))RaschetZadelkamsfgZadelka.TextMatrix(1, 1) = Str(Round(Rd, 2))msfgZadelka.TextMatrix(2, 1) = Str(Round(Rb, 2))msfgZadelka.TextMatrix(3, 1) = Str(Round(Xa, 2))End SubPrivate Sub Form_Load()End SubPrivate Sub vixod_Click()Unload MeEnd Sub
|
|