Presentation is loading. Please wait.

Presentation is loading. Please wait.

Spreadsheet-Based Decision Support Systems

Similar presentations


Presentation on theme: "Spreadsheet-Based Decision Support Systems"— Presentation transcript:

1 Spreadsheet-Based Decision Support Systems
Chapter 15: Sub Procedures and Function Procedures Prof. Name Position (123) University Name

2 Overview 15.1 Introduction 15.2 Sub Procedures
15.3 Function Procedures 15.4 Public and Private Procedures 15.5 Applications 15.6 Summary

3 Introduction Calling sub procedures
Executing function procedures to return a value Pass variables by reference and by value Private and public procedures Two applications which work with calling sub procedures and creating function procedures which pass variables

4 Sub Procedures Calling Other Procedures
Passing Variables in Procedures

5 Calling Other Procedures
You should group various actions into several smaller sub procedures rather than having one large sub procedure in which the entire program is written. The ideal module structure for your program is to have one Main() sub procedure from which other sub procedures are called. This Main macro will usually be assigned to a “Start” button on the “Welcome” sheet. To call another sub procedure, we use the command Call followed by the sub procedure name.

6 Calling Other Procedures (cont’d)
For example, consider three different sub procedures, called GetInput(), Calculations(), and CreateReport(). We can then call these three sub procedures from the Main() sub procedure as follows. Sub Main() Call GetInput Call Calculations Call CreateReport End Sub You can also call other sub procedures from these three sub procedures.

7 Passing Variables in Procedures
We can also pass variables to a procedure when calling the procedure. Passing a variable by reference implies that we are giving the name of the variable to which the procedure can refer to find the current variable value; that is, we are referring to the storage space of that value. The function procedure can actually access and modify the value of the specified variable. Passing a variable by value implies that we are copying the current value of the specified variable and using that value in the procedure. The function procedure cannot modify the variable, but only use its current value. Passing variables in sub procedures can be helpful when performing a task multiple times with changing parameters.

8 Function Procedures Passing Variables in Functions

9 Creating Function Procedures
Function procedures are sub procedures which can pass variables or return values. A function procedure can be called from any sub procedure or any other function procedure, using the Call statement. Function FunctionName() …. End Function

10 Passing Variables in Functions
To pass a variable in VBA, you should insert the variable as an argument/parameter of the function when it is called. Call FunctionName(variable to be passed) If the function will receive a variable as input to the function, the function procedure statement must include a variable name as an argument. Function FunctionName(variable passed) It is not necessary that variables be passed when calling a function nor return a value Default method for passing variables is by reference, can specify ByVal in function argument to pass by value

11 Passing Variables in Functions (cont’d)
We create a function which calculates the sum of two values. Function Sum(a, b) …… End Function The variable name used as an argument when the function is called and the variable name used in the function procedure statement to not need to be the same. They must be of the same data type if the data type is specified in the function statement. Call Sum(x, y) This would imply that we have declared x and y as variables in the procedure from which we call our function

12 Passing Variables in Functions (cont’d)
The variables a and b in this example do not need to be declared. They will be the variables used throughout the function procedure. In this case a and b will assume the respective data types assigned to x and y. If we had defined our function statement with data types in the argument, we would be restricted to only passing variables of that data type. Function Sum(a As Integer, b As Integer) To return a value from a function in VBA, you should assign a value to the name of the function procedure. Function Sum(a, b) Sum = a + b End Function

13 Public and Private Procedures
A sub procedure, like a variable, can also be defined as Public or Private. A private sub procedure is declared by putting the word Private before the Sub statement. Private sub procedures can only be called from procedures in the same module. Private sub procedures are also not listed when you try to run a macro in Excel. A public sub procedure can be called from any other procedure. The word Public can be put in front of the Sub statement, or the Sub statement can be written without a preceding statement.

14 Public and Private Procedures (cont’d)
Consider four small sub procedures. Two of these procedures are private: Test1() and Test2() Since they are in the same module, they can call one another. Private Sub Test1() MsgBox "This is Test1" Call Test2 End Sub Private Sub Test2() MsgBox "This is Test2"

15 Public and Private Procedures (cont’d)
The third sub procedure called Test3() is public but in another module. We are not allowed to call either of the private sub procedures in the original module. That is, Test3() cannot contain the code: Call Test1 or Call Test2. However, we can call this public procedure from one of our private procedures. Private Sub Test1() MsgBox "This is Test1" Call Test3 End Sub

16 Public and Private Procedures (cont’d)
The fourth sub procedure called Test4() is also public and in the same module as Test1() and Test2(). Even though Test4() is public it can still call the private procedures since they are in the same module. Sub Test4() MsgBox “This is Test4” Call Test1 End Sub

17 Applications Navigating Procedures Derived Math Functions

18 Applications Many functions are already available to us through Excel formulas and VBA math functions; however, there may be specific needs depending on the program or DSS you are developing that may require a customized function. Navigating Procedures Derived Math Functions

19 Navigating Procedures
In many of the case studies we develop, and in general good GUI design, there are several buttons in our workbook used to navigate through the different spreadsheets. “Continue”, “Next”, “Back”, “Previous”, etc. Each time one of these buttons is clicked, we want to close the current worksheet, that is hide it, and make the next appropriate worksheet visible. [We want to try to always have only one sheet showing; this is to minimize the user’s awareness of background actions being performed in the spreadsheet and code.]

20 Navigating Procedures (cont’d)
Consider a workbook with several worksheets. “Input”, “Step 1”, “Step 2”, and “Optimization” These worksheets should be viewed by the user in the order listed. If we click a “Next” button on the “Input” worksheet we want to hide the “Input” sheet and make the “Step 1” sheet visible Sub NextSheet() Worksheet(“Step 1”).Visible = True Worksheet(“Input”).Visible = False End Sub [Note: We must make the new sheet visible before hiding the current sheet. If we make these statements in the reverse order, we will momentarily have a workbook with no visible worksheets; this will create an error in VBA.]

21 Navigating Procedures (cont’d)
We cannot assign this same macro to the “Next” button found on the “Step 1” worksheet. If we press “Next” on the “Step 1” sheet, we want to make the “Step 2” sheet visible and hide the “Step 1” sheet. Sub NextSheet() Worksheet(“Step 2”).Visible = True Worksheet(“Step 1”).Visible = False End Sub

22 Navigating Procedures (cont’d)
Our solution is to create a function procedure which passes a worksheet name as its variable; we call this the NextSheet() function. We can capture the desired worksheet name in each unique sub procedure associated with the buttons on each sheet and then call a function to make this worksheet visible and hide the current worksheet. Public name As String Sub InputNext() name = “Step 1” Call NextSheet(name) End Sub Function NextSheet(name) Worksheets(name).Visible = True ActiveSheet.Visible = False End Function

23 Figure 15.1 We use this function structure above to assign related macros to the “Next” button on each of the sheets in our workbook.

24 Navigating Procedures (cont’d)
We have a particular sheet that is usually hidden but which can be shown at some point; this is an “Example” worksheet which the user may refer to at times while using our program. To view this “Example” sheet, there may be a “View Example” button on all other sheets in the workbook. If this button is clicked, we want to close the current sheet and show the “Example” sheet. On the “Example” sheet we may have a “Return to Program” button which should re-open the previously visible sheet.

25 Figure 15.2 To perform these actions, we need to capture the original worksheet name in which we first click the “Example” button so that we know which sheet to re-open when the “Return to Program” button is clicked. Public ws As Worksheet Sub ViewExample() Worksheets(“Example”).Visible = True Call CloseCurrent() End Sub Function CloseCurrent() Set ws = ActiveSheet ws.Visible = False End Function Sub ReturnToProgram() Ws.Visible = True Worksheets(“Example”).Visible = False this time we will not need to pass a variable

26 Derived Math Functions
The pre-defined VBA math functions and trigonometric functions can be used to derive new functions. To actually create these derived functions in Excel, we create a function procedure and both pass a variable and return some value. To create the Log base n derived math function, we could create the following function. Function LogBaseN(x, n) LogBaseN = Log(x) / Log(n) End Function

27 Derived Math Functions (cont’d)
The values for x and n would need to have been assigned in the sub procedure which calls this function prior to calling the function. In these functions we may not directly call the function using the Call statement; we can instead just refer to the function name, such as in a Message Box or another function. Sub FindLog() Dim x, n As Integer x = InputBox(“Enter x value of Log base n of x function: “) n = InputBox(“Enter n value of Log base n of x function: “) MsgBox “The value of Log base “ & n & “ of “ & x & “ is: “ & LogBaseN(n, x) End Sub Note that the variables x and n are declared privately in the sub procedure but can still be passed to the function. Also notice that since the data type for x and n is the same we can just state it once after declaring both variables. Also note that it is irrelevant which order sub procedures and functions are entered into a module. The code is not read from procedure to procedure in a module; rather a particular procedure is run and only if another procedure is called is it also run.

28 Summary The ideal module structure for a program is to have one Main() sub procedure from which other sub procedures are called. To call another sub or function procedure, use the command Call followed by the sub procedure name. Function procedures are similar to sub procedures and follow this basic structure: Function FunctionName() …. End Function To pass a variable in VBA, you should insert the variable as an argument/parameter of the function when it is called. Use the following structure to call a function: Call FunctionName(variable to be passed) A sub procedure, like a variable, can also be defined as Public or Private.

29 Additional Links (place links here) Projectile
Simple forms with basic Excel manipulation Birthday Simulation Simple simulation with statistical analysis Portfolio Management and Optimization Using the Solver


Download ppt "Spreadsheet-Based Decision Support Systems"

Similar presentations


Ads by Google