Field Selection Graphical User Interface

Abstract
A field selection graphical user interface (GUI) for use with a protocol analyzer. The GUI allows selecting a source presented by the GUI, selecting a field from a plurality of fields presented by the GUI associated with the selected source, defining one or more preconditions associated with the selected field from a plurality of preconditions presented by the GUI relevant to the selected field, and calculating a field layout in accordance with the selected field and defined one or more preconditions. The GUI further allows selecting a second field from the plurality of fields presented by the GUI associated with the selected source, defining one or more preconditions associated with the selected second field from a plurality of preconditions presented by the GUI relevant to the selected second field, and calculating a field layout in accordance with the selected field and the second field.
Description
BACKGROUND

This application relates to test systems intended for protocol analysis, and to a graphical user interface allowing for the building of aggregate fields that present complex combinations of fields and subfields from different sources.


Some areas of protocol analysis require building and using special aggregate fields that may present complex combinations of fields and subfields from different data sources. Such aggregate fields can be used to present analyzed data in different views that simplify the data, and provide better user perception of the analyzed data. One of these views may comprise a Wave Form View, which may present data as a set of wave form lines. Furthermore, one or more fields that are part of one or more of the above-noted aggregate fields may be conditional; they exist and are to be presented in a particular field layout only if one or more preconditions are met. These preconditions may in themselves comprise one or more simple field definition (such as “field X equals value Y”), or may comprise more complex Boolean or other logic, perhaps combining multiple logic patterns.


Traditionally, the ability to define these aggregate fields in a protocol analyzer has been difficult.


SUMMARY

The inventors of the present invention have recognized that in order to build such aggregate fields, as described above, it is desirable to provide a specialized graphical user interface (GUI) providing an easy and convenient way to select one or more fields and/or one r more subfields from one or more multiple sources, define one or more necessary (or preferred) preconditions, and provide a plurality of different combination options for preferably specifying how one or more selected fields and/or subfields should be combined in order to build a desired resulting aggregate fields.


While field selection GUIs have been presented in various different Wave Form View applications, in particular these solutions do not allow for the designation of one or more of the noted preconditions for the one or more selected fields. These and other applications allow for field selections from field layouts and may provide field combination options, but they fail to provide to a user field selection options along with precondition selection and definition in a simple to use, single GUI. Typically, preconditions and the like may be set in one or more filtering GUI presentations, separated from any field selection ability, thus reducing flexibility of the system and making overall field definition in a protocol analyzer inconvenient for the user.


This application is therefore directed to a unique GUI allowing a user to select one or more multiple fields from one or more multi field layouts (such as definitions of different types of data packets that may be used by different transport or other data transmission protocols), define and set up one or more field preconditions, and preferably all of these selections into an aggregate or combined field. Some of these fields may be defined as conditional in that they may only be provided in the multi field layout for selection if one or more conditions are met, such as if some other field first contains some other predefined value. The meeting of such preconditions preferably will allow for the presentation of one or more of such conditional fields in the multi field layout. Thus, one or more preconditions may be set in accordance with one or more of such fields to present the conditions in accordance with which it may be available or selection. The inventive GUI presented in accordance with one or more embodiments of the present invention efficiently combines both specifying field preconditions and field selection in one convenient GUI.


Therefore, it would be beneficial to provide a system and apparatus that provides a single GUI for setting preconditions and selecting fields to be part of a test protocol in accordance with a protocol analyzer.


Still other objects and advantages of the invention will be apparent from the specification and the drawings.





BRIEF DESCRIPTION OF DRAWINGS

For a more complete understanding of the invention, reference is made to the following description and accompanying drawings, in which:



FIG. 1 is a graphical display depicting a field selection dialog window in accordance with an embodiment of the invention;



FIG. 2 is a graphical display depicting selection of a static field from one source in accordance with an embodiment of the invention;



FIG. 3 is a graphical display depicting selection of a conditional field in accordance with an embodiment of the invention;



FIG. 4 is a graphical display depicting the results of adding a field in accordance with an embodiment of the invention;



FIG. 5 is a graphical display depicting the results of adding a field showing expanded combined fields in accordance with an embodiment of the invention;



FIG. 6 is a graphical display depicting selection of a field from multiple sources in accordance with an embodiment of the invention;



FIG. 7 is a graphical display depicting selection of a field from multiple sources showing expanded combined fields in accordance with an embodiment of the invention;



FIG. 8 is a graphical display depicting selection of fields from different sources to make a combination in accordance with an embodiment of the invention;



FIG. 9 is a graphical display depicting an add combined field dialog box in accordance with an embodiment of the invention;



FIG. 10 is a graphical display depicting a result of manually combining fields from different sources in accordance with an embodiment of the invention;



FIG. 11 is a graphical display depicting selection of a field to be added to a manually created field combination in accordance with an embodiment of the invention;



FIG. 12 is a graphical display depicting a modify combined field dialog box in accordance with an embodiment of the invention;



FIG. 13 is a graphical display depicting a result of manually combining fields in accordance with an embodiment of the invention;



FIG. 14 is a graphical display depicting selection of a field to be removed from a manually created field combination in accordance with an embodiment of the invention;



FIG. 15 is a graphical display depicting a modify combined field dialog box in accordance with an embodiment of the invention;



FIG. 16 is a graphical display depicting a modify combined field dialog box after removing fields in accordance with an embodiment of the invention;



FIG. 17 is a graphical display depicting a result of removing fields in accordance with an embodiment of the invention;



FIG. 18 is a graphical display depicting definition of a subfield in accordance with an embodiment of the invention;



FIG. 19 is a graphical user interface display depicting an add subfield or replace existing field dialog box in accordance with an embodiment of the invention;



FIG. 20 is a graphical display depicting a result of adding a subfield in accordance with an embodiment of the invention; and



FIG. 21 is a graphical display depicting a result of defining different field groups for a single field having different preconditions in accordance with an embodiment of the invention.





DETAILED DESCRIPTION

A detailed description of illustrative embodiments will now be provided, making reference to the figures and providing details of the information flow and presentation to a user. Like reference numbers and designations in the various figures indicate like elements.


An inventive GUI is presented in accordance with one or more embodiments of the invention, and in particular is designed to allow for the following:

    • 1) Select a “static field” to create a Wave Form View line from one source. “Static field” has a fixed location and length in a packet and don't depend on any other fields.
    • 2) Select a “dynamic field” to create a Wave Form View line from one source. “Dynamic field” can have different locations (and even lengths) in a packet and depends on other field values. (For example, AET “MSRADDR” field is present only if “BaseType” field has value “MSR”)
    • 3) Select multiple fields from different sources, treat them as a one virtual “multi-source field” and create a Wave Form View line for it.
    • 4) Select subfields of some field and show them as separate Wave Form View lines.
    • 5) Provide flexibility to specify some conditions and different combination options when selecting fields—i.e. show in a Wave Form View line only fields that match some search criteria, show the same field for 2 different sources (like Core0_Thread0 and Core0_Thread1 in AET) in different Wave Form View lines.



FIG. 1 depicts a preferred embodiment of the invention. As is shown in FIG. 1, a field selecting GUI 100 is presented to a user. The GUI is preferably arranged in a manner similar to that of a find/filter dialog. As is shown in FIG. 1, a source selection pane 110 allows for the selection of one or more sources of data for analysis. A field selection pane allows for selection of a particular field for analysis. In a preferred embodiment, field selection pane 120 is dependent upon source selection pane 110; upon selection of a particular source, only relevant fields are preferably displayed for selection. Of course, all fields may be displayed to the user at all times. Also shown in accordance with GUI 100 is a selected/combined field pane 130 that depicts various selected source and field combinations. Thus, the user is able to build a library of the various desired source and field combinations. Also presented in pane 130 as a set of radio buttons 140 allowing the user to select among one or more methods for combining the selected/combined fields, and in particular whether to combine those from different sources.


In accordance with GUI 100, and as is shown in FIG. 2, a preferred set of steps for selecting a static field (a field that does not depend on any other field) may comprise the following steps.


1. Select the source in Source selection pane 110.


2. Select the field in field selection pane 120.


3. Click “Add” button 125 (or double-click the field in the Field selection pane).


4. The field selection will appear in the Selected/Combine Field pane 130.


Referring next to FIG. 3, use of the inventive GUI for selection of a dynamic or conditional field from a single source is shown. The following description of selection of preconditions may be applied to fields that require such preconditions, or may alternatively be applied to one or more fields that may not require such preconditions, but such preconditions may be employed to reduce a data set or the like. In this particular embodiment, the field MSRADDR is dependent upon the “Base Type=MSR. These steps may comprise the following.

    • 1. Select a source in source selection pane 110
    • 2. Select and set one or more values of the fields upon which “conditional” field depends on in field selection pane 120, as shown in FIG. 3.
    • 3. Subsequently select the conditional field in the Field selection pane 120.
    • 4. Click Add button 125 (or double-click the field in the Field selection pane).
    • 5. The field selection will appear in the Selected/Combine Field pane 130.


Referring next to FIG. 4, use of the inventive GUI for selection of a field from a single source matching some predefined filter condition is shown. In this particular embodiment, if the user wants to select a field that matches some filtering criteria consisting of several pre-conditions (for example: select MOT “Address” if Opcode=WRITE or Opcode=READ) then the steps the user may take may comprise the following.

    • 1. Select a source in source selection pane 110.
    • 2. Select the “Combine From the Same Source” field combination option using the appropriate radio button 140.
    • 3. Select and set values of the fields which define the first pre-condition of the conditional field in field selection pane 120 (as shown in FIG. 4), then subsequently select the conditional field in field selection pane 120 (not shown in FIG. 4) and click add button 125 (or double-click the field in the Field selection pane).
    • 4. Repeat step 3 for the second pre-condition.
    • 5. Repeat step 3 for all the other pre-conditions.
    • 6. The field selections will appear in the Selected/Combine Field pane 130. Note that the “expand combined fields radio button is section 140 is not selected, and thus, because there are two preconditions set (for Address—MOT in this example) there is an indication of two combined preconditions associated with this field. If the ‘expand combined fields” radio button is selected, the result is as shown in FIG. 5, in which each precondition is separately shown in Selected/Combine Field pane 130.


In case of the depicted MOT “Address” example in FIGS. 4 and 5, the following steps and results may be performed.

    • 1. Select MOT in the Source selection pane 110.
    • 2. Set Opcode field to WRITE in pane 120.
    • 3. Select and add “Address” field in pane 120 using add button 125.
    • 4. Set Opcode field to READ in pane 120.
    • 5. Select and add “Address” field again in pane 120 using add button 125.


Referring next to FIG. 6, the steps that may be employed for selecting a field from different sources when the fields have the same name is shown. As is shown in FIG. 6, these steps may preferably comprise the following.


If user wants to select fields from different sources when all the fields have the same name (i.e. AET fields from different CoreX_ThreadY sources) then user actions can be described as follows:

    • 1. Select “Combine From Different Sources” field combination option using the appropriate radio button 140.
    • 2. Select the first source in source selection pane 110.
    • 3. Select and set values of the fields which define the first pre-condition of the “conditional” field in field selection pane 120, then subsequently select the “conditional” field in field selection pane 120 and click “Add” button 125 (or double-click the field in the Field selection pane).
    • 4. Select the next source in source selection pane 120, and repeat actions described in the item 3 for the fields.
    • 5. The field selection combining multiple fields will appear in the Selected/Combine Field pane 130. Note that as in FIG. 4, the “expand combined fields radio button in section 140 is not selected, and thus, because there are two preconditions set there is an indication of two combined preconditions associated with this field. If the ‘expand combined fields” radio button is selected, the result is as shown in FIG. 7, in which each precondition is separately shown in Selected/Combine Field pane 130.


Referring next to FIG. 8, manual field selection when fields have different names and different sources are to be employed will be described. Such manual selection may be necessary or preferable because field combination options provided for automation by the inventive field selection GUI may not be able to automatically determine how to combine user field selections into one virtual field. In such a situation, the GUI preferably aids the user in creating field combinations manually.


Therefore, as is shown in FIG. 8, steps for a user to perform these actions may comprise the following.

    • 1. Select any of the field combination options using radio buttons 140 that allow the user to get close to a desired result.
    • 2. Select the first source in source selection pane 110.
    • 3. Select and set values of the fields which define pre-conditions of the “conditional” field in field selection pane 120, then subsequently select the “conditional” field in the field selection pane 120 and click “Add” button 125 (or double-click the field in the Field selection pane).
    • 4. Select the next source in source selection panel 110 and repeat actions described in the item 3 or the fields in field selection panel 120.
    • 5. Field selections combining multiple fields with the same name will appear in the Selected/Combine Field pane 130. As is shown in FIG. 8, each of the combinations is shown in pane 130.


Processing then passes to the steps depicted in FIG. 9, in which

    • 1. First, the user may select one or more fields from pane 130 to combine (MSRADDR and Address in our example as shown in FIG. 8).
    • 2. Right clicking, or otherwise further selecting the selected fields then may pull up the add combined field dialog 900, as shown in FIG. 9. Once dialog 900 is shown, each field definition 910 (corresponding to the fields previously shown in pane 130 of FIG. 8) is shown in expanded form. The use is preferably prompted to type a name for the combined field in area 920, and then select the OK button 930 to close the add combined field dialog box 900.


The result is shown in FIG. 10, in which a manually combined custom field labeled “Address” containing multiple field selections is shown in panel 130, and includes a designation of 4 combined fields therein. If the expand combined fields checkbox radio button in portion 140 is checked then panel 130 will display all field selections from different sources that were combined automatically based on selected field combination options. But manually combined fields still will be shown as combined fields. This allows the user to easily add new field selections to the manually combined fields, as will now be described. Of course, it may be possible to display all of the fields in an expanded format, if desired.


In accordance with this particular embodiment of the invention, in order to see all field selections used to build a combined field, the user may preferably select the combined field and right-click or otherwise indicate similar selection of the field. This action will cause the “Add Combined Field” dialog 900 (See FIG. 9) to pop up and display all the field selections used to build the combined field. If the “Expand Combined Fields” checkbox is checked all automatic field combinations are “unrolled”, so it is possible to create manual field combinations using field selections that are parts of automatic field combinations. In this case field selections used by manual field combinations will be removed from automatic field combinations. In alternative embodiments of the present invention, the user may be provided with the ability to unroll one or more field selections individually by selection of a proper indicator or the like.


In order to create a new field selection that may be added to one of the manually created combination, the process may comprise the following steps, referring to FIG. 11.

    • 1. Create a new field selection preferably by the manual method described above, as a single entity field selection, or through any other appropriately indicated method.
    • 2. Select both the manually created combined field and the field added in item 1 from panel 130, in the manner as shown in FIG. 11.
    • 3. Right click or otherwise select one of the previously selected fields in pane 130. This selection will once again bring up a modify combined field dialog box 1200. Dialog box 1200 will list all of the previous field selections that were manually combined 1210, along with the new field entry, as is shown in FIG. 12.
    • 4. The user is then asked to enter a name in dialog box 1220 and to select okay button 1230 to create a new combination that will include all of the listed field selections. The result is shown in FIG. 13, in which the field selection has been added to the manually created combination in panel 130.


Once a manually created field combination is generated, it may be desirable for the user, at some point, to remove one or more of the field selections from the manually created field selection. The GUI in accordance with an embodiment of the invention provides a convenient manner for the user to perform this operation. This operation preferably comprises the following steps.

    • 1. Select a manually created combination from panel 130, as shown in FIG. 14.
    • 2. Right click or otherwise appropriately select the previously selected manually created combination to bring up the modify combined field dialog box 1200 as shown in FIG. 14.
    • 3. As is further shown in FIG. 15, one or more field selection that are to be removed from the manually created combined field are preferably selected, and a remove selection button 1540 is selected to remove the selected field selections. FIG. 16 depicts the resulting state of modify combined field dialog box 1200, showing that the previously selected field selection is no longer present. FIG. 17 further presents dialog box 100 depicting the changes in panel 130.
    • 4. If it is determined by the user that they wish to uncombined the entire manually created combined field, then an uncombined all button 1650 in FIG. 16 may be selected. As a result, the entire manually created combined field will be uncombined.


Referring once again to FIG. 1, if they don't combine radio button 140 is selected, no automatic combinations will be performed or generated. This option preferably turns off automatic field combining and may instruct the GUI to create a Wave Form View line for each field selection, regardless of whether the field selections logically belong to the same field or not. This option may also preferably affect only automatic field combinations, and may not affect manually combined fields. So it is possible, in accordance with one or more embodiments of the present invention, to manually create field combinations when this combination option is selected.


In accordance with one or more embodiments of the present invention, it may be desirable to select one or more subfields from a whole field, and to display these subfields in a wave form view display. Subfields may be combined with a whole field and then they establish a “field group” in the Wave Form View—where a whole field is represented by a Wave Form View line and subfields are represented by a Wave Form View subline. Subfields may also be used to build separate Wave Form View lines in case when their parent field is not selected.


In a particular exemplary embodiment of the invention, in order to combine a field and its subfields into a field group, all of the fields and subfields preferably have the same preconditions. The case when field and some subfield have different preconditions may be classified as not valid and not accepted by the Field Selection GUI of this embodiment of the invention. Of course, in one or more alternative embodiments of the invention, this combination may be allowed and declared valid.


In order to select a subfield, the process may preferably comprise the following steps, as first shown in FIG. 18.

    • 1. Select a parent field as noted above from panel 120, and then select subfield button 1750.
    • 2. Once the add subfield or replace existing field dialog box 1900 appears, as shown in FIG. 19, starting and ending bit fields 1910, 1920 may be provided to designate the starting and ending locations of the subfield. The subfield name may also be changed in field 1905 if the auto generated name is not preferred.
    • 3. By selecting the add subfield button 1930 the subfield is added to the field group, as is shown panel 130 in FIG. 20.
    • 4. Alternatively, replace field button 1940 allows for the replacement of the field with the defined subfield.


As noted above, in accordance with this embodiment of the invention, a parent field and any such subfields are preferably defined as a single field group having the same preconditions. As such, and change in a precondition for either the parent field, or any of the subfields results in a change in preconditions for the entire field group, including the parent and all associated subfields. This allows for valid field groups to be maintained, as such field groups preferably al have the same preconditions in order to remain valid, and to thus be accepted by the field selection GUI of one or more embodiments of the present invention.


If, on the other hand, it is desirable to provide a field group where a field and subfields may have different preconditions, such a situation is preferably handled by creating two different field groups having different preconditions, by based upon the same field. In this manner, the steps of FIGS. 18-20 are preferably performed, first for a selected field with a set of relates subfields and preconditions, and next for the selected field again (perhaps with the same or different subfields) and on or more different preconditions. The result will be as shown in FIG. 21 in which a same parent field is listed twice in pane 130. If it is desirable to have the field represented by one set of a wave form line and sub lines, even with multiple field groups describing the same field with different preconditions, the combine from the same source radio button from radio buttons 140 may be selected. Alternatively, selecting the don't combine radio button from radio buttons 140 may be selected, thus resulting in each field group being represented by different sets of waveform and sub lines.


Therefore, in accordance with the invention, a user is able to easily set one or more preconditions for a field group, and to easily display results. The various embodiments of the invention allow for a user to present complex field combination and definition logic in accordance with the processing of a protocol analyzer. Complex virtual fields may be built from other complex, or aggregate, fields and/or simple fields, thus allowing the user to build very complex virtual fields with complex aggregate preconditions, thus resulting in a final combined field, perhaps having multiple preconditions from any number of selected fields and sub fields, and thus presenting a very complex condition.


While the application is described as a GUI for use with a protocol analyzer, such GUI may be employed with any computer, general or special purpose, with sufficient processors, memory, storage, and programming to perform the job of such a protocol analyzer. The protocol analyzer or other general purpose computer preferably has an input for receiving one or more data streams, a processor for processing the one or more received data streams, and a display for displaying the output from the processor, as well as a graphical user interface as defined in accordance with the various embodiments of the invention. Of course, other well known components of a protocol analyzer or other general purpose computer may also be provided. This application further may be directed to a software package or instruction stored in a non-transitory, computer readable storage medium, that when employed by a general or special purpose computer, cause the computer to perform the functions described herein.


It will thus be seen that the objects set forth above, among those made apparent from the preceding description, are efficiently attained and, because certain changes may be made in carrying out the above method and in the construction(s) set forth without departing from the spirit and scope of the invention, it is intended that all matter contained in the above description and shown in the accompanying drawings shall be interpreted as illustrative and not in a limiting sense.


It is also to be understood that the following claims are intended to cover all of the generic and specific features of the invention herein described and all statements of the scope of the invention which, as a matter of language, might be said to fall therebetween.

Claims
  • 1. A field selection graphical user interface (GUI) for use with a protocol analyzer, the GUI allowing a user to perform the steps of: selecting a field from a plurality of fields presented by the GUI;defining one or more preconditions associated with the selected field from a plurality of preconditions presented by the GUI relevant to the selected field; andcalculating a field layout in accordance with the selected field and defined one or more preconditions.
  • 2. The field selection GUI of claim 1, further comprising the step of first selecting a source presented by the GUI with which the selected field is to be associated.
  • 3. The field selection GUI of claim 1, further comprising the steps of: selecting a second field from the plurality of fields presented by the GUI;defining one or more preconditions associated with the selected second field from a plurality of preconditions presented by the GUI relevant to the selected second field; andcalculating a field layout in accordance with the selected field and the defined one or more preconditions associated therewith, and the selected second field and the defined one or more preconditions associated therewith.
  • 4. The field selection GUI of claim 3, wherein the second selected field is conditional on the first selected field.
  • 5. The field selection GUI of claim 3, wherein the selected field and the second selected field are dependent on the same source.
  • 6. The field selection GUI of claim 3, where the selected field and the second selected field are dependent on different sources.
  • 7. The field selection GUI of claim 3, wherein the selected field and the second selected field are automatically combined into a field combination.
  • 8. The field selection GUI of claim 3, wherein the selected field and the second selected field are manually combined into a manually combined field combination.
  • 9. The field selection GUI of claim 8, further comprising the steps of: selecting a third field from a plurality of fields presented by the GUI;defining one or more preconditions associated with the selected third field from a plurality of preconditions presented by the GUI relevant to the selected third field; andmanually adding the selected third field and associated preconditions to the manually combined field combination.
  • 10. The field selection GUI of claim 9, further comprising the steps of: selecting one of the field, second field and third field from the field combination; andremoving the selected field from the manually combined field combination.
  • 11. The field selection GUI of claim 3, wherein the selected field and the second selected field are the same field, the selected field and the second selected field having different preconditions associated therewith.
  • 12. The field selection GUI of claim 1, further comprising the steps of: defining a subfield associated with the selected field; andcalculating a field layout in accordance with the selected field, the defined subfield, and one or more preconditions associated therewith.
  • 13. The field selection GUI of claim 12, wherein the one or more preconditions are the same for the selected field and the defined subfield.
  • 14. The field selection GUI of claim 1, further comprising the step of displaying a wave form view of one or more data sources in accordance with the calculated field layout.
  • 15. A protocol analyzer, comprising: an input for receiving one or more data streams;a processor for processing the one or more input data streams; anda display for displaying the results of the processing of the one or more input data streams, and for displaying a field selection graphical user interface (GUI) for defining one or more wave form view lines as calculated by the processor, the GUI prompting a user to perform the steps of: selecting a source presented by the GUIselecting a field from a plurality of fields presented by the GUI associated with the selected source;defining one or more preconditions associated with the selected field from a plurality of preconditions presented by the GUI relevant to the selected field; andcalculating a field layout in accordance with the selected field and defined one or more preconditions.
  • 16. The protocol analyzer of claim 15, wherein the GUI further prompts the user to perform the steps of: selecting a second field from the plurality of fields presented by the GUI associated with the selected source;defining one or more preconditions associated with the selected second field from a plurality of preconditions presented by the GUI relevant to the selected second field; andcalculating a field layout in accordance with the selected field and the defined one or more preconditions associated therewith, and the selected second field and the defined one or more preconditions associated therewith.
  • 17. The protocol analyzer of claim 16, wherein the selected field and the second selected field are manually combined into a manually combined field combination.
  • 18. The field selection GUI of claim 17, wherein the GUI further prompts the user to perform the steps of: selecting a third field from a plurality of fields presented by the GUI;defining one or more preconditions associated with the selected third field from a plurality of preconditions presented by the GUI relevant to the selected third field; andmanually adding the selected third field and associated preconditions to the manually combined field combination.
  • 19. The field selection GUI of claim 18, wherein the GUI further prompts the user to perform the steps of: defining a subfield associated with one or more of the selected fields; andcalculating a field layout in accordance with the one or more of the selected fields, the defined subfield, and one or more preconditions associated therewith.
  • 20. A computer program stored on a non-transitory storage medium, the computer program, when implemented on a protocol analyzer, causing the protocol analyzer to display a field selection graphical user interface (GUI) for prompting a user to perform the steps of: selecting a source presented by the GUIselecting a field from a plurality of fields presented by the GUI associated with the selected source;defining one or more preconditions associated with the selected field from a plurality of preconditions presented by the GUI relevant to the selected field; andselecting a second field from the plurality of fields presented by the GUI associated with the selected source;defining one or more preconditions associated with the selected second field from a plurality of preconditions presented by the GUI relevant to the selected second field; andcalculating a field layout in accordance with the selected field and the defined one or more preconditions associated therewith, and the selected second field and the defined one or more preconditions associated therewith.