| Bill-of-Material Post-Processing Macros | 
%BOMRMLB: Indented Bill of Material
| %bomrmlb ( | ROOT=root, IN=SAS-data-set, LEV=variable, PARENT=variable, | 
|  | COMP=variable, QUANTITY=variable, QTYPROD=variable, | 
|  | FACTOR=variable, LEADTIME=variable, TOTLEAD=variable, | 
|  | OFFSET=variable, TOTOFF=variable, PARENID=variable, | 
|  | PROD=variable, REQ=req, OUT=SAS-data-set, DROP=variables); | 
 
 constructs an indented bill of material for a given item referred 
 to as the item Root, which lists 
 all components directly or indirectly used in the item Root. 
 If a component is a subassembly, all its components and all their 
 components are also listed, down to purchased items and raw materials. 
 The parameters for this macro are as follows:
 
- ROOT=root
- specifies the part number of the item 
 for which the indented bill of material is constructed. 
 This item is referred to as the item Root. 
 You must specify either a number or a quoted string 
 for the ROOT= parameter, 
 depending on the type of the Component variable.
 
- IN=SAS-data-set
- names the Indented BOM input data set. 
 The default value is the most recently created SAS data set. 
 A null value is replaced by the default value.
 
- LEV=variable
- identifies the variable in the Indented BOM 
 data set that contains the indenture level information. 
 The default value is _Level_. 
 A null value is replaced by the default value.
 
- PARENT=variable
- identifies the variable in the Indented BOM 
 data set that contains the parent item's part number. 
 A null value tells the macro program not to look for the variable 
 in the input data set that contains the parent item's part number. 
 The default value is _Parent_.
 
- COMP=variable
- identifies the variable in the Indented BOM 
 data set that contains the component's part number. 
 This variable is referred to as the Component variable. 
 
 
 The default value is _Part_. 
 A null value is replaced by the default value.
 
- QUANTITY=variable
- identifies the variable in the Indented 
 BOM data set that contains the quantity per assembly information. 
 A null value tells the macro program not to look for the variable 
 in the input data set that contains the quantity per assembly 
 information. 
 The default value is Qty_Per.
 
- QTYPROD=variable
- identifies the variable in the Indented 
 BOM data set that contains the quantity per product information. 
 A null value tells the macro program not to look for the variable 
 in the input data set that contains the quantity per product 
 information. 
 The default value is Qty_Prod.
 
- FACTOR=variable
- identifies the variable in the Indented 
 BOM data set that contains the scrap factor information. 
 A null value tells the macro program not to look for the variable 
 in the input data set that contains the scrap factor 
 information. 
 The default value is S_Factor.
 
- LEADTIME=variable
- identifies the variable in the Indented BOM 
 data set that contains the lead time information.  If you do not specify 
 this parameter or specify a null value, 
 the macro program will not look for the variable in the input 
 data set that contains the lead time information.
 
- TOTLEAD=variable
- identifies the variable in the Indented 
 BOM data set that contains the total lead time information. 
 A null value tells the macro program not to look for the variable 
 in the input data set that contains the total lead time information. 
 The default value is Tot_Lead. 
 The specification of the TOTLEAD= parameter is ignored if the macro 
 program cannot find the variable in 
 the Indented BOM data set that contains the lead 
 time information.
 
- OFFSET=variable
- identifies the variable in the Indented 
 BOM data set that contains the lead-time offset information. 
 A null value tells the macro program not to look for the variable 
 in the input data set that contains 
 the lead-time offset information. 
 The default value is L_Offset.
 
- TOTOFF=variable
- identifies the variable in the Indented 
 BOM data set that contains the total lead-time offset information. 
 A null value tells the macro program not to look for the variable 
 in the input data set that contains 
 the total lead-time offset information. 
 The default value is Tot_Off. 
 The specification of the TOTOFF= parameter is ignored if 
 the macro program cannot find the variable in 
 the Indented BOM data set that contains the 
 lead-time offset information.
 
- PARENID=variable
- identifies the variable in the Indented 
 BOM data set that contains the ID number for the parent record. 
 A null value tells the macro program not to look for the variable 
 in the input data set that contains the ID number of the parent record. 
 The default value is Paren_ID.
 
- PROD=variable
- identifies the variable in the Indented 
 BOM data set that contains the end item's part number. 
 A null value tells the macro program not to look for the variable 
 in the input data set that contains the end item's part number. 
 The default value is _Prod_.
 
- REQ=req
- specifies the quantity required for the item 
 Root.  The default value is 1.  A null value 
 is replaced by the default value.
 
- OUT=SAS-data-set
- names the output data set that contains 
 indented bill of material for the item Root. 
 The default value is _BOMOUT_. 
 A null value is replaced 
 by the default value.
 
- DROP=variables
- identifies all the variables in the Indented 
 BOM data set that you do not want to be included in the output 
 data set.  You can list the variables in any form that SAS allows. 
 If you do not specify the DROP= parameter, or specify a null 
 value, all variables in the Indented BOM data set are included in 
 the output data set.
 
The input data set for this macro is the Indented BOM data set 
 described in the section "Input Data Sets".
 
The following parameters 
 specify the variables in the input data set that are required by the 
 %BOMRMLB macro.
 
- COMP=
 
- A character or numeric variable that contains the part 
                  number of the component. 
 
- LEV=
 
- A numeric variable that contains the indenture level 
                  information. 
 
The following parameters specify the variables in the Indented BOM 
 input data set that are used by the macro, if they can be found in 
 the data set.
 
- FACTOR=
 
- A numeric variable that contains the scrap factor 
                  information. 
 
- LEADTIME=
 
- A numeric variable that contains the lead time of the 
                  component. 
 
- OFFSET=
 
- A numeric variable that contains the lead-time offset 
                  information. 
 
- PARENID=
 
- A numeric variable that contains the ID number for the 
                  parent record. 
 
- PARENT=
 
- A character or numeric variable that contains the part 
                  number of the parent item.  The type of this variable 
                  must be the same as that of the variable specified in the 
                  COMP= parameter. 
 
- PROD=
 
- A character or numeric variable that contains the part 
                  number of the end item.  The type of this variable must 
                  be the same as that of the variable specified in the 
                  COMP= parameter. 
 
- QTYPROD=
 
- A numeric variable that contains the quantity per product 
                  information. 
 
- QUANTITY=
 
- A numeric variable that contains the quantity per 
                  assembly information. 
 
- TOTLEAD=
 
- A numeric variable that contains the total lead time 
                  information. 
 
- TOTOFF=
 
- A numeric variable that contains the total lead-time 
                  offset information. 
 
- DROP=
 
- Variables that you do not want to be included in the 
                  output data set. 
 
The output data set contains the indented bill of material for the item 
 Root.  This data set is a subset 
 of the Indented BOM input data set, and 
 has the same variables as the 
 Indented BOM data set, except for the variables 
 that are specified in the DROP= parameter.  The quantity per product 
 (the value of the variable specified in the QTYPROD= parameter) of each 
 record in this data set reflects the quantity needed in producing  units of the item Root, 
 where
 
 units of the item Root, 
 where  is the value specified in the REQ= parameter.
 is the value specified in the REQ= parameter.
 
Note that the first record of the output data set does not contain 
 a parent-component relationship.  Therefore, the values for all variables 
 that contain product structure information in this record have to be missing. 
 The %BOMRMLB macro sets the values for the variables that are specified in the 
 PARENT=, QUANTITY=, FACTOR=, and OFFSET= parameters to a missing 
 value.  It also sets the value of the variable specified in the PARENID= 
 parameter to a missing value since the first record does not have a parent 
 record.  If there are other variables that also contain product structure 
 data, you must manually set the values for those variables in the first 
 record.  See the section "Product Structure Data Set" in Chapter 2 
 for the variables that contain product structure information.
 
Upon completion, this macro defines a macro variable, _BOMRMLB_, 
 which contains a character string that indicates the status of the 
 macro execution.  See the section "Macro Variables" for the possible values 
 of this macro variable.
 
The following statement constructs an indented bill of material for the item 
 'A100' from the Indented BOM data set displayed in Figure 3.1.
 
  
    %bomrmlb(root='A100', in=IndBOM, quantity=QtyPer, 
             factor=Fscrap, leadtime=LeadTime, offset=LTOff, 
             out=BomOut1, drop=Paren_ID Part_ID _Prod_);
 
The indented bill of material for the item 'A100' is displayed 
 in Figure 3.2.
 
| 
 
| 0 |  | A100 | One-way socket assem. | . | . | 1 | Each | 1 | 1 | . | 0 | . | . |  
| 1 | A100 | 1500 | Steel holder | 1 | 0.0 | 1 | Each | 2 | 3 | 0 | 0 | . | . |  
| 2 | 1500 | 1400 | 1/4-20 Screw | 2 | 0.0 | 2 | Each | 1 | 4 | 0 | 0 | . | . |  
| 1 | A100 | 1600 | One-way socket | 1 | 0.0 | 1 | Each | 2 | 3 | 0 | 0 | . | . |  
| 1 | A100 | 1700 | Wiring assembly | 1 | 0.0 | 1 | Each | 1 | 2 | 0 | 0 | . | . |  
| 2 | 1700 | 2200 | 16-Gauge lamp cord | 12 | 0.1 | 12 | Feet | 2 | 4 | 0 | 0 | . | 07APR2001 |  
| 2 | 1700 | 2210 | 14-Gauge lamp cord | 12 | 0.1 | 12 | Feet | 2 | 4 | 0 | 0 | 08APR2001 | . |  
| 2 | 1700 | 2300 | Standard plug terminal | 1 | 0.0 | 1 | Each | 1 | 3 | 0 | 0 | . | . |  | 
Figure 3.2: Indented Bill of Material for Item A100 (BomOut1)