Causal inference is an important and active field in both academia and industry. Causal inference identifies causes, measures their effects, and directs policy making. Since randomized controlled trials are often expensive or even impossible, the causal effect may be estimated from observational data. There are several technical difficulties to do so, especially in the big-data world. For example, there may be a large number of potential covariates; there may be unknown nonlinear relationships between those covariates and an outcome variable and a treatment variable, and the variables may be discrete, continuous, or mixed.
Here, the outcome variables are a result of interest, and the treatment variables are a possible cause that describes the action, the intervention, or the treatment assignment. The other variables describe characteristics of the object of interest (such as a patient, customer, store, etc.) or the situation and context. The outcome variables or treatment variables may be a vector of variables, although in most real-world cases, they are scalars. The causal effect, also known as the treatment effect, is the effect of the treatment variables on the outcome variables.
For example, in the process of studying the effect of a new medicine on a patient, the outcome is the final health status of the patient, and the treatment is whether to assign the medicine to the patient and what dosage to assign. For any individual, the outcome is only observed for the treatment value chosen, but not the outcome at any other treatment value. What if a different treatment value was provided to the individual? Would the outcome be better? Such a what-if outcome can never be directly observed. For observational data, the covariates might affect both outcome and treatment, introducing a selection bias. To correct the selection bias, both the treatment model (the relationship between the treatment and the covariates) and the outcome model (the relationship between the outcome and the treatment and covariates) are modeled, and various methods are used to define a debiased estimator. What is missing is a confidence interval of the estimator to indicate a confidence in the chosen treatment and associated outcome.
In an example embodiment, a computer-readable medium is provided having stored thereon computer-readable instructions that when executed by a computing device, cause the computing device to compute a standard error of an estimator determined by training a machine learning model. A treatment model trained to compute an estimated treatment variable value for each observation vector of a plurality of observation vectors is executed. Each observation vector includes covariate variable values for a plurality of covariate variables, a treatment variable value for a treatment variable, and an outcome variable value for an outcome variable. An outcome model trained to compute an estimated outcome value for each observation vector of the plurality of observation vectors using the treatment variable value for each observation vector of the plurality of observation vectors is executed. A standard error value associated with the outcome model is computed using a first variance value computed using the treatment variable value of the plurality of observation vectors, using a second variance value computed using the treatment variable value and the estimated treatment variable value of the plurality of observation vectors, and using a third variance value computed using the estimated outcome value of the plurality of observation vectors. The computed standard error value is output.
In another example embodiment, a computing device is provided. The computing device includes, but is not limited to, a processor and a computer-readable medium operably coupled to the processor. The computer-readable medium has instructions stored thereon that, when executed by the processor, cause the computing device to compute a standard error of an estimator determined by training a machine learning model.
In yet another example embodiment, a method of computing a standard error of an estimator determined by training a machine learning model is provided.
Other principal features of the disclosed subject matter will become apparent to those skilled in the art upon review of the following drawings, the detailed description, and the appended claims.
The patent or application file contains at least one drawing executed in color. Copies of this patent or patent application publication with color drawing(s) will be provided by the Office upon request and payment of the necessary fee.
Illustrative embodiments of the disclosed subject matter will hereafter be described referring to the accompanying drawings, wherein like numerals denote like elements.
Causal effects may be estimated through the observational data, for example, captured in an input dataset 124 (shown referring to
In a paper by M. H. Farrell, et al. titled Deep Learning for Individual Heterogeneity: An Automatic Inference Framework and published in 2021 (Farrell) and in U.S. Pat. No. 11,354,566 that issued Jun. 7, 2022, a semi-parametric framework based on Deep Neural Networks is used. The debiasing process includes Influence Functions, which require that the outcome model be in the form: G(α(x)+β(x)t), where G(.) is any known function, and α(.) and β(.) can be in any unknown form. This semi-parametric framework handles high dimensional covariates and a mixture of continuous and discrete variables well. If the treatment is binary, the unknown function forms g(.) and ƒ(.) may be highly nonlinear, but the semi-parametric framework handles this since for any function form ƒ(x,t), ƒ(x, t) can be expressed as G(α(x)+β(x)t). However, when the treatment is multi-valued, or continuous, or count, the semi-parametric framework based on Deep Neural Networks cannot handle highly nonlinear function forms g(.) and ƒ(.), which means there is a risk of misspecification. The restrictive form G(α(x)+β(x)t) cannot express the true unknown form ƒ(x, t). For continuous treatment variables, a paper by Kyle Colangelo and Ying-Ying Lee titled Double Debiased Machine Learning Nonparametric Inference with Continuous Treatments and published in 2022 (the Colangelo paper) proposed a non-parametric framework to deal with this challenge, but a 95% confidence interval of the estimator only covers about 23% of the true values meaning the confidence interval is not trustworthy. A training application 122 (shown referring to
As discussed previously, when the treatment variable is binary, the semi-parametric framework can be directly used as a “nonparametric” framework, since no assumption of model specification is needed. When the treatment variable is multi-valued, the treatment variable can be levelized. The treatment variable can take K different values assumed as t=0, . . . , K−1. A vector (K−1) by 1 vector can be constructed such that =0K-1 corresponds to t=0, and =ei corresponds to t=i, i=1, . . . , K−1, where 0K-1 is a (K−1) by 1 vector of zeros, and ei is a (K−1) by 1 unit vector with the ith element as one and the remaining elements as zero. Then, G(α(x)+β(x)′) can express any form of outcome model ƒ(x, t), so that the semi-parametric framework can be used as a “nonparametric” framework without any model-specification assumption. For debiasing when the treatment variable is continuous or count, an inverse probability of treatment weighting (IPTW) as described in a paper by Nicholas C. Chesnaye, et al. titled An Introduction to Inverse Probability of Treatment Weighting in Observational Research and published in 2021 may be applied.
Referring to
Input interface 102 provides an interface for receiving information from the user or another device for entry into model training device 100 as understood by those skilled in the art. Input interface 102 may interface with various input technologies including, but not limited to, a keyboard 112, a microphone 113, a mouse 114, a display 116, a track ball, a keypad, one or more buttons, etc. to allow the user to enter information into model training device 100 or to make selections presented in a user interface displayed on display 116.
The same interface may support both input interface 102 and output interface 104. For example, display 116 comprising a touch screen provides a mechanism for user input and for presentation of output to the user. Model training device 100 may have one or more input interfaces that use the same or a different input interface technology. The input interface technology further may be accessible by model training device 100 through communication interface 106.
Output interface 104 provides an interface for outputting information for review by a user of model training device 100 and/or for use by another application or device. For example, output interface 104 may interface with various output technologies including, but not limited to, display 116, a speaker 118, a printer 120, etc. Model training device 100 may have one or more output interfaces that use the same or a different output interface technology. The output interface technology further may be accessible by model training device 100 through communication interface 106.
Communication interface 106 provides an interface for receiving and transmitting data between devices using various protocols, transmission technologies, and media as understood by those skilled in the art. Communication interface 106 may support communication using various transmission media that may be wired and/or wireless. Model training device 100 may have one or more communication interfaces that use the same or a different communication interface technology. For example, model training device 100 may support communication using an Ethernet port, a Bluetooth antenna, a telephone jack, a USB port, etc. Data and/or messages may be transferred between model training device 100 and another computing device of a distributed computing system 130 using communication interface 106.
Computer-readable medium 108 is a non-transitory electronic holding place or storage for information so the information can be accessed by processor 110 as understood by those skilled in the art. Computer-readable medium 108 can include, but is not limited to, any type of random access memory (RAM), any type of read only memory (ROM), any type of flash memory, etc. such as magnetic storage devices (e.g., hard disk, floppy disk, magnetic strips, . . . ), optical disks (e.g., compact disc (CD), digital versatile disc (DVD), . . . ), smart cards, flash memory devices, etc. Model training device 100 may have one or more computer-readable media that use the same or a different memory media technology. For example, computer-readable medium 108 may include different types of computer-readable media that may be organized hierarchically to provide efficient access to the data stored therein as understood by a person of skill in the art. As an example, a cache may be implemented in a smaller, faster memory that stores copies of data from the most frequently/recently accessed main memory locations to reduce an access latency. Model training device 100 also may have one or more drives that support the loading of a memory media such as a CD, DVD, an external hard drive, etc. One or more external hard drives further may be connected to model training device 100 using communication interface 106.
Processor 110 executes instructions as understood by those skilled in the art. The instructions may be carried out by a special purpose computer, logic circuits, or hardware circuits. Processor 110 may be implemented in hardware and/or firmware. Processor 110 executes an instruction, meaning it performs/controls the operations called for by that instruction. The term “execution” is the process of running an application or the carrying out of the operation called for by an instruction. The instructions may be written using one or more programming languages, scripting languages, assembly languages, etc. Processor 110 operably couples with input interface 102, with output interface 104, with communication interface 106, and with computer-readable medium 108 to receive, to send, and to process information. Processor 110 may retrieve a set of instructions from a permanent memory device and copy the instructions in an executable form to a temporary memory device that is generally some form of RAM. Model training device 100 may include a plurality of processors that use the same or a different processing technology.
Some machine-learning approaches may be more efficiently and speedily executed and processed with machine-learning specific processors (e.g., not a generic central processing unit (CPU)). Such processors may also provide additional energy savings when compared to generic CPUs. For example, some of these processors can include a graphical processing unit, an application-specific integrated circuit, a field-programmable gate array, an artificial intelligence accelerator, a purpose-built chip architecture for machine learning, and/or some other machine-learning specific processor that implements a machine learning approach using semiconductor (e.g., silicon, gallium arsenide) devices. These processors may also be employed in heterogeneous computing architectures with a number of and a variety of different types of cores, engines, nodes, and/or layers to achieve additional various energy efficiencies, processing speed improvements, data communication speed improvements, and/or data efficiency targets and improvements throughout various parts of the system.
Training application 122 performs operations associated with defining trained model description 126 from data stored in input dataset 124. Trained model description 126 may be used to predict a treatment value for data stored in a second dataset 824 (shown referring to
Referring to the example embodiment of
Training application 122 may be implemented as a Web application. For example, training application 122 may be configured to receive hypertext transport protocol (HTTP) responses and to send HTTP requests. The HTTP responses may include web pages such as hypertext markup language (HTML) documents and linked objects generated in response to the HTTP requests. Each web page may be identified by a uniform resource locator (URL) that includes the location or address of the computing device that contains the resource to be accessed in addition to the location of the resource on that computing device. The type of file or resource depends on the Internet application protocol such as the file transfer protocol, HTTP, H.323, etc. The file accessed may be a simple text file, an image file, an audio file, a video file, an executable, a common gateway interface application, a Java applet, an extensible markup language (XML) file, or any other type of file supported by HTTP.
Input dataset 124 may include, for example, a plurality of rows and a plurality of columns. The plurality of rows may be referred to as observation vectors or records (observations), and the columns may be referred to as variables. In an alternative embodiment, input dataset 124 may be transposed. The plurality of variables defines a vector x; for each observation vector i=1, 2, . . . , N, where N is a number of the observation vectors included in input dataset 124. Input dataset 124 may include additional variables that are not included in the plurality of variables. One or more variables of the plurality of variables may describe a characteristic of a physical object. For example, if input dataset 124 includes data related to operation of a vehicle, the variables may include a type of vehicle, an oil pressure, a speed, a gear indicator, a gas tank level, a tire pressure for each tire, an engine temperature, a radiator level, etc. The plurality of variables may include a plurality of covariates from which a first set of covariates x(1) may be selected from the plurality of covariates to train a treatment model, and a second set of covariates x(2) may be selected from the plurality of covariates to train an outcome model. The plurality of variables further includes a treatment variable and an outcome variable.
In data science, engineering, and statistical applications, data often consists of multiple measurements (across sensors, characteristics, responses, etc.) collected across multiple time instances (patients, test subjects, etc.). These measurements may be collected in input dataset 124 for analysis and processing or streamed to model training device 100 as it is generated. Input dataset 124 may include data captured as a function of time for one or more physical objects. The data stored in input dataset 124 may be captured at different time points periodically, intermittently, when an event occurs, etc. Input dataset 124 may include data captured at a high data rate such as 200 or more observation vectors per second for one or more physical objects. One or more columns of input dataset 124 may include a time and/or date value. Input dataset 124 may include data captured under normal and abnormal operating conditions of the physical object.
The data stored in input dataset 124 may be received directly or indirectly from the source and may or may not be pre-processed in some manner. For example, the data may be pre-processed using an event stream processor such as the SAS® Event Stream Processing Engine (ESPE), developed and provided by SAS Institute Inc. of Cary, North Carolina, USA. For example, data stored in input dataset 124 may be generated as part of the Internet of Things (IoT), where things (e.g., machines, devices, phones, sensors) can be connected to networks and the data from these things collected and processed within the things and/or external to the things before being stored in input dataset 124. For example, the IoT can include sensors in many different devices and types of devices, and high value analytics can be applied to identify hidden relationships and drive increased efficiencies. This can apply to both big data analytics and real-time analytics. Some of these devices may be referred to as edge devices and may involve edge computing circuitry. These devices may provide a variety of stored or generated data, such as network data or data specific to the network devices themselves. Again, some data may be processed with an ESPE, which may reside in the cloud or in an edge device before being stored in input dataset 124.
The data stored in input dataset 124 may include any type of content represented in any computer-readable format such as binary, alphanumeric, numeric, string, markup language, etc. The content may include textual information, graphical information, image information, audio information, numeric information, etc. that further may be encoded using various encoding techniques as understood by a person of skill in the art.
Input dataset 124 may be stored on computer-readable medium 108 or on one or more computer-readable media of distributed computing system 130 and accessed by model training device 100 using communication interface 106, input interface 102, and/or output interface 104. Input dataset 124 may be stored in various compressed formats such as a coordinate format, a compressed sparse column format, a compressed sparse row format, etc. The data may be organized using delimited fields, such as comma or space separated fields, fixed width fields, using a SAS® dataset, etc. The SAS dataset may be a SAS® file stored in a SAS® library that a SAS® software tool creates and processes. The SAS dataset contains data values that are organized as a table of observation vectors (rows) and variables (columns) that can be processed by one or more SAS software tools.
Input dataset 124 may be stored using various data structures as known to those skilled in the art including one or more files of a file system, a relational database, one or more tables of a system of tables, a structured query language database, etc. on model training device 100 or on distributed computing system 130. Model training device 100 may coordinate access to input dataset 124 that is distributed across distributed computing system 130 that may include one or more computing devices. For example, input dataset 124 may be stored in a cube distributed across a grid of computers as understood by a person of skill in the art. As another example, input dataset 124 may be stored in a multi-node Hadoop® cluster. For instance, Apache™ Hadoop® is an open-source software framework for distributed computing supported by the Apache Software Foundation. As another example, input dataset 124 may be stored in a cloud of computers and accessed using cloud computing technologies, as understood by a person of skill in the art. The SAS® LASR™ Analytic Server may be used as an analytic platform to enable multiple users to concurrently access data stored in input dataset 124. The SAS Viya open, cloud-ready, in-memory architecture also may be used as an analytic platform to enable multiple users to concurrently access data stored in input dataset 124. SAS CAS may be used as an analytic server with associated cloud services in SAS Viya. Some systems may use SAS In-Memory Statistics for Hadoop® to read big data once and analyze it several times by persisting it in-memory for the entire session. Some systems may be of other types and configurations.
Referring to
In an operation 200, a first indicator may be received that indicates input dataset 124. For example, the first indicator indicates a location and a name of input dataset 124. As an example, the first indicator may be received by training application 122 after selection from a user interface window or after entry by a user into a user interface window. In an alternative embodiment, input dataset 124 may not be selectable. For example, a most recently created dataset may be used automatically. As understood by a person of skill in the art, input dataset 124 may be partitioned or otherwise divided into training, validation, and/or test datasets as part of training a neural network model and executing the trained neural network model to compute a performance score.
In an operation 202, a second indicator may be received that indicates a plurality of variables or features to include in training a model, such as a neural network model, using input dataset 124. For example, the second indicator may indicate a column number(s) or a column name(s) used to define each of the first set of covariates x(1), the second set of covariates x(2), the treatment variable t, and the outcome variable y.
In an operation 204, a third indicator may be received for a treatment model. The treatment model may be any machine learning model. For example, the third indicator indicates a name of a treatment model type for the treatment model that performs prediction such as determining a predicted treatment or action to take for each observation vector of input dataset 124. The third indicator may be received by training application 122 from a user interface window or after entry by a user into a user interface window. A default value for the treatment model type may further be stored, for example, in computer-readable medium 108. As an example, the treatment model type may be selected from “SVM”, “K-Cluster”, “Neural Network”, “Logistic Regression”, “Forest”, “Gradient Boosting”, “Decision Tree”, “Factorization Machine”, “Deep Neural Network”, “Bayesian Deep Neural Network”, etc. The model type indicated by “SVM” may refer to a support vector machine (SVM) model type. The model type indicated by “K-Cluster” may refer to a k-means clustering model type. The model type indicated by “Neural Network” may refer to a neural network model type. The model type indicated by “Logistic Regression” may refer to a logistic regression model type. The model type indicated by “Forest” may refer to a random forest model type. The model type indicated by “Gradient Boosting” may refer to a gradient boosting model type. The model type indicated by “Decision Tree” may refer to a decision tree model type. The model type indicated by “Factorization Machine” may refer to a factorization machine model type. The model type indicated by “Deep Neural Network” may refer to a deep neural network (DNN) machine model type. The model type indicated by “Bayesian Deep Neural Network” may refer to a Bayesian DNN machine model type. For example, a default model type may be indicated by “Deep Neural Network”. Of course, the model type may be labeled or selected in a variety of different manners by the user as understood by a person of skill in the art. In an alternative embodiment, the model type may not be selectable, and a single model type is implemented by model training application 122. For example, the model type indicated as “Deep Neural Network” may be used by default or without allowing a selection. The model types “SVM”, “K-Cluster”, “Neural Network”, “Logistic Regression”, “Forest”, “Gradient Boosting”, “Decision Tree”, “Factorization Machine”, “Deep Neural Network”, and “Bayesian Deep Neural Network” may be trained and scored using machine learning software from SAS Institute Inc. of Cary, NC, USA.
The third indicator may further indicate one or more hyperparameters to use for training and validating the indicated model type and/or values for an automatic tuning method (autotune option) as well as other training options such an objective function, training stop criteria, etc. For illustration, an automatic tuning process is described in U.S. Pat. Nos. 10,360,517; 10,600,005; 10,832,174; and 11,093,833. Hyperparameters define values or various options that govern a training process based on the model type. The default values of these hyperparameters may not be suitable for all applications. To reduce the effort in adjusting these hyperparameters, an automatic tuning process may be used to identify the best settings for the hyperparameters though the hyperparameters may optionally be selected as an input option by a user.
For illustration, the treatment model may be trained to regress t on x(1) to estimate £ for each observation vector using a DNN such that {circumflex over (t)}=ĝDNN(x(1)). A default value for the DNN architecture may further be stored, for example, in computer-readable medium 108. For the treatment model, a negative log likelihood function is an illustrative loss function though other loss functions may be indicated or otherwise used. For illustration, the architecture defines a plurality of layers and their connectivity including a type of each layer. Illustrative layers include an input layer, a convolution layer, a rectified linear activation function (ReLU) layer, a pooling layer, an output layer, etc. A ReLU layer is a piecewise linear function that outputs the input directly if it is positive, and outputs zero otherwise. One or more hyperparameters may be defined for each layer that may vary based on a type of each layer. For example, an activation function, a number of neurons, a number of groups, a dropout rate, a height and/or a width of a convolution window, a number of filters, an initialization method for filter weights, width and height padding dimensions, a number of categories or labels or unique values of the target variable value, such as ti, a detection threshold, etc. may be defined as hyperparameters for training the neural network.
A deep learning action set provided as part of SAS® Viya may be used to build the treatment model and add layers to the treatment model. In general, the treatment model includes an input layer that provides x(1) to hidden layers with the same or a different number of nodes on each hidden layer. A last layer of the hidden layers provides input to an output layer that computes a predicted treatment value when the treatment variable is of the continuous or count type or a predicted probability of assigning the treatment or different treatment categorical values when the treatment variable is of the binary or discrete type.
In an operation 206, a fourth indicator may be received for an outcome model. The outcome model may be any machine learning model. For example, the fourth indicator indicates a name of an outcome model type for the outcome model that performs prediction such as determining a predicted outcome given a treatment for each observation vector of input dataset 124. The fourth indicator may be received by training application 122 from a user interface window or after entry by a user into a user interface window. A default value for the outcome model type may further be stored, for example, in computer-readable medium 108. As an example, similar to the treatment model type, the outcome model type may be selected from “SVM”, “K-Cluster”, “Neural Network”, “Logistic Regression”, “Forest”, “Gradient Boosting”, “Decision Tree”, “Factorization Machine”, “Deep Neural Network”, etc. The fourth indicator may further indicate one or more hyperparameters to use for training and validating the indicated outcome model type and/or values for an automatic tuning method (autotune option) as well as other training options such an objective function, training stop criteria, etc.
For illustration, the outcome model may be trained to regress y on x(2) and t or {circumflex over (t)} using a DNN such that ŷ={circumflex over (ƒ)}DNN(x(2), t). A default architecture for the DNN architecture may further be stored, for example, in computer-readable medium 108. x(2) may be identical to x(1). IPTW may be used for debiasing.
In an operation 208, a fifth indicator may be received that indicates an estimator function to estimate a statistical parameter such as a potential outcome î from the outcome model. In another illustrative embodiment, the estimator function may be an average over all individuals. For example, the estimator function for the potential outcome
where N is the sample size, xi(2) is the covariates for observation or individual i, and t is the specific treatment value of interest (noting that t is not ti, the observed treatment value that the individual i receives). In another illustrative embodiment, the estimator function may use a finite difference method because the definition of the statistical parameter of interest requires a derivative. For example, the estimator function for the average partial effects (APE) is
where ε is a user-specified small positive value such as 10−8.
In an operation 210, the treatment model defined in operation 204 is trained with a treatment variable value ti and covariate values for the first set of covariates xi(1) read from input dataset 124 for each observation vector i of the N observation vectors to regress t on x(1) to estimate {circumflex over (t)} for each observation vector of the N observation vectors. The training process optimizes the loss function based on the target variable that is the treatment variable t that includes a treatment value for each observation vector. In an illustrative embodiment, a double/debiased machine learning method such as that described in a paper by Victor Chernozhukov, et al. titled Double/Debiased Machine Learning for Treatment and Structural Parameters and published in The Econometrics Journal, volume 21, issue 1 on Feb. 1, 2018 on pages C1-C68 or a sample-split technique may be used. For example, the observation vectors in input dataset 124 may be divided randomly into k folds with an ith fold held out. The remaining (k−1) folds of observation vectors are used to train the treatment model and the ith fold of observation vectors is used to compute the estimated value to get {circumflex over (ƒ)}(i)(.), i=1, . . . , k. All of the k fold estimations become {circumflex over (ƒ)}(.).
In an operation 212, the trained treatment model is executed with the covariate values for the first set of covariates x(1) read from input dataset 124 for each observation vector of the N observation vectors to estimate the treatment variable value {circumflex over (t)} for each observation vector of the N observation vectors.
In an operation 214, a weight value wi is computed for each observation vector of the N observation vectors. Various functions may be used to compute the weight value. For illustration, using IPTW when assuming that the treatment value follows a Gaussian distribution centered around an estimated treatment value,
where v={circumflex over (σ)}2 indicates a variance of the estimated treatment values, and {circumflex over (σ)} indicates a standard deviation of the estimated treatment values computed in operation 212. For example,
The weight values further can be normalized or truncated.
In an operation 216, a selection bias value Sb is computed using a first variance value v1 computed using the treatment variable values ti, i=1, . . . , N and using a second variance value v2 computed using the treatment variable values ti, i=1, . . . , N and the estimated treatment variable values
where
and
The computation is based on the principle that the better the treatment can be predicted, the more selection bias the covariates introduce.
In an operation 218, a standard error parameter value SEP is computed, for example, using
Linear regression may have been used on a log transform of the variables N and Sb to find a convergence rate for the estimator function as β1 log(N)+β2 log(Sb) to determine that ≈−≈0.2 for a DNN. For example, after collecting 95% quantiles of an estimator's distribution from 1500 simulated trials based on five different data generating processes (DGPs) with three different sample size per DGP and 100 trials per sample size, a convergence rate was computed.
In an operation 220, the outcome model defined in operation 206 is trained with the outcome variable value yi and covariate values for the second set of covariates xi(2) read from input dataset 124 for each observation vector i of the N observation vectors to regress y on x(2) and the treatment variable value t for each observation vector of the N observation vectors. Again, in an illustrative embodiment, a similar training method to that described with respect to the treatment model may be used. The loss function may include the weight value wi. The second set of covariates x(2) are the variables input to the outcome model and the estimated outcome ŷ may be computed according to the equation ŷ=ƒ(x(2), t).
In an operation 222, the trained outcome model {circumflex over (ƒ)}( ) is executed with the covariate values for the second set of covariates x(2) read from input dataset 124 for each observation vector of the N observation vectors and the treatment variable value t to estimate the outcome variable y for each observation vector of the N observation vectors. To compute the estimated potential outcome value, ŷi={circumflex over (ƒ)}(x(2), t), i=1, . . . , N is computed by executing the trained outcome model {circumflex over (ƒ)}( ) To compute the estimated APE, the trained outcome model {circumflex over (ƒ)}( ) is executed twice, once to compute ŷi,+={circumflex over (ƒ)}(xi(2), t+ε), i=1, . . . , N and once to compute ŷi,−={circumflex over (ƒ)}(xi(2), t−ε), i=1, . . . , N.
For potential outcome estimation, a grid of treatment variable values is used. For each treatment variable value in the grid of treatment variable values, the trained outcome model {circumflex over (ƒ)}( ) is executed for each observation vector of the N observation vectors with the respective treatment variable grid value. For example, the grid may include 100 different treatment variable values. For illustration, the grid of values may be selected by a user using a minimum value, a maximum value, and an increment value or using a list of values.
In an operation 224, a statistical parameter estimate is computed for each observation vector of the N observation vectors using the estimator function indicated in operation 208. For example, {circumflex over (r)}i=ŷi, i=1, . . . , N when the statistical parameter is the potential outcome. To create a dose-response curve, {circumflex over (r)}i(j)={circumflex over (ƒ)}(xi(2), t(j)), i=1, . . . , N, j=1, . . . . M, where M indicates a number of possible treatment values. In an alternative embodiment, the APE is the statistical parameter and
In an operation 226, a standard error value SE of the estimator is computed using a third variance value computed from the statistical parameter variable values,
where
For example, for the estimator of the potential outcome,
In another example, for the estimator of the APE,
where
to minimize the mean squared error of the estimator {circumflex over (r)}(t). In an alternative embodiment, a confidence interval of the estimator can be computed in addition to or in the alternative to the standard error based on a predefined percent value such as 95% as understood by a person of skill in the art.
In an operation 228, the trained outcome model and/or the trained treatment model are output. For example, the trained outcome model and/or the trained treatment model may be output to trained model description 126. The standard error value SE may further be output to a table, to display 116, etc.
Five different kinds of data generating processes (DGPs) were executed to test training application 122. For each DGP, three sample sizes were generated for N=5,000,10,000, 50,000. For each sample size, 100 trials were simulated. For each trial, the potential outcome was estimated for 100 different treatment values. That is, 150,000=5×3×100×100 potential outcome estimators and their confidence intervals were computed and compared to the true values. A first experiment was based on the same simulation described in section 5.1 of the Colangelo paper:
where
the (i, j)-entry Σij=0.5 for |i−j|=1 and Σij=0 for |i−j|>1 for i, j=1, . . . ,100, and Φ is the cumulative distribution function of N(0,1). Thus, the potential outcome was Y(t)=EX(1.2t+1.2X′θ+t2+tX1)=1.2t+t2.
Referring to
Referring to
Referring to
described in the Colangelo paper to estimate the standard error for the APE. A first APE curve 312 shows the true APE for the selected trial, and a second APE curve 314 shows the estimated APE for the selected trial. Though not visible a confidence interval is shown. The coverage rate for the 95% CI was only 43%.
Referring to
A second experiment was based on:
where x2˜ Ber(0.5), x1˜U(0,1), u˜U(0,1), η˜U(0,1), and Y(t)=EX(25(1−x1)e((a−1)log(t)+(b−1)log(1−t))+0.5).
Referring to
Referring to
A third experiment was based on:
where x2˜Ber(0.5), x1˜U(0,1), u˜U(0,1), η˜U(0,1), and Y(t)=EX(25(1−x1)e((a−1)log(t)+(b−1)log(1−t))+0.5). Only the treatment model changed relative to the second experiment.
Referring to
Referring to
A fourth experiment was based on:
where x2˜Ber(0.5), x1˜U(0,1), u˜U(0,1), η˜U(0,1), and Y(t)=EX(25(1−x1)e((a−1)log(t)+(b−1)log(1−t))+0.5). Only the treatment model changed relative to the second experiment.
Referring to
Referring to
A fifth experiment was based on:
Referring to
Referring to
Table 1 shows the real coverage rate of the 95% confidence intervals in average across the five experiments and the three different sample sizes using the method described in the Colangelo paper (CL) and using training application 122 (TA 122). The coverage rate was 93% using training application 122 and 22% using the method described in the Colangelo paper meaning the standard error computed in operation 226 and its associated 95% confidence interval is trustworthy while the standard error computed using the method described in the Colangelo paper is not trustworthy.
Referring to
Second input interface 802 provides the same or similar functionality as that described with reference to input interface 102 of model training device 100 though referring to prediction device 800. Second output interface 804 provides the same or similar functionality as that described with reference to output interface 104 of model training device 100 though referring to prediction device 800. Second communication interface 806 provides the same or similar functionality as that described with reference to communication interface 106 of model training device 100 though referring to prediction device 800. Data and messages may be transferred between prediction device 800 and a distributed computing system 828 using second communication interface 806. Distributed computing system 130 and distributed computing system 828 may be the same or different computing systems. Second computer-readable medium 808 provides the same or similar functionality as that described with reference to computer-readable medium 108 of model training device 100 though referring to prediction device 800. Second processor 810 provides the same or similar functionality as that described with reference to processor 110 of model training device 100 though referring to prediction device 800.
Prediction application 822 performs operations associated with predicting a treatment value and/or an outcome value for each observation vector included in second dataset 824. The predicted value may be stored in predicted dataset 826 to support various data analysis functions as well as provide alert/messaging related to each predicted value. Some or all of the operations described herein may be embodied in prediction application 822. The operations may be implemented using hardware, firmware, software, or any combination of these methods.
Referring to the example embodiment of
One or more operations of prediction application 822 further may be performed by an ESPE on an event stream instead of reading observation vectors from second dataset 824. Prediction application 822 and training application 122 may be the same or different applications that are integrated in various manners to train the treatment and/or outcome model using input dataset 124 that may be distributed on distributed computing system 130 and to execute the trained treatment and/or outcome model to predict the treatment value or the outcome value for each observation vector included in second dataset 824 that may be distributed on distributed computing system 828.
Prediction application 822 may be implemented as a Web application. Prediction application 822 may be integrated with other system processing tools to automatically process data generated as part of operation of an enterprise, to predict a treatment value or an outcome value, and/or to provide a warning or alert associated with the prediction using second input interface 802, second output interface 804, and/or second communication interface 806 so that appropriate action can be initiated in response. For example, a warning or an alert may be presented using a second display 816, a second speaker 818, a second printer 820, etc. or sent to one or more computer-readable media, display, speaker, printer, etc. of distributed computing system 828.
Input dataset 124 and second dataset 824 may be generated, stored, and accessed using the same or different mechanisms. The treatment variable and the outcome variable are not defined in second dataset 824. Similar to input dataset 124, second dataset 824 may include a plurality of rows and a plurality of columns with the plurality of rows referred to as observations or records, and the columns referred to as variables that are associated with an observation. Second dataset 824 may be transposed.
Similar to input dataset 124, second dataset 824 may be stored on second computer-readable medium 808 or on one or more computer-readable media of distributed computing system 828 and accessed by prediction device 800 using second communication interface 806. Data stored in second dataset 824 may be a sensor measurement or a data communication value, for example, from a sensor 813, may be generated or captured in response to occurrence of an event or a transaction, generated by a device such as in response to an interaction by a user with the device, for example, from a second keyboard 812 or a second mouse 814, etc. The data stored in second dataset 824 may include any type of content represented in any computer-readable format such as binary, alphanumeric, numeric, string, markup language, etc. The content may include textual information, graphical information, image information, audio information, numeric information, etc. that further may be encoded using various encoding techniques as understood by a person of skill in the art. The data stored in second dataset 824 may be captured at different time points periodically, intermittently, when an event occurs, etc. One or more columns may include a time value. Similar to input dataset 124, data stored in second dataset 824 may be generated as part of the IoT, and some or all data may be pre- or post-processed by an ESPE.
Similar to input dataset 124, second dataset 824 may be stored in various compressed formats such as a coordinate format, a compressed sparse column format, a compressed sparse row format, etc. Second dataset 824 further may be stored using various structures as known to those skilled in the art including a file system, a relational database, a system of tables, a structured query language database, etc. on prediction device 800 and/or on distributed computing system 828. Prediction device 800 may coordinate access to second dataset 824 that is distributed across a plurality of computing devices that make up distributed computing system 828. For example, second dataset 824 may be stored in a cube distributed across a grid of computers as understood by a person of skill in the art. As another example, second dataset 824 may be stored in a multi-node Hadoop® cluster. As another example, second dataset 824 may be stored in a cloud of computers and accessed using cloud computing technologies, as understood by a person of skill in the art. The SAS® LASR™ Analytic Server and/or SAS® Viya™ may be used as an analytic platform to enable multiple users to concurrently access data stored in second dataset 824.
Referring to
In an operation 900, a sixth indicator may be received that indicates second dataset 824. For example, the sixth indicator indicates a location and a name of second dataset 824. As an example, the sixth indicator may be received by prediction application 822 after selection from a user interface window or after entry by a user into a user interface window. In an alternative embodiment, second dataset 824 may not be selectable. For example, a most recently created dataset may be used automatically.
In an operation 902, a seventh indicator may be received that indicates trained model description 126. For example, the seventh indicator indicates a location and a name of trained model description 126. As an example, the seventh indicator may be received by prediction application 822 after selection from a user interface window or after entry by a user into a user interface window. In an alternative embodiment, trained model description 126 may not be selectable. For example, most recently created model configuration data may be used automatically. As another example, trained model description 126 may be provided automatically as part of integration with training application 122.
In an operation 904, one or both of the trained treatment model or the trained outcome model description is read from trained model description 126.
In an operation 906, one or both of the trained treatment model or the trained outcome model are instantiated with the model description.
In an operation 908, an observation vector is read from second dataset 824.
In an operation 910, the observation vector is input to the instantiated model.
In an operation 912, a predicted treatment or outcome value for the read observation vector is received as an output of the instantiated model.
In an operation 914, the predicted treatment value may be output, for example, by storing the predicted treatment value with the observation vector to predicted dataset 826. In addition, or in the alternative, the predicted treatment value may be presented on second display 816, printed on second printer 820, sent to another computing device using second communication interface 806, an alarm or other alert signal may be sounded through second speaker 818, etc.
In an operation 916, a determination is made concerning whether or not second dataset 824 includes another observation vector. When second dataset 824 includes another observation vector, processing continues in an operation 918. When second dataset 824 does not include another observation vector, processing continues in an operation 920.
In operation 918, a next observation vector is read from second dataset 824, and processing continues in operation 910.
In operation 920, processing stops and cleanup is performed as needed.
The word “illustrative” is used herein to mean serving as an example, instance, or illustration. Any aspect or design described herein as “illustrative” is not necessarily to be construed as preferred or advantageous over other aspects or designs. Further, for the purposes of this disclosure and unless otherwise specified, “a” or “an” means “one or more”. Still further, using “and” or “or” in the detailed description is intended to include “and/or” unless specifically indicated otherwise. The illustrative embodiments may be implemented as a method, apparatus, or article of manufacture using standard programming and/or engineering techniques to produce software, firmware, hardware, or any combination thereof to control a computer to implement the disclosed embodiments.
The foregoing description of illustrative embodiments of the disclosed subject matter has been presented for purposes of illustration and of description. It is not intended to be exhaustive or to limit the disclosed subject matter to the precise form disclosed, and modifications and variations are possible in light of the above teachings or may be acquired from practice of the disclosed subject matter. The embodiments were chosen and described in order to explain the principles of the disclosed subject matter and as practical applications of the disclosed subject matter to enable one skilled in the art to utilize the disclosed subject matter in various embodiments and with various modifications as suited to the particular use contemplated.
The present application claims the benefit of and priority under 35 U.S.C. § 119(e) to U.S. Provisional Patent Application No. 63/460,015 filed Apr. 17, 2023, the entire contents of which are hereby incorporated by reference.
Number | Date | Country | |
---|---|---|---|
63460015 | Apr 2023 | US |