240 likes | 379 Views
Introduction to Engineering Computing GEEN 1300 Lecture 7 15 June 2010 Review for midterm. Hooking VBA code to the “Compute Re” button…. D ouble-click the Compute Re button. This will cause the following Sub wrapper to pop up in a code module:. In here , we must add code
E N D
Introduction to Engineering Computing • GEEN 1300 • Lecture 7 • 15 June2010 • Review for midterm
Hooking VBA code to the “Compute Re” button… Double-click the Compute Re button. This will cause the following Sub wrapper to pop up in a code module: In here, we must add code to carry out the necessary calculations and display the Reynolds Number result
This variable is the name you created for your textbox This is a variable you create and use in your calculation. Do NOT use the textbox name on the LHS of your calculation – it will not work!!
How to run and remove user forms insert a new module and add this Sub to start the UserForm double-click the Quit button and add the code to remove (“unload”) the UserForm run the StartReynoldsNumbermacro… …and enter values with units selected
UserForms UserForms can be loaded automatically when the workbook is opened. (This is called an “event handler.”) And they can also be unloaded automatically when the workbook is closed. • Go to VBE and double click on thisworkbook item in Project • Explorer. (If Project Explorer doesn’t show up, use view) • 2. Change left field at top from General to Workbook. • 3. Type in ReynoldsNumber.Show • (this is not on any exam; it’s just a useful FYI)
Things to Remember!!! • Create your own variables to carry out calculations, NOT the variables in the user form • Make sure the variables from the user form that you assign to your created variables are the same names as in your user form • These variables are those used from your text boxes and your option buttons, NOT your labels • You should not have the same name for your text box as for your label
This variable is the name you created for your option button FormatNumber – number of digits after the decimal point. Does not round.
If you get a Reynolds number of 2134.3721 and the program says MsgBox(FormatNumber(Re,1)), what will the message box say? • 2134 • 2135 • 2134.3 • 2134.37 • 2134.4
optional MsgBox Function MsgBox(“prompt”,buttons,”title”,helpfile,context)
optional MsgBox Function MsgBox(“prompt”,buttons,”title”,helpfile,context) Button codes vbOKOnlyvbExclamation vbOKCancelvbInformation vbAbortRetryIgnore vbDefaultButton1 vbYesNoCancel vbDefaultButton2 vbYesNo vbDefaultButton3 vbRetryCancel vbDefaultButton4 vbCriticalvbSystemModal vbQuestion
MsgBox Function MsgBox result is button clicked by user Putting line breaks into the message displayed:
Announcements: • Midterm exam Thursday at 8am • Open book • Open notes • Open Excel/VBE • No cheat sheet (duh) • No collaboration
What the exam looks like: Excel: Displaying data (surface plots, creating xy grids) Fitting a model to a set of data points How good is the model overall? How good are the coefficients? Transforming equations to regression-friendly forms
What the exam looks like: VBE: Defining functions for use in spreadsheet Defining subs to manipulate spreadsheet Tracing through a function or sub (control flow) Calling a sub or function from another sub Fixing functions or subs with bugs Making a UserForm
How to study: • Review all lecture notes • Review all lab & homework problems • Re-read any textbook sections & lecture notes that you need in order to fill in or clarify any shaky/fuzzy topics • Think about Excel/VBA strengths & weaknesses • Email and/or come to help hours with any questions
Excel syntax • Precedence order, parentheses • Cell references & cell addressing • Formula copy • How to translate equations & word statements to/from Excel • Plotting • Different types of models: • Building them (see next slides) • Evaluating them (R2 & co.) • Using them
Trendline & data regression • What does each one do? What’s the difference between them? • Which one do you use for what kind of problem? • What do you feed into them and what do they return? • How to transform equations so that these tools will work on them (also know when to do that and when you can’t) • How to fit linear models if you don’t have these tools?
Excel, cont.: • Goal Seek & Solver • What does each one do? • What’s the difference between them? • Which one do you use for what kind of problem? • What do you feed into them and what do they return?
Excel, cont.: • Matrices • Matrix math in Excel: naming, addition, subtraction, scaling, multiplication, inverse, determinant, transpose • The identity matrix • Systems of linear equations: • How they correspond to matrix problems • How to translate sets of linear equations to/from the equivalent matrix equation • How to solve that matrix equation
Excel, cont.: • Iteration • How & when to use iteration • Bisection • What it does (including what a root is) • How the algorithm works • How to implement it in Excel
VBA: • The environment • VBA “world” & Excel “world” • The VBE • Modules: what they are & how you insert them • The debugger: • How you use it • What it lets you find out • How that’s different between Subs & Functions
VBA, cont.: • Basic Syntax • Write/evaluate VBA statements • Know the basic functions (arithmetic, logic, relational) • Understand the precedence rules • Subs & Functions • Know the differences • Know how to write & use both
VBA, cont.: • Decisions • Know how to decode them and how to write them • Including working with logical and relational operators • Loops • Know how all five loop structures work • Be able to write one for a prescribed task • Be able to figure out what a given loop will produce • Flowcharts • Be able to translate simple flowcharts to/from code
VBA, cont.: • Modular programming • Variables • When, why, & how do you declare variables? • When should you use different kinds of variables? • Scoping • Dialog boxes • MsgBox & InputBox • Understand them and use them • User forms