data:image/s3,"s3://crabby-images/2579b/2579ba898b4b5b3975634dd8d67830f87e5334c7" alt=""
Survival Analysis
Survival analysis is a branch of statistics for analyzing the expected duration of time until one or more events happen, such as death in biological organisms and failure in mechanical systems. This topic is called reliability theory or reliability analysis in engineering, duration analysis or duration modelling in economics, and event history analysis in sociology. Survival analysis attempts to answer questions such as: what is the proportion of a population which will survive past a certain time? Of those that survive, at what rate will they die or fail? Can multiple causes of death or failure be taken into account? How do particular circumstances or characteristics increase or decrease the probability of survival?
Survival analysis involves the modelling of time to event data; in this context, death or failure is considered an "event" in the survival analysis literature – traditionally only a single event occurs for each subject, after which the organism or mechanism is dead or broken.
Let's look at the malignant melonoma survival data from here. Data set contains time, survival time in days, status (1: died from melanoma, 2: alive, 3: dead from other causes), sex (1: male 0: female) and ulcer (1: present, 0: absent). Download the data from here.
Here is the basic code to run a survival analysis:
data:image/s3,"s3://crabby-images/c8df1/c8df151f620aadcbba0a3e3cf580cff6e67e8538" alt=""
TIME statement specifies the time variable and STATUS specifies whether the event is censored or not. We know that only status=1 denotes death from melanoma, 2 and 3 are censored data. Here is the survival plot from the output:
data:image/s3,"s3://crabby-images/f0bd1/f0bd157e0db9ef69c7be3c2a16ef1fca02962d5e" alt=""
data:image/s3,"s3://crabby-images/cec26/cec2622be78c30c2fb4b78e443facd199a62a4ba" alt=""
In order to see confidence bands, we need to specify what type of confidence band we'd like to see. Choices are Hall-Wellner (HW) and Equal Precision (EP)
data:image/s3,"s3://crabby-images/bf13c/bf13cd7e4f3af3280222097c500d807755cda50f" alt=""
data:image/s3,"s3://crabby-images/3d2c9/3d2c9e2f8c722194e62ebb3d62ee9d835bde4a2e" alt=""
To see the effects of sex on survival, we can specify it as a STRATA:
data:image/s3,"s3://crabby-images/addda/adddaf3b984c49b96bf103faa70b77988f74da97" alt=""
data:image/s3,"s3://crabby-images/c5347/c5347e99a653cbf2255fc9cb2bf6ae57d1942c6d" alt=""
As can be seen from the survival plot, females have longer survival times compared to males. But let's also get some test values to comment. We can add TUKEY test to our comparison of males and females. Here's how it's done with the results:
data:image/s3,"s3://crabby-images/43054/430544ed8c51e2d5af1321900195eade93d9ff82" alt=""
data:image/s3,"s3://crabby-images/0ea14/0ea14a5a61dd48388e0f8ee4de7fe0ac0fb9ab64" alt=""
Results are shown for both Logrank and Wilcoxon tests. Both tests have p-values less than 0.05 therefore the effect of gender is significant. Note that Wilocoxon test gives more weight on shorter survival times and the difference of survival between genders at early onset gives raise to more significant p-value to Wilcoxon compared to Log-Rank. Now let's see the effect of ulcer on survival times while adjusting for gender difference.
data:image/s3,"s3://crabby-images/c8791/c87917339c07181c8fd8bec75c43cfbb3cc7a53a" alt=""
data:image/s3,"s3://crabby-images/db7f6/db7f6153d4b6aa5ab8690a37684429837a56912f" alt=""
data:image/s3,"s3://crabby-images/0389a/0389aeccbae6dc350c0ee09ad661dc1626b3150c" alt=""
data:image/s3,"s3://crabby-images/267f2/267f2fdf4131bfb4951099bdd89f826eb11cc2ea" alt=""
Results are highly significant and the effect of ulcer on different gender is evident as compared to gender-only test.
Example: Remission Times for Acute Myelogenous Leukaemia
Description: A clinical trial to evaluate the efficacy of maintenance chemotherapy for acute myelogenous leukaemia was conducted by Embury et al. (1977) at Stanford University. After reaching a stage of remission through treatment by chemotherapy, patients were randomized into two groups. The first group received maintenance chemotherapy and the second group did not. The aim of the study was to see if maintenance chemotherapy increased the length of the remission. The data here formed a preliminary analysis which was conducted in October 1974.
time | cens | group |
9 | 1 | 1 |
13 | 1 | 1 |
13 | 0 | 1 |
18 | 1 | 1 |
23 | 1 | 1 |
28 | 0 | 1 |
31 | 1 | 1 |
34 | 1 | 1 |
45 | 0 | 1 |
48 | 1 | 1 |
161 | 0 | 1 |
5 | 1 | 2 |
5 | 1 | 2 |
8 | 1 | 2 |
8 | 1 | 2 |
12 | 1 | 2 |
16 | 0 | 2 |
23 | 1 | 2 |
27 | 1 | 2 |
30 | 1 | 2 |
33 | 1 | 2 |
43 | 1 | 2 |
45 | 1 | 2 |
time: The length of the complete remission (in weeks).
cens: An indicator of right censoring. 1 indicates that the patient had a relapse and so time is the length of the remission. 0 indicates that the patient had left the study or was still in remission in October 1974, that is the length of remission is right-censored.
group: The group into which the patient was randomized. Group 1 received maintenance chemotherapy, group 2 did not.
Source: https://vincentarelbundock.github.io/Rdatasets/doc/boot/aml.html
Download the data from here
Task: Analyze the dataset wrt survival times of group 1 and 2.
data:image/s3,"s3://crabby-images/d6ffe/d6ffeb3c958fd684ffcd0f7453131ce13678f1a1" alt=""
data:image/s3,"s3://crabby-images/9937b/9937b8ff17c552272e7572ff355acef0ab78153e" alt=""
data:image/s3,"s3://crabby-images/266ba/266badafdf6f2f5f4e07725e215231b00573509c" alt=""
While the survival graph shows some difference between group 1 and 2, neither of the Wilcoxon or Log-Rank tests is significant. Therefore, the difference between the survial times of group 1 and 2 is not statistically significant at the 0.05 level.
Let's also get Log and Log-Log survival plots in addition to Linear survival plot. We can do this by specifying the plots we would like to see in the PROC LIFETEST statement.
data:image/s3,"s3://crabby-images/e5b72/e5b72e4c2b77b17625c65c1904e12fda7da63d5e" alt=""
data:image/s3,"s3://crabby-images/f8b7c/f8b7cc9e2ea0c10fbe457f93bf87b3f036946477" alt=""
Example: Channing House Data
Description: Channing House is a retirement centre in Palo Alto, California. These data were collected between the opening of the house in 1964 until July 1, 1975. In that time 97 men and 365 women passed through the centre. For each of these, their age on entry and also on leaving or death was recorded. A large number of the observations were censored mainly due to the resident being alive on July 1, 1975 when the data was collected. Over the time of the study 130 women and 46 men died at Channing House. Differences between the survival of the sexes, taking age into account, was one of the primary concerns of this study.
sex: A factor for the sex of each resident ("Male" or "Female").
entry: The residents age (in months) on entry to the centre.
exit: The age (in months) of the resident on death, leaving the centre or July 1, 1975 whichever event occurred first.
time: The length of time (in months) that the resident spent at Channing House. (time=exit-entry).
cens: The indicator of right censoring. 1 indicates that the resident died at Channing House, 0 indicates that they left the house prior to July 1, 1975 or that they were still alive and living in the centre at that date.
Source: https://vincentarelbundock.github.io/Rdatasets/doc/boot/channing.html
Download the data from here
Task: Survival analysis along with testing covariates gender and age.
Let's first run our LIFETEST procedure in its simple form and see what our survival graph looks like.
data:image/s3,"s3://crabby-images/43284/43284a9ef9fbc231178d0992e4c03201cb6993ff" alt=""
data:image/s3,"s3://crabby-images/5af47/5af476136154560699630c035dcb9fecd64f608d" alt=""
It looks like our linear survival assumption seems to be valid. Now we can test the effect of gender on survival.
data:image/s3,"s3://crabby-images/4f946/4f946bffc3b3ae623d1a9d5a695695bfbe19ac0f" alt=""
data:image/s3,"s3://crabby-images/37bb1/37bb1e26eaffcd53751e34b629a381c3fd71a9fe" alt=""
data:image/s3,"s3://crabby-images/44abe/44abeca80ec95de925328830fa0b8c6de822bb6f" alt=""
Effect of gender on survival is statistically significant. But what about the age? It may be possible that females survive longer because they are younger when they enter the house.
data:image/s3,"s3://crabby-images/0de4b/0de4b093027de752b0f06d83975ed798adca667f" alt=""
data:image/s3,"s3://crabby-images/bdff2/bdff2469b2204a7d3f50e8c3bc703f9949064f87" alt=""
Effect of age is clearly significant for both genders. Therefore age effect is not favoring one gender over another. We can see this by testing age differences between females and males when they first enter the house. To do this, we can run a t-test with PROC TTEST.
data:image/s3,"s3://crabby-images/3722d/3722dccfb00f8bab9380fa47c4ce360558aab661" alt=""
data:image/s3,"s3://crabby-images/85f60/85f6044f1904ebce9af234b2a37c436d39e041de" alt=""
data:image/s3,"s3://crabby-images/bbc67/bbc679b735ef0edc8f8a0a6d5cccf8cc4b08be92" alt=""
Results show that there is no significant age differences between males and females. The effect of gender on survival times is independent of the age, i.e. females survive longer than males.
Example: Customer Purchase
Description: Garden dataset contains 30,000 customers who were observed over a four year period. Their start time is when they make their first purchase. They are monitored until the end of the four year period.
id_number: Customer ID.
start: Customer's first purchase.
end: Customer's second purchase.
censor: 1 if there is a second purchase, 0 if not.
last_day: End of the study.
time: Number of months between first purchase and second or last day of study, whicever is smaller.
garden: Dollars spent in garden department of first purchase.
decorating: Dollars spent in decorating department of first purchase.
car: Dollars spent in auto department of first purchase.
electrical: Dollars spent in electrical department of first purchase.
safety: Dollars spent in safety department of first purchase.
computer: Dollars spent in computer department of first purchase.
previous_garden: Previous amount spent in garden tools.
previous_decorating: Previous amount spent in decorating tools.
previous_car: Previous amount spent in auto tools.
previous_electrical: Previous amount spent in electrical tools.
previous_safety: Previous amount spent in safety tools.
previous_computer: Previous amount spent in computer tools.
amount_clv: Total amount spent in customer lifetime.
strata: Strata based on total number of orders. A: 1-2 orders between 2011 and 2013, B: 1-2 orders in 2014, C: 3-4 orders, D: 5-10 orders, E: 11-20 orders, F: >21 orders.
account_origin: Channel where the account is originated.
order: Channel where the first purchase is made.
age: Binned age.
credit_score: Binned credit score.
behavior: Binned behavior.
mosaic: Mosaic bureau data.
credicard: Method of payment or credit card brand.
family: Family bureau data.
income: Income bureau data.
Source: Business Survival Analysis Using SAS, J. Ribeiro.
Download the data from here
Task: Design a model to predict the importance of covariates in survival.
The analysis of survival data requires special techniques because the data are almost always incomplete, and familiar parametric assumptions might be unjustifiable. Investigators follow subjects until they reach a prespecified endpoint (for example, death). However, subjects sometimes withdraw from a study, or the study is completed before the endpoint is reached. In these cases, the survival times (also known as failure times) are censored; subjects survived to a certain time beyond which their status is unknown. The uncensored survival times are sometimes referred to as event times. Methods of survival analysis must account for both censored and uncensored data.
Many types of models have been used for survival data. Two of the more popular types of models are the accelerated failure time model and the Cox proportional hazards model. Each has its own assumptions about the underlying distribution of the survival times. Two closely related functions often used to describe the distribution of survival times are the survivor function and the hazard function (see the section Failure Time Distribution for definitions). The accelerated failure time model assumes a parametric form for the effects of the explanatory variables and usually assumes a parametric form for the underlying survivor function. Cox’s proportional hazards model also assumes a parametric form for the effects of the explanatory variables, but it allows an unspecified form for the underlying survivor function.
The PHREG procedure performs regression analysis of survival data based on the Cox proportional hazards model. Cox’s semiparametric model is widely used in the analysis of survival data to explain the effect of explanatory variables on hazard rates.
Here's the code to find which covariates are important for survival, i.e. time.
PROC PHREG DATA=tutorial.garden_sample;
MODEL time*censor(0) = account_origin age amount_clv strata income computer credicard credit_Score decorating electrical family garden mosaic order prev_car prev_computer prev_decorating prev_electrical prev_garden prev_safety safety / SELECTION=STEPWISE;
RUN;
Summary of Stepwise Selection | |||||||
---|---|---|---|---|---|---|---|
Step | Effect | DF | Number In |
Score Chi-Square |
Wald Chi-Square |
Pr > ChiSq | |
Entered | Removed | ||||||
1 | Strata | 5 | 1 | 12052.1093 | <.0001 | ||
2 | Credit_score | 4 | 2 | 273.1409 | <.0001 | ||
3 | Prev_Garden | 1 | 3 | 84.6997 | <.0001 | ||
4 | Order | 2 | 4 | 48.3254 | <.0001 | ||
5 | Account_Origin | 3 | 5 | 74.4897 | <.0001 | ||
6 | Safety | 1 | 6 | 21.5602 | <.0001 | ||
7 | Prev_Decorating | 1 | 7 | 31.6292 | <.0001 | ||
8 | Decorating | 1 | 8 | 11.6206 | 0.0007 | ||
9 | Prev_Car | 1 | 9 | 9.0293 | 0.0027 | ||
10 | Credicard | 5 | 10 | 12.3538 | 0.0302 | ||
11 | Income | 1 | 11 | 4.4819 | 0.0343 | ||
12 | Computer | 1 | 12 | 4.0999 | 0.0429 |
Example: Chemotherapy for Stage B/C colon cancer
Description: These are data from one of the first successful trials of adjuvant chemotherapy for colon cancer. Levamisole is a low-toxicity compound previously used to treat worm infestations in animals; 5-FU is a moderately toxic (as these things go) chemotherapy agent. There are two records per person, one for recurrence and one for death.
id: Patient ID.
study: 1 for all patients.
rx: Treatment - Obs(ervation), Lev(amisole), Lev(amisole)+5-FU.
sex: 1=male, 0=female.
age: Age in years.
obstruct: Obstruction of colon by tumour.
perfor: Perforation of colon.
adhere: Adherence to nearby organs.
nodes: Number of lymph nodes with detectable cancer.
time: Days until event or censoring.
status: Censoring status.
differ: Differentiation of tumour (1=well, 2=moderate, 3=poor).
extent: Extent of local spread (1=submucosa, 2=muscle, 3=serosa, 4=contiguous structures).
surg: Time from surgery to registration (0=short, 1=long).
node4: More than 4 positive lymph nodes.
etype: Event type: 1=recurrence,2=death.
Source: https://vincentarelbundock.github.io/Rdatasets/doc/survival/colon.html
Download the data from here
Task: Design a model to predict the importance of covariates in survival.
Let's first take a look at recurrence with different treatments:
PROC LIFETEST DATA=tutorial.colon PLOTS=HAZARD;
TIME time*status(0);
STRATA rx;
WHERE etype=1;
RUN;
data:image/s3,"s3://crabby-images/97fca/97fcaedcaa865af9c1a3dfb06ce11be23cdec1d6" alt=""
data:image/s3,"s3://crabby-images/5e37a/5e37a4a0d561c56ec39e38218c688bb18c385be0" alt=""
data:image/s3,"s3://crabby-images/785e6/785e6fb5db0943b8e6bdd65c8e2e0294c1ffd8b8" alt=""
Mean survival time is 1474 days, i.e. average time before recurrence occurs is about 4 years. Survival plot shows that rx=Lev+5FU seems effective whereas Lev alone is not effective. Also hazard plot shows that majority of the recurrence occur around 400 days, ~1 year, regardless of the treatment received. After that there is a slightly increased risk around 1400 days, particularly for rx=Obs and rx=Lev. It seems like recurrence would not likely occur if it does not occur within first 4 years.
Now let's analyze the survival till death.
PROC LIFETEST DATA=tutorial.colon PLOTS=HAZARD;
TIME time*status(0);
STRATA rx;
WHERE etype=2;
RUN;
data:image/s3,"s3://crabby-images/17a87/17a87ea28443635f42fb9a506766550f0e9dcf15" alt=""
data:image/s3,"s3://crabby-images/52f4f/52f4f215182793a958b729242de47a35149565a9" alt=""
data:image/s3,"s3://crabby-images/60542/60542d3c77a443a05d9c0e3a291000493071521e" alt=""
Average survival time with Stage B/C colon cancer is around 1793 days, i.e. about 5 years. Again rx=Lev+5FU seems to be effective in survival. The biggest risk for death is around 600 for Lev+5FU and around 800 otherwise. This might be because the patients who are treated with Lev+5FU are already in more serious condition than others. Regardless, hazard rate for patients with Lev+5FU is clearly lower, i.e. these patients are more likely to survive.
Let's now see the effect of gender/rx combination.
PROC LIFETEST DATA=tutorial.colon PLOTS=HAZARD;
TIME time*status(0);
STRATA rx;
WHERE etype=2;
RUN;
data:image/s3,"s3://crabby-images/9156e/9156e2e1cd321f772d662c8e746d51be3309dd8f" alt=""
Interestingly, it seems like Lev+5FU is more effective on male patients. However to understand the effect of covariates we need to use another tool, PHREG:
PROC PHREG DATA=tutorial.colon;
CLASS rx(REF='Obs') differ(REF='1') extent(REF='1') surg(REF='0') sex obstruct perfor adhere;
MODEL time*status(0) = rx|sex obstruct perfor adhere differ extent surg nodes / SELECTION=STEPWISE SLENTRY=0.25 SLSTAY=0.05;
HAZARDRATIO 'H1' nodes / UNITS=1 CL=BOTH;
HAZARDRATIO 'H2' rx / DIFF=REF CL=BOTH;
HAZARDRATIO 'H3' extent / DIFF=REF CL=BOTH;
HAZARDRATIO 'H4' surg / DIFF=REF CL=BOTH;
WHERE etype=2;
RUN;
Results of stepwise selection of covariables are below. Covariables nodes, extent, rx, surg are significant whereas others are not (Note I ran this analysis before that's why I specified HAZARDRATIO for the selected variables only - it would not be apparent at first to you.).
data:image/s3,"s3://crabby-images/62c97/62c976bd9e1175300c17480bfa335fe64f6458ab" alt=""
Let's look at the hazard ratio for nodes below. Hazard ratio results tell us that every additional malignant nodes increases the chance of death by 1.094 times in a given time period. A patient with 4 nodes is 1.094x1.094x1.094 = 1.31 times more likely to die than a patient with only 1 node.
data:image/s3,"s3://crabby-images/d0a22/d0a22b4331c7381bcbe7e64bb771872a2b031a7f" alt=""
Hazard ratios for treatment below shows that Lev alone is not effective (by 95% confidence) because confidence level includes 1. Lev+5FU, on the other hand, is clearly effective.
data:image/s3,"s3://crabby-images/5c13c/5c13c5a9302bc92a3e6edbe32c50f1e53eb9364d" alt=""
You can see below the hazard ratios for extent and surg. Interpretation of the results are similar.
data:image/s3,"s3://crabby-images/0c184/0c1848185af23e05dd83c82b5bc78d2b019edc01" alt=""
While the analysis seemed to reach a conclusion we are still missing a certain piece: what are the chances of survival after the disease is recurred? Our dataset includes time to death which is the time beginning from the first time disease is discovered. Time to death after recurrence is thus td-tr, where td and tr are the time to death and time to recurrence, respectively. Our dataset does not offer this info readily so we have to utilize PROC SQL to reformat our dataset so that we can use it for further analysis.
PROC SQL;
CREATE TABLE colon_new AS
SELECT a.id,
a.rx,
a.sex,
a.age,
a.obstruct,
a.perfor,
a.adhere,
a.nodes,
a.status AS statusd,
b.status AS statusr,
a.differ,
a.extent,
a.surg,
a.node4,
a.time AS timetodeath,
b.time AS timetorec,
a.time-b.time AS timediff
FROM tutorial.colon a JOIN tutorial.colon b ON a.id=b.id
WHERE a.etype = 1 AND b.etype = 1
;
QUIT;
Now we can invoke LIFETEST to get a first glance at our survival:
PROC LIFETEST DATA=colon_new PLOTS=HAZARD;
TIME timediff*statusd(0);
STRATA rx;
RUN;
data:image/s3,"s3://crabby-images/3c953/3c953c1c10d0513a17a2453cbd95eced4c0ff3a6" alt=""
data:image/s3,"s3://crabby-images/efd5d/efd5dbc32dcf81684226d95777e70c4d64e35972" alt=""
We can clearly see that once the recurrence is occured treatment has little effect, if any. It looks like once the disease recur, death is most likely within 700-800 days. Let's try to quantify our effects with PHREG:
PROC PHREG DATA=tutorial.colon;
CLASS rx(REF='Obs') differ(REF='1') extent(REF='1') surg(REF='0') sex obstruct perfor adhere;
MODEL timediff*statusd(0) = rx|sex obstruct perfor adhere differ extent surg nodes / SELECTION=STEPWISE SLENTRY=0.25 SLSTAY=0.05;
HAZARDRATIO 'H1' nodes / UNITS=1 CL=BOTH;
HAZARDRATIO 'H2' rx / DIFF=REF CL=BOTH;
HAZARDRATIO 'H3' sex / DIFF=REF CL=BOTH;
HAZARDRATIO 'H4' age / UNITS=5 CL=BOTH;
RUN;
data:image/s3,"s3://crabby-images/da085/da0856d641d433c725736ff405100bb998eb3602" alt=""
Again the number of nodes is the most important parameter in survival once the disease is recurred. Each additional node increases the odds of death 1.057 times. Effect of treatment seems to be dependent on the gender. Treatment has no effect on women (both Lev and Lev+5FU have confidence limits including 1, middle point). For men, treatment seems to be have a negative effect. However this might be because more serious patients actually receive treatment. Let's see for example whether patients older or with high number nodes received different treatments by ANOVA.
data:image/s3,"s3://crabby-images/f3fd9/f3fd904792abadea3d3ec1e6ac6fa9f2cf244c64" alt=""
data:image/s3,"s3://crabby-images/a1c2b/a1c2b4cf11ec6fd97aff4517dfd2a3cfad765736" alt=""
Looks like the effect is real: treatment has a negative effect once the disease is recurred. Age also has a negative effect on survival: every 5 additional year increases the odds of death by 1.083.
Leave a Comment