The present invention relates to information technology (“IT”), and deals more particularly with assessing IT components (including components still under development) in view of a set of attributes.
As information technology products become more complex, developers thereof are increasingly interested in use of software component engineering (also referred to as “IT component engineering”). Software component engineering focuses, generally, on building software parts as modular units, referred to hereinafter as “components”, that can be readily consumed and exploited by a higher-level software packaging or offering (such as a software product), where each of the components is typically designed to provide a specific functional capability or service.
Software components (referred to equivalently herein as “IT components” or simply “components”) are preferably reusable among multiple software products. For example, a component might be developed to provide message logging, and products that wish to include message logging capability may then “consume”, or incorporate, the message logging component. This type of component reuse has a number of advantages. As one example, development costs are typically reduced when components can be reused. As another example, end user satisfaction may be increased when the user experiences a common “look and feel” for a particular functional capability, such as the message logging function, among multiple products that reuse the same component.
When a sufficient number of product functions can be provided by component reuse, a development team can quickly assemble products and solutions that produce a specific technical or business capability or result.
One approach to component reuse is to evaluate an existing software product to determine what functionality, or categories thereof, the existing product provides. This approach, which is commonly referred to as “functional decomposition”, seeks to identify functional capabilities that can be “harvested” as one or more components that can then be made available for incorporating into other products.
However, functional decomposition has drawbacks, and mere existence of functional capability in an existing product is not an indicator that the capability will adapt well in other products or solutions.
The present invention provides techniques for assessing IT components. In one preferred embodiment, this comprises: determining a plurality of criteria that are important to a target market, and at least one attribute to be used for measuring each of the criteria; specifying objective measurements for each of the attributes; and conducting an evaluation of an IT component. Conducting the evaluation preferably further comprises: inspecting a representation of the IT component, with reference to selected ones of the attributes; assigning attribute values to the selected attributes, according to how the IT component compares to the specified objective measurements; generating an assessment score, for the IT component, from the assigned attribute values; and generating a list of recommended actions, the list having an entry for each of the selected attributes for which the assigned attribute value falls below a threshold, each of the entries providing at least one suggestion for improving the assigned attribute value.
The foregoing is a summary and thus contains, by necessity, simplifications, generalizations, and omissions of detail; consequently, those skilled in the art will appreciate that the summary is illustrative only and is not intended to be in any way limiting. Other aspects, inventive features, and advantages of the present invention, as defined by the appended claims, will become apparent in the non-limiting detailed description set forth below.
The present invention will now be described with reference to the following drawings, in which like reference numbers denote the same element throughout.
The present invention provides techniques for assessing IT components. Code harvested from existing products as a reusable component can be assessed to ensure that the component is suited for reusability. By assessing a harvested component in view of its intended use, components can be provided that improve market acceptance for a particular consuming application and/or target market. Furthermore, newly-developed components—or plans or designs therefor—can be assessed using techniques disclosed herein. Reusability and consistency of the components may thereby be improved. Additionally, it is more likely that components assessed as described herein will have a positive impact on market acceptance of a consuming product or solution.
As discussed earlier, the functional decomposition approach has drawbacks when creating software components by harvesting functionality from existing products. As one example, a drawback of the functional decomposition approach is that no consideration is generally given during the decomposition process as to how the harvested component(s) will ultimately be used, or to the results achieved from such use. This may result in the creation of components that do not achieve their potential for reuse and/or that fail to satisfy requirements of their target market or target audience of users. Suppose a message logging capability is identified as a reusable component during functional decomposition, for example. If the code providing that message logging capability performs inefficiently or has poor usability, then these disadvantages will be propagated to other products that reuse the message logging component. As another example, a functional capability for providing an administrative interface within a product might be identified as a potential component for harvesting. However, an assessment of this functional capability, conducted using techniques disclosed herein, might indicate that the code providing this administrative interface capability has a number of other inhibitors that would be detrimental when the code is consumed by other products.
In addition, because it seeks to break down already-existing code into components, the functional decomposition approach does not seek to provide components that are designed specifically to satisfy particular market requirements or market requirements which may be of most importance in the target market.
The related application entitled “Assessing Information Technology Products” (Ser. No. 10/612,540) defines techniques for assessing a product as a whole. Components included in the product are assessed only insofar as functionality of the component may be incidentally exposed by the product. If a product includes one or more components that have undesirable characteristics, for example, these characteristics may be attributed to the product as a whole, but it is not evident that the source of the undesirable characteristics is one or more particular components. Accordingly, remedial steps (such as replacing a component or altering a component's functionality to improve it characteristics) are not easily identifiable.
In preferred embodiments, the present invention provides techniques for assessing IT components by comparing a component (including a component still under development) to a set of criteria that are designed to measure the component's success at addressing requirements of a target market, and each of these criteria has one or more attributes. The measurement criteria may be different in priority from one another, and may therefore be weighted such that varying importance of particular requirements to the target market can be reflected. In preferred embodiments, a component assessment score is created as a result of the comparison. When necessary, a set of recommendations for changing a component may also be created.
Referring now to
Requirements of the identified target market are also identified (Block 105). As discussed in the related applications, a number of factors may influence whether an IT product is successful with its target market, and these factors may vary among different segments of the market. Accordingly, the requirements that are important to the target market are used in assessing components to be provided in products and solutions (referred to herein more generally as “products”) to be marketed therein.
Criteria of importance to the target market, and attributes for measurement thereof, are identified (Block 110) for use in the assessment process. Multiple attributes may be defined for any particular requirement, as deemed appropriate. High-potential attributes may also be identified. Objective means for measuring each criterion are preferably determined as well. Optionally, weights to be used with each criterion may also be determined.
As one example, if an identified requirement is “reasonable footprint”, then a measurement attribute may be defined such as “requires less than . . . [some amount of storage]”; or, if an identified requirement is “easy to learn and use”, then a measurement attribute may be defined such as “novice user can use functionality without reference to documentation”. Degrees of support for particular attributes may also be measured. For example, a measurement attribute of the “easy to learn and use” requirement might be specified as “novice user can successfully use X of 12 key functions on first attempt”, where the value of “X” may be expressed as “1-3”, “4-6”, “7-9”, and so forth.
Market segments may be structured in a number of ways. For example, a target market for an IT product may be segmented according to industry. As another example, a market may be segmented based upon company size, which may be measured in terms of the number of employees of the company. The manner in which a market is segmented does not form part of the present invention, and techniques disclosed herein are not limited to a particular type of market segmentation. Furthermore, the attributes of importance to a particular market segment may vary widely, and embodiments of the present invention are not limited to use with a particular set of attributes. Attributes discussed herein should therefore be construed as illustrating, but not limiting, use of techniques of the present invention.
Block 115 asks whether the component assessment is to be conducted with regard to functionality to be harvested from an existing product. If so, then at Block 120, functionality from the existing product is identified as a potential component (or multiple potential components), and the assessment is then carried out (Block 125) with regard to the identified potential component(s).
If the test at Block 115 has a negative result, then at Block 130, a test is made to determine whether the component assessment is to be conducted with regard to functionality of an existing component. If so, then the assessment is carried out (Block 145) with regard to the existing component.
If the test at Block 130 has a negative result, then the assessment is carried out (Block 135) with regard to plans and/or design specifications for a component that does not yet exist.
Following the assessment at any of Blocks 125, 135, and 145, a test is made at Block 140 as to whether the assessment results indicate that this is a suitable component. This test preferably comprises comparing a numeric component assessment score to a predetermined threshold. Assessment results, and how those results can be used to determine whether a component is suitable, will be discussed in more detail below. If the test at Block 140 is negative, then deficiencies identified during the assessment process are addressed (Block 150). For example, it might be determined that harvested functionality needs to be modified before becoming a reusable component. Or, it might be determined that a component yet to be developed needs redesign in selected areas.
Following Block 150, a reassessment is preferably conducted (Block 155). The operations depicted in
As will be obvious, assessment of more than one existing/planned component can be performed at Blocks 125, 135, and 145, and the subsequent processing depicted in
Assessing components to be consumed by a product or solution, using the approach shown in
Techniques of the present invention are described herein with reference to particular criteria and attributes developed to assess software with reference to requirements that have been identified for a hypothetical target market, as well as with reference to a component assessment score that is expressed as a numeric value. However, it should be noted that these descriptions are by way of illustrating use of the novel techniques of the present invention, and should not be construed as limiting the present invention to these examples. In particular, alternative target markets, alternative criteria and attributes, and alternative techniques for computing and expressing a result of the assessment process may be used without deviating from the scope of the present invention.
Easy to Install. This criterion measures how easily the consuming product of the assessed component is installed in its intended market. Attributes used for this measurement may include: (i) whether the installation can be performed using only a single server; (ii) whether installation is quick (e.g., measurable in minutes, not hours); (iii) whether installation is non-disruptive to the system and personnel; and (iv) whether the package is OEM-ready with a “silent” install/uninstall (that is, whether the package includes functionality for installing and uninstalling itself without manual intervention).
Complete Software Solution. This criterion judges whether the consuming product of the assessed component provides a complete software solution for its users. Attributes may include: (i) whether all components, tools, and information needed for successfully implementing the consuming product are provided as a single package; (ii) whether the packaged solution is condensed—that is, providing only the required function; and (iii) whether all components of the packaged solution have consistent terms and conditions (sometimes referred to as “T's and C's”).
Easy to Integrate. This criterion is used to measure how easy it is to integrate the assessed component with other components. Attributes used in this comparison may include: (i) whether the component coexists with, and works well with, other components of the consuming product; (ii) whether the assessed component interoperates well with existing components in its target environment; and (iii) whether the component exploits services of its target platform that have been proven to reduce total cost of ownership.
Easy to Manage. This criterion measures how easy the assessed component is to manage or administer, if applicable. Attributes defined for this criterion may include: (i) whether the component is operational “out of the box” (e.g., as delivered to the developer, when provided as a reusable component of a development toolkit); (ii) whether the component, as delivered, provides a default configuration that is appropriate for most installations; (iii) whether the set-up and configuration of the component can be performed with minimal administrative skill and interaction; (iv) whether application templates and/or wizards are provided to simplify use of the component and its more complex tasks; (v) whether the component is easy to fix if defects are found; and (vi) whether the component is easy to upgrade.
Easy to Learn and Use. Another criterion to be measured is how easy it is to learn and use the assessed component. Attributes for this measurement may include: (i) whether the component's user interface is simple and intuitive; (ii) whether samples and tools are provided, in order to facilitate a quick and successful first-use experience; and (iii) whether quality documentation, that is readily available, is provided.
Extensible and Flexible. Another criterion used in the assessment is the component's extensibility and flexibility. Attributes used for this measurement may include: (i) whether a clear upgrade path exists to more advanced features and functions; and (ii) whether the customer's investment is protected when upgrading to advanced components or versions thereof.
Reasonable Footprint. For many IT markets, the availability of computing resources such as storage space and memory usage is considered to be important, and thus a criterion that may be used in assessing components is whether the component has a reasonable footprint. Attributes may include: (i) whether the component's usage of resources such as random-access memory (“RAM”), central processing unit (“CPU”) capacity, and persistent storage (such as disk space) fits well on a computing platform used in the target environment; and (ii) whether the component's dependency chain is streamlined and does not impose a significant burden.
Target Market Platform Support. Finally, another criterion used when assessing components for the target market may be platform support. An attribute used for this purpose may be whether the component is available on all “key” platforms of the target market. Priority may be given to selected platforms.
The particular criteria to be used for a component assessment, and attributes used for those criteria, are preferably determined by market research that analyzes what factors are significant to people making IT purchasing decisions. Preferred embodiments of the assessment process disclosed herein use these criteria and attributes as a framework for evaluating components. The market research preferably also includes an analysis of how important the various factors are in the purchasing decision. Therefore, preferred embodiments of the present invention allow weights to be assigned to attributes and/or criteria, enabling them to have a variable influence on a component's assessment score. These weights preferably reflect the importance of the corresponding attribute/criteria to the target market Accordingly,
It should be noted that the attributes and criteria that are important to IT purchasing decisions may change over time. In addition, the relative importance thereof may change. Therefore, embodiments of the present invention preferably provide flexibility in the assessment process and, in particular, in the attributes and criteria that are measured, in how the measurements are weighted, and/or in how a component's assessment score is calculated using this information.
By using the framework of the present invention with its well-defined and objective measurement criteria and attributes, and its objective checkpoints, the assessment process can be used advantageously to guide and focus component harvesting/development efforts, as well as to gauge impacts of adding an already-developed component to a consuming product intended for a target market (This will be described in more detail below. See, for example, the discussion of
Preferably, numeric values such as a scale of 1 to 5 are used when measuring each of the attributes during the assessment process. In this manner, relative degrees of support (or non-support) can be indicated. (Alternatively, another scale, such as 0 to 5, might be used.) In the examples used herein, a value of 5 indicates the best case, and 1 represents the worst case. In preferred embodiments, textual descriptions are provided for each numeric value of each attribute. These textual descriptions are designed to assist component assessors in performing an objective, rather than subjective, assessment Preferably, the textual descriptions are defined so that a component being assessed will receive a score of 3 on an attribute if the component meets the market's expectation for that attribute, a score of 4 if the component exceeds expectations, and a score of 5 if the component greatly exceeds expectations or sets new precedent for how the attribute is reflected in the component. On the other hand, the descriptions are preferably defined so that a component that meets some expectations for an attribute (but fails to completely meet expectations) will receive a score of 2 for that attribute, and a component that obviously fails to meet expectations for the attribute (or is considered obsolete with reference to the attribute) will receive a score of 1.
A component name and vendor (see elements 420, 430) may be specified, along with version and release information (see element 440) or other information that identifies the particular component under assessment.
A set of measurement guidelines (see element 470) is preferably provided as textual descriptions for use by the component assessors. In the example, a value of 3 is assigned to this attribute if the component fully supports a set of “expected” services, but fails to support all “suggested” services. A value of 5 is assigned if the assessed component fully leverages all of the provided (i.e., expected as well as suggested) services, whereas a value of 1 is assigned if the component fails to support the expected services and the suggested services. If the assessed component supports (but does not fully leverage) expected and suggested services, then a value of 4 is assigned. And, if the assessed component supports some of the expected services, then a value of 2 is assigned. (What constitutes an “expected service” and a “suggested service” may vary widely from one component to another and/or from one target market to another.)
Element 480 indicates that an optional feature of preferred embodiments allows per-attribute deviations when assigning values to attributes for the assessed component. In this example, the deviation information explains that the provided services may be dependent on the platform(s) on which this component will be used.
One or more checkpoints and corresponding recommended actions may also be provided. See elements 490 and 499, respectively, where sample checkpoints and actions have been provided for this attribute. In addition, a set of values may be specified to indicate how providing each of these will impact or improve the component's assessment score. See element 495, where sample values have been provided. (The information shown at 490-499 may be used, for example, when developing prescriptive statements of the type discussed with reference to Block 115 of
Information similar to that depicted in
Referring now to
An algorithm or computational steps are preferably developed (Block 510) to use the measurement data for computing a component assessment score. This algorithm may be embodied in a spread sheet or other automated technique.
One or more trial assessments may then be conducted (Block 515) for validation. For example, one or more existing components may be assessed, and the results thereof may be analyzed to determine whether an appropriate set of criteria, attributes, priorities, and deviations has been put in place. If necessary, adjustments may be made, and the process of
A component assessment as disclosed herein may be performed in an iterative manner. This is illustrated in
When the component reaches the planning checkpoint, plan information is preferably used to conduct an initial assessment. This initial assessment is preferably conducted by the component development team, as a self-assessment, using the same criteria and attributes (and the same textual descriptions of how values will be assigned) as will be used by the component assessment team later on. See element 610. The component development team preferably uses its component development plans (e.g., the planned component features) as a basis for this self-assessment Performing an assessment while an IT component is still in the planning phase may prove valuable for guiding a component development plan. Component features can be selected from among a set of candidates, and the subsequent development effort can then focus its efforts, in view of how this component (plan) assessment indicates that the wants and needs of the target market will be met.
As stated earlier, a component assessment score is preferably expressed as a numeric value. A minimum value for an acceptable score is preferably defined, and if the self-assessment at the planning checkpoint is lower than this minimum value, then in preferred embodiments, the component development team is required to revise its component development plan to raise the component's score and/or to request a deviation for one or more low-scoring attributes. Optionally, approval of the revised plan or a deviation request may be required.
Another assessment is then preferably performed during the development phase, as the component nears the end of the development phase (e.g., prior to releasing the component for consumption by products). This is illustrated in
The evaluators may optionally perform a review of basic component information (Block 720) to determine whether this component is a candidate for undergoing the assessment process. Depending on the outcome (Block 725), then the flow shown in
When Block 730 is reached, then this component is a candidate, and the evaluators preferably generate what is referred to herein as an “assessment workbook” for the component. The assessment workbook provides a centralized place for recording information about the component, and when assessments are performed during multiple phases (as discussed above), preferably includes the assessment information from each of the multiple assessments for the component. Items that may be recorded in the assessment workbook include planning information, competitive positioning of consuming products, comparative data for predecessor versions of a component, inspection findings, and/or assessment calculations.
At Block 730, the assessment workbook is preferably populated (i.e., updated) with initial information taken from the questionnaire that was submitted by the component team at Block 700. Note that some of the information on the questionnaire may directly generate measurement data, while for other information, further details are required from the actual component assessment. For example, the target platform service exploitation information discussed above with reference to
A component assessment is preferably scheduled (Block 735), and is subsequently carried out (Block 740). Performing the assessment preferably comprises conducting an inspection of the component, when carried out during the development phase, or of the component development plan, when carried out in the planning phase. When the operational component (or an interim version thereof) is available, this inspection preferably includes simulating a “first-use” experience, whereby an independent team or party (i.e., someone other than a development team member) receives the component in a manner similar to its intended delivery (for example, when a component is proposed for inclusion in a developer's toolkit, as some number of CD-ROMs, other storage media, or download instructions, and so forth) and then begins to use the functions of the component. (Note that when an assessment is performed using an interim version of a component, the scores that are assigned for the various attributes preferably consider any differences that will exist between the interim version and the final version, to the extent that such differences are known. Preferably, the component planning/development team provides detailed information on such differences to the component assessment team. If no operational code is available, then the inspection may be performed by review of code or similar documentation.)
Results of the inspection are captured (Block 745) in the assessment workbook. Values are assigned for each of the measurement attributes (Block 750), and these values are recorded in the assessment workbook. As discussed earlier, these values are preferably selected from a numeric range, such as 1 to 5, and textual descriptions are preferably defined in advance to assist the assessors in consistently applying the measurements to achieve an objective component assessment score.
Once the inspection has been completed and values are assigned and recorded for all of the measurement attributes, a component assessment score is generated (Block 755). The manner in which the score is computed, given the gathered information, may vary widely. One or more recommendations may also be generated, depending on how the component scores on particular attributes, to inform the component team where changes should be made to improve the component's score (and therefore, to improve the component's reusability and/or other factors such as what impact the component will have on acceptance of consuming products by their target market).
According to preferred embodiments, any measurement attribute for which the assigned value is 1 or 2 requires follow-up action by the component team, as these are not considered acceptable values. Thus, attributes receiving these values are preferably flagged or otherwise indicated in the assessment workbook. Preferred embodiments also require an overall score of at least 7 on a scale of 0 to 10, and any component scoring lower than 7 requires review of its assessment attributes and improvement before being approved for release and/or inclusion in a component library. (Overall scores and minimum required scores may be expressed in other ways, such as by using percentages values, without deviating from the scope of the present invention.) Optionally, selected attributes may be designated as critical or imperative for acceptance of this component's functionality in the target marketplace. In this case, even though a component's overall assessment score exceeds the minimum acceptable value, if it scores a 1 or 2 on a critical attribute, then review and improvement is required on these scores before the component can be approved.
When weights have been assigned to the various measurement attributes, then these weights may be used to prioritize the recommendations that result from the assessment. In this manner, actions that will result in the biggest improvement in the component assessment score can be addressed first.
The assessment workbook and analysis is then sent to the component team (Block 760) for their review. The component team then prepares an action plan (Block 765), as necessary, to address each of the recommendations. A meeting between the component assessors and representatives of the component team may be held to discuss the findings in the assessment workbook and/or the recommendations. The action plan may be prepared thereafter. Preferably, the actions from this action plan are recorded in the assessment workbook.
At Block 770, a test is made as to whether this component (or component plan) should proceed. If not (for example, if the component assessment score is too low, and sufficient improvements do not appear likely or cost-effective), then the process of
Block 780 indicates that, when the component's action plan has been carried out, an application for component approval may be submitted. This application is then reviewed (Block 785) by the appropriate person(s), who is/are preferably distinct from the assessment team, and if approved (i.e., the test at Block 790 has a positive result), then the process of
Optionally, a special designation may be granted to the component when the test in Block 790 has a positive result. This designation may be used, for example, to indicate that this component has achieved at least some predetermined assessment score with regard to the assessment criteria, thereby enabling developers to consider this designation when selecting from among a set of candidate components provided in a component library or toolkit. A component that fails to meet this predetermined assessment score may still be released for reuse, but without the special designation. Furthermore, the test performed at Block 725 of
As stated earlier, a minimum acceptable assessment score is preferably specified for components to be assessed using the component assessment process. In addition to using this minimum score for determining when an assessed component is required either (i) to make changes and undergo a subsequent assessment and/or (ii) to justify its deviations, the minimum score may be used as a gating factor for receiving the special designation discussed above. Referring now to
Element 920 provides a sample list of criteria and attributes that have been identified as critical. In this example, 7 of the 8 measurement criteria from
For each assessed aspect, the assessment report indicates how that component scored for each of the criteria (see the “Score” columns), the weight assigned to prioritize that criterion (see the “Wt.” columns), and the contribution that this weighted criterion assessment makes to the overall assessment score for this aspect (see the “Contr.” columns). In preferred embodiments, an algorithm is then used to produce the overall aspect assessment score from the weighted criteria contributions. In this example, the “Widget Runtime” aspect 1020 has an assessment score of 3.50 (see 1040) and the “Widget Development Tools” aspect 1030 has an assessment score of 4.25 (see 1050).
A summary 1120 is also provided, listing each of the attributes that did not achieve the minimum acceptable score (which, in preferred embodiments, is a 3 on the 5-point scale, as stated above). In this example, one attribute of the “Easy to Learn and Use” criterion (see 1121) failed to meet this minimum score. In the example report, the actual score assigned to the failing attribute is presented, along with an impact value and comments. The impact value indicates, for each failing attribute, how much of an improvement to the overall assessment score would be realized if this attribute's score was raised to the minimum score of 3. For each attribute in this summary 1120, the assessment team preferably provides comments that explain why the particular attribute value was assigned. Thus, as shown in this example (see 1122), an improvement of 0.034 could be realized in the component's assessment score (from a score of “2”) if samples were provided for some function “PQR”.
A recommended actions summary 1130 is also provided, according to preferred embodiments, notifying the component team as to the assessment team's recommendations for improving the component's score. In this example, a recommended action has been provided for the attribute 1121 that did not meet requirements.
Preferably, the attributes in summary 1120 and the corresponding actions in summary 1130 are listed in decreasing order of potential improvement in the assessment score. This prioritized ranking is beneficial to the component development team, as it allows them to prioritize their efforts for revising the component in view of where the most significant gains can be made in the component's assessment score. (Preferably, attribute weights are used in determining the impact values shown for each attribute in summary 1120, and these impact values are then used for the prioritization.)
Additionally, more-detailed information may also be included in assessment reports, although this detail has not been shown in the sample report 1100. Preferably, the summary information shown in
As has been demonstrated, the present invention defines advantageous techniques for assessing IT components. Importance of various attributes to the target market are reflected in the assessments, and assessment results may then be provided to component teams to influence component harvesting, planning, and/or development efforts.
As will be appreciated by one of skill in the art, embodiments of the present invention may be provided as methods, systems, or computer program products comprising computer-readable program code. Accordingly, the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment, or an embodiment combining software and hardware aspects. The computer program products maybe embodied on one or more computer-usable storage media (including, but not limited to, disk storage, CD-ROM, optical storage, and so forth) having computer-readable program code embodied therein.
When implemented by computer-readable program code, the instructions contained therein may be provided to a processor of a general purpose computer, special purpose computer, embedded processor, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing embodiments of the present invention.
These computer-readable program code instructions may also be stored in a computer-readable memory that can direct a computer or other programmable data processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable memory produce an article of manufacture including instruction means which implement embodiments of the present invention.
The computer-readable program code instructions may also be loaded onto a computer or other programmable data processing apparatus to cause a series of operational steps to be performed on the computer or other programmable apparatus to produce a computer-implemented method such that the instructions which execute on the computer or other programmable apparatus provide steps for implementing embodiments of the present invention.
While preferred embodiments of the present invention have been described, additional variations and modifications in those embodiments may occur to those skilled in the art once they learn of the basic inventive concepts. Therefore, it is intended that the appended claims shall be construed to include preferred embodiments and all such variations and modifications as fall within the spirit and scope of the invention.
The present application is related to the following commonly-assigned and co-pending U.S. patent applications, which were filed concurrently herewith: Ser. No. 10/______, which is titled “Market-Driven Design of Information Technology Components”; Ser. No. 10/______ , which is titled “Role-Based Assessment of Information Technology Packages”; and Ser. No. 10/______, which is titled “Selecting Information Technology Components for Target Market Offerings”. The first of these related applications is referred to herein as “the component design application”. The present application is also related to the following commonly-assigned and co-pending U.S. patent applications, all of which were filed on May 16, 2003 and which are referred to herein as “the related applications”: Ser. No. 10/612,540, entitled “Assessing Information Technology Products”; Ser. No. 10/439,573, entitled “Designing Information Technology Products”; Ser. No. 10/439,570, entitled “Information Technology Portfolio Management”; and Ser. No. 10/439,569, entitled “Identifying Platform Enablement Issues for Information Technology Products”.