I have a function that returns an lm object. I want to produce predicted values based on some new data. The new data is a data.frame in the exact format as the data passed to the lm function, except that the response has been removed (since we’re predicting, not training). I would expect to execute the following, but get an error:
predict( model , newdata )
"Error in eval(expr, envir, enclos) : object 'ModelResponse' not found"
In my case, ModelResponse was the name of the response column in the data I originally trained on. So just for kicks, I tried to insert NA reponse:
newdata$ModelResponse = NA
predict( model , newdata )
Error in terms.default(object, data = data) : no terms component nor attribute
Highly frustrating! R’s notion of models/regression doesn’t match mine: 1. I train a model with some data and get a model object. 2. I can score new data from any environment/function/frame/etc. so long as I input data into the model object that “looks like” the data I trained on (i.e. same column names). This is a standard black-box paradigm.
So here are my questions:
1. What concept(s) am I missing here?
2. How do I get my scenario to work?
3. How can I get model object to be portable? str(model) shows me that the model object saved the original data it trained on! So the model object is massive. I want my model to be portable to any function/environment/etc. and only contain the data it needs to score.
In the absence of str() on either the model or the data offered to the model, here’s my guess regarding this error message:
I guess that you made a model object named “model” and that your outcome variable (the left-hand-side of the formula( in the original call to lm was named “ModelResponse” and that you then named a column in newdata by the same name. But what you should have done was leave out the “ModelResponse” columns (because that is what you are predicting) and put in the “Model_Predictor1″, Model_Predictor2”, etc. … i.e. all the names on the right-hand-side of the formula given to lm()
The coef() function will allow you to extract the information needed to make the model portable.
Since you expressed interest in the rms/Hmisc package combo
Function, here it is using the help-example from ols and comparing the output with an extracted function and the rmsPredictmethod. Note the capitals, since these are designed to work with the package equivalents oflmandglm(..., family="binomial")andcoxph, which in rms becomeols,lrm, andcph.(I have learned through experience that the restricted cubic-spline fit functions coming from rms need to have spaces and carriage returns added to improve readability. )