This description relates to specifying and applying rules to data.
Many modern applications, including business applications, process large sets of data (i.e., “datasets”) which can be compiled from various sources. The various sources that provide data to the dataset can have different levels of data quality. To ensure that the applications function properly, an adequate level of data quality in the dataset should be maintained. To maintain an adequate level of data quality, the dataset can be processed by a data validation system. Such a system applies validation rules to the dataset before it is provided to the application. In some examples, the data validation system uses the results of validation rules to calculate a measure of data quality and alert an administrator of the application if the measure of data quality falls below a predetermined threshold. In other examples, the data validation system includes modules for handling data that fails one or more of the validation rules. For example, the data validation system can discard or repair data that fails one or more of the validation rules.
In general, the validation rules applied by the data validation system are defined by an administrator of the data validation system.
In general, one innovative aspect of the subject matter described in this specification can be embodied in an aspect 1 that include a system that includes processors and processing instructions, including a user interface module configured to render a plurality of cells arranged in a two-dimensional grid having a first axis and a second axis, the two-dimensional grid including one or more subsets of the cells extending in a direction along the first axis of the two-dimensional grid, each subset of the one or more subsets associated with a respective field of an element of the plurality of elements of the dataset, and multiple subsets of the cells extending in a direction along the second axis of the two-dimensional grid, one or more of the multiple subsets associated with a respective validation rule. The method includes rendering a subset of the cells extending in a direction along the second axis of the two-dimensional grids, each cell in the subset being associated with the respective field at the corresponding position in the grid identified by the second axis, and being capable of being used as a conditional cell. A condition cell associated with a field includes an input element, for receiving input in the form of a conditional expression. A processing module configured to evaluate a conditional expression from a condition cell and, based on that evaluation, apply one or more validation rules to at least one element of the dataset.
Other embodiments of this aspect include corresponding computer systems, apparatus, and computer programs recorded on one or more computer storage devices, each configured to perform the actions of the methods. A system of one or more computers can be configured to perform particular actions by virtue of having software, firmware, hardware, or a combination of them installed on the system that in operation causes or causes the system to perform the actions. One or more computer programs can be configured to perform particular actions by virtue of including instructions that, when executed by data processing apparatus, cause the apparatus to perform the actions.
The foregoing and other embodiments can each optionally include one or more of the following features, alone or in combination.
An aspect 2 according to aspect 1 includes that the input element may receive a condition such that at least one validation rule associated with the second axis is applied to the associated field when the condition is satisfied.
An aspect 3 according to aspects 1 or 2 include that the condition may be dependent on a value of a second field different from the associated field.
An aspect 4 according to aspects 1, 2, and 3 includes applying validation rules to data in a first field of a first element of the dataset including determining selected validation rules associated with cells from a subset of cells extending in the direction along the second axis associated with the first field of the first element, based on any input received in the input elements of the cells; determining a condition associated with the selected validation rules based on input received in an input element of a condition cell associated with the first field; determining that the condition is satisfied; and applying the selected validation rules to the first field.
An aspect 5 according to aspects 1, 2, 3, or 4 includes that the input element of the condition cell may be configured to receive an operator and a value associated with the operator.
An aspect 6 according to aspects 1, 2, 3, 4 or 5 includes that determining that the condition is satisfied may include applying the operator to the value associated with the operator and a value in a second field of the first element of the dataset, the second field being identified by the field identifier.
Aspects of the disclosed system can have one or more of the following advantages. A user interface can enable a business user to identify validation rules. The application of a validation rule can be conditional on the value of a field in a data element. Validating a dataset can increase the performance of application using that dataset. Conditional validation rules can improve system performance by bypassing the unnecessary application of validation rules. Conditional validation rules can reduce system complexity, but allowing specific validation rules to be easily applied for uncommon test cases.
Other features and advantages of the invention will become apparent from the following description and the claims.
Data processing systems accept data from different sources and produce outputs based on the data. The data processed by the system can include anomalies, errors, or issues. These data quality problems can be due to, for example, errors caused by inaccurate entry, such as typographical errors, machine failures, such as data corruption, and errors caused by translation errors, such as an incorrect identification of the encoding of the data. Errors can also be due to missing or unreported data, improperly formatted data, change in specification at data producer that results in misinterpreted data at data consumer, errors in reference code sets resulting in mismatches with data, synchronization problems (e.g. new reference data fails to appear on time and source data does not match older reference data), introduction of new code values, etc. In general, a goal of data quality system is to detect issues in the data that need to be measured, usually as part of a data improvement program (number of issues should go down over time).
Data validation is the process of measuring the quality of the data. In general, one or more data validation tests are executed against a data source. Quality of the data is quantified and, if necessary, action can be taken to improve the quality of the data.
A user interface can simplify the process of creating a validation rule. In general, a validation rule is a set of one or more validation tests that can be applied to data to determine the data quality. For example, a validation rule may include a validation test that determines whether a field of data is of a particular data type and a validation test that determines whether a field of data is of a particular size. The systems, methods, and mediums described herein have at least some of the following advantages over the prior art. A user interface can enable a business user to identify validation rules. Logical rules can be associated with business terms. Fields in a dataset can also be associated with business terms. Default validation rules can be determined based on the associations. Logical rules can decrease the time spent validating a data set. Another useful reference point is a system for specifying and applying rules to data is described in U.S. patent application Ser. No. 13/653,995, entitled “SPECIFYING AND APPLYING RULES TO DATA” and filed Oct. 17, 2012, the contents of which are incorporated by reference.
A business term represents a concept that is embodied in the data. For example, a relational database table named “cust_tbl” may include a field named “phone_no.” A row in the “cust_tbl” with a value in the “phone_no” field represents that a customer exists with that particular phone number. In this example, “customer” is a business term embodied in, at least, the “cust_tbl” and “phone number” is a business term embodied in the “phone_no” field.
The execution environment 104 can be hosted on one or more general-purpose computers under the control of a suitable operating system, such as UNIX. For example, the execution environment 104 can include a multiple-node parallel computing environment: this can include configuration of computer systems using multiple central processing units (CPUs); either local (e.g., multiprocessor systems such as SMP computers) or locally distributed processors (e.g., multiple processors coupled as clusters or MPPs); remote or remotely distributed processors (e.g., multiple processors coupled via a local area network (LAN) and/or wide-area network (WAN)); or any combination thereof.
The execution environment includes a user interface (UI) module 106 and a processing module 108. The UI module 106 manages input received from a user 110 over a user interface 112 (e.g., a graphical view on a display screen) which is utilized in specifying validation rules to be used by the processing module 108 for processing data from the data source 102.
The processing module 108 reads data from the data source 102 and performs validation procedures based on validation information obtained by the UI module 106. Storage devices providing the data source 102 can be local to the execution environment 104, for example, being stored on a storage medium connected to a computer running the execution environment 104 (e.g., hard drive 114). Alternatively or additionally, the storage devices can be remote to the execution environment 104, for example, being hosted on a remote system (e.g., mainframe 116) in communication with a computer running the execution environment 104, over a remote connection.
In general, a dataset accessed from the data source 102 includes a number of data elements, which can be records formatted according to a predetermined record structure, or rows in a database table. Each data element can include values for a number of fields, for example, attributes defined within a record structure or columns in a database table, possibly including null or empty values. Various characteristics of values in the fields or the presence or absence of values in certain fields can be considered valid or invalid. For example, a “last_name” field including the string “Smith” may be considered valid, while a “last_name” field that is blank may be considered invalid. The conditions that determine whether a field is valid or invalid can be different for different fields. For example, a “middle_name” field including the string “Randolf” may be considered valid and a “middle_name” field that is blank may also be considered valid.
In general, fields in a dataset can represent a physical representation of a business rule. For example, a “first_name” field (which may for example, be a variable-length character string stored in a relational database) in a “customer” data set may include data that is the first name of a customer and therefore is associated with a business term “first name”. That is, the character string “John” in the “first_name” field of a data element of the customer data set represents the existence of a business customer with the given name “John.” Other datasets may represent the same business concept in different ways. For example, a second dataset can include the field “fname” which may also correspond to the business term “first name.”
The UI module 106 renders the user interface 112. The user interface 112 may be rendered, for example, on a computer monitor. The user interface 112 includes a number of cells 224 arranged in a two-dimensional grid 225 with a first axis 226 and a second axis 228. One or more subsets 230 of the cells 224, (referred to as rows 230 in the remainder of the detailed description) extends in a direction along the first axis 226 of the two-dimensional grid 225. Each of the rows 230 is associated with a field 218. In some arrangements, the first (i.e., leftmost) cell of each of the rows 230 includes the name of the data element 218 associated with the row 230. In this example, the first cells of each row include the data element names “Field 1,” “Field 2,” . . . “Field M”.
Multiple subsets 232 of the cells 224 (referred to as columns 232 in the remainder of the detailed description) extend along the second axis 228. One or more of the columns 232 is associated with a validation test 234. The columns 232 can include a “conditions” column 250 that identifies circumstances under which the validations rules associated with the data element (identified by the row) are applied. In some examples, the first (i.e., the topmost) cell of each of the remaining columns 232 includes the name of the validation test 234 associated with the column, or a name such as “Conditional Test” or “Conditions” for the conditions column 250. In this example, the validation rule names are “Validation Test 1,” “Validation Test 2,” . . . “Validation Test N”. It is noted that in some examples, the directions of the first axis 226 and the second axis 228 can be swapped, causing the rows 230 associated with the fields 218 to become columns and the columns 232 associated with the validation test 234 to become rows.
After one or more validation test columns 232 are added to the two-dimensional grid 225, the user 110 can specify which validation test 234 should be applied to which data elements 218. An example, of different kinds of validation tests that can be specified is described in U.S. Pat. No. 8,069,129 entitled “EDITING AND COMPILING BUSINESS RULES”, incorporated herein by reference.
The user interface 112 includes a condition column 250 that allows the user to establish a pre-condition for testing the validation rules for a given row. The user may specify that “Condition 1” 252 should be met before applying “Validation Test 1” with Test Parameters1,1 236 to the data element “Field 1” 218.
The condition can refer to a data element that may or may not be the subject of the validation. For example, the condition may require that a field in the data element have a value that matches a predetermined value, is included in a range or set of possible values, or matches a provided regular expression. The field may or may not be the field that is the subject of the validation test. For example, condition 1 252 may test the value of Field 3 254 before applying Validation Test 1 234 to the value of Field 1 218. The condition can require that a data element have a value (for example, the data element does not include a null value indicator.) In some implementations, conditions can be data driven. For example, data driven conditions can include record of a certain type, accounts in a certain range, countries in a set of values. The conditions may involve lookup files or referencing data in another input file or database table.
In some implementations, establishing a condition can include identifying a field, an operation, and a value. The operation can be, for example, a Boolean function. The field identifies which data element is going to be evaluated by the condition, the operation identifies how the field is going to be evaluated, and a value is used to determine whether the condition is satisfied based on the evaluation. For example, for the condition:
Country=‘US’
the field is Country, the operator is ‘=’, and the value is ‘US’. The condition is satisfied is a value in a country field for the data element is equal to ‘US’, and the condition is not satisfied if the value is not ‘US’.
In some implementations, when a user adds a condition to a field the user interface automatically creates a new validation test row for that field. For example, in response to the addition of the condition 252 to Field 1 218 the user interface inserts a new row 256. Multiple rows in the user interface that each refer to the same Field may be evaluated sequentially, that is from top to bottom. A field in the data element being validated fails the validation rule if it fails any validation test that the system determines should be applied. For example, if the system determines that Condition 1 252 is satisfied and applies Validation Test 1 234 with Test Parameters1,1 236 to the value in the data element and that value does not meet the validation test then the field of the data element fails and the failure counter 240 is incremented.
In some implementations, once a field passes any of the conditional tests, no subsequent validation tests are applied to that field. For example, if the system determines that validate test 1 252 is satisfied then validation test 256 would not be applied.
In other implementations, each validation rule for which the conditions are met is applied. In some implementations, the system may designate a final validation rule as an catchall validation rule that is only executed if no other validation rule is applied to the field. In some implementations, a user may designate a validation rule as an catchall validation rule by supplying a predetermined condition, for example, by using a keyword (such as “else”) in the condition test column. In general, a catchall validation rule is a validation rule that executes on a field if and only if no other validation rule has executed for that field. In some implementations, whenever a conditional is used for a field, a catchall is provided for that field automatically.
In some implementations, a validation rule set may include multiple different condition tests that are each associated with one or more validation rules. For example, a business rule may have one set of validation rules that are applied when country code is ‘US’ and another set of one or more validation rules that are applied when the state code is “MA”. And other set of validation rules may be applied when the last name begins with a “W.”
In some implementations, only a single condition will be triggered for a given validation rule set, for example, after a single condition is true, the associated one or more validation rules are applied and then the validation rule set ends.
In other implementations, each condition is tested and all of the validation rules associated with any triggered condition are applied.
In some implementations, a validation rule set can include conditional validation rules and non-conditional validation rules. The non-conditional validation rules can be applied whether or not any condition is triggered.
The first validation 308 indicates that if the country is “US” then the postal code must be of the format “(99999)|(99999-9999).” The second validation 310 indicates that if the country is “CA” then the postal code must be of the format “A9A 9A9”. The third validation 312 indicates that if the country is “UK” then the postal code must be of the format “A((A9)|9)(A|9)? 9AA.” A fourth validation 314 is a catchall provision as designated by the condition “Else.” In this example, the fourth validation rule tests that the postal code is of the format “(99999)|(99999-9999).”
The user interface 300 also includes a fifth validation 316 that determines whether the country field contains one of the values “US”, “CA”, UK”.
The techniques described above can be implemented using software for execution on a computer. For instance, the software forms procedures in one or more computer programs that execute on one or more programmed or programmable computer systems (which can be of various architectures such as distributed, client/server, or grid) each including at least one processor, at least one data storage system (including volatile and non-volatile memory and/or storage elements), at least one input device or port, and at least one output device or port. The software can form one or more modules of a larger program, for example, that provides other services related to the design and configuration of dataflow graphs. The nodes and elements of the graph can be implemented as data structures stored in a computer readable medium or other organized data conforming to a data model stored in a data repository.
The software can be provided on a storage medium, such as a CD-ROM, readable by a general or special purpose programmable computer, or delivered (encoded in a propagated signal) over a communication medium of a network to a storage medium of the computer where it is executed. All of the functions can be performed on a special purpose computer, or using special-purpose hardware, such as coprocessors. The software can be implemented in a distributed manner in which different parts of the computation specified by the software are performed by different computers. Each such computer program is preferably stored on or downloaded to a storage media or device (e.g., solid state memory or media, or magnetic or optical media) readable by a general or special purpose programmable computer, for configuring and operating the computer when the storage media or device is read by the computer system to perform the procedures described herein. The inventive system can also be considered to be implemented as a computer-readable storage medium, configured with a computer program, where the storage medium so configured causes a computer system to operate in a specific and predefined manner to perform the functions described herein.
A number of embodiments of the invention have been described. Nevertheless, it will be understood that various modifications can be made without departing from the spirit and scope of the invention. For example, some of the steps described above can be order independent, and thus can be performed in an order different from that described.
It is to be understood that the foregoing description is intended to illustrate and not to limit the scope of the invention, which is defined by the scope of the appended claims. For example, a number of the function steps described above can be performed in a different order without substantially affecting overall processing. Other embodiments are within the scope of the following claims.
Number | Name | Date | Kind |
---|---|---|---|
5630127 | Moore | May 1997 | A |
5758351 | Gibson et al. | May 1998 | A |
5966072 | Stanfill et al. | Oct 1999 | A |
6088702 | Plantz | Jul 2000 | A |
6494159 | Sirmalis et al. | Dec 2002 | B2 |
6708186 | Claborn et al. | Mar 2004 | B1 |
6948154 | Rothermel et al. | Sep 2005 | B1 |
7080088 | Lau | Jul 2006 | B1 |
7110924 | Prewett et al. | Sep 2006 | B2 |
7164422 | Wholey, III et al. | Jan 2007 | B1 |
7167850 | Stanfill | Jan 2007 | B2 |
7661067 | Chen et al. | Feb 2010 | B2 |
7689565 | Gandhi | Mar 2010 | B1 |
7716630 | Wholey et al. | May 2010 | B2 |
7765529 | Singh et al. | Jul 2010 | B1 |
7840949 | Schumacher et al. | Nov 2010 | B2 |
7853553 | Lankinen et al. | Dec 2010 | B2 |
7890509 | Pearcy et al. | Feb 2011 | B1 |
7895586 | Ozone | Feb 2011 | B2 |
7979646 | Furtek et al. | Jul 2011 | B2 |
8069129 | Gould et al. | Nov 2011 | B2 |
8423564 | Hayes | Apr 2013 | B1 |
8484159 | Stanfill et al. | Jul 2013 | B2 |
8516008 | Marquardt | Aug 2013 | B1 |
20010007959 | Abdalla | Jul 2001 | A1 |
20010014890 | Liu et al. | Aug 2001 | A1 |
20020161799 | Maguire et al. | Oct 2002 | A1 |
20020194196 | Weinberg | Dec 2002 | A1 |
20020194314 | Kouznetsov | Dec 2002 | A1 |
20030016246 | Singh | Jan 2003 | A1 |
20030041063 | Brady | Feb 2003 | A1 |
20030154191 | Fish | Aug 2003 | A1 |
20030163441 | Godfredsen | Aug 2003 | A1 |
20030163597 | Hellman et al. | Aug 2003 | A1 |
20040015783 | Lennon et al. | Jan 2004 | A1 |
20040024740 | McGeorge, Jr. | Feb 2004 | A1 |
20040056908 | Bjornson et al. | Mar 2004 | A1 |
20040088318 | Brady | May 2004 | A1 |
20040225632 | Benson et al. | Nov 2004 | A1 |
20040225682 | Murman | Nov 2004 | A1 |
20040239681 | Robotham et al. | Dec 2004 | A1 |
20050010896 | Meliksetian et al. | Jan 2005 | A1 |
20050060313 | Naimat et al. | Mar 2005 | A1 |
20050060317 | Lott et al. | Mar 2005 | A1 |
20050097561 | Schumacher | May 2005 | A1 |
20050114369 | Gould et al. | May 2005 | A1 |
20050178833 | Kisliakov | Aug 2005 | A1 |
20050187984 | Chen | Aug 2005 | A1 |
20050234762 | Pinto et al. | Oct 2005 | A1 |
20050262121 | Cesare et al. | Nov 2005 | A1 |
20050289167 | Haselden et al. | Dec 2005 | A1 |
20060007464 | Percey | Jan 2006 | A1 |
20060020570 | Wu | Jan 2006 | A1 |
20060095466 | Stevens et al. | May 2006 | A1 |
20060200739 | Bhatia et al. | Sep 2006 | A1 |
20060282480 | Johnson | Dec 2006 | A1 |
20070011208 | Smith | Jan 2007 | A1 |
20070011668 | Wholey et al. | Jan 2007 | A1 |
20070027858 | Weinberg et al. | Feb 2007 | A1 |
20070050750 | Bykov et al. | Mar 2007 | A1 |
20070094060 | Apps et al. | Apr 2007 | A1 |
20070136692 | Seymour et al. | Jun 2007 | A1 |
20070179956 | Whitmyer | Aug 2007 | A1 |
20070198457 | Olenick et al. | Aug 2007 | A1 |
20070220022 | Lankinen | Sep 2007 | A1 |
20070226203 | Ayda et al. | Sep 2007 | A1 |
20070239751 | Wei et al. | Oct 2007 | A1 |
20070271381 | Wholey et al. | Nov 2007 | A1 |
20070276787 | Piedmonte | Nov 2007 | A1 |
20070294119 | Eicher et al. | Dec 2007 | A1 |
20080049022 | Sherb et al. | Feb 2008 | A1 |
20080126988 | Mudaliar | May 2008 | A1 |
20080201359 | Warshavsky et al. | Aug 2008 | A1 |
20080228697 | Ayda et al. | Sep 2008 | A1 |
20080243772 | Fuxman et al. | Oct 2008 | A1 |
20080243891 | Super et al. | Oct 2008 | A1 |
20080256014 | Gould et al. | Oct 2008 | A1 |
20080312979 | Lee et al. | Dec 2008 | A1 |
20080313204 | Schultz et al. | Dec 2008 | A1 |
20090037488 | Abrams | Feb 2009 | A1 |
20090063515 | Bar-Or et al. | Mar 2009 | A1 |
20090083313 | Stanfill et al. | Mar 2009 | A1 |
20090094291 | Yalamanchi | Apr 2009 | A1 |
20090234623 | Germain | Sep 2009 | A1 |
20090319494 | Gooder | Dec 2009 | A1 |
20090327196 | Studer et al. | Dec 2009 | A1 |
20100100220 | Belanger et al. | Apr 2010 | A1 |
20100114833 | Mu | May 2010 | A1 |
20100121890 | Perkins et al. | May 2010 | A1 |
20100138388 | Wakeling et al. | Jun 2010 | A1 |
20100145914 | Kanno et al. | Jun 2010 | A1 |
20100198769 | Gould et al. | Aug 2010 | A1 |
20100223218 | Prendergast | Sep 2010 | A1 |
20110061057 | Harris et al. | Mar 2011 | A1 |
20110066602 | Studer et al. | Mar 2011 | A1 |
20110145297 | Singh | Jun 2011 | A1 |
20110276789 | Chambers et al. | Nov 2011 | A1 |
20110295863 | Weir et al. | Dec 2011 | A1 |
20120054164 | Falkebo et al. | Mar 2012 | A1 |
20120102029 | Larson et al. | Apr 2012 | A1 |
20120158625 | Nelke et al. | Jun 2012 | A1 |
20120167112 | Harris et al. | Jun 2012 | A1 |
20120185449 | Gould et al. | Jul 2012 | A1 |
20120310905 | Hans | Dec 2012 | A1 |
20130166515 | Kung | Jun 2013 | A1 |
20140108357 | Procops | Apr 2014 | A1 |
Number | Date | Country |
---|---|---|
2221733 | Aug 2010 | EP |
05-507376 | Oct 1993 | JP |
07-044368 | Feb 1995 | JP |
H11-143755 | May 1999 | JP |
2006-277624 | Oct 2006 | JP |
2008-524671 | Jul 2008 | JP |
2008-547134 | Dec 2008 | JP |
2010056867 | May 2010 | WO |
2010065511 | Jun 2010 | WO |
Entry |
---|
Harkins, Susan “Use Excel's Conditional Formatting to Find Errors” TechRepublic, pp. 1-3, Feb. 16, 2008: http://www.techrepublic.com/blog/microsoft-office/use-excels-conditional-formatting-to-find-errors/. |
International Search Report & Written Opinion issued in PCT application No. PCT/US09/66210, mailed Jan. 27, 2010, 8 pages. |
International Search Report & Written Opinion issued in PCT application No. PCT/US10/49142, dated Nov. 5, 2010, 11 pages. |
International Search Report & Written Opinion issued in PCT application No. PCT/US2011/057623, dated Jan. 25, 2012, 13 pages. |
International Search Report & Written Opinion issued in PCT application No. PCT/US2012/021286, dated May 4, 2012, 15 pages. |
International Search Report & Written Opinion issued in PCT application No. PCT/US2013/064979, mailed Nov. 28, 2013, 11 pages. |
Japanese Office Action issued in JP2012-529903, dated Aug. 7, 2014, 4 pages (English Translation). |
Japanese Office Action issued in JP2011-539631, dated Oct. 24, 2013, 3 pages (English Translation). |
Liskin, Miriam “Microsoft Access 97 for Windows SuperGuide” Ziff-Davis Press, Jan. 1, 1997, ch. 4 & 15, pp. 117-157 and 687-739. |
Melia, Mark et al., “Constraint-Based Validation of Adaptive e-Learning Courseware,” IEEE Transactions on Learning Technologies, vol. 2, No. 1, Jan.-Mar. 2009, pp. 37-49. |
Rull, Guillem et al., “MVT: A Schema Mapping Validation Tool,” EDBT'09, Mar. 24-26, 2009, pp. 1120-1123. |
Van Megen, Rudolf et al., “Costs and benefits of early defect detection: experiences from developing client server and host applications,” Software Quality Journal 4, 247-256 (1995). |
Chaiken et al., “Xope: easy and efficient parallel processing of massive data sets,” J. Proc. of the VLDB Endowment Homepagearchive, vol. I, No. 2, (2008), pp. 1265-1276. |
Pinheiro et al., “Mobile agents for aggregation of network management data,” Agent Systems and Applications, (1999) pp. 130-140. |
Transaction History, U.S. Appl. No. 12/628,521, filed Mar. 25, 2016 (3 pages). |
Transaction History, U.S. Appl. No. 12/883,721, filed Mar. 25, 2016 (5 pages). |
Transaction History, U.S. Appl. No. 13/281,039, filed Mar. 25, 2016 (3 pages). |
Transaction History, U.S. Appl. No. 13/350,191, filed Mar. 25, 2016 (3 pages). |
Transaction History, U.S. Appl. No. 13/653,995, filed Mar. 25, 2016 (3 pages). |
Transaction History, U.S. Appl. No. 13/950,826, filed Mar. 25, 2016 (2 pages). |
International Search Report and Written Opinion issued in PCT/US2015/049131, dated Nov. 26, 2015, 14 pages. |
Japanese Office Action issued in JP 2012-529903, dated Aug. 7, 2014, 4 pages (English Translation). |
Number | Date | Country | |
---|---|---|---|
20160070733 A1 | Mar 2016 | US |