Generally, the invention relates to providing profile based data access to users. More specifically, the invention relates to method and system for providing profile-based data access through a semantic domain layer.
Most of data visualization and reporting tools available nowadays, have capabilities to create and configure data connections, query, join, and filter. These existing tools provide assistance to load and visualize data from different data sets. Moreover, in order to create data sets via these tools, there is a need to take help from an Information Technology (IT) team (or data engineer) to identify right data sources, tables (tables, fields, joins) and data definitions. Once the data sources are identified, then using these existing tools, final datasets are created. Further, the final datasets created, that are available within the existing tools are used for data visualization and querying activities. Based on the final datasets created, all business users (or end user) creates reports and dashboard as per their requirements.
However, there are certain limitations and complications in the existing tools that are used for data visualization and querying activities. The limitations in the existing tools includes strong dependency to identify and create final datasets before the final datasets can be used for reporting and data visualization purpose. Additionally, the final datasets created using these existing tools are available and limited within these tools only and can be consumed internally (i.e., within the tools itself). In other words, the final datasets created are not visible outside to get consumed by external applications.
Further, during creation of the final dataset, permissions for row level and column level for a user are static. In addition, these permissions have to be defined for the user while creating the final datasets. Moreover, user level permissions and access need to get defined at user, role, and group level. This in turn provides limited capabilities for dynamic user persona detection and available control. Since, user views, filter conditions, and access levels need to get defined at user, role, and group level, these existing tools provides less integration and reusability capabilities of the final datasets created and data definitions.
Also, the existing tools provides limited self-service approach to business users for creating visualization, reports, and dashboards, as there is a need of separate report layer to access data sets and create reports. Moreover, the existing tools are untrustworthy and don't have a single source of truth as data sources are available without masking and encryption. Due to above listed limitations, these existing tools cannot bring self-service approach to create visualization on top of data, due to dependency on IT teams or data engineers, and static behavior.
Therefore, there is a need of an efficient and reliable method and system providing profile-based data and visualization access through a semantic domain layer.
In one embodiment, a method for providing profile-based data and visualization access through a semantic domain layer is disclosed. The method may include receiving a user request to access data. The method may include determining a user profile from a plurality of user profiles associated with the user. It should be noted that, the plurality of user profiles corresponds to a plurality of users. The method may include extracting a first access level from a first set of access levels associated with the user profile. The method may include mapping the user profile with a domain object from a plurality of domain objects, based on a second access level from the first set of access levels associated with the domain object. The method may include selectively rendering at least a portion of the data requested in the user request to the user, in response to mapping the user profile with the domain object.
In another embodiment, a system for providing profile-based data and visualization access through a semantic domain layer is disclosed. The system includes a processor and a memory communicatively coupled to the processor. The memory may store processor-executable instructions, which, on execution, may causes the processor to receive a user request to access data. It should be noted that, the plurality of user profiles corresponds to a plurality of users. The processor-executable instructions, on execution, may further cause the processor to determine a user profile from a plurality of user profiles associated with the user. The processor-executable instructions, on execution, may further cause the processor to extract a first access level from a first set of access levels associated with the user profile. The processor-executable instructions, on execution, may further cause the processor to map the user profile with a domain object from a plurality of domain objects, based on a second access level from the first set of access levels associated with the domain object. The processor-executable instructions, on execution, may further cause the processor to selectively render at least a portion of the data requested in the user request to the user, in response to mapping the user profile with the domain object.
In yet another embodiment, a non-transitory computer-readable medium storing computer-executable instruction for providing profile-based data and visualization access through a semantic domain layer is disclosed. The stored instructions, when executed by a processor, may cause the processor to perform operations including receiving a user request to access data. The operations may further include determining a user profile from a plurality of user profiles associated with the user. It should be noted that, the plurality of user profiles corresponds to a plurality of users. The operations may further include extracting a first access level from a first set of access levels associated with the user profile. The operations may further include extracting a first access level from a first set of access levels associated with the user profile. The operations may further include mapping the user profile with a domain object from a plurality of domain objects, based on a second access level from the first set of access levels associated with the domain object. The operations may further include selectively rendering at least a portion of the data requested in the user request to the user, in response to mapping the user profile with the domain object.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory only and are not restrictive of the invention, as claimed.
The present application can be best understood by reference to the following description taken in conjunction with the accompanying drawing figures, in which like parts may be referred to by like numerals.
The following description is presented to enable a person of ordinary skill in the art to make and use the invention and is provided in the context of particular applications and their requirements. Various modifications to the embodiments will be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other embodiments and applications without departing from the spirit and scope of the invention. Moreover, in the following description, numerous details are set forth for the purpose of explanation. However, one of ordinary skill in the art will realize that the invention might be practiced without the use of these specific details. In other instances, well-known structures and devices are shown in block diagram form in order not to obscure the description of the invention with unnecessary detail. Thus, the invention is not intended to be limited to the embodiments shown but is to be accorded the widest scope consistent with the principles and features disclosed herein.
While the invention is described in terms of particular examples and illustrative figures, those of ordinary skill in the art will recognize that the invention is not limited to the examples or figures described. Those skilled in the art will recognize that the operations of the various embodiments may be implemented using hardware, software, firmware, or combinations thereof, as appropriate. For example, some processes can be carried out using processors or other digital circuitry under the control of software, firmware, or hard-wired logic. (The term “logic” herein refers to fixed hardware, programmable logic and/or an appropriate combination thereof, as would be recognized by one skilled in the art to carry out the recited functions.) Software and firmware can be stored on computer-readable storage media. Some other processes can be implemented using analog circuitry, as is well known to one of ordinary skill in the art. Additionally, memory or other storage, as well as communication components, may be employed in embodiments of the invention.
A system 100 for providing profile based data access through a semantic domain layer 102, is illustrated in
In particular, in order to provide profile based data access to a user, initially, the semantic domain layer 102 may create a plurality of user profiles. The plurality of user profiles created may correspond to a plurality of users. In an embodiment, each of the plurality of user profiles may also be referred as a user persona. Moreover, each of the plurality of user profiles may be created by an administrator of the semantic domain layer 102. In an embodiment, the administrator may correspond to a person that may have access of all functionalities of the semantic domain layer 102. In other words, the administrator may be referred to as the person that may be responsible to create new user profiles, create new domain objects, provide access level and access permission to other users working in an organization. Examples of the administrator may include, but are not limited to, owner of an organization, head of a department, or a manager, etc.
Further, each of the plurality of user profiles created may be associated with at least one of a plurality of user attributes. The plurality of user attributes may include, but are not limited to at least one of employee Identifier (ID), organization ID, team ID, business unit ID, user location, current designation, department, user type, or access levels. Thereafter, the administrator may assign a first access level from a first set of access levels to each of the plurality of user profiles via the semantic domain layer 102. In an embodiment, the first access level may be assigned to verify a user requesting data access. In order to verify the user, the semantic domain layer 102 may validate whether, the user requesting the access of data belongs to the plurality of user profiles created or not. In addition, the first set of access levels may include a public access level, a private access level, and a protected access level.
Once the user profile is created, the administrator may create a plurality of domain objects utilizing the semantic domain layer 102. In order create the plurality of domain object, at least one data source may be selected from a plurality of data warehouse and structured files 104. Examples of the at least one data source may include, but are not limited to any type of databases, flat files, and web services. A method of creating each of the plurality of domain objects is explained in detail in conjunction with
Further, the semantic domain layer 102 may receive a user request to access data. Upon receiving the user request, the semantic domain layer 102 may provide access of the requested data based on mapping of the user profile with a domain object from the plurality of domain objects. In an embodiment, the mapping of the user profile with the domain object may be done only when the user profile of the user requesting the access of data corresponds to one of the plurality of user profiles created. Thereafter, at least a portion of the data requested by the user in the user request may be rendered to the user as an output 106. The portion of requested data may be rendered to the user in one of a predefined set of data visualization formats. The predefined set of data visualization formats may include, but are not limited to, charts, graphs, tables, reports, and diagrams.
In an embodiment, the system 100 developed with the semantic domain layer 102 may be referred to as a semantic domain layer web application. Moreover, the semantic domain layer 102 disclosed may be platform agnostic. This means that the disclosed sematic domain layer 102 may be integrated with any external platforms. In addition, the integration of the semantic domain layer 102 may be done without having to worry about exposing sensitive data and usage of unnecessary filtration conditions while querying data from various data sources.
Referring now to
First component from the set of components, i.e., the SDL user interface 202 may be configured to provide a set of functionalities to each of a plurality of users. In this embodiment, each of the plurality of users may correspond to an administrator or a user of the semantic domain layer 200. The set of functionalities may include an ease to access, create and manage each of a plurality of domain objects, selection of at least one data source, a set of tables, a plurality of fields, and an access level, and access permission. The access level may correspond to one of a first set of access levels and one of a second set of access level. In an embodiment, the first set of access levels may be associated with the plurality of users and the plurality of domain objects. Additionally, the second set of access levels may correspond to an encrypted access and a masked access associated with a plurality of fields within a set of tables. In an embodiment, each of the set of tables may be associated with one of the plurality of domain objects.
In order to provide access of the set of functionalities, the SDL user interface 202 may include a domain object management unit 204, a user management unit 206, and a user based permission unit 208. The user based permission unit 208 may be associated with a domain object level 210, a feature level 212, and an attribute level 214. In particular, the domain object management unit 204 may be configured to manage data received from multiple data sources. In an embodiment, the data received from multiple data sources may be associated with the plurality of domain objects. Further, the domain object management unit 204 may identify a set of tables associated with each of the plurality of domain objects.
Moreover, the data received from multiple data sources may be present in denormalized form in each of the set of tables. It should be noted that, every row of the set of tables identified may correspond to an instance of each of the plurality of domain objects. Once the set of tables are identified, the domain object management unit 204 may normalize data present within each of the set of tables. In other words, the domain object management unit 204 may create an alias for at least one of a plurality of fields within the set of tables. The plurality of fields may correspond to one of a row and a column within one of the set of tables. In an embodiment, the alias may be created to standardize data representation across each of the set of tables.
In an embodiment, each of the plurality of domain objects may also be referred as an entity set. Moreover, each of the plurality of domain objects may correspond to a collection of categorical properties, i.e., feature vectors and attribute vectors. In an embodiment, the feature vectors may correspond to a plurality of rows present within the set of tables. In addition, the attribute vectors may correspond to a plurality of columns present within the set of tables. Further, each of the collection of categorical properties may be used for setting granular level access permissions on each of the plurality of domain objects based on the plurality of user profiles. The plurality of user profiles may correspond to each of the plurality of users.
Further, the user management unit 206 may be configured to create and manage each of the plurality of user profiles corresponding to the plurality of users. In an embodiment, each of the plurality of user profiles may be created based on at least one of the plurality of user attributes associated with each of the plurality of users. The plurality of user attributes may include, but are not limited to at least one of employee ID, organization ID, team ID, business unit ID, user location, current designation, department, user type, and access level. An exemplary embodiment depicting creation of user profile has been explained in detail in conjunction with
Moreover, the user based permission unit 208 may be configured to assign the access level and the access permission to access at least one of the plurality of domain objects. The access level and access permissions may be assigned based on the user profile of each of the plurality of users. The access level may correspond to one of a first set of access level and one of a second set of access level. In addition, the access permissions may correspond to permissions defined for each of the plurality of users to access the plurality of domain objects. In an embodiment, the access permission may be defined based on the access level assigned.
In an embodiment, a first access level from the first set of access levels may be assigned to each of the plurality of users. In addition, a second access level form the first set of access levels may be assigned based on each of the plurality of domain objects. In present
In one embodiment, when the second access level from the first set of access levels may be defined to be the public access level for at least one domain object from the plurality of domain objects, name of the at least one domain object may be visible to one or more of the plurality of user based on their associated user profiles. In addition, the at least one domain object may be accessible by each of the plurality of users. In another embodiment, when the second access level from the first set of access levels may be defined to be the private access level for at least one domain object from the plurality of domain objects, name and accessibility of the at least one domain object may be provided to at least one user from the plurality of users having permissions to see and access the at least one domain object. In yet another embodiment, when the second access level from the first set of access levels may be defined to be the protected access level for at least one domain object from the plurality of domain object, name of the at least one domain object may be visible to each of the plurality of users. In addition, the at least one domain object may be accessible by at least one of the plurality of users having permissions to access the at least one domain object.
Further, one of the second set of access levels may be assigned to at least one of the plurality of fields. In an embodiment, the second set of access levels may include the encrypted access and the masked access of one of the plurality of fields, to at least one of the plurality of users. Each of the plurality of fields may be present within the set of tables. Further, each of the plurality of fields may correspond to one of the row and the column within one of the set of tables. In an embodiment, an access level from the second set of access levels corresponding to the row of at least one of the plurality of fields may be assigned at the feature level 212. In addition, an access level from the second set of access level corresponding to the column of at least one of the plurality of fields may be assigned at the attribute level 214.
Once the plurality of user profiles and the plurality of domain objects are created, the SDL user interface 202 may verify a user request received to access data via an identify/authorization server 218. In addition, the identify/authorization server 218 may be configured to identify profile of the user that may be requesting the access of the data. Moreover, the identify/authorization server 218 may be responsible to map the user with the domain object associated with the user profile.
Further, the SDL user interface 202 may store a metadata information associated with each of the plurality of users to access each of the plurality of domain objects in a metadata store 216. The metadata information may include the user profile of each of the plurality of users, information of each of the plurality of domain objects, and the access level assigned to each of the plurality of users for the plurality of domain objects. Once the metadata information is stored in the metadata store 216, then the stored metadata information may be utilized by the SDL query engine 220.
The SDL query engine 220 may utilize the metadata information to provide access of at least one domain object from the plurality of domain objects to at least one of the plurality of users. In an embodiment, the SDL query engine 220 may correspond to data definition web Application Programming Interface (API). Moreover, the SDL query engine 220 may provide access of data present in the at least one domain object to at least one of the plurality of users based on the access level defined for the at least one of the plurality of users. A method of providing access of the at least one domain object has been explained in detail in conjunction with
Further, in order to provide access of the data to the at least one user, the SDL query engine 220 may include a domain object listing unit 222, a field listing unit 224, a query interface 226, and a dynamic formation of metadata unit 228. The domain object listing unit 222 may be configured to list a set of allowed domain object from the plurality of domain objects that is accessible by the at least one user. The field listing unit 224 may be configured to list one or more fields present within the set of tables to the at least one user. Each of the set of tables may be associated with the set of allowed domain objects that is accessible by the at least one user. The query interface 226 may be configured to verify a query generated to access the domain. The query generated may be represented as depicted below via an equation (1):
DomainObject·ObjectProperty·AccessControlled=True/False (1)
In above equation (1), domain object may correspond to the domain object from the plurality of domain objects. Object property may correspond to a type of the domain object. In other words, the object property may depict a set of predefined properties associated with the domain object. By way of an example, one of the set of predefined properties may correspond to the first set of access level defined for the domain object. The first set of access level may include a public access level, a private access level, and a protected access level. In an embodiment, the administrator of the semantic domain layer 200 may define one of the first set of access levels for at least one user to access the domain object. Further, the administrator of the semantic domain layer 200 may modify the one of the first set of access levels defined for the domain object as per requirement of the at least one user. For example, the administrator may modify one of the first set of access levels based on organizational hierarchy (e.g., parent, child of) and type of data present in the domain object (e.g., master data, transaction data).
Access control may correspond to the access permission defined for the at least one user corresponding to the domain object. In an embodiment, when the query generated may be defined to be true, then the data of that domain object may be accessible by the at least one user. In another embodiment, when the query generated may be defined to be false, then the data of that domain object may not be accessible by the at least one user. It should be noted that, default value of the query generated for each of the plurality of domain objects may be defined to be false. Moreover, user (i.e., the administrator) of the semantic layer may change the default value based on his requirement.
Further, in order to verify the query generated, the SDL query engine 220 may interact with the metadata store 216 of the SDL user interface 202 and a JDBC/ODBC driver 230. In other words, the SDL query engine 220 may act a connector between the SDL user interface 202 and the JDBC/ODBC driver 230. Once the generated query is verified, the dynamic formation of metadata unit 228, may dynamically fetch and render the data corresponding to the set of allowed domain objects, to the at least one user.
In an embodiment, the JDBC/ODBC driver 230 may be configured to hold list of each of the plurality of domain objects and the plurality of fields corresponding to each of the plurality of users. In addition, the JDBC/ODBC driver 230 may be configured to retrieve one of the second access level assigned to the row for each of the plurality of fields from the set of allowed domain objects. It should be noted that, the JDBC/ODBC driver 230 may be available as 32 bit and 64 bit to support framework for the semantic domain layer 200. In an embodiment, the JDBC/ODBC driver 230 may also be referred as data connection drivers.
Further, the JDBC/ODBC driver 230 may facilitate querying of data received from various data sources via the semantic domain layer 200. In addition, queries in standard Structured Query Language (SQL) may be directly accessed via the JDBC/ODBC driver 230 to query data including conditions like, ‘where’, ‘group’ and ‘order’. In addition, the JDBC/ODBC driver 230 may be highly optimized to enables better performance for the semantic domain layer 200. In addition, the JDBC/ODBC driver 230 provides an additional layer of data security for the data.
In order to facilitate querying of data, the JDBC/ODBC driver 230 may include POSTGRES 232, HIVE 234, MYSQL 236, and MSSQL 238. The POSTGRES 232 may correspond to an open source object relational database management system. The HIVE 234 may correspond to a data warehouse software. The MYSQL 236 may correspond to a community driven database management system. The MSSQL 238 may correspond to a relational database management system.
In particular, as will be appreciated by those of ordinary skill in the art, the semantic domain layer 200 described herein may be implemented in any computing device, either by hardware, software, or combinations of hardware and software. For example, suitable code may be accessed and executed by the one or more processors on any computing device to perform some or all of the techniques described herein. Similarly, application specific integrated circuits (ASICs) configured to perform some or all of the processes described herein may be included in the one or more processors on the computing system. Moreover, the functionality of various components of the semantic domain layer 200 may be integrated with any computing devices.
Referring now to
Once the plurality of user profiles is created, at step 304, a user request may be received to access data. In an embodiment, the data may correspond to an information associated with at least of a plurality of domain objects. Upon receiving, the user request, at step 306, a user profile associated with the user may be determined from the plurality of user profiles created. In other words, the user profile of the user requesting the access of the data may be determined. Once the user profile is determined, at step 308, a first access level associated with the user profile may be extracted from a first set of access levels. In other words, the first access level may correspond to an access level associated with the user profile. In an embodiment, the first set of access levels may include a public access level, a private access level, and a protected access level.
By way of an example, based on the first access level extracted, the user profile may be validated. In order to validate the user profile, a check may be performed. The check may be performed to identify which one of the public access level, the private access level, or protected access level the first access level extracted corresponds to. In one embodiment, when the first access level extracted corresponds to the public access level, then the user of that user profile may only have access to all public data. In another embodiment, when the first access level extracted corresponds to the private access level, then the user of that user profile may additionally have access to all private data. In yet another embodiment, when the first access level extracted corresponds to the protected access level, then the user of that user profile may additionally have access to all protected data in hashed format.
Once the user is validated based on the first access level extracted, at step 310, the user profile may be mapped with a domain object from a plurality of domain objects. A process of mapping the user profile with the domain object is explained in detail in conjunction with
In one embodiment, when the second access level associated with the domain object corresponds to the public access level, then the user may be able to see name of that domain object. In addition, the user may be able to access all data present in the domain object corresponding to the public access level. In another embodiment, when the second access level associated with the domain object corresponds to the private access level. Then, the user may be able to see name and access data of that domain object only if the user has permission to access that domain object. In yet another embodiment, when the second access level associated with the domain object corresponds to the protected access level. Then, the name of the domain object may be visible to the user. However, the user may access data of the domain object with protected access level, only when he has permission to access data.
Once the mapping of the user profile with the domain object is done, at step 312, at least a portion of the data requested may be selectively rendered to the user. In an embodiment, the portion of data may correspond to a part of the data requested by the user in the user request. It should be noted that, the portion the data requested may be rendered to the user in response to mapping the user profile with the domain object. Moreover, at step 314, at least a portion of the data requested by the user may be presented in one of a predefined set of data visualization formats. The predefined set of data visualization formats may include, but is not limited to, charts, graphs, tables, and diagrams.
Referring now to
Once the domain object is created, at step 404, the second access level from the first set of access levels is assigned to the domain object. The first set of access levels may include the public access level, the private access level, and the protected access level. It should be noted that, the second access level may be assigned to each of the plurality of domain objects created. Once the second access level is assigned to each of the plurality of domain objects, mapping of the user profile may be done with the domain object from the plurality of domain objects.
Referring now to
Upon identifying the set of tables, at step 508, one of the first set of access levels may be assigned to each of the plurality of fields. In an embodiment, each of the plurality of fields may be present within the set of tables. Further, at step 510, one of the first set of access level may be assigned to each of the plurality of users. In reference to
Further, at step 512, a second set of access levels may be assigned to at least one of the plurality of fields. In an embodiment, the second set of access level may include, but are not limited to an encrypted access and a masked access. In addition, each of the plurality of fields may correspond to one of a row and a column within one of the set of tables. In an embodiment, once the first set of access levels and the set of access levels are assigned, at step 514, an alias may be created for at least one of the plurality of field. In an embodiment, the alias may be created to standardize data representation across the set of tables.
Referring now to
The first set of selectable options includes domain object name, database name, and access level as depicted in present
Moreover, the domain object list represented on the user interface 600a further depicts a second set of selectable options. The second set of selectable options includes fields, joins, and where details. In present
Once a user from the plurality of user selects the ‘+object’ button to create the new object domain, a UI 600b of the semantic domain layer may be opened as depicted in
Once the user clicks on the next button, a UI 600c may open as depicted in
Upon clicking on the next button, based on selection of the at least one data source, a UI 600d may be opened as depicted in
Once the relevant tables are selected, upon clicking on next button, a UI 600e may be opened as depicted in the
Once the relevant tables and the plurality of fields are selected, then after click on the next button depicted in the UI 600e, a UI 600f may be opened as depicted via
Further, the user may add where condition while creating new domain object via a UI 600g as depicted in
Referring now to
As depicted in present
Lastly, permission to access the specific domain object may defined for the selected username. As depicted in present
Once the access level and the access permissions are defined for the user, then the administrator may assign a second set of access level to each of a plurality of fields via a UI 700b as depicted in
As depicted in
Similarly, the second set of access level for each column associated with each of the plurality of field may be assigned via a UI 700c. In an embodiment, each column present within the set of tables may correspond to the attribute vector. The administrator may assign the second set of access level for each column corresponding to each of the plurality of users via the UI 700c. Moreover, one of the second set of access level for each column may be easily assigned by selecting the username, and the domain object as depicted in present
Referring now to
In order to create the new user profile, the administrator may click on user management option from the set of options, present in left side of the menu. Once the user management option is selected, the UI 800 may open as depicted in present
Various embodiments provide method and system for providing profile-based data and visualization access through a semantic domain layer. The disclosed method and system may receive a user request to access data. Moreover, the disclosed method and system may determine a user profile from a plurality of user profiles associated with the user. The plurality of user profiles corresponds to a plurality of users. Further, the disclosed method and system may extract a first access level from a first set of access levels associated with the user profile. In addition, the disclosed method and system may map the user profile with a domain object from a plurality of domain objects, based on a second access level from the first set of access levels associated with the domain object. Thereafter, the disclosed method and system may selectively render at least a portion of the data requested in the user request to the user, in response to mapping the user profile with the domain object.
The system and method provide some advantages like, the system and the method may provide exposure and reuse of pre-created datasets across multiple tools having single source of truth of data access, thereby minimizing dependency of IT teams. Further, the disclosed method and system may enable dynamic application, control permissions, and user access based on user persona even without modifying query. In addition, the disclosed method and system may provide dynamic behavior to control rows and column level of data access based on user persona (GEO, roles, authorizations). Moreover, the disclosed method and system may define auto join and may detect relationship between data and user. Additionally, the disclosed method and the system may hide, mask and encrypt data based on user persona.
It will be appreciated that, for clarity purposes, the above description has described embodiments of the invention with reference to different functional units and processors. However, it will be apparent that any suitable distribution of functionality between different functional units, processors or at least may be used without detracting from the invention. For example, functionality illustrated to be performed by separate processors or controllers may be performed by the same processor or controller. Hence, references to specific functional units are only to be seen as references to suitable means for providing the described functionality, rather than indicative of a strict logical or physical structure or organization.
Although the present invention has been described in connection with some embodiments, it is not intended to be limited to the specific form set forth herein. Rather, the scope of the present invention is limited only by the claims. Additionally, although a feature may appear to be described in connection with particular embodiments, one skilled in the art would recognize that various features of the described embodiments may be combined in accordance with the invention.
Furthermore, although individually listed, a plurality of means, elements or process steps may be implemented by, for example, a single unit or processor. Additionally, although individual features may be included in different claims, these may possibly be advantageously combined, and the inclusion in different claims does not imply that a combination of features is not feasible and/or advantageous. Also, the inclusion of a feature in one category of claims does not imply a limitation to this category, but rather the feature may be equally applicable to other claim categories, as appropriate.
Number | Date | Country | Kind |
---|---|---|---|
202111010599 | Mar 2021 | IN | national |
Number | Name | Date | Kind |
---|---|---|---|
6996566 | George et al. | Feb 2006 | B1 |
8230343 | Logan et al. | Jul 2012 | B2 |
8245186 | Gryko et al. | Aug 2012 | B2 |
8321836 | Meijer et al. | Nov 2012 | B2 |
8332337 | Harrison et al. | Dec 2012 | B2 |
8396804 | Dala et al. | Mar 2013 | B1 |
8468391 | Balani et al. | Jun 2013 | B2 |
8656343 | Fox et al. | Feb 2014 | B2 |
8756185 | Dawson et al. | Jun 2014 | B2 |
8918739 | Butin et al. | Dec 2014 | B2 |
8983900 | Hegde et al. | Mar 2015 | B2 |
9135151 | Betak et al. | Sep 2015 | B2 |
9207931 | Fox et al. | Dec 2015 | B2 |
9424167 | Lee et al. | Aug 2016 | B2 |
9489630 | Achin et al. | Nov 2016 | B2 |
9519477 | Champlin-Scharff et al. | Dec 2016 | B2 |
9602738 | Choe et al. | Mar 2017 | B2 |
9652846 | Codella et al. | May 2017 | B1 |
9665467 | Angwin et al. | May 2017 | B2 |
9710767 | Dietrich et al. | Jul 2017 | B1 |
9740462 | Rao et al. | Aug 2017 | B2 |
9779492 | Garnavi et al. | Oct 2017 | B1 |
9898387 | Rodmell | Feb 2018 | B2 |
9928160 | Champlin-Scharff et al. | Mar 2018 | B2 |
10466978 | Vidan et al. | Nov 2019 | B1 |
10614382 | Wu | Apr 2020 | B1 |
11763371 | Rackley, III | Sep 2023 | B2 |
20020156799 | Markel et al. | Oct 2002 | A1 |
20070074167 | Cohrs et al. | Mar 2007 | A1 |
20070112574 | Greene | May 2007 | A1 |
20070239769 | Fazal et al. | Oct 2007 | A1 |
20070274563 | Jung et al. | Nov 2007 | A1 |
20080320444 | Meijer et al. | Dec 2008 | A1 |
20090030902 | Aharoni et al. | Jan 2009 | A1 |
20090089078 | Bursey | Apr 2009 | A1 |
20090172047 | Boyko et al. | Jul 2009 | A1 |
20090181665 | Sater et al. | Jul 2009 | A1 |
20100114806 | Harrison et al. | May 2010 | A1 |
20100153382 | Vidov et al. | Jun 2010 | A1 |
20110214064 | Schneider | Sep 2011 | A1 |
20110276354 | Bijani et al. | Nov 2011 | A1 |
20110313969 | Ramu | Dec 2011 | A1 |
20120290412 | Marovets | Nov 2012 | A1 |
20130007700 | Villar et al. | Jan 2013 | A1 |
20130066717 | Marovets | Mar 2013 | A1 |
20130095864 | Marovets | Apr 2013 | A1 |
20130191185 | Galvin | Jul 2013 | A1 |
20130212562 | Fox et al. | Aug 2013 | A1 |
20130339311 | Ferrari et al. | Dec 2013 | A1 |
20140115562 | Fox et al. | Apr 2014 | A1 |
20140122697 | Liu et al. | May 2014 | A1 |
20140164507 | Tesch et al. | Jun 2014 | A1 |
20140172490 | Snyder | Jun 2014 | A1 |
20140282400 | Moorthi et al. | Sep 2014 | A1 |
20140330578 | Pincus | Nov 2014 | A1 |
20150082277 | Champlin-Scharff et al. | Mar 2015 | A1 |
20150213793 | Phelan et al. | Jul 2015 | A1 |
20150269060 | Rodmell | Sep 2015 | A1 |
20150281295 | Tong et al. | Oct 2015 | A1 |
20150379554 | Copeland | Dec 2015 | A1 |
20160132608 | Rathod | May 2016 | A1 |
20160170742 | Pallath et al. | Jun 2016 | A1 |
20160255139 | Rathod | Sep 2016 | A1 |
20170004065 | Angwin et al. | Jan 2017 | A1 |
20170006135 | Siebel et al. | Jan 2017 | A1 |
20170083428 | Champlin-Scharff et al. | Mar 2017 | A1 |
20170109136 | Colle et al. | Apr 2017 | A1 |
20170124487 | Szeto et al. | May 2017 | A1 |
20170132817 | Mahajan et al. | May 2017 | A1 |
20170185904 | Padmanabhan et al. | Jun 2017 | A1 |
20170199930 | Trabelsi | Jul 2017 | A1 |
20170206064 | Breazeal et al. | Jul 2017 | A1 |
20170213132 | Hammond et al. | Jul 2017 | A1 |
20170213154 | Hammond et al. | Jul 2017 | A1 |
20170330205 | Belanger et al. | Nov 2017 | A1 |
20170357568 | Hughes et al. | Dec 2017 | A1 |
20180052898 | Allan et al. | Feb 2018 | A1 |
20180067732 | Seetharaman et al. | Mar 2018 | A1 |
20180068271 | Abebe et al. | Mar 2018 | A1 |
20180089572 | Aili et al. | Mar 2018 | A1 |
20180101465 | Keinan | Apr 2018 | A1 |
20180107583 | Champlin-Scharff et al. | Apr 2018 | A1 |
20220391419 | Dubey | Dec 2022 | A1 |
20230352132 | Gold | Nov 2023 | A1 |
Number | Date | Country |
---|---|---|
2004075466 | Sep 2004 | WO |
Entry |
---|
Systems and methods for semantic reasoning,U.S. Appl. No. 61/846,118, filed Jul. 15, 2013. |
Dave Mariani, What is a Universal Semantic Layer? Why Would You Want One?, Blog / Analytics & Strategy, Nov. 29, 2021, atscale.com. |
Number | Date | Country | |
---|---|---|---|
20220391419 A1 | Dec 2022 | US |