Previously known electronic health record (EHR) systems store patient data chronologically and according to the data type (e.g., medicine, procedure, laboratory results, etc.). Physicians spend a significant portion of their practice time interacting with medical records, which are not organized in a way that promotes efficient analysis.
The invention and the following detailed description of certain embodiments thereof may be understood by reference to the following figures:
In a variety of applications, physicians and other medical personnel access patient records to make diagnoses and care decisions. Patient records are often organized in chronological order and sometimes organized by data type. Chronological and/or type organization of EHR requires a physician to review and connect disjoint data from various portions of an EHR. For example, many patients who suffer from a disease may take medications to manage the progression of the disease. In order for a physician to determine whether the dose of the medications is adequate from a chronological organization of EHR, the physicians would have to first have to review the problem list of the EHR to see the patient's current medical problems, then scan the medication section to determine what dose the patient is on, and finally navigate to the laboratory section to determine the patient's tolerance to the medication, all of which involves multiple checks and time.
The problem-oriented medical record (POMR) is a paradigm for presenting medical information that, in contrast to chronological presentations, organizes data around the patient's problem list. In the POMR model, all relevant information pertaining to a patient problem may be presented in the same location within the EHR. POMR organization may improve a physicians' ability to reason about each of their patients' problems and save time and errors associated with reviewing chronological EHR.
Generation of POMR may include determining problems and linking the problems to their associated labs, medications, procedures, and the like. Traditionally, determining problems and linking the problems to associated data is a manual process that involves multiple experts coming to an agreement while maintaining an adequate level of accuracy. Manual analysis is inefficient and pre-determined associations cannot process and organize problems and associations that were not previously encountered. Additions or changes to problems may require costly and lengthy manual updates to problem lists and associations.
Systems, methods, and apparatuses described herein provide for automatic generation of a knowledge base that may be leveraged for organizing EHR into POMR. The knowledge base may be used to transform a chronological EHR organization into POMR. Systems, methods, and apparatuses described herein automatically link problems to their associated labs, medications, and procedures and are speedier and more flexible than the otherwise manual processes. Systems, methods, and apparatuses described herein use machine learning on electronic health records to automatically construct problem-based groupings of relevant medications, procedures, and/or laboratory tests. Systems, methods, and apparatuses described herein exploit both pre-trained concept embeddings and usage data relating the concepts contained in a longitudinal data set from a large health system.
A knowledge base may include a collection of triples that represent a source, target, and a relation between the source and the target.
A knowledge graph may include thousands or even millions of triples. Even in very large graphs, with many nodes and relations, the graph may be incomplete. In some cases, relationships between problems and targets may not be established or defined. New targets may be introduced and may not be related to problems. An incomplete graph may result in incomplete mapping of EHR data to a POMR if some elements in the EHR are not mapped to problems. In embodiments, a knowledge graph may be automatically updated and completed to determine missing relations between problems and targets.
As described herein, the knowledge base may be created automatically. In embodiments, the knowledge base may be updated automatically to define new problems and determine relations between problems and targets. In embodiments, the knowledge base may be updated for specific organizations, medical fields, and the like. The knowledge base may be continuously updated, periodically updated, and/or in response to a trigger such as an indication of new data or an indication from a user. In embodiments, creating and updating the knowledge base may include neural network models that adapt pre-trained medical concept embeddings and learn from both an annotated knowledge-base as well as a longitudinal data set of inpatient and outpatient encounters.
Embedding may be a representation of tokens (i.e., words, phrases, medical concepts) in a vector space such that the embedding includes relevant information about the token. Token embedding may preserve information about the meaning of the token. Two tokens that have similar meanings may have token embeddings that are close to each other in the vector space. By contrast, two tokens that do not have similar meanings may have token embeddings that are not close to each other in the vector space. An embedding may be a vector in an N-dimensional vector space that represents the tokens. For example, the embeddings may be constructed so that tokens with similar meanings or categories are close to one another in the N-dimensional vector space. Embeddings may use larger vector spaces, such as a 128-dimensional vector space or a 512-dimensional vector space.
Any appropriate techniques may be used to compute embeddings. For example, the words may be converted to one-hot vectors where the one-hot vectors are the length of the vocabulary, and the vectors are 1 in an element corresponding to the word and 0 for other elements. The one-hot vectors may then be processed using any appropriate techniques, such as the techniques implemented in Word2Vec or GloVe software. A word embedding may accordingly be created for each word in the vocabulary. An additional embedding may also be added to represent out-of-vocabulary words.
In some cases, the knowledge base completion 406 component may be further trained on additional medical data sets and external embeddings 408, site-specific data sets and embeddings 412, and/or data set statistics/features 410 such as co-occurrence of data elements in at least a subset of the medical data set 410. The additional data 408, 410, 412 may be used to train the knowledge base completion 406 component to identify missing relations and/or targets in the first knowledge base 404 and generate an updated second knowledge base 402 that includes additional mappings and relations between problems and targets.
In embodiments, the first knowledge base may be an initial knowledge base, such as a seed knowledge base, or may be another knowledge base that was manually or automatically created. The initial knowledge base may be determined from an initial data set. An example medical data set may include a data set including longitudinal health records, inpatient records, outpatient records, and/or emergency department information from an appropriately scoped record set, such as a large regional healthcare system. An example medical data set may include associated diagnoses codes for at least a portion of the records, where the diagnoses codes may correspond to medical problems or may use a separate codification system. The example medical data set may be anonymized, for example, with the removal of names or identifying information, shifting of dates, or the like. An example medical data set may be encounter-based, for example, with each encounter having an associated set of diagnoses codes, medications, procedures, tests, and/or the like.
The initial knowledge base may be generated by determining a problem set. In embodiments, the problem set may be obtained from Clinical Classifications Software (CCS) or diagnosis-related groups (DRG). In embodiments, the problem set may be derived from the medical data set. The problem set may be defined as a set of diagnosis codes from the data set. To define new problems, an annotator (such as an emergency medicine attending physician) may be presented with a list of diagnosis codes ranked by how many unique patients in the data set were associated with the code at any point in their history. In some cases, codes may be limited according to codes that appear in a threshold number of records, such as at least 50 patient records in the data set. The list of codes may be annotated by assigning a diagnosis code to a new problem definition as appropriate. Problem sets may be expanded as needed for an application or field of use by adding or subtracting problems. An example problem set derived from the data set is shown in Table 1.
Referencing Table 1, an example problem set for an implementation is depicted for purposes of illustration. The example problem set will depend upon the initial data set, the relevant problems represented therein, and the problem definition operations, including the utilization of site-specific problems, standardized problems, and/or combinations of these.
In embodiments, the determination of an initial knowledge base may include an annotation process for the medical data set. The annotation process may collect a set of annotated triplets (problem, relation, target). In some embodiments, annotated triplets may be determined from the previously generated problem and target lists. In some embodiments, annotated triplets may be obtained from experts by presenting experts with a problem list of candidate medication, laboratory, and procedure codes derived from the data set in relation to each problem from a list. In embodiments, annotations and triplets may be determined from user input and interactions with data from an interface.
In embodiments, annotation may be performed on a subset of triplet candidates. Subset candidates may be determined using an importance score between a problem and an associated data element such as medication, procedure, or lab, for example, as set forth in equation 1:
IMPT=log(p(xi=1|yj=1))−log(p(xi=1|yj=0)) Equation 1.Importance score
In the example of equation 1, xi is a binary variable denoting the existence of a medication, procedure, lab, or other treatment aspect (e.g., follow-up schedules, monitoring, contra-indication, etc.) occurring in an encounter record with a reported diagnosis code, and yj is a binary variable denoted the presence of a diagnosis code in the definition of problem j in an encounter record. The example importance score (IMPT) captures the increase in likelihood of a medication, procedure, lab, etc., appearing in an encounter record when a given problem is also recorded in that record. In embodiments, the top 50 or top 100 codes may be presented for annotation for each problem in a problem list. Annotators may score each problem candidate pair. Scoring may be based on a binary indication of relevance. In one embodiment, relevance may indicate that the candidate would be of interest to a physician. In embodiments, other scoring methods may be used, such as 1-10, continuous range, and the like. Positive and negative relations may be recorded and used in the knowledge base. Negative relations may indicate that a relation between a problem and target should not be present in the knowledge base.
The initial list of candidate codes may be expanded, for example, by performing a second round of annotation using a model trained on the first set. An example operation to expand the initial list of candidate codes replaces the importance score with a relation-specific scoring function (e.g., g(r)) applied to each triplet using a three-way dot product, as depicted in equation 2.
The initial knowledge base comprising annotated triples and medical data set may be processed using the knowledge base completion 406 component that may include a model. A model of the component 406 may be initialized, trained, and used to determine new relations in the initial knowledge graph.
An example operation to initialize and pre-process model (such as a neural network model), which may be a part of, or all of, training the neural network model, includes using external embeddings representing concepts from standardized sets such as RxNorm, Current Procedural Terminology (CPT) and/or Logical Observation Identifiers Names and Codes (LOINC) to initialize parameters for medication, procedure, lab codes, and/or other data elements when the embedding codes are present in the initial data set of the first knowledge base 404. Codes that are not present may be initialized randomly. To initialized problem embeddings, codes in a problem's definition may be combined. An example operation includes translating codes between coding systems (e.g., Systematized Nomenclature of Medicine (SNOMED), International Classification of Diseases (ICD)-10, and/or ICD-9), keeping codes with one-to-one mappings. Embeddings are initialized, in the example, as the weighted average of each definition code, with weights determined according to the frequency of each definition code in the initial data set. An example operation includes initializing relation embeddings to be an all-ones vector, such that the scoring function (e.g., equation 2) reduces to a dot product between the source and target embeddings.
In some cases, external embeddings may have limited efficacy on site-specific codes from an internal vocabulary. External embeddings may have limited efficacy on standardized codes that don't appear in the embeddings' vocabularies. For codes missing from the external vocabulary, embeddings may be randomly initialized. In some cases, initialization of embeddings for missing codes includes acquiring embeddings for them by training on the site data set and exploit nearest neighbors of the codes. Specifically, for each code missing from the external vocabulary, its embedding may be initialized by first finding the k nearest neighbors of the code in the site embedding space, limited to those codes that do exist in the external vocabulary. In some embodiments, k may be configurable to any number and may depend on the size and configuration of the knowledge base and/or data sets. Initialization of the embedding may further take the element-wise average of the corresponding external embeddings of those neighbor codes and use that to initialize an embedding for the missing code.
After initialization, the model (which may include the DistMult model) of the knowledge base completion component 406 may be trained using the ranking loss, which guides the model to rank true triplets higher than randomly sampled negative triplets, with a margin. In certain embodiments, the data set includes explicit negative examples that result from the annotation process. The negative examples may improve the training over random sampling from the vocabulary. Negative examples may be ranked highly according to an importance score, which may improve learning. The training set may be shuffles so that during training, each batch consists of a random selection of positive and negative examples. The model may be optimized with gradient descent. Learning rate and batch size may be tuned by pilot experiments using the validation set.
An example operation to train the model includes the relation-specific scoring function (e.g., g(r)) applied to each triplet of the initial knowledge base 404 using a three-way dot product, as depicted in equation 2:
In the example of equation 2, es is the source (problem) embedding, et is the target embedding, and d is the dimensionality of embeddings. The example of equation 2 utilizes a DistMult approach. Higher ranked triplets may indicate a true triplet
Additionally or alternatively, an example knowledge base completion 406 component trains and uses its own embeddings (e.g., site-specific embeddings) 412, allowing for greater coverage of the codes used and the possibility of including internal codes without mapping. Example training embeddings on a data set include training a skip-gram model that treats each encounter as a unit, using the entire set of codes in an encounter as context for a given code. In the example, problem embeddings are initialized using an unweighted average of definition code embeddings. Site-specific embeddings may be utilized in addition to and/or as a replacement for scored embeddings described previously.
In certain embodiments, the implementation of a problem-oriented medical record includes a significant aspect that is institution-specific. Accordingly, the neural network model learns from both concept-level information and site-level information. An example knowledge base completion 406 component builds features from the statistics of the data set 410. Example operations to build features from the statistics include counting co-occurrences of each problem/target pair in the data set and normalizing by the count of the target. An example further includes counting each occurrence once per patient. Example operations to determine that a problem/target paid has co-occurred include one or more of: determining that an explicit relation exists between the two in the data (e.g., an annotated diagnostic code corresponding to a problem definition in a record, with the target also listed in the record); determining that the problem/target appear in the same encounter; determining that the problem appears within a time window and at a same facility as the target (e.g., +/−two weeks, three days, and/or other time parameter, which may be symmetric or asymmetric for past/future determinations, and/or according to rules related to the problem and/or target); and/or determining that the problem appears within a time window of the appearance of the target, at any facility (e.g., which may be the same or a distinct time window relative to the time window at the same facility determination).
An example medical data set 408 further includes statistics and/or features 410 for the medical data set 408, for example, including data relations, co-occurrence counts (e.g., for problems, medications, diagnoses, etc.), and/or timing of co-occurrences (e.g., time windows before and/or after a treatment, whereby the occurrence of a problem is considered to be a co-occurrence).
Example operations of the knowledge base completion 406 component include using the vectors of features constructed from the data set, which may further include adjusting the scoring function. For example, referencing equation 3, a similar bilinear term is utilized to combine the specialty feature vectors for problem and target, using a separate set of relational parameters. Referencing equation 4, other features f(s,t) are concatenated with the scores from embeddings and specialty feature vectors to determine a final score. In the example of equation 3, the v values represent the feature vectors, where vr
Referencing
The example apparatus 500 includes a problem list 506, for example stored data maintaining a list of problems to be included as organizing concepts for problem-oriented record(s) 502, such as problems defined during a training operation, problems added by a user through a user interface, and/or new problems determined automatically analyzing the second knowledge base 402 and/or the medical data set 408. The example apparatus 500 includes a record processor component 508 that processes the second knowledge base 402 to provide an output, for example, to an insurer, a medical provider, and/or a recipient (e.g., a patient, referral, administrator, relative, etc.). An example record processor component 508 generates a patient problem list (e.g., problems occurring within a patient group, and/or a count or frequency of problems occurring within the patient group) and/or a related medical element list (e.g., treatments, medicines, procedures, etc., as reflected by the problems list). An example record processor component 508 further receives a patient medical record 510 and provides a problem-oriented record 502 (e.g., as a problem-oriented view of the medical record 510). Providing the problem-oriented record 502 includes one or more of storing the problem-oriented record 502 associated with the patient for selective access; providing a visualization, table, or other viewable data element to a user device (e.g., a display screen associated with a medical provider, insurance provider, patient record access, or the like); and/or aggregating the problem-oriented record 502 based on patient medical records 510 for a group of patients.
An example co-occurrence of the data elements (e.g., statistics 410) includes determining a normalized count of co-occurrences among the data elements. An example co-occurrence of the data elements (e.g., statistics 410) includes determining a count of co-occurrences within a time frame represented by data elements in the medical data set 408. In certain embodiments, the example modeling component 504 constructs more than one second knowledge base 402, for example, constructing more than one knowledge base, each having a distinct vocabulary. An example operation to train the neural network model includes training on negative examples in the first knowledge base 404.
An example modeling component 504 determines embeddings from the medical data set 408 and initializes the neural network model based on the embeddings. An example modeling component 504 further determines missing vocabulary in the embeddings, determines neighbors of the missing vocabulary in second embeddings, calculates element-wise average value(s) of the neighbors, and adds missing vocabulary to the embeddings, where the added missing vocabulary is initialized with the calculated average value(s).
Referencing
Referencing
Referencing
Referencing
Referencing
Referencing
Referencing
The example system 1200 includes a trained model 1210 component, for example, that stores and/or accesses a trained neural network model that is operated to provide an updated knowledge base and/or determine a POMR. The example system 1200 includes record processor 1212 component that accesses records (e.g., patient records 1216, the medical data set 1222, provider records (not shown), a site-specific data set (not shown), and/or any other records utilized throughout the present disclosure). In certain embodiments, the record processor 1212 controls access and/or permissions to records and/or provides requested records that are selectively processed (e.g., anonymized, time-shifted, or the like). The example system 1200 includes a feature extractor 1214 component configured to extract features as described throughout the present disclosure, including at least in
In embodiments, annotated triplets (such as those used to create an initial knowledge base 404) may be split into training, validation, and test sets. An example split includes dividing the annotated triplets at random, with a majority of the annotated triplets forming the training set (e.g., >50%, 70%, etc.) and with the remainder of the annotated triplets divided between validation and test data sets. Example operations include training the neural network model using the ranking loss which guides the model to rank true triplets higher than randomly sampled negative triplets, with a margin. In certain embodiments, the data set includes explicit negative examples that result from the annotation process, which improves the training over random sampling from the vocabulary. The validation set may be utilized to tune the learning rate and batch size with pilot experiments.
In embodiments, rank loss may be computed using any number of functions. One example of determining ranking loss is shown in equation 5, where T is the set of positive annotated examples and T′ is the set of negative annotated examples.
Inference includes scoring each triplet (source, relation, target) in the validation set, along with all negative triplets in the validation set having the same problem and relation type. Example metrics computed include the mean ranking (MR) of the true triplet among the set, the mean reciprocal rank (MRR), a first hit frequency (e.g., Hits @ 10, or frequency of the true triplet appearing in the top 10), and/or a second hit frequency (e.g., Hits @ 30, or frequency of the true triplet appearing in the top 30).
Referencing Table 2, example validation data is depicted, providing an illustration of model performance for predicting randomly held-out triplets (e.g., a portion of the medical data set 408 reserved for validation), and/or new data separate from the training data. The table lists externally-trained embeddings and site-specific embeddings trained according to embodiments herein. The table also lists an “Ontology baseline” that combines results from National Drug File Reference Terminology (NDF-RT) and CPT heuristics for medications and procedures (respectively). The set of negatives for the example includes all annotated negatives for a given problem and relation type, but the negatives in the held-out triples are a smaller, random sample of all negative for the problem-relation type pair. Accordingly, results of the trained data set and the held-out triples are not directly comparable. The (Frozen) results are according to the initialized embeddings without any training. It can be seen that the site-specific embeddings lag the externally trained embeddings for the Frozen results. Results are also depicted for relation embeddings, for combined relation and target embeddings, and for combined relation, target, and feature embeddings. The example of Table 2, or similar data for embodiments, provides for evaluation of how performance is developed from aspects of the trained model. In the example of Table 2, the gain from training for site-specific embeddings is larger than the gain for external embeddings. The example of Table 2 suggests that improvements are contributed by the relation parameters and that the addition of engineered features (emphasized in bold on Table 2) provides a strong boost to performance, with comparable performance from the site-specific embeddings relative to the external embeddings.
External +
9.2
0.461
0.353
0.525
0.442
0.676
0.605
0.754
Features
Site-
10.5
0.406
0.300
0.425
0.388
0.459
0.548
0.692
specific +
Features
Some medical problems are more strongly related with some types of entities. For example, urinary tract infection (UTI) is strongly associated with urinalysis and particular antibiotic medications, but there is not a routinely performed procedure for this common condition. Referencing Table 3, an example performance break-down on the test set is depicted by problem, e.g., to help analyze results in this light. Poor performance in sleep apnea medications may not be important, as there are few medications that directly treat that problem. In designing the POMR, it is not expected that every problem would always have associated labs, medications, and procedures, and performing analyses such as that depicted in Table 3 could be used to decide which suggested elements to turn on.
Referencing
Referencing Table 4, an example suggestion set for an implementation is depicted for purposes of illustration. The example suggestion set includes medications, procedures, and/or lab tests according to a trained model, for example, using the 10 highest scoring medications, procedures, and/or lab tests corresponding to the example problem (e.g., “UTI” in the example of Table 1). In the examples of Tables 4-7, the medications, procedures, and labs are depicted separately (e.g., the third-highest suggested medication does not have a specific relationship to the third-highest suggested procedure), and the number of presented suggestions are illustrative, and a different number of presented suggestions may be utilized, and/or the number of suggested medications, procedures, and/or labs may be distinct from each other. The examples of Tables 4-7 depict suggested medication, procedures, and/or labs, but may additionally or alternatively include any other data elements 106, such as follow-up schedules, monitoring schedules, dietary recommendations, and/or any other data elements of interest.
Referencing Table 5, an example suggestion set for an implementation is depicted for purposes of illustration. The example suggestion set includes medications, procedures, and/or lab tests according to a trained model, for example, using the 10 highest scoring medications, procedures, and/or lab tests corresponding to the example problem (e.g., “Hypokalemia” in the example of Table 1).
Referencing Table 6, an example suggestion set for an implementation is depicted for purposes of illustration. The example suggestion set includes medications, procedures, and/or lab tests according to a trained model, for example, using the 10 highest scoring medications, procedures, and/or lab tests corresponding to the example problem (e.g., “Thrombocytopenia” in the example of Table 1).
Referencing Table 7, an example suggestion set for an implementation is depicted for purposes of illustration. The example suggestion set includes medications, procedures, and/or lab tests according to a trained model, for example, using the 10 highest scoring medications, procedures, and/or lab tests corresponding to the example problem (e.g., “Sleep apnea” in the example of Table 1).
The methods and systems described herein may be deployed in part or in whole through a machine that executes computer software, program codes, and/or instructions on a processor. “Processor” as used herein is meant to include at least one processor and unless context clearly indicates otherwise, the plural and the singular should be understood to be interchangeable. Any aspects of the present disclosure may be implemented as a computer-implemented method on the machine, as a system or apparatus as part of or in relation to the machine, or as a computer program product embodied in a computer readable medium executing on one or more of the machines. The processor may be part of a server, client, network infrastructure, mobile computing platform, stationary computing platform, or other computing platform. A processor may be any kind of computational or processing device capable of executing program instructions, codes, binary instructions and the like. The processor may be or include a signal processor, digital processor, embedded processor, microprocessor or any variant such as a co-processor (math co-processor, graphic co-processor, communication co-processor and the like) and the like that may directly or indirectly facilitate execution of program code or program instructions stored thereon. In addition, the processor may enable execution of multiple programs, threads, and codes. The threads may be executed simultaneously to enhance the performance of the processor and to facilitate simultaneous operations of the application. By way of implementation, methods, program codes, program instructions and the like described herein may be implemented in one or more thread. The thread may spawn other threads that may have assigned priorities associated with them; the processor may execute these threads based on priority or any other order based on instructions provided in the program code. The processor may include memory that stores methods, codes, instructions and programs as described herein and elsewhere. The processor may access a storage medium through an interface that may store methods, codes, and instructions as described herein and elsewhere. The storage medium associated with the processor for storing methods, programs, codes, program instructions or other type of instructions capable of being executed by the computing or processing device may include but may not be limited to one or more of a CD-ROM, DVD, memory, hard disk, flash drive, RAM, ROM, cache and the like.
A processor may include one or more cores that may enhance speed and performance of a multiprocessor. In embodiments, the process may be a dual core processor, quad core processors, other chip-level multiprocessor and the like that combine two or more independent cores (called a die).
The methods and systems described herein may be deployed in part or in whole through a machine that executes computer software on a server, client, firewall, gateway, hub, router, or other such computer and/or networking hardware. The software program may be associated with a server that may include a file server, print server, domain server, internet server, intranet server and other variants such as secondary server, host server, distributed server and the like. The server may include one or more of memories, processors, computer readable media, storage media, ports (physical and virtual), communication devices, and interfaces capable of accessing other servers, clients, machines, and devices through a wired or a wireless medium, and the like. The methods, programs, or codes as described herein and elsewhere may be executed by the server. In addition, other devices required for execution of methods as described in this application may be considered as a part of the infrastructure associated with the server.
The server may provide an interface to other devices including, without limitation, clients, other servers, printers, database servers, print servers, file servers, communication servers, distributed servers and the like. Additionally, this coupling and/or connection may facilitate remote execution of program across the network. The networking of some or all of these devices may facilitate parallel processing of a program or method at one or more locations without deviating from the scope of the disclosure. In addition, any of the devices attached to the server through an interface may include at least one storage medium capable of storing methods, programs, code and/or instructions. A central repository may provide program instructions to be executed on different devices. In this implementation, the remote repository may act as a storage medium for program code, instructions, and programs.
The software program may be associated with a client that may include a file client, print client, domain client, internet client, intranet client and other variants such as secondary client, host client, distributed client and the like. The client may include one or more of memories, processors, computer readable media, storage media, ports (physical and virtual), communication devices, and interfaces capable of accessing other clients, servers, machines, and devices through a wired or a wireless medium, and the like. The methods, programs, or codes as described herein and elsewhere may be executed by the client. In addition, other devices required for execution of methods as described in this application may be considered as a part of the infrastructure associated with the client.
The client may provide an interface to other devices including, without limitation, servers, other clients, printers, database servers, print servers, file servers, communication servers, distributed servers and the like. Additionally, this coupling and/or connection may facilitate remote execution of program across the network. The networking of some or all of these devices may facilitate parallel processing of a program or method at one or more locations without deviating from the scope of the disclosure. In addition, any of the devices attached to the client through an interface may include at least one storage medium capable of storing methods, programs, applications, code and/or instructions. A central repository may provide program instructions to be executed on different devices. In this implementation, the remote repository may act as a storage medium for program code, instructions, and programs.
The methods and systems described herein may be deployed in part or in whole through network infrastructures. The network infrastructure may include elements such as computing devices, servers, routers, hubs, firewalls, clients, personal computers, communication devices, routing devices and other active and passive devices, modules and/or components as known in the art. The computing and/or non-computing device(s) associated with the network infrastructure may include, apart from other components, a storage medium such as flash memory, buffer, stack, RAM, ROM and the like. The processes, methods, program codes, instructions described herein and elsewhere may be executed by one or more of the network infrastructural elements.
The methods, program codes, and instructions described herein and elsewhere may be implemented on a cellular network having multiple cells. The cellular network may either be frequency division multiple access (FDMA) network or code division multiple access (CDMA) network. The cellular network may include mobile devices, cell sites, base stations, repeaters, antennas, towers, and the like. The cell network may be a GSM, GPRS, 3G, EVDO, mesh, or other networks types.
The methods, programs codes, and instructions described herein and elsewhere may be implemented on or through mobile devices. The mobile devices may include navigation devices, cell phones, mobile phones, mobile personal digital assistants, laptops, palmtops, netbooks, pagers, electronic books readers, music players and the like. These devices may include, apart from other components, a storage medium such as a flash memory, buffer, RAM, ROM and one or more computing devices. The computing devices associated with mobile devices may be enabled to execute program codes, methods, and instructions stored thereon. Alternatively, the mobile devices may be configured to execute instructions in collaboration with other devices. The mobile devices may communicate with base stations interfaced with servers and configured to execute program codes. The mobile devices may communicate on a peer-to-peer network, mesh network, or other communications network. The program code may be stored on the storage medium associated with the server and executed by a computing device embedded within the server. The base station may include a computing device and a storage medium. The storage device may store program codes and instructions executed by the computing devices associated with the base station.
The computer software, program codes, and/or instructions may be stored and/or accessed on machine readable media that may include: computer components, devices, and recording media that retain digital data used for computing for some interval of time; semiconductor storage known as random access memory (RAM); mass storage typically for more permanent storage, such as optical discs, forms of magnetic storage like hard disks, tapes, drums, cards and other types; processor registers, cache memory, volatile memory, non-volatile memory; optical storage such as CD, DVD; removable media such as flash memory (e.g. USB sticks or keys), floppy disks, magnetic tape, paper tape, punch cards, standalone RAM disks, Zip drives, removable mass storage, off-line, and the like; other computer memory such as dynamic memory, static memory, read/write storage, mutable storage, read only, random access, sequential access, location addressable, file addressable, content addressable, network attached storage, storage area network, bar codes, magnetic ink, and the like.
The methods and systems described herein may transform physical and/or or intangible items from one state to another. The methods and systems described herein may also transform data representing physical and/or intangible items from one state to another.
The elements described and depicted herein, including in flow charts and block diagrams throughout the figures, imply logical boundaries between the elements. However, according to software or hardware engineering practices, the depicted elements and the functions thereof may be implemented on machines through computer executable media having a processor capable of executing program instructions stored thereon as a monolithic software structure, as standalone software modules, or as modules that employ external routines, code, services, and so forth, or any combination of these, and all such implementations may be within the scope of the present disclosure. Examples of such machines may include, but may not be limited to, personal digital assistants, laptops, personal computers, mobile phones, other handheld computing devices, medical equipment, wired or wireless communication devices, transducers, chips, calculators, satellites, tablet PCs, electronic books, gadgets, electronic devices, devices having artificial intelligence, computing devices, networking equipment, servers, routers and the like. Furthermore, the elements depicted in the flow chart and block diagrams or any other logical component may be implemented on a machine capable of executing program instructions. Thus, while the foregoing drawings and descriptions set forth functional aspects of the disclosed systems, no particular arrangement of software for implementing these functional aspects should be inferred from these descriptions unless explicitly stated or otherwise clear from the context. Similarly, it will be appreciated that the various steps identified and described above may be varied, and that the order of steps may be adapted to particular applications of the techniques disclosed herein. All such variations and modifications are intended to fall within the scope of this disclosure. As such, the depiction and/or description of an order for various steps should not be understood to require a particular order of execution for those steps, unless required by a particular application, or explicitly stated or otherwise clear from the context.
The methods and/or processes described above, and steps thereof, may be realized in hardware, software or any combination of hardware and software suitable for a particular application. The hardware may include a general-purpose computer and/or dedicated computing device or specific computing device or particular aspect or component of a specific computing device. The processes may be realized in one or more microprocessors, microcontrollers, embedded microcontrollers, programmable digital signal processors or other programmable device, along with internal and/or external memory. The processes may also, or instead, be embodied in an application specific integrated circuit, a programmable gate array, programmable array logic, or any other device or combination of devices that may be configured to process electronic signals. It will further be appreciated that one or more of the processes may be realized as a computer executable code capable of being executed on a machine-readable medium.
The computer executable code may be created using a structured programming language such as C, an object oriented programming language such as C++, or any other high-level or low-level programming language (including assembly languages, hardware description languages, and database programming languages and technologies) that may be stored, compiled or interpreted to run on one of the above devices, as well as heterogeneous combinations of processors, processor architectures, or combinations of different hardware and software, or any other machine capable of executing program instructions.
Thus, in one aspect, each method described above and combinations thereof may be embodied in computer executable code that, when executing on one or more computing devices, performs the steps thereof. In another aspect, the methods may be embodied in systems that perform the steps thereof, and may be distributed across devices in a number of ways, or all of the functionality may be integrated into a dedicated, standalone device or other hardware. In another aspect, the means for performing the steps associated with the processes described above may include any of the hardware and/or software described above. All such permutations and combinations are intended to fall within the scope of the present disclosure.
While the invention has been disclosed in connection with the preferred embodiments shown and described in detail, various modifications and improvements thereon will become readily apparent to those skilled in the art. Accordingly, the spirit and scope of the present invention is not to be limited by the foregoing examples, but is to be understood in the broadest sense allowable by law.
All documents referenced herein are hereby incorporated by reference in the entirety.
This patent application claims the benefit of U.S. Patent Application Ser. No. 63/004,914, filed Apr. 3, 2020, and entitled “KNOWLEDGE-BASE COMPLETION FOR CONSTRUCTING PROBLEM-ORIENTED MEDICAL RECORDS” (ASAP-0029-P01). The content of the foregoing application is hereby incorporated by reference in its entirety for all purposes.
Number | Date | Country | |
---|---|---|---|
63004914 | Apr 2020 | US |